Skip to main content

PyCO2SYS: marine carbonate system calculations in Python

Project description

PyCO2SYS

Tests pypi badge Conda Version DOI Docs Coverage License: GPL v3 Code style: black

Introduction

PyCO2SYS is a Python implementation of CO2SYS, based on the MATLAB v2.0.5 but also including the updates made for MATLAB CO2SYS v3 as well as some additional related calculations. PyCO2SYS solves the full marine carbonate system from the values of any two of its parameters.

Every combination of input parameters has been tested, with differences in the results small enough to be attributable to floating point errors and iterative solver endpoint differences (i.e. negligible). See the scripts in validate to see how and check this for yourself, and their discussion in the online docs. Please let us know ASAP if you discover a discrepancy that we have not spotted!

Documentation is available online at PyCO2SYS.readthedocs.io.

There are also some usage examples that you can either download or run live in your web browser (with no Python installation required) at PyCO2SYS-examples.

Citation

A paper describing PyCO2SYS is freely available:

Humphreys, M. P., Lewis, E. R., Sharp, J. D., and Pierrot, D. (2022). PyCO2SYS v1.8: marine carbonate system calculations in Python. Geoscientific Model Development 15, 15-43. doi:10.5194/gmd-15-15-2022.

Please also specify the full version number that you used. You can find this in Python with:

import PyCO2SYS as pyco2
pyco2.hello()

As per the instructions in the the CO2SYS-MATLAB repo, you should also consider citing the original work by Lewis and Wallace (1998).

Installation

The current version of PyCO2SYS is not compatible with Numpy v2. The problem lies with Autograd, rather than PyCO2SYS itself. We are currently working on an updated version of PyCO2SYS which will avoid this problem and work with Numpy v2.

If you manage Python with conda, we recommend that you first install NumPy, pandas and xarray into the environment where PyCO2SYS is to be installed with conda.

With pip

Install from the Python Package Index:

pip install PyCO2SYS

Update an existing installation:

pip install PyCO2SYS --upgrade --no-cache-dir

With conda/mamba

Install from the conda-forge channel:

conda install PyCO2SYS -c conda-forge

Documentation

Documentation for the current release, based on the main branch, is available at PyCO2SYS.readthedocs.io and at mvdh.xyz/PyCO2SYS.

Basic use

The only function you need is pyco2.sys. To solve the marine carbonate system from two of its parameters (par1 and par2), just use:

import PyCO2SYS as pyco2
results = pyco2.sys(par1, par2, par1_type, par2_type, **kwargs)

The keys to the results dict are described in the documentation. Arguments should be provided as scalars or NumPy arrays in any mutually broadcastable combination. A large number of optional kwargs can be provided to specify everything beyond the carbonate system parameters — read the docs!.

You can also look at the examples Notebooks that you can try out without needing to install anything on your computer.

About

PyCO2SYS is maintained by Dr Matthew Humphreys at the NIOZ (Royal Netherlands Institute for Sea Research) with the support of the main developers of all previous versions of CO2SYS.

Contributions are welcome - please check the guidelines before setting to work.

License

PyCO2SYS is licensed under the GNU General Public License version 3 (GPLv3).

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

pyco2sys-1.8.3.3.tar.gz (108.6 kB view details)

Uploaded Source

Built Distribution

PyCO2SYS-1.8.3.3-py3-none-any.whl (110.7 kB view details)

Uploaded Python 3

File details

Details for the file pyco2sys-1.8.3.3.tar.gz.

File metadata

  • Download URL: pyco2sys-1.8.3.3.tar.gz
  • Upload date:
  • Size: 108.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.0

File hashes

Hashes for pyco2sys-1.8.3.3.tar.gz
Algorithm Hash digest
SHA256 d96c3d0e864199370108895fa66edc802fc05f98a87abfa5b5defc80aafcdbd5
MD5 9ee00d1d3ff1bb72f223b9e6a7e99056
BLAKE2b-256 15c00678ebc7e463a65f0013bfd2c12292e8de3f62f27209eee4a5e0b62a2bc2

See more details on using hashes here.

File details

Details for the file PyCO2SYS-1.8.3.3-py3-none-any.whl.

File metadata

  • Download URL: PyCO2SYS-1.8.3.3-py3-none-any.whl
  • Upload date:
  • Size: 110.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.0

File hashes

Hashes for PyCO2SYS-1.8.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 3a30436e70a92a9a444fd6c88a3947eee3f90dcf1bf5eedf0db8744e337ce519
MD5 4e12b26499c3cc6652ed10b9e415e412
BLAKE2b-256 78f5325ba4e6c0291519e29db34fc04591e36ca5f15d7d0ed9016d9d0e19f056

See more details on using hashes here.

Supported by

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