// Created on: 1991-01-10 // 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_NamedUnknown_HeaderFile #define _Expr_NamedUnknown_HeaderFile #include #include #include #include #include #include #include #include class Expr_GeneralExpression; class Expr_NotAssigned; class Standard_OutOfRange; class Standard_NumericError; class Expr_InvalidAssignment; class Expr_InvalidOperand; class Expr_NotEvaluable; class TCollection_AsciiString; class Expr_NamedUnknown; DEFINE_STANDARD_HANDLE(Expr_NamedUnknown, Expr_NamedExpression) //! This class describes any variable of an expression. //! Assignment is treated directly in this class. class Expr_NamedUnknown : public Expr_NamedExpression { public: Standard_EXPORT Expr_NamedUnknown(const TCollection_AsciiString& name); //! Tests if an expression is assigned to . Standard_Boolean IsAssigned() const; //! If exists, returns the assigned expression. //! An exception is raised if the expression does not exist. Standard_EXPORT const Handle(Expr_GeneralExpression)& AssignedExpression() const; //! Assigns to expression. //! Raises exception if refers to . Standard_EXPORT void Assign (const Handle(Expr_GeneralExpression)& exp); //! Supresses the assigned expression void Deassign(); //! Returns the number of sub-expressions contained //! in ( >= 0) Standard_EXPORT Standard_Integer NbSubExpressions() const Standard_OVERRIDE; //! Returns the -th sub-expression of //! raises OutOfRange if > NbSubExpressions(me) Standard_EXPORT const Handle(Expr_GeneralExpression)& SubExpression (const Standard_Integer I) const Standard_OVERRIDE; //! Returns a GeneralExpression after replacement of //! NamedUnknowns by an associated expression and after //! values computation. Standard_EXPORT Handle(Expr_GeneralExpression) Simplified() const Standard_OVERRIDE; //! Returns a GeneralExpression after a simplification //! of the arguments of . Standard_EXPORT Handle(Expr_GeneralExpression) ShallowSimplified() const Standard_OVERRIDE; //! Returns a copy of having the same unknowns and functions. Standard_EXPORT Handle(Expr_GeneralExpression) Copy() const Standard_OVERRIDE; //! Tests if contains NamedUnknown. Standard_EXPORT Standard_Boolean ContainsUnknowns() const Standard_OVERRIDE; //! Tests if is contained in . Standard_EXPORT Standard_Boolean Contains (const Handle(Expr_GeneralExpression)& exp) const Standard_OVERRIDE; Standard_EXPORT Standard_Boolean IsLinear() const Standard_OVERRIDE; //! Returns the derivative on unknown of Standard_EXPORT Handle(Expr_GeneralExpression) Derivative (const Handle(Expr_NamedUnknown)& X) const Standard_OVERRIDE; //! Replaces all occurences of with in //! Raises InvalidOperand if contains . Standard_EXPORT void Replace (const Handle(Expr_NamedUnknown)& var, const Handle(Expr_GeneralExpression)& with) Standard_OVERRIDE; //! Returns the value of (as a Real) by //! replacement of by . //! Raises NotEvaluable if contains NamedUnknown not //! in or NumericError if result cannot be computed. Standard_EXPORT Standard_Real Evaluate (const Expr_Array1OfNamedUnknown& vars, const TColStd_Array1OfReal& vals) const Standard_OVERRIDE; DEFINE_STANDARD_RTTIEXT(Expr_NamedUnknown,Expr_NamedExpression) protected: private: Handle(Expr_GeneralExpression) myExpression; }; #include #endif // _Expr_NamedUnknown_HeaderFile