1
0
mirror of https://gitlab.com/obbart/universal_robots_ros_driver.git synced 2026-04-10 10:00:48 +02:00

Changed from simpleActionServer to Actionserver. Fixed bug that prevented starting the driver in

non-ros-control mode
This commit is contained in:
Thomas Timm Andersen
2015-10-08 17:01:37 +02:00
parent d8b8d86ecb
commit d4102dd97d

View File

@@ -26,7 +26,8 @@
#include "sensor_msgs/JointState.h" #include "sensor_msgs/JointState.h"
#include "geometry_msgs/WrenchStamped.h" #include "geometry_msgs/WrenchStamped.h"
#include "control_msgs/FollowJointTrajectoryAction.h" #include "control_msgs/FollowJointTrajectoryAction.h"
#include "actionlib/server/simple_action_server.h" #include "actionlib/server/action_server.h"
#include "actionlib/server/server_goal_handle.h"
#include "trajectory_msgs/JointTrajectoryPoint.h" #include "trajectory_msgs/JointTrajectoryPoint.h"
#include "ur_msgs/SetIO.h" #include "ur_msgs/SetIO.h"
#include "ur_msgs/SetPayload.h" #include "ur_msgs/SetPayload.h"
@@ -46,8 +47,8 @@ protected:
std::condition_variable rt_msg_cond_; std::condition_variable rt_msg_cond_;
std::condition_variable msg_cond_; std::condition_variable msg_cond_;
ros::NodeHandle nh_; ros::NodeHandle nh_;
actionlib::SimpleActionServer<control_msgs::FollowJointTrajectoryAction> as_; actionlib::ActionServer<control_msgs::FollowJointTrajectoryAction> as_;
actionlib::SimpleActionServer<control_msgs::FollowJointTrajectoryAction>::Goal goal_; actionlib::ActionServer<control_msgs::FollowJointTrajectoryAction>::Goal goal_;
control_msgs::FollowJointTrajectoryFeedback feedback_; control_msgs::FollowJointTrajectoryFeedback feedback_;
control_msgs::FollowJointTrajectoryResult result_; control_msgs::FollowJointTrajectoryResult result_;
ros::Subscriber speed_sub_; ros::Subscriber speed_sub_;
@@ -66,9 +67,11 @@ protected:
public: public:
RosWrapper(std::string host) : RosWrapper(std::string host) :
as_(nh_, "follow_joint_trajectory", false), robot_(rt_msg_cond_, as_(nh_, "follow_joint_trajectory",
msg_cond_, host), io_flag_delay_(0.05), joint_offsets_(6, boost::bind(&RosWrapper::goalCB, this, _1),
0.0) { boost::bind(&RosWrapper::cancelCB, this, _1), false), robot_(
rt_msg_cond_, msg_cond_, host), io_flag_delay_(0.05), joint_offsets_(
6, 0.0) {
std::string joint_prefix = ""; std::string joint_prefix = "";
std::vector<std::string> joint_names; std::vector<std::string> joint_names;
@@ -95,6 +98,14 @@ public:
controller_manager_.reset( controller_manager_.reset(
new controller_manager::ControllerManager( new controller_manager::ControllerManager(
hardware_interface_.get(), nh_)); hardware_interface_.get(), nh_));
double max_vel_change = 0.12; // equivalent of an acceleration of 15 rad/sec^2
if (ros::param::get("~max_acceleration", max_vel_change)) {
max_vel_change = max_vel_change / 125;
}
sprintf(buf, "Max acceleration set to: %f [rad/sec²]",
max_vel_change * 125);
print_debug(buf);
hardware_interface_->setMaxVelChange(max_vel_change);
} }
//Using a very high value in order to not limit execution of trajectories being sent from MoveIt! //Using a very high value in order to not limit execution of trajectories being sent from MoveIt!
max_velocity_ = 10.; max_velocity_ = 10.;
@@ -129,14 +140,6 @@ public:
} }
robot_.setServojTime(servoj_time); robot_.setServojTime(servoj_time);
double max_vel_change = 0.12; // equivalent of an acceleration of 15 rad/sec^2
if (ros::param::get("~max_acceleration", max_vel_change)) {
max_vel_change = max_vel_change/125;
}
sprintf(buf, "Max acceleration set to: %f [rad/sec²]", max_vel_change*125);
print_debug(buf);
hardware_interface_->setMaxVelChange(max_vel_change);
if (robot_.start()) { if (robot_.start()) {
if (use_ros_control_) { if (use_ros_control_) {
ros_control_thread_ = new std::thread( ros_control_thread_ = new std::thread(
@@ -144,12 +147,7 @@ public:
print_debug( print_debug(
"The control thread for this driver has been started"); "The control thread for this driver has been started");
} else { } else {
//register the goal and feedback callbacks //start actionserver
as_.registerGoalCallback(
boost::bind(&RosWrapper::goalCB, this));
as_.registerPreemptCallback(
boost::bind(&RosWrapper::preemptCB, this));
as_.start(); as_.start();
//subscribe to the data topic of interest //subscribe to the data topic of interest
@@ -178,12 +176,12 @@ public:
} }
private: private:
void goalCB() { void goalCB(
actionlib::ServerGoalHandle<
control_msgs::FollowJointTrajectoryAction> gh) {
print_info("on_goal"); print_info("on_goal");
actionlib::SimpleActionServer<control_msgs::FollowJointTrajectoryAction>::GoalConstPtr goal = goal_ = *gh.getGoal(); //make a copy that we can modify
as_.acceptNewGoal();
goal_ = *goal; //make a copy that we can modify
if (!validateJointNames()) { if (!validateJointNames()) {
std::string outp_joint_names = ""; std::string outp_joint_names = "";
for (unsigned int i = 0; i < goal_.trajectory.joint_names.size(); for (unsigned int i = 0; i < goal_.trajectory.joint_names.size();
@@ -194,28 +192,28 @@ private:
result_.error_string = result_.error_string =
"Received a goal with incorrect joint names: " "Received a goal with incorrect joint names: "
+ outp_joint_names; + outp_joint_names;
as_.setAborted(result_, result_.error_string); gh.setRejected(result_, result_.error_string);
print_error(result_.error_string); print_error(result_.error_string);
} }
if (!has_positions()) { if (!has_positions()) {
result_.error_code = result_.INVALID_GOAL; result_.error_code = result_.INVALID_GOAL;
result_.error_string = "Received a goal without positions"; result_.error_string = "Received a goal without positions";
as_.setAborted(result_, result_.error_string); gh.setRejected(result_, result_.error_string);
print_error(result_.error_string); print_error(result_.error_string);
} }
if (!has_velocities()) { if (!has_velocities()) {
result_.error_code = result_.INVALID_GOAL; result_.error_code = result_.INVALID_GOAL;
result_.error_string = "Received a goal without velocities"; result_.error_string = "Received a goal without velocities";
as_.setAborted(result_, result_.error_string); gh.setRejected(result_, result_.error_string);
print_error(result_.error_string); print_error(result_.error_string);
} }
if (!traj_is_finite()) { if (!traj_is_finite()) {
result_.error_string = "Received a goal with infinites or NaNs"; result_.error_string = "Received a goal with infinites or NaNs";
result_.error_code = result_.INVALID_GOAL; result_.error_code = result_.INVALID_GOAL;
as_.setAborted(result_, result_.error_string); gh.setRejected(result_, result_.error_string);
print_error(result_.error_string); print_error(result_.error_string);
} }
@@ -223,7 +221,7 @@ private:
result_.error_code = result_.INVALID_GOAL; result_.error_code = result_.INVALID_GOAL;
result_.error_string = result_.error_string =
"Received a goal with velocities that are higher than %f", max_velocity_; "Received a goal with velocities that are higher than %f", max_velocity_;
as_.setAborted(result_, result_.error_string); gh.setRejected(result_, result_.error_string);
print_error(result_.error_string); print_error(result_.error_string);
} }
@@ -237,16 +235,21 @@ private:
velocities.push_back(goal_.trajectory.points[i].velocities); velocities.push_back(goal_.trajectory.points[i].velocities);
} }
gh.setAccepted();
robot_.doTraj(timestamps, positions, velocities); robot_.doTraj(timestamps, positions, velocities);
result_.error_code = result_.SUCCESSFUL; result_.error_code = result_.SUCCESSFUL;
as_.setSucceeded(result_); gh.setSucceeded(result_);
} }
void preemptCB() { void cancelCB(
actionlib::ServerGoalHandle<
control_msgs::FollowJointTrajectoryAction> gh) {
print_info("on_cancel"); print_info("on_cancel");
// set the action state to preempted // set the action state to preempted
robot_.stopTraj(); robot_.stopTraj();
as_.setPreempted(); result_.error_code = result_.SUCCESSFUL;
result_.error_string = "Goal cancelled by client";
gh.setCanceled(result_);
} }
bool setIO(ur_msgs::SetIORequest& req, ur_msgs::SetIOResponse& resp) { bool setIO(ur_msgs::SetIORequest& req, ur_msgs::SetIOResponse& resp) {