IvfSpline3d.h

00001 //
00002 // Copyright 1999-2006 by Structural Mechanics, Lund University.
00003 //
00004 // This library is free software; you can redistribute it and/or
00005 // modify it under the terms of the GNU Library General Public
00006 // License as published by the Free Software Foundation; either
00007 // version 2 of the License, or (at your option) any later version.
00008 //
00009 // This library is distributed in the hope that it will be useful,
00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012 // Library General Public License for more details.
00013 //
00014 // You should have received a copy of the GNU Library General Public
00015 // License along with this library; if not, write to the Free Software
00016 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
00017 // USA.
00018 //
00019 // Please report all bugs and problems to "ivf@byggmek.lth.se".
00020 //
00021 //
00022 // Written by Jonas Lindemann
00023 //
00024 
00025 #ifndef _CIvfSpline3d_h_
00026 #define _CIvfSpline3d_h_
00027 
00028 #include <ivf/ivfconfig.h>
00029 
00030 #include <ivfmath/IvfMathBase.h>
00031 #include <ivfmath/IvfSplineSegment3d.h>
00032 
00033 IvfSmartPointer(CIvfSpline3d);
00034 
00043 class IVFMATH_API CIvfSpline3d : public CIvfMathBase {
00044 private:
00045         int m_size;
00046         std::vector<CIvfSplineSegment3d*> m_segments;   
00047         std::vector<CIvfVec3d*> m_points;
00048 
00049         std::vector<double> m_tau;    // Slack/tightening
00050         std::vector<double> m_gamma;  // Continuity
00051         std::vector<double> m_beta;   // Bias
00052 
00053         CIvfVec3d* m_start;
00054         CIvfVec3d* m_end;
00055 
00056         void initSpline();
00057         void updateSpline();
00058 public:
00060         CIvfSpline3d();
00061 
00063         virtual ~CIvfSpline3d();
00064 
00065         IvfClassInfo("CIvfSpline3d",CIvfMathBase);
00066 
00068         void clear();
00069 
00071         int getSize();
00072 
00078         void setSize(int size);
00079         
00081         CIvfVec3d* getPoint(int idx);
00082         
00088         CIvfVec3d& getPosition(double t);
00089 
00091         void update();
00092 
00094         void setTangentWeight(int idx, double value);
00095 
00097         void setContinuity(int idx, double value);
00098         
00100         void setTension(int idx, double value);
00101 
00107         double getSpeed(double t);
00108 
00114         CIvfVec3d& getTangent(double t);
00115 };
00116 
00117 #endif 

Generated on Fri Sep 1 15:36:47 2006 for Interactive Visualisation Framework - Ivf++ by  doxygen 1.4.6-NO