18 #ifndef __ESCRIPT_NULLDOMAIN_H__
19 #define __ESCRIPT_NULLDOMAIN_H__
49 virtual JMPI getMPI()
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;
83 virtual std::pair<int,DataTypes::dim_t> getDataShape(
int functionSpaceCode)
const;
89 virtual int getDim()
const {
return 1; }
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;
111 virtual const int* borrowListOfTagsInUse(
int functionSpaceCode)
const;
113 virtual void setTags(
int functionSpaceType,
int newTag,
const escript::Data& mask)
const;
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;
#define MPI_COMM_WORLD
Definition: EsysMPI.h:50
int MPI_Comm
Definition: EsysMPI.h:44
Base class for all escript domains.
Definition: AbstractDomain.h:51
Data represents a collection of datapoints.
Definition: Data.h:64
Definition: FunctionSpace.h:36
NullDomain provides a null value for domain. Needed for the construction of a default FunctionSpace.
Definition: NullDomain.h:41
virtual int getNumberOfTagsInUse(int) const
returns the number of tags in use and a pointer to an array with the number of tags in use
Definition: NullDomain.h:109
static int NullDomainFS
Definition: NullDomain.h:43
virtual bool isValidFunctionSpaceType(int fsCode) const
Returns true if the given integer is a valid function space type for this domain.
Definition: NullDomain.h:56
virtual int getMPISize() const
return the number of processors used for this domain
Definition: NullDomain.h:50
virtual int getDim() const
Returns the spatial dimension of the domain.
Definition: NullDomain.h:89
virtual MPI_Comm getMPIComm() const
get the communicator for this domain. Returns an integer on non-MPI builds Routine must be implemente...
Definition: NullDomain.h:54
bool supportsContactElements() const
Definition: NullDomain.h:115
virtual int getReducedSolutionCode() const
Definition: NullDomain.h:80
virtual void MPIBarrier() const
If compiled for MPI then execute an MPI_Barrier, else do nothing.
Definition: NullDomain.h:52
virtual int getSolutionCode() const
Definition: NullDomain.h:79
virtual const DataTypes::dim_t * borrowSampleReferenceIDs(int) const
Returns a borrowed pointer to the sample reference number id list.
Definition: NullDomain.h:87
virtual int getContinuousFunctionCode() const
Definition: NullDomain.h:74
virtual bool onMasterProcessor() const
Return true if on MPI master, else false.
Definition: NullDomain.h:53
static DataTypes::dim_t referenceID
Definition: NullDomain.h:44
virtual int getFunctionOnBoundaryCode() const
Definition: NullDomain.h:76
NullDomain()
Definition: NullDomain.h:47
virtual bool canTag(int) const
Checks if this domain allows tags for the specified functionSpaceCode.
Definition: NullDomain.h:105
virtual int getFunctionCode() const
Definition: NullDomain.h:75
virtual int getDiracDeltaFunctionsCode() const
Definition: NullDomain.h:81
virtual int getFunctionOnContactZeroCode() const
Definition: NullDomain.h:77
virtual bool probeInterpolationAcross(int, const AbstractDomain &, int) const
Definition: NullDomain.h:70
virtual int getFunctionOnContactOneCode() const
Definition: NullDomain.h:78
virtual bool operator!=(const AbstractDomain &other) const
Return true if given domains are not equal.
Definition: NullDomain.h:93
virtual int getMPIRank() const
return the number MPI rank of this processor
Definition: NullDomain.h:51
virtual int getTagFromSampleNo(int, DataTypes::index_t) const
Return the tag key for the given sample number.
Definition: NullDomain.h:85
#define ESCRIPT_DLL_API
Definition: escriptcore/src/system_dep.h:30
std::vector< int > ShapeType
The shape of a single datapoint.
Definition: DataTypes.h:44
index_t dim_t
Definition: DataTypes.h:66
int index_t
type for array/matrix indices used both globally and on each rank
Definition: DataTypes.h:61
Definition: AbstractContinuousDomain.cpp:23
boost::shared_ptr< JMPI_ > JMPI
Definition: EsysMPI.h:74