Go to the documentation of this file.
34 #ifndef IOSS_Ioex_DatabaseIO_h
35 #define IOSS_Ioex_DatabaseIO_h
69 class StructuredBlock;
71 class ElementTopology;
77 struct CommunicationMetaData;
107 const std::string
get_format()
const override {
return "Exodus";}
122 int *bad_count =
nullptr)
const override;
124 bool open_group__(
const std::string &group_name)
override;
148 Ioss::Map &entity_map,
void *ids,
size_t num_to_get,
149 size_t offset)
const;
152 std::vector<std::string> &block_membership)
const override;
159 size_t data_size)
const override = 0;
161 size_t data_size)
const override = 0;
163 size_t data_size)
const override = 0;
165 size_t data_size)
const override = 0;
167 size_t data_size)
const override = 0;
169 void *
data,
size_t data_size)
const override = 0;
171 size_t data_size)
const override = 0;
173 size_t data_size)
const override = 0;
175 size_t data_size)
const override = 0;
177 size_t data_size)
const override = 0;
179 size_t data_size)
const override = 0;
181 size_t data_size)
const override = 0;
183 size_t data_size)
const override = 0;
186 size_t data_size)
const override = 0;
188 size_t data_size)
const override = 0;
190 size_t data_size)
const override = 0;
192 size_t data_size)
const override = 0;
194 size_t data_size)
const override = 0;
196 void *
data,
size_t data_size)
const override = 0;
198 size_t data_size)
const override = 0;
200 size_t data_size)
const override = 0;
202 size_t data_size)
const override = 0;
204 size_t data_size)
const override = 0;
206 size_t data_size)
const override = 0;
208 size_t data_size)
const override = 0;
210 size_t data_size)
const override = 0;
227 virtual bool open_input_file(
bool write_message, std::string *error_msg,
int *bad_count,
228 bool abort_if_error)
const = 0;
229 virtual bool handle_output_file(
bool write_message, std::string *error_msg,
int *bad_count,
230 bool overwrite,
bool abort_if_error)
const = 0;
237 template <
typename T>
250 int attribute_count,
const std::string &type);
255 int64_t position, int64_t block_count,
259 int64_t position = 0);
void generate_sideset_truth_table()
Definition: Ioex_DatabaseIO.C:1458
void add_region_fields()
Definition: Ioex_DatabaseIO.C:1156
bool fileExists
Definition: Ioex_DatabaseIO.h:327
void get_reduction_field(ex_entity_type type, const Ioss::Field &field, const Ioss::GroupingEntity *ge, void *variables) const
Definition: Ioex_DatabaseIO.C:942
std::map< ex_entity_type, VariableNameMap > m_variables
Definition: Ioex_DatabaseIO.h:312
bool is_input() const
Determine whether the database is an input database.
Definition: Ioss_DatabaseIO.h:212
bool ok__(bool write_message=false, std::string *error_message=nullptr, int *bad_count=nullptr) const override
Definition: Ioex_DatabaseIO.C:331
void compute_block_membership__(Ioss::SideBlock *efblock, std::vector< std::string > &block_membership) const override
Definition: Ioex_DatabaseIO.C:698
void open_state_file(int state)
Definition: Ioex_DatabaseIO.C:1051
Holds metadata for bulk data associated with a GroupingEntity.
Definition: Ioss_Field.h:47
void put_info()
Definition: Ioex_DatabaseIO.C:510
ValueContainer globalValues
Definition: Ioex_DatabaseIO.h:314
int flushInterval
Definition: Ioex_DatabaseIO.h:325
std::vector< int > IntVector
Definition: Ioss_CodeTypes.h:51
std::map< std::string, int, std::less< std::string > > VariableNameMap
Definition: Ioex_DatabaseIO.h:80
void write_results_metadata(bool gather_data=true)
Definition: Ioex_DatabaseIO.C:1269
int spatialDimension
Definition: Ioex_DatabaseIO.h:288
std::string m_groupName
Definition: Ioex_DatabaseIO.h:280
Ioss::Int64Vector nodeCmapIds
Definition: Ioex_DatabaseIO.h:296
void put_qa()
Definition: Ioex_DatabaseIO.C:445
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
Definition: Ioex_DatabaseIO.h:96
bool end__(Ioss::State state) override
Definition: Ioex_DatabaseIO.C:1017
State
Access states for a database.
Definition: Ioss_State.h:42
entity_type
Definition: Iovs_DatabaseIO.C:81
void output_results_names(ex_entity_type type, VariableNameMap &variables) const
Definition: Ioex_DatabaseIO.C:1525
A grouping entity that contains other grouping entities.
Definition: Ioss_Region.h:98
void read_reduction_fields() const
Definition: Ioex_DatabaseIO.C:997
void flush_database__() const override
Definition: Ioex_DatabaseIO.C:1603
int get_current_state() const
Definition: Ioex_DatabaseIO.C:566
EntityIdSet ids_
Definition: Ioex_DatabaseIO.h:282
void output_other_meta_data()
Definition: Ioex_DatabaseIO.C:1930
A collection of nodes.
Definition: Ioss_NodeSet.h:53
int exodusFilePtr
Definition: Ioex_DatabaseIO.h:279
void internal_write_results_metadata(ex_entity_type type, std::vector< T * > entities, int &glob_index)
Definition: Ioex_DatabaseIO.C:1367
void get_step_times__() override=0
A collection of element faces.
Definition: Ioss_FaceSet.h:54
A structured zone – i,j,k.
Definition: Ioss_StructuredBlock.h:103
void closeDW() const
Function which invokes stageout from BB to Disk, prior to completion of final close.
Definition: Ioss_DatabaseIO.C:353
const std::string get_format() const override
Definition: Ioex_DatabaseIO.h:107
A collection of Ioss::Property objects.
Definition: Ioss_PropertyManager.h:49
DatabaseIO & operator=(const DatabaseIO &from)=delete
void set_maximum_symbol_length(int requested_symbol_size) override
Definition: Ioex_DatabaseIO.h:140
unsigned entity_field_support() const override
Definition: Ioex_DatabaseIO.C:275
A collection of element edges.
Definition: Ioss_EdgeSet.h:54
A collection of elements.
Definition: Ioss_ElementSet.h:54
int64_t add_results_fields(ex_entity_type type, Ioss::GroupingEntity *entity, int64_t position=0)
Definition: Ioex_DatabaseIO.C:1163
Definition: Ioss_CommSet.h:51
void finalize_file_open() const
Definition: Ioex_DatabaseIO.C:368
std::vector< double > ValueContainer
Definition: Ioex_DatabaseIO.h:84
virtual bool handle_output_file(bool write_message, std::string *error_msg, int *bad_count, bool overwrite, bool abort_if_error) const =0
bool begin_state__(int state, double time) override
Definition: Ioex_DatabaseIO.C:1112
std::vector< unsigned char > nodeConnectivityStatus
Definition: Ioex_DatabaseIO.h:316
~DatabaseIO() override
Definition: Ioex_DatabaseIO.C:265
A collection of element faces with the same topology.
Definition: Ioss_FaceBlock.h:53
int get_database_step(int global_step) const
Definition: Ioex_DatabaseIO.C:1583
void set_int_byte_size_api(Ioss::DataSize size) const override
Returns 4 or 8.
Definition: Ioex_DatabaseIO.C:225
An input or output Database.
Definition: Ioss_DatabaseIO.h:82
void write_reduction_fields() const
Definition: Ioex_DatabaseIO.C:983
A namespace for the exodus database format.
Definition: Ioex_IOFactory.C:62
bool blockAdjacenciesCalculated
Definition: Ioex_DatabaseIO.h:330
void closeDatabase__() const override
Definition: Ioex_DatabaseIO.h:217
int64_t faceCount
Definition: Ioex_DatabaseIO.h:291
Ioss::Int64Vector elemCmapIds
Definition: Ioex_DatabaseIO.h:298
virtual void write_meta_data()=0
std::map< ex_entity_type, Ioss::IntVector > m_truthTable
Definition: Ioex_DatabaseIO.h:311
std::vector< int64_t > Int64Vector
Definition: Ioss_CodeTypes.h:52
A collection of element sides having the same topology.
Definition: Ioss_SideBlock.h:59
int64_t get_field_internal(const Ioss::Region *reg, const Ioss::Field &field, void *data, size_t data_size) const override=0
Definition: Ioex_DatabaseIO.C:752
int64_t internal_add_results_fields(ex_entity_type type, Ioss::GroupingEntity *entity, int64_t position, int64_t block_count, Ioss::IntVector &truth_table, Ioex::VariableNameMap &variables)
Definition: Ioex_DatabaseIO.C:1171
int int_byte_size_db() const override
Definition: Ioex_DatabaseIO.C:253
void store_reduction_field(ex_entity_type type, const Ioss::Field &field, const Ioss::GroupingEntity *ge, void *variables) const
Definition: Ioex_DatabaseIO.C:875
Base class for all 'block'-type grouping entities, which means all members of the block are similar o...
Definition: Ioss_EntityBlock.h:61
void add_attribute_fields(ex_entity_type entity_type, Ioss::GroupingEntity *block, int attribute_count, const std::string &type)
Definition: Ioex_DatabaseIO.C:1682
virtual int free_file_pointer() const
Definition: Ioex_DatabaseIO.C:307
bool create_subgroup__(const std::string &group_name) override
Definition: Ioex_DatabaseIO.C:412
A collection of elements having the same topology.
Definition: Ioss_ElementBlock.h:48
bool nodeConnectivityStatusCalculated
Definition: Ioex_DatabaseIO.h:332
size_t handle_block_ids(const Ioss::EntityBlock *eb, ex_entity_type map_type, Ioss::Map &entity_map, void *ids, size_t num_to_get, size_t offset) const
Definition: Ioex_DatabaseIO.C:616
std::map< ex_entity_type, int > m_groupCount
Definition: Ioex_DatabaseIO.h:293
int exodusMode
Definition: Ioex_DatabaseIO.h:284
void error_message(const Ioss::Field &field, Ioss::Field::BasicType requested_type)
Definition: Ioss_Field.C:64
int64_t put_field_internal(const Ioss::Region *reg, const Ioss::Field &field, void *data, size_t data_size) const override=0
Definition: Ioex_DatabaseIO.C:780
Ioss::Int64Vector elemCmapElemCnts
Definition: Ioex_DatabaseIO.h:299
Definition: Ioss_Map.h:52
int64_t commsetNodeCount
Definition: Ioex_DatabaseIO.h:300
int gather_names(ex_entity_type type, VariableNameMap &variables, const Ioss::GroupingEntity *ge, int index, bool reduction)
Definition: Ioex_DatabaseIO.C:1380
std::vector< char > data
Definition: cth_pressure_map.C:74
virtual int get_file_pointer() const override=0
Definition: Ioex_DatabaseIO.C:283
void openDatabase__() const override
Definition: Ioex_DatabaseIO.h:215
time_t timeLastFlush
Definition: Ioex_DatabaseIO.h:324
A collection of all nodes in the region.
Definition: Ioss_NodeBlock.h:53
std::set< std::pair< int64_t, int64_t > > EntityIdSet
Definition: Ioex_DatabaseIO.h:94
int maximumNameLength
Definition: Ioex_DatabaseIO.h:287
int64_t edgeCount
Definition: Ioex_DatabaseIO.h:290
VariableNameMap::value_type VNMValuePair
Definition: Ioex_DatabaseIO.h:81
void finalize_write(int state, double sim_time)
Definition: Ioex_DatabaseIO.C:1612
int maximum_symbol_length() const override
Get the length of the longest name in the database file.
Definition: Ioex_DatabaseIO.h:136
bool minimizeOpenFiles
Definition: Ioex_DatabaseIO.h:328
int MPI_Comm
Definition: Ioss_CodeTypes.h:96
DataSize
The number of bytes used to store an integer type.
Definition: Ioss_DataSize.h:40
virtual bool open_input_file(bool write_message, std::string *error_msg, int *bad_count, bool abort_if_error) const =0
A collection of element sides.
Definition: Ioss_SideSet.h:53
Base class for all 'grouping' entities. The following derived classes are typical:
Definition: Ioss_GroupingEntity.h:93
void get_nodeblocks()
Definition: Ioex_DatabaseIO.C:584
bool end_state__(int state, double time) override
Definition: Ioex_DatabaseIO.C:1140
bool open_group__(const std::string &group_name) override
Definition: Ioex_DatabaseIO.C:390
bool begin__(Ioss::State state) override
Definition: Ioex_DatabaseIO.C:1010
std::map< std::string, Ioss::Int64Vector > activeNodeSetNodesIndex
Definition: Ioex_DatabaseIO.h:322
int64_t commsetElemCount
Definition: Ioex_DatabaseIO.h:301
int dbRealWordSize
Definition: Ioex_DatabaseIO.h:285
Ioss::Int64Vector nodeCmapNodeCnts
Definition: Ioex_DatabaseIO.h:297