escript  Revision_
NullDomain.h
Go to the documentation of this file.
1 
2 /*****************************************************************************
3 *
4 * Copyright (c) 2003-2020 by The University of Queensland
5 * http://www.uq.edu.au
6 *
7 * Primary Business: Queensland, Australia
8 * Licensed under the Apache License, version 2.0
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Development until 2012 by Earth Systems Science Computational Center (ESSCC)
12 * Development 2012-2013 by School of Earth Sciences
13 * Development from 2014-2017 by Centre for Geoscience Computing (GeoComp)
14 * Development from 2019 by School of Earth and Environmental Sciences
15 **
16 *****************************************************************************/
17 
18 #ifndef __ESCRIPT_NULLDOMAIN_H__
19 #define __ESCRIPT_NULLDOMAIN_H__
20 
21 #include "system_dep.h"
22 #include "AbstractDomain.h"
23 
24 namespace escript {
25 
40 class ESCRIPT_DLL_API NullDomain : public AbstractDomain
41 {
42 private:
43  static int NullDomainFS;
44  static DataTypes::dim_t referenceID;
45 
46 public:
47  NullDomain() {}
48 
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; }
54  virtual MPI_Comm getMPIComm() const { return MPI_COMM_WORLD; }
55 
56  virtual bool isValidFunctionSpaceType(int fsCode) const {
57  return fsCode==NullDomainFS;
58  }
59 
60  virtual std::string getDescription() const;
61 
62  virtual std::string functionSpaceTypeAsString(int functionSpaceType) const;
63 
64  virtual void interpolateOnDomain(escript::Data& target,const escript::Data& source) const;
65 
66  virtual bool probeInterpolationOnDomain(int functionSpaceType_source,int functionSpaceType_target) const;
67 
68  virtual void interpolateAcross(escript::Data& target, const escript::Data& source) const;
69 
70  virtual bool probeInterpolationAcross(int, const AbstractDomain&, int) const {
71  return false;
72  }
73 
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; }
82 
83  virtual std::pair<int,DataTypes::dim_t> getDataShape(int functionSpaceCode) const;
84 
85  virtual int getTagFromSampleNo(int, DataTypes::index_t) const { return 1; }
86 
87  virtual const DataTypes::dim_t* borrowSampleReferenceIDs(int) const { return &referenceID; }
88 
89  virtual int getDim() const { return 1; }
90 
91  virtual bool operator==(const AbstractDomain& other) const;
92 
93  virtual bool operator!=(const AbstractDomain& other) const {
94  return !(*this==other);
95  }
96 
97  virtual void write(const std::string& filename) const;
98 
99  virtual void dump(const std::string& filename) const;
100 
101  virtual void setTagMap(const std::string& name, int tag);
102 
103  virtual int getTag(const std::string& name) const;
104 
105  virtual bool canTag(int) const { return true; }
106 
107  virtual std::string showTagNames() const;
108 
109  virtual int getNumberOfTagsInUse(int) const { return 1; }
110 
111  virtual const int* borrowListOfTagsInUse(int functionSpaceCode) const;
112 
113  virtual void setTags(int functionSpaceType, int newTag, const escript::Data& mask) const;
114 
115  bool supportsContactElements() const { return false; }
116 
117  virtual void setNewX(const escript::Data& arg);
118 
119  virtual signed char preferredInterpolationOnDomain(
120  int functionSpaceType_source,
121  int functionSpaceType_target) const;
122 
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;
127 
128  virtual escript::Data getX() const;
129 #ifdef ESYS_HAVE_BOOST_NUMPY
130  virtual boost::python::numpy::ndarray getNumpyX() const;
131 #endif
132  virtual escript::Data getNormal() const;
133  virtual escript::Data getSize() const;
134  virtual void setToX(escript::Data& out) const;
135  virtual void setToNormal(escript::Data& out) const;
136  virtual void setToSize(escript::Data& out) const;
137  virtual void setToGradient(escript::Data& grad, const escript::Data& arg) const;
138  virtual bool ownSample(int fs_code, DataTypes::index_t id) const;
139  virtual escript::Data randomFill(const DataTypes::ShapeType& shape,
140  const FunctionSpace& what, long seed,
141  const boost::python::tuple& filter) const;
142 };
143 
144 } // end of namespace
145 
146 #endif // __ESCRIPT_NULLDOMAIN_H__
147 
ESCRIPT_DLL_API
#define ESCRIPT_DLL_API
Definition: escriptcore/src/system_dep.h:29
escript::NullDomain::probeInterpolationOnDomain
virtual bool probeInterpolationOnDomain(int functionSpaceType_source, int functionSpaceType_target) const
True if interpolation is possible from source to target.
Definition: NullDomain.cpp:69
escript::NullDomain::getDescription
virtual std::string getDescription() const
Return a description for this domain.
Definition: NullDomain.cpp:45
getTag
int getTag(unsigned char sourcex, unsigned char sourcey, unsigned char sourcez, unsigned char targetx, unsigned char targety, unsigned char targetz)
Definition: blocktools.cpp:413
escript::NullDomain::preferredInterpolationOnDomain
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:140
escript::NullDomain
NullDomain provides a null value for domain. Needed for the construction of a default FunctionSpace.
Definition: NullDomain.h:52
escript::DomainException
Definition: DomainException.h:39
escript::AbstractDomain::throwStandardException
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:56
escript::NullDomain::getNormal
virtual escript::Data getNormal() const
Return boundary normals. The function space is chosen appropriately.
Definition: NullDomain.cpp:167
escript::NullDomain::write
virtual void write(const std::string &filename) const
Writes the domain to an external file filename.
Definition: NullDomain.cpp:116
escript::NullDomain::setToGradient
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:176
escript::FunctionSpace
Definition: FunctionSpace.h:47
escript::Data::getFunctionSpace
const FunctionSpace & getFunctionSpace() const
Return the function space.
Definition: Data.h:462
escript::NullDomain::borrowListOfTagsInUse
virtual const int * borrowListOfTagsInUse(int functionSpaceCode) const
Definition: NullDomain.cpp:102
speckley::probeInterpolationAcross
bool probeInterpolationAcross(int fsType_source, const escript::AbstractDomain &domain, int fsType_target, int dim)
Definition: CrossDomainCoupler.cpp:31
escript::FunctionSpace::getDomain
const_Domain_ptr getDomain() const
Returns the function space domain.
Definition: FunctionSpace.cpp:102
weipa::VisItControl::initialize
bool initialize(const std::string &simFile, const std::string &comment)
Definition: VisItControl.cpp:203
system_dep.h
MPI_COMM_WORLD
#define MPI_COMM_WORLD
Definition: EsysMPI.h:47
escript::Data
Data represents a collection of datapoints.
Definition: Data.h:63
escript::NullDomain::functionSpaceTypeAsString
virtual std::string functionSpaceTypeAsString(int functionSpaceType) const
Return a description for the given function space type code.
Definition: NullDomain.cpp:50
escript::NullDomain::ownSample
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:130
escript::DataTypes::dim_t
index_t dim_t
Definition: DataTypes.h:90
escript::DataTypes::ShapeType
std::vector< int > ShapeType
The shape of a single datapoint.
Definition: DataTypes.h:68
escript::NullDomain::getDataShape
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:83
escript::JMPI
boost::shared_ptr< JMPI_ > JMPI
Definition: EsysMPI.h:71
escript::NullDomain::randomFill
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:107
DomainException.h
escript::NullDomain::getSize
virtual escript::Data getSize() const
Returns the local size of samples. The function space is chosen appropriately.
Definition: NullDomain.cpp:180
AbstractDomain.h
escript::NullDomain::setToX
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:205
escript::NullDomain::dump
virtual void dump(const std::string &filename) const
dumps the domain to an external file filename.
Definition: NullDomain.cpp:112
escript::NullDomain::setTagMap
virtual void setTagMap(const std::string &name, int tag)
sets a map from a clear tag name to a tag key
Definition: NullDomain.cpp:155
escript::NullDomain::setNewX
virtual void setNewX(const escript::Data &arg)
Assigns new location to the domain.
Definition: NullDomain.cpp:163
escript::NullDomain::setToNormal
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:172
escript::NullDomain::setTags
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:159
escript::NullDomain::isCellOriented
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:125
escript::NullDomain::referenceID
static DataTypes::dim_t referenceID
Definition: NullDomain.h:69
escript::NullDomain::getTag
virtual int getTag(const std::string &name) const
Return the tag key for tag name.
Definition: NullDomain.cpp:150
escript::DataTypes::index_t
int index_t
type for array/matrix indices used both globally and on each rank
Definition: DataTypes.h:85
escript::NullDomain::showTagNames
virtual std::string showTagNames() const
Returns all tag names in a single string sperated by commas.
Definition: NullDomain.cpp:145
escript
Definition: AbstractContinuousDomain.cpp:23
escript::NullDomain::commonFunctionSpace
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:120
NullDomain.h
escript::NullDomain::getX
virtual escript::Data getX() const
Returns locations in the domain. The function space is chosen appropriately.
Definition: NullDomain.cpp:189
escript::NullDomain::interpolateAcross
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:78
MPI_Comm
int MPI_Comm
Definition: EsysMPI.h:41
escript::NullDomain::setToSize
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:185
Data.h
escript::AbstractDomain
Base class for all escript domains.
Definition: AbstractDomain.h:62
escript::NullDomain::operator==
virtual bool operator==(const AbstractDomain &other) const
Return true if given domains are equal.
Definition: NullDomain.cpp:92
escript::NullDomain::getApproximationOrder
virtual int getApproximationOrder(const int functionSpaceCode) const
returns the approximation order used for a function space functionSpaceCode
Definition: NullDomain.cpp:135
escript::NullDomain::interpolateOnDomain
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:60
escript::NullDomain::getMPI
virtual JMPI getMPI() const
returns a shared pointer to the MPI information wrapper for this domain
Definition: NullDomain.cpp:55
escript::NullDomain::NullDomainFS
static int NullDomainFS
Definition: NullDomain.h:68