These tools provide functionality for interacting with ODrive devices via a CAN bus, including device discovery, configuration, and demonstration actions such as setting positions or running predefined movements.
- Requires Python 3.6 or newer.
- Dependencies:
python-can
. Install withpip install python-can
.
- calibrate.py: Runs ODrive calibration sequence on each detected ODrive, one at a time.
- clear_errors.py: Clears all errors on detected ODrive devices.
- setup.py: Configures ODrive devices based on settings specified in
config.py
. - test_console.py: Slider tUI, controls position for all ODrvies.
tools/
├── README.md
├── calibrate.py
├── clear_errors.py
├── setup.py
├── test_console.py
├── data
│ ├── config.py - Configuration settings for ODrive devices.
│ └── flat_endpoints.json - Detailed list of ODrive firmware endpoints.
└── src
├── can_utils.py - Utility functions for CAN communication.
├── configure.py - Applies configurations to ODrive devices.
├── control.py - Interfaces for control actions on ODrive devices.
└── metrics.py - Polls a variety of ODrive metrics.
- config.py: Contains user-defined settings for ODrive devices, such as motor parameters and control modes.
- Ensure this file is properly edited to match your hardware setup before running
setup.py
.
- Configuring ODrives: Run
python setup.py
to apply settings fromconfig.py
to connected ODrive devices. - Clearing Errors: Execute
python clear_errors.py
to clear any errors from ODrive devices, ensuring they are ready for operation. - Demonstration Scripts: Run
python test_console.py
to demonstrate various capabilities of the ODrive motors and display live metrics.
Scripts are equipped with basic error handling for common issues such as missing configuration keys or communication failures, ensuring smooth operation during setup and demonstrations.