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_DISCRETEFUNCTION_H
00043 #define SUNDANCE_DISCRETEFUNCTION_H
00044
00045 #include "SundanceDefs.hpp"
00046 #include "SundanceExpr.hpp"
00047 #include "SundanceDiscreteFunctionStub.hpp"
00048 #include "SundanceDiscreteFunctionData.hpp"
00049 #include "SundanceFuncWithBasis.hpp"
00050 #include "SundanceDiscreteSpace.hpp"
00051 #include "PlayaVectorDecl.hpp"
00052
00053 namespace Sundance
00054 {
00055 using namespace Teuchos;
00056
00057
00058
00059
00060
00061
00062 class DiscreteFunction : public DiscreteFunctionStub,
00063 public FuncWithBasis
00064 {
00065 public:
00066
00067 DiscreteFunction(const DiscreteSpace& space, const std::string& name="");
00068
00069
00070 DiscreteFunction(const DiscreteSpace& space, const Vector<double>& vec,
00071 const std::string& name="");
00072
00073
00074 DiscreteFunction(const DiscreteSpace& space, const double& constantValue,
00075 const std::string& name="");
00076
00077 DiscreteFunction(const DiscreteSpace& space, const Array<string>& names);
00078
00079
00080 DiscreteFunction(const DiscreteSpace& space, const Vector<double>& vec,
00081 const Array<string>& names);
00082
00083
00084 DiscreteFunction(const DiscreteSpace& space, const double& constantValue,
00085 const Array<string>& name);
00086
00087
00088 static const DiscreteFunction* discFunc(const Expr& expr);
00089
00090
00091
00092 static DiscreteFunction* discFunc(Expr& expr);
00093
00094
00095 void updateGhosts() const ;
00096
00097
00098 void setVector(const Vector<double>& vec);
00099
00100
00101 const Vector<double>& getVector() const
00102 {return data_->getVector();}
00103
00104
00105 const DiscreteSpace& discreteSpace() const
00106 {return data_->discreteSpace();}
00107
00108
00109 const Mesh& mesh() const {return discreteSpace().mesh();}
00110
00111
00112 const RCP<DOFMapBase>& map() const {return discreteSpace().map();}
00113
00114
00115 RCP<GhostView<double> > ghostView() const
00116 {return data_->ghostView();}
00117
00118 const DiscreteFunctionData* data() const {return data_.get();}
00119
00120
00121
00122 virtual ~DiscreteFunction() {;}
00123
00124
00125 GET_RCP(ExprBase);
00126
00127
00128
00129 RCP<const MapStructure> getLocalValues(int cellDim,
00130 const Array<int>& cellLID,
00131 Array<Array<double> >& localValues) const ;
00132
00133
00134 private:
00135
00136 RCP<DiscreteFuncDataStub> getRCP(DiscreteFunctionData* ptr);
00137
00138 RCP<DiscreteFunctionData> data_;
00139
00140 };
00141
00142
00143
00144
00145
00146 void updateDiscreteFunction(const Expr& newVals, Expr oldVals);
00147
00148
00149
00150
00151
00152
00153 Expr copyDiscreteFunction(const Expr& u0, const string& name = "");
00154
00155
00156
00157
00158
00159 void addVecToDiscreteFunction(Expr u, const Vector<double>& v);
00160
00161
00162
00163
00164 Vector<double> getDiscreteFunctionVector(const Expr& u);
00165
00166
00167
00168
00169
00170 void setDiscreteFunctionVector(Expr u, const Vector<double>& v);
00171
00172
00173
00174
00175
00176 Mesh getDiscreteFunctionMesh(const Expr& u);
00177
00178
00179
00180
00181
00182 DiscreteSpace getDiscreteSpace(const Expr& u);
00183
00184
00185 }
00186
00187
00188
00189 #endif