File indexing completed on 2026-06-25 08:29:36
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _GeomInt_ParFunctionOfMyGradientOfTheComputeLineBezierOfWLApprox_HeaderFile
0018 #define _GeomInt_ParFunctionOfMyGradientOfTheComputeLineBezierOfWLApprox_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_DefineAlloc.hxx>
0022 #include <Standard_Handle.hxx>
0023
0024 #include <GeomInt_TheMultiLineOfWLApprox.hxx>
0025 #include <Standard_Integer.hxx>
0026 #include <Standard_Real.hxx>
0027 #include <GeomInt_ParLeastSquareOfMyGradientOfTheComputeLineBezierOfWLApprox.hxx>
0028 #include <TColStd_HArray1OfInteger.hxx>
0029 #include <AppParCurves_HArray1OfConstraintCouple.hxx>
0030 #include <math_MultipleVarFunctionWithGradient.hxx>
0031 #include <AppParCurves_Constraint.hxx>
0032 class GeomInt_TheMultiLineOfWLApprox;
0033 class GeomInt_TheMultiLineToolOfWLApprox;
0034 class GeomInt_ParLeastSquareOfMyGradientOfTheComputeLineBezierOfWLApprox;
0035 class GeomInt_ResConstraintOfMyGradientOfTheComputeLineBezierOfWLApprox;
0036 class AppParCurves_MultiCurve;
0037
0038 class GeomInt_ParFunctionOfMyGradientOfTheComputeLineBezierOfWLApprox
0039 : public math_MultipleVarFunctionWithGradient
0040 {
0041 public:
0042 DEFINE_STANDARD_ALLOC
0043
0044
0045
0046 Standard_EXPORT GeomInt_ParFunctionOfMyGradientOfTheComputeLineBezierOfWLApprox(
0047 const GeomInt_TheMultiLineOfWLApprox& SSP,
0048 const Standard_Integer FirstPoint,
0049 const Standard_Integer LastPoint,
0050 const Handle(AppParCurves_HArray1OfConstraintCouple)& TheConstraints,
0051 const math_Vector& Parameters,
0052 const Standard_Integer Deg);
0053
0054
0055
0056 Standard_EXPORT Standard_Integer NbVariables() const;
0057
0058
0059
0060
0061
0062 Standard_EXPORT Standard_Boolean Value(const math_Vector& X, Standard_Real& F);
0063
0064
0065
0066 Standard_EXPORT Standard_Boolean Gradient(const math_Vector& X, math_Vector& G);
0067
0068
0069
0070 Standard_EXPORT Standard_Boolean Values(const math_Vector& X, Standard_Real& F, math_Vector& G);
0071
0072
0073 Standard_EXPORT const math_Vector& NewParameters() const;
0074
0075
0076
0077 Standard_EXPORT const AppParCurves_MultiCurve& CurveValue();
0078
0079
0080
0081 Standard_EXPORT Standard_Real Error(const Standard_Integer IPoint,
0082 const Standard_Integer CurveIndex) const;
0083
0084
0085
0086 Standard_EXPORT Standard_Real MaxError3d() const;
0087
0088
0089
0090 Standard_EXPORT Standard_Real MaxError2d() const;
0091
0092 Standard_EXPORT AppParCurves_Constraint
0093 FirstConstraint(const Handle(AppParCurves_HArray1OfConstraintCouple)& TheConstraints,
0094 const Standard_Integer FirstPoint) const;
0095
0096 Standard_EXPORT AppParCurves_Constraint
0097 LastConstraint(const Handle(AppParCurves_HArray1OfConstraintCouple)& TheConstraints,
0098 const Standard_Integer LastPoint) const;
0099
0100 protected:
0101
0102
0103 Standard_EXPORT void Perform(const math_Vector& X);
0104
0105 private:
0106 Standard_Boolean Done;
0107 GeomInt_TheMultiLineOfWLApprox MyMultiLine;
0108 AppParCurves_MultiCurve MyMultiCurve;
0109 Standard_Integer Degre;
0110 math_Vector myParameters;
0111 Standard_Real FVal;
0112 math_Vector ValGrad_F;
0113 math_Matrix MyF;
0114 math_Matrix PTLX;
0115 math_Matrix PTLY;
0116 math_Matrix PTLZ;
0117 math_Matrix A;
0118 math_Matrix DA;
0119 GeomInt_ParLeastSquareOfMyGradientOfTheComputeLineBezierOfWLApprox MyLeastSquare;
0120 Standard_Boolean Contraintes;
0121 Standard_Integer NbP;
0122 Standard_Integer NbCu;
0123 Standard_Integer Adeb;
0124 Standard_Integer Afin;
0125 Handle(TColStd_HArray1OfInteger) tabdim;
0126 Standard_Real ERR3d;
0127 Standard_Real ERR2d;
0128 Standard_Integer FirstP;
0129 Standard_Integer LastP;
0130 Handle(AppParCurves_HArray1OfConstraintCouple) myConstraints;
0131 };
0132
0133 #endif