Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

GridSpacing: Per-Component UnitSI & UnitDimension #193

Merged
merged 5 commits into from
Nov 13, 2018
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
31 changes: 26 additions & 5 deletions STANDARD.md
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ Each file's *root* group (path `/`) must at least contain the attributes:
present standard (e.g. fields on an unstructured mesh),
this can be done be storing this data within a path that *is not*
of the form given by `basePath` (e.g. `/extra_data`). In this
way, the openPMD parsing tools will not parse this additional data.
way, the openPMD data readers will not parse this additional data.

The following attribute is *optional* in each each file's *root* group
(path `/`) and indicates if a file also follows an openPMD extension
Expand Down Expand Up @@ -430,11 +430,32 @@ In addition, the following attribute is *recommended* (see the section
on Unit Systems and Dimensionality, further below):

- `gridUnitSI`
- type: *(float64 / REAL8)*
- type: 1-dimensional array containing N *(float64 / REAL8)*

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Note: This does not extend, but instead changes the definition of gridUnitSI. According to this wording, writing a single scalar to be used for all axes will no longer be supported for 2.0, meaning that all writers need to change this.
Do we additionally want to allow scalars here in 2.0, or should writers migrate?

Currently implementing this by printing a warning for legacy-defined scalar values for gridUnitSI in openPMD/openPMD-api#1534:

Mesh &Mesh::setGridUnitSI(double gusi)
{
    setAttribute("gridUnitSI", gusi);
    if (auto standard = IOHandler()->m_standard;
        standard >= OpenpmdStandard::v_2_0_0)
    {
        std::cerr << "[Mesh::setGridUnitSI] Warning: Setting a scalar "
                     "`gridUnitSI` in a file with openPMD version '" +
                std::string(auxiliary::formatStandard(standard)) +
                "'. Consider specifying a vector instead in order to "
                "specify the gridUnitSI per axis (ref.: "
                "https://github.com/openPMD/openPMD-standard/pull/193).\n";
    }
    return *this;
}

elements, where N is the number of dimensions in the simulation.
The order of the N values must be identical to the axes in `axisLabels`.
- description: unit-conversion factor to multiply each value in
`gridSpacing` and `gridGlobalOffset`, in order to convert
from simulation units to SI units
- example: `1.0e-9`
- example: `(1.0e-9, 1.0e-9, 1.0e-6)`

- `gridUnitDimension`
- type: 1-dimensional array of 7 N *(float64 / REAL8)*
elements, where N is the number of dimensions in the simulation.
The order of the N 7-value arrays must be identical to the axes in `axisLabels`.
- description: powers of the 7 base measures characterizing the
grid axes's dimensions (length L, mass M, time T,
electric current I, thermodynamic temperature theta,
amount of substance N, luminous intensity J)
- note: this is similar to `unitDimension`, but applies to each axis
The 7 numbers characterizing the dimension of an axis are stored
contiguously in this 1D array.
- examples (with `L`, `M` and `T` as defined in `unitDimension`)
- For a 2D spatial grid (`L=1`), store array
`(1., 0., 0., 0., 0., 0., 0., 1., 0., 0., 0., 0., 0., 0.)`
- For a 2D phase space (Dimension "L" along the first axis
and "L*M/T" along the second axis), store array
`(1., 0., 0., 0., 0., 0., 0., 1., 1., -1., 0., 0., 0., 0. )`


The following attributes must be stored with each `scalar record` and each
*component* of a `vector record`:
Expand Down Expand Up @@ -591,15 +612,15 @@ patch order:
Unit Systems and Dimensionality
-------------------------------

All datasets and attributes can be written in arbitrary units, in openPMD.
All datasets and attributes can be written in arbitrary units, in openPMD.
Typically, this will be the unit system adopted internally by the
software that writes openPMD (e.g. the unit system adopted internally
by a physics simulation code), in order to avoid a reduction in performance
associated with unit conversion during the write process.

However, for each dataset and attribute, it is **very strongly** recommended to
provide the conversion factor from the chosen unit system to the International
System of Units (SI). (See the description of the attributes `timeUnitSI`,
System of Units (SI). (See the description of the attributes `timeUnitSI`,
`gridUnitSI` and `unitSI`, in the present document.) This allows
the reading softwares to convert the datasets to units that any user can
understand, without requiring them to know the chosen unit system.
Expand Down