// Created on: 1991-01-14 // Created by: Arnaud BOUZY // Copyright (c) 1991-1999 Matra Datavision // Copyright (c) 1999-2014 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #ifndef _Expr_NamedFunction_HeaderFile #define _Expr_NamedFunction_HeaderFile #include #include #include #include #include #include #include #include #include class Expr_GeneralExpression; class Standard_OutOfRange; class Standard_DimensionMismatch; class Standard_NumericError; class Expr_NotEvaluable; class TCollection_AsciiString; class Expr_NamedUnknown; class Expr_GeneralFunction; class Expr_NamedFunction; DEFINE_STANDARD_HANDLE(Expr_NamedFunction, Expr_GeneralFunction) class Expr_NamedFunction : public Expr_GeneralFunction { public: //! Creates a function of given variables with name //! defined by the expression . Standard_EXPORT Expr_NamedFunction(const TCollection_AsciiString& name, const Handle(Expr_GeneralExpression)& exp, const Expr_Array1OfNamedUnknown& vars); //! Sets the name to . Standard_EXPORT void SetName (const TCollection_AsciiString& newname); //! Returns the name assigned to Standard_EXPORT TCollection_AsciiString GetName() const; //! Returns the number of variables of . Standard_EXPORT Standard_Integer NbOfVariables() const Standard_OVERRIDE; //! Returns the variable denoted by in . //! Raises OutOfRange if is greater than //! NbOfVariables of , or less than or equal to zero. Standard_EXPORT Handle(Expr_NamedUnknown) Variable (const Standard_Integer index) const Standard_OVERRIDE; //! Computes the value of with the given variables. //! Raises DimensionMismatch if Length(vars) is different from //! Length(values). Standard_EXPORT Standard_Real Evaluate (const Expr_Array1OfNamedUnknown& vars, const TColStd_Array1OfReal& values) const Standard_OVERRIDE; //! Returns a copy of with the same form. Standard_EXPORT Handle(Expr_GeneralFunction) Copy() const Standard_OVERRIDE; //! Returns Derivative of for variable . Standard_EXPORT Handle(Expr_GeneralFunction) Derivative (const Handle(Expr_NamedUnknown)& var) const Standard_OVERRIDE; //! Returns Derivative of for variable with //! degree . Standard_EXPORT Handle(Expr_GeneralFunction) Derivative (const Handle(Expr_NamedUnknown)& var, const Standard_Integer deg) const Standard_OVERRIDE; //! Tests if and are similar functions (same //! name and same used expression). Standard_EXPORT Standard_Boolean IsIdentical (const Handle(Expr_GeneralFunction)& func) const Standard_OVERRIDE; //! Tests if is linear on variable on range Standard_EXPORT Standard_Boolean IsLinearOnVariable (const Standard_Integer index) const Standard_OVERRIDE; Standard_EXPORT TCollection_AsciiString GetStringName() const Standard_OVERRIDE; //! Returns equivalent expression of . Standard_EXPORT Handle(Expr_GeneralExpression) Expression() const; //! Modifies expression of . //! Warning: Beware of derivatives. See FunctionDerivative Standard_EXPORT void SetExpression (const Handle(Expr_GeneralExpression)& exp); DEFINE_STANDARD_RTTIEXT(Expr_NamedFunction,Expr_GeneralFunction) protected: private: TCollection_AsciiString myName; Handle(Expr_GeneralExpression) myExp; Expr_Array1OfNamedUnknown myVariables; }; #endif // _Expr_NamedFunction_HeaderFile