Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ubiquityrobotics/ubiquity_motor
Package that provides a ROS interface for the motors in UbiquityRobotics robots
https://github.com/ubiquityrobotics/ubiquity_motor
magni ros
Last synced: about 1 month ago
JSON representation
Package that provides a ROS interface for the motors in UbiquityRobotics robots
- Host: GitHub
- URL: https://github.com/ubiquityrobotics/ubiquity_motor
- Owner: UbiquityRobotics
- License: bsd-3-clause
- Created: 2015-02-15T05:15:03.000Z (almost 10 years ago)
- Default Branch: noetic-devel
- Last Pushed: 2023-11-16T09:58:40.000Z (about 1 year ago)
- Last Synced: 2024-10-30T22:44:09.642Z (2 months ago)
- Topics: magni, ros
- Language: C++
- Size: 2.02 MB
- Stars: 25
- Watchers: 13
- Forks: 24
- Open Issues: 28
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.rst
- License: LICENSE
Awesome Lists containing this project
README
# ubiquity_motor
[![Build Status](https://travis-ci.org/UbiquityRobotics/ubiquity_motor.svg?branch=indigo-devel)](https://travis-ci.org/UbiquityRobotics/ubiquity_motor)## Introduction
This is a Package that provides a ROS interface for the motors in UbiquityRobotics robots. It communicates with the motor controller via a serial port.
## Installation
This package may be installed from binaries for both x86 and ARM architectures.
The package may be installed with:
`sudo apt-get install ros-kinetic-ubiquity-motor`
Configuration launch files for the _Magni_ robot are in the package [magni_robot](https://github.com/UbiquityRobotics/magni_robot).
## ROS API
### Subscribed topics
`cmd_vel` [geometry_msgs/Twist](http://docs.ros.org/api/geometry_msgs/html/msg/Twist.html)
The command input.`system_control` [std_msgs/String](http://docs.ros.org/api/std_msgs/html/msg/Sring.html)
A channel to command the motor node to change mode of operation.
A text string with a commnad followed by parameter such as `enable` or `disable` are used.motor_control disable Stops the MCB control over serial (used for firmware load)
motor_control enable Re-attaches the MCB control over serial for normal operationspeed_control disable Stops the robot so no speed control is used for collision avoiance
speed_control enable Re-enables the motor node to respond to cmd_vel speed messages
### Published topics
`odom` [nav_msgs/Odometry](http://docs.ros.org/api/nav_msgs/html/msg/Odometry.html)
Odometry computed from motor controller messages.`/tf` [tf/tfMessage](http://docs.ros.org/api/tf/html/msg/tfMessage.html)
The transform from `odom` to `base_link``firmware_version` [std_msgs/String](https://docs.ros.org/en/jade/api/std_msgs/html/msg/String.html)
Version of motor control board (MCB) firmware formatted as "vXX YYYYMMDD" or just "vXX" if there's no daycode found.`battery_state` [sensor_msgs/BatteryState](http://docs.ros.org/jade/api/sensor_msgs/html/msg/BatteryState.html)
Charge state of the robot's batteries.`publish_cmd` [geometry_msgs/TwistStamped](http://docs.ros.org/api/geometry_msgs/html/msg/TwistStamped.html)
The value of `cmd_vel` after limits were applied. Available if the `publish_cmd` paramater is set.`motor_power_active` [std_msgs/Bool](http://docs.ros.org/api/std_msgs/html/msg/Bool.html)
The state of motor power being active is published. This follows the ESTOP switch within about a half second.`motor_state` ubiquity_motor::MotorState
The combined motor state for both wheels with positions, rotate rates, currents, pwm drive values`left_error` [std_msgs/Int32](http://docs.ros.org/api/std_msgs/html/msg/Int32.html)
The error in expected left wheel position relative to current left wheel position is published for diagnostics purposes.`right_error` [std_msgs/Int32](http://docs.ros.org/api/std_msgs/html/msg/Int32.html)
The error in expected right wheel position relative to current right wheel position is published for diagnostics purposes.`left_current` [std_msgs/Int32](http://docs.ros.org/api/std_msgs/html/msg/Float32.html)
The motor current in amps that the left motor is running at at this time`right_current` [std_msgs/Int32](http://docs.ros.org/api/std_msgs/html/msg/Float32.html)
The motor current in amps that the right motor is running at at this time`left_tick_interval` [std_msgs/Int32](http://docs.ros.org/api/std_msgs/html/msg/Int32.html)
A value that is proportional to the time between left wheel encoder ticks for usage in diagnostics. This unsigned value is only published when velocity is non zero.`right_tick_interval` [std_msgs/Int32](http://docs.ros.org/api/std_msgs/html/msg/Int32.html)
A value that is proportional to the time between right wheel encoder ticks for usage in diagnostics. This unsigned value is only published when velocity is non zero.### Parameters
#### Comms paramaters
`serial_port` (string, default: "/dev/ttyS0")
Name of device with which to communicate with motor controller hardware.`baud_rate` (int, default: 9600)
Baud rate for serial communication with motor controller hardware.#### Firmware parameters
`pid_proportional` (int, default: 5000)
The `P` paramater for the motor controller's `PID` controller.`pid_integral` (int, default: 10)
The `I` paramater for the motor controller's `PID` controller.`pid_derivative` (int, default: 1)
The `D` paramater for the motor controller's `PID` controller.`pid_denominator` (int, default: 1000)
Divisor for the above `PID` paramaters.`pid_moving_buffer_size` (int, default: 10)
Size of a moving buffer used in the control loop.`pid_control` (int, default: 0)
This word enables non-standard modes for motor control in the firmware. Consult factory for guidance in usage of this parameter.`drive_type` (string, default: "standard")
This modifies turning and some other motor control parameters if not set to 'standard'. This parameter is set to '4wd' on some custom systems but those require dual MCB controllers and are far more complex systems so do not change this unless instructed to do so by the factory. This setting is only of value for MCB firmware of version v41 or later.`wheel_type` (string, default: "standard")
This is used to change the type of wheel and encoder combination in use. The origional Magni up into 2021 was only one wheel type which we call 'standard' here. This wheel had a chrome hubcap. In 2021 we started some custom development for a wheel that would set this parameter to 'thin' as the wheel was thinner but also had different drive characteristics. This setting is only of value for MCB firmware of version v41 or later.`wheel_gear_ratio` (float, default: 4.294)
We are looking into different ratios for the gearing internal to the wheel hub. This ratio impacts the wheel control logic as it is in effect a ratio between the wheel encoders and the wheel itself on the ground. The only other value of use as of late 2021 here is '5.17' which is not released at this time.`fw_max_pwm` (int, default: 350)
This is a safety cap on the max value we will drive our low level motor control hardware. Do not change this unless instructed to do so by the factory. Prior to late 2021 this was defaulted to 250 internally in the firmware.`deadman_timer` (int, default: 2400000)
If a message is not received after this interval (in MCU clock ticks), the motor controller should assume an error condition and stop.`battery_voltage_multiplier` (float, default: 0.5185)
Used to calculate battery voltage from motor controller messages.`battery_voltage_offset` (float, default: 0.40948)
Used to calculate battery voltage from motor controller messages.#### Node parameters
`controller_loop_rate` (double, default: 20.0)
Rate (in Hz) at which to send commands to the motor controller hardware.#### diff_drive_controller paramaters
`left_wheel` (string | string[...])
Left wheel joint name or list of joint names.`right_wheel` (string | string[...])
Right wheel joint name or list of joint names.`pose_covariance_diagonal` (double[6])
Diagonal of the covariance matrix for odometry pose publishing.`twist_covariance_diagonal` (double[6])
Diagonal of the covariance matrix for odometry twist publishing.`publish_rate` (double, default: 50.0)
Frequency (in Hz) at which the odometry is published. Used for both tf and odom.`wheel_separation_multiplier` (double, default: 1.0)
Multiplier applied to the wheel separation parameter. This is used to account for a difference between the robot model and a real robot.`wheel_radius_multiplier` (double, default: 1.0)
Multiplier applied to the wheel radius parameter. This is used to account for a difference between the robot model and a real robot.`cmd_vel_timeout` (double, default: 0.5)
Allowed period (in seconds) allowed between two successive velocity commands. After this delay, a zero speed command will be sent to the wheels.`base_frame_id` (string, default: base_link)
Base frame_id, which is used to fill in the child_frame_id of the Odometry messages and TF.`linear/x/has_velocity_limits` (bool, default: false)
Whether the controller should limit linear speed.`linear/x/max_velocity` (double)
Maximum linear velocity (in m/s).`linear/x/min_velocity` (double)
Minimum linear velocity (in m/s). Setting this to 0.0 will disable backwards motion. When unspecified, -max_velocity is used.`linear/x/has_acceleration_limits` (bool, default: false)
Whether the controller should limit linear acceleration.`linear/x/max_acceleration` (double)
Maximum linear acceleration (in m/s^2).`linear/x/min_acceleration` (double)
Minimum linear acceleration (in m/s^2). When unspecified, -max_acceleration is used.`linear/x/has_jerk_limits` (bool, default: false)
Whether the controller should limit linear jerk.`linear/x/max_jerk` (double)
Maximum linear jerk (in m/s^3).`angular/z/has_velocity_limits` (bool, default: false)
Whether the controller should limit angular velocity.`angular/z/max_velocity` (double)
Maximum angular velocity (in rad/s).`angular/z/min_velocity` (double)
Minimum angular velocity (in rad/s). Setting this to 0.0 will disable counter-clockwise rotation. When unspecified, -max_velocity is used.`angular/z/has_acceleration_limits` (bool, default: false)
Whether the controller should limit angular acceleration.`angular/z/max_acceleration` (double)
Maximum angular acceleration (in rad/s^2).`angular/z/min_acceleration` (double)
Minimum angular acceleration (in rad/s^2). When unspecified, -max_acceleration is used.`angular/z/has_jerk_limits` (bool, default: false)
Whether the controller should limit angular jerk.`angular/z/max_jerk` (double)
Maximum angular jerk (in m/s^3).`enable_odom_tf` (bool, default: true)
Whether to publish to TF directly.`wheel_separation` (double)
The distance of the left and right wheel(s). The diff_drive_controller will attempt to read the value from the URDF if this parameter is not specified.`wheel_radius` (double)
Radius of the wheels. It is expected they all have the same size. The diff_drive_controller will attempt to read the value from the URDF if this parameter is not specified.`odom_frame_id` (string, default: "/odom")
Name of frame in which to publish odometry.`publish_cmd` (bool, default: false)
Publish the velocity command to be executed. It is to monitor the effect of limiters on the controller input.`allow_multiple_cmd_vel_publishers` (bool, default: false)
When enabled the controller will brake if there is more than one publishers on its input topic, `~/cmd_vel`.