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 "MeshLib/Location.h"
17#include "partition.h"
18
19namespace MeshLib::IO
20{
21XdmfData::XdmfData(std::size_t const size_partitioned_dim,
22 std::size_t const size_tuple,
23 MeshPropertyDataType const mesh_property_data_type,
24 std::string const& name,
25 std::optional<MeshLib::MeshItemType> const attribute_center,
26 unsigned int const index,
27 unsigned int const n_files)
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 name(name),
54 attribute_center(attribute_center),
55 index(index)
56{
57 auto partition_info = getPartitionInfo(size_partitioned_dim, n_files);
58 // TODO (tm) XdmfLib does not support 64 bit data types so far
59 assert(partition_info.local_length <
60 std::numeric_limits<unsigned int>::max());
61 auto const ui_global_components =
62 static_cast<unsigned int>(partition_info.global_length);
63 auto const ui_tuple_size = static_cast<unsigned int>(size_tuple);
64
65 if (ui_tuple_size == 1)
66 {
67 global_block_dims = {ui_global_components};
68 }
69 else
70 {
71 global_block_dims = {ui_global_components, ui_tuple_size};
72 }
73
74 DBUG(
75 "XDMF: dataset name: {:s}, offset: {:d} "
76 "global_blocks: {:d}, tuples: {:d}",
77 name, partition_info.local_offset, global_block_dims[0], ui_tuple_size);
78}
79} // 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:33
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)
XdmfData contains meta data to be passed to the XdmfWriter - it does not contain the actual values!...
Definition XdmfData.cpp:21