This ROS interface implements a FollowJointTrajectoryAction interface for controlling (primarily) robot arms. More...
#include <follow_joint_trajectory.h>
Public Member Functions | |
FollowJointTrajectoryController () | |
virtual std::vector< std::string > | getClaimedNames () |
Get the names of joints/controllers which this controller exclusively claims. | |
virtual std::vector< std::string > | getCommandedNames () |
Get the names of joints/controllers which this controller commands. | |
virtual std::string | getType () |
Get the type of this controller. | |
virtual int | init (ros::NodeHandle &nh, ControllerManager *manager) |
Initialize the controller and any required data structures. | |
virtual bool | reset () |
Cleanly reset the controller to it's initial state. Some controllers may choose to stop themselves. This is mainly used in the case of the the robot exiting some fault condition. | |
virtual bool | start () |
Attempt to start the controller. This should be called only by the ControllerManager instance. | |
virtual bool | stop (bool force) |
Attempt to stop the controller. This should be called only by the ControllerManager instance. | |
virtual void | update (const ros::Time &now, const ros::Duration &dt) |
This is the update loop for the controller. | |
virtual | ~FollowJointTrajectoryController () |
Private Types | |
typedef actionlib::SimpleActionServer < control_msgs::FollowJointTrajectoryAction > | server_t |
Private Member Functions | |
void | executeCb (const control_msgs::FollowJointTrajectoryGoalConstPtr &goal) |
Callback for goal. | |
TrajectoryPoint | getPointFromCurrent (bool incl_vel, bool incl_acc, bool zero_vel) |
Get a trajectory point from the current position/velocity/acceleration. | |
Private Attributes | |
std::vector< bool > | continuous_ |
control_msgs::FollowJointTrajectoryFeedback | feedback_ |
ros::Time | goal_time |
double | goal_time_tolerance_ |
TrajectoryPoint | goal_tolerance_ |
bool | has_goal_tolerance_ |
bool | has_path_tolerance_ |
bool | initialized_ |
std::vector< std::string > | joint_names_ |
std::vector< JointHandlePtr > | joints_ |
TrajectoryPoint | last_sample_ |
ControllerManager * | manager_ |
TrajectoryPoint | path_tolerance_ |
bool | preempted_ |
boost::shared_ptr < TrajectorySampler > | sampler_ |
boost::mutex | sampler_mutex_ |
boost::shared_ptr< server_t > | server_ |
bool | stop_on_path_violation_ |
bool | stop_with_action_ |
This ROS interface implements a FollowJointTrajectoryAction interface for controlling (primarily) robot arms.
Definition at line 65 of file follow_joint_trajectory.h.
typedef actionlib::SimpleActionServer<control_msgs::FollowJointTrajectoryAction> robot_controllers::FollowJointTrajectoryController::server_t [private] |
Definition at line 67 of file follow_joint_trajectory.h.
Definition at line 48 of file follow_joint_trajectory.cpp.
virtual robot_controllers::FollowJointTrajectoryController::~FollowJointTrajectoryController | ( | ) | [inline, virtual] |
Definition at line 71 of file follow_joint_trajectory.h.
void robot_controllers::FollowJointTrajectoryController::executeCb | ( | const control_msgs::FollowJointTrajectoryGoalConstPtr & | goal | ) | [private] |
Callback for goal.
Definition at line 344 of file follow_joint_trajectory.cpp.
std::vector< std::string > robot_controllers::FollowJointTrajectoryController::getClaimedNames | ( | ) | [virtual] |
Get the names of joints/controllers which this controller exclusively claims.
Implements robot_controllers::Controller.
Definition at line 610 of file follow_joint_trajectory.cpp.
std::vector< std::string > robot_controllers::FollowJointTrajectoryController::getCommandedNames | ( | ) | [virtual] |
Get the names of joints/controllers which this controller commands.
Implements robot_controllers::Controller.
Definition at line 605 of file follow_joint_trajectory.cpp.
TrajectoryPoint robot_controllers::FollowJointTrajectoryController::getPointFromCurrent | ( | bool | incl_vel, |
bool | incl_acc, | ||
bool | zero_vel | ||
) | [private] |
Get a trajectory point from the current position/velocity/acceleration.
Definition at line 570 of file follow_joint_trajectory.cpp.
virtual std::string robot_controllers::FollowJointTrajectoryController::getType | ( | ) | [inline, virtual] |
Get the type of this controller.
Reimplemented from robot_controllers::Controller.
Definition at line 114 of file follow_joint_trajectory.h.
int robot_controllers::FollowJointTrajectoryController::init | ( | ros::NodeHandle & | nh, |
ControllerManager * | manager | ||
) | [virtual] |
Initialize the controller and any required data structures.
nh | Node handle for this controller. |
manager | The controller manager instance, this is needed for the controller to get information about joints, etc. |
Reimplemented from robot_controllers::Controller.
Definition at line 53 of file follow_joint_trajectory.cpp.
bool robot_controllers::FollowJointTrajectoryController::reset | ( | ) | [virtual] |
Cleanly reset the controller to it's initial state. Some controllers may choose to stop themselves. This is mainly used in the case of the the robot exiting some fault condition.
Implements robot_controllers::Controller.
Definition at line 177 of file follow_joint_trajectory.cpp.
bool robot_controllers::FollowJointTrajectoryController::start | ( | ) | [virtual] |
Attempt to start the controller. This should be called only by the ControllerManager instance.
Implements robot_controllers::Controller.
Definition at line 136 of file follow_joint_trajectory.cpp.
bool robot_controllers::FollowJointTrajectoryController::stop | ( | bool | force | ) | [virtual] |
Attempt to stop the controller. This should be called only by the ControllerManager instance.
force | Should we force the controller to stop? Some controllers may wish to continue running until they absolutely have to stop. |
Implements robot_controllers::Controller.
Definition at line 155 of file follow_joint_trajectory.cpp.
void robot_controllers::FollowJointTrajectoryController::update | ( | const ros::Time & | now, |
const ros::Duration & | dt | ||
) | [virtual] |
This is the update loop for the controller.
time | The system time. |
dt | The timestep since last call to update. |
Implements robot_controllers::Controller.
Definition at line 183 of file follow_joint_trajectory.cpp.
std::vector<bool> robot_controllers::FollowJointTrajectoryController::continuous_ [private] |
Definition at line 137 of file follow_joint_trajectory.h.
control_msgs::FollowJointTrajectoryFeedback robot_controllers::FollowJointTrajectoryController::feedback_ [private] |
Definition at line 165 of file follow_joint_trajectory.h.
Definition at line 166 of file follow_joint_trajectory.h.
Definition at line 163 of file follow_joint_trajectory.h.
Definition at line 162 of file follow_joint_trajectory.h.
Definition at line 161 of file follow_joint_trajectory.h.
action was preempted (has nothing to do with preempt() above).
Definition at line 158 of file follow_joint_trajectory.h.
Definition at line 132 of file follow_joint_trajectory.h.
std::vector<std::string> robot_controllers::FollowJointTrajectoryController::joint_names_ [private] |
Definition at line 136 of file follow_joint_trajectory.h.
std::vector<JointHandlePtr> robot_controllers::FollowJointTrajectoryController::joints_ [private] |
Definition at line 135 of file follow_joint_trajectory.h.
should we stop this controller when a path tolerance has been violated?
Definition at line 155 of file follow_joint_trajectory.h.
Definition at line 133 of file follow_joint_trajectory.h.
Definition at line 159 of file follow_joint_trajectory.h.
Definition at line 156 of file follow_joint_trajectory.h.
boost::shared_ptr<TrajectorySampler> robot_controllers::FollowJointTrajectoryController::sampler_ [private] |
Definition at line 140 of file follow_joint_trajectory.h.
boost::mutex robot_controllers::FollowJointTrajectoryController::sampler_mutex_ [private] |
Definition at line 141 of file follow_joint_trajectory.h.
boost::shared_ptr<server_t> robot_controllers::FollowJointTrajectoryController::server_ [private] |
Definition at line 138 of file follow_joint_trajectory.h.
should we stop this controller when the action has terminated (or hold position)?
Definition at line 146 of file follow_joint_trajectory.h.
Definition at line 143 of file follow_joint_trajectory.h.