odeagent.h

Go to the documentation of this file.
00001 /***************************************************************************
00002  *   Copyright (C) 2005 by Robot Group Leipzig                             *
00003  *    martius@informatik.uni-leipzig.de                                    *
00004  *    fhesse@informatik.uni-leipzig.de                                     *
00005  *    der@informatik.uni-leipzig.de                                        *
00006  *                                                                         *
00007  *   This program is free software; you can redistribute it and/or modify  *
00008  *   it under the terms of the GNU General Public License as published by  *
00009  *   the Free Software Foundation; either version 2 of the License, or     *
00010  *   (at your option) any later version.                                   *
00011  *                                                                         *
00012  *   This program is distributed in the hope that it will be useful,       *
00013  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
00014  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
00015  *   GNU General Public License for more details.                          *
00016  *                                                                         *
00017  *   You should have received a copy of the GNU General Public License     *
00018  *   along with this program; if not, write to the                         *
00019  *   Free Software Foundation, Inc.,                                       *
00020  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
00021  *                                                                         *
00022  *   $Log: odeagent.h,v $
00023  *   Revision 1.3  2006/07/20 17:19:43  martius
00024  *   removed using namespace std from matrix.h
00025  *
00026  *   Revision 1.2  2006/07/14 12:23:31  martius
00027  *   selforg becomes HEAD
00028  *
00029  *   Revision 1.1.2.6  2006/05/15 13:14:10  robot3
00030  *   STRG-R now makes screenshots in jpg-format
00031  *   STRG-F now toggles the file logging (controller stuff) on/off
00032  *   STRG-G now restarts the GuiLogger
00033  *
00034  *   Revision 1.1.2.5  2006/03/31 16:16:58  fhesse
00035  *   changed trace() to init_tracing()
00036  *   and check for init at beginning of step
00037  *
00038  *   Revision 1.1.2.4  2006/03/29 15:08:06  martius
00039  *   Agent::interninit not necessary
00040  *
00041  *   Revision 1.1.2.3  2006/03/28 14:14:44  fhesse
00042  *   tracing of a given primitive (in the osg window) added
00043  *
00044  *   Revision 1.1.2.2  2005/12/06 10:13:23  martius
00045  *   openscenegraph integration started
00046  *
00047  *   Revision 1.1.2.1  2005/11/15 12:29:18  martius
00048  *   new selforg structure and OdeAgent, OdeRobot ...
00049  *
00050  *                                                                 *
00051  ***************************************************************************/
00052 #ifndef __ODEAGENT_H
00053 #define __ODEAGENT_H
00054 
00055 #include <selforg/agent.h>
00056 #include "oderobot.h"
00057 #include "osgprimitive.h"
00058 #include "primitive.h"
00059 
00060 namespace lpzrobots {
00061 
00062 /** Specialised agent for ode robots
00063  */
00064   class OdeAgent : public Agent {
00065   public:
00066   /** constructor
00067    */
00068   OdeAgent(const PlotOption& plotOption)  : Agent(plotOption) {tracing_initialized=false;}
00069   OdeAgent(const std::list<PlotOption>& plotOptions) : Agent(plotOptions) {tracing_initialized=false;}
00070   /** destructor
00071    */
00072   virtual ~OdeAgent() {}
00073 
00074   /** initializes the object with the given controller, robot and wiring
00075       and initializes pipe to guilogger
00076   */
00077   virtual bool init(AbstractController* controller, OdeRobot* robot, AbstractWiring* wiring){
00078     return Agent::init(controller, robot, wiring);
00079   }
00080 
00081   /** Performs an step of the agent, including sensor reading, pushing sensor values through wiring, 
00082       controller step, pushing controller outputs (= motorcommands) back through wiring and sent 
00083       resulting motorcommands to robot.
00084       @param noise Noise strength.
00085   */
00086   virtual void step(double noise);
00087 
00088   void internInit(){
00089     trace_length=0; // number of past robot positions shown in osg
00090   }
00091 
00092   /** 
00093    * Returns a pointer to the robot.
00094    */
00095   virtual OdeRobot* getRobot() { return (OdeRobot*)robot;}
00096 
00097   /// gives the number of past robot positions shown as trace in osg
00098   virtual int getTraceLength(){return trace_length;}
00099 
00100   /**
00101    * initialize tracing in ode
00102    * @param tracelength number of past positions shown as trace in osg 
00103    * @param tracethickness  thickness of the trace
00104    */
00105   virtual void init_tracing(int tracelength=1000, double tracethickness=0.003);
00106 
00107 
00108   private:
00109   int trace_length;
00110   double trace_thickness;
00111   int counter;
00112   bool tracing_initialized;
00113 
00114   OSGPrimitive** segments; // stores segments(cylinders) of the trace
00115   osg::Vec3 lastpos;
00116 };
00117 
00118 }
00119 
00120 #endif

Generated on Mon Aug 7 16:40:14 2006 for Robotsystem of the Robot Group Leipzig by  doxygen 1.4.7