File indexing completed on 2025-01-18 10:03:29
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _Extrema_FunctPSNorm_HeaderFile
0018 #define _Extrema_FunctPSNorm_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_DefineAlloc.hxx>
0022
0023 #include <gp_Pnt.hxx>
0024 #include <TColStd_SequenceOfReal.hxx>
0025 #include <Extrema_SequenceOfPOnSurf.hxx>
0026 #include <Standard_Boolean.hxx>
0027 #include <math_FunctionSetWithDerivatives.hxx>
0028 #include <math_Vector.hxx>
0029
0030 class Adaptor3d_Surface;
0031 class math_Matrix;
0032 class Extrema_POnSurf;
0033
0034
0035
0036
0037
0038
0039
0040
0041
0042
0043
0044
0045
0046
0047
0048
0049
0050
0051
0052
0053
0054
0055
0056 class Extrema_FuncPSNorm : public math_FunctionSetWithDerivatives
0057 {
0058 public:
0059
0060 DEFINE_STANDARD_ALLOC
0061
0062
0063 Standard_EXPORT Extrema_FuncPSNorm();
0064
0065 Standard_EXPORT Extrema_FuncPSNorm(const gp_Pnt& P, const Adaptor3d_Surface& S);
0066
0067
0068 Standard_EXPORT void Initialize (const Adaptor3d_Surface& S);
0069
0070
0071 Standard_EXPORT void SetPoint (const gp_Pnt& P);
0072
0073 Standard_EXPORT Standard_Integer NbVariables() const Standard_OVERRIDE;
0074
0075 Standard_EXPORT Standard_Integer NbEquations() const Standard_OVERRIDE;
0076
0077
0078 Standard_EXPORT Standard_Boolean Value (const math_Vector& UV, math_Vector& F) Standard_OVERRIDE;
0079
0080
0081 Standard_EXPORT Standard_Boolean Derivatives (const math_Vector& UV, math_Matrix& DF) Standard_OVERRIDE;
0082
0083
0084 Standard_EXPORT Standard_Boolean Values (const math_Vector& UV, math_Vector& F, math_Matrix& DF) Standard_OVERRIDE;
0085
0086
0087 Standard_EXPORT virtual Standard_Integer GetStateNumber() Standard_OVERRIDE;
0088
0089
0090 Standard_EXPORT Standard_Integer NbExt() const;
0091
0092
0093 Standard_EXPORT Standard_Real SquareDistance (const Standard_Integer N) const;
0094
0095
0096 Standard_EXPORT const Extrema_POnSurf& Point (const Standard_Integer N) const;
0097
0098 private:
0099
0100 gp_Pnt myP;
0101 const Adaptor3d_Surface* myS;
0102 Standard_Real myU;
0103 Standard_Real myV;
0104 gp_Pnt myPs;
0105 TColStd_SequenceOfReal mySqDist;
0106 Extrema_SequenceOfPOnSurf myPoint;
0107 Standard_Boolean myPinit;
0108 Standard_Boolean mySinit;
0109 };
0110 #endif