Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042 #ifndef SUNDANCE_FUNCTIONALPOLYNOMIAL_H
00043 #define SUNDANCE_FUNCTIONALPOLYNOMIAL_H
00044
00045 #include "SundanceDefs.hpp"
00046 #include "SundanceEvaluatableExpr.hpp"
00047
00048
00049 namespace Sundance
00050 {
00051 using namespace Sundance;
00052 using namespace Teuchos;
00053
00054
00055
00056
00057
00058
00059
00060
00061 class FunctionalPolynomial : public EvaluatableExpr
00062 {
00063 public:
00064
00065 FunctionalPolynomial(const RCP<ScalarExpr>& expr);
00066
00067 FunctionalPolynomial(const Map<int, RCP<ScalarExpr> >& funcs,
00068 const Map<int, Set<MultiIndex> >& funcMultiIndices,
00069 const Array<Map<MultipleDeriv, RCP<ScalarExpr> > > & coeffs);
00070
00071
00072 virtual ~FunctionalPolynomial() {;}
00073
00074
00075
00076 virtual Set<MultipleDeriv>
00077 internalFindW(int order, const EvalContext& context) const ;
00078
00079
00080
00081
00082 virtual RCP<ExprBase> getRcp() {return rcp(this);}
00083
00084
00085 virtual Evaluator* createEvaluator(const EvaluatableExpr* expr,
00086 const EvalContext& context) const ;
00087
00088
00089 RCP<FunctionalPolynomial> addPoly(const FunctionalPolynomial* other,
00090 int sign) const ;
00091
00092
00093 RCP<FunctionalPolynomial> multiplyPoly(const FunctionalPolynomial* other) const ;
00094
00095
00096 RCP<FunctionalPolynomial> multiplyScalar(const RCP<ScalarExpr>& alpha) const ;
00097
00098
00099 RCP<FunctionalPolynomial> addFunction(const RCP<ScalarExpr>& u,
00100 int sign) const ;
00101
00102
00103 static bool isConvertibleToPoly(const ScalarExpr* expr) ;
00104
00105
00106 static RCP<FunctionalPolynomial> toPoly(const RCP<ScalarExpr>& expr);
00107
00108
00109
00110
00111 virtual std::ostream& toText(std::ostream& os, bool paren) const ;
00112
00113
00114 virtual XMLObject toXML() const ;
00115
00116
00117 virtual bool lessThan(const ScalarExpr* other) const ;
00118
00119 private:
00120
00121
00122 Map<int, RCP<ScalarExpr> > funcs_;
00123
00124
00125 Map<int, Set<MultiIndex> > funcMultiIndices_;
00126
00127
00128 Array<Map<MultipleDeriv, RCP<ScalarExpr> > > coeffs_;
00129
00130
00131 Array<Set<MultipleDeriv> > keys_;
00132
00133
00134 Set<Deriv> findFuncsForSummation(const Set<MultipleDeriv>& prevSet,
00135 const MultipleDeriv& thisSet) const ;
00136
00137
00138
00139
00140
00141 MultipleDeriv successorTerm(const MultipleDeriv& md) const ;
00142
00143
00144 void stepRecurrence(int level, const Map<MultipleDeriv, std::string>& sPrev,
00145 Map<MultipleDeriv, std::string>& sCurr) const ;
00146
00147
00148 std::string evalString() const ;
00149 };
00150 }
00151
00152 #endif