Go to the documentation of this file.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
00034
00035
00036
00037
00038 #ifndef NURBS_FITTING_CURVE_2D_ATDM_H
00039 #define NURBS_FITTING_CURVE_2D_ATDM_H
00040
00041 #include <pcl/surface/on_nurbs/nurbs_tools.h>
00042 #include <pcl/surface/on_nurbs/nurbs_data.h>
00043 #include <pcl/surface/on_nurbs/nurbs_solve.h>
00044 #include <pcl/surface/on_nurbs/fitting_curve_2d_apdm.h>
00045
00046 namespace pcl
00047 {
00048 namespace on_nurbs
00049 {
00050
00055 class FittingCurve2dATDM : public FittingCurve2dAPDM
00056 {
00057 public:
00058
00062 FittingCurve2dATDM (int order, NurbsDataCurve2d *data);
00063
00067 FittingCurve2dATDM (NurbsDataCurve2d *data, const ON_NurbsCurve &nc);
00068
00072 void
00073 assemble (const FittingCurve2dAPDM::Parameter ¶meter);
00074
00077 virtual double
00078 solve (double damp = 1.0);
00079
00082 virtual double
00083 updateCurve (double damp);
00084
00085 protected:
00087 virtual void
00088 addPointConstraint (const double ¶m, const Eigen::Vector2d &point, const Eigen::Vector2d &normal,
00089 double weight, unsigned &row);
00090
00092 virtual void
00093 addCageRegularisation (double weight, unsigned &row, const std::vector<double> &elements, double wConcav = 0.0);
00094
00096 virtual void
00097 assembleInterior (double wInt, double sigma2, double rScale, unsigned &row);
00098
00101 virtual void
00102 assembleClosestPoints (const std::vector<double> &elements, double weight, double sigma2, unsigned &row);
00103
00106 virtual void
00107 assembleClosestPoints (int res, double weight, unsigned &row);
00108
00109 };
00110 }
00111 }
00112
00113 #endif