Servo Control Tuning Tool for Real and Simulated Actuators. Utilizes Kscale KOS and KOS-SIM
Project description
ktune
ktune is a servo control tuning utility for matching real2sim. It utilizes Kscales kos and kos-sim.
# ktune - Actuator Sim2Real Tuning Utility
**ktune** is a command line tool for running simple actuator tests (sine, step, and chirp) on both simulation and real robot systems. It is designed to help you tune actuator parameters, collect performance data, and compare responses between simulation and hardware.
## Features
- **Sine Test:** Command an actuator with a sine wave and log both commanded and measured positions/velocities.
- **Step Test:** Perform step changes to evaluate actuator response, including overshoot analysis.
- **Chirp Test:** Execute a chirp waveform to test actuator dynamics over a frequency sweep.
- **Sim2Real Comparison:** Run tests concurrently on a simulator and a real robot, then plot and compare the results.
- **Servo Configuration:** Easily enable or disable additional servos on the real robot via command line options.
## Installation
```
pip install ktune
```
*Note:* Ensure that the `pykos` library is installed and correctly configured for your setup.
## Usage
The `ktune.py` script can run in different test modes. Use the `--help` flag for full details on available options.
### Running a Sine Test
Run a sine wave test on actuator 11 with a frequency of 1.0 Hz, amplitude of 5.0°, and duration of 5 seconds:
```bash
./ktune.py --actuator-id 11 --test sine --freq 1.0 --amp 5.0 --duration 5.0
Running a Step Test
Perform a step test with a step size of 10° and a hold time of 3 seconds per step, running for 2 cycles:
./ktune.py --actuator-id 11 --test step --step-size 10.0 --step-hold-time 3.0 --step-count 2
Running a Chirp Test
Execute a chirp test with an amplitude of 5.0°, initial frequency of 1.0 Hz, sweep rate of 0.5 Hz/s, and duration of 5 seconds:
./ktune.py --actuator-id 11 --test chirp --chirp-amp 5.0 --chirp-init-freq 1.0 --chirp-sweep-rate 0.5 --chirp-duration 5.0
Configuring Additional Servos
Enable or disable additional servos on the real robot:
# Enable servos with IDs 11, 12, and 13:
./ktune.py --enable-servos 11,12,13
# Disable servos with IDs 31, 32, and 33:
./ktune.py --disable-servos 31,32,33
Command Line Options
Below is a summary of the key command line arguments:
-
General Settings:
--sim_ip: Simulator KOS-SIM IP address (default:127.0.0.1)--ip: Real robot KOS IP address (default:192.168.42.1)--actuator-id: Actuator ID to test (default:11)--test: Test type to run (sine,step,chirp)
-
Sine Test Parameters:
--freq: Sine wave frequency (Hz)--amp: Sine wave amplitude (degrees)--duration: Test duration (seconds)
-
Step Test Parameters:
--step-size: Step size (degrees)--step-hold-time: Time to hold at each step (seconds)--step-count: Number of step cycles
-
Chirp Test Parameters:
--chirp-amp: Chirp amplitude (degrees)--chirp-init-freq: Chirp initial frequency (Hz)--chirp-sweep-rate: Chirp sweep rate (Hz/s)--chirp-duration: Chirp test duration (seconds)
-
Actuator Configuration:
--kp,--kd,--ki: Gains for real actuator control--sim-kp,--sim-kv: Gains for simulation--acceleration: Actuator acceleration (deg/s²)--max-torque: Maximum torque limit--torque-off: Disable actuator torque if specified
-
Data Logging and Plotting:
--no-log: Disable data logging and plotting--log-duration-pad: Additional logging duration after motion ends (seconds)--sample-rate: Data collection rate (Hz)
-
Servo Enable/Disable:
--enable-servos: Comma-separated list of servo IDs to enable on the real robot--disable-servos: Comma-separated list of servo IDs to disable on the real robot
Data Logging and Plotting
By default, ktune logs both command and response data for the actuators and generates comparison plots between simulation and real robot performance. Plots are saved to the plots/ directory with a timestamp in the filename. Use the --no-log flag to disable data logging and plotting if not needed.
License
This project is licensed under the MIT License.
Contributing
Contributions, issues, and feature requests are welcome! Feel free to open an issue or submit a pull request.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ktune-0.1.1.tar.gz.
File metadata
- Download URL: ktune-0.1.1.tar.gz
- Upload date:
- Size: 13.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cf1761ffccb4744f1ffc527078dbca528068cfcbb83e1a6e558073d65014f192
|
|
| MD5 |
fd38497ee38989f9ecb4b4a21af6e5dd
|
|
| BLAKE2b-256 |
04f00ad03a9c82c2fa9444fab74c1b7d523b54ffcbd75ad0697f8e5eb142b979
|
File details
Details for the file ktune-0.1.1-py3-none-any.whl.
File metadata
- Download URL: ktune-0.1.1-py3-none-any.whl
- Upload date:
- Size: 11.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4b662ef2b291fa2288dbe65d5867aaa7c09c590615c1d973971013c01a7d6fb3
|
|
| MD5 |
2c38f62c4bbd4ebc0f7442e2969bb531
|
|
| BLAKE2b-256 |
e7d062aebe0d73d09b38c2867cffb68bd6e33dab964bd651f18ff2f906b7bea3
|