Learn R Programming

⚠️There's a newer version (3.3.3) of this package.Take me there.

seacarb

Carbonate chemistry with R

In 2003, Aurélien Proye and I put together seacarb, an R package that calculates various parameters of the carbonate system in seawater. The package was subsequently upgraded. In 2008, a new version (2.0) was built with the assistance of Héloïse Lavigne. Five additional functions were included to assist the design of perturbation experiments to investigate ocean acidification and other functions were revised in order to strictly follow the "Guide to best practices for ocean CO2 measurements" (Dickson et al., 2007). Seacarb uses equations mostly from the following sources:

  • Dickson A. G., Sabine C. L. & Christian J. R., 2007. Guide to best practices for ocean CO2 measurements. PICES Special Publication 3:1-191.
  • DOE, 1994. Handbook of methods for the analysis of the various parameters of the carbon dioxide system in sea water; version 2. Dickson, A. G. and Goyet, C., editors. ORNL/CDIAC-74, 1994.
  • Frankignoulle M., 1994. A complete set of buffer factors for acid/base CO2 system in seawater. Journal of Marine Systems 5: 111-118.
  • Orr J. C., Epitalon J.-M., Dickson A. G. & Gattuso J.-P., 2018. Routine uncertainty propagation for the marine carbon dioxide system. Marine Chemistry 207:84-107.
  • Zeebe R. E. & Wolf-Gladrow D. A., 2001. CO2 in seawater: equilibrium, kinetics, isotopes. Amsterdam: Elsevier, 346 pp.

A portion of the code has been adapted, with permission from the authors, from the Matlab files mentioned above. I am grateful to Richard Zeebe and Dieter Wolf-Gladrow for that. Héloïse Lavigne contributed a lot to seacarb in 2008 and 2009; this was critical to the launch of version 2.0 and subsequent updates. Portions of code and/or corrections have also been contributed by Jean-Marie Epitalon (2004, 2018), Bernard Gentili (2006), Karline Soetaert (2007) and Jim Orr (2007, 2010, 2018). Jean-Marie Epitalon considerably improved the code, leading to much faster calculations in version 3.0.

Orr et al. (2015) assessed seacarb together with other packages which calculate the seawater carbonate chemistry. In 2018, option to calculate uncertainty propagation was added (Orr et al., 2018).

This program is provided free under the GNU General Public License (GNU GPL). It will be improved using the comments that I will receive. If you are new to R, please check the manuals and FAQs available on the R-project web site to get information on how to install R and the seacarb package on your system. Please only report and comment on seacarb, not on general problems related to R.

Briefly, after installing R and if you have an Internet connection, here is the simplest way to install seacarb:

  • Launch R
  • To install seacarb (to be done only once), type the following command: install.packages("seacarb")
  • To load the seacarb package into memory in order to use it (to be done each time R is launched), type the following command: library(seacarb)

The seacarb package can be downloaded from the Comprehensive R Archive Network (CRAN; see link below). The documentation is included in the package and is accessible using standard R commands. Please give due credit to the publications mentioned above and cite seacarb as follows:

Gattuso J.-P., Epitalon J.-M., Lavigne H. & Orr J., 2020. seacarb: seawater carbonate chemistry. R package version 3.2.13. http://CRAN.R-project.org/package=seacarb

Copy Link

Version

Install

install.packages('seacarb')

Monthly Downloads

831

Version

3.2.15

License

GPL (>= 2)

Maintainer

Jean-Pierre Gattuso

Last Published

January 20th, 2021

Functions in seacarb (3.2.15)

K2p

Second dissociation constant of phosphoric acid (mol/kg)
K0

Henry's constant mol/(kg/atm)
K1

First dissociation constant of carbonic acid (mol/kg)
Kf

Equilibrium constant of hydrogen fluoride (mol/kg)
K2

Second dissociation constant of carbonic acid (mol/kg)
K1p

First dissociation constant of phosphoric acid (mol/kg)
K3p

