Go to the documentation of this file.
33 #ifndef IOSS_Iocgns_ParallelDatabaseIO_h
34 #define IOSS_Iocgns_ParallelDatabaseIO_h
59 class ElementTopology;
87 const std::string
get_format()
const override {
return "CGNS";}
135 size_t data_size)
const override;
137 size_t data_size)
const override;
139 size_t data_size)
const override;
141 size_t data_size)
const override;
143 size_t data_size)
const override;
145 void *
data,
size_t data_size)
const override;
147 size_t data_size)
const override;
149 size_t data_size)
const override;
151 size_t data_size)
const override;
153 size_t data_size)
const override;
155 size_t data_size)
const override;
157 size_t data_size)
const override;
159 size_t data_size)
const override;
162 void *
data,
size_t data_size)
const;
165 size_t data_size)
const override;
167 size_t data_size)
const override;
169 size_t data_size)
const override;
171 size_t data_size)
const override;
173 size_t data_size)
const override;
175 void *
data,
size_t data_size)
const override;
177 size_t data_size)
const override;
179 size_t data_size)
const override;
181 size_t data_size)
const override;
183 size_t data_size)
const override;
185 size_t data_size)
const override;
187 size_t data_size)
const override;
189 size_t data_size)
const override;
192 void *
data,
size_t data_size)
const;
200 size_t offset,
size_t count)
const;
204 size_t &owned_node_count,
size_t &owned_node_offset)
const;
211 mutable std::unique_ptr<DecompositionDataBase>
decomp;
219 mutable std::vector<size_t>
int64_t handle_node_ids(void *ids, int64_t num_to_get) const
Definition: Iocgns_ParallelDatabaseIO.C:2426
void read_meta_data__() override
Definition: Iocgns_ParallelDatabaseIO.C:352
bool begin_state__(int state, double time) override
Definition: Iocgns_ParallelDatabaseIO.C:939
MeshType
The mesh type – structured, unstructured, hybrid (future), or unknown.
Definition: Ioss_MeshType.h:39
std::map< int, Ioss::Map * > m_globalToBlockLocalNodeMap
Definition: Iocgns_ParallelDatabaseIO.h:223
const std::string get_format() const override
Definition: Iocgns_ParallelDatabaseIO.h:87
Holds metadata for bulk data associated with a GroupingEntity.
Definition: Ioss_Field.h:47
unsigned entity_field_support() const override
Definition: Iocgns_ParallelDatabaseIO.C:2420
int m_cgnsFilePtr
Definition: Iocgns_ParallelDatabaseIO.h:208
void write_adjacency_data()
Definition: Iocgns_ParallelDatabaseIO.C:778
void write_meta_data()
Definition: Iocgns_ParallelDatabaseIO.C:761
int64_t get_field_internal_sub_nb(const Ioss::NodeBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const
Definition: Iocgns_ParallelDatabaseIO.C:1183
std::vector< double > m_timesteps
Definition: Iocgns_ParallelDatabaseIO.h:221
Definition: Iocgns_ParallelDatabaseIO.h:76
A collection of element edges with the same topology.
Definition: Ioss_EdgeBlock.h:53
DatabaseUsage
Specifies how an Ioss::DatabaseIO object will be used.
Definition: Ioss_DBUsage.h:40
The main namespace for the Ioss library.
Definition: Ioad_DatabaseIO.C:66
std::map< std::string, int > m_zoneNameMap
Definition: Iocgns_ParallelDatabaseIO.h:222
State
Access states for a database.
Definition: Ioss_State.h:42
void flush_database__() const override
Definition: Iocgns_ParallelDatabaseIO.C:973
int int_byte_size_db() const override
Definition: Iocgns_ParallelDatabaseIO.h:108
A grouping entity that contains other grouping entities.
Definition: Ioss_Region.h:98
void handle_structured_blocks()
Definition: Iocgns_ParallelDatabaseIO.C:514
A collection of nodes.
Definition: Ioss_NodeSet.h:53
A collection of element faces.
Definition: Ioss_FaceSet.h:54
A structured zone – i,j,k.
Definition: Ioss_StructuredBlock.h:103
CGNSIntVector m_elemGlobalImplicitMap
Definition: Iocgns_ParallelDatabaseIO.h:225
A collection of Ioss::Property objects.
Definition: Ioss_PropertyManager.h:49
int m_flushInterval
Definition: Iocgns_ParallelDatabaseIO.h:213
A collection of element edges.
Definition: Ioss_EdgeSet.h:54
A collection of elements.
Definition: Ioss_ElementSet.h:54
const Ioss::Map & get_map(entity_type type) const
Definition: Iocgns_ParallelDatabaseIO.C:983
Definition: Ioss_CommSet.h:51
size_t finalize_structured_blocks()
Definition: Iocgns_ParallelDatabaseIO.C:491
std::vector< int64_t > get_processor_zone_node_offset() const
Definition: Iocgns_ParallelDatabaseIO.C:2485
std::vector< cgsize_t > CGNSIntVector
Definition: Iocgns_ParallelDatabaseIO.h:74
A collection of element faces with the same topology.
Definition: Ioss_FaceBlock.h:53
void openDatabase__() const override
Definition: Iocgns_ParallelDatabaseIO.C:211
void release_memory__() override
Definition: Iocgns_ParallelDatabaseIO.C:329
int64_t put_field_internal(const Ioss::Region *reg, const Ioss::Field &field, void *data, size_t data_size) const override
Definition: Iocgns_ParallelDatabaseIO.C:1632
An input or output Database.
Definition: Ioss_DatabaseIO.h:82
void resolve_zone_shared_nodes(const CGNSIntVector &nodes, CGNSIntVector &connectivity_map, size_t &owned_node_count, size_t &owned_node_offset) const
Definition: Iocgns_ParallelDatabaseIO.C:608
int64_t handle_element_ids(const Ioss::ElementBlock *eb, void *ids, size_t num_to_get, size_t offset, size_t count) const
Definition: Iocgns_ParallelDatabaseIO.C:1601
int m_currentCellCenterSolutionIndex
Definition: Iocgns_ParallelDatabaseIO.h:215
A collection of element sides having the same topology.
Definition: Ioss_SideBlock.h:59
bool begin__(Ioss::State state) override
Definition: Iocgns_ParallelDatabaseIO.C:908
int64_t get_field_internal(const Ioss::Region *reg, const Ioss::Field &field, void *data, size_t data_size) const override
Definition: Iocgns_ParallelDatabaseIO.C:1043
void handle_unstructured_blocks()
Definition: Iocgns_ParallelDatabaseIO.C:409
void write_results_meta_data()
Definition: Iocgns_ParallelDatabaseIO.C:2418
A collection of elements having the same topology.
Definition: Ioss_ElementBlock.h:48
Definition: Ioss_Map.h:52
int64_t element_global_to_local__(int64_t global) const override
Definition: Iocgns_ParallelDatabaseIO.C:346
std::vector< size_t > m_bcOffset
Definition: Iocgns_ParallelDatabaseIO.h:220
std::vector< char > data
Definition: cth_pressure_map.C:74
int64_t node_global_to_local__(int64_t global, bool must_exist) const override
Definition: Iocgns_ParallelDatabaseIO.C:340
void finalize_database() override
Definition: Iocgns_ParallelDatabaseIO.C:316
bool end__(Ioss::State state) override
Definition: Iocgns_ParallelDatabaseIO.C:914
int m_currentVertexSolutionIndex
Definition: Iocgns_ParallelDatabaseIO.h:214
entity_type
Definition: Iocgns_ParallelDatabaseIO.h:79
A collection of all nodes in the region.
Definition: Ioss_NodeBlock.h:53
bool end_state__(int state, double time) override
Definition: Iocgns_ParallelDatabaseIO.C:950
void get_step_times__() override
Definition: Iocgns_ParallelDatabaseIO.C:772
int MPI_Comm
Definition: Ioss_CodeTypes.h:96
Ioss::MeshType m_meshType
Definition: Iocgns_ParallelDatabaseIO.h:209
int get_file_pointer() const override
Definition: Iocgns_ParallelDatabaseIO.C:203
~ParallelDatabaseIO()
Definition: Iocgns_ParallelDatabaseIO.C:191
A namespace for the CGNS database format.
Definition: Iocgns_DatabaseIO.C:444
A collection of element sides.
Definition: Ioss_SideSet.h:53
void closeDatabase__() const override
Definition: Iocgns_ParallelDatabaseIO.C:295
std::vector< size_t > m_zoneOffset
Definition: Iocgns_ParallelDatabaseIO.h:217
ParallelDatabaseIO(Ioss::Region *region, const std::string &filename, Ioss::DatabaseUsage db_usage, MPI_Comm communicator, const Ioss::PropertyManager &props)
Definition: Iocgns_ParallelDatabaseIO.C:167
std::unique_ptr< DecompositionDataBase > decomp
Definition: Iocgns_ParallelDatabaseIO.h:211
bool node_major() const override
Definition: Iocgns_ParallelDatabaseIO.h:102
bool needs_shared_node_information() const override
Determine whether the database needs information about process ownership of nodes.
Definition: Iocgns_ParallelDatabaseIO.h:104
int64_t put_field_internal_sub_nb(const Ioss::NodeBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const
Definition: Iocgns_ParallelDatabaseIO.C:1845