File indexing completed on 2026-06-15 08:29:07
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _BRepApprox_BSpParFunctionOfMyBSplGradientOfTheComputeLineOfApprox_HeaderFile
0018 #define _BRepApprox_BSpParFunctionOfMyBSplGradientOfTheComputeLineOfApprox_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_DefineAlloc.hxx>
0022 #include <Standard_Handle.hxx>
0023
0024 #include <BRepApprox_TheMultiLineOfApprox.hxx>
0025 #include <Standard_Integer.hxx>
0026 #include <Standard_Real.hxx>
0027 #include <BRepApprox_BSpParLeastSquareOfMyBSplGradientOfTheComputeLineOfApprox.hxx>
0028 #include <TColStd_HArray1OfInteger.hxx>
0029 #include <AppParCurves_HArray1OfConstraintCouple.hxx>
0030 #include <math_MultipleVarFunctionWithGradient.hxx>
0031 #include <TColStd_Array1OfReal.hxx>
0032 #include <TColStd_Array1OfInteger.hxx>
0033 #include <math_IntegerVector.hxx>
0034 #include <AppParCurves_Constraint.hxx>
0035 class BRepApprox_TheMultiLineOfApprox;
0036 class BRepApprox_TheMultiLineToolOfApprox;
0037 class BRepApprox_BSpParLeastSquareOfMyBSplGradientOfTheComputeLineOfApprox;
0038 class AppParCurves_MultiBSpCurve;
0039 class math_Matrix;
0040
0041 class BRepApprox_BSpParFunctionOfMyBSplGradientOfTheComputeLineOfApprox
0042 : public math_MultipleVarFunctionWithGradient
0043 {
0044 public:
0045 DEFINE_STANDARD_ALLOC
0046
0047
0048
0049 Standard_EXPORT BRepApprox_BSpParFunctionOfMyBSplGradientOfTheComputeLineOfApprox(
0050 const BRepApprox_TheMultiLineOfApprox& SSP,
0051 const Standard_Integer FirstPoint,
0052 const Standard_Integer LastPoint,
0053 const Handle(AppParCurves_HArray1OfConstraintCouple)& TheConstraints,
0054 const math_Vector& Parameters,
0055 const TColStd_Array1OfReal& Knots,
0056 const TColStd_Array1OfInteger& Mults,
0057 const Standard_Integer NbPol);
0058
0059
0060
0061 Standard_EXPORT Standard_Integer NbVariables() const;
0062
0063
0064
0065
0066
0067 Standard_EXPORT Standard_Boolean Value(const math_Vector& X, Standard_Real& F);
0068
0069
0070
0071 Standard_EXPORT Standard_Boolean Gradient(const math_Vector& X, math_Vector& G);
0072
0073
0074
0075 Standard_EXPORT Standard_Boolean Values(const math_Vector& X, Standard_Real& F, math_Vector& G);
0076
0077
0078 Standard_EXPORT const math_Vector& NewParameters() const;
0079
0080
0081
0082 Standard_EXPORT AppParCurves_MultiBSpCurve CurveValue();
0083
0084
0085
0086 Standard_EXPORT Standard_Real Error(const Standard_Integer IPoint,
0087 const Standard_Integer CurveIndex);
0088
0089
0090
0091 Standard_EXPORT Standard_Real MaxError3d() const;
0092
0093
0094
0095 Standard_EXPORT Standard_Real MaxError2d() const;
0096
0097
0098
0099 Standard_EXPORT const math_Matrix& FunctionMatrix() const;
0100
0101
0102
0103 Standard_EXPORT const math_Matrix& DerivativeFunctionMatrix() const;
0104
0105
0106
0107
0108
0109 Standard_EXPORT const math_IntegerVector& Index() const;
0110
0111 Standard_EXPORT AppParCurves_Constraint
0112 FirstConstraint(const Handle(AppParCurves_HArray1OfConstraintCouple)& TheConstraints,
0113 const Standard_Integer FirstPoint) const;
0114
0115 Standard_EXPORT AppParCurves_Constraint
0116 LastConstraint(const Handle(AppParCurves_HArray1OfConstraintCouple)& TheConstraints,
0117 const Standard_Integer LastPoint) const;
0118
0119 Standard_EXPORT void SetFirstLambda(const Standard_Real l1);
0120
0121 Standard_EXPORT void SetLastLambda(const Standard_Real l2);
0122
0123 protected:
0124
0125
0126 Standard_EXPORT void Perform(const math_Vector& X);
0127
0128 private:
0129 Standard_Boolean Done;
0130 BRepApprox_TheMultiLineOfApprox MyMultiLine;
0131 AppParCurves_MultiBSpCurve MyMultiBSpCurve;
0132 Standard_Integer nbpoles;
0133 math_Vector myParameters;
0134 Standard_Real FVal;
0135 math_Vector ValGrad_F;
0136 math_Matrix MyF;
0137 math_Matrix PTLX;
0138 math_Matrix PTLY;
0139 math_Matrix PTLZ;
0140 math_Matrix A;
0141 math_Matrix DA;
0142 BRepApprox_BSpParLeastSquareOfMyBSplGradientOfTheComputeLineOfApprox MyLeastSquare;
0143 Standard_Boolean Contraintes;
0144 Standard_Integer NbP;
0145 Standard_Integer NbCu;
0146 Standard_Integer Adeb;
0147 Standard_Integer Afin;
0148 Handle(TColStd_HArray1OfInteger) tabdim;
0149 Standard_Real ERR3d;
0150 Standard_Real ERR2d;
0151 Standard_Integer FirstP;
0152 Standard_Integer LastP;
0153 Handle(AppParCurves_HArray1OfConstraintCouple) myConstraints;
0154 Standard_Real mylambda1;
0155 Standard_Real mylambda2;
0156 };
0157
0158 #endif