Validator and examples for openPMD format
Project description
openPMD Validator Scripts
This repository contains scripts to validate existing files that (claim to)
implement the openPMD Standard
in version 1.1.*
.
Additional scripts to create random/empty files with the valid markup of the standard are also provided.
Rationale
These tools are intended for developers that want to implementent the standard. They were written to allow an easy implement-test-correct workflow without the hazzle to check every word of the written standard twice.
Nevertheless, these scripts can not validate 100% of the standard and uncovered sections shall be cross-checked manually with the words of the written standard.
For more information on requirements for implementations, please refer to the section Implementations of the openPMD standard. The repository openPMD-projects also lists a large collection of open source projects that already implement the openPMD standard.
Install
Choose one of the install methods below to get started:
PyPI
# optional: append --user
pip install openPMD-validator==1.1.0.6
Spack
spack install py-openpmd-validator@1.1.0.6 ^py-h5py~mpi
spack load --dependencies py-openpmd-validator@1.1.0.6 ^py-h5py~mpi
Conda
conda install -c conda-forge openpmd-validator
From Source
wget https://github.com/openPMD/openPMD-validator/archive/1.1.0.6.tar.gz
tar -xf 1.1.0.6.tar.gz
cd openPMD-validator-1.1.0.6/
# optional: append --user
python setup.py install
Usage
CLI
We provide the command-line tools for individual files:
# optional: create dummy example files
openPMD_createExamples_h5
# validate
openPMD_check_h5 -i example.h5
# optional: append --EDPIC for the Partice-in-Cell Extension
Module
Additionally, the validator tools can be used as Python module in your projects, e.g. to verify a file before opening it for reading.
Create:
from openpmd_validator import createExamples_h5
# create "example.h5"
createExamples_h5.main()
Check:
from openpmd_validator import check_h5
result_array = check_h5.check_file("example.h5", verbose=False)
print("Result: %d Errors and %d Warnings."
%( result_array[0], result_array[1]))
Development
The development of these scripts is carried out per-branch. Each branch corresponds to a certain version of the standard and might be updated in case tests did contain bugs or we found a way to cover more sections of the standard.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file openPMD-validator-1.1.0.6.tar.gz
.
File metadata
- Download URL: openPMD-validator-1.1.0.6.tar.gz
- Upload date:
- Size: 16.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6ac3c744b2e0f5cdb6d89ee265b8c5d33bc2bf0fcbbd71a75dfd1d82f5d292ca |
|
MD5 | 45e83b495497f046d5317426d86afe4d |
|
BLAKE2b-256 | 8fdc43d986b4230920f59e8764fad1302769e9cb77864079d2296f762816749b |
File details
Details for the file openPMD_validator-1.1.0.6-py3-none-any.whl
.
File metadata
- Download URL: openPMD_validator-1.1.0.6-py3-none-any.whl
- Upload date:
- Size: 17.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5a3de687ef98d0054d5484a4c27951b6a0c51fa87db608a312e89ec4f002bb73 |
|
MD5 | d0c5d528e0eaa6917b0c5708ed565e43 |
|
BLAKE2b-256 | 8c55ef3f3ceb1db7938e92117f952e23d0348cad3dfdc98d55adbf915621efe2 |