escript  Revision_
weipa/src/RipleyDomain.h
Go to the documentation of this file.
1 
2 /*****************************************************************************
3 *
4 * Copyright (c) 2003-2018 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 by Centre for Geoscience Computing (GeoComp)
14 *
15 *****************************************************************************/
16 
17 #ifndef __WEIPA_RIPLEYDOMAIN_H__
18 #define __WEIPA_RIPLEYDOMAIN_H__
19 
20 #include <weipa/DomainChunk.h>
21 #include <weipa/RipleyElements.h>
22 #include <boost/enable_shared_from_this.hpp>
23 
24 namespace weipa {
25 
35 class RipleyDomain : public DomainChunk, public boost::enable_shared_from_this<RipleyDomain>
36 {
37 public:
38  RipleyDomain();
39  RipleyDomain(const RipleyDomain& m);
40  virtual ~RipleyDomain() {}
41  virtual bool initFromEscript(const escript::AbstractDomain* domain);
42  virtual bool initFromFile(const std::string& filename);
43  virtual bool writeToSilo(DBfile* dbfile, const std::string& pathInSilo,
44  const StringVec& labels, const StringVec& units,
45  bool writeMeshData);
46  virtual void reorderGhostZones(int ownIndex);
47  virtual void removeGhostZones(int ownIndex);
48  virtual StringVec getMeshNames() const;
49  virtual StringVec getVarNames() const;
50  virtual ElementData_ptr getElementsByName(const std::string& name) const;
51  virtual NodeData_ptr getMeshByName(const std::string& name) const;
52  virtual DataVar_ptr getDataVarByName(const std::string& name) const;
53  virtual Centering getCenteringForFunctionSpace(int fsCode) const;
54  virtual NodeData_ptr getMeshForFunctionSpace(int fsCode) const;
55  virtual ElementData_ptr getElementsForFunctionSpace(int fsCode) const;
56  virtual NodeData_ptr getNodes() const { return nodes; }
57  virtual std::string getSiloPath() const { return siloPath; }
58  virtual void setSiloPath(const std::string& path) { siloPath = path; }
59 
60 private:
61  bool initialized;
65  std::string siloPath;
66 };
67 
68 } // namespace weipa
69 
70 #endif // __WEIPA_RIPLEYDOMAIN_H__
71 
weipa::RipleyDomain::setSiloPath
virtual void setSiloPath(const std::string &path)
Sets the silo path to be used when saving to a Silo file.
Definition: weipa/src/RipleyDomain.h:81
weipa::RipleyDomain::reorderGhostZones
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/RipleyDomain.cpp:214
weipa::RipleyDomain::removeGhostZones
virtual void removeGhostZones(int ownIndex)
Removes 'ghost' elements and nodes.
Definition: weipa/src/RipleyDomain.cpp:227
weipa::RipleyDomain::cells
RipleyElements_ptr cells
Definition: weipa/src/RipleyDomain.h:86
weipa::DataVar_ptr
boost::shared_ptr< DataVar > DataVar_ptr
Definition: weipa.h:63
weipa
Definition: DataVar.cpp:49
weipa::RipleyDomain::nodes
RipleyNodes_ptr nodes
Definition: weipa/src/RipleyDomain.h:85
weipa::RipleyElements_ptr
boost::shared_ptr< RipleyElements > RipleyElements_ptr
Definition: RipleyElements.h:31
weipa::RipleyDomain::siloPath
std::string siloPath
Definition: weipa/src/RipleyDomain.h:88
weipa::RipleyDomain::writeToSilo
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/RipleyDomain.cpp:241
weipa::RipleyDomain::initFromEscript
virtual bool initFromEscript(const escript::AbstractDomain *domain)
Initialises the domain using an escript domain instance.
Definition: weipa/src/RipleyDomain.cpp:48
weipa::RipleyDomain::getVarNames
virtual StringVec getVarNames() const
Returns the names of all 'special' domain variables.
Definition: weipa/src/RipleyDomain.cpp:144
weipa::ElementData_ptr
boost::shared_ptr< ElementData > ElementData_ptr
Definition: weipa.h:65
weipa::RipleyDomain::initFromFile
virtual bool initFromFile(const std::string &filename)
Reads the domain from a dump file.
Definition: weipa/src/RipleyDomain.cpp:69
weipa::RipleyDomain::getDataVarByName
virtual DataVar_ptr getDataVarByName(const std::string &name) const
Creates and returns a variable with domain data.
Definition: weipa/src/RipleyDomain.cpp:159
weipa::RipleyDomain::faces
RipleyElements_ptr faces
Definition: weipa/src/RipleyDomain.h:87
weipa::RipleyDomain::~RipleyDomain
virtual ~RipleyDomain()
Definition: weipa/src/RipleyDomain.h:63
weipa::RipleyDomain::getElementsByName
virtual ElementData_ptr getElementsByName(const std::string &name) const
Returns element data with given name.
Definition: weipa/src/RipleyDomain.cpp:191
weipa::RipleyDomain::getElementsForFunctionSpace
virtual ElementData_ptr getElementsForFunctionSpace(int fsCode) const
Returns the element data for given function space code.
Definition: weipa/src/RipleyDomain.cpp:95
weipa::RipleyDomain::getMeshNames
virtual StringVec getMeshNames() const
Returns the names of all meshes within this domain.
Definition: weipa/src/RipleyDomain.cpp:128
weipa::RipleyDomain::getSiloPath
virtual std::string getSiloPath() const
Returns the absolute path within Silo file if writeToSilo() or setSiloPath() was called before,...
Definition: weipa/src/RipleyDomain.h:80
weipa::RipleyDomain::RipleyDomain
RipleyDomain()
Definition: weipa/src/RipleyDomain.cpp:34
weipa::RipleyDomain::initialized
bool initialized
Definition: weipa/src/RipleyDomain.h:84
weipa::NodeData_ptr
boost::shared_ptr< NodeData > NodeData_ptr
Definition: weipa.h:67
weipa::StringVec
std::vector< std::string > StringVec
Definition: weipa.h:59
weipa::RipleyDomain::getCenteringForFunctionSpace
virtual Centering getCenteringForFunctionSpace(int fsCode) const
Returns whether data on given function space is node or cell centered.
Definition: weipa/src/RipleyDomain.cpp:75
weipa::RipleyDomain::getMeshForFunctionSpace
virtual NodeData_ptr getMeshForFunctionSpace(int fsCode) const
Returns the node mesh for given function space code.
Definition: weipa/src/RipleyDomain.cpp:81
escript::AbstractDomain
Base class for all escript domains.
Definition: AbstractDomain.h:56
weipa::Centering
Centering
Definition: DomainChunk.h:29
weipa::RipleyDomain::getMeshByName
virtual NodeData_ptr getMeshByName(const std::string &name) const
Returns the node mesh with given name.
Definition: weipa/src/RipleyDomain.cpp:202
weipa::RipleyDomain::getNodes
virtual NodeData_ptr getNodes() const
Returns a pointer to the full nodes.
Definition: weipa/src/RipleyDomain.h:79
weipa::RipleyNodes_ptr
boost::shared_ptr< RipleyNodes > RipleyNodes_ptr
Definition: RipleyNodes.h:29