Skip to main content

OpenGHG gas calibration scale conversion tool

Project description

OpenGHG gas calibration scale conversion tool

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:

$$ \chi_{WMO} = (\chi_{CSIRO}+3.17)/0.9898 $$

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.

Installation

pip

You can install openghg_calcscales using pip

pip install openghg_calscales

conda

Or with conda by doing

conda install -c conda-forge -c openghg openghg_calscales

Developer

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/

Usage

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.

Development

For the recommended development process please see the OpenGHG documentation

Release

The package is released using GitHub actions and pushed to conda and PyPI.

1. Update the CHANGELOG

  • 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.

2. Update pyproject.toml

For a new release the package version must be updated in the pyproject.toml file. Try and follow the Semantic Versioning method.

3. Tag the commit

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

4. Check GitHub Actions runners

Check the GitHub Actions runners to ensure the tests have all passed and the build for conda and PyPI has run successfully.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

openghg_calscales-0.1.3.tar.gz (9.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

openghg_calscales-0.1.3-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file openghg_calscales-0.1.3.tar.gz.

File metadata

  • Download URL: openghg_calscales-0.1.3.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for openghg_calscales-0.1.3.tar.gz
Algorithm Hash digest
SHA256 5d10f4034a8ae933099099ce8aa4b4ea8d34d1a7c083ce0d131e37b5a5693a7e
MD5 711a5cc6780cd816b417f23dba8ab0f8
BLAKE2b-256 80ed416dab8dcac5dcf5f67e57e141aced267c98703cbef11608c328ad94f6f1

See more details on using hashes here.

Provenance

The following attestation bundles were made for openghg_calscales-0.1.3.tar.gz:

Publisher: test_build.yaml on openghg/openghg_calscales

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file openghg_calscales-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for openghg_calscales-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 c526e46a2731941ba568e6c731caf77335781a3c34843689368160ece411a851
MD5 55144d8e9029cdb922260d128293b23b
BLAKE2b-256 3269ca6716fcb1d122a6427953be2df0560ecc6eecbf38ed39bc0656d8941c81

See more details on using hashes here.

Provenance

The following attestation bundles were made for openghg_calscales-0.1.3-py3-none-any.whl:

Publisher: test_build.yaml on openghg/openghg_calscales

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page