00001 /* 00002 MobileRobots Advanced Robotics Interface for Applications (ARIA) 00003 Copyright (C) 2004, 2005 ActivMedia Robotics LLC 00004 Copyright (C) 2006, 2007 MobileRobots Inc. 00005 00006 This program is free software; you can redistribute it and/or modify 00007 it under the terms of the GNU General Public License as published by 00008 the Free Software Foundation; either version 2 of the License, or 00009 (at your option) any later version. 00010 00011 This program is distributed in the hope that it will be useful, 00012 but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 GNU General Public License for more details. 00015 00016 You should have received a copy of the GNU General Public License 00017 along with this program; if not, write to the Free Software 00018 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00019 00020 If you wish to redistribute ARIA under different terms, contact 00021 MobileRobots for information about a commercial version of ARIA at 00022 robots@mobilerobots.com or 00023 MobileRobots Inc, 19 Columbia Drive, Amherst, NH 03031; 800-639-9481 00024 */ 00025 00026 #ifndef ARINTERPOLATION_H 00027 #define ARINTERPOLATION_H 00028 00029 #include "ariaTypedefs.h" 00030 #include "ariaUtil.h" 00031 00043 class ArInterpolation 00044 { 00045 public: 00047 AREXPORT ArInterpolation(size_t numberOfReadings = 100); 00049 AREXPORT virtual ~ArInterpolation(); 00051 AREXPORT bool addReading(ArTime timeOfReading, ArPose position); 00053 AREXPORT int getPose(ArTime timeStamp, ArPose *position); 00055 AREXPORT void setNumberOfReadings(size_t numberOfReadings); 00057 AREXPORT size_t getNumberOfReadings(void) const; 00059 AREXPORT void reset(void); 00060 protected: 00061 std::list<ArTime> myTimes; 00062 std::list<ArPose> myPoses; 00063 size_t mySize; 00064 }; 00065 00066 #endif