Loading [MathJax]/extensions/tex2jax.js
OGS
XdmfData.cpp
Go to the documentation of this file.
1
10#include "XdmfData.h"
11
12#include <cassert>
13#include <map>
14
15#include "BaseLib/Error.h"
16#include "partition.h"
17
18namespace MeshLib::IO
19{
20XdmfData::XdmfData(std::size_t const size_partitioned_dim,
21 std::size_t const size_tuple,
22 MeshPropertyDataType const mesh_property_data_type,
23 std::string const& name,
24 std::optional<MeshLib::MeshItemType> const attribute_center,
25 unsigned int const index,
26 unsigned int const n_files,
27 std::optional<ParentDataType> const parent_data_type)
28 : starts(
29 [&size_tuple]()
30 {
31 if (size_tuple > 1)
32 {
33 return std::vector<XdmfDimType>{0, 0};
34 }
35 else
36 {
37 return std::vector<XdmfDimType>{0};
38 }
39 }()),
40 strides(
41 [&size_tuple]()
42 {
43 if (size_tuple > 1)
44 {
45 return std::vector<XdmfDimType>{1, 1};
46 }
47 else
48 {
49 return std::vector<XdmfDimType>{1};
50 }
51 }()),
52 data_type(mesh_property_data_type),
53 size_partitioned_dim(size_partitioned_dim),
54 name(name),
55 attribute_center(attribute_center),
56 index(index),
57 parent_data_type(parent_data_type)
58{
59 auto partition_info = getPartitionInfo(size_partitioned_dim, n_files);
60 assert(partition_info.local_length <
61 std::numeric_limits<unsigned int>::max());
62 auto const ui_global_components =
63 static_cast<unsigned int>(partition_info.global_length);
64 auto const ui_tuple_size = static_cast<unsigned int>(size_tuple);
65
66 if (ui_tuple_size == 1)
67 {
68 global_block_dims = {ui_global_components};
69 }
70 else
71 {
72 global_block_dims = {ui_global_components, ui_tuple_size};
73 }
74
75 DBUG(
76 "XDMF: dataset name: {:s}, offset: {:d} "
77 "global_blocks: {:d}, tuples: {:d}",
78 name, partition_info.local_offset, global_block_dims[0], ui_tuple_size);
79}
80} // namespace MeshLib::IO
void DBUG(fmt::format_string< Args... > fmt, Args &&... args)
Definition Logging.h:30
MeshPropertyDataType
Collects and holds all metadata for writing XDMF file.
PartitionInfo getPartitionInfo(std::size_t const size, unsigned int const n_files)
Definition partition.cpp:35
Dispatches functions specific to execution platform (w/o MPI)
XdmfData(std::size_t size_partitioned_dim, std::size_t size_tuple, MeshPropertyDataType mesh_property_data_type, std::string const &name, std::optional< MeshLib::MeshItemType > attribute_center, unsigned int const index, unsigned int n_files, std::optional< ParentDataType > parent_data_type)
XdmfData contains meta data to be passed to the XdmfWriter - it does not contain the actual values!...
Definition XdmfData.cpp:20