From 6d7513b64232544a5af7fafcb7f5c2628d2a75d7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Franz=20P=C3=B6schel?= Date: Mon, 18 Dec 2023 15:24:50 +0100 Subject: [PATCH] Default value for gridUnitSI set upon flush --- include/openPMD/Mesh.hpp | 21 ++++++++++----------- src/Mesh.cpp | 13 ++++++++++++- test/CoreTest.cpp | 15 +++++++-------- 3 files changed, 29 insertions(+), 20 deletions(-) diff --git a/include/openPMD/Mesh.hpp b/include/openPMD/Mesh.hpp index 219d4f7163..ea564acb61 100644 --- a/include/openPMD/Mesh.hpp +++ b/include/openPMD/Mesh.hpp @@ -184,9 +184,8 @@ class Mesh : public BaseRecord * Mesh::gridSpacing and Mesh::gridGlobalOffset, in order to convert from * simulation units to SI units. * - * Note that this API follows the legacy (openPMD 1.*) definition - * of gridUnitSI. - * In order to specify the gridUnitSI per dimension, + * Valid for openPMD version 1.*. + * In order to specify the gridUnitSI per dimension (openPMD 2.*), * use the vector overload or `setGridUnitSIPerDimension()`. * * @param gridUnitSI unit-conversion factor to multiply each value in @@ -196,12 +195,14 @@ class Mesh : public BaseRecord */ Mesh &setGridUnitSI(double gridUnitSI); - /** Set the unit-conversion factor per dimension to multiply each value in + /** Alias for `setGridUnitSI(std::vector)`. + * + * Set the unit-conversion factor per dimension to multiply each value in * Mesh::gridSpacing and Mesh::gridGlobalOffset, in order to convert from * simulation units to SI units. * - * Note that this is a feature of openPMD 2.0. - * The legacy behavior (a scalar gridUnitSI) is implemented + * Valid for openPMD 2.*. + * The legacy behavior (openPMD 1.*, a scalar gridUnitSI) is implemented * by `setGridUnitSI(double)`. * * @param gridUnitSI unit-conversion factor to multiply each value in @@ -220,14 +221,12 @@ class Mesh : public BaseRecord */ std::vector gridUnitSIPerDimension() const; - /** Alias for `setGridUnitSI(std::vector)`. - * - * Set the unit-conversion factor per dimension to multiply each value in + /* Set the unit-conversion factor per dimension to multiply each value in * Mesh::gridSpacing and Mesh::gridGlobalOffset, in order to convert from * simulation units to SI units. * - * Note that this is a feature of openPMD 2.0. - * The legacy behavior (a scalar gridUnitSI) is implemented + * Valid for openPMD 2.*. + * The legacy behavior (openPMD 1.*, a scalar gridUnitSI) is implemented * by `setGridUnitSI(double)`. * * @param gridUnitSI unit-conversion factor to multiply each value in diff --git a/src/Mesh.cpp b/src/Mesh.cpp index 61122d15f3..50bb32424c 100644 --- a/src/Mesh.cpp +++ b/src/Mesh.cpp @@ -42,7 +42,6 @@ Mesh::Mesh() setAxisLabels({"x"}); // empty strings are not allowed in HDF5 setGridSpacing(std::vector{1}); setGridGlobalOffset({0}); - setGridUnitSI(1); } Mesh::Geometry Mesh::geometry() const @@ -405,6 +404,18 @@ void Mesh::flush_impl( comp.second.flush(comp.first, flushParams); } } + if (!containsAttribute("gridUnitSI")) + { + if (auto series = retrieveSeries(); series.openPMD() < "2.") + { + setGridUnitSI(1); + } + else + { + setGridUnitSIPerDimension( + std::vector(retrieveMeshDimensionality(*this), 1)); + } + } flushAttributes(flushParams); } } diff --git a/test/CoreTest.cpp b/test/CoreTest.cpp index 3182145667..27663d11a1 100644 --- a/test/CoreTest.cpp +++ b/test/CoreTest.cpp @@ -527,11 +527,10 @@ TEST_CASE("mesh_constructor_test", "[core]") REQUIRE(m.gridSpacing() == gs); std::vector ggo{0}; REQUIRE(m.gridGlobalOffset() == ggo); - REQUIRE(m.gridUnitSI() == static_cast(1)); REQUIRE( m.numAttributes() == - 8); /* axisLabels, dataOrder, geometry, gridGlobalOffset, gridSpacing, - gridUnitSI, timeOffset, unitDimension */ + 7); /* axisLabels, dataOrder, geometry, gridGlobalOffset, gridSpacing, + timeOffset, unitDimension */ o.flush(); REQUIRE(m["x"].unitSI() == 1); @@ -556,22 +555,22 @@ TEST_CASE("mesh_modification_test", "[core]") m.setGeometry(Mesh::Geometry::spherical); REQUIRE(m.geometry() == Mesh::Geometry::spherical); - REQUIRE(m.numAttributes() == 8); + REQUIRE(m.numAttributes() == 7); m.setDataOrder(Mesh::DataOrder::F); REQUIRE(m.dataOrder() == Mesh::DataOrder::F); - REQUIRE(m.numAttributes() == 8); + REQUIRE(m.numAttributes() == 7); std::vector al{"z_", "y_", "x_"}; m.setAxisLabels({"z_", "y_", "x_"}); REQUIRE(m.axisLabels() == al); - REQUIRE(m.numAttributes() == 8); + REQUIRE(m.numAttributes() == 7); std::vector gs{1e-5, 2e-5, 3e-5}; m.setGridSpacing(gs); REQUIRE(m.gridSpacing() == gs); - REQUIRE(m.numAttributes() == 8); + REQUIRE(m.numAttributes() == 7); std::vector ggo{1e-10, 2e-10, 3e-10}; m.setGridGlobalOffset({1e-10, 2e-10, 3e-10}); REQUIRE(m.gridGlobalOffset() == ggo); - REQUIRE(m.numAttributes() == 8); + REQUIRE(m.numAttributes() == 7); m.setGridUnitSI(42.0); REQUIRE(m.gridUnitSI() == static_cast(42)); REQUIRE(m.numAttributes() == 8);