Third dissociation constant of phosphoric acid (mol/kg)
Kb

Dissociation constant of boric acid (mol/kg)
K2si

Second dissociation constant of Si(OH)4
Khs

Dissociation constant of hydrogen sulfide (mol/kg)
Ksi

Dissociation constant of Si(OH)4
Pcorrect

Pressure correction of equilibrium constants
Ks

Stability constant of hydrogen sulfate (mol/kg)
Pcoeffs

Coefficients used for pressure-correcting the equilibrium constants
Kn

Dissociation constant of ammonium (mol/kg)
Om

Carbonate saturation state for magnesian calcites
sir

Parameters of the seawater carbonate system including the substrate-inhibitor-ratio (SIR)
amp

pH value of the AMP buffer
Kspa

Solubility product of aragonite (mol/kg)
sir_b

Parameters of the seawater carbonate system with boron addition, including the substrate-inhibitor-ratio (SIR)
sir_full

Parameters of the seawater carbonate system including the substrate-inhibitor-ratio (SIR) - extension of carb
alkalinity

Example data file for function at
Kspc

Solubility product of calcite (mol/kg)
buffergen

Buffer factors of the seawater carbonate system as defined by Hagens and Middelburg (2016)
Kw

Ion product of water (mol2/kg2)
buffer

Buffer parameters of the seawater carbonate system
buffesm

Buffer capacities of the seawater carbonate system from Egleston et al. (2010), corrected and enhanced
carbb

Parameters of the seawater carbonate system with boron addition
bor

Total boron concentration (mol/kg)
bjerrum

Bjerrum plot
fCO2insi

fCO2 at in situ temperature
eos2teos_chem

Convert temperature and salinity from EOS-80 to TEOS-10
eos2teos_geo

Convert temperature and salinity from EOS-80 to TEOS-10
carb

Parameters of the seawater carbonate system
f2pCO2

Converts the CO2 fugacity to CO2 partial pressure
errors

Uncertainty propagation for computed marine carbonate system variables
d2p

Converts depth in meters to pressure in dbar
kconv

Conversion factors to change the pH scale of dissociation constants
p2xCO2

Converts partial pressure of CO2 to mole fraction of CO2
carbfull

Parameters of the seawater carbonate system - extension of carb
pCa

pCa
pH

Potentiometric pH
derivnum

Numerical derivatives of seawater carbonate system variables
pHslope

Slope of the calibration curve of a pH electrode
kfg

variable for internal use
pHinsi

pH at in situ temperature and pressure
oa

Perturbation of the seawater carbonate system
pgas

pgas
p2d

Converts pressure in dbar to depth in meters
pHconv

Conversion of pH
tris

pH of TRIS buffer
pmix

pmix
vapress

Computes vapor pressure of seawater
ppH

ppH
sa2sp_geo

From absolute to practical salinity
pTA

pTA
pHspec

Calculates pHT from results of spectrophotometric measurements
speciation

ionic forms as a function of pH
teos2eos_chem

Convert temperature and salinity from TEOS-10 to EOS-80
seaFET

Test seaFET data file
p2fCO2

Converts pCO2 (partial pressure in CO2) into fCO2 (fugacity of CO2)
theta

Potential temperature of seawater
teos2eos_geo

Convert temperature and salinity from TEOS-10 to EOS-80
seacarb_test_P0

Test data file (at P=0) to test the use of the carb function
x2pCO2

Converts mole fraction to partial pressure of CO2
seacarb_test_P300

Test data file (at P=300) to test the use of the carb function
sf_calc

Calculation of calibrated pH for seaFET sensor
psi

Molar ratio of CO2 released vs CaCO3 precipitated
sa2sp_chem

From absolute to practical salinity
sp2sa_chem

From Practical to absolute salinity
rho

Density of seawater (kg/m3)
sf_calib

Calibration coefficients for seaFET sensor
sp2sa_geo

From practical to absolute salinity