example1_driver.h
Go to the documentation of this file.
00001 /*
00002  *  Copyright (c) 2011, A.M.Howard, S.Williams
00003  *  All rights reserved.
00004  *
00005  *  Redistribution and use in source and binary forms, with or without
00006  *  modification, are permitted provided that the following conditions are met:
00007  *      * Redistributions of source code must retain the above copyright
00008  *        notice, this list of conditions and the following disclaimer.
00009  *      * Redistributions in binary form must reproduce the above copyright
00010  *        notice, this list of conditions and the following disclaimer in the
00011  *        documentation and/or other materials provided with the distribution.
00012  *      * Neither the name of the <organization> nor the
00013  *        names of its contributors may be used to endorse or promote products
00014  *        derived from this software without specific prior written permission.
00015  *
00016  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
00017  *  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00018  *  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00019  *  DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
00020  *  DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00021  *  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00022  *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00023  *  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00024  *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00025  *  SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00026  */
00027 /*
00028  * This is a very simple example demonstrating the use of the ActuatorArrayDriver
00029  * base class. This example makes use of convenience classes provided in the base
00030  * class to read a simple list of actuators from the parameter server and set up
00031  * the standard ActuatorArrayDriver communication interface. This example does
00032  * not make use of the robot description. Instead, the init_actuator_ function
00033  * manually fills in some of the useful properties for each actuator. A
00034  * DummyActuator class is used to simulate the operation of a real R/C Servo motor.
00035  * This removes the need to have specific hardware to test the basic
00036  * ActuatorArrayDriver system.
00037  *
00038  *  Created on: Nov 27, 2011
00039  *      Author: Stephen Williams
00040  */
00041 
00042 #ifndef EXAMPLE1_DRIVER_H_
00043 #define EXAMPLE1_DRIVER_H_
00044 
00045 #include <actuator_array_driver/actuator_array_driver.h>
00046 #include <actuator_array_example/dummy_actuator.h>
00047 
00048 namespace actuator_array_example
00049 {
00050 
00051 class Example1Driver : public actuator_array_driver::ActuatorArrayDriver<actuator_array_driver::JointProperties>
00052 {
00053 private:
00054 
00055   // An array of simulated actuators
00056   std::map<int, DummyActuator> actuators_;
00057 
00058   // Keep track of the previous time a read/update was called
00059   ros::Time previous_time_;
00060 
00061 public:
00062   Example1Driver();
00063   virtual ~Example1Driver();
00064 
00065   // Overload the four main functions used by the ActuatorArrayDriver base class
00066   bool read_(ros::Time ts = ros::Time::now());
00067   bool command_();
00068   bool stop_();
00069   bool home_();
00070 };
00071 
00072 }
00073 #endif  // EXAMPLE1_DRIVER_H_


actuator_array_example
Author(s): Stephen Williams
autogenerated on Wed Nov 27 2013 12:01:28