escript  Revision_
weipa/src/FinleyDomain.h
Go to the documentation of this file.
1 
2 /*****************************************************************************
3 *
4 * Copyright (c) 2003-2016 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_FINLEYDOMAIN_H__
18 #define __WEIPA_FINLEYDOMAIN_H__
19 
20 #include <weipa/DomainChunk.h>
21 #include <weipa/FinleyElements.h>
22 #include <boost/enable_shared_from_this.hpp>
23 
24 namespace finley {
25  class Mesh;
26 }
27 
28 namespace weipa {
29 
41 class FinleyDomain : public DomainChunk, public boost::enable_shared_from_this<FinleyDomain>
42 {
43 public:
44  FinleyDomain();
45  FinleyDomain(const FinleyDomain& m);
46  virtual ~FinleyDomain();
47  virtual bool initFromEscript(const escript::AbstractDomain* domain);
48  virtual bool initFromFile(const std::string& filename);
49  virtual bool writeToSilo(DBfile* dbfile, const std::string& pathInSilo,
50  const StringVec& labels, const StringVec& units,
51  bool writeMeshData);
52  virtual void reorderGhostZones(int ownIndex);
53  virtual void removeGhostZones(int ownIndex);
54  virtual StringVec getMeshNames() const;
55  virtual StringVec getVarNames() const;
56  virtual ElementData_ptr getElementsByName(const std::string& name) const;
57  virtual NodeData_ptr getMeshByName(const std::string& name) const;
58  virtual DataVar_ptr getDataVarByName(const std::string& name) const;
59  virtual Centering getCenteringForFunctionSpace(int fsCode) const;
60  virtual NodeData_ptr getMeshForFunctionSpace(int fsCode) const;
61  virtual ElementData_ptr getElementsForFunctionSpace(int fsCode) const;
62  virtual NodeData_ptr getNodes() const { return nodes; }
63  virtual std::string getSiloPath() const { return siloPath; }
64  virtual void setSiloPath(const std::string& path) { siloPath = path; }
65 
66 private:
67  void cleanup();
68 
74  std::string siloPath;
75 };
76 
77 } // namespace weipa
78 
79 #endif // __WEIPA_FINLEYDOMAIN_H__
80 
Represents a full Finley or Dudley domain including nodes and elements.
Definition: weipa/src/FinleyDomain.h:41
virtual NodeData_ptr getNodes() const
Returns a pointer to the full nodes.
Definition: weipa/src/FinleyDomain.h:62
bool initialized
Definition: weipa/src/FinleyDomain.h:69
std::string siloPath
Definition: weipa/src/FinleyDomain.h:74
boost::shared_ptr< FinleyNodes > FinleyNodes_ptr
Definition: FinleyNodes.h:34
FinleyElements_ptr faces
Definition: weipa/src/FinleyDomain.h:72
boost::shared_ptr< FinleyElements > FinleyElements_ptr
Definition: FinleyElements.h:56
virtual void setSiloPath(const std::string &path)
Sets the silo path to be used when saving to a Silo file.
Definition: weipa/src/FinleyDomain.h:64
std::vector< std::string > StringVec
Definition: weipa.h:60
A suite of factory methods for creating various finley domains.
Definition: finley/src/Assemble.h:31
Definition: DataVar.cpp:39
Abstract base class for weipa&#39;s interface to an Escript domain or one chunk thereof if domain decompo...
Definition: DomainChunk.h:45
virtual std::string getSiloPath() const
Returns the absolute path within Silo file if writeToSilo() or setSiloPath() was called before...
Definition: weipa/src/FinleyDomain.h:63
FinleyElements_ptr cells
Definition: weipa/src/FinleyDomain.h:71
boost::shared_ptr< DataVar > DataVar_ptr
Definition: weipa.h:64
FinleyElements_ptr contacts
Definition: weipa/src/FinleyDomain.h:73
Centering
Definition: DomainChunk.h:30
boost::shared_ptr< ElementData > ElementData_ptr
Definition: weipa.h:66
Base class for all escript domains.
Definition: AbstractDomain.h:45
boost::shared_ptr< NodeData > NodeData_ptr
Definition: weipa.h:68
FinleyNodes_ptr nodes
Definition: weipa/src/FinleyDomain.h:70