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 _IMPLICITIZECURVEALGO_H
00034 #define _IMPLICITIZECURVEALGO_H
00035
00036
00037 #include "BernsteinTriangularPoly.h"
00038 #include "SplineCurve.h"
00039 #include "BaryCoordSystem.h"
00040
00041
00042 namespace Go {
00045
00046
00047
00069 class ImplicitizeCurveAlgo {
00070 public:
00072 ImplicitizeCurveAlgo() : tol_(3.0e-15) { }
00075 explicit ImplicitizeCurveAlgo(int deg) : deg_(deg), tol_(3.0e-15) { }
00079 ImplicitizeCurveAlgo(const SplineCurve& curve, int deg)
00080 : curve_(curve), deg_(deg), tol_(3.0e-15) { }
00081
00084 void useSplineCurve(const SplineCurve& curve)
00085 { curve_ = curve; }
00086
00089 void setDegree(int deg)
00090 { deg_ = deg; }
00091
00094 void setTolerance(double tol)
00095 { tol_ = tol; }
00096
00099 void perform();
00100
00106 void getResultData(BernsteinTriangularPoly& implicit,
00107 BaryCoordSystem2D& bc, double& sigma_min)
00108 {
00109 implicit = implicit_;
00110 bc = bc_;
00111 sigma_min = sigma_min_;
00112 }
00113
00114 private:
00115 SplineCurve curve_;
00116 BernsteinTriangularPoly implicit_;
00117 BaryCoordSystem2D bc_;
00118 int deg_;
00119 double tol_;
00120 double sigma_min_;
00121
00122 };
00123
00124
00126 }
00127
00128
00129 #endif // _IMPLICITIZECURVEALGO_H
00130
00131