28#include "ioex_export.h"
47 class StructuredBlock;
49 class ElementTopology;
52 class PropertyManager;
58 struct CommunicationMetaData;
99 IOSS_NODISCARD bool ok_nl(
bool write_message =
false, std::string *error_message =
nullptr,
100 int *bad_count =
nullptr)
const override;
102 bool open_group_nl(
const std::string &group_name)
override;
103 bool create_subgroup_nl(
const std::string &group_name)
override;
108 void open_state_file(
int state);
110 bool begin_state_nl(
int state,
double time)
override;
111 bool end_state_nl(
int state,
double time)
override;
120 maximumNameLength = requested_symbol_size;
125 Ioss::Map &entity_map,
void *ids,
size_t num_to_get,
126 size_t offset)
const;
129 std::vector<std::string> &block_membership)
const override;
135 size_t data_size)
const override = 0;
137 size_t data_size)
const override = 0;
139 size_t data_size)
const override = 0;
141 size_t data_size)
const override = 0;
143 size_t data_size)
const override = 0;
145 void *data,
size_t data_size)
const override = 0;
147 size_t data_size)
const override = 0;
149 size_t data_size)
const override = 0;
151 size_t data_size)
const override = 0;
153 size_t data_size)
const override = 0;
155 size_t data_size)
const override = 0;
157 size_t data_size)
const override = 0;
159 size_t data_size)
const override = 0;
161 size_t data_size)
const override = 0;
163 size_t data_size)
const override = 0;
166 size_t data_size)
const override = 0;
168 size_t data_size)
const override = 0;
170 size_t data_size)
const override = 0;
172 size_t data_size)
const override = 0;
174 size_t data_size)
const override = 0;
176 void *data,
size_t data_size)
const override = 0;
178 size_t data_size)
const override = 0;
180 size_t data_size)
const override = 0;
182 size_t data_size)
const override = 0;
184 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;
209 virtual int free_file_pointer()
const;
211 virtual bool open_input_file(
bool write_message, std::string *error_msg,
int *bad_count,
212 bool abort_if_error)
const = 0;
214 bool overwrite,
bool abort_if_error)
const = 0;
215 void finalize_file_open()
const;
218 get_current_state()
const;
222 template <
typename T>
223 void internal_gather_results_metadata(ex_entity_type type, std::vector<T *> entities);
225 void generate_sideset_truth_table();
227 void output_results_names(ex_entity_type type,
VariableNameMap &variables,
228 bool reduction)
const;
232 void get_nodeblocks();
233 void get_assemblies();
236 void update_block_omissions_from_assemblies();
239 const std::string &type);
242 void output_other_meta_data();
245 int64_t position, int64_t block_count,
252 void add_region_fields();
254 void *variables)
const;
257 void *variables)
const;
258 void write_reduction_fields()
const;
259 void read_reduction_fields()
const;
265 void flush_database_nl()
const override;
266 void finalize_write(
int state,
double sim_time);
268 mutable int m_exodusFilePtr{-1};
270 mutable int m_exodusBasePtr{-1};
276 mutable int exodusMode{EX_CLOBBER};
277 mutable int dbRealWordSize{8};
279 mutable int maximumNameLength{32};
280 int spatialDimension{0};
282 int64_t edgeCount{0};
283 int64_t faceCount{0};
292 int64_t commsetNodeCount{0};
293 int64_t commsetElemCount{0};
317 time_t timeLastFlush{0};
318 int flushInterval{-1};
320 mutable bool fileExists{
false};
321 mutable bool minimizeOpenFiles{
false};
323 mutable bool blockAdjacenciesCalculated{
false};
325 mutable bool nodeConnectivityStatusCalculated{
#define IOSS_NODISCARD
Definition Ioss_CodeTypes.h:54
int Ioss_MPI_Comm
Definition Ioss_CodeTypes.h:63
Definition Ioex_BaseDatabaseIO.h:78
int64_t put_field_internal(const Ioss::ElementBlock *eb, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t put_field_internal(const Ioss::SideBlock *fb, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::Assembly *as, const Ioss::Field &field, void *data, size_t data_size) const override=0
virtual bool handle_output_file(bool write_message, std::string *error_msg, int *bad_count, bool overwrite, bool abort_if_error) const =0
std::map< ex_entity_type, VariableNameMap > m_variables
Definition Ioex_BaseDatabaseIO.h:304
Ioss::Int64Vector elemCmapElemCnts
Definition Ioex_BaseDatabaseIO.h:291
int64_t put_field_internal(const Ioss::EdgeBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::FaceSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0
Ioss::Int64Vector elemCmapIds
Definition Ioex_BaseDatabaseIO.h:290
int64_t put_field_internal(const Ioss::Assembly *as, const Ioss::Field &field, void *data, size_t data_size) const override=0
virtual void write_meta_data(Ioss::IfDatabaseExistsBehavior behavior)=0
int64_t put_field_internal(const Ioss::SideSet *fs, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::SideBlock *fb, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::Blob *blob, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::EdgeBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t put_field_internal(const Ioss::FaceSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::ElementBlock *eb, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t put_field_internal(const Ioss::StructuredBlock *sb, const Ioss::Field &field, void *data, size_t data_size) const override=0
std::vector< unsigned char > nodeConnectivityStatus
Definition Ioex_BaseDatabaseIO.h:309
Ioss::Int64Vector nodeCmapIds
Definition Ioex_BaseDatabaseIO.h:288
int64_t put_field_internal(const Ioss::FaceBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::StructuredBlock *sb, const Ioss::Field &field, void *data, size_t data_size) const override=0
void set_maximum_symbol_length(int requested_symbol_size) override
Definition Ioex_BaseDatabaseIO.h:117
int64_t put_field_internal(const Ioss::EdgeSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t put_field_internal(const Ioss::Blob *blob, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::CommSet *cs, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::NodeSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0
std::string m_groupName
Definition Ioex_BaseDatabaseIO.h:272
IOSS_NODISCARD int maximum_symbol_length() const override
Get the length of the longest name in the database file.
Definition Ioex_BaseDatabaseIO.h:113
Ioss::Int64Vector nodeCmapNodeCnts
Definition Ioex_BaseDatabaseIO.h:289
virtual bool open_input_file(bool write_message, std::string *error_msg, int *bad_count, bool abort_if_error) const =0
int64_t get_field_internal(const Ioss::NodeBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const override=0
std::map< ex_entity_type, std::map< int64_t, ValueContainer > > m_reductionValues
Definition Ioex_BaseDatabaseIO.h:307
IOSS_NODISCARD std::string get_format() const override
Definition Ioex_BaseDatabaseIO.h:85
int64_t put_field_internal(const Ioss::ElementSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::EdgeSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t get_field_internal(const Ioss::SideSet *fs, const Ioss::Field &field, void *data, size_t data_size) const override=0
std::map< ex_entity_type, Ioss::IntVector > m_truthTable
Definition Ioex_BaseDatabaseIO.h:303
void closeDatabase_nl() const override
Definition Ioex_BaseDatabaseIO.h:201
int64_t get_field_internal(const Ioss::FaceBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const override=0
void openDatabase_nl() const override
Definition Ioex_BaseDatabaseIO.h:199
int64_t put_field_internal(const Ioss::NodeBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const override=0
EntityIdSet ids_
Definition Ioex_BaseDatabaseIO.h:274
std::map< std::string, Ioss::Int64Vector > activeNodeSetNodesIndex
Definition Ioex_BaseDatabaseIO.h:315
int64_t get_field_internal(const Ioss::ElementSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0
std::map< ex_entity_type, VariableNameMap > m_reductionVariables
Definition Ioex_BaseDatabaseIO.h:305
int64_t put_field_internal(const Ioss::CommSet *cs, const Ioss::Field &field, void *data, size_t data_size) const override=0
int64_t put_field_internal(const Ioss::NodeSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0
std::map< ex_entity_type, int > m_groupCount
Definition Ioex_BaseDatabaseIO.h:285
A homogeneous collection of other GroupingEntities.
Definition Ioss_Assembly.h:31
A homogeneous collection of other GroupingEntities.
Definition Ioss_Blob.h:31
Definition Ioss_CommSet.h:27
An input or output Database.
Definition Ioss_DatabaseIO.h:63
A collection of element edges with the same topology.
Definition Ioss_EdgeBlock.h:29
A collection of element edges.
Definition Ioss_EdgeSet.h:30
A collection of elements having the same topology.
Definition Ioss_ElementBlock.h:29
A collection of elements.
Definition Ioss_ElementSet.h:30
Base class for all 'block'-type grouping entities, which means all members of the block are similar o...
Definition Ioss_EntityBlock.h:38
A collection of element faces with the same topology.
Definition Ioss_FaceBlock.h:29
A collection of element faces.
Definition Ioss_FaceSet.h:30
Holds metadata for bulk data associated with a GroupingEntity.
Definition Ioss_Field.h:25
Base class for all 'grouping' entities. The following derived classes are typical:
Definition Ioss_GroupingEntity.h:67
A collection of all nodes in the region.
Definition Ioss_NodeBlock.h:33
A collection of nodes.
Definition Ioss_NodeSet.h:29
A collection of Ioss::Property objects.
Definition Ioss_PropertyManager.h:36
A grouping entity that contains other grouping entities.
Definition Ioss_Region.h:90
A collection of element sides having the same topology.
Definition Ioss_SideBlock.h:37
A collection of element sides.
Definition Ioss_SideSet.h:29
A structured zone – i,j,k.
Definition Ioss_StructuredBlock.h:104
A namespace for the exodus database format.
Definition Ioex_BaseDatabaseIO.C:198
VariableNameMap::value_type VNMValuePair
Definition Ioex_BaseDatabaseIO.h:62
std::map< std::string, int, std::less<> > VariableNameMap
Definition Ioex_BaseDatabaseIO.h:61
std::set< std::pair< int64_t, int64_t > > EntityIdSet
Definition Ioex_BaseDatabaseIO.h:75
std::vector< double > ValueContainer
Definition Ioex_BaseDatabaseIO.h:65
The main namespace for the Ioss library.
Definition Ioad_DatabaseIO.C:40
State
Access states for a database.
Definition Ioss_State.h:15
std::vector< int64_t > Int64Vector
Definition Ioss_CodeTypes.h:22
DataSize
The number of bytes used to store an integer type.
Definition Ioss_DataSize.h:13
DatabaseUsage
Specifies how an Ioss::DatabaseIO object will be used.
Definition Ioss_DBUsage.h:13
std::vector< int > IntVector
Definition Ioss_CodeTypes.h:21
IfDatabaseExistsBehavior
Definition Ioss_DBUsage.h:32