|
| | DatabaseIO (Ioss::Region *region, const std::string &filename, Ioss::DatabaseUsage db_usage, MPI_Comm communicator, const Ioss::PropertyManager &props) |
| |
| | DatabaseIO (const DatabaseIO &from)=delete |
| |
| DatabaseIO & | operator= (const DatabaseIO &from)=delete |
| |
| | ~DatabaseIO () override |
| |
| unsigned | entity_field_support () const override |
| |
| virtual int | get_file_pointer () const =0 |
| |
| bool | ok (bool write_message=false, std::string *error_message=nullptr, int *bad_count=nullptr) const |
| | Check to see if database state is OK. More...
|
| |
| bool | using_parallel_io () const |
| |
| int64_t | node_global_to_local (int64_t global, bool must_exist) const |
| | Get the local (process-specific) node number corresponding to a global node number. More...
|
| |
| int64_t | element_global_to_local (int64_t global) const |
| |
| virtual bool | node_major () const |
| |
| void | release_memory () |
| |
| virtual void | finalize_database () |
| |
| std::string | get_filename () const |
| | Get the file name associated with the database. More...
|
| |
| const std::string & | decoded_filename () const |
| | Get a file-per-processor filename associated with the database. More...
|
| |
| bool | is_input () const |
| | Determine whether the database is an input database. More...
|
| |
| Ioss::DatabaseUsage | usage () const |
| | Get the Ioss::DatabaseUsage type of the database. More...
|
| |
| virtual bool | needs_shared_node_information () const |
| | Determine whether the database needs information about process ownership of nodes. More...
|
| |
| Ioss::IfDatabaseExistsBehavior | open_create_behavior () const |
| |
| void | create_path (const std::string &filename) const |
| | This function is used to create the path to an output directory (or history, restart, etc.) More...
|
| |
| void | set_region (Region *region) |
| |
| void | openDatabase () const |
| |
| void | closeDatabase () const |
| |
| void | flush_database () const |
| |
| bool | open_group (const std::string &group_name) |
| | If a database type supports groups and if the database contains groups, open the specified group. More...
|
| |
| bool | create_subgroup (const std::string &group_name) |
| | If a database type supports groups, create the specified group as a child of the current group. More...
|
| |
| bool | begin (Ioss::State state) |
| | Set the database to the given State. More...
|
| |
| bool | end (Ioss::State state) |
| | Return the database to STATE_CLOSED. More...
|
| |
| bool | begin_state (Region *region, int state, double time) |
| |
| bool | end_state (Region *region, int state, double time) |
| |
| void | read_meta_data () |
| |
| void | get_step_times () |
| |
| virtual bool | internal_edges_available () const |
| |
| virtual bool | internal_faces_available () const |
| |
| const std::vector< std::string > & | get_information_records () const |
| | Get all information records (informative strings) for the database. More...
|
| |
| void | add_information_records (const std::vector< std::string > &info) |
| | Add multiple information records (informative strings) to the database. More...
|
| |
| void | add_information_record (const std::string &info) |
| | Add an information record (an informative string) to the database. More...
|
| |
| const std::vector< std::string > & | get_qa_records () const |
| | Get all QA records, each of which consists of 4 strings, from the database. More...
|
| |
| 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 database. More...
|
| |
| bool | get_logging () const |
| |
| void | set_logging (bool on_off) |
| |
| template<typename T > |
| int64_t | get_field (const T *reg, const Field &field, void *data, size_t data_size) const |
| |
| template<typename T > |
| int64_t | put_field (const T *reg, const Field &field, void *data, size_t data_size) const |
| |
| bool | is_parallel_consistent () const |
| |
| void | set_parallel_consistency (bool on_off) |
| |
| bool | get_use_generic_canonical_name () const |
| |
| void | set_use_generic_canonical_name (bool yes_no) |
| |
| bool | ignore_database_names () const |
| |
| void | ignore_database_names (bool yes_no) |
| |
| char | get_field_separator () const |
| |
| bool | get_field_recognition () const |
| |
| void | set_field_separator (char separator) |
| | Set the character used to separate a field suffix from the field basename when recognizing vector, tensor fields. More...
|
| |
| void | set_field_recognition (bool yes_no) |
| |
| void | set_lower_case_variable_names (bool true_false) const |
| |
| void | set_surface_split_type (Ioss::SurfaceSplitType split_type) |
| |
| Ioss::SurfaceSplitType | get_surface_split_type () const |
| |
| void | set_block_omissions (const std::vector< std::string > &omissions, const std::vector< std::string > &inclusions={}) |
| |
| void | get_block_adjacencies (const Ioss::ElementBlock *eb, std::vector< std::string > &block_adjacency) const |
| |
| void | compute_block_membership (Ioss::SideBlock *efblock, std::vector< std::string > &block_membership) const |
| |
| AxisAlignedBoundingBox | get_bounding_box (const Ioss::ElementBlock *eb) const |
| |
| AxisAlignedBoundingBox | get_bounding_box (const Ioss::StructuredBlock *sb) const |
| |
| int | int_byte_size_api () const |
| | Returns 4 or 8. More...
|
| |
| Region * | get_region () const |
| |
| void | set_cycle_count (int count) const |
| |
| void | set_overlay_count (int count) const |
| |
| void | set_time_scale_factor (double factor) |
| |
| const Ioss::ParallelUtils & | util () const |
| |
| const Ioss::PropertyManager & | get_property_manager () const |
| |
| int | parallel_rank () const |
| | Get the processor that this mesh database is on. More...
|
| |
| int | parallel_size () const |
| |
| bool | is_parallel () const |
| |
| template<> |
| void | create_group (EntityType type, const std::string &, const std::vector< std::string > &group_spec, const SideSet *) |
| |
|
| bool | ok__ (bool write_message=false, std::string *error_message=nullptr, int *bad_count=nullptr) const override=0 |
| |
| bool | open_group__ (const std::string &group_name) override |
| |
| bool | create_subgroup__ (const std::string &group_name) override |
| |
| bool | begin__ (Ioss::State state) override |
| |
| bool | end__ (Ioss::State state) override |
| |
| bool | begin_state__ (Ioss::Region *region, int state, double time) override |
| |
| bool | end_state__ (Ioss::Region *region, int state, double time) override |
| |
| void | get_step_times__ () override=0 |
| |
| int | maximum_symbol_length () const override |
| | Get the length of the longest name in the database file. More...
|
| |
| void | set_maximum_symbol_length (int requested_symbol_size) override |
| |
| 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, size_t count) const |
| |
| void | compute_block_membership__ (Ioss::SideBlock *efblock, std::vector< std::string > &block_membership) const override |
| |
| int | int_byte_size_db () const override |
| |
| void | set_int_byte_size_api (Ioss::DataSize size) const override |
| | Returns 4 or 8. More...
|
| |
| int64_t | get_field_internal (const Ioss::Region *reg, const Ioss::Field &field, void *data, size_t data_size) const override=0 |
| |
| int64_t | get_field_internal (const Ioss::NodeBlock *nb, 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 | get_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::ElementBlock *eb, 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 |
| |
| 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::NodeSet *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::FaceSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0 |
| |
| int64_t | get_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::SideSet *fs, 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 | put_field_internal (const Ioss::Region *reg, const Ioss::Field &field, void *data, size_t data_size) const override=0 |
| |
| int64_t | put_field_internal (const Ioss::NodeBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const override=0 |
| |
| int64_t | put_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::FaceBlock *nb, const Ioss::Field &field, void *data, size_t data_size) const override=0 |
| |
| 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::StructuredBlock *sb, 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 | put_field_internal (const Ioss::NodeSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0 |
| |
| 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::FaceSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=0 |
| |
| int64_t | put_field_internal (const Ioss::ElementSet *ns, const Ioss::Field &field, void *data, size_t data_size) const override=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 | put_field_internal (const Ioss::CommSet *cs, const Ioss::Field &field, void *data, size_t data_size) const override=0 |
| |
| virtual void | write_meta_data ()=0 |
| |
| void | write_results_metadata () |
| |
| void | openDatabase__ () const override |
| |
| void | closeDatabase__ () const override |
| |
| virtual int | free_file_pointer () const |
| |
| int | get_current_state () const |
| |
| void | put_qa () |
| |
| void | put_info () |
| |
| template<typename T > |
| void | internal_write_results_metadata (ex_entity_type type, std::vector< T *> entities, int &glob_index) |
| |
| void | generate_sideset_truth_table () |
| |
| void | output_results_names (ex_entity_type type, VariableNameMap &variables) const |
| |
| int | gather_names (ex_entity_type type, VariableNameMap &variables, const Ioss::GroupingEntity *ge, int index, bool reduction) |
| |
| void | get_nodeblocks () |
| |
| void | add_attribute_fields (ex_entity_type entity_type, Ioss::GroupingEntity *block, int attribute_count, const std::string &type) |
| |
| void | output_other_meta_data () |
| |
| 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) |
| |
| int64_t | add_results_fields (ex_entity_type type, Ioss::GroupingEntity *entity, int64_t position=0) |
| |
| void | add_region_fields () |
| |
| void | store_reduction_field (ex_entity_type type, const Ioss::Field &field, const Ioss::GroupingEntity *ge, void *variables) const |
| |
| void | get_reduction_field (ex_entity_type type, const Ioss::Field &field, const Ioss::GroupingEntity *ge, void *variables) const |
| |
| void | write_reduction_fields () const |
| |
| void | read_reduction_fields () const |
| |
| int | get_database_step (int global_step) const |
| |
| void | flush_database__ () const override |
| |
| void | finalize_write (double sim_time) |
| |
| | DatabaseIO (Region *region, std::string filename, Ioss::DatabaseUsage db_usage, MPI_Comm communicator, const Ioss::PropertyManager &props) |
| |
| void | set_common_side_topology () const |
| |
| template<typename T > |
| void | create_groups (const std::string &property_name, EntityType type, const std::string &type_name, const T *set_type) |
| |
| template<typename T > |
| void | create_group (EntityType type, const std::string &type_name, const std::vector< std::string > &group_spec, const T *set_type) |
| |
| void | handle_groups () |
| |
| void | check_side_topology () const |
| |
| size_t Ioex::DatabaseIO::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, |
|
|
size_t |
count |
|
) |
| const |
|
protected |
NOTE: "element" is generic for "element", "face", or "edge"
There are two modes we need to support in this routine:
- Initial definition of element map (local->global) and elemMap.reverse (global->local).
- Redefinition of element map via 'reordering' of the original map when the elements on this processor are the same, but their order is changed.
So, there will be two maps the 'elemMap.map' map is a 'direct lookup' map which maps current local position to global id and the 'elemMap.reverse' is an associative lookup which maps the global id to 'original local'. There is also a 'elemMap.reorder' which is direct lookup and maps current local position to original local.
The ids coming in are the global ids; their position is the local id -1 (That is, data[0] contains the global id of local element 1 in this element block). The 'model-local' id is given by eb_offset + 1 + position:
int local_position = elemMap.reverseElementMap[i+1]
But, this assumes 1..numel elements are being output at the same time; we are actually outputting a blocks worth of elements at a time, so we need to consider the block offsets. So... local-in-block position 'i' is index 'eb_offset+i' in 'elemMap.map' and the 'local_position' within the element blocks data arrays is 'local_position-eb_offset'. With this, the position within the data array of this element block is:
int eb_position = elemMap.reverse[elemMap.map[eb_offset+i+1]]-eb_offset-1
To determine which map to update on a call to this function, we use the following hueristics: – If the database state is 'Ioss::STATE_MODEL:', then update the 'elemMap.reverse'. – If the database state is not Ioss::STATE_MODEL, then leave the 'elemMap.reverse' alone since it corresponds to the information already written to the database. [May want to add a Ioss::STATE_REDEFINE_MODEL] – Always update elemMap.map to match the passed in 'ids' array.
NOTE: the maps are built an element block at a time... NOTE: The mapping is done on TRANSIENT fields only; MODEL fields should be in the original order...