IOSS  2.0
Ioss_Region.h
Go to the documentation of this file.
1 // Copyright(C) 1999-2017 National Technology & Engineering Solutions
2 // of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
3 // NTESS, the U.S. Government retains certain rights in this software.
4 //
5 // Redistribution and use in source and binary forms, with or without
6 // modification, are permitted provided that the following conditions are
7 // met:
8 //
9 // * Redistributions of source code must retain the above copyright
10 // notice, this list of conditions and the following disclaimer.
11 //
12 // * Redistributions in binary form must reproduce the above
13 // copyright notice, this list of conditions and the following
14 // disclaimer in the documentation and/or other materials provided
15 // with the distribution.
16 //
17 // * Neither the name of NTESS nor the names of its
18 // contributors may be used to endorse or promote products derived
19 // from this software without specific prior written permission.
20 //
21 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 
33 #ifndef IOSS_Ioss_Region_h
34 #define IOSS_Ioss_Region_h
35 
36 #include <Ioss_CoordinateFrame.h> // for CoordinateFrame
37 #include <Ioss_DatabaseIO.h> // for DatabaseIO
38 #include <Ioss_EntityType.h> // for EntityType, etc
39 #include <Ioss_GroupingEntity.h> // for GroupingEntity
40 #include <Ioss_MeshType.h>
41 #include <Ioss_Property.h> // for Property
42 #include <Ioss_State.h> // for State
43 #include <cstddef> // for size_t, nullptr
44 #include <cstdint> // for int64_t
45 #include <functional> // for less
46 #include <iosfwd> // for ostream
47 #include <map> // for map, map<>::value_compare
48 #include <string> // for string, operator<
49 #include <utility> // for pair
50 #include <vector> // for vector
51 namespace Ioss {
52  class CommSet;
53  class EdgeBlock;
54  class EdgeSet;
55  class ElementBlock;
56  class ElementSet;
57  class FaceBlock;
58  class FaceSet;
59  class Field;
60  class NodeBlock;
61  class NodeSet;
62  class SideBlock;
63  class SideSet;
64  class StructuredBlock;
65 } // namespace Ioss
66 // Needed for node_global_to_local inline function.
67 
68 namespace Ioss {
69 
70  class CoordinateFrame;
71 
72  using NodeBlockContainer = std::vector<NodeBlock *>;
73  using EdgeBlockContainer = std::vector<EdgeBlock *>;
74  using FaceBlockContainer = std::vector<FaceBlock *>;
75  using ElementBlockContainer = std::vector<ElementBlock *>;
76 
77  using NodeSetContainer = std::vector<NodeSet *>;
78  using EdgeSetContainer = std::vector<EdgeSet *>;
79  using FaceSetContainer = std::vector<FaceSet *>;
80  using ElementSetContainer = std::vector<ElementSet *>;
81 
82  using SideSetContainer = std::vector<SideSet *>;
83  using StructuredBlockContainer = std::vector<StructuredBlock *>;
84  using CommSetContainer = std::vector<CommSet *>;
85  using StateTimeContainer = std::vector<double>;
86 
87  using CoordinateFrameContainer = std::vector<CoordinateFrame>;
88 
89  using AliasMap = std::map<std::string, std::string, std::less<std::string>>;
90 
91  /** \brief A grouping entity that contains other grouping entities.
92  *
93  * Maintains a list of NodeBlocks, ElementBlocks, NodeLists, CommLists and Surfaces.
94  * [Similar to the "Composite Pattern" in Design Patterns] All interface to
95  * GroupingEntities is through the Region class; clients of the IO subsystem have no direct
96  * access to the underlying GroupingEntities (other than the Region).
97  */
98  class Region : public GroupingEntity
99  {
100  public:
101  explicit Region(DatabaseIO *iodatabase = nullptr, const std::string &my_name = "");
102 
103  ~Region() override;
104 
105  std::string type_string() const override { return "Region"; }
106  std::string short_type_string() const override { return "region"; }
107  EntityType type() const override { return REGION; }
108 
109  MeshType mesh_type() const;
110  const std::string mesh_type_string() const;
111  bool node_major() const;
112 
113  void output_summary(std::ostream &strm, bool do_transient = true);
114 
115  bool supports_field_type(Ioss::EntityType fld_type) const;
116 
117  // Helper function...
118  int64_t node_global_to_local(int64_t global, bool must_exist = true) const;
119 
120  bool begin_mode(State new_state);
121  bool end_mode(State current_state);
122 
123  // Add a new state at this time, return state number
124  virtual int add_state(double time)
125  {
126  IOSS_FUNC_ENTER(m_);
127  return add_state__(time);
128  }
129  virtual int add_state__(double time);
130 
131  // Get time corresponding to specified state
132 
133  virtual double get_state_time(int state = -1) const;
134  int get_current_state() const;
135  double begin_state(int state);
136  double end_state(int state);
137 
138  /** \brief Determine whether the metadata defining the model (nontransient,
139  * geometry, and toploloty) has been set.
140  *
141  * \returns True if the metadata defining the model has been set.
142  */
143  bool model_defined() const { return modelDefined; }
144 
145  /** \brief Determine whether the metadata related to the transient
146  * data has been set.
147  *
148  * \returns True if the metadata related to the transient data has been set.
149  */
150  bool transient_defined() const { return transientDefined; }
151 
152  // Return a pair consisting of the step (1-based) corresponding to
153  // the maximum time on the database and the corresponding maximum
154  // time value. Note that this may not necessarily be the last step
155  // on the database if cycle and overlay are being used.
156  std::pair<int, double> get_max_time() const;
157 
158  // Return a pair consisting of the step (1-based) corresponding to
159  // the minimum time on the database and the corresponding minimum
160  // time value. Note that this may not necessarily be the first step
161  // on the database if cycle and overlay are being used.
162  std::pair<int, double> get_min_time() const;
163 
164  // Functions for an output region...
165  bool add(NodeBlock *node_block);
166  bool add(EdgeBlock *edge_block);
167  bool add(FaceBlock *face_block);
168  bool add(ElementBlock *element_block);
169  bool add(SideSet *sideset);
170  bool add(NodeSet *nodeset);
171  bool add(EdgeSet *edgeset);
172  bool add(FaceSet *faceset);
173  bool add(ElementSet *elementset);
174  bool add(CommSet *commset);
175  bool add(StructuredBlock *structured_block);
176  bool add(const CoordinateFrame &frame);
177 
178  const NodeBlockContainer & get_node_blocks() const;
179  const EdgeBlockContainer & get_edge_blocks() const;
180  const FaceBlockContainer & get_face_blocks() const;
182  const SideSetContainer & get_sidesets() const;
183  const NodeSetContainer & get_nodesets() const;
184  const EdgeSetContainer & get_edgesets() const;
185  const FaceSetContainer & get_facesets() const;
186  const ElementSetContainer & get_elementsets() const;
187  const CommSetContainer & get_commsets() const;
190 
191  // Retrieve the Grouping Entity with the specified name.
192  // Returns nullptr if the entity does not exist
193  GroupingEntity * get_entity(const std::string &my_name, EntityType io_type) const;
194  GroupingEntity * get_entity(const std::string &my_name) const;
195  NodeBlock * get_node_block(const std::string &my_name) const;
196  EdgeBlock * get_edge_block(const std::string &my_name) const;
197  FaceBlock * get_face_block(const std::string &my_name) const;
198  ElementBlock * get_element_block(const std::string &my_name) const;
199  SideSet * get_sideset(const std::string &my_name) const;
200  SideBlock * get_sideblock(const std::string &my_name) const;
201  NodeSet * get_nodeset(const std::string &my_name) const;
202  EdgeSet * get_edgeset(const std::string &my_name) const;
203  FaceSet * get_faceset(const std::string &my_name) const;
204  ElementSet * get_elementset(const std::string &my_name) const;
205  CommSet * get_commset(const std::string &my_name) const;
206  StructuredBlock *get_structured_block(const std::string &my_name) const;
207 
208  const CoordinateFrame &get_coordinate_frame(int64_t id) const;
209 
210  // Add the name 'alias' as an alias for the database entity with the
211  // name 'db_name'. Returns true if alias added; false if problems
212  // adding alias.
213  bool add_alias(const std::string &db_name, const std::string &alias);
214  bool add_alias(const GroupingEntity *ge);
215  std::string get_alias(const std::string &alias) const;
216  std::string get_alias__(const std::string &alias) const; // Not locked by mutex
217 
218  const AliasMap &get_alias_map() const;
219 
220  /// Get a map containing all aliases defined for the entity with basename 'name'
221  int get_aliases(const std::string &my_name, std::vector<std::string> &aliases) const;
222 
223  // This routine transfers all relavant aliases from the 'this'
224  // region and applies them to the 'to' file.
225  void transfer_mesh_aliases(Region *to) const;
226 
227  // Ensure that the 'this' region has the same ids and names as the 'from' region.
228  void synchronize_id_and_name(const Region *from, bool sync_attribute_field_names = false);
229 
230  // Returns true if the passed in name refers to a known Entity
231  // defined on this region. If true, then 'type' (if non-nullptr) is
232  // filled in with the type of the entity; if false, then type (if
233  // non-nullptr) is set to 'INVALID' This function is defined to
234  // consolidate several distinct implementations of this code in
235  // client code. Because of this, the 'type' used in the client
236  // code is repeated here instead of something more generic.
237  bool is_valid_io_entity(const std::string &my_name, unsigned int io_type,
238  std::string *my_type = nullptr) const;
239 
240  // Retrieve the element block that contains the specified element
241  // The 'local_id' is the local database id (1-based), not the global id.
242  // returns nullptr if no element block contains this element (local_id <= 0
243  // or greater than number of elements in database)
244  ElementBlock *get_element_block(size_t local_id) const;
245 
246  // Retrieve the structured block that contains the specified node
247  // The 'global_offset' is the global offset (0-based)
248  // returns nullptr if no structured block contains this node (local_id <= 0
249  // or greater than number of cell-nodes in database)
250  StructuredBlock *get_structured_block(size_t global_offset) const;
251 
252  // Handle implicit properties -- These are calcuated from data stored
253  // in the grouping entity instead of having an explicit value assigned.
254  // An example would be 'element_block_count' for a region.
255  Property get_implicit_property(const std::string &my_name) const override;
256 
257  const std::vector<std::string> &get_information_records() const;
258  void add_information_records(const std::vector<std::string> &info);
259  void add_information_record(const std::string &info);
260 
261  const std::vector<std::string> &get_qa_records() const;
262  void add_qa_record(const std::string &code, const std::string &code_qa,
263  const std::string &date = "", const std::string &time = "");
264 
265  protected:
266  int64_t internal_get_field_data(const Field &field, void *data,
267  size_t data_size = 0) const override;
268 
269  int64_t internal_put_field_data(const Field &field, void *data,
270  size_t data_size = 0) const override;
271 
272  private:
273  // Add the name 'alias' as an alias for the database entity with the
274  // name 'db_name'. Returns true if alias added; false if problems
275  // adding alias. Not protected by mutex -- call internally only.
276  bool add_alias__(const std::string &db_name, const std::string &alias);
277  bool add_alias__(const GroupingEntity *ge);
278 
279  bool begin_mode__(State new_state);
280  bool end_mode__(State current_state);
281 
282  void delete_database() override;
283 
284  AliasMap aliases_; ///< Stores alias mappings
285 
286  // Containers for all grouping entities
291 
296 
302 
304  mutable int stateCount;
307  };
308 } // namespace Ioss
309 
310 /** \brief Get the index (1-based) of the currently-active state.
311  *
312  * \returns The index.
313  */
314 inline int Ioss::Region::get_current_state() const { return currentState; }
315 
317 {
318  return static_cast<unsigned int>((get_database()->entity_field_support() & fld_type) != 0u) != 0u;
319 }
320 
321 inline int64_t Ioss::Region::node_global_to_local(int64_t global, bool must_exist) const
322 {
323  return get_database()->node_global_to_local(global, must_exist);
324 }
325 
326 /** \brief Get all information records (informative strings) for the region's database.
327  *
328  * \returns The informative strings.
329  */
330 inline const std::vector<std::string> &Ioss::Region::get_information_records() const
331 {
332  IOSS_FUNC_ENTER(m_);
333  return get_database()->get_information_records();
334 }
335 
336 /** \brief Add multiple information records (informative strings) to the region's database.
337  *
338  * \param[in] info The strings to add.
339  */
340 inline void Ioss::Region::add_information_records(const std::vector<std::string> &info)
341 {
342  IOSS_FUNC_ENTER(m_);
343  return get_database()->add_information_records(info);
344 }
345 
346 /** \brief Add an information record (an informative string) to the region's database.
347  *
348  * \param[in] info The string to add.
349  */
350 inline void Ioss::Region::add_information_record(const std::string &info)
351 {
352  IOSS_FUNC_ENTER(m_);
353  return get_database()->add_information_record(info);
354 }
355 
356 /** \brief Add a QA record, which consists of 4 strings, to the region's database
357  *
358  * The 4 function parameters correspond to the 4 QA record strings.
359  *
360  * \param[in] code A descriptive code name, such as the application that modified the database.
361  * \param[in] code_qa A descriptive string, such as the version of the application that modified
362  * the database.
363  * \param[in] date A relevant date, such as the date the database was modified.
364  * \param[in] time A relevant time, such as the time the database was modified.
365  */
366 inline void Ioss::Region::add_qa_record(const std::string &code, const std::string &code_qa,
367  const std::string &date, const std::string &time)
368 {
369  IOSS_FUNC_ENTER(m_);
370  return get_database()->add_qa_record(code, code_qa, date, time);
371 }
372 
373 /** \brief Get all QA records, each of which consists of 4 strings, from the region's database.
374  *
375  * The 4 strings that make up a database QA record are:
376  *
377  * 1. A descriptive code name, such as the application that modified the database.
378  *
379  * 2. A descriptive string, such as the version of the application that modified the database.
380  *
381  * 3. A relevant date, such as the date the database was modified.
382  *
383  * 4. A relevant time, such as the time the database was modified.
384  *
385  * \returns All QA records in a single vector. Every 4 consecutive elements of the
386  * vector make up a single QA record.
387  */
388 inline const std::vector<std::string> &Ioss::Region::get_qa_records() const
389 {
390  IOSS_FUNC_ENTER(m_);
391  return get_database()->get_qa_records();
392 }
393 
394 #endif
Definition: Ioss_EntityType.h:52
bool modelDefined
Definition: Ioss_Region.h:305
const std::vector< std::string > & get_information_records() const
Get all information records (informative strings) for the region&#39;s database.
Definition: Ioss_Region.h:330
double end_state(int state)
End a state (moment in time).
Definition: Ioss_Region.C:918
const NodeSetContainer & get_nodesets() const
Get all the region&#39;s NodeSet objects.
Definition: Ioss_Region.C:1313
A named value that has a known type.
Definition: Ioss_Property.h:47
SideSet * get_sideset(const std::string &my_name) const
Get the side set with the given name.
Definition: Ioss_Region.C:1709
int currentState
Definition: Ioss_Region.h:303
StateTimeContainer stateTimes
Definition: Ioss_Region.h:301
SideBlock * get_sideblock(const std::string &my_name) const
Get the side block with the given name.
Definition: Ioss_Region.C:1730
bool begin_mode(State new_state)
Set the Region and the associated DatabaseIO to the given State.
Definition: Ioss_Region.C:530
The main namespace for the Ioss library.
Definition: Iocgns_DatabaseIO.h:50
std::vector< CoordinateFrame > CoordinateFrameContainer
Definition: Ioex_Utils.h:52
StructuredBlock * get_structured_block(const std::string &my_name) const
Get the structured block with the given name.
Definition: Ioss_Region.C:1688
An input or output Database.
Definition: Ioss_DatabaseIO.h:80
std::vector< FaceSet * > FaceSetContainer
Definition: Ioss_Region.h:79
bool end_mode(State current_state)
Return the Region and the associated DatabaseIO to STATE_CLOSED.
Definition: Ioss_Region.C:596
const AliasMap & get_alias_map() const
Get all original name / alias pairs for the region.
Definition: Ioss_Region.C:1486
std::map< std::string, std::string, std::less< std::string > > AliasMap
Definition: Ioss_Region.h:89
std::vector< NodeBlock * > NodeBlockContainer
Definition: Ioss_Region.h:72
CoordinateFrameContainer coordinateFrames
Definition: Ioss_Region.h:299
A collection of nodes.
Definition: Ioss_NodeSet.h:53
int64_t internal_get_field_data(const Field &field, void *data, size_t data_size=0) const override
Definition: Ioss_Region.C:2120
A collection of element faces with the same topology.
Definition: Ioss_FaceBlock.h:53
A collection of element faces.
Definition: Ioss_FaceSet.h:54
Base class for all &#39;grouping&#39; entities. The following derived classes are typical: ...
Definition: Ioss_GroupingEntity.h:93
ElementSetContainer elementSets
Definition: Ioss_Region.h:295
double begin_state(int state)
Begin a state (moment in time).
Definition: Ioss_Region.C:869
std::vector< StructuredBlock * > StructuredBlockContainer
Definition: Ioss_Region.h:83
void transfer_mesh_aliases(Region *to) const
Transfer all relevant aliases from this region to another region.
Definition: Ioss_Region.C:2134
int64_t node_global_to_local(int64_t global, bool must_exist=true) const
Definition: Ioss_Region.h:321
A collection of element edges.
Definition: Ioss_EdgeSet.h:54
NodeBlock * get_node_block(const std::string &my_name) const
Get the node block with the given name.
Definition: Ioss_Region.C:1604
FaceBlockContainer faceBlocks
Definition: Ioss_Region.h:289
A collection of element sides having the same topology.
Definition: Ioss_SideBlock.h:61
bool end_mode__(State current_state)
Definition: Ioss_Region.C:602
bool is_valid_io_entity(const std::string &my_name, unsigned int io_type, std::string *my_type=nullptr) const
Determine whether the entity with the given name and type exists.
Definition: Ioss_Region.C:1874
const EdgeBlockContainer & get_edge_blocks() const
Get all the region&#39;s EdgeBlock objects.
Definition: Ioss_Region.C:1283
CommSet * get_commset(const std::string &my_name) const
Get the comm set with the given name.
Definition: Ioss_Region.C:1832
EdgeBlock * get_edge_block(const std::string &my_name) const
Get the edge block with the given name.
Definition: Ioss_Region.C:1625
Property get_implicit_property(const std::string &my_name) const override
Get an implicit property – These are calcuated from data stored in the grouping entity instead of ha...
Definition: Ioss_Region.C:2004
EdgeBlockContainer edgeBlocks
Definition: Ioss_Region.h:288
int64_t internal_put_field_data(const Field &field, void *data, size_t data_size=0) const override
Definition: Ioss_Region.C:2125
State
Access states for a database.
Definition: Ioss_State.h:42
MeshType mesh_type() const
Definition: Ioss_Region.C:395
bool transient_defined() const
Determine whether the metadata related to the transient data has been set.
Definition: Ioss_Region.h:150
A collection of elements having the same topology.
Definition: Ioss_ElementBlock.h:48
std::vector< EdgeSet * > EdgeSetContainer
Definition: Ioss_Region.h:78
AliasMap aliases_
Stores alias mappings.
Definition: Ioss_Region.h:284
A structured zone – i,j,k.
Definition: Ioss_StructuredBlock.h:103
A collection of elements.
Definition: Ioss_ElementSet.h:54
EdgeSetContainer edgeSets
Definition: Ioss_Region.h:293
std::vector< CommSet * > CommSetContainer
Definition: Ioss_Region.h:84
int get_current_state() const
Get the index (1-based) of the currently-active state.
Definition: Ioss_Region.h:314
bool add_alias__(const std::string &db_name, const std::string &alias)
Definition: Ioss_Region.C:1414
std::string get_alias__(const std::string &alias) const
Definition: Ioss_Region.C:1450
~Region() override
Definition: Ioss_Region.C:332
std::vector< double > StateTimeContainer
Definition: Ioss_Region.h:85
bool supports_field_type(Ioss::EntityType fld_type) const
Definition: Ioss_Region.h:316
std::vector< EdgeBlock * > EdgeBlockContainer
Definition: Ioss_Region.h:73
std::vector< NodeSet * > NodeSetContainer
Definition: Ioss_Region.h:77
SideSetContainer sideSets
Definition: Ioss_Region.h:297
const StructuredBlockContainer & get_structured_blocks() const
Get all the region&#39;s StructuredBlock objects.
Definition: Ioss_Region.C:1301
void add_information_records(const std::vector< std::string > &info)
Add multiple information records (informative strings) to the region&#39;s database.
Definition: Ioss_Region.h:340
virtual int add_state(double time)
Definition: Ioss_Region.h:124
bool begin_mode__(State new_state)
Definition: Ioss_Region.C:555
bool transientDefined
Definition: Ioss_Region.h:306
const CoordinateFrame & get_coordinate_frame(int64_t id) const
Get the coordinate frame with the given id.
Definition: Ioss_Region.C:1853
StructuredBlockContainer structuredBlocks
Definition: Ioss_Region.h:300
A collection of all nodes in the region.
Definition: Ioss_NodeBlock.h:53
const CommSetContainer & get_commsets() const
Get all the region&#39;s CommSet objects.
Definition: Ioss_Region.C:1337
const ElementBlockContainer & get_element_blocks() const
Get all the region&#39;s ElementBlock objects.
Definition: Ioss_Region.C:1295
const FaceSetContainer & get_facesets() const
Get all the region&#39;s FaceSet objects.
Definition: Ioss_Region.C:1325
CommSetContainer commSets
Definition: Ioss_Region.h:298
const ElementSetContainer & get_elementsets() const
Get all the region&#39;s ElementSet objects.
Definition: Ioss_Region.C:1331
EntityType type() const override
Get the EntityType, which indicates the particular type of GroupingEntity this is.
Definition: Ioss_Region.h:107
const EdgeSetContainer & get_edgesets() const
Get all the region&#39;s EdgeSet objects.
Definition: Ioss_Region.C:1319
ElementBlockContainer elementBlocks
Definition: Ioss_Region.h:290
const std::string mesh_type_string() const
Definition: Ioss_Region.C:410
const CoordinateFrameContainer & get_coordinate_frames() const
Get all the region&#39;s CoordinateFrame objects.
Definition: Ioss_Region.C:1343
bool model_defined() const
Determine whether the metadata defining the model (nontransient, geometry, and toploloty) has been se...
Definition: Ioss_Region.h:143
void add_information_record(const std::string &info)
Add an information record (an informative string) to the region&#39;s database.
Definition: Ioss_Region.h:350
Definition: Ioss_CommSet.h:51
FaceSetContainer faceSets
Definition: Ioss_Region.h:294
const FaceBlockContainer & get_face_blocks() const
Get all the region&#39;s FaceBlock objects.
Definition: Ioss_Region.C:1289
FaceSet * get_faceset(const std::string &my_name) const
Get the face set with the given name.
Definition: Ioss_Region.C:1790
int stateCount
Definition: Ioss_Region.h:304
NodeSetContainer nodeSets
Definition: Ioss_Region.h:292
void output_summary(std::ostream &strm, bool do_transient=true)
Print a summary of entities in the region.
Definition: Ioss_Region.C:427
FaceBlock * get_face_block(const std::string &my_name) const
Get the face block with the given name.
Definition: Ioss_Region.C:1646
std::vector< char > data
Definition: cth_pressure_map.C:73
bool node_major() const
Definition: Ioss_Region.C:393
A grouping entity that contains other grouping entities.
Definition: Ioss_Region.h:98
std::string short_type_string() const override
Get a short name of the particular type of entity.
Definition: Ioss_Region.h:106
int get_aliases(const std::string &my_name, std::vector< std::string > &aliases) const
Get a map containing all aliases defined for the entity with basename &#39;name&#39;.
Definition: Ioss_Region.C:1468
virtual int add_state__(double time)
Add a state for a specified time.
Definition: Ioss_Region.C:704
NodeSet * get_nodeset(const std::string &my_name) const
Get the node set with the given name.
Definition: Ioss_Region.C:1748
ElementSet * get_elementset(const std::string &my_name) const
Get the element set with the given name.
Definition: Ioss_Region.C:1811
void add_qa_record(const std::string &code, const std::string &code_qa, const std::string &date="", const std::string &time="")
Add a QA record, which consists of 4 strings, to the region&#39;s database.
Definition: Ioss_Region.h:366
ElementBlock * get_element_block(const std::string &my_name) const
Get the element block with the given name.
Definition: Ioss_Region.C:1667
A collection of element sides.
Definition: Ioss_SideSet.h:59
void delete_database() override
Definition: Ioss_Region.C:391
Holds metadata for bulk data associated with a GroupingEntity.
Definition: Ioss_Field.h:47
bool add(NodeBlock *node_block)
Add a node block to the region.
Definition: Ioss_Region.C:996
std::vector< SideSet * > SideSetContainer
Definition: Ioss_Region.h:82
std::pair< int, double > get_max_time() const
Get the maximum time step index (1-based) and time for the region.
Definition: Ioss_Region.C:805
const SideSetContainer & get_sidesets() const
Get all the region&#39;s SideSet objects.
Definition: Ioss_Region.C:1307
MeshType
The mesh type – structured, unstructured, hybrid (future), or unknown.
Definition: Ioss_MeshType.h:39
const NodeBlockContainer & get_node_blocks() const
Get all the region&#39;s NodeBlock objects.
Definition: Ioss_Region.C:1277
std::vector< ElementBlock * > ElementBlockContainer
Definition: Ioss_Region.h:75
#define IOSS_FUNC_ENTER(m)
Definition: Ioss_CodeTypes.h:115
void synchronize_id_and_name(const Region *from, bool sync_attribute_field_names=false)
Ensure that the restart and results files have the same ids.
Definition: Ioss_Region.C:2187
Definition: Ioss_CoordinateFrame.h:42
EdgeSet * get_edgeset(const std::string &my_name) const
Get the edge set with the given name.
Definition: Ioss_Region.C:1769
EntityType
The particular type of GroupingEntity.
Definition: Ioss_EntityType.h:39
std::vector< FaceBlock * > FaceBlockContainer
Definition: Ioss_Region.h:74
Region(DatabaseIO *iodatabase=nullptr, const std::string &my_name="")
Constructor reads in all metadata from disk.
Definition: Ioss_Region.C:290
std::string type_string() const override
Get the name of the particular type of entity.
Definition: Ioss_Region.h:105
virtual double get_state_time(int state=-1) const
Get the time corresponding to the specified state or the currently active state.
Definition: Ioss_Region.C:753
std::string get_alias(const std::string &alias) const
Get the original name for an alias.
Definition: Ioss_Region.C:1444
A collection of element edges with the same topology.
Definition: Ioss_EdgeBlock.h:53
std::pair< int, double > get_min_time() const
Get the minimum time step index (1-based) and time for the region.
Definition: Ioss_Region.C:838
NodeBlockContainer nodeBlocks
Definition: Ioss_Region.h:287
std::vector< ElementSet * > ElementSetContainer
Definition: Ioss_Region.h:80
bool add_alias(const std::string &db_name, const std::string &alias)
Add an alias for a name in a region.
Definition: Ioss_Region.C:1408
GroupingEntity * get_entity(const std::string &my_name, EntityType io_type) const
Get an entity of a known EntityType.
Definition: Ioss_Region.C:1494
const std::vector< std::string > & get_qa_records() const
Get all QA records, each of which consists of 4 strings, from the region&#39;s database.
Definition: Ioss_Region.h:388