Go to the documentation of this file.
18 #ifndef __ESCRIPT_NULLDOMAIN_H__
19 #define __ESCRIPT_NULLDOMAIN_H__
43 static int NullDomainFS;
49 virtual JMPI getMPI()
const;
50 virtual int getMPISize()
const {
return 1; }
51 virtual int getMPIRank()
const {
return 0; }
52 virtual void MPIBarrier()
const {}
53 virtual bool onMasterProcessor()
const {
return true; }
56 virtual bool isValidFunctionSpaceType(
int fsCode)
const {
57 return fsCode==NullDomainFS;
60 virtual std::string getDescription()
const;
62 virtual std::string functionSpaceTypeAsString(
int functionSpaceType)
const;
66 virtual bool probeInterpolationOnDomain(
int functionSpaceType_source,
int functionSpaceType_target)
const;
74 virtual int getContinuousFunctionCode()
const {
return NullDomainFS; }
75 virtual int getFunctionCode()
const {
return NullDomainFS; }
76 virtual int getFunctionOnBoundaryCode()
const {
return NullDomainFS; }
77 virtual int getFunctionOnContactZeroCode()
const {
return NullDomainFS; }
78 virtual int getFunctionOnContactOneCode()
const {
return NullDomainFS; }
79 virtual int getSolutionCode()
const {
return NullDomainFS; }
80 virtual int getReducedSolutionCode()
const {
return NullDomainFS; }
81 virtual int getDiracDeltaFunctionsCode()
const {
return NullDomainFS; }
83 virtual std::pair<int,DataTypes::dim_t> getDataShape(
int functionSpaceCode)
const;
87 virtual const DataTypes::dim_t* borrowSampleReferenceIDs(
int)
const {
return &referenceID; }
89 virtual int getDim()
const {
return 1; }
91 virtual bool operator==(
const AbstractDomain& other)
const;
93 virtual bool operator!=(
const AbstractDomain& other)
const {
94 return !(*
this==other);
97 virtual void write(
const std::string& filename)
const;
99 virtual void dump(
const std::string& filename)
const;
101 virtual void setTagMap(
const std::string& name,
int tag);
103 virtual int getTag(
const std::string& name)
const;
105 virtual bool canTag(
int)
const {
return true; }
107 virtual std::string showTagNames()
const;
109 virtual int getNumberOfTagsInUse(
int)
const {
return 1; }
111 virtual const int* borrowListOfTagsInUse(
int functionSpaceCode)
const;
113 virtual void setTags(
int functionSpaceType,
int newTag,
const escript::Data& mask)
const;
115 bool supportsContactElements()
const {
return false; }
119 virtual signed char preferredInterpolationOnDomain(
120 int functionSpaceType_source,
121 int functionSpaceType_target)
const;
123 virtual bool commonFunctionSpace(
const std::vector<int>& fs,
124 int& resultcode)
const;
125 virtual bool isCellOriented(
int functionSpaceCode)
const;
126 virtual int getApproximationOrder(
const int functionSpaceCode)
const;
129 #ifdef ESYS_HAVE_BOOST_NUMPY
130 virtual boost::python::numpy::ndarray getNumpyX()
const;
141 const boost::python::tuple& filter)
const;
146 #endif // __ESCRIPT_NULLDOMAIN_H__
#define ESCRIPT_DLL_API
Definition: escriptcore/src/system_dep.h:30
virtual bool probeInterpolationOnDomain(int functionSpaceType_source, int functionSpaceType_target) const
True if interpolation is possible from source to target.
Definition: NullDomain.cpp:71
virtual std::string getDescription() const
Return a description for this domain.
Definition: NullDomain.cpp:47
virtual signed char preferredInterpolationOnDomain(int functionSpaceType_source, int functionSpaceType_target) const
Preferred direction of interpolation. If you really need to test for a particular direction,...
Definition: NullDomain.cpp:142
NullDomain provides a null value for domain. Needed for the construction of a default FunctionSpace.
Definition: NullDomain.h:54
Definition: DomainException.h:41
void throwStandardException(const std::string &functionName) const
Throw a standard exception. This function is called if any attempt is made to use a base class functi...
Definition: AbstractDomain.cpp:57
virtual escript::Data getNormal() const
Return boundary normals. The function space is chosen appropriately.
Definition: NullDomain.cpp:169
virtual void write(const std::string &filename) const
Writes the domain to an external file filename.
Definition: NullDomain.cpp:118
virtual void setToGradient(escript::Data &grad, const escript::Data &arg) const
Copies the gradient of arg into grad. The actual function space to be considered for the gradient is ...
Definition: NullDomain.cpp:178
Definition: FunctionSpace.h:49
const FunctionSpace & getFunctionSpace() const
Return the function space.
Definition: Data.h:463
virtual const int * borrowListOfTagsInUse(int functionSpaceCode) const
Definition: NullDomain.cpp:104
bool probeInterpolationAcross(int fsType_source, const escript::AbstractDomain &domain, int fsType_target, int dim)
Definition: CrossDomainCoupler.cpp:32
const_Domain_ptr getDomain() const
Returns the function space domain.
Definition: FunctionSpace.cpp:103
bool initialize(const std::string &simFile, const std::string &comment)
Definition: VisItControl.cpp:206
#define MPI_COMM_WORLD
Definition: EsysMPI.h:48
Data represents a collection of datapoints.
Definition: Data.h:64
virtual std::string functionSpaceTypeAsString(int functionSpaceType) const
Return a description for the given function space type code.
Definition: NullDomain.cpp:52
virtual bool ownSample(int fs_code, DataTypes::index_t id) const
True if this rank owns the sample(id) Must be implemented by the Domain adapter.
Definition: NullDomain.cpp:132
index_t dim_t
Definition: DataTypes.h:93
std::vector< int > ShapeType
The shape of a single datapoint.
Definition: DataTypes.h:71
virtual std::pair< int, DataTypes::dim_t > getDataShape(int functionSpaceCode) const
Returns the number of data points per sample, and the number of samples as a pair.
Definition: NullDomain.cpp:85
boost::shared_ptr< JMPI_ > JMPI
Definition: EsysMPI.h:72
virtual escript::Data randomFill(const DataTypes::ShapeType &shape, const FunctionSpace &what, long seed, const boost::python::tuple &filter) const
Fills the data object with filtered random values.
Definition: NullDomain.cpp:109
virtual escript::Data getSize() const
Returns the local size of samples. The function space is chosen appropriately.
Definition: NullDomain.cpp:182
virtual void setToX(escript::Data &out) const
Copies the location of data points on the domain into out. The actual function space to be considered...
Definition: NullDomain.cpp:207
virtual void dump(const std::string &filename) const
dumps the domain to an external file filename.
Definition: NullDomain.cpp:114
virtual void setTagMap(const std::string &name, int tag)
sets a map from a clear tag name to a tag key
Definition: NullDomain.cpp:157
virtual void setNewX(const escript::Data &arg)
Assigns new location to the domain.
Definition: NullDomain.cpp:165
virtual void setToNormal(escript::Data &out) const
Copies the surface normals at data points into out. The actual function space to be considered is def...
Definition: NullDomain.cpp:174
virtual void setTags(int functionSpaceType, int newTag, const escript::Data &mask) const
assigns new tag newTag to all samples of functionspace with a positive value of mask for any its samp...
Definition: NullDomain.cpp:161
virtual bool isCellOriented(int functionSpaceCode) const
returns true if data on this domain and a function space of type functionSpaceCode has to considered ...
Definition: NullDomain.cpp:127
static DataTypes::dim_t referenceID
Definition: NullDomain.h:72
virtual int getTag(const std::string &name) const
Return the tag key for tag name.
Definition: NullDomain.cpp:152
int index_t
type for array/matrix indices used both globally and on each rank
Definition: DataTypes.h:88
virtual std::string showTagNames() const
Returns all tag names in a single string sperated by commas.
Definition: NullDomain.cpp:147
Definition: AbstractContinuousDomain.cpp:23
virtual bool commonFunctionSpace(const std::vector< int > &fs, int &resultcode) const
given a vector of FunctionSpace type codes, pass back a code which then can all be interpolated to.
Definition: NullDomain.cpp:122
virtual escript::Data getX() const
Returns locations in the domain. The function space is chosen appropriately.
Definition: NullDomain.cpp:191
virtual void interpolateAcross(escript::Data &target, const escript::Data &source) const
Interpolates data given on source onto target where source and target are given on different domains.
Definition: NullDomain.cpp:80
int MPI_Comm
Definition: EsysMPI.h:42
virtual void setToSize(escript::Data &out) const
Copies the size of samples into out. The actual function space to be considered is defined by out....
Definition: NullDomain.cpp:187
Base class for all escript domains.
Definition: AbstractDomain.h:64
virtual bool operator==(const AbstractDomain &other) const
Return true if given domains are equal.
Definition: NullDomain.cpp:94
virtual int getApproximationOrder(const int functionSpaceCode) const
returns the approximation order used for a function space functionSpaceCode
Definition: NullDomain.cpp:137
virtual void interpolateOnDomain(escript::Data &target, const escript::Data &source) const
Interpolates data given on source onto target where source and target have to be given on the same do...
Definition: NullDomain.cpp:62
virtual JMPI getMPI() const
returns a shared pointer to the MPI information wrapper for this domain
Definition: NullDomain.cpp:57
static int NullDomainFS
Definition: NullDomain.h:71