00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033 #ifndef _GOPROJECTCURVE_
00034 #define _GOPROJECTCURVE_
00035
00036 #include <boost/smart_ptr.hpp>
00037
00038 #include "Point.h"
00039 #include "EvalCurve.h"
00040 #include "SplineCurve.h"
00041 #include "SplineSurface.h"
00042
00043
00044 namespace Go
00045 {
00048
00049
00052
00053 class ProjectCurve : public EvalCurve
00054 {
00055 public:
00056
00073 ProjectCurve(boost::shared_ptr<Go::SplineCurve>& space_crv,
00074 boost::shared_ptr<Go::SplineSurface>& surf,
00075 boost::shared_ptr<Go::Point>& start_par_pt,
00076 boost::shared_ptr<Go::Point>& end_par_pt,
00077 double epsgeo,
00078 const RectDomain* domain_of_interest = NULL);
00079
00081 virtual ~ProjectCurve();
00082
00083
00084 virtual Go::Point eval( double t) const;
00085
00086
00087 virtual void eval(double t, int n, Go::Point der[]) const;
00088
00089
00090 virtual double start() const;
00091
00092
00093 virtual double end() const;
00094
00097 virtual int dim() const;
00098
00109 virtual bool approximationOK(double par, Go::Point approxpos,
00110 double tol1, double tol2) const;
00111
00112 private:
00113 const boost::shared_ptr<Go::SplineCurve> space_crv_;
00114 const boost::shared_ptr<Go::SplineSurface> surf_;
00115 const boost::shared_ptr<Go::Point> start_par_pt_;
00116 const boost::shared_ptr<Go::Point> end_par_pt_;
00117 const double epsgeo_;
00118 const RectDomain* domain_of_interest_;
00119
00120
00121 std::vector<double> createSeed(double tpar) const;
00122
00123 };
00124
00125
00127 }
00128
00129 #endif //_GOPROJECTCURVE_
00130