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