dynamixel_hardware_interface package from dynamixel_hardware_interface repodynamixel_hardware_interface |
|
Package Summary
Tags | No category tags. |
Version | 1.0.0 |
License | Apache 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/ROBOTIS-GIT/dynamixel_hardware_interface.git |
VCS Type | git |
VCS Version | humble |
Last Updated | 2024-12-11 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Pyo
Authors
- Hye-Jong KIM
- Sungho Woo
Dynamixel Hardware Interface User Guide
1. Introduction
ROS 2 package providing a hardware interface for controlling Dynamixel motors via the ros2_control framework. This repository includes the dynamixel_hardware_interface plugin for seamless integration with ROS 2 control, along with the dynamixel_interfaces package containing custom message definitions used by the interface
2. Prerequisites
This package currently supports ROS 2 Humble only. Ensure that ROS 2 Humble is properly installed (ROS 2 Humble installation guide).
-
Dynamixel SDK:
- Install the Dynamixel SDK using the following command:
sudo apt install ros-humble-dynamixel-sdk
-
Hardware Requirements:
- Dynamixel servos
- USB2 Dynamixel or U2D2 adapter
- Proper power supply for Dynamixel motors
3. Installation
- Clone the repository into your ROS workspace:
cd ~/${WORKSPACE}/src
git clone -b humble https://github.com/ROBOTIS-GIT/dynamixel_hardware_interface.git
git clone -b humble https://github.com/ROBOTIS-GIT/dynamixel_interfaces.git
- Build the package:
cd ~/${WORKSPACE}
colcon build
- Source your workspace:
source ~/${WORKSPACE}/install/setup.bash
4. Currently Used Packages
This project integrates with the following ROS 2 packages to provide extended functionality:
-
open_manipulator_x A ROS-based open-source software package designed for the Open Manipulator-X, a 4-DOF robotic arm. It provides essential features like motion planning, kinematics, and control utilities for seamless integration with ROS 2 environments.
-
open_manipulator_y A ROS-based package tailored for the Open Manipulator-Y, a 6-DOF robotic arm. This package offers enhanced compatibility and extended functionalities for advanced manipulator control and operations.
5. Configuration
To effectively use the Dynamixel Hardware Interface in a ROS 2 control system, you need to configure specific parameters in your ros2_control
hardware description file. Below is a concise explanation of the key parameters, illustrated with examples from the OpenManipulator-X ROS 2 control.xacro file.
- Port Settings: Define serial port and baud rate for communication.
- Hardware Setup: Configure joints and transmissions.
- Joints: Control and monitor robot joints.
- GPIO: Define and control Dynamixel motors.
1. Port and Communication Settings
These parameters define how the interface communicates with the Dynamixel motors:
-
port_name
: Serial port for communication. -
baud_rate
: Communication baud rate. -
error_timeout_sec
: Timeout for communication errors.
2. Hardware Configuration
These parameters define the hardware setup:
-
number_of_joints
: Total number of joints. -
number_of_transmissions
: Number of transmissions. -
Transmission Matrices: Define joint-to-transmission mappings.
3. Joint Configuration
Joints define the control and state interfaces for robot movement:
Key Attributes
-
name
: Unique joint name. Example:${prefix}joint1
Sub-Elements
-
<command_interface>
: Sends commands to joints.
<command_interface name="position">
-
<state_interface>
: Monitors joint state data.
<state_interface name="position"/>
<state_interface name="velocity"/>
<state_interface name="effort"/>
4. GPIO Configuration
The GPIO tag is used to define the configuration of Dynamixel motors in a robotics system. It serves as a declarative structure to set up motor-specific parameters, command interfaces, and state monitoring capabilities. This allows seamless integration of Dynamixel hardware with software frameworks.
Key Attributes
-
name
: A unique identifier for the motor configuration (e.g.,dxl1
). -
ID
: The unique ID assigned to the motor in the Dynamixel network (e.g.,11
).
Sub-Elements
-
<param>
: Specifies motor-specific settings. These parameters correspond to the properties of the Dynamixel motor, such as its type, control mode, or PID gain values.
<param name="type">dxl</param>
-
<command_interface>
: Defines the control commands that can be sent to the motor. For example, setting the desired goal position.
<command_interface name="Goal Position"/>
-
<state_interface>
: Specifies the state feedback interfaces to monitor real-time motor data, such as position, velocity, and current.
<state_interface name="Present Position"/>
<state_interface name="Present Velocity"/>
<state_interface name="Present Current"/>
Example GPIO Configuration
Below is an example of a fully defined GPIO configuration for a Dynamixel motor. This example demonstrates how to configure a motor with ID 11
, define command interfaces, monitor state data, and set additional parameters such as PID gains and drive mode.
<gpio name="dxl1">
<param name="type">dxl</param>
<param name="ID">11</param>
<command_interface name="Goal Position"/>
<state_interface name="Present Position"/>
<state_interface name="Present Velocity"/>
<state_interface name="Present Current"/>
<param name="Position P Gain">800</param> <!-- Proportional gain for position control -->
<param name="Position I Gain">100</param> <!-- Integral gain for position control -->
<param name="Position D Gain">100</param> <!-- Derivative gain for position control -->
<param name="Drive Mode">0</param> <!-- 0: Clockwise, 1: Counterclockwise -->
</gpio>
Dynamixel Control Table Reference
The Dynamixel hardware interface uses control tables, defined in model-specific files such as xm430_w350.model
, to configure and interact with the motor’s internal settings. These control tables map hardware parameters to specific memory addresses and data types, enabling fine-grained control and monitoring.
Example from xm430_w350.model
:
[Control Table]
Address Size Data Name
0 2 Model Number
2 4 Model Information
6 1 Firmware Version
7 1 ID
...
Usage
- The control table specifies the internal memory layout of the Dynamixel motor.
- For instance, you can set the motor ID at address
7
, or configure firmware-specific options at address6
.
These settings can be defined within the GPIO configuration or dynamically updated through commands based on the control table schema.
This professional explanation highlights the flexibility and precision of the Dynamixel hardware interface, empowering developers to fully utilize their motor’s capabilities within a structured framework. For further details, refer to the official Dynamixel e-Manual.
6. Usage
Ensure the parameters are configured correctly in your ros2_control
YAML file or XML launch file.
- Example Parameter Configuration
<ros2_control>
<param name="dynamixel_state_pub_msg_name">dynamixel_hardware_interface/dxl_state</param>
<param name="get_dynamixel_data_srv_name">dynamixel_hardware_interface/get_dxl_data</param>
<param name="set_dynamixel_data_srv_name">dynamixel_hardware_interface/set_dxl_data</param>
<param name="reboot_dxl_srv_name">dynamixel_hardware_interface/reboot_dxl</param>
<param name="set_dxl_torque_srv_name">dynamixel_hardware_interface/set_dxl_torque</param>
</ros2_control>
Topic and Service Descriptions
1. dynamixel_state_pub_msg_name
-
Description: Defines the topic name for publishing the Dynamixel state.
-
Default Value:
dynamixel_hardware_interface/dxl_state
2. get_dynamixel_data_srv_name
-
Description: Specifies the service name for retrieving Dynamixel data.
-
Default Value:
dynamixel_hardware_interface/get_dxl_data
3. set_dynamixel_data_srv_name
-
Description: Specifies the service name for setting Dynamixel data.
-
Default Value:
dynamixel_hardware_interface/set_dxl_data
4. reboot_dxl_srv_name
-
Description: Specifies the service name for rebooting Dynamixel motors.
-
Default Value:
dynamixel_hardware_interface/reboot_dxl
5. set_dxl_torque_srv_name
-
Description: Specifies the service name for enabling or disabling torque on Dynamixel motors.
-
Default Value:
dynamixel_hardware_interface/set_dxl_torque
7. Contributing
We welcome contributions! Please follow the guidelines in CONTRIBUTING.md to submit issues or pull requests.
8. License
This project is licensed under the MIT License. See the LICENSE file for details.
Changelog for package dynamixel_hardware_interface
1.0.0 (2024-12-04)
- First release of dynamixel_hardware_interface package
- Contributors: Hye-Jong Kim, Sungho Woo
Wiki Tutorials
Package Dependencies
Deps | Name |
---|---|
ament_cmake | |
ament_lint_auto | |
ament_lint_common | |
rclcpp | |
hardware_interface | |
pluginlib | |
realtime_tools | |
dynamixel_sdk | |
std_srvs | |
dynamixel_interfaces |
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged dynamixel_hardware_interface at Robotics Stack Exchange
dynamixel_hardware_interface package from dynamixel_hardware_interface repodynamixel_hardware_interface |
|
Package Summary
Tags | No category tags. |
Version | 0.0.3 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/OUXT-Polaris/dynamixel_hardware_interface.git |
VCS Type | git |
VCS Version | master |
Last Updated | 2023-12-07 |
Dev Status | DEVELOPED |
CI status | No Continuous Integration |
Released | RELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- masaya
Authors
Changelog for package dynamixel_hardware_interface
0.0.3 (2021-06-16)
- Merge pull request #12 from OUXT-Polaris/fix/depends add boost to the depends
- add boost to the depends
- Contributors: Masaya Kataoka
0.0.1 (2021-06-13)
- add realtime_tools to the depends
- enable publish diag topic
- add interface
- enable parse params
- add diagnostic updator
- fix plugin setting
- modifu cmakelist
- modify configuration
- add implementation of each function
- add class definition
- add source
- Merge pull request #9 from OUXT-Polaris/feature/tempelature_interface Feature/tempelature interface
- add tempelature interface
- enable update temperature
- remove unused lines
- move some function
- Merge pull request #8 from OUXT-Polaris/feature/velocity_interface Feature/velocity interface
- apply reformat
- modify controller
- add interfaces
- apply reformat
- add exception
- Merge pull request #7 from OUXT-Polaris/doc/readme add dos
- add dos
- Merge pull request #6 from OUXT-Polaris/feature/publish_joint_angle Feature/publish joint angle
- Merge branch 'master' of https://github.com/OUXT-Polaris/dynamixel_hardware_interface into feature/publish_joint_angle
- enable return toruqeEnable result
- Merge pull request #5 from OUXT-Polaris/fix/document_generator_python_version update python version
- update python version
- Merge pull request #4 from OUXT-Polaris/feature/wx540-t260 enable run torque enable while configure
- apply reformat
- enable run torque enable while configure
- Merge pull request #3 from OUXT-Polaris/feature/wx540-t260 Feature/wx540 t260
- apply reformat
- enable update goal position
- update function order
- update radianToPOsition functions
- apply reformat
- enable override function
- fix byte size
- add PacketByteSize field
- add address class
- enable get position from dynamixel
- add error message
- Merge pull request #2 from OUXT-Polaris/feature/document_generation Feature/document generation
- update documentation
- add description to the header file
- change directory
- apply reformat
- add coments
- update workflow
- update workfloe
- update workflow
- add workflow
- add new workflow
- Merge pull request #1 from OUXT-Polaris/workflow/foxy update CI workflow for foxy
- applu reformat
- Merge branch 'master' of https://github.com/OUXT-Polaris/dynamixel_hardware_interface into workflow/foxy
- use clang-format
- add licence file
- update .github/workflows/ROS2-Foxy.yaml
- update dependency.repos
- chenge methods as virtual
- add new rviz
- rename launch
- enable update joint states
- add dummy mode
- remove unused urdf
- implement read function
- apply reformat
- apply reformat
- apply reformat
- comment out controllers
- configure interface
- rename morter
- add launch files
- enable error output
- apply reformat
- rename function
- enable get command interfaces
- add updateJointPosition function
- implement export_state_interface function
- add setGoalPosition function
- enable torque
- enable construct motor instance
- add include gurad
- update .gitignore
- add interface class
- initial commit
- Contributors: Masaya Kataoka, robotx_buildfarm
Wiki Tutorials
Package Dependencies
System Dependencies
Name |
---|
boost |
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged dynamixel_hardware_interface at Robotics Stack Exchange
dynamixel_hardware_interface package from dynamixel_motor_experimental repodynamixel_hardware_interface gearbox |
|
Package Summary
Tags | No category tags. |
Version | UNKNOWN |
License | BSD |
Build type | ROSBUILD |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/arebgun/dynamixel_motor_experimental.git |
VCS Type | git |
VCS Version | master |
Last Updated | 2013-09-11 |
Dev Status | UNMAINTAINED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
Authors
- Antons Rebguns
Wiki Tutorials
Package Dependencies
Deps | Name |
---|---|
roscpp | |
pluginlib | |
actionlib | |
gearbox | |
control_msgs | |
trajectory_msgs | |
diagnostic_msgs | |
diagnostic_updater | |
std_srvs |