IRI ROS Specific Driver Class. More...
#include <wam_controller_driver_node.h>
IRI ROS Specific Driver Class.
This class inherits from the IRI Core class IriBaseNodeDriver<IriBaseDriver>, to provide an execution thread to the driver object. A complete framework with utilites to test the node functionallity or to add diagnostics to specific situations is also given. The inherit template design form allows complete access to any IriBaseDriver object implementation.
As mentioned, tests in the different driver states can be performed through class methods such as addNodeOpenedTests() or addNodeRunningTests(). Tests common to all nodes may be also executed in the pattern class IriBaseNodeDriver. Similarly to the tests, diagnostics can easyly be added. See ROS Wiki for more details: http://www.ros.org/wiki/diagnostics/ (Tutorials: Creating a Diagnostic Analyzer) http://www.ros.org/wiki/self_test/ (Example: Self Test)
Definition at line 61 of file wam_controller_driver_node.h.
constructor
This constructor mainly creates and initializes the WamControllerDriverNode topics through the given public_node_handle object. IriBaseNodeDriver attributes may be also modified to suit node specifications.
All kind of ROS topics (publishers, subscribers, servers or clients) can be easyly generated with the scripts in the iri_ros_scripts package. Refer to ROS and IRI Wiki pages for more details:
http://www.ros.org/wiki/ROS/Tutorials/WritingPublisherSubscriber(c++) http://www.ros.org/wiki/ROS/Tutorials/WritingServiceClient(c++) http://wikiri.upc.es/index.php/Robotics_Lab
nh | a reference to the node handle object to manage all ROS topics. |
Definition at line 4 of file wam_controller_driver_node.cpp.
Destructor.
This destructor is called when the object is about to be destroyed.
Definition at line 271 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::addNodeDiagnostics | ( | void | ) | [protected, virtual] |
node add diagnostics
In this function ROS diagnostics applied to this specific node may be added. Common use diagnostics for all nodes are already called from IriBaseNodeDriver::addDiagnostics(), which also calls this function. Information of how ROS diagnostics work can be readen here: http://www.ros.org/wiki/diagnostics/ http://www.ros.org/doc/api/diagnostic_updater/html/example_8cpp-source.html
Implements iri_base_driver::IriBaseNodeDriver< WamControllerDriver >.
Definition at line 251 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::addNodeOpenedTests | ( | void | ) | [protected, virtual] |
open status driver tests
In this function tests checking driver's functionallity when driver_base status=open can be added. Common use tests for all nodes are already called from IriBaseNodeDriver tests methods. For more details on how ROS tests work, please refer to the Self Test example in: http://www.ros.org/wiki/self_test/
Implements iri_base_driver::IriBaseNodeDriver< WamControllerDriver >.
Definition at line 255 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::addNodeRunningTests | ( | void | ) | [protected, virtual] |
run status driver tests
In this function tests checking driver's functionallity when driver_base status=run can be added. Common use tests for all nodes are already called from IriBaseNodeDriver tests methods. For more details on how ROS tests work, please refer to the Self Test example in: http://www.ros.org/wiki/self_test/
Implements iri_base_driver::IriBaseNodeDriver< WamControllerDriver >.
Definition at line 263 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::addNodeStoppedTests | ( | void | ) | [protected, virtual] |
stop status driver tests
In this function tests checking driver's functionallity when driver_base status=stop can be added. Common use tests for all nodes are already called from IriBaseNodeDriver tests methods. For more details on how ROS tests work, please refer to the Self Test example in: http://www.ros.org/wiki/self_test/
Implements iri_base_driver::IriBaseNodeDriver< WamControllerDriver >.
Definition at line 259 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::follow_joint_trajectoryGetFeedbackCallback | ( | control_msgs::FollowJointTrajectoryFeedbackPtr & | feedback | ) | [private] |
Definition at line 233 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::follow_joint_trajectoryGetResultCallback | ( | control_msgs::FollowJointTrajectoryResultPtr & | result | ) | [private] |
Definition at line 221 of file wam_controller_driver_node.cpp.
bool WamControllerDriverNode::follow_joint_trajectoryHasSucceedCallback | ( | void | ) | [private] |
Definition at line 209 of file wam_controller_driver_node.cpp.
bool WamControllerDriverNode::follow_joint_trajectoryIsFinishedCallback | ( | void | ) | [private] |
Definition at line 193 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::follow_joint_trajectoryStartCallback | ( | const control_msgs::FollowJointTrajectoryGoalConstPtr & | goal | ) | [private] |
Definition at line 173 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::follow_joint_trajectoryStopCallback | ( | void | ) | [private] |
Definition at line 184 of file wam_controller_driver_node.cpp.
bool WamControllerDriverNode::hold_onCallback | ( | iri_wam_common_msgs::wamholdon::Request & | req, |
iri_wam_common_msgs::wamholdon::Response & | res | ||
) | [private] |
Definition at line 100 of file wam_controller_driver_node.cpp.
bool WamControllerDriverNode::joints_moveCallback | ( | iri_wam_common_msgs::joints_move::Request & | req, |
iri_wam_common_msgs::joints_move::Response & | res | ||
) | [private] |
Definition at line 133 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::mainNodeThread | ( | void | ) | [protected, virtual] |
main node thread
This is the main thread node function. Code written here will be executed in every node loop while the driver is on running state. Loop frequency can be tuned by modifying loop_rate attribute.
Here data related to the process loop or to ROS topics (mainly data structs related to the MSG and SRV files) must be updated. ROS publisher objects must publish their data in this process. ROS client servers may also request data to the corresponding server topics.
Implements iri_base_driver::IriBaseNodeDriver< WamControllerDriver >.
Definition at line 40 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::postNodeOpenHook | ( | void | ) | [private, virtual] |
post open hook
This function is called by IriBaseNodeDriver::postOpenHook(). In this function specific parameters from the driver must be added so the ROS dynamic reconfigure application can update them.
Implements iri_base_driver::IriBaseNodeDriver< WamControllerDriver >.
Definition at line 247 of file wam_controller_driver_node.cpp.
void WamControllerDriverNode::reconfigureNodeHook | ( | int | level | ) | [protected, virtual] |
specific node dynamic reconfigure
This function is called reconfigureHook()
level | integer |
Implements iri_base_driver::IriBaseNodeDriver< WamControllerDriver >.
Definition at line 267 of file wam_controller_driver_node.cpp.
IriActionServer<control_msgs::FollowJointTrajectoryAction> WamControllerDriverNode::follow_joint_trajectory_aserver_ [private] |
Definition at line 83 of file wam_controller_driver_node.h.
CMutex WamControllerDriverNode::hold_on_mutex_ [private] |
Definition at line 75 of file wam_controller_driver_node.h.
Definition at line 73 of file wam_controller_driver_node.h.
Definition at line 67 of file wam_controller_driver_node.h.
CMutex WamControllerDriverNode::joints_move_mutex_ [private] |
Definition at line 78 of file wam_controller_driver_node.h.
Definition at line 76 of file wam_controller_driver_node.h.
sensor_msgs::JointState WamControllerDriverNode::JointState_msg_ [private] |
Definition at line 68 of file wam_controller_driver_node.h.
Definition at line 65 of file wam_controller_driver_node.h.
geometry_msgs::PoseStamped WamControllerDriverNode::PoseStamped_msg_ [private] |
Definition at line 66 of file wam_controller_driver_node.h.