trajectory_segment.hpp

Go to the documentation of this file.
00001 /***************************************************************************
00002   tag: Erwin Aertbelien  Mon Jan 10 16:38:39 CET 2005  trajectory_segment.h
00003 
00004                         trajectory_segment.h -  description
00005                            -------------------
00006     begin                : Mon January 10 2005
00007     copyright            : (C) 2005 Erwin Aertbelien
00008     email                : erwin.aertbelien@mech.kuleuven.ac.be
00009 
00010  ***************************************************************************
00011  *   This library is free software; you can redistribute it and/or         *
00012  *   modify it under the terms of the GNU Lesser General Public            *
00013  *   License as published by the Free Software Foundation; either          *
00014  *   version 2.1 of the License, or (at your option) any later version.    *
00015  *                                                                         *
00016  *   This library is distributed in the hope that it will be useful,       *
00017  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
00018  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU     *
00019  *   Lesser General Public License for more details.                       *
00020  *                                                                         *
00021  *   You should have received a copy of the GNU Lesser General Public      *
00022  *   License along with this library; if not, write to the Free Software   *
00023  *   Foundation, Inc., 59 Temple Place,                                    *
00024  *   Suite 330, Boston, MA  02111-1307  USA                                *
00025  *                                                                         *
00026  ***************************************************************************/
00027 
00028 
00029 /*****************************************************************************
00030  *  \author
00031  *      Erwin Aertbelien, Div. PMA, Dep. of Mech. Eng., K.U.Leuven
00032  *
00033  *  \version
00034  *              ORO_Geometry V0.2
00035  *
00036  *      \par History
00037  *              - $log$
00038  *
00039  *      \par Release
00040  *              $Id: trajectory_segment.h,v 1.1.1.1.2.5 2003/07/23 16:44:26 psoetens Exp $
00041  *              $Name:  $
00042  ****************************************************************************/
00043 
00044 #ifndef KDL_MOTION_TRAJECTORY_SEGMENT_H
00045 #define KDL_MOTION_TRAJECTORY_SEGMENT_H
00046 
00047 #include "frames.hpp"
00048 #include "frames_io.hpp"
00049 #include "trajectory.hpp"
00050 #include "path.hpp"
00051 #include "velocityprofile.hpp"
00052 
00053 
00054 namespace KDL {
00055 
00056 
00062         class Trajectory_Segment :  public Trajectory
00063         {
00064                 VelocityProfile* motprof;
00065                 Path*      geom;
00066                 bool aggregate;
00067         public:
00071                 Trajectory_Segment(Path* _geom, VelocityProfile* _motprof, bool _aggregate=true);
00072 
00077                 Trajectory_Segment(Path* _geom, VelocityProfile* _motprof, double duration, bool _aggregate=true);
00078 
00079                 virtual Path* GetPath();
00080                 virtual VelocityProfile* GetProfile();
00081                 virtual double Duration() const;
00082                 // The duration of the trajectory
00083 
00084                 virtual Frame Pos(double time) const;
00085                 // Position of the trajectory at <time>.
00086 
00087                 virtual Twist Vel(double time) const;
00088                 // The velocity of the trajectory at <time>.
00089                 virtual Twist Acc(double time) const;
00090                 // The acceleration of the trajectory at <time>.
00091 
00092                 virtual Trajectory* Clone() const
00093                         {
00094                                 if ( aggregate )
00095                                         return new Trajectory_Segment( geom->Clone(), motprof->Clone(), true );
00096                                 return new Trajectory_Segment( geom, motprof, false );
00097                         }
00098 
00099                 virtual void Write(std::ostream& os) const;
00100 
00101                 virtual ~Trajectory_Segment();
00102         };
00103 
00104 
00105 
00106 }
00107 
00108 
00109 #endif

Generated on Wed Nov 23 19:00:49 2011 for FreeCAD by  doxygen 1.6.1