103 std::vector<XdmfData>
const& constant_attributes,
104 std::vector<XdmfData>
const& variable_attributes,
105 std::string
const& h5filename, std::string
const& ogs_version,
106 std::string
const& mesh_name)
112 auto const time_dataitem_genfn =
113 [](
unsigned long long const time_step,
int const max_step,
114 std::string
const& h5filename, std::string
const& mesh_name)
117 [time_step, max_step, h5filename, mesh_name](
auto const& xdmfdata)
120 fmt::runtime(
"\n\t\t<DataItem DataType=\"{datatype}\" "
121 "Dimensions=\"{local_dimensions}\" "
123 "Precision=\"{precision}\">"
124 "{filename}:/meshes/{meshname}/{datasetname}|"
125 "{time_step} {starts}:1 {strides}:1 "
126 "{local_dimensions}:{max_step} "
127 "{global_dimensions}</"
130 "local_dimensions"_a =
131 fmt::join(xdmfdata.global_block_dims,
" "),
133 "filename"_a = h5filename,
134 "meshname"_a = mesh_name,
135 "datasetname"_a = xdmfdata.name,
136 "starts"_a = fmt::join(xdmfdata.starts,
" "),
137 "strides"_a = fmt::join(xdmfdata.strides,
" "),
138 "global_dimensions"_a =
139 fmt::join(xdmfdata.global_block_dims,
" "),
140 "time_step"_a = fmt::format(
"{}", time_step),
141 "max_step"_a = fmt::format(
"{}", max_step));
146 auto const string_join_fn = [](
auto const& collection)
147 {
return fmt::to_string(fmt::join(collection,
"")); };
151 auto const m_bind_fn = [](
auto const& transform,
auto const& join)
153 return [join, transform](
auto const& collection)
155 std::vector<std::string> temp;
156 temp.reserve(collection.size());
157 for (std::size_t i = 0; i < collection.size(); ++i)
160 temp.push_back(transform(collection[i], i + 4));
169 auto const pointer_transfrom = [](
auto const& elements)
172 fmt::runtime(
"\n\t<xi:include xpointer=\"element(/{elements})\"/>"),
173 "elements"_a = fmt::join(elements,
"/"));
178 auto const attribute_transform =
179 [](
XdmfData const& attribute,
auto const& dataitem_transform)
182 "\n\t<Attribute Center=\"{center}\" ElementCell=\"\" "
183 "ElementDegree=\"0\" "
184 "ElementFamily=\"\" ItemType=\"\" Name=\"{name}\" "
185 "Type=\"None\">{dataitem}\n\t</Attribute>",
187 "name"_a = attribute.
name,
188 "dataitem"_a = dataitem_transform(attribute));
192 auto const geometry_transform =
193 [](
XdmfData const& geometry,
auto const& dataitem_transform)
196 fmt::runtime(
"\n\t<Geometry Origin=\"\" "
197 "Type=\"XYZ\">{dataitem}\n\t</Geometry>"),
198 "dataitem"_a = dataitem_transform(geometry));
201 auto tag_string = [](
auto const& topology,
int nodes_per_element,
202 auto const& dataitem_transform)
205 fmt::runtime(
"\n\t<Topology Type=\"{topology_type}\" "
206 "NodesPerElement=\"{nodes_per_element}\" "
207 "NumberOfElements=\"{number_of_elements}\">{dataitem}"
211 "dataitem"_a = dataitem_transform(topology),
212 "nodes_per_element"_a = nodes_per_element,
217 auto const topology_transform =
218 [&tag_string](
XdmfData const& topology,
auto const& dataitem_transform)
223 return tag_string(topology, 1, dataitem_transform);
225 return tag_string(topology, 2, dataitem_transform);
246 "Type=\"{topology_type}\">{dataitem}\n\t</Topology>"),
249 "dataitem"_a = dataitem_transform(topology));
251 OGS_FATAL(
"Could not transform unknown XDMF topology type");
252 return std::string{};
257 auto const grid_transform =
258 [](
double const& time_value,
auto const& geometry,
auto const& topology,
259 auto const& constant_attributes,
auto const& variable_attributes)
263<Grid Name="Grid" GridType="Uniform">
264 <Time Value="{time_value:.{precision}g}"/>
270 "time_value"_a = time_value,
272 "precision"_a = std::numeric_limits<double>::max_digits10,
273 "geometry"_a = geometry,
274 "topology"_a = topology,
275 "fix_attributes"_a = constant_attributes,
276 "variable_attributes"_a = variable_attributes);
280 enum class time_attribute
288 auto const time_step_fn = [time_dataitem_genfn, pointer_transfrom,
290 mesh_name](
auto const& component_transform,
291 unsigned long long const time_step,
293 time_attribute
const variable)
295 return [component_transform, time_dataitem_genfn, pointer_transfrom,
296 variable, time_step, max_step, h5filename,
297 mesh_name](
XdmfData const& attr, std::size_t
const index)
301 ((time_step > 0 && (variable == time_attribute::variable)) ||
305 auto dataitem = time_dataitem_genfn(time_step, max_step,
306 h5filename, mesh_name);
307 return component_transform(attr, dataitem);
312 std::array<unsigned int, 5> position = {
313 1, 1, 2, 1,
static_cast<unsigned int>(index)};
314 return pointer_transfrom(position);
323 auto const time_grid_transform =
324 [time_step_fn, m_bind_fn, string_join_fn, grid_transform,
325 geometry_transform, topology_transform, attribute_transform](
326 double const time,
int const step,
int const max_step,
327 auto const& geometry,
auto const& topology,
328 auto const& constant_attributes,
auto const& variable_attributes)
330 auto const time_step_geometry_transform = time_step_fn(
331 geometry_transform, step, max_step, time_attribute::constant);
332 auto const time_step_topology_transform = time_step_fn(
333 topology_transform, step, max_step, time_attribute::constant);
334 auto const time_step_const_attribute_fn = time_step_fn(
335 attribute_transform, step, max_step, time_attribute::constant);
336 auto const time_step_variable_attribute_fn = time_step_fn(
337 attribute_transform, step, max_step, time_attribute::variable);
341 auto const variable_attributes_transform =
342 m_bind_fn(time_step_variable_attribute_fn, string_join_fn);
343 auto const constant_attributes_transform =
344 m_bind_fn(time_step_const_attribute_fn, string_join_fn);
346 return grid_transform(
347 time, time_step_geometry_transform(geometry, 2),
348 time_step_topology_transform(topology, 3),
349 constant_attributes_transform(constant_attributes),
350 variable_attributes_transform(variable_attributes));
356 auto const temporal_grid_collection_transform =
357 [time_grid_transform](
358 auto const& times,
auto const& geometry,
auto const& topology,
359 auto const& constant_attributes,
auto const& variable_attributes)
362 auto const max_step = times.size();
363 std::vector<std::string> grids;
364 grids.reserve(max_step);
365 for (
size_t time_step = 0; time_step < max_step; ++time_step)
367 grids.push_back(time_grid_transform(
368 times[time_step], time_step, max_step, geometry, topology,
369 constant_attributes, variable_attributes));
373 "\n<Grid CollectionType=\"Temporal\" GridType=\"Collection\" "
374 "Name=\"Collection\">{grids}\n</Grid>\n"),
375 "grids"_a = fmt::join(grids,
""));
380 auto const xdmf_writer_fn = [temporal_grid_collection_transform](
381 auto ogs_version,
auto geometry,
382 auto topology,
auto constant_attributes,
383 auto variable_attributes)
388 return [temporal_grid_collection_transform,
389 ogs_version = std::move(ogs_version),
390 geometry = std::move(geometry), topology = std::move(topology),
391 constant_attributes = std::move(constant_attributes),
392 variable_attributes = std::move(variable_attributes)](
393 std::vector<double>
const& times)
396 "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<Xdmf "
397 "xmlns:xi=\"http://www.w3.org/2001/XInclude\" "
398 "Version=\"3.0\">\n<Domain>\n<Information Name=\"OGS_VERSION\" "
399 "Value=\"{ogs_version}\"/>{grid_collection}</Domain>\n</Xdmf>",
400 "ogs_version"_a = ogs_version,
401 "grid_collection"_a = temporal_grid_collection_transform(
402 times, geometry, topology, constant_attributes,