escript  Revision_
RipleyNodes.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_RIPLEYNODES_H__
18 #define __WEIPA_RIPLEYNODES_H__
19 
20 #include <weipa/NodeData.h>
21 
22 class DBfile;
23 
24 namespace ripley {
25 class RipleyDomain;
26 }
27 
28 namespace weipa {
29 
30 class RipleyNodes;
31 typedef boost::shared_ptr<RipleyNodes> RipleyNodes_ptr;
32 
38 class RipleyNodes : public NodeData
39 {
40 public:
42  RipleyNodes(const std::string& meshName);
43 
44  RipleyNodes(RipleyNodes_ptr fullNodes, IntVec& requiredNodes,
45  const std::string& meshName);
46 
48  RipleyNodes(const RipleyNodes& m);
49 
51  virtual ~RipleyNodes();
52 
54  bool initFromRipley(const ripley::RipleyDomain* ripleyDomain);
55 
57  bool writeToSilo(DBfile* dbfile);
58 
60  virtual void writeCoordinatesVTK(std::ostream& os, int ownIndex);
61 
63  void setSiloPath(const std::string& path) { siloPath = path; }
64 
68  const IntVec& getVarDataByName(const std::string& name) const;
69 
71  virtual StringVec getVarNames() const;
72 
74  virtual std::string getName() const { return name; }
75 
77  std::string getFullSiloName() const;
78 
80  virtual const IntVec& getNodeIDs() const { return nodeID; }
81 
83  virtual const IntVec& getNodeDistribution() const { return nodeDist; }
84 
86  virtual const IntVec& getGlobalNodeIndices() const { return nodeID; }
87 
89  virtual const CoordArray& getCoords() const { return coords; }
90 
92  virtual int getNumDims() const { return numDims; }
93 
95  virtual int getNumNodes() const { return numNodes; }
96 
98  virtual int getGlobalNumNodes() const { return globalNumNodes; }
99 
100 protected:
102  int numDims;
103  int numNodes;
108  std::string name;
109  std::string siloPath;
110 };
111 
112 
113 inline std::string RipleyNodes::getFullSiloName() const
114 {
115  std::string result(siloPath);
116  if (result.length() == 0 || *result.rbegin() != '/')
117  result += '/';
118  result += name;
119  return result;
120 }
121 
122 } // namespace weipa
123 
124 #endif // __WEIPA_RIPLEYNODES_H__
125 
ripley
Definition: ripley/src/AbstractAssembler.h:24
weipa::RipleyNodes::getVarNames
virtual StringVec getVarNames() const
Returns a vector with the mesh variable names.
Definition: RipleyNodes.cpp:192
weipa::RipleyNodes::getNodeDistribution
virtual const IntVec & getNodeDistribution() const
Returns the node distribution array.
Definition: RipleyNodes.h:82
weipa::RipleyNodes::siloPath
std::string siloPath
the name of this node mesh
Definition: RipleyNodes.h:108
weipa::RipleyNodes::name
std::string name
node distribution
Definition: RipleyNodes.h:107
weipa::RipleyNodes::coords
CoordArray coords
Definition: RipleyNodes.h:100
ripley::RipleyDomain::getNumNodesPerDim
virtual const dim_t * getNumNodesPerDim() const =0
returns the number of nodes per MPI rank in each dimension
ripley::Nodes
Definition: Ripley.h:63
weipa::RipleyNodes::getNumDims
virtual int getNumDims() const
Returns the dimensionality of this mesh (2 or 3).
Definition: RipleyNodes.h:91
ripley::RipleyDomain::getNodeDistribution
virtual IndexVector getNodeDistribution() const =0
returns the node distribution vector
weipa
Definition: DataVar.cpp:49
weipa::RipleyNodes::~RipleyNodes
virtual ~RipleyNodes()
Virtual destructor.
Definition: RipleyNodes.cpp:108
weipa::RipleyNodes::getNodeIDs
virtual const IntVec & getNodeIDs() const
Returns the node ID array.
Definition: RipleyNodes.h:79
weipa::RipleyNodes::nodeDist
IntVec nodeDist
node tags
Definition: RipleyNodes.h:106
weipa::RipleyNodes::nodeID
IntVec nodeID
global number of nodes
Definition: RipleyNodes.h:104
weipa::RipleyNodes::getName
virtual std::string getName() const
Returns the name of this node mesh.
Definition: RipleyNodes.h:73
weipa::RipleyNodes
Stores and manipulates ripley mesh nodes.
Definition: RipleyNodes.h:37
paso::util::copy
void copy(dim_t N, double *out, const double *in)
out = in
Definition: PasoUtil.h:110
weipa::NodeData
Definition: NodeData.h:37
weipa::RipleyNodes::getVarDataByName
const IntVec & getVarDataByName(const std::string &name) const
Returns an array of nodal data by the given name.
Definition: RipleyNodes.cpp:179
ripley::RipleyDomain
RipleyDomain extends the AbstractContinuousDomain interface for the Ripley library and is the base cl...
Definition: ripley/src/RipleyDomain.h:112
ripley::RipleyDomain::getNumDataPointsGlobal
virtual dim_t getNumDataPointsGlobal() const =0
returns the number of data points summed across all MPI processes
escript::DataTypes::dim_t
index_t dim_t
Definition: DataTypes.h:87
weipa::IndexMap
std::map< int, size_t > IndexMap
Definition: weipa.h:61
weipa::CoordArray
std::vector< float * > CoordArray
Definition: weipa.h:60
weipa::RipleyNodes::getNumNodes
virtual int getNumNodes() const
Returns the number of mesh nodes.
Definition: RipleyNodes.h:94
weipa::RipleyNodes::getGlobalNumNodes
virtual int getGlobalNumNodes() const
Returns the total number of mesh nodes for a distributed mesh.
Definition: RipleyNodes.h:97
weipa::RipleyNodes::setSiloPath
void setSiloPath(const std::string &path)
Sets the silo path to be used when saving.
Definition: RipleyNodes.h:62
weipa::RipleyNodes::writeToSilo
bool writeToSilo(DBfile *dbfile)
Writes node data to a Silo file.
Definition: RipleyNodes.cpp:224
weipa::RipleyNodes::RipleyNodes
RipleyNodes(const std::string &meshName)
Constructor with mesh name.
Definition: RipleyNodes.cpp:37
weipa::RipleyNodes::getCoords
virtual const CoordArray & getCoords() const
Returns the coordinates of the mesh nodes.
Definition: RipleyNodes.h:88
weipa::RipleyNodes::initFromRipley
bool initFromRipley(const ripley::RipleyDomain *ripleyDomain)
Initialises with ripley domain.
Definition: RipleyNodes.cpp:118
ripley::RipleyDomain::getDim
virtual int getDim() const
returns the number of spatial dimensions of the domain
Definition: ripley/src/RipleyDomain.h:187
weipa::RipleyNodes::getGlobalNodeIndices
virtual const IntVec & getGlobalNodeIndices() const
Returns the global node index array.
Definition: RipleyNodes.h:85
weipa::RipleyNodes::nodeTag
IntVec nodeTag
node IDs
Definition: RipleyNodes.h:105
ripley::RipleyDomain::borrowSampleReferenceIDs
const dim_t * borrowSampleReferenceIDs(int fsType) const =0
returns the array of reference numbers for a function space type
ripley::IndexVector
std::vector< index_t > IndexVector
Definition: Ripley.h:55
weipa::RipleyNodes::writeCoordinatesVTK
virtual void writeCoordinatesVTK(std::ostream &os, int ownIndex)
Writes coordinates to a stream in VTK text format.
Definition: RipleyNodes.cpp:203
ripley::RipleyDomain::getLocalCoordinate
virtual double getLocalCoordinate(index_t index, int dim) const =0
returns the index'th coordinate value in given dimension for this rank
weipa::RipleyNodes::getFullSiloName
std::string getFullSiloName() const
Returns full Silo mesh name, e.g. "/block0000/Nodes".
Definition: RipleyNodes.h:112
weipa::StringVec
std::vector< std::string > StringVec
Definition: weipa.h:59
weipa::RipleyNodes::numDims
int numDims
x, y[, z] coordinates of nodes
Definition: RipleyNodes.h:101
weipa::RipleyNodes::numNodes
int numNodes
dimensionality (2 or 3)
Definition: RipleyNodes.h:102
weipa::RipleyNodes::globalNumNodes
int globalNumNodes
number of nodes
Definition: RipleyNodes.h:103
ripley::RipleyDomain::getDataShape
virtual std::pair< int, dim_t > getDataShape(int fsType) const
returns the number of data points per sample, and the number of samples as a pair.
Definition: ripley/src/RipleyDomain.cpp:150
weipa::IntVec
std::vector< int > IntVec
Definition: weipa.h:58
weipa::RipleyNodes_ptr
boost::shared_ptr< RipleyNodes > RipleyNodes_ptr
Definition: RipleyNodes.h:29