17 #ifndef __WEIPA_SPECKLEYDOMAIN_H__ 18 #define __WEIPA_SPECKLEYDOMAIN_H__ 20 #include <weipa/DomainChunk.h> 21 #include <weipa/SpeckleyElements.h> 22 #include <boost/enable_shared_from_this.hpp> 43 virtual bool writeToSilo(DBfile* dbfile,
const std::string& pathInSilo,
70 #endif // __WEIPA_SPECKLEYDOMAIN_H__ SpeckleyNodes_ptr nodes
Definition: weipa/src/SpeckleyDomain.h:62
Represents a full Speckley domain including nodes and elements.
Definition: weipa/src/SpeckleyDomain.h:35
SpeckleyElements_ptr cells
Definition: weipa/src/SpeckleyDomain.h:63
virtual Centering getCenteringForFunctionSpace(int fsCode) const
Returns whether data on given function space is node or cell centered.
Definition: weipa/src/SpeckleyDomain.cpp:74
virtual StringVec getVarNames() const
Returns the names of all 'special' domain variables.
Definition: weipa/src/SpeckleyDomain.cpp:141
virtual void removeGhostZones(int ownIndex)
Removes 'ghost' elements and nodes.
Definition: weipa/src/SpeckleyDomain.cpp:216
virtual bool initFromFile(const std::string &filename)
Reads the domain from a dump file.
Definition: weipa/src/SpeckleyDomain.cpp:68
std::vector< std::string > StringVec
Definition: weipa.h:60
virtual bool initFromEscript(const escript::AbstractDomain *domain)
Initialises the domain using an escript domain instance.
Definition: weipa/src/SpeckleyDomain.cpp:49
virtual NodeData_ptr getMeshForFunctionSpace(int fsCode) const
Returns the node mesh for given function space code.
Definition: weipa/src/SpeckleyDomain.cpp:80
SpeckleyDomain()
Definition: weipa/src/SpeckleyDomain.cpp:35
std::string siloPath
Definition: weipa/src/SpeckleyDomain.h:65
virtual NodeData_ptr getNodes() const
Returns a pointer to the full nodes.
Definition: weipa/src/SpeckleyDomain.h:56
virtual ElementData_ptr getElementsByName(const std::string &name) const
Returns element data with given name.
Definition: weipa/src/SpeckleyDomain.cpp:188
virtual void reorderGhostZones(int ownIndex)
Reorders elements so that 'ghost' elements (i.e. those that do not belong to ownIndex) appear last...
Definition: weipa/src/SpeckleyDomain.cpp:211
virtual StringVec getMeshNames() const
Returns the names of all meshes within this domain.
Definition: weipa/src/SpeckleyDomain.cpp:125
Definition: DataVar.cpp:39
Abstract base class for weipa's interface to an Escript domain or one chunk thereof if domain decompo...
Definition: DomainChunk.h:45
virtual ElementData_ptr getElementsForFunctionSpace(int fsCode) const
Returns the element data for given function space code.
Definition: weipa/src/SpeckleyDomain.cpp:96
bool initialized
Definition: weipa/src/SpeckleyDomain.h:61
boost::shared_ptr< DataVar > DataVar_ptr
Definition: weipa.h:64
virtual bool writeToSilo(DBfile *dbfile, const std::string &pathInSilo, const StringVec &labels, const StringVec &units, bool writeMeshData)
Writes the domain to a Silo file.
Definition: weipa/src/SpeckleyDomain.cpp:221
boost::shared_ptr< SpeckleyElements > SpeckleyElements_ptr
Definition: SpeckleyElements.h:32
Centering
Definition: DomainChunk.h:30
virtual DataVar_ptr getDataVarByName(const std::string &name) const
Creates and returns a variable with domain data.
Definition: weipa/src/SpeckleyDomain.cpp:156
boost::shared_ptr< SpeckleyNodes > SpeckleyNodes_ptr
Definition: SpeckleyNodes.h:30
boost::shared_ptr< ElementData > ElementData_ptr
Definition: weipa.h:66
SpeckleyElements_ptr faces
Definition: weipa/src/SpeckleyDomain.h:64
virtual void setSiloPath(const std::string &path)
Sets the silo path to be used when saving to a Silo file.
Definition: weipa/src/SpeckleyDomain.h:58
Base class for all escript domains.
Definition: AbstractDomain.h:45
virtual std::string getSiloPath() const
Returns the absolute path within Silo file if writeToSilo() or setSiloPath() was called before...
Definition: weipa/src/SpeckleyDomain.h:57
virtual ~SpeckleyDomain()
Definition: weipa/src/SpeckleyDomain.h:40
boost::shared_ptr< NodeData > NodeData_ptr
Definition: weipa.h:68
virtual NodeData_ptr getMeshByName(const std::string &name) const
Returns the node mesh with given name.
Definition: weipa/src/SpeckleyDomain.cpp:199