File indexing completed on 2025-01-18 10:03:30
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _FEmTool_LinearFlexion_HeaderFile
0018 #define _FEmTool_LinearFlexion_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_Type.hxx>
0022
0023 #include <math_Matrix.hxx>
0024 #include <Standard_Integer.hxx>
0025 #include <FEmTool_ElementaryCriterion.hxx>
0026 #include <GeomAbs_Shape.hxx>
0027 #include <TColStd_HArray2OfInteger.hxx>
0028 #include <math_Vector.hxx>
0029
0030
0031 class FEmTool_LinearFlexion;
0032 DEFINE_STANDARD_HANDLE(FEmTool_LinearFlexion, FEmTool_ElementaryCriterion)
0033
0034
0035 class FEmTool_LinearFlexion : public FEmTool_ElementaryCriterion
0036 {
0037
0038 public:
0039
0040
0041 Standard_EXPORT FEmTool_LinearFlexion(const Standard_Integer WorkDegree, const GeomAbs_Shape ConstraintOrder);
0042
0043 Standard_EXPORT virtual Handle(TColStd_HArray2OfInteger) DependenceTable() const Standard_OVERRIDE;
0044
0045 Standard_EXPORT virtual Standard_Real Value() Standard_OVERRIDE;
0046
0047 Standard_EXPORT virtual void Hessian (const Standard_Integer Dimension1, const Standard_Integer Dimension2, math_Matrix& H) Standard_OVERRIDE;
0048
0049 Standard_EXPORT virtual void Gradient (const Standard_Integer Dimension, math_Vector& G) Standard_OVERRIDE;
0050
0051
0052
0053
0054 DEFINE_STANDARD_RTTIEXT(FEmTool_LinearFlexion,FEmTool_ElementaryCriterion)
0055
0056 protected:
0057
0058
0059
0060
0061 private:
0062
0063
0064 math_Matrix RefMatrix;
0065 Standard_Integer myOrder;
0066
0067
0068 };
0069
0070
0071
0072
0073
0074
0075
0076 #endif