File indexing completed on 2025-01-18 10:03:26
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017 #ifndef _Expr_FunctionDerivative_HeaderFile
0018 #define _Expr_FunctionDerivative_HeaderFile
0019
0020 #include <Standard.hxx>
0021 #include <Standard_Type.hxx>
0022
0023 #include <Standard_Integer.hxx>
0024 #include <Expr_GeneralFunction.hxx>
0025 #include <Standard_Real.hxx>
0026 #include <Expr_Array1OfNamedUnknown.hxx>
0027 #include <TColStd_Array1OfReal.hxx>
0028 class Expr_GeneralExpression;
0029 class Expr_NamedUnknown;
0030 class TCollection_AsciiString;
0031
0032
0033 class Expr_FunctionDerivative;
0034 DEFINE_STANDARD_HANDLE(Expr_FunctionDerivative, Expr_GeneralFunction)
0035
0036
0037 class Expr_FunctionDerivative : public Expr_GeneralFunction
0038 {
0039
0040 public:
0041
0042
0043
0044
0045
0046 Standard_EXPORT Expr_FunctionDerivative(const Handle(Expr_GeneralFunction)& func, const Handle(Expr_NamedUnknown)& withX, const Standard_Integer deg);
0047
0048
0049 Standard_EXPORT Standard_Integer NbOfVariables() const Standard_OVERRIDE;
0050
0051
0052
0053
0054 Standard_EXPORT Handle(Expr_NamedUnknown) Variable (const Standard_Integer index) const Standard_OVERRIDE;
0055
0056
0057
0058
0059 Standard_EXPORT Standard_Real Evaluate (const Expr_Array1OfNamedUnknown& vars, const TColStd_Array1OfReal& values) const Standard_OVERRIDE;
0060
0061
0062 Standard_EXPORT Handle(Expr_GeneralFunction) Copy() const Standard_OVERRIDE;
0063
0064
0065 Standard_EXPORT Handle(Expr_GeneralFunction) Derivative (const Handle(Expr_NamedUnknown)& var) const Standard_OVERRIDE;
0066
0067
0068
0069 Standard_EXPORT Handle(Expr_GeneralFunction) Derivative (const Handle(Expr_NamedUnknown)& var, const Standard_Integer deg) const Standard_OVERRIDE;
0070
0071
0072
0073 Standard_EXPORT Standard_Boolean IsIdentical (const Handle(Expr_GeneralFunction)& func) const Standard_OVERRIDE;
0074
0075
0076 Standard_EXPORT Standard_Boolean IsLinearOnVariable (const Standard_Integer index) const Standard_OVERRIDE;
0077
0078
0079 Standard_EXPORT Handle(Expr_GeneralFunction) Function() const;
0080
0081
0082 Standard_EXPORT Standard_Integer Degree() const;
0083
0084
0085 Standard_EXPORT Handle(Expr_NamedUnknown) DerivVariable() const;
0086
0087 Standard_EXPORT TCollection_AsciiString GetStringName() const Standard_OVERRIDE;
0088
0089 Standard_EXPORT Handle(Expr_GeneralExpression) Expression() const;
0090
0091 Standard_EXPORT void UpdateExpression();
0092
0093
0094 friend class Expr_NamedFunction;
0095
0096
0097 DEFINE_STANDARD_RTTIEXT(Expr_FunctionDerivative,Expr_GeneralFunction)
0098
0099 protected:
0100
0101
0102
0103
0104 private:
0105
0106
0107 Handle(Expr_GeneralFunction) myFunction;
0108 Handle(Expr_GeneralExpression) myExp;
0109 Handle(Expr_NamedUnknown) myDerivate;
0110 Standard_Integer myDegree;
0111
0112
0113 };
0114
0115
0116
0117
0118
0119
0120
0121 #endif