Convert from one calibration scale to another. If multiple conversions are required, conversion functions are chained together, following the shortest path.
Conversions can be defined as a function of the original scale, or as a function of time.
For example, conversion of CO from the WMO-X2014A to the CSIRO-94 scale uses a function:
Or the conversion of the SIO-93 to the SIO-98 scale for N$_2$O involves a 4th order polynomial as a function of time.
The code uses sympy
to rearrange the equations to do the conversion in the reverse order, or, in the case of time-based conversions, calculate the inverse. The shortest path between two scales is found using networkx
.
Please feel free to propose new scale conversions or bug fixes by submitting a pull request.
You can install openghg_calcscales
using pip
pip install openghg_calscales
Or with conda
by doing
conda install -c conda-forge -c openghg openghg_calscales
If you want to make modifications to the package you can use an editable install with pip
First, clone the repository using git
git clone https://github.com/openghg/openghg_calscales.git
And then install the package using pip
pip install -e openghg_calscales/
For example, to convert a Pandas Series or xarray DataArray from the CSIRO-94 to TU-87 scale for CH4:
from openghg_calscales import convert
ch4_tu1987 = convert(ch4_csiro94, "CH4", "CSIRO-94", "TU-1987")
Add your own functions to data/convert_functions.csv
, and submit them as a pull request to share with others.
For the recommended development process please see the OpenGHG documentation
The package is released using GitHub actions and pushed to conda and PyPI.
- Update the changelog to add the header for the new version and add the date.
- Update the Unreleased header to match the version you're releasing and
...HEAD
.
For a new release the package version must be updated in the pyproject.toml
file. Try and follow the Semantic Versioning method.
Now tag the commit. First we create the tag and add a message (remember to insert correct version numbers here).
git tag -a x.x.x -m "openghg_calscales release vx.x.x"
Next push the tag. This will trigger the automated release by GitHub Actions.
git push origin x.x.x
Check the GitHub Actions runners to ensure the tests have all passed and the build for conda and PyPI has run successfully.