42 #include <control_msgs/JointTrajectoryControllerState.h> 44 #include <diff_drive_controller/DiffDriveControllerConfig.h> 47 #include <dynamic_reconfigure/server.h> 48 #include <geometry_msgs/TwistStamped.h> 51 #include <nav_msgs/Odometry.h> 55 #include <tf/tfMessage.h> 140 std::shared_ptr<realtime_tools::RealtimePublisher<geometry_msgs::TwistStamped> >
cmd_vel_pub_;
143 std::shared_ptr<realtime_tools::RealtimePublisher<nav_msgs::Odometry> >
odom_pub_;
144 std::shared_ptr<realtime_tools::RealtimePublisher<tf::tfMessage> >
tf_odom_pub_;
148 std::shared_ptr<realtime_tools::RealtimePublisher<control_msgs::JointTrajectoryControllerState> >
controller_state_pub_;
207 : left_wheel_radius_multiplier(1.0)
208 , right_wheel_radius_multiplier(1.0)
209 , wheel_separation_multiplier(1.0)
212 , enable_odom_tf(true)
217 os <<
"DynamicParams:\n" 219 <<
"\tOdometry parameters:\n" 224 <<
"\tPublication parameters:\n" 225 <<
"\t\tPublish executed velocity command: " << (params.
publish_cmd?
"enabled":
"disabled") <<
"\n" 226 <<
"\t\tPublication rate: " << params.
publish_rate <<
"\n" 227 <<
"\t\tPublish frame odom on tf: " << (params.
enable_odom_tf?
"enabled":
"disabled");
261 const std::string& wheel_param,
262 std::vector<std::string>& wheel_names);
271 const std::string& left_wheel_name,
272 const std::string& right_wheel_name,
273 bool lookup_wheel_separation,
274 bool lookup_wheel_radius);
289 void reconfCallback(DiffDriveControllerConfig& config, uint32_t );
308 double wheel_separation,
309 double left_wheel_radius,
310 double right_wheel_radius);
realtime_tools::RealtimeBuffer< Commands > command_
bool allow_multiple_cmd_vel_publishers_
Whether to allow multiple publishers on cmd_vel topic or not:
bool init(hardware_interface::VelocityJointInterface *hw, ros::NodeHandle &root_nh, ros::NodeHandle &controller_nh)
Initialize controller.
double wheel_separation_
Wheel separation, wrt the midpoint of the wheel width:
void updateDynamicParams()
Update the dynamic parameters in the RT loop.
double wheel_separation_multiplier
std::vector< hardware_interface::JointHandle > left_wheel_joints_
Hardware handles:
Velocity command related:
double vel_right_desired_previous_
double wheel_radius_
Wheel radius (assuming it's the same for the left and right wheels):
std::string odom_frame_id_
Frame to use for odometry and odom tf:
void brake()
Brakes the wheels, i.e. sets the velocity to 0.
size_t wheel_joints_size_
Number of wheel joints:
boost::recursive_mutex dyn_reconf_server_mutex_
bool getWheelNames(ros::NodeHandle &controller_nh, const std::string &wheel_param, std::vector< std::string > &wheel_names)
Get the wheel names from a wheel param.
PLUGINLIB_EXPORT_CLASS(diff_drive_controller::DiffDriveController, controller_interface::ControllerBase)
std::shared_ptr< realtime_tools::RealtimePublisher< control_msgs::JointTrajectoryControllerState > > controller_state_pub_
Controller state publisher.
std::vector< double > vel_left_previous_
Previous velocities from the encoders:
double right_wheel_radius_multiplier
std::vector< double > vel_right_previous_
std::vector< hardware_interface::JointHandle > right_wheel_joints_
std::shared_ptr< realtime_tools::RealtimePublisher< nav_msgs::Odometry > > odom_pub_
Odometry related:
void starting(const ros::Time &time)
Starts controller.
double vel_left_desired_previous_
Previous velocities from the encoders:
std::shared_ptr< realtime_tools::RealtimePublisher< geometry_msgs::TwistStamped > > cmd_vel_pub_
Publish executed commands.
void cmdVelCallback(const geometry_msgs::Twist &command)
Velocity command callback.
ros::Time last_state_publish_time_
ros::Subscriber sub_command_
void update(const ros::Time &time, const ros::Duration &period)
Updates controller, i.e. computes the odometry and sets the new velocity commands.
realtime_tools::RealtimeBuffer< DynamicParams > dynamic_params_
The Odometry class handles odometry readings (2D pose and velocity with related timestamp) ...
bool publish_wheel_joint_controller_state_
Publish wheel data:
double right_wheel_radius_multiplier_
ros::Duration publish_period_
Odometry related:
double left_wheel_radius_multiplier
void publishWheelData(const ros::Time &time, const ros::Duration &period, Commands &curr_cmd, double wheel_separation, double left_wheel_radius, double right_wheel_radius)
bool publish_cmd_
Publish limited velocity:
SpeedLimiter limiter_lin_
std::shared_ptr< ReconfigureServer > dyn_reconf_server_
double cmd_vel_timeout_
Timeout to consider cmd_vel commands old:
friend std::ostream & operator<<(std::ostream &os, const DynamicParams ¶ms)
SpeedLimiter limiter_ang_
bool setOdomParamsFromUrdf(ros::NodeHandle &root_nh, const std::string &left_wheel_name, const std::string &right_wheel_name, bool lookup_wheel_separation, bool lookup_wheel_radius)
Sets odometry parameters from the URDF, i.e. the wheel radius and separation.
double left_wheel_radius_multiplier_
bool enable_odom_tf_
Whether to publish odometry to tf or not:
Commands last1_cmd_
Speed limiters:
void reconfCallback(DiffDriveControllerConfig &config, uint32_t)
Callback for dynamic_reconfigure server.
std::shared_ptr< realtime_tools::RealtimePublisher< tf::tfMessage > > tf_odom_pub_
void setOdomPubFields(ros::NodeHandle &root_nh, ros::NodeHandle &controller_nh)
Sets the odometry publishing fields.
dynamic_reconfigure::Server< DiffDriveControllerConfig > ReconfigureServer
Dynamic Reconfigure server.
void stopping(const ros::Time &)
Stops controller.
double wheel_separation_multiplier_
Wheel separation and radius calibration multipliers:
std::string base_frame_id_
Frame to use for the robot base: