Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/robohouse-delft/dynamixel2-rs
Rust implementation of the dynamixel protocol 2.0
https://github.com/robohouse-delft/dynamixel2-rs
dynamixel hacktoberfest robotics rust servo-motor
Last synced: 3 months ago
JSON representation
Rust implementation of the dynamixel protocol 2.0
- Host: GitHub
- URL: https://github.com/robohouse-delft/dynamixel2-rs
- Owner: robohouse-delft
- License: bsd-2-clause
- Created: 2020-06-15T20:22:19.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-04-10T13:30:51.000Z (10 months ago)
- Last Synced: 2024-04-10T15:29:39.817Z (10 months ago)
- Topics: dynamixel, hacktoberfest, robotics, rust, servo-motor
- Language: Rust
- Homepage:
- Size: 190 KB
- Stars: 9
- Watchers: 4
- Forks: 3
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG
- License: LICENSE.md
Awesome Lists containing this project
README
# dynamixel2 [![docs][docs-badge]][docs] [![tests][tests-badge]][tests]
[docs]: https://docs.rs/dynamixel2/
[tests]: https://github.com/robohouse-delft/dynamixel2-rs/actions?query=workflow%3Atests
[docs-badge]: https://docs.rs/dynamixel2/badge.svg
[tests-badge]: https://github.com/robohouse-delft/dynamixel2-rs/workflows/tests/badge.svgAn implementation of the [Dynamixel Protocol 2.0].
[Dynamixel Protocol 2.0]: https://emanual.robotis.com/docs/en/dxl/protocol2/
This library aims to provide a easy to use but low level implementation of the Dynamixel Protocol 2.0.
That means it allows you to execute arbitrary commands with arbitrary parameters.The library does not aim to provide an easy interface to the higher level functions of a servo motor,
such as moving it to a specific angle or at a specific speed.
Instead, you will have to write the appropriate values to the correct registers yourself.The main interface is the [`Bus`] struct, which represents the serial communication bus.
The [`Bus`] struct exposes functions for all supported instructions such as [`Bus::ping`], [`Bus::read`], [`Bus::write`] and much more.
Additionally, you can also transmit raw commands using [`Bus::write_instruction`] and [`Bus::read_status_response`], or [`Bus::transfer_single`].The library currently implements all instructions except for the Control Table Backup, Fast Sync Read and Fast Sync Write instructions.
## Optional features
You can enable the `log` feature to have the library use `log::trace!()` to log all sent instructions and received replies.
[`Bus`]: https://docs.rs/dynamixel2/latest/dynamixel2/struct.Bus.html
[`Bus::ping`]: https://docs.rs/dynamixel2/latest/dynamixel2/struct.Bus.html#method.ping
[`Bus::read`]: https://docs.rs/dynamixel2/latest/dynamixel2/struct.Bus.html#method.read
[`Bus::write`]: https://docs.rs/dynamixel2/latest/dynamixel2/struct.Bus.html#method.write
[`Bus::write_instruction`]: https://docs.rs/dynamixel2/latest/dynamixel2/struct.Bus.html#method.write_instruction
[`Bus::read_status_response`]: https://docs.rs/dynamixel2/latest/dynamixel2/struct.Bus.html#method.read_status_response
[`Bus::transfer_single`]: https://docs.rs/dynamixel2/latest/dynamixel2/struct.Bus.html#method.transfer_single