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 _IMPLICITIZESURFACEALGO_H
00034 #define _IMPLICITIZESURFACEALGO_H
00035
00036
00037 #include "BernsteinTetrahedralPoly.h"
00038 #include "SplineSurface.h"
00039 #include "BaryCoordSystem.h"
00040
00041
00042 namespace Go {
00045
00046
00047
00070 class ImplicitizeSurfaceAlgo {
00071 public:
00073 ImplicitizeSurfaceAlgo() : tol_(3.0e-15) { }
00076 explicit ImplicitizeSurfaceAlgo(int deg) : deg_(deg), tol_(3.0e-15) { }
00080 ImplicitizeSurfaceAlgo(const SplineSurface& surf, int deg)
00081 : surf_(surf), deg_(deg), tol_(3.0e-15) { }
00082
00085 void useSplineSurface(const SplineSurface& surf)
00086 { surf_ = surf; }
00087
00090 void setDegree(int deg)
00091 { deg_ = deg; }
00092
00095 void setTolerance(double tol)
00096 { tol_ = tol; }
00097
00100 void perform();
00101
00107 void getResultData(BernsteinTetrahedralPoly& implicit,
00108 BaryCoordSystem3D& bc, double& sigma_min)
00109 {
00110 implicit = implicit_;
00111 bc = bc_;
00112 sigma_min = sigma_min_;
00113 }
00114
00115 private:
00116 SplineSurface surf_;
00117 BernsteinTetrahedralPoly implicit_;
00118 BaryCoordSystem3D bc_;
00119 int deg_;
00120 double tol_;
00121 double sigma_min_;
00122
00123 };
00124
00125
00127 }
00128
00129
00130 #endif // _IMPLICITIZESURFACEALGO_H
00131
00132