34 #ifndef IOSS_Ioex_DatabaseIO_h 35 #define IOSS_Ioex_DatabaseIO_h 69 class StructuredBlock;
71 class ElementTopology;
77 struct CommunicationMetaData;
110 unsigned entity_field_support()
const override;
118 bool ok__(
bool write_message =
false, std::string *
error_message =
nullptr,
119 int *bad_count =
nullptr)
const override = 0;
121 bool open_group__(
const std::string &group_name)
override;
122 bool create_subgroup__(
const std::string &group_name)
override;
127 bool begin_state__(
Ioss::Region *region,
int state,
double time)
override;
128 bool end_state__(
Ioss::Region *region,
int state,
double time)
override;
129 void get_step_times__()
override = 0;
138 maximumNameLength = requested_symbol_size;
143 Ioss::Map &entity_map,
void *ids,
size_t num_to_get,
size_t offset,
147 std::vector<std::string> &block_membership)
const override;
149 int int_byte_size_db()
const override;
154 size_t data_size)
const override = 0;
156 size_t data_size)
const override = 0;
158 size_t data_size)
const override = 0;
160 size_t data_size)
const override = 0;
162 size_t data_size)
const override = 0;
164 void *data,
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 size_t data_size)
const override = 0;
178 size_t data_size)
const override = 0;
181 size_t data_size)
const override = 0;
183 size_t data_size)
const override = 0;
185 size_t data_size)
const override = 0;
187 size_t data_size)
const override = 0;
189 size_t data_size)
const override = 0;
191 void *data,
size_t data_size)
const override = 0;
193 size_t data_size)
const override = 0;
195 size_t data_size)
const override = 0;
197 size_t data_size)
const override = 0;
199 size_t data_size)
const override = 0;
201 size_t data_size)
const override = 0;
203 size_t data_size)
const override = 0;
205 size_t data_size)
const override = 0;
207 virtual void write_meta_data() = 0;
208 void write_results_metadata();
219 virtual int free_file_pointer()
const;
221 int get_current_state()
const;
225 template <
typename T>
226 void internal_write_results_metadata(ex_entity_type type, std::vector<T *> entities,
229 void generate_sideset_truth_table();
231 void output_results_names(ex_entity_type type,
VariableNameMap &variables)
const;
235 void get_nodeblocks();
238 int attribute_count,
const std::string &type);
240 void output_other_meta_data();
243 int64_t position, int64_t block_count,
247 int64_t position = 0);
249 void add_region_fields();
250 void store_reduction_field(ex_entity_type type,
const Ioss::Field &field,
253 void get_reduction_field(ex_entity_type type,
const Ioss::Field &field,
255 void write_reduction_fields()
const;
256 void read_reduction_fields()
const;
260 int get_database_step(
int global_step)
const;
262 void flush_database__()
const override;
263 void finalize_write(
double sim_time);
267 mutable int exodusFilePtr{-1};
272 mutable int exodusMode{EX_CLOBBER};
273 mutable int dbRealWordSize{8};
275 mutable int maximumNameLength{32};
276 int spatialDimension{0};
278 int64_t edgeCount{0};
279 int64_t faceCount{0};
288 int64_t commsetNodeCount{0};
289 int64_t commsetElemCount{0};
312 time_t timeLastFlush{0};
314 mutable bool fileExists{
false};
315 mutable bool minimizeOpenFiles{
false};
317 mutable bool blockAdjacenciesCalculated{
false};
319 mutable bool nodeConnectivityStatusCalculated{
std::vector< double > ValueContainer
Definition: Ioex_DatabaseIO.h:84
The main namespace for the Ioss library.
Definition: Iocgns_DatabaseIO.h:50
size_t handle_block_ids(const Ioss::EntityBlock *eb, Ioss::State db_state, Ioss::Map &entity_map, void *ids, size_t int_byte_size, size_t num_to_get, int my_processor)
Definition: Iovs_DatabaseIO.C:854
An input or output Database.
Definition: Ioss_DatabaseIO.h:80
DataSize
The number of bytes used to store an integer type.
Definition: Ioss_DataSize.h:40
A collection of nodes.
Definition: Ioss_NodeSet.h:53
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 'grouping' entities. The following derived classes are typical: ...
Definition: Ioss_GroupingEntity.h:93
A collection of element edges.
Definition: Ioss_EdgeSet.h:54
A collection of element sides having the same topology.
Definition: Ioss_SideBlock.h:61
std::vector< int > IntVector
Definition: Ioss_CodeTypes.h:42
std::set< std::pair< int64_t, int64_t > > EntityIdSet
Definition: Ioex_DatabaseIO.h:94
Ioss::Int64Vector elemCmapIds
Definition: Ioex_DatabaseIO.h:286
Ioss::Int64Vector elemCmapElemCnts
Definition: Ioex_DatabaseIO.h:287
State
Access states for a database.
Definition: Ioss_State.h:42
A collection of elements having the same topology.
Definition: Ioss_ElementBlock.h:48
std::map< std::string, int, std::less< std::string > > VariableNameMap
Definition: Ioex_DatabaseIO.h:80
A structured zone – i,j,k.
Definition: Ioss_StructuredBlock.h:98
A collection of elements.
Definition: Ioss_ElementSet.h:54
void closeDatabase__() const override
Definition: Ioex_DatabaseIO.h:212
Base class for all 'block'-type grouping entities, which means all members of the block are similar o...
Definition: Ioss_EntityBlock.h:61
DatabaseUsage
Specifies how an Ioss::DatabaseIO object will be used.
Definition: Ioss_DBUsage.h:40
void openDatabase__() const override
Definition: Ioex_DatabaseIO.h:210
void set_maximum_symbol_length(int requested_symbol_size) override
Definition: Ioex_DatabaseIO.h:135
A namespace for the exodus database format.
Definition: Ioex_IOFactory.C:61
EntityIdSet ids_
Definition: Ioex_DatabaseIO.h:270
A collection of all nodes in the region.
Definition: Ioss_NodeBlock.h:53
std::map< ex_entity_type, VariableNameMap > m_variables
Definition: Ioex_DatabaseIO.h:300
std::vector< int64_t > Int64Vector
Definition: Ioss_CodeTypes.h:43
ValueContainer globalValues
Definition: Ioex_DatabaseIO.h:302
Definition: Ioss_Map.h:52
Definition: Ioss_CommSet.h:51
int get_file_pointer()
Definition: Iodw_DatabaseIO.C:64
VariableNameMap::value_type VNMValuePair
Definition: Ioex_DatabaseIO.h:81
A grouping entity that contains other grouping entities.
Definition: Ioss_Region.h:98
Ioss::Int64Vector nodeCmapIds
Definition: Ioex_DatabaseIO.h:284
A collection of element sides.
Definition: Ioss_SideSet.h:59
Holds metadata for bulk data associated with a GroupingEntity.
Definition: Ioss_Field.h:47
std::map< ex_entity_type, Ioss::IntVector > m_truthTable
Definition: Ioex_DatabaseIO.h:299
int MPI_Comm
Definition: Ioss_CodeTypes.h:79
Ioss::Int64Vector nodeCmapNodeCnts
Definition: Ioex_DatabaseIO.h:285
std::string m_groupName
Definition: Ioex_DatabaseIO.h:268
Definition: Ioex_DatabaseIO.h:96
int maximum_symbol_length() const override
Get the length of the longest name in the database file.
Definition: Ioex_DatabaseIO.h:131
std::vector< unsigned char > nodeConnectivityStatus
Definition: Ioex_DatabaseIO.h:304
A collection of Ioss::Property objects.
Definition: Ioss_PropertyManager.h:49
entity_type
Definition: Iovs_DatabaseIO.C:81
std::map< std::string, Ioss::Int64Vector > activeNodesetNodesIndex
Definition: Ioex_DatabaseIO.h:310
std::vector< char > data
Definition: Ioss_Utils.C:78
A collection of element edges with the same topology.
Definition: Ioss_EdgeBlock.h:53
std::map< ex_entity_type, int > m_groupCount
Definition: Ioex_DatabaseIO.h:281
void error_message(const Ioss::Field &field, Ioss::Field::BasicType requested_type)
Definition: Ioss_Field.C:63