00001 /* 00002 Enki - a fast 2D robot simulator 00003 Copyright (C) 1999-2008 Stephane Magnenat <stephane at magnenat dot net> 00004 Copyright (C) 2004-2005 Markus Waibel <markus dot waibel at epfl dot ch> 00005 Copyright (c) 2004-2005 Antoine Beyeler <abeyeler at ab-ware dot com> 00006 Copyright (C) 2005-2006 Laboratory of Intelligent Systems, EPFL, Lausanne 00007 Copyright (C) 2006-2008 Laboratory of Robotics Systems, EPFL, Lausanne 00008 See AUTHORS for details 00009 00010 This program is free software; the authors of any publication 00011 arising from research using this software are asked to add the 00012 following reference: 00013 Enki - a fast 2D robot simulator 00014 http://lis.epfl.ch/enki 00015 Stephane Magnenat <stephane at magnenat dot net>, 00016 Markus Waibel <markus dot waibel at epfl dot ch> 00017 Laboratory of Intelligent Systems, EPFL, Lausanne. 00018 00019 You can redistribute this program and/or modify 00020 it under the terms of the GNU General Public License as published by 00021 the Free Software Foundation; either version 2 of the License, or 00022 (at your option) any later version. 00023 00024 This program is distributed in the hope that it will be useful, 00025 but WITHOUT ANY WARRANTY; without even the implied warranty of 00026 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00027 GNU General Public License for more details. 00028 00029 You should have received a copy of the GNU General Public License 00030 along with this program; if not, write to the Free Software 00031 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00032 */ 00033 00034 #ifndef __ENKI_DIFFERENTIAL_WHEELED_H 00035 #define __ENKI_DIFFERENTIAL_WHEELED_H 00036 00041 #include <enki/PhysicalEngine.h> 00042 00043 namespace Enki 00044 { 00045 class DifferentialWheeled: public Robot 00046 { 00047 public: 00049 double leftSpeed; 00051 double rightSpeed; 00052 00054 double leftEncoder; 00056 double rightEncoder; 00058 double leftOdometry; 00060 double rightOdometry; 00061 00062 protected: 00064 double distBetweenWheels; 00066 double maxSpeed; 00068 double noiseAmount; 00069 00070 private: 00072 double cmdAngSpeed; 00074 Vector cmdSpeed; 00075 00076 public: 00078 DifferentialWheeled(double distBetweenWheels, double maxSpeed, double noiseAmount); 00079 00081 void resetEncoders(); 00082 00084 virtual void controlStep(double dt); 00086 virtual void applyForces(double dt); 00087 }; 00088 } 00089 00090 #endif
1.5.1