Skip to main content

Python implementation of CO2SYS

Project description

PyCO2SYS

PyPI version DOI Docs Build Status Coverage License: GPL v3 Code style: black

PyCO2SYS is a Python implementation of CO2SYS, based on the MATLAB v2.0.5 but also including the updates made for the forthcoming 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

The citation for PyCO2SYS alone is:

Humphreys, M. P., Gregor, L., Pierrot, D., van Heuven, S. M. A. C., Lewis, E. R., and Wallace, D. W. R. (2020). PyCO2SYS: marine carbonate system calculations in Python. Zenodo. doi:10.5281/zenodo.3744275.

The DOI above refers to all versions of PyCO2SYS. Please also specify the version number that you used. You can find this in Python with:

import PyCO2SYS as pyco2
pyco2.say_hello()

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

Installation

Install from the Python Package Index:

pip install PyCO2SYS

Update an existing installation:

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

Basic use

The default API has been kept as close to the MATLAB version as possible, although the first output is now a dict for convenience. If you want the MATLAB-like experience, simplest recommended usage is therefore:

from PyCO2SYS import CO2SYS
CO2dict = CO2SYS(PAR1, PAR2, PAR1TYPE, PAR2TYPE, SAL, TEMPIN, TEMPOUT, PRESIN, PRESOUT,
    SI, PO4, pHSCALEIN, K1K2CONSTANTS, KSO4CONSTANTS, NH3=0.0, H2S=0.0)

Each field in the output CO2dict corresponds to a column in the original MATLAB output DATA. The keys to the dict come from the original MATLAB output HEADERS. Vector inputs should be provided as Numpy arrays. Everything gets flattened with ravel(). Single-value inputs are fine - they are automatically cast into correctly-sized arrays. The extra inputs not present in the MATLAB version are all optional and explained in the documentation. There are more of these than appear in the example above.

It is also possible to provide Pandas Series and Xarray DataArrays using the wrapper functions provided. For this and a more detailed explanation of all the inputs and outputs, see the Pythonic API documentation.

You can also look at the example scripts here in the repo, or there are also some examples as Jupyter Notebooks that you can try out without needing to install anything on your computer.

About

PyCO2SYS is maintained by Dr Matthew Humphreys of the NIOZ (Royal Netherlands Institute for Sea Research) with support from 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.4.1.tar.gz (79.5 kB view details)

Uploaded Source

Built Distribution

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

PyCO2SYS-1.4.1-py3-none-any.whl (101.0 kB view details)

Uploaded Python 3

File details

Details for the file PyCO2SYS-1.4.1.tar.gz.

File metadata

  • Download URL: PyCO2SYS-1.4.1.tar.gz
  • Upload date:
  • Size: 79.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.3.1.post20200622 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.8.3

File hashes

Hashes for PyCO2SYS-1.4.1.tar.gz
Algorithm Hash digest
SHA256 94f31081f6062d12562b9c1b6225d63714a3efb5b4e1c2fd878ef299a4a15d14
MD5 27ff50d43e2ff02fc1ab153921521b4f
BLAKE2b-256 58bfab99c698bfb557eb50e4ca0723b809e7d0339369c9b260379b8f8873368d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: PyCO2SYS-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 101.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.3.1.post20200622 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.8.3

File hashes

Hashes for PyCO2SYS-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8eeab259c48983a6274aad7c66952932f92b17b7bb49e91f1a9f3d952955b85a
MD5 1f068c497f56a41c069b4a43124d7690
BLAKE2b-256 3a26d3cee4be163fbd6cc5b811a93adf31bfe4969e65f853fbd70647e1c6eb20

See more details on using hashes here.

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