00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00023 #ifndef libmath_simplifier_h
00024 #define libmath_simplifier_h
00025
00026 #include <math++/visitor.h>
00027
00028 namespace math {
00029
00033 template<typename T>
00034 class TSimplifier : public TNodeVisitor<T> {
00035 public:
00037 static TNode<T> *simplify(const TNode<T> *AExpression);
00038
00039 private:
00040 TNode<T> *FResult;
00041
00042 private:
00043 TSimplifier();
00044
00046 T calculate(const TNode<T> *) const;
00047
00048 virtual void visit(TNumberNode<T> *);
00049 virtual void visit(TSymbolNode<T> *);
00050 virtual void visit(TParamNode<T> *);
00051
00052 virtual void visit(TPlusNode<T> *);
00053 virtual void visit(TNegNode<T> *);
00054
00055 virtual void visit(TMulNode<T> *);
00056 virtual void visit(TDivNode<T> *);
00057
00058 virtual void visit(TPowNode<T> *);
00059 virtual void visit(TSqrtNode<T> *);
00060
00061 virtual void visit(TSinNode<T> *);
00062 virtual void visit(TCosNode<T> *);
00063 virtual void visit(TTanNode<T> *);
00064 virtual void visit(TLnNode<T> *);
00065
00066 virtual void visit(TFuncNode<T> *);
00067 virtual void visit(TIfNode<T> *);
00068
00069 virtual void visit(TEquNode<T> *);
00070 virtual void visit(TUnEquNode<T> *);
00071 virtual void visit(TGreaterNode<T> *);
00072 virtual void visit(TLessNode<T> *);
00073 virtual void visit(TGreaterEquNode<T> *);
00074 virtual void visit(TLessEquNode<T> *);
00075 };
00076
00077 }
00078
00079 #include <math++/simplifier.tcc>
00080
00081 #endif