Coder Social home page Coder Social logo

ajschiller / pyco2sys Goto Github PK

View Code? Open in Web Editor NEW

This project forked from mvdh7/pyco2sys

0.0 1.0 0.0 111.06 MB

Marine carbonate system calculations in Python

Home Page: https://pyco2sys.rtfd.io

License: GNU General Public License v3.0

Python 94.14% MATLAB 5.78% TeX 0.07%

pyco2sys's Introduction

PyCO2SYS

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

Contents:

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

The citation for the PyCO2SYS code is:

Humphreys, M. P., Sandborn, D. E., Gregor, L., Pierrot, D., van Heuven, S. M. A. C., Lewis, E. R., and Wallace, D. W. R. (2021). 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.hello()

There is also a manuscript in review:

Humphreys, M. P., Lewis, E. R., Sharp, J. D., and Pierrot, D. (2021). PyCO2SYS v1.7: marine carbonate system calculations in Python. Geoscientific Model Development Discussions [preprint]. doi:10.5194/gmd-2021-159.

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

Installation

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.

Then, you can install from the Python Package Index:

pip install PyCO2SYS

Update an existing installation:

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

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 online 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).

pyco2sys's People

Contributors

mvdh7 avatar mphtest avatar lukegre avatar d-sandborn avatar ajschiller avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.