"""
Auto-generated wrapper for C ufunc extension; do not edit!
"""
from . import _gsw_ufuncs
from ._utilities import match_args_return
[docs]
def adiabatic_lapse_rate_from_CT(SA, CT, p):
"""
Calculates the adiabatic lapse rate of sea water from Conservative
Temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
adiabatic_lapse_rate : array-like, K/Pa
adiabatic lapse rate
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqn. (2.22.1) of this TEOS-10 Manual.
"""
return _gsw_ufuncs.adiabatic_lapse_rate_from_ct(SA, CT, p)
adiabatic_lapse_rate_from_CT.types = _gsw_ufuncs.adiabatic_lapse_rate_from_ct.types
adiabatic_lapse_rate_from_CT = match_args_return(adiabatic_lapse_rate_from_CT)
[docs]
def adiabatic_lapse_rate_ice(t, p):
"""
Calculates the adiabatic lapse rate of ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
adiabatic_lapse_rate_ice : array-like, K/Pa
adiabatic lapse rate
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
"""
return _gsw_ufuncs.adiabatic_lapse_rate_ice(t, p)
adiabatic_lapse_rate_ice.types = _gsw_ufuncs.adiabatic_lapse_rate_ice.types
adiabatic_lapse_rate_ice = match_args_return(adiabatic_lapse_rate_ice)
[docs]
def alpha(SA, CT, p):
"""
Calculates the thermal expansion coefficient of seawater with respect to
Conservative Temperature using the computationally-efficient expression
for specific volume in terms of SA, CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
alpha : array-like, 1/K
thermal expansion coefficient
with respect to Conservative Temperature
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (2.18.3) of this TEOS-10 manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.alpha(SA, CT, p)
alpha.types = _gsw_ufuncs.alpha.types
alpha = match_args_return(alpha)
[docs]
def alpha_on_beta(SA, CT, p):
"""
Calculates alpha divided by beta, where alpha is the thermal expansion
coefficient and beta is the saline contraction coefficient of seawater
from Absolute Salinity and Conservative Temperature. This function uses
the computationally-efficient expression for specific volume in terms of
SA, CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
alpha_on_beta : array-like, g kg^-1 K^-1
thermal expansion coefficient with respect to
Conservative Temperature divided by the saline
contraction coefficient at constant Conservative
Temperature
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.20 and appendix K of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2014: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling.
"""
return _gsw_ufuncs.alpha_on_beta(SA, CT, p)
alpha_on_beta.types = _gsw_ufuncs.alpha_on_beta.types
alpha_on_beta = match_args_return(alpha_on_beta)
[docs]
def alpha_wrt_t_exact(SA, t, p):
"""
Calculates the thermal expansion coefficient of seawater with respect to
in-situ temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
alpha_wrt_t_exact : array-like, 1/K
thermal expansion coefficient
with respect to in-situ temperature
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqn. (2.18.1) of this TEOS-10 manual.
"""
return _gsw_ufuncs.alpha_wrt_t_exact(SA, t, p)
alpha_wrt_t_exact.types = _gsw_ufuncs.alpha_wrt_t_exact.types
alpha_wrt_t_exact = match_args_return(alpha_wrt_t_exact)
[docs]
def alpha_wrt_t_ice(t, p):
"""
Calculates the thermal expansion coefficient of ice with respect to
in-situ temperature.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
alpha_wrt_t_ice : array-like, 1/K
thermal expansion coefficient of ice with respect
to in-situ temperature
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqn. (2.18.1) of this TEOS-10 manual.
"""
return _gsw_ufuncs.alpha_wrt_t_ice(t, p)
alpha_wrt_t_ice.types = _gsw_ufuncs.alpha_wrt_t_ice.types
alpha_wrt_t_ice = match_args_return(alpha_wrt_t_ice)
[docs]
def beta(SA, CT, p):
"""
Calculates the saline (i.e. haline) contraction coefficient of seawater
at constant Conservative Temperature using the computationally-efficient
75-term expression for specific volume in terms of SA, CT and p
(Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
beta : array-like, kg/g
saline contraction coefficient
at constant Conservative Temperature
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (2.19.3) of this TEOS-10 manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.beta(SA, CT, p)
beta.types = _gsw_ufuncs.beta.types
beta = match_args_return(beta)
[docs]
def beta_const_t_exact(SA, t, p):
"""
Calculates the saline (i.e. haline) contraction coefficient of seawater
at constant in-situ temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
beta_const_t_exact : array-like, kg/g
saline contraction coefficient
at constant in-situ temperature
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (2.19.1) of this TEOS-10 manual.
"""
return _gsw_ufuncs.beta_const_t_exact(SA, t, p)
beta_const_t_exact.types = _gsw_ufuncs.beta_const_t_exact.types
beta_const_t_exact = match_args_return(beta_const_t_exact)
[docs]
def C_from_SP(SP, t, p):
"""
Calculates conductivity, C, from (SP,t,p) using PSS-78 in the range
2 < SP < 42. If the input Practical Salinity is less than 2 then a
modified form of the Hill et al. (1986) formula is used for Practical
Salinity. The modification of the Hill et al. (1986) expression is to
ensure that it is exactly consistent with PSS-78 at SP = 2.
Parameters
----------
SP : array-like
Practical Salinity (PSS-78), unitless
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
C : array-like, mS/cm
conductivity
Notes
-----
The conductivity ratio returned by this function is consistent with the
input value of Practical Salinity, SP, to 2x10^-14 psu over the full
range of input parameters (from pure fresh water up to SP = 42 psu).
This error of 2x10^-14 psu is machine precision at typical seawater
salinities. This accuracy is achieved by having four different
polynomials for the starting value of Rtx (the square root of Rt) in
four different ranges of SP, and by using one and a half iterations of
a computationally efficient modified Newton-Raphson technique (McDougall
and Wotherspoon, 2013) to find the root of the equation.
Note that strictly speaking PSS-78 (Unesco, 1983) defines Practical
Salinity in terms of the conductivity ratio, R, without actually
specifying the value of C(35,15,0) (which we currently take to be
42.9140 mS/cm).
References
----------
Hill, K.D., T.M. Dauphinee and D.J. Woods, 1986: The extension of the
Practical Salinity Scale 1978 to low salinities. IEEE J. Oceanic Eng.,
OE-11, 1, 109 - 112.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix E of this TEOS-10 Manual.
McDougall T. J. and S. J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
Unesco, 1983: Algorithms for computation of fundamental properties of
seawater. Unesco Technical Papers in Marine Science, 44, 53 pp.
"""
return _gsw_ufuncs.c_from_sp(SP, t, p)
C_from_SP.types = _gsw_ufuncs.c_from_sp.types
C_from_SP = match_args_return(C_from_SP)
[docs]
def cabbeling(SA, CT, p):
"""
Calculates the cabbeling coefficient of seawater with respect to
Conservative Temperature. This function uses the computationally-
efficient expression for specific volume in terms of SA, CT and p
(Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
cabbeling : array-like, 1/K^2
cabbeling coefficient with respect to
Conservative Temperature.
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqns. (3.9.2) and (P.4) of this TEOS-10 manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.cabbeling(SA, CT, p)
cabbeling.types = _gsw_ufuncs.cabbeling.types
cabbeling = match_args_return(cabbeling)
[docs]
def chem_potential_water_ice(t, p):
"""
Calculates the chemical potential of water in ice from in-situ
temperature and pressure.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
chem_potential_water_ice : array-like, J/kg
chemical potential of ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.chem_potential_water_ice(t, p)
chem_potential_water_ice.types = _gsw_ufuncs.chem_potential_water_ice.types
chem_potential_water_ice = match_args_return(chem_potential_water_ice)
[docs]
def chem_potential_water_t_exact(SA, t, p):
"""
Calculates the chemical potential of water in seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
chem_potential_water_t_exact : array-like, J/g
chemical potential of water in seawater
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.chem_potential_water_t_exact(SA, t, p)
chem_potential_water_t_exact.types = _gsw_ufuncs.chem_potential_water_t_exact.types
chem_potential_water_t_exact = match_args_return(chem_potential_water_t_exact)
[docs]
def cp_ice(t, p):
"""
Calculates the isobaric heat capacity of ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
cp_ice : array-like, J kg^-1 K^-1
heat capacity of ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.cp_ice(t, p)
cp_ice.types = _gsw_ufuncs.cp_ice.types
cp_ice = match_args_return(cp_ice)
[docs]
def cp_t_exact(SA, t, p):
"""
Calculates the isobaric heat capacity of seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
cp_t_exact : array-like, J/(kg*K)
heat capacity of seawater
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.cp_t_exact(SA, t, p)
cp_t_exact.types = _gsw_ufuncs.cp_t_exact.types
cp_t_exact = match_args_return(cp_t_exact)
[docs]
def CT_first_derivatives(SA, pt):
"""
Calculates the following two derivatives of Conservative Temperature
(1) CT_SA, the derivative with respect to Absolute Salinity at
constant potential temperature (with pr = 0 dbar), and
2) CT_pt, the derivative with respect to potential temperature
(the regular potential temperature which is referenced to 0 dbar)
at constant Absolute Salinity.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
pt : array-like
Potential temperature referenced to a sea pressure, degrees C
Returns
-------
CT_SA : array-like, K/(g/kg)
The derivative of Conservative Temperature with respect to
Absolute Salinity at constant potential temperature
(the regular potential temperature which has reference
sea pressure of 0 dbar).
CT_pt : array-like, unitless
The derivative of Conservative Temperature with respect to
potential temperature (the regular one with pr = 0 dbar)
at constant SA. CT_pt is dimensionless.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqns. (A.12.3a,b) and (A.15.8) of this TEOS-10 Manual.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.ct_first_derivatives(SA, pt)
CT_first_derivatives.types = _gsw_ufuncs.ct_first_derivatives.types
CT_first_derivatives = match_args_return(CT_first_derivatives)
[docs]
def CT_first_derivatives_wrt_t_exact(SA, t, p):
"""
Calculates the following three derivatives of Conservative Temperature.
These derivatives are done with respect to in-situ temperature t (in the
case of CT_T_wrt_t) or at constant in-situ tempertature (in the cases of
CT_SA_wrt_t and CT_P_wrt_t).
(1) CT_SA_wrt_t, the derivative of CT with respect to Absolute Salinity
at constant t and p, and
(2) CT_T_wrt_t, derivative of CT with respect to in-situ temperature t
at constant SA and p.
(3) CT_P_wrt_t, derivative of CT with respect to pressure P (in Pa) at
constant SA and t.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
CT_SA_wrt_t : array-like, K kg/g
The first derivative of Conservative Temperature with
respect to Absolute Salinity at constant t and p.
[ K/(g/kg)] i.e.
CT_T_wrt_t : array-like, unitless
The first derivative of Conservative Temperature with
respect to in-situ temperature, t, at constant SA and p.
CT_P_wrt_t : array-like, K/Pa
The first derivative of Conservative Temperature with
respect to pressure P (in Pa) at constant SA and t.
Notes
-----
This function uses the full Gibbs function. Note that this function
avoids the NaN that would exist in CT_SA_wrt_t at SA = 0 if it were
evaluated in the straightforward way from the derivatives of the Gibbs
function function.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqns. (A.15.3) and (A.15.8) of this TEOS-10 Manual for
CT_T_wrt_t and CT_SA_wrt_t respectively.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.ct_first_derivatives_wrt_t_exact(SA, t, p)
CT_first_derivatives_wrt_t_exact.types = _gsw_ufuncs.ct_first_derivatives_wrt_t_exact.types
CT_first_derivatives_wrt_t_exact = match_args_return(CT_first_derivatives_wrt_t_exact)
[docs]
def CT_freezing(SA, p, saturation_fraction):
"""
Calculates the Conservative Temperature at which seawater freezes. The
Conservative Temperature freezing point is calculated from the exact
in-situ freezing temperature which is found by a modified Newton-Raphson
iteration (McDougall and Wotherspoon, 2014) of the equality of the
chemical potentials of water in seawater and in ice.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
CT_freezing : array-like, deg C
Conservative Temperature at freezing of seawater
That is, the freezing temperature expressed in terms of
Conservative Temperature (ITS-90).
Notes
-----
An alternative GSW function, gsw_CT_freezing_poly, it is based on a
computationally-efficient polynomial, and is accurate to within -5e-4 K
and 6e-4 K, when compared with this function.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., and S.J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.ct_freezing(SA, p, saturation_fraction)
CT_freezing.types = _gsw_ufuncs.ct_freezing.types
CT_freezing = match_args_return(CT_freezing)
[docs]
def CT_freezing_first_derivatives(SA, p, saturation_fraction):
"""
Calculates the first derivatives of the Conservative Temperature at
which seawater freezes, with respect to Absolute Salinity SA and
pressure P (in Pa).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
CTfreezing_SA : array-like, K kg/g
the derivative of the Conservative Temperature at
freezing (ITS-90) with respect to Absolute Salinity at
fixed pressure [ K/(g/kg) ] i.e.
CTfreezing_P : array-like, K/Pa
the derivative of the Conservative Temperature at
freezing (ITS-90) with respect to pressure (in Pa) at
fixed Absolute Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
"""
return _gsw_ufuncs.ct_freezing_first_derivatives(SA, p, saturation_fraction)
CT_freezing_first_derivatives.types = _gsw_ufuncs.ct_freezing_first_derivatives.types
CT_freezing_first_derivatives = match_args_return(CT_freezing_first_derivatives)
[docs]
def CT_freezing_first_derivatives_poly(SA, p, saturation_fraction):
"""
Calculates the first derivatives of the Conservative Temperature at
which seawater freezes, with respect to Absolute Salinity SA and
pressure P (in Pa) of the comptationally efficient polynomial fit of the
freezing temperature (McDougall et al., 2014).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
CTfreezing_SA : array-like, K kg/g
the derivative of the Conservative Temperature at
freezing (ITS-90) with respect to Absolute Salinity at
fixed pressure [ K/(g/kg) ] i.e.
CTfreezing_P : array-like, K/Pa
the derivative of the Conservative Temperature at
freezing (ITS-90) with respect to pressure (in Pa) at
fixed Absolute Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
"""
return _gsw_ufuncs.ct_freezing_first_derivatives_poly(SA, p, saturation_fraction)
CT_freezing_first_derivatives_poly.types = _gsw_ufuncs.ct_freezing_first_derivatives_poly.types
CT_freezing_first_derivatives_poly = match_args_return(CT_freezing_first_derivatives_poly)
[docs]
def CT_freezing_poly(SA, p, saturation_fraction):
"""
Calculates the Conservative Temperature at which seawater freezes.
The error of this fit ranges between -5e-4 K and 6e-4 K when compared
with the Conservative Temperature calculated from the exact in-situ
freezing temperature which is found by a Newton-Raphson iteration of the
equality of the chemical potentials of water in seawater and in ice.
Note that the Conservative Temperature freezing temperature can be found
by this exact method using the function gsw_CT_freezing.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
CT_freezing : array-like, deg C
Conservative Temperature at freezing of seawater
That is, the freezing temperature expressed in
terms of Conservative Temperature (ITS-90).
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
"""
return _gsw_ufuncs.ct_freezing_poly(SA, p, saturation_fraction)
CT_freezing_poly.types = _gsw_ufuncs.ct_freezing_poly.types
CT_freezing_poly = match_args_return(CT_freezing_poly)
[docs]
def CT_from_enthalpy(SA, h, p):
"""
Calculates the Conservative Temperature of seawater, given the Absolute
Salinity, specific enthalpy, h, and pressure p. The specific enthalpy
input is the one calculated from the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
h : array-like
Specific enthalpy, J/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
CT : array-like, deg C
Conservative Temperature ( ITS-90)
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
McDougall, T.J., and S.J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.ct_from_enthalpy(SA, h, p)
CT_from_enthalpy.types = _gsw_ufuncs.ct_from_enthalpy.types
CT_from_enthalpy = match_args_return(CT_from_enthalpy)
[docs]
def CT_from_enthalpy_exact(SA, h, p):
"""
Calculates the Conservative Temperature of seawater, given the Absolute
Salinity, SA, specific enthalpy, h, and pressure p. The specific
enthalpy input is calculated from the full Gibbs function of seawater,
gsw_enthalpy_t_exact.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
h : array-like
Specific enthalpy, J/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
CT : array-like, deg C
Conservative Temperature ( ITS-90)
Notes
-----
Note that this function uses the full Gibbs function. There is an
alternative to calling this function, namely
gsw_CT_from_enthalpy(SA,h,p), which uses the computationally
efficient 75-term expression for specific volume in terms of SA, CT
and p (Roquet et al., 2015).
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
McDougall T.J. and S.J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.ct_from_enthalpy_exact(SA, h, p)
CT_from_enthalpy_exact.types = _gsw_ufuncs.ct_from_enthalpy_exact.types
CT_from_enthalpy_exact = match_args_return(CT_from_enthalpy_exact)
[docs]
def CT_from_entropy(SA, entropy):
"""
Calculates Conservative Temperature with entropy as an input variable.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
entropy : array-like
Specific entropy, J/(kg*K)
Returns
-------
CT : array-like, deg C
Conservative Temperature (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.10 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.ct_from_entropy(SA, entropy)
CT_from_entropy.types = _gsw_ufuncs.ct_from_entropy.types
CT_from_entropy = match_args_return(CT_from_entropy)
[docs]
def CT_from_pt(SA, pt):
"""
Calculates Conservative Temperature of seawater from potential
temperature (whose reference sea pressure is zero dbar).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
pt : array-like
Potential temperature referenced to a sea pressure, degrees C
Returns
-------
CT : array-like, deg C
Conservative Temperature (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.3 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.ct_from_pt(SA, pt)
CT_from_pt.types = _gsw_ufuncs.ct_from_pt.types
CT_from_pt = match_args_return(CT_from_pt)
[docs]
def CT_from_rho(rho, SA, p):
"""
Calculates the Conservative Temperature of a seawater sample, for given
values of its density, Absolute Salinity and sea pressure (in dbar),
using the computationally-efficient expression for specific volume in
terms of SA, CT and p (Roquet et al., 2015).
Parameters
----------
rho : array-like
Seawater density (not anomaly) in-situ, e.g., 1026 kg/m^3.
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
CT : array-like, deg C
Conservative Temperature (ITS-90)
CT_multiple : array-like, deg C
Conservative Temperature (ITS-90)
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling, 90, pp. 29-43.
"""
return _gsw_ufuncs.ct_from_rho(rho, SA, p)
CT_from_rho.types = _gsw_ufuncs.ct_from_rho.types
CT_from_rho = match_args_return(CT_from_rho)
[docs]
def CT_from_t(SA, t, p):
"""
Calculates Conservative Temperature of seawater from in-situ
temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
CT : array-like, deg C
Conservative Temperature (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.3 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.ct_from_t(SA, t, p)
CT_from_t.types = _gsw_ufuncs.ct_from_t.types
CT_from_t = match_args_return(CT_from_t)
[docs]
def CT_maxdensity(SA, p):
"""
Calculates the Conservative Temperature of maximum density of seawater.
This function returns the Conservative temperature at which the density
of seawater is a maximum, at given Absolute Salinity, SA, and sea
pressure, p (in dbar). This function uses the computationally-efficient
expression for specific volume in terms of SA, CT and p
(Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
CT_maxdensity : array-like, deg C
Conservative Temperature at which
the density of seawater is a maximum for
given Absolute Salinity and pressure.
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.42 of this TEOS-10 Manual.
McDougall T. J. and S. J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.ct_maxdensity(SA, p)
CT_maxdensity.types = _gsw_ufuncs.ct_maxdensity.types
CT_maxdensity = match_args_return(CT_maxdensity)
[docs]
def CT_second_derivatives(SA, pt):
"""
Calculates the following three, second-order derivatives of Conservative
Temperature
(1) CT_SA_SA, the second derivative with respect to Absolute Salinity
at constant potential temperature (with p_ref = 0 dbar),
(2) CT_SA_pt, the derivative with respect to potential temperature
(the regular potential temperature which is referenced to 0 dbar)
and Absolute Salinity, and
(3) CT_pt_pt, the second derivative with respect to potential
temperature (the regular potential temperature which is referenced
to 0 dbar) at constant Absolute Salinity.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
pt : array-like
Potential temperature referenced to a sea pressure, degrees C
Returns
-------
CT_SA_SA : array-like, K/((g/kg)^2)
The second derivative of Conservative Temperature with
respect to Absolute Salinity at constant potential
temperature (the regular potential temperature which
has reference sea pressure of 0 dbar).
CT_SA_pt : array-like,
The derivative of Conservative Temperature with
respect to potential temperature (the regular one with
p_ref : array-like, 1/(g/kg)
0 dbar) and Absolute Salinity.
CT_pt_pt : array-like,
The second derivative of Conservative Temperature with
respect to potential temperature (the regular one with
p_ref : array-like, 1/K
0 dbar) at constant SA.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See appendix A.12 of this TEOS-10 Manual.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.ct_second_derivatives(SA, pt)
CT_second_derivatives.types = _gsw_ufuncs.ct_second_derivatives.types
CT_second_derivatives = match_args_return(CT_second_derivatives)
[docs]
def deltaSA_atlas(p, lon, lat):
"""
Calculates the Absolute Salinity Anomaly atlas value, SA - SR, in
the open ocean by spatially interpolating the global reference data set
of deltaSA_atlas to the location of the seawater sample.
Parameters
----------
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
deltaSA_atlas : array-like, g/kg
Absolute Salinity Anomaly atlas value
Notes
-----
The Absolute Salinity Anomaly atlas value in the Baltic Sea is
evaluated separately, since it is a function of Practical Salinity, not
of space. The present function returns a deltaSA_atlas of zero for
data in the Baltic Sea. The correct way of calculating Absolute
Salinity in the Baltic Sea is by calling gsw_SA_from_SP.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.deltasa_atlas(p, lon, lat)
deltaSA_atlas.types = _gsw_ufuncs.deltasa_atlas.types
deltaSA_atlas = match_args_return(deltaSA_atlas)
[docs]
def deltaSA_from_SP(SP, p, lon, lat):
"""
Calculates Absolute Salinity Anomaly from Practical Salinity. Since SP
is non-negative by definition, this function changes any negative input
values of SP to be zero.
Parameters
----------
SP : array-like
Practical Salinity (PSS-78), unitless
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
deltaSA : array-like, g/kg
Absolute Salinity Anomaly
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 2.5 and appendices A.4 and A.5 of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1117-1128.
https://os.copernicus.org/articles/8/1117/2012/os-8-1117-2012.pdf
"""
return _gsw_ufuncs.deltasa_from_sp(SP, p, lon, lat)
deltaSA_from_SP.types = _gsw_ufuncs.deltasa_from_sp.types
deltaSA_from_SP = match_args_return(deltaSA_from_SP)
[docs]
def dilution_coefficient_t_exact(SA, t, p):
"""
Calculates the dilution coefficient of seawater. The dilution
coefficient of seawater is defined as the Absolute Salinity times the
second derivative of the Gibbs function with respect to Absolute
Salinity, that is, SA.*g_SA_SA.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
dilution_coefficient_t_exact : array-like, (J/kg)(kg/g)
dilution coefficient
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.dilution_coefficient_t_exact(SA, t, p)
dilution_coefficient_t_exact.types = _gsw_ufuncs.dilution_coefficient_t_exact.types
dilution_coefficient_t_exact = match_args_return(dilution_coefficient_t_exact)
[docs]
def dynamic_enthalpy(SA, CT, p):
"""
Calculates dynamic enthalpy of seawater using the computationally-
efficient expression for specific volume in terms of SA, CT and p
(Roquet et al., 2015). Dynamic enthalpy is defined as enthalpy minus
potential enthalpy (Young, 2010).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
dynamic_enthalpy : array-like, J/kg
dynamic enthalpy
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.2 of this TEOS-10 Manual.
McDougall, T. J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
See Eqns. (18) and (22)
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
Young, W.R., 2010: Dynamic enthalpy, Conservative Temperature, and the
seawater Boussinesq approximation. Journal of Physical Oceanography,
40, 394-400.
"""
return _gsw_ufuncs.dynamic_enthalpy(SA, CT, p)
dynamic_enthalpy.types = _gsw_ufuncs.dynamic_enthalpy.types
dynamic_enthalpy = match_args_return(dynamic_enthalpy)
[docs]
def enthalpy(SA, CT, p):
"""
Calculates specific enthalpy of seawater using the computationally-
efficient expression for specific volume in terms of SA, CT and p
(Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
enthalpy : array-like, J/kg
specific enthalpy
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (A.30.6) of this TEOS-10 Manual.
McDougall, T.J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
See Eqns. (18) and (22)
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.enthalpy(SA, CT, p)
enthalpy.types = _gsw_ufuncs.enthalpy.types
enthalpy = match_args_return(enthalpy)
[docs]
def enthalpy_CT_exact(SA, CT, p):
"""
Calculates specific enthalpy of seawater from Absolute Salinity and
Conservative Temperature and pressure.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
enthalpy_CT_exact : array-like, J/kg
specific enthalpy
Notes
-----
Note that this function uses the full Gibbs function. There is an
alternative to calling this function, namely gsw_enthalpy(SA,CT,p),
which uses the computationally-efficient 75-term expression for specific
volume in terms of SA, CT and p (Roquet et al., 2015).
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.11 of this TEOS-10 Manual.
McDougall, T. J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
See Eqns. (18) and (22)
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.enthalpy_ct_exact(SA, CT, p)
enthalpy_CT_exact.types = _gsw_ufuncs.enthalpy_ct_exact.types
enthalpy_CT_exact = match_args_return(enthalpy_CT_exact)
[docs]
def enthalpy_diff(SA, CT, p_shallow, p_deep):
"""
Calculates the difference of the specific enthalpy of seawater between
two different pressures, p_deep (the deeper pressure) and p_shallow
(the shallower pressure), at the same values of SA and CT. This
function uses the computationally-efficient expression for specific
volume in terms of SA, CT and p (Roquet et al., 2015). The output
(enthalpy_diff) is the specific enthalpy evaluated at (SA,CT,p_deep)
minus the specific enthalpy at (SA,CT,p_shallow).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p_shallow : array-like
Upper sea pressure (absolute pressure minus 10.1325 dbar), dbar
p_deep : array-like
Lower sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
enthalpy_diff : array-like, J/kg
difference of specific enthalpy
(deep minus shallow)
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqns. (3.32.2) and (A.30.6) of this TEOS-10 Manual.
McDougall, T.J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
See Eqns. (18) and (22)
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.enthalpy_diff(SA, CT, p_shallow, p_deep)
enthalpy_diff.types = _gsw_ufuncs.enthalpy_diff.types
enthalpy_diff = match_args_return(enthalpy_diff)
[docs]
def enthalpy_first_derivatives(SA, CT, p):
"""
Calculates the following two derivatives of specific enthalpy (h) of
seawater using the computationally-efficient expression for
specific volume in terms of SA, CT and p (Roquet et al., 2015).
(1) h_SA, the derivative with respect to Absolute Salinity at
constant CT and p, and
(2) h_CT, derivative with respect to CT at constant SA and p.
Note that h_P is specific volume (1/rho) it can be calculated by calling
gsw_specvol(SA,CT,p).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
h_SA : array-like, J/g
The first derivative of specific enthalpy with respect to
Absolute Salinity at constant CT and p.
[ J/(kg (g/kg))] i.e.
h_CT : array-like, J/(kg K)
The first derivative of specific enthalpy with respect to
CT at constant SA and p.
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqns. (A.11.18), (A.11.15) and (A.11.12) of this TEOS-10 Manual.
McDougall, T.J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
See Eqns. (18) and (22)
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling, 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.enthalpy_first_derivatives(SA, CT, p)
enthalpy_first_derivatives.types = _gsw_ufuncs.enthalpy_first_derivatives.types
enthalpy_first_derivatives = match_args_return(enthalpy_first_derivatives)
[docs]
def enthalpy_first_derivatives_CT_exact(SA, CT, p):
"""
Calculates the following two derivatives of specific enthalpy, h,
(1) h_SA, the derivative with respect to Absolute Salinity at
constant CT and p, and
(2) h_CT, derivative with respect to CT at constant SA and p.
Note that h_P is specific volume, v, it can be calculated by calling
gsw_specvol_CT_exact(SA,CT,p).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
h_SA : array-like, J/g
The first derivative of specific enthalpy with respect to
Absolute Salinity at constant CT and p.
[ J/(kg (g/kg))] i.e.
h_CT : array-like, J/(kg K)
The first derivative of specific enthalpy with respect to
CT at constant SA and p.
Notes
-----
Note that this function uses the full Gibbs function. There is an
alternative to calling this function, namely
gsw_enthalpy_first_derivatives(SA,CT,p) which uses the computationally
efficient 75-term expression for specific volume in terms of SA, CT and
p (Roquet et al., 2015).
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqns. (A.11.18), (A.11.15) and (A.11.12) of this TEOS-10 Manual.
McDougall, T.J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
See Eqns. (18) and (22)
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.enthalpy_first_derivatives_ct_exact(SA, CT, p)
enthalpy_first_derivatives_CT_exact.types = _gsw_ufuncs.enthalpy_first_derivatives_ct_exact.types
enthalpy_first_derivatives_CT_exact = match_args_return(enthalpy_first_derivatives_CT_exact)
[docs]
def enthalpy_ice(t, p):
"""
Calculates the specific enthalpy of ice (h_Ih).
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
enthalpy_ice : array-like, J/kg
specific enthalpy of ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.enthalpy_ice(t, p)
enthalpy_ice.types = _gsw_ufuncs.enthalpy_ice.types
enthalpy_ice = match_args_return(enthalpy_ice)
[docs]
def enthalpy_second_derivatives(SA, CT, p):
"""
Calculates the following three second-order derivatives of specific
enthalpy (h),using the computationally-efficient expression for
specific volume in terms of SA, CT and p (Roquet et al., 2015).
(1) h_SA_SA, second-order derivative with respect to Absolute Salinity
at constant CT & p.
(2) h_SA_CT, second-order derivative with respect to SA & CT at
constant p.
(3) h_CT_CT, second-order derivative with respect to CT at constant SA
and p.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
h_SA_SA : array-like, J/(kg (g/kg)^2)
The second derivative of specific enthalpy with respect to
Absolute Salinity at constant CT & p.
h_SA_CT : array-like, J/(kg K(g/kg))
The second derivative of specific enthalpy with respect to
SA and CT at constant p.
h_CT_CT : array-like, J/(kg K^2)
The second derivative of specific enthalpy with respect to
CT at constant SA and p.
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
See Eqns. (18) and (22)
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.enthalpy_second_derivatives(SA, CT, p)
enthalpy_second_derivatives.types = _gsw_ufuncs.enthalpy_second_derivatives.types
enthalpy_second_derivatives = match_args_return(enthalpy_second_derivatives)
[docs]
def enthalpy_second_derivatives_CT_exact(SA, CT, p):
"""
Calculates the following three second-order derivatives of specific
enthalpy (h),
(1) h_SA_SA, second-order derivative with respect to Absolute Salinity
at constant CT & p.
(2) h_SA_CT, second-order derivative with respect to SA & CT at
constant p.
(3) h_CT_CT, second-order derivative with respect to CT at constant SA
and p.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
h_SA_SA : array-like, J/(kg (g/kg)^2)
The second derivative of specific enthalpy with respect to
Absolute Salinity at constant CT & p.
h_SA_CT : array-like, J/(kg K(g/kg))
The second derivative of specific enthalpy with respect to
SA and CT at constant p.
h_CT_CT : array-like, J/(kg K^2)
The second derivative of specific enthalpy with respect to
CT at constant SA and p.
Notes
-----
Note that this function uses the full Gibbs function. There is an
alternative to calling this function, namely
gsw_enthalpy_second_derivatives(SA,CT,p) which uses the computationally
efficient 75-term expression for specific volume in terms of SA, CT and
p (Roquet et al., 2015).
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T. J., 2003: Potential enthalpy: A conservative oceanic
variable for evaluating heat content and heat fluxes. Journal of
Physical Oceanography, 33, 945-963.
See Eqns. (18) and (22)
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.enthalpy_second_derivatives_ct_exact(SA, CT, p)
enthalpy_second_derivatives_CT_exact.types = _gsw_ufuncs.enthalpy_second_derivatives_ct_exact.types
enthalpy_second_derivatives_CT_exact = match_args_return(enthalpy_second_derivatives_CT_exact)
[docs]
def enthalpy_SSO_0(p):
"""
enthalpy at (SSO,CT=0,p)
Parameters
----------
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
double, array
Notes
-----
gsw_enthalpy_SSO_0 enthalpy at (SSO,CT=0,p)
(75-term eqn.)
This function calculates enthalpy at the Standard Ocean Salinity, SSO,
and at a Conservative Temperature of zero degrees C, as a function of
pressure, p, in dbar, using a streamlined version of the 75-term
computationally-efficient expression for specific volume, that is, a
streamlined version of the code "gsw_enthalpy(SA,CT,p)".
VERSION NUMBER: 3.06.12 (25th May, 2020)
References
----------
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.enthalpy_sso_0(p)
enthalpy_SSO_0.types = _gsw_ufuncs.enthalpy_sso_0.types
enthalpy_SSO_0 = match_args_return(enthalpy_SSO_0)
[docs]
def enthalpy_t_exact(SA, t, p):
"""
Calculates the specific enthalpy of seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
enthalpy_t_exact : array-like, J/kg
specific enthalpy
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.enthalpy_t_exact(SA, t, p)
enthalpy_t_exact.types = _gsw_ufuncs.enthalpy_t_exact.types
enthalpy_t_exact = match_args_return(enthalpy_t_exact)
[docs]
def entropy_first_derivatives(SA, CT):
"""
Calculates the following two partial derivatives of specific entropy
(eta)
(1) eta_SA, the derivative with respect to Absolute Salinity at
constant Conservative Temperature, and
(2) eta_CT, the derivative with respect to Conservative Temperature at
constant Absolute Salinity.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
eta_SA : array-like, J/(g K)
The derivative of specific entropy with respect to
Absolute Salinity (in units of g kg^-1) at constant
Conservative Temperature.
eta_CT : array-like, J/(kg K^2)
The derivative of specific entropy with respect to
Conservative Temperature at constant Absolute Salinity.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqns. (A.12.8) and (P.14a,c) of this TEOS-10 Manual.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.entropy_first_derivatives(SA, CT)
entropy_first_derivatives.types = _gsw_ufuncs.entropy_first_derivatives.types
entropy_first_derivatives = match_args_return(entropy_first_derivatives)
[docs]
def entropy_from_CT(SA, CT):
"""
Calculates specific entropy of seawater from Conservative Temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
entropy : array-like, J/(kg*K)
specific entropy
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.10 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.entropy_from_ct(SA, CT)
entropy_from_CT.types = _gsw_ufuncs.entropy_from_ct.types
entropy_from_CT = match_args_return(entropy_from_CT)
[docs]
def entropy_from_pt(SA, pt):
"""
Calculates specific entropy of seawater as a function of potential
temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
pt : array-like
Potential temperature referenced to a sea pressure, degrees C
Returns
-------
entropy : array-like, J/(kg*K)
specific entropy
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.10 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.entropy_from_pt(SA, pt)
entropy_from_pt.types = _gsw_ufuncs.entropy_from_pt.types
entropy_from_pt = match_args_return(entropy_from_pt)
[docs]
def entropy_from_t(SA, t, p):
"""
Calculates specific entropy of seawater from in-situ temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
entropy : array-like, J/(kg*K)
specific entropy
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.entropy_from_t(SA, t, p)
entropy_from_t.types = _gsw_ufuncs.entropy_from_t.types
entropy_from_t = match_args_return(entropy_from_t)
[docs]
def entropy_ice(t, p):
"""
Calculates specific entropy of ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
ice_entropy : array-like, J kg^-1 K^-1
specific entropy of ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.entropy_ice(t, p)
entropy_ice.types = _gsw_ufuncs.entropy_ice.types
entropy_ice = match_args_return(entropy_ice)
[docs]
def entropy_part(SA, t, p):
"""
entropy minus the terms that are a function of only SA
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
double, array
Notes
-----
sw_entropy_part entropy minus the terms that are a function of only SA
This function calculates entropy, except that it does not evaluate any
terms that are functions of Absolute Salinity alone. By not calculating
these terms, which are a function only of Absolute Salinity, several
unnecessary computations are avoided (including saving the computation
of a natural logarithm). These terms are a necessary part of entropy,
but are not needed when calculating potential temperature from in-situ
temperature.
VERSION NUMBER: 3.06.12 (25th May, 2020)
"""
return _gsw_ufuncs.entropy_part(SA, t, p)
entropy_part.types = _gsw_ufuncs.entropy_part.types
entropy_part = match_args_return(entropy_part)
[docs]
def entropy_part_zerop(SA, pt0):
"""
entropy_part evaluated at the sea surface
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
pt0 : array-like
Potential temperature with reference pressure of 0 dbar, degrees C
Returns
-------
double, array
Notes
-----
gsw_entropy_part_zerop entropy_part evaluated at the sea surface
This function calculates entropy at a sea pressure of zero, except that
it does not evaluate any terms that are functions of Absolute Salinity
alone. By not calculating these terms, which are a function only of
Absolute Salinity, several unnecessary computations are avoided
(including saving the computation of a natural logarithm). These terms
are a necessary part of entropy, but are not needed when calculating
potential temperature from in-situ temperature.
The inputs to "gsw_entropy_part_zerop(SA,pt0)" are Absolute Salinity
and potential temperature with reference sea pressure of zero dbar.
VERSION NUMBER: 3.06.12 (25th May, 2020)
"""
return _gsw_ufuncs.entropy_part_zerop(SA, pt0)
entropy_part_zerop.types = _gsw_ufuncs.entropy_part_zerop.types
entropy_part_zerop = match_args_return(entropy_part_zerop)
[docs]
def entropy_second_derivatives(SA, CT):
"""
Calculates the following three second-order partial derivatives of
specific entropy (eta)
(1) eta_SA_SA, the second derivative with respect to Absolute
Salinity at constant Conservative Temperature, and
(2) eta_SA_CT, the derivative with respect to Absolute Salinity and
Conservative Temperature.
(3) eta_CT_CT, the second derivative with respect to Conservative
Temperature at constant Absolute Salinity.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
eta_SA_SA : array-like, J/(kg K(g/kg)^2)
The second derivative of specific entropy with respect
to Absolute Salinity (in units of g kg^-1) at constant
Conservative Temperature.
eta_SA_CT : array-like, J/(kg (g/kg) K^2)
The second derivative of specific entropy with respect
to Conservative Temperature at constant Absolute
eta_CT_CT : array-like, J/(kg K^3)
The second derivative of specific entropy with respect
to Conservative Temperature at constant Absolute
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqns. (P.14b) and (P.15a,b) of this TEOS-10 Manual.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.entropy_second_derivatives(SA, CT)
entropy_second_derivatives.types = _gsw_ufuncs.entropy_second_derivatives.types
entropy_second_derivatives = match_args_return(entropy_second_derivatives)
[docs]
def Fdelta(p, lon, lat):
"""
Calculates Fdelta from the Absolute Salinity Anomaly Ratio (SAAR). It
finds SAAR by calling the function "gsw_SAAR(p,long,lat)" and then
simply calculates Fdelta from
Parameters
----------
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
Fdelta : array-like, unitless
ratio of SA to Sstar, minus 1
Notes
-----
Fdelta = (1 + r1)SAAR/(1 - r1*SAAR)
= (SA/Sstar) - 1
with r1 being the constant 0.35 based on the work of Pawlowicz et al.
(2011). Note that since SAAR is everywhere less than 0.001 in the global
ocean, Fdelta is only slightly different to 1.35*SAAR.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 2.5 and appendices A.4 and A.5 of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
Pawlawicz, R., D.G. Wright and F.J. Millero, 2011; The effects of
biogeochemical processes on oceanic conductivity/salinty/density
relationships and the characterization of real seawater. Ocean Science,
7, 363-387. https://os.copernicus.org/articles/7/363/2011/os-7-363-2011.pdf
"""
return _gsw_ufuncs.fdelta(p, lon, lat)
Fdelta.types = _gsw_ufuncs.fdelta.types
Fdelta = match_args_return(Fdelta)
[docs]
def frazil_properties(SA_bulk, h_bulk, p):
"""
Calculates the mass fraction of ice (mass of ice divided by mass of ice
plus seawater), w_Ih_final, which results from given values of the bulk
Absolute Salinity, SA_bulk, bulk enthalpy, h_bulk, occurring at pressure
p. The final values of Absolute Salinity, SA_final, and Conservative
Temperature, CT_final, of the interstitial seawater phase are also
returned. This code assumes that there is no dissolved air in the
seawater (that is, saturation_fraction is assumed to be zero
throughout the code).
Parameters
----------
SA_bulk : array-like
bulk Absolute Salinity of the seawater and ice mixture, g/kg
h_bulk : array-like
bulk enthalpy of the seawater and ice mixture, J/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
SA_final : array-like, g/kg
Absolute Salinity of the seawater in the final state,
whether or not any ice is present.
CT_final : array-like, deg C
Conservative Temperature of the seawater in the final
state, whether or not any ice is present.
w_Ih_final : array-like, unitless
mass fraction of ice in the final seawater-ice mixture.
If this ice mass fraction is positive, the system is at
thermodynamic equilibrium. If this ice mass fraction is
zero there is no ice in the final state which consists
only of seawater which is warmer than the freezing
temperature.
Notes
-----
When the mass fraction w_Ih_final is calculated as being a positive
value, the seawater-ice mixture is at thermodynamic equilibrium.
This code returns w_Ih_final = 0 when the input bulk enthalpy, h_bulk,
is sufficiently large (i.e. sufficiently "warm") so that there is no ice
present in the final state. In this case the final state consists of
only seawater rather than being an equilibrium mixture of seawater and
ice which occurs when w_Ih_final is positive. Note that when
w_Ih_final = 0, the final seawater is not at the freezing temperature.
Note that there is another GSW code,
gsw_frazil_properties_potential_poly(SA_bulk,h_pot_bulk,p) which
treats potential enthalpy as the conservative variable, while, in
contrast, the present code treats in situ enthalpy as the conservative
variable during the interaction of seawater and ice Ih.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of ice and sea ice into seawater, and frazil ice formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall, T.J., and S.J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
Anonymous, 2014: Modelling the interaction between seawater and frazil
ice. Manuscript, March 2015. See Eqns. (8) - (15) of this manuscript.
"""
return _gsw_ufuncs.frazil_properties(SA_bulk, h_bulk, p)
frazil_properties.types = _gsw_ufuncs.frazil_properties.types
frazil_properties = match_args_return(frazil_properties)
[docs]
def frazil_properties_potential(SA_bulk, h_pot_bulk, p):
"""
Calculates the mass fraction of ice (mass of ice divided by mass of ice
plus seawater), w_Ih_eq, which results from given values of the bulk
Absolute Salinity, SA_bulk, bulk potential enthalpy, h_pot_bulk,
occurring at pressure p. The final equilibrium values of Absolute
Salinity, SA_eq, and Conservative Temperature, CT_eq, of the
interstitial seawater phase are also returned. This code assumes that
there is no dissolved air in the seawater (that is, saturation_fraction
is assumed to be zero throughout the code).
Parameters
----------
SA_bulk : array-like
bulk Absolute Salinity of the seawater and ice mixture, g/kg
h_pot_bulk : array-like
bulk enthalpy of the seawater and ice mixture, J/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
SA_final : array-like, g/kg
Absolute Salinity of the seawater in the final state,
whether or not any ice is present.
CT_final : array-like, deg C
Conservative Temperature of the seawater in the final
state, whether or not any ice is present.
w_Ih_final : array-like, unitless
mass fraction of ice in the final seawater-ice mixture.
If this ice mass fraction is positive, the system is at
thermodynamic equilibrium. If this ice mass fraction is
zero there is no ice in the final state which consists
only of seawater which is warmer than the freezing
temperature.
Notes
-----
When the mass fraction w_Ih_final is calculated as being a positive
value, the seawater-ice mixture is at thermodynamic equilibrium.
This code returns w_Ih_final = 0 when the input bulk enthalpy, h_bulk,
is sufficiently large (i.e. sufficiently "warm") so that there is no ice
present in the final state. In this case the final state consists of
only seawater rather than being an equilibrium mixture of seawater and
ice which occurs when w_Ih_final is positive. Note that when
w_Ih_final = 0, the final seawater is not at the freezing temperature.
Note that this code uses the exact forms of CT_freezing and
pot_enthalpy_ice_freezing.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of ice and sea ice into seawater, and frazil ice formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall, T.J., and S.J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
Anonymous, 2014: Modelling the interaction between seawater and frazil
ice. Manuscript, March 2015. See Eqns. (8)-(15) of this manuscript.
"""
return _gsw_ufuncs.frazil_properties_potential(SA_bulk, h_pot_bulk, p)
frazil_properties_potential.types = _gsw_ufuncs.frazil_properties_potential.types
frazil_properties_potential = match_args_return(frazil_properties_potential)
[docs]
def frazil_properties_potential_poly(SA_bulk, h_pot_bulk, p):
"""
Calculates the mass fraction of ice (mass of ice divided by mass of ice
plus seawater), w_Ih_eq, which results from given values of the bulk
Absolute Salinity, SA_bulk, bulk potential enthalpy, h_pot_bulk,
occurring at pressure p. The final equilibrium values of Absolute
Salinity, SA_eq, and Conservative Temperature, CT_eq, of the
interstitial seawater phase are also returned. This code assumes that
there is no dissolved air in the seawater (that is, saturation_fraction
is assumed to be zero throughout the code).
Parameters
----------
SA_bulk : array-like
bulk Absolute Salinity of the seawater and ice mixture, g/kg
h_pot_bulk : array-like
bulk enthalpy of the seawater and ice mixture, J/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
SA_final : array-like, g/kg
Absolute Salinity of the seawater in the final state,
whether or not any ice is present.
CT_final : array-like, deg C
Conservative Temperature of the seawater in the final
state, whether or not any ice is present.
w_Ih_final : array-like, unitless
mass fraction of ice in the final seawater-ice mixture.
If this ice mass fraction is positive, the system is at
thermodynamic equilibrium. If this ice mass fraction is
zero there is no ice in the final state which consists
only of seawater which is warmer than the freezing
temperature.
Notes
-----
When the mass fraction w_Ih_final is calculated as being a positive
value, the seawater-ice mixture is at thermodynamic equilibrium.
This code returns w_Ih_final = 0 when the input bulk enthalpy, h_bulk,
is sufficiently large (i.e. sufficiently "warm") so that there is no ice
present in the final state. In this case the final state consists of
only seawater rather than being an equilibrium mixture of seawater and
ice which occurs when w_Ih_final is positive. Note that when
w_Ih_final = 0, the final seawater is not at the freezing temperature.
Note that this code uses the polynomial forms of CT_freezing and
pot_enthalpy_ice_freezing. This code is intended to be used in ocean
models where the model prognostic variables are SA_bulk and h_pot_bulk.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of ice and sea ice into seawater, and frazil ice formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall, T.J., and S.J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
Anonymous, 2014: Modelling the interaction between seawater and frazil
ice. Manuscript, March 2015. See Eqns. (8)-(15) of this manuscript.
"""
return _gsw_ufuncs.frazil_properties_potential_poly(SA_bulk, h_pot_bulk, p)
frazil_properties_potential_poly.types = _gsw_ufuncs.frazil_properties_potential_poly.types
frazil_properties_potential_poly = match_args_return(frazil_properties_potential_poly)
[docs]
def frazil_ratios_adiabatic(SA, p, w_Ih):
"""
Calculates the ratios of SA, CT and P changes when frazil ice forms or
melts in response to an adiabatic change in pressure of a mixture of
seawater and frazil ice crystals.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
w_Ih : array-like
mass fraction of ice: the mass of ice divided by the
sum of the masses of ice and seawater. 0 <= wIh <= 1. unitless.
Returns
-------
dSA_dCT_frazil : array-like, g/(kg K)
the ratio of the changes in Absolute Salinity
to that of Conservative Temperature
dSA_dP_frazil : array-like, g/(kg Pa)
the ratio of the changes in Absolute Salinity
to that of pressure (in Pa)
dCT_dP_frazil : array-like, K/Pa
the ratio of the changes in Conservative Temperature
to that of pressure (in Pa)
Notes
-----
Note that the first output, dSA_dCT_frazil, is dSA/dCT rather than
dCT/dSA. This is done so that when SA = 0, the output, dSA/dCT, is zero
whereas dCT/dSA would then be infinite.
Also note that both dSA_dP_frazil and dCT_dP_frazil are the pressure
derivatives with the pressure measured in Pa not dbar.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqns. (47), (48) and (49) of this manuscript.
"""
return _gsw_ufuncs.frazil_ratios_adiabatic(SA, p, w_Ih)
frazil_ratios_adiabatic.types = _gsw_ufuncs.frazil_ratios_adiabatic.types
frazil_ratios_adiabatic = match_args_return(frazil_ratios_adiabatic)
[docs]
def frazil_ratios_adiabatic_poly(SA, p, w_Ih):
"""
Calculates the ratios of SA, CT and P changes when frazil ice forms or
melts in response to an adiabatic change in pressure of a mixture of
seawater and frazil ice crystals.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
w_Ih : array-like
mass fraction of ice: the mass of ice divided by the
sum of the masses of ice and seawater. 0 <= wIh <= 1. unitless.
Returns
-------
dSA_dCT_frazil : array-like, g/(kg K)
the ratio of the changes in Absolute Salinity
to that of Conservative Temperature
dSA_dP_frazil : array-like, g/(kg Pa)
the ratio of the changes in Absolute Salinity
to that of pressure (in Pa)
dCT_dP_frazil : array-like, K/Pa
the ratio of the changes in Conservative Temperature
to that of pressure (in Pa)
Notes
-----
Note that the first output, dSA_dCT_frazil, is dSA/dCT rather than
dCT/dSA. This is done so that when SA = 0, the output, dSA/dCT, is zero
whereas dCT/dSA would then be infinite.
Also note that both dSA_dP_frazil and dCT_dP_frazil are the pressure
derivatives with the pressure measured in Pa not dbar.
This function uses the computationally-efficient expression for specific
volume in terms of SA, CT and p (Roquet et al., 2015) and the polynomial
expression for freezing temperature based on Conservative Temperature
(McDougall et al., 2015).
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqns. (47), (48) and (49) of this manuscript.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.frazil_ratios_adiabatic_poly(SA, p, w_Ih)
frazil_ratios_adiabatic_poly.types = _gsw_ufuncs.frazil_ratios_adiabatic_poly.types
frazil_ratios_adiabatic_poly = match_args_return(frazil_ratios_adiabatic_poly)
def gibbs(ns, nt, np, SA, t, p):
"""
Calculates specific Gibbs energy and its derivatives up to order 3 for
seawater. The Gibbs function for seawater is that of TEOS-10
(IOC et al., 2010), being the sum of IAPWS-08 for the saline part and
IAPWS-09 for the pure water part. These IAPWS releases are the
officially blessed IAPWS descriptions of Feistel (2008) and the pure
water part of Feistel (2003). Absolute Salinity, SA, in all of the GSW
routines is expressed on the Reference-Composition Salinity Scale of
2008 (RCSS-08) of Millero et al. (2008).
Parameters
----------
ns : array-like
order of SA derivative, integer in (0, 1, 2)
nt : array-like
order of t derivative, integer in (0, 1, 2)
np : array-like
order of p derivative, integer in (0, 1, 2)
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
gibbs : array-like
Specific Gibbs energy or its derivatives.
The Gibbs energy (when ns = nt = np = 0) has units of J/kg.
The Absolute Salinity derivatives are output in units of (J/kg) (g/kg)^(-ns).
The temperature derivatives are output in units of (J/kg) (K)^(-nt).
The pressure derivatives are output in units of (J/kg) (Pa)^(-np).
The mixed derivatives are output in units of (J/kg) (g/kg)^(-ns) (K)^(-nt) (Pa)^(-np).
Note: The derivatives are taken with respect to pressure in Pa, not
withstanding that the pressure input into this routine is in dbar.
References
----------
Feistel, R., 2003: A new extended Gibbs thermodynamic potential of
seawater, Progr. Oceanogr., 58, 43-114.
Feistel, R., 2008: A Gibbs function for seawater thermodynamics
for -6 to 80°C and salinity up to 120 g kg–1, Deep-Sea Res. I,
55, 1639-1671.
IAPWS, 2008: Release on the IAPWS Formulation 2008 for the
Thermodynamic Properties of Seawater. The International Association
for the Properties of Water and Steam. Berlin, Germany, September
2008, available from https://iapws.org/. This Release is referred
to as IAPWS-08.
IAPWS, 2009: Supplementary Release on a Computationally Efficient
Thermodynamic Formulation for Liquid Water for Oceanographic Use.
The International Association for the Properties of Water and Steam.
Doorwerth, The Netherlands, September 2009, available from
https://iapws.org/. This Release is referred to as IAPWS-09.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 2.6 and appendices A.6, G and H of this TEOS-10 Manual.
Millero, F.J., R. Feistel, D.G. Wright, and T.J. McDougall, 2008:
The composition of Standard Seawater and the definition of the
Reference-Composition Salinity Scale, Deep-Sea Res. I, 55, 50-72.
Reference page in Help browser
<a href="matlab:doc gsw_gibbs">doc gsw_gibbs</a>
Note that this reference page includes the code contained in gsw_gibbs.
We have opted to encode this programme as it is a global standard and
such we cannot allow anyone to change it.
"""
return _gsw_ufuncs.gibbs(ns, nt, np, SA, t, p)
gibbs.types = _gsw_ufuncs.gibbs.types
gibbs = match_args_return(gibbs)
def gibbs_ice(nt, np, t, p):
"""
Ice specific Gibbs energy and derivatives up to order 2.
Parameters
----------
nt : array-like
order of t derivative, integer in (0, 1, 2)
np : array-like
order of p derivative, integer in (0, 1, 2)
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
gibbs_ice : array-like
Specific Gibbs energy of ice or its derivatives.
The Gibbs energy (when nt = np = 0) has units of J/kg.
The temperature derivatives are output in units of (J/kg) (K)^(-nt).
The pressure derivatives are output in units of (J/kg) (Pa)^(-np).
The mixed derivatives are output in units of (J/kg) (K)^(-nt) (Pa)^(-np).
Note. The derivatives are taken with respect to pressure in Pa, not
withstanding that the pressure input into this routine is in dbar.
References
----------
IAPWS, 2009: Revised release on the Equation of State 2006 for H2O Ice
Ih. The International Association for the Properties of Water and
Steam. Doorwerth, The Netherlands, September 2009.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See appendix I.
Reference page in Help browser
<a href="matlab:doc gsw_gibbs_ice">doc gsw_gibbs_ice</a>
Note that this reference page includes the code contained in
gsw_gibbs_ice. We have opted to encode this programme as it is a global
standard and such we cannot allow anyone to change it.
"""
return _gsw_ufuncs.gibbs_ice(nt, np, t, p)
gibbs_ice.types = _gsw_ufuncs.gibbs_ice.types
gibbs_ice = match_args_return(gibbs_ice)
[docs]
def gibbs_ice_part_t(t, p):
"""
part of the first temperature derivative of Gibbs energy of ice
that is the output is gibbs_ice(1,0,t,p) + S0
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
gibbs_ice_part_t : array-like, J kg^-1 K^-1
part of temperature derivative
References
----------
IAPWS, 2009: Revised Release on the Equation of State 2006 for H2O Ice
Ih. The International Association for the Properties of Water and
Steam. Doorwerth, The Netherlands, September 2009.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See appendix I.
"""
return _gsw_ufuncs.gibbs_ice_part_t(t, p)
gibbs_ice_part_t.types = _gsw_ufuncs.gibbs_ice_part_t.types
gibbs_ice_part_t = match_args_return(gibbs_ice_part_t)
[docs]
def gibbs_ice_pt0(pt0):
"""
part of the first temperature derivative of Gibbs energy of ice
that is the output is "gibbs_ice(1,0,pt0,0) + s0"
Parameters
----------
pt0 : array-like
Potential temperature with reference pressure of 0 dbar, degrees C
Returns
-------
gibbs_ice_part_pt0 : array-like, J kg^-1 K^-1
part of temperature derivative
References
----------
IAPWS, 2009: Revised Release on the Equation of State 2006 for H2O Ice
Ih. The International Association for the Properties of Water and
Steam. Doorwerth, The Netherlands, September 2009.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See appendix I.
"""
return _gsw_ufuncs.gibbs_ice_pt0(pt0)
gibbs_ice_pt0.types = _gsw_ufuncs.gibbs_ice_pt0.types
gibbs_ice_pt0 = match_args_return(gibbs_ice_pt0)
[docs]
def gibbs_ice_pt0_pt0(pt0):
"""
The second temperature derivative of Gibbs energy of ice at the
potential temperature with reference sea pressure of zero dbar. That is
the output is gibbs_ice(2,0,pt0,0).
Parameters
----------
pt0 : array-like
Potential temperature with reference pressure of 0 dbar, degrees C
Returns
-------
gibbs_ice_pt0_pt0 : array-like, J kg^-1 K^-2
temperature second derivative at pt0
References
----------
IAPWS, 2009: Revised Release on the Equation of State 2006 for H2O Ice
Ih. The International Association for the Properties of Water and
Steam. Doorwerth, The Netherlands, September 2009.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See appendix I.
"""
return _gsw_ufuncs.gibbs_ice_pt0_pt0(pt0)
gibbs_ice_pt0_pt0.types = _gsw_ufuncs.gibbs_ice_pt0_pt0.types
gibbs_ice_pt0_pt0 = match_args_return(gibbs_ice_pt0_pt0)
[docs]
def gibbs_pt0_pt0(SA, pt0):
"""
gibbs_tt at (SA,pt,0)
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
pt0 : array-like
Potential temperature with reference pressure of 0 dbar, degrees C
Returns
-------
double, array
Notes
-----
gsw_gibbs_pt0_pt0 gibbs_tt at (SA,pt,0)
This function calculates the second derivative of the specific Gibbs
function with respect to temperature at zero sea pressure. The inputs
are Absolute Salinity and potential temperature with reference sea
pressure of zero dbar.
VERSION NUMBER: 3.06.13 (7th September, 2020)
"""
return _gsw_ufuncs.gibbs_pt0_pt0(SA, pt0)
gibbs_pt0_pt0.types = _gsw_ufuncs.gibbs_pt0_pt0.types
gibbs_pt0_pt0 = match_args_return(gibbs_pt0_pt0)
[docs]
def grav(lat, p):
"""
Calculates acceleration due to gravity as a function of latitude and as
a function of pressure in the ocean.
Parameters
----------
lat : array-like
Latitude, -90 to 90 degrees
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
grav : array-like, m s^-2
gravitational acceleration
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix D of this TEOS-10 Manual.
Moritz, H., 2000: Geodetic reference system 1980. J. Geodesy, 74,
pp. 128-133.
Saunders, P.M., and N.P. Fofonoff, 1976: Conversion of pressure to
depth in the ocean. Deep-Sea Res., pp. 109-111.
"""
return _gsw_ufuncs.grav(lat, p)
grav.types = _gsw_ufuncs.grav.types
grav = match_args_return(grav)
[docs]
def Helmholtz_energy_ice(t, p):
"""
Calculates the Helmholtz energy of ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
Helmholtz_energy_ice : array-like, J/kg
Helmholtz energy of ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.helmholtz_energy_ice(t, p)
Helmholtz_energy_ice.types = _gsw_ufuncs.helmholtz_energy_ice.types
Helmholtz_energy_ice = match_args_return(Helmholtz_energy_ice)
[docs]
def Hill_ratio_at_SP2(t):
"""
Calculates the Hill ratio, which is the adjustment needed to apply for
Practical Salinities smaller than 2. This ratio is defined at a
Practical Salinity = 2 and in-situ temperature, t using PSS-78. The Hill
ratio is the ratio of 2 to the output of the Hill et al. (1986) formula
for Practical Salinity at the conductivity ratio, Rt, at which Practical
Salinity on the PSS-78 scale is exactly 2.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
Returns
-------
Hill_ratio : array-like, unitless
Hill ratio at SP of 2
References
----------
Hill, K.D., T.M. Dauphinee & D.J. Woods, 1986: The extension of the
Practical Salinity Scale 1978 to low salinities. IEEE J. Oceanic Eng.,
11, 109 - 112.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix E of this TEOS-10 Manual.
McDougall T.J. and S.J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
Unesco, 1983: Algorithms for computation of fundamental properties of
seawater. Unesco Technical Papers in Marine Science, 44, 53 pp.
"""
return _gsw_ufuncs.hill_ratio_at_sp2(t)
Hill_ratio_at_SP2.types = _gsw_ufuncs.hill_ratio_at_sp2.types
Hill_ratio_at_SP2 = match_args_return(Hill_ratio_at_SP2)
[docs]
def ice_fraction_to_freeze_seawater(SA, CT, p, t_Ih):
"""
Calculates the mass fraction of ice (mass of ice divided by mass of ice
plus seawater), which, when melted into seawater having (SA,CT,p) causes
the final dilute seawater to be at the freezing temperature. The other
outputs are the Absolute Salinity and Conservative Temperature of the
final diluted seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
t_Ih : array-like
In-situ temperature of ice (ITS-90), degrees C
Returns
-------
SA_freeze : array-like, g/kg
Absolute Salinity of seawater after the mass fraction of
ice, ice_fraction, at temperature t_Ih has melted into the
original seawater, and the final mixture is at the freezing
temperature of seawater.
CT_freeze : array-like, deg C
Conservative Temperature of seawater after the mass
fraction, w_Ih, of ice at temperature t_Ih has melted into
the original seawater, and the final mixture is at the
freezing temperature of seawater.
w_Ih : array-like, unitless
mass fraction of ice, having in-situ temperature t_Ih,
which, when melted into seawater at (SA,CT,p) leads to the
final diluted seawater being at the freezing temperature.
This output must be between 0 and 1.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., and S.J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (9) of this manuscript.
"""
return _gsw_ufuncs.ice_fraction_to_freeze_seawater(SA, CT, p, t_Ih)
ice_fraction_to_freeze_seawater.types = _gsw_ufuncs.ice_fraction_to_freeze_seawater.types
ice_fraction_to_freeze_seawater = match_args_return(ice_fraction_to_freeze_seawater)
[docs]
def infunnel(SA, CT, p):
"""
"oceanographic funnel" check for the 75-term equation
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
in_funnel : array-like,
0, if SA, CT and p are outside the "funnel"
= 1, if SA, CT and p are inside the "funnel"
Notes
-----
gsw_infunnel "oceanographic funnel" check for the 75-term equation
USAGE:
in_funnel = gsw_infunnel(SA,CT,p)
INPUT:
SA = Absolute Salinity [ g kg^-1 ]
CT = Conservative Temperature (ITS-90) [ deg C ]
p = sea pressure [ dbar ]
( i.e. absolute pressure - 10.1325 dbar )
SA & CT need to have the same dimensions.
p may have dimensions 1x1 or Mx1 or 1xN or MxN, where SA & CT are MxN.
OUTPUT:
in_funnel = 0, if SA, CT and p are outside the "funnel"
= 1, if SA, CT and p are inside the "funnel"
Note. The term "funnel" (McDougall et al., 2003) describes the range of
SA, CT and p over which the error in the fit of the computationally
efficient 75-term expression for specific volume in terms of SA, CT
and p was calculated (Roquet et al., 2015).
AUTHOR:
Trevor McDougall and Paul Barker [ help@teos-10.org ]
VERSION NUMBER: 3.06.13 (23rd May, 2021)
"""
return _gsw_ufuncs.infunnel(SA, CT, p)
infunnel.types = _gsw_ufuncs.infunnel.types
infunnel = match_args_return(infunnel)
[docs]
def internal_energy(SA, CT, p):
"""
Calculates specific internal energy of seawater using the
computationally-efficient expression for specific volume in terms of SA,
CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
internal_energy : array-like, J/kg
specific internal energy
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.internal_energy(SA, CT, p)
internal_energy.types = _gsw_ufuncs.internal_energy.types
internal_energy = match_args_return(internal_energy)
[docs]
def internal_energy_ice(t, p):
"""
Calculates the specific internal energy of ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
internal_energy_ice : array-like, J/kg
specific internal energy (u)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.internal_energy_ice(t, p)
internal_energy_ice.types = _gsw_ufuncs.internal_energy_ice.types
internal_energy_ice = match_args_return(internal_energy_ice)
[docs]
def kappa(SA, CT, p):
"""
Calculates the isentropic compressibility of seawater. This function
has inputs of Absolute Salinity and Conservative Temperature. This
function uses the computationally-efficient expression for
specific volume in terms of SA, CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
kappa : array-like, 1/Pa
isentropic compressibility of seawater
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (2.17.1) of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.kappa(SA, CT, p)
kappa.types = _gsw_ufuncs.kappa.types
kappa = match_args_return(kappa)
[docs]
def kappa_const_t_ice(t, p):
"""
Calculates isothermal compressibility of ice.
Note. This is the compressibility of ice AT CONSTANT IN-SITU
TEMPERATURE
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
kappa_const_t_ice : array-like, 1/Pa
isothermal compressibility
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.kappa_const_t_ice(t, p)
kappa_const_t_ice.types = _gsw_ufuncs.kappa_const_t_ice.types
kappa_const_t_ice = match_args_return(kappa_const_t_ice)
[docs]
def kappa_ice(t, p):
"""
Calculates the isentropic compressibility of ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
kappa_ice : array-like, 1/Pa
isentropic compressibility
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.kappa_ice(t, p)
kappa_ice.types = _gsw_ufuncs.kappa_ice.types
kappa_ice = match_args_return(kappa_ice)
[docs]
def kappa_t_exact(SA, t, p):
"""
Calculates the isentropic compressibility of seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
kappa_t_exact : array-like, 1/Pa
isentropic compressibility
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqns. (2.16.1) and the row for kappa in Table P.1 of appendix P
of this TEOS-10 Manual.
"""
return _gsw_ufuncs.kappa_t_exact(SA, t, p)
kappa_t_exact.types = _gsw_ufuncs.kappa_t_exact.types
kappa_t_exact = match_args_return(kappa_t_exact)
[docs]
def latentheat_evap_CT(SA, CT):
"""
Calculates latent heat, or enthalpy, of evaporation at p = 0 (the
surface). It is defined as a function of Absolute Salinity, SA, and
Conservative Temperature, CT, and is valid in the ranges
0 < SA < 42 g/kg and 0 < CT < 40 deg C. The errors range between
-0.4 and 0.6 J/kg.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
latentheat_evap : array-like, J/kg
latent heat of evaporation
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.39 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.latentheat_evap_ct(SA, CT)
latentheat_evap_CT.types = _gsw_ufuncs.latentheat_evap_ct.types
latentheat_evap_CT = match_args_return(latentheat_evap_CT)
[docs]
def latentheat_evap_t(SA, t):
"""
Calculates latent heat, or enthalpy, of evaporation at p = 0 (the
surface). It is defined as a function of Absolute Salinity, SA, and
in-situ temperature, t, and is valid in the ranges 0 < SA < 40 g/kg
and 0 < CT < 42 deg C. The errors range between -0.4 and 0.6 J/kg.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
Returns
-------
latentheat_evap : array-like, J/kg
latent heat of evaporation
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.39 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.latentheat_evap_t(SA, t)
latentheat_evap_t.types = _gsw_ufuncs.latentheat_evap_t.types
latentheat_evap_t = match_args_return(latentheat_evap_t)
[docs]
def latentheat_melting(SA, p):
"""
Calculates latent heat, or enthalpy, of melting. It is defined in terms
of Absolute Salinity, SA, and sea pressure, p, and is valid in the
ranges 0 < SA < 42 g kg^-1 and 0 < p < 10,000 dbar. This is based on
the IAPWS Releases IAPWS-09 (for pure water), IAPWS-08 (for the saline
compoonent of seawater and IAPWS-06 for ice Ih.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
latentheat_melting : array-like, J/kg
latent heat of melting
References
----------
IAPWS, 2008: Release on the IAPWS Formulation 2008 for the Thermodynamic
Properties of Seawater. The International Association for the Properties
of Water and Steam. Berlin, Germany, September 2008. This Release is
known as IAPWS-09.
IAPWS, 2009a: Revised Release on the Equation of State 2006 for H2O Ice
Ih. The International Association for the Properties of Water and Steam.
Doorwerth, The Netherlands, September 2009. This Release is known as
IAPWS-06
IAPWS, 2009b: Supplementary Release on a Computationally Efficient
Thermodynamic Formulation for Liquid Water for Oceanographic Use. The
International Association for the Properties of Water and Steam.
Doorwerth, The Netherlands, September 2009. This Release is known as
IAPWS-09.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.34 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.latentheat_melting(SA, p)
latentheat_melting.types = _gsw_ufuncs.latentheat_melting.types
latentheat_melting = match_args_return(latentheat_melting)
[docs]
def melting_ice_equilibrium_SA_CT_ratio(SA, p):
"""
Calculates the ratio of SA to CT changes when ice melts into seawater
with both the seawater and the seaice temperatures being almost equal to
the equilibrium freezing temperature. It is assumed that a small mass
of ice melts into an infinite mass of seawater. If indeed the
temperature of the seawater and the ice were both equal to the freezing
temperature, then no melting or freezing would occur; an imbalance
between these three temperatures is needed for freezing or melting to
occur (the three temperatures being (1) the seawater temperature,
(2) the ice temperature, and (3) the freezing temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
melting_ice_equilibrium_SA_CT_ratio : array-like, g/(kg K)
the ratio dSA/dCT of SA to CT
changes when ice melts into seawater, with
the seawater and seaice being close to the
freezing temperature.
Notes
-----
The output, melting_ice_equilibrium_SA_CT_ratio, is dSA/dCT rather than
dCT/dSA. This is done so that when SA = 0, the output, dSA/dCT is zero
whereas dCT/dSA would be infinite.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (16) of this manuscript.
"""
return _gsw_ufuncs.melting_ice_equilibrium_sa_ct_ratio(SA, p)
melting_ice_equilibrium_SA_CT_ratio.types = _gsw_ufuncs.melting_ice_equilibrium_sa_ct_ratio.types
melting_ice_equilibrium_SA_CT_ratio = match_args_return(melting_ice_equilibrium_SA_CT_ratio)
[docs]
def melting_ice_equilibrium_SA_CT_ratio_poly(SA, p):
"""
Calculates the ratio of SA to CT changes when ice melts into seawater
with both the seawater and the seaice temperatures being almost equal to
the equilibrium freezing temperature. It is assumed that a small mass
of ice melts into an infinite mass of seawater. If indeed the
temperature of the seawater and the ice were both equal to the freezing
temperature, then no melting or freezing would occur; an imbalance
between these three temperatures is needed for freezing or melting to
occur (the three temperatures being (1) the seawater temperature,
(2) the ice temperature, and (3) the freezing temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
melting_ice_equilibrium_SA_CT_ratio : array-like, g/(kg K)
the ratio dSA/dCT of SA to CT
changes when ice melts into seawater, with
the seawater and seaice being close to the
freezing temperature.
Notes
-----
The output, melting_ice_equilibrium_SA_CT_ratio, is dSA/dCT rather than
dCT/dSA. This is done so that when SA = 0, the output, dSA/dCT is zero
whereas dCT/dSA would be infinite.
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (16) of this manuscript.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.melting_ice_equilibrium_sa_ct_ratio_poly(SA, p)
melting_ice_equilibrium_SA_CT_ratio_poly.types = _gsw_ufuncs.melting_ice_equilibrium_sa_ct_ratio_poly.types
melting_ice_equilibrium_SA_CT_ratio_poly = match_args_return(melting_ice_equilibrium_SA_CT_ratio_poly)
[docs]
def melting_ice_into_seawater(SA, CT, p, w_Ih, t_Ih):
"""
Calculates the final Absolute Salinity, final Conservative Temperature
and final ice mass fraction that results when a given mass fraction of
ice melts and is mixed into seawater whose properties are (SA,CT,p).
This code takes the seawater to contain no dissolved air.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
w_Ih : array-like
mass fraction of ice: the mass of ice divided by the
sum of the masses of ice and seawater. 0 <= wIh <= 1. unitless.
t_Ih : array-like
In-situ temperature of ice (ITS-90), degrees C
Returns
-------
SA_final : array-like, g/kg
Absolute Salinity of the seawater in the final state,
whether or not any ice is present.
CT_final : array-like, deg C
Conservative Temperature of the seawater in the final
state, whether or not any ice is present.
w_Ih_final : array-like, unitless
mass fraction of ice in the final seawater-ice mixture.
If this ice mass fraction is positive, the system is at
thermodynamic equilibrium. If this ice mass fraction is
zero there is no ice in the final state which consists
only of seawater which is warmer than the freezing
temperature.
Notes
-----
When the mass fraction w_Ih_final is calculated as being a positive
value, the seawater-ice mixture is at thermodynamic equilibrium.
This code returns w_Ih_final = 0 when the input bulk enthalpy, h_bulk,
is sufficiently large (i.e. sufficiently "warm") so that there is no ice
present in the final state. In this case the final state consists of
only seawater rather than being an equilibrium mixture of seawater and
ice which occurs when w_Ih_final is positive. Note that when
w_Ih_final = 0, the final seawater is not at the freezing temperature.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of ice and sea ice into seawater, and frazil ice formation.
Journal of Physical Oceanography, 44, 1751-1775.
"""
return _gsw_ufuncs.melting_ice_into_seawater(SA, CT, p, w_Ih, t_Ih)
melting_ice_into_seawater.types = _gsw_ufuncs.melting_ice_into_seawater.types
melting_ice_into_seawater = match_args_return(melting_ice_into_seawater)
[docs]
def melting_ice_SA_CT_ratio(SA, CT, p, t_Ih):
"""
Calculates the ratio of SA to CT changes when ice melts into seawater.
It is assumed that a small mass of ice melts into an infinite mass of
seawater. Because of the infinite mass of seawater, the ice will always
melt.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
t_Ih : array-like
In-situ temperature of ice (ITS-90), degrees C
Returns
-------
melting_ice_SA_CT_ratio : array-like, g kg^-1 K^-1
the ratio of SA to CT changes when ice melts
into a large mass of seawater
Notes
-----
The output, melting_seaice_SA_CT_ratio, is dSA/dCT rather than dCT/dSA.
This is done so that when SA = 0, the output, dSA/dCT is zero whereas
dCT/dSA would be infinite.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (13) of this manuscript.
"""
return _gsw_ufuncs.melting_ice_sa_ct_ratio(SA, CT, p, t_Ih)
melting_ice_SA_CT_ratio.types = _gsw_ufuncs.melting_ice_sa_ct_ratio.types
melting_ice_SA_CT_ratio = match_args_return(melting_ice_SA_CT_ratio)
[docs]
def melting_ice_SA_CT_ratio_poly(SA, CT, p, t_Ih):
"""
Calculates the ratio of SA to CT changes when ice melts into seawater.
It is assumed that a small mass of ice melts into an infinite mass of
seawater. Because of the infinite mass of seawater, the ice will always
melt.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
t_Ih : array-like
In-situ temperature of ice (ITS-90), degrees C
Returns
-------
melting_ice_SA_CT_ratio : array-like, g kg^-1 K^-1
the ratio of SA to CT changes when ice melts
into a large mass of seawater
Notes
-----
The output, melting_seaice_SA_CT_ratio, is dSA/dCT rather than dCT/dSA.
This is done so that when SA = 0, the output, dSA/dCT is zero whereas
dCT/dSA would be infinite.
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (13) of this manuscript.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.melting_ice_sa_ct_ratio_poly(SA, CT, p, t_Ih)
melting_ice_SA_CT_ratio_poly.types = _gsw_ufuncs.melting_ice_sa_ct_ratio_poly.types
melting_ice_SA_CT_ratio_poly = match_args_return(melting_ice_SA_CT_ratio_poly)
[docs]
def melting_seaice_equilibrium_SA_CT_ratio(SA, p):
"""
Calculates the ratio of SA to CT changes when sea ice melts into
seawater with both the seawater and the sea ice temperatures being
almost equal to the equilibrium freezing temperature. It is assumed
that a small mass of seaice melts into an infinite mass of seawater. If
indeed the temperature of the seawater and the sea ice were both equal
to the freezing temperature, then no melting or freezing would occur; an
imbalance between these three temperatures is needed for freezing or
melting to occur (the three temperatures being (1) the seawater
temperature, (2) the sea ice temperature, and (3) the freezing
temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
melting_seaice_equilibrium_SA_CT_ratio : array-like, g/(kg K)
the ratio dSA/dCT of SA to CT
changes when sea ice melts into seawater, with
the seawater and sea ice being close to the
freezing temperature.
Notes
-----
Note that the output of this function, dSA/dCT is independent of the
sea ice salinity, SA_seaice. That is, the output applies equally to
pure ice Ih and to sea ice with seaice salinity, SA_seaice. This result
is proven in McDougall et al. (2014).
The output, melting_seaice_equilibrium_SA_CT_ratio, is dSA/dCT rather
than dCT/dSA. This is done so that when SA = 0, the output, dSA/dCT is
zero whereas dCT/dSA would be infinite.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (29) of this manuscript.
"""
return _gsw_ufuncs.melting_seaice_equilibrium_sa_ct_ratio(SA, p)
melting_seaice_equilibrium_SA_CT_ratio.types = _gsw_ufuncs.melting_seaice_equilibrium_sa_ct_ratio.types
melting_seaice_equilibrium_SA_CT_ratio = match_args_return(melting_seaice_equilibrium_SA_CT_ratio)
[docs]
def melting_seaice_equilibrium_SA_CT_ratio_poly(SA, p):
"""
Calculates the ratio of SA to CT changes when sea ice melts into
seawater with both the seawater and the sea ice temperatures being
almost equal to the equilibrium freezing temperature. It is assumed
that a small mass of seaice melts into an infinite mass of seawater. If
indeed the temperature of the seawater and the sea ice were both equal
to the freezing temperature, then no melting or freezing would occur; an
imbalance between these three temperatures is needed for freezing or
melting to occur (the three temperatures being (1) the seawater
temperature, (2) the sea ice temperature, and (3) the freezing
temperature.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
melting_seaice_equilibrium_SA_CT_ratio : array-like, g/(kg K)
the ratio dSA/dCT of SA to CT
changes when sea ice melts into seawater, with
the seawater and sea ice being close to the
freezing temperature.
Notes
-----
Note that the output of this function, dSA/dCT is independent of the
sea ice salinity, SA_seaice. That is, the output applies equally to
pure ice Ih and to sea ice with seaice salinity, SA_seaice. This result
is proven in McDougall et al. (2014).
The output, melting_seaice_equilibrium_SA_CT_ratio, is dSA/dCT rather
than dCT/dSA. This is done so that when SA = 0, the output, dSA/dCT is
zero whereas dCT/dSA would be infinite.
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (29) of this manuscript.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.melting_seaice_equilibrium_sa_ct_ratio_poly(SA, p)
melting_seaice_equilibrium_SA_CT_ratio_poly.types = _gsw_ufuncs.melting_seaice_equilibrium_sa_ct_ratio_poly.types
melting_seaice_equilibrium_SA_CT_ratio_poly = match_args_return(melting_seaice_equilibrium_SA_CT_ratio_poly)
[docs]
def melting_seaice_into_seawater(SA, CT, p, w_seaice, SA_seaice, t_seaice):
"""
Calculates the Absolute Salinity and Conservative Temperature that
results when a given mass of sea ice (or ice) melts and is mixed into a
known mass of seawater (whose properties are (SA,CT,p)).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
w_seaice : array-like
mass fraction of ice: the mass of sea-ice divided by the sum
of the masses of sea-ice and seawater. 0 <= wIh <= 1. unitless.
SA_seaice : array-like
Absolute Salinity of sea ice: the mass fraction of salt
in sea ice, expressed in g of salt per kg of sea ice.
t_seaice : array-like
In-situ temperature of the sea ice at pressure p (ITS-90), degrees C
Returns
-------
SA_final : array-like, g/kg
Absolute Salinity of the mixture of the melted sea ice
(or ice) and the original seawater
CT_final : array-like, deg C
Conservative Temperature of the mixture of the melted
sea ice (or ice) and the original seawater
Notes
-----
If the ice contains no salt (e.g. if it is of glacial origin), then the
input 'SA_seaice' should be set to zero.
Ice formed at the sea surface (sea ice) typically contains between 2 g/kg
and 12 g/kg of salt (defined as the mass of salt divided by the mass of
ice Ih plus brine) and this programme returns NaN's if the input
SA_seaice is greater than 15 g/kg. If the SA_seaice input is not zero,
usually this would imply that the pressure p should be zero, as sea ice
only occurs near the sea surface. The code does not impose that p = 0
if SA_seaice is non-zero. Rather, this is left to the user.
The Absolute Salinity, SA_brine, of the brine trapped in little pockets
in the sea ice, is in thermodynamic equilibrium with the ice Ih that
surrounds these pockets. As the sea ice temperature, t_seaice, may be
less than the freezing temperature, SA_brine is usually greater than the
Absolute Salinity of the seawater at the time and place when and where
the sea ice was formed. So usually SA_brine will be larger than SA.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
Eqns. (8) and (9) are the simplifications when SA_seaice = 0.
"""
return _gsw_ufuncs.melting_seaice_into_seawater(SA, CT, p, w_seaice, SA_seaice, t_seaice)
melting_seaice_into_seawater.types = _gsw_ufuncs.melting_seaice_into_seawater.types
melting_seaice_into_seawater = match_args_return(melting_seaice_into_seawater)
[docs]
def melting_seaice_SA_CT_ratio(SA, CT, p, SA_seaice, t_seaice):
"""
Calculates the ratio of SA to CT changes when sea ice melts into
seawater. It is assumed that a small mass of sea ice melts into an
infinite mass of seawater. Because of the infinite mass of seawater,
the sea ice will always melt.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
SA_seaice : array-like
Absolute Salinity of sea ice: the mass fraction of salt
in sea ice, expressed in g of salt per kg of sea ice.
t_seaice : array-like
In-situ temperature of the sea ice at pressure p (ITS-90), degrees C
Returns
-------
melting_seaice_SA_CT_ratio : array-like, g/(kg K)
the ratio dSA/dCT of SA to CT changes when
sea ice melts into a large mass of seawater
Notes
-----
Ice formed at the sea surface (sea ice) typically contains between 2 g/kg
and 12 g/kg of salt (defined as the mass of salt divided by the mass of
ice Ih plus brine) and this programme returns NaN's if the input
SA_seaice is greater than 15 g/kg. If the SA_seaice input is not zero,
usually this would imply that the pressure p should be zero, as sea ice
only occurs near the sea surface. The code does not impose that p = 0
if SA_seaice is non-zero. Rather, this is left to the user.
The Absolute Salinity, SA_brine, of the brine trapped in little pockets
in the sea ice, is in thermodynamic equilibrium with the ice Ih that
surrounds these pockets. As the seaice temperature, t_seaice, may be
less than the freezing temperature, SA_brine is usually greater than the
Absolute Salinity of the seawater at the time and place when and where
the sea ice was formed. So usually SA_brine will be larger than SA.
The output, melting_seaice_SA_CT_ratio, is dSA/dCT rather than dCT/dSA.
This is done so that when (SA - seaice_SA) = 0, the output, dSA/dCT is
zero whereas dCT/dSA would be infinite.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (28) of this manuscript.
"""
return _gsw_ufuncs.melting_seaice_sa_ct_ratio(SA, CT, p, SA_seaice, t_seaice)
melting_seaice_SA_CT_ratio.types = _gsw_ufuncs.melting_seaice_sa_ct_ratio.types
melting_seaice_SA_CT_ratio = match_args_return(melting_seaice_SA_CT_ratio)
[docs]
def melting_seaice_SA_CT_ratio_poly(SA, CT, p, SA_seaice, t_seaice):
"""
Calculates the ratio of SA to CT changes when sea ice melts into
seawater. It is assumed that a small mass of sea ice melts into an
infinite mass of seawater. Because of the infinite mass of seawater,
the sea ice will always melt.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
SA_seaice : array-like
Absolute Salinity of sea ice: the mass fraction of salt
in sea ice, expressed in g of salt per kg of sea ice.
t_seaice : array-like
In-situ temperature of the sea ice at pressure p (ITS-90), degrees C
Returns
-------
melting_seaice_SA_CT_ratio : array-like, g/(kg K)
the ratio dSA/dCT of SA to CT changes when
sea ice melts into a large mass of seawater
Notes
-----
Ice formed at the sea surface (sea ice) typically contains between 2 g/kg
and 12 g/kg of salt (defined as the mass of salt divided by the mass of
ice Ih plus brine) and this programme returns NaN's if the input
SA_seaice is greater than 15 g/kg. If the SA_seaice input is not zero,
usually this would imply that the pressure p should be zero, as sea ice
only occurs near the sea surface. The code does not impose that p = 0
if SA_seaice is non-zero. Rather, this is left to the user.
The Absolute Salinity, SA_brine, of the brine trapped in little pockets
in the sea ice, is in thermodynamic equilibrium with the ice Ih that
surrounds these pockets. As the seaice temperature, t_seaice, may be
less than the freezing temperature, SA_brine is usually greater than the
Absolute Salinity of the seawater at the time and place when and where
the sea ice was formed. So usually SA_brine will be larger than SA.
The output, melting_seaice_SA_CT_ratio, is dSA/dCT rather than dCT/dSA.
This is done so that when (SA - seaice_SA) = 0, the output, dSA/dCT is
zero whereas dCT/dSA would be infinite.
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (31) of this manuscript.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.melting_seaice_sa_ct_ratio_poly(SA, CT, p, SA_seaice, t_seaice)
melting_seaice_SA_CT_ratio_poly.types = _gsw_ufuncs.melting_seaice_sa_ct_ratio_poly.types
melting_seaice_SA_CT_ratio_poly = match_args_return(melting_seaice_SA_CT_ratio_poly)
[docs]
def O2sol(SA, CT, p, lon, lat):
"""
Calculates the oxygen concentration expected at equilibrium with air at
an Absolute Pressure of 101325 Pa (sea pressure of 0 dbar) including
saturated water vapor. This function uses the solubility coefficients
derived from the data of Benson and Krause (1984), as fitted by Garcia
and Gordon (1992, 1993).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
O2sol : array-like, umol/kg
solubility of oxygen in micro-moles per kg
Notes
-----
Note that this algorithm has not been approved by IOC and is not work
from SCOR/IAPSO Working Group 127. It is included in the GSW
Oceanographic Toolbox as it seems to be oceanographic best practice.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
Benson, B.B., and D. Krause, 1984: The concentration and isotopic
fractionation of oxygen dissolved in freshwater and seawater in
equilibrium with the atmosphere. Limnology and Oceanography, 29,
620-632.
Garcia, H.E., and L.I. Gordon, 1992: Oxygen solubility in seawater:
Better fitting equations. Limnology and Oceanography, 37, 1307-1312.
Garcia, H.E., and L.I. Gordon, 1993: Erratum: Oxygen solubility in
seawater: better fitting equations. Limnology and Oceanography, 38,
656.
"""
return _gsw_ufuncs.o2sol(SA, CT, p, lon, lat)
O2sol.types = _gsw_ufuncs.o2sol.types
O2sol = match_args_return(O2sol)
[docs]
def O2sol_SP_pt(SP, pt):
"""
Calculates the oxygen concentration expected at equilibrium with air at
an Absolute Pressure of 101325 Pa (sea pressure of 0 dbar) including
saturated water vapor. This function uses the solubility coefficients
derived from the data of Benson and Krause (1984), as fitted by Garcia
and Gordon (1992, 1993).
Parameters
----------
SP : array-like
Practical Salinity (PSS-78), unitless
pt : array-like
Potential temperature referenced to a sea pressure, degrees C
Returns
-------
O2sol : array-like, umol/kg
solubility of oxygen in micro-moles per kg
Notes
-----
Note that this algorithm has not been approved by IOC and is not work
from SCOR/IAPSO Working Group 127. It is included in the GSW
Oceanographic Toolbox as it seems to be oceanographic best practice.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
Benson, B.B., and D. Krause, 1984: The concentration and isotopic
fractionation of oxygen dissolved in freshwater and seawater in
equilibrium with the atmosphere. Limnology and Oceanography, 29,
620-632.
Garcia, H.E., and L.I. Gordon, 1992: Oxygen solubility in seawater:
Better fitting equations. Limnology and Oceanography, 37, 1307-1312.
Garcia, H.E., and L.I. Gordon, 1993: Erratum: Oxygen solubility in
seawater: better fitting equations. Limnology and Oceanography, 38,
656.
"""
return _gsw_ufuncs.o2sol_sp_pt(SP, pt)
O2sol_SP_pt.types = _gsw_ufuncs.o2sol_sp_pt.types
O2sol_SP_pt = match_args_return(O2sol_SP_pt)
def p_from_z(z, lat, geo_strf_dyn_height, sea_surface_geopotential):
"""
Calculates sea pressure from height using computationally-efficient
75-term expression for density, in terms of SA, CT and p (Roquet et al.,
2015). Dynamic height anomaly, geo_strf_dyn_height, if provided,
must be computed with its p_ref = 0 (the surface). Also if provided,
sea_surface_geopotental is the geopotential at zero sea pressure. This
function solves Eqn.(3.32.3) of IOC et al. (2010) iteratively for p.
Parameters
----------
z : array-like
Depth, positive up, m
lat : array-like
Latitude, -90 to 90 degrees
geo_strf_dyn_height : array-like
dynamic height anomaly, m^2/s^2
Note that the reference pressure, p_ref, of geo_strf_dyn_height must
be zero (0) dbar.
sea_surface_geopotential : array-like
geopotential at zero sea pressure, m^2/s^2
Returns
-------
p : array-like, dbar
sea pressure
( i.e. absolute pressure - 10.1325 dbar )
Notes
-----
Note. Height (z) is NEGATIVE in the ocean. Depth is -z.
Depth is not used in the GSW computer software library.
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
McDougall, T.J., and S.J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, pp. 20-25.
Moritz, H., 2000: Geodetic reference system 1980. J. Geodesy, 74,
pp. 128-133.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling, 90, pp. 29-43.
Saunders, P.M., 1981: Practical conversion of pressure to depth.
Journal of Physical Oceanography, 11, pp. 573-574.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.p_from_z(z, lat, geo_strf_dyn_height, sea_surface_geopotential)
p_from_z.types = _gsw_ufuncs.p_from_z.types
p_from_z = match_args_return(p_from_z)
[docs]
def pot_enthalpy_from_pt_ice(pt0_ice):
"""
Calculates the potential enthalpy of ice from potential temperature of
ice (whose reference sea pressure is zero dbar).
Parameters
----------
pt0_ice : array-like
Potential temperature of ice (ITS-90), degrees C
Returns
-------
pot_enthalpy_ice : array-like, J/kg
potential enthalpy of ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.pot_enthalpy_from_pt_ice(pt0_ice)
pot_enthalpy_from_pt_ice.types = _gsw_ufuncs.pot_enthalpy_from_pt_ice.types
pot_enthalpy_from_pt_ice = match_args_return(pot_enthalpy_from_pt_ice)
[docs]
def pot_enthalpy_from_pt_ice_poly(pt0_ice):
"""
Calculates the potential enthalpy of ice from potential temperature of
ice (whose reference sea pressure is zero dbar). This is a
compuationally efficient polynomial fit to the potential enthalpy of
ice.
Parameters
----------
pt0_ice : array-like
Potential temperature of ice (ITS-90), degrees C
Returns
-------
pot_enthalpy_ice : array-like, J/kg
potential enthalpy of ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.pot_enthalpy_from_pt_ice_poly(pt0_ice)
pot_enthalpy_from_pt_ice_poly.types = _gsw_ufuncs.pot_enthalpy_from_pt_ice_poly.types
pot_enthalpy_from_pt_ice_poly = match_args_return(pot_enthalpy_from_pt_ice_poly)
[docs]
def pot_enthalpy_ice_freezing(SA, p):
"""
Calculates the potential enthalpy of ice at which seawater freezes.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
pot_enthalpy_ice_freezing : array-like, J/kg
potential enthalpy of ice at freezing
of seawater
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
"""
return _gsw_ufuncs.pot_enthalpy_ice_freezing(SA, p)
pot_enthalpy_ice_freezing.types = _gsw_ufuncs.pot_enthalpy_ice_freezing.types
pot_enthalpy_ice_freezing = match_args_return(pot_enthalpy_ice_freezing)
[docs]
def pot_enthalpy_ice_freezing_first_derivatives(SA, p):
"""
Calculates the first derivatives of the potential enthalpy of ice at
which seawater freezes, with respect to Absolute Salinity SA and
pressure P (in Pa).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
pot_enthalpy_ice_freezing_SA : array-like, K kg/g
the derivative of the potential enthalpy
of ice at freezing (ITS-90) with respect to Absolute
salinity at fixed pressure [ K/(g/kg) ] i.e.
pot_enthalpy_ice_freezing_P : array-like, K/Pa
the derivative of the potential enthalpy
of ice at freezing (ITS-90) with respect to pressure
(in Pa) at fixed Absolute Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
"""
return _gsw_ufuncs.pot_enthalpy_ice_freezing_first_derivatives(SA, p)
pot_enthalpy_ice_freezing_first_derivatives.types = _gsw_ufuncs.pot_enthalpy_ice_freezing_first_derivatives.types
pot_enthalpy_ice_freezing_first_derivatives = match_args_return(pot_enthalpy_ice_freezing_first_derivatives)
[docs]
def pot_enthalpy_ice_freezing_first_derivatives_poly(SA, p):
"""
Calculates the first derivatives of the potential enthalpy of ice Ih at
which ice melts into seawater with Absolute Salinity SA and at pressure
p. This code uses the computationally efficient polynomial fit of the
freezing potential enthalpy of ice Ih (McDougall et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
pot_enthalpy_ice_freezing_SA : array-like, J/g
the derivative of the potential enthalpy
of ice at freezing (ITS-90) with respect to Absolute
salinity at fixed pressure [ (J/kg)/(g/kg) ] i.e.
pot_enthalpy_ice_freezing_P : array-like, (J/kg)/Pa
the derivative of the potential enthalpy
of ice at freezing (ITS-90) with respect to pressure
(in Pa) at fixed Absolute Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall et al. 2015: A reference for this polynomial.
"""
return _gsw_ufuncs.pot_enthalpy_ice_freezing_first_derivatives_poly(SA, p)
pot_enthalpy_ice_freezing_first_derivatives_poly.types = _gsw_ufuncs.pot_enthalpy_ice_freezing_first_derivatives_poly.types
pot_enthalpy_ice_freezing_first_derivatives_poly = match_args_return(pot_enthalpy_ice_freezing_first_derivatives_poly)
[docs]
def pot_enthalpy_ice_freezing_poly(SA, p):
"""
Calculates the potential enthalpy of ice at which seawater freezes.
The error of this fit ranges between -2.5 and 1 J/kg with an rms of
1.07, between SA of 0 and 120 g/kg and p between 0 and 10,000 dbar (the
error in the fit is between -0.7 and 0.7 with an rms of
0.3, between SA of 0 and 120 g/kg and p between 0 and 5,000 dbar) when
compared with the potential enthalpy calculated from the exact in-situ
freezing temperature which is found by a Newton-Raphson iteration of the
equality of the chemical potentials of water in seawater and in ice.
Note that the potential enthalpy at freezing can be found
by this exact method using the function gsw_pot_enthalpy_ice_freezing.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
pot_enthalpy_ice_freezing : array-like, J/kg
potential enthalpy of ice at freezing
of seawater
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
"""
return _gsw_ufuncs.pot_enthalpy_ice_freezing_poly(SA, p)
pot_enthalpy_ice_freezing_poly.types = _gsw_ufuncs.pot_enthalpy_ice_freezing_poly.types
pot_enthalpy_ice_freezing_poly = match_args_return(pot_enthalpy_ice_freezing_poly)
[docs]
def pot_rho_t_exact(SA, t, p, p_ref):
"""
Calculates potential density of seawater. Note. This function outputs
potential density, not potential density anomaly; that is, 1000 kg/m^3
is not subtracted.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
p_ref : array-like
Reference pressure, dbar
Returns
-------
pot_rho_t_exact : array-like, kg/m^3
potential density (not potential density anomaly)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.4 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.pot_rho_t_exact(SA, t, p, p_ref)
pot_rho_t_exact.types = _gsw_ufuncs.pot_rho_t_exact.types
pot_rho_t_exact = match_args_return(pot_rho_t_exact)
[docs]
def pressure_coefficient_ice(t, p):
"""
Calculates pressure coefficient of ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
pressure_coefficient_ice : array-like, Pa/K
pressure coefficient of ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (2.15.1) of this TEOS-10 Manual.
"""
return _gsw_ufuncs.pressure_coefficient_ice(t, p)
pressure_coefficient_ice.types = _gsw_ufuncs.pressure_coefficient_ice.types
pressure_coefficient_ice = match_args_return(pressure_coefficient_ice)
[docs]
def pressure_freezing_CT(SA, CT, saturation_fraction):
"""
Calculates the pressure (in dbar) of seawater at the freezing
temperature. That is, the output is the pressure at which seawater,
with Absolute Salinity SA, Conservative Temperature CT, and with
saturation_fraction of dissolved air, freezes. If the input values are
such that there is no value of pressure in the range between 0 dbar and
10,000 dbar for which seawater is at the freezing temperature, the
output, pressure_freezing, is put equal to NaN.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
pressure_freezing : array-like, dbar
sea pressure at which the seawater freezes
( i.e. absolute pressure - 10.1325 dbar )
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See section 3.33 of this TEOS-10 Manual.
McDougall T. J. and S. J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.pressure_freezing_ct(SA, CT, saturation_fraction)
pressure_freezing_CT.types = _gsw_ufuncs.pressure_freezing_ct.types
pressure_freezing_CT = match_args_return(pressure_freezing_CT)
[docs]
def pt0_from_t(SA, t, p):
"""
Calculates potential temperature with reference pressure, p_ref = 0 dbar.
The present routine is computationally faster than the more general
function "gsw_pt_from_t(SA,t,p,p_ref)" which can be used for any
reference pressure value.
This subroutine calls "gsw_entropy_part(SA,t,p)",
"gsw_entropy_part_zerop(SA,pt0)" and "gsw_gibbs_pt0_pt0(SA,pt0)".
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
pt0 : array-like, deg C
potential temperature
with reference sea pressure (p_ref) = 0 dbar.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.1 of this TEOS-10 Manual.
McDougall T. J. and S. J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.pt0_from_t(SA, t, p)
pt0_from_t.types = _gsw_ufuncs.pt0_from_t.types
pt0_from_t = match_args_return(pt0_from_t)
[docs]
def pt0_from_t_ice(t, p):
"""
Calculates potential temperature of ice Ih with a reference pressure of
0 dbar, from in-situ temperature, t.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
pt0_ice : array-like, deg C
potential temperature of ice Ih with reference pressure of
zero dbar (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix I of this TEOS-10 Manual.
McDougall T. J. and S. J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.pt0_from_t_ice(t, p)
pt0_from_t_ice.types = _gsw_ufuncs.pt0_from_t_ice.types
pt0_from_t_ice = match_args_return(pt0_from_t_ice)
[docs]
def pt_first_derivatives(SA, CT):
"""
Calculates the following two partial derivatives of potential
temperature (the regular potential temperature whose reference sea
pressure is 0 dbar)
(1) pt_SA, the derivative with respect to Absolute Salinity at
constant Conservative Temperature, and
(2) pt_CT, the derivative with respect to Conservative Temperature at
constant Absolute Salinity.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
pt_SA : array-like, K/(g/kg)
The derivative of potential temperature with respect to
Absolute Salinity at constant Conservative Temperature.
pt_CT : array-like, unitless
The derivative of potential temperature with respect to
Conservative Temperature at constant Absolute Salinity.
pt_CT is dimensionless.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqns. (A.12.6), (A.12.3), (P.6) and (P.8) of this TEOS-10 Manual.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.pt_first_derivatives(SA, CT)
pt_first_derivatives.types = _gsw_ufuncs.pt_first_derivatives.types
pt_first_derivatives = match_args_return(pt_first_derivatives)
[docs]
def pt_from_CT(SA, CT):
"""
Calculates potential temperature (with a reference sea pressure of
zero dbar) from Conservative Temperature. This function uses 1.5
iterations through a modified Newton-Raphson (N-R) iterative solution
procedure, starting from a rational-function-based initial condition
for both pt and dCT_dpt.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
pt : array-like, deg C
potential temperature referenced to a sea pressure
of zero dbar (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See sections 3.1 and 3.3 of this TEOS-10 Manual.
McDougall, T.J., and S.J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.pt_from_ct(SA, CT)
pt_from_CT.types = _gsw_ufuncs.pt_from_ct.types
pt_from_CT = match_args_return(pt_from_CT)
[docs]
def pt_from_entropy(SA, entropy):
"""
Calculates potential temperature with reference pressure p_ref = 0 dbar
and with entropy as an input variable.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
entropy : array-like
Specific entropy, J/(kg*K)
Returns
-------
pt : array-like, deg C
potential temperature
with reference sea pressure (p_ref) = 0 dbar.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.10 of this TEOS-10 Manual.
McDougall T. J. and S. J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.pt_from_entropy(SA, entropy)
pt_from_entropy.types = _gsw_ufuncs.pt_from_entropy.types
pt_from_entropy = match_args_return(pt_from_entropy)
[docs]
def pt_from_pot_enthalpy_ice(pot_enthalpy_ice):
"""
Calculates the potential temperature of ice from the potential enthalpy
of ice. The reference sea pressure of both the potential temperature
and the potential enthalpy is zero dbar.
Parameters
----------
pot_enthalpy_ice : array-like
Potential enthalpy of ice, J/kg
Returns
-------
pt0_ice : array-like, deg C
potential temperature of ice (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall T. J. and S. J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.pt_from_pot_enthalpy_ice(pot_enthalpy_ice)
pt_from_pot_enthalpy_ice.types = _gsw_ufuncs.pt_from_pot_enthalpy_ice.types
pt_from_pot_enthalpy_ice = match_args_return(pt_from_pot_enthalpy_ice)
[docs]
def pt_from_pot_enthalpy_ice_poly(pot_enthalpy_ice):
"""
Calculates the potential temperature of ice (whose reference sea
pressure is zero dbar) from the potential enthalpy of ice. This is a
compuationally efficient polynomial fit to the potential enthalpy of
ice.
Parameters
----------
pot_enthalpy_ice : array-like
Potential enthalpy of ice, J/kg
Returns
-------
pt0_ice : array-like, deg C
potential temperature of ice (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.pt_from_pot_enthalpy_ice_poly(pot_enthalpy_ice)
pt_from_pot_enthalpy_ice_poly.types = _gsw_ufuncs.pt_from_pot_enthalpy_ice_poly.types
pt_from_pot_enthalpy_ice_poly = match_args_return(pt_from_pot_enthalpy_ice_poly)
[docs]
def pt_from_t(SA, t, p, p_ref):
"""
Calculates potential temperature with the general reference pressure,
p_ref, from in-situ temperature, t. This function calls
"gsw_entropy_part" which evaluates entropy except for the parts which
are a function of Absolute Salinity alone.
A faster gsw routine exists if p_ref is indeed zero dbar. This routine
is "gsw_pt0_from_t(SA,t,p)".
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
p_ref : array-like
Reference pressure, dbar
Returns
-------
pt : array-like, deg C
potential temperature with reference pressure, p_ref, on the
ITS-90 temperature scale
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 3.1 of this TEOS-10 Manual.
McDougall T. J. and S. J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.pt_from_t(SA, t, p, p_ref)
pt_from_t.types = _gsw_ufuncs.pt_from_t.types
pt_from_t = match_args_return(pt_from_t)
[docs]
def pt_from_t_ice(t, p, p_ref):
"""
Calculates potential temperature of ice Ih with the general reference
pressure, p_ref, from in-situ temperature, t.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
p_ref : array-like
Reference pressure, dbar
Returns
-------
pt_ice : array-like, deg C
potential temperature of ice Ih with reference pressure,
p_ref, on the ITS-90 temperature scale
Notes
-----
A faster gsw routine exists if p_ref is indeed zero dbar. This routine
is "gsw_pt0_from_t_ice(t,p)".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix I of this TEOS-10 Manual.
McDougall T. J. and S. J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.pt_from_t_ice(t, p, p_ref)
pt_from_t_ice.types = _gsw_ufuncs.pt_from_t_ice.types
pt_from_t_ice = match_args_return(pt_from_t_ice)
[docs]
def pt_second_derivatives(SA, CT):
"""
Calculates the following three second-order derivatives of potential
temperature (the regular potential temperature which has a reference
sea pressure of 0 dbar),
(1) pt_SA_SA, the second derivative with respect to Absolute Salinity
at constant Conservative Temperature,
(2) pt_SA_CT, the derivative with respect to Conservative Temperature
and Absolute Salinity, and
(3) pt_CT_CT, the second derivative with respect to Conservative
Temperature at constant Absolute Salinity.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
pt_SA_SA : array-like, K/((g/kg)^2)
The second derivative of potential temperature (the
regular potential temperature which has reference sea
pressure of 0 dbar) with respect to Absolute Salinity
at constant Conservative Temperature.
pt_SA_CT : array-like, 1/(g/kg)
The derivative of potential temperature with respect
to Absolute Salinity and Conservative Temperature.
pt_CT_CT : array-like, 1/K
The second derivative of potential temperature (the
regular one with p_ref = 0 dbar) with respect to
Conservative Temperature at constant SA.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See Eqns. (A.12.9) and (A.12.10) of this TEOS-10 Manual.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.pt_second_derivatives(SA, CT)
pt_second_derivatives.types = _gsw_ufuncs.pt_second_derivatives.types
pt_second_derivatives = match_args_return(pt_second_derivatives)
[docs]
def rho(SA, CT, p):
"""
Calculates in-situ density from Absolute Salinity and Conservative
Temperature, using the computationally-efficient expression for
specific volume in terms of SA, CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
rho : array-like, kg/m^3
in-situ density
Notes
-----
Note that potential density with respect to reference pressure, pr, is
obtained by calling this function with the pressure argument being pr
(i.e. "gsw_rho(SA,CT,pr)").
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.20 and appendix K of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling, 90, pp. 29-43.
"""
return _gsw_ufuncs.rho(SA, CT, p)
rho.types = _gsw_ufuncs.rho.types
rho = match_args_return(rho)
[docs]
def rho_alpha_beta(SA, CT, p):
"""
Calculates in-situ density, the appropriate thermal expansion coefficient
and the appropriate saline contraction coefficient of seawater from
Absolute Salinity and Conservative Temperature. This function uses the
computationally-efficient expression for specific volume in terms of
SA, CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
rho : array-like, kg/m^3
in-situ density
alpha : array-like, 1/K
thermal expansion coefficient
with respect to Conservative Temperature
beta : array-like, kg/g
saline (i.e. haline) contraction
coefficient at constant Conservative Temperature
Notes
-----
Note that potential density (pot_rho) with respect to reference pressure
p_ref is obtained by calling this function with the pressure argument
being p_ref as in [pot_rho, ~, ~] = gsw_rho_alpha_beta(SA,CT,p_ref).
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.20 and appendix K of this TEOS-10 Manual.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.rho_alpha_beta(SA, CT, p)
rho_alpha_beta.types = _gsw_ufuncs.rho_alpha_beta.types
rho_alpha_beta = match_args_return(rho_alpha_beta)
[docs]
def rho_first_derivatives(SA, CT, p):
"""
Calculates the three (3) partial derivatives of in-situ density with
respect to Absolute Salinity, Conservative Temperature and pressure.
Note that the pressure derivative is done with respect to pressure in
Pa, not dbar. This function uses the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
rho_SA : array-like, (kg/m^3)(g/kg)^-1
partial derivative of density
with respect to Absolute Salinity
rho_CT : array-like, kg/(m^3 K)
partial derivative of density
with respect to Conservative Temperature
rho_P : array-like, kg/(m^3 Pa)
partial derivative of density
with respect to pressure in Pa
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.20 and appendix K of this TEOS-10 Manual.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.rho_first_derivatives(SA, CT, p)
rho_first_derivatives.types = _gsw_ufuncs.rho_first_derivatives.types
rho_first_derivatives = match_args_return(rho_first_derivatives)
[docs]
def rho_first_derivatives_wrt_enthalpy(SA, CT, p):
"""
Calculates the following two first-order derivatives of rho,
(1) rho_SA_wrt_h, first-order derivative with respect to Absolute
Salinity at constant h & p.
(2) rho_h, first-order derivative with respect to h at
constant SA & p.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
rho_SA_wrt_h : array-like, ((kg/m^3)(g/kg)^-1
The first derivative of rho with respect to
Absolute Salinity at constant CT & p.
rho_h : array-like, (m^3/kg)(J/kg)^-1
The first derivative of rho with respect to
SA and CT at constant p.
Notes
-----
Note that this function uses the using the computationally-efficient
75 term expression for specific volume (Roquet et al., 2015). There is
an alternative to calling this function, namely
gsw_specvol_first_derivatives_wrt_enthalpy_CT_exact(SA,CT,p) which uses
the full Gibbs function (IOC et al., 2010).
This 75-term equation has been fitted in a restricted range of parameter
space, and is most accurate inside the "oceanographic funnel" described
in McDougall et al. (2010). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.rho_first_derivatives_wrt_enthalpy(SA, CT, p)
rho_first_derivatives_wrt_enthalpy.types = _gsw_ufuncs.rho_first_derivatives_wrt_enthalpy.types
rho_first_derivatives_wrt_enthalpy = match_args_return(rho_first_derivatives_wrt_enthalpy)
[docs]
def rho_ice(t, p):
"""
Calculates in-situ density of ice from in-situ temperature and pressure.
Note that the output, rho_ice, is density, not density anomaly; that
is, 1000 kg/m^3 is not subtracted from it.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
rho_ice : array-like, kg/m^3
in-situ density of ice (not density anomaly)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.rho_ice(t, p)
rho_ice.types = _gsw_ufuncs.rho_ice.types
rho_ice = match_args_return(rho_ice)
[docs]
def rho_second_derivatives(SA, CT, p):
"""
Calculates the following five second-order derivatives of rho,
(1) rho_SA_SA, second-order derivative with respect to Absolute
Salinity at constant CT & p.
(2) rho_SA_CT, second-order derivative with respect to SA & CT at
constant p.
(3) rho_CT_CT, second-order derivative with respect to CT at
constant SA & p.
(4) rho_SA_P, second-order derivative with respect to SA & P at
constant CT.
(5) rho_CT_P, second-order derivative with respect to CT & P at
constant SA.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
rho_SA_SA : array-like, (kg/m^3)(g/kg)^-2
The second-order derivative of rho with respect to
Absolute Salinity at constant CT & p.
rho_SA_CT : array-like, (kg/m^3)(g/kg)^-1 K^-1
The second-order derivative of rho with respect to
SA and CT at constant p.
rho_CT_CT : array-like, (kg/m^3) K^-2
The second-order derivative of rho with respect to CT at
constant SA & p
rho_SA_P : array-like, (kg/m^3)(g/kg)^-1 Pa^-1
The second-order derivative with respect to SA & P at
constant CT.
rho_CT_P : array-like, (kg/m^3) K^-1 Pa^-1
The second-order derivative with respect to CT & P at
constant SA.
Notes
-----
Note that this function uses the using the computationally-efficient
expression for specific volume (Roquet et al., 2015). There is an
alternative to calling this function, namely
gsw_rho_second_derivatives_CT_exact(SA,CT,p) which uses the full Gibbs
function (IOC et al., 2010).
This 75-term equation has been fitted in a restricted range of parameter
space, and is most accurate inside the "oceanographic funnel" described
in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.rho_second_derivatives(SA, CT, p)
rho_second_derivatives.types = _gsw_ufuncs.rho_second_derivatives.types
rho_second_derivatives = match_args_return(rho_second_derivatives)
[docs]
def rho_second_derivatives_wrt_enthalpy(SA, CT, p):
"""
Calculates the following three second-order derivatives of rho with
respect to enthalpy,
(1) rho_SA_SA, second-order derivative with respect to Absolute Salinity
at constant h & p.
(2) rho_SA_h, second-order derivative with respect to SA & h at
constant p.
(3) rho_h_h, second-order derivative with respect to h at
constant SA & p.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
rho_SA_SA : array-like, (kg/m^3)(g/kg)^-2
The second-order derivative of rho with respect to
Absolute Salinity at constant h & p.
rho_SA_h : array-like, J/(kg K(g/kg))
The second-order derivative of rho with respect to
SA and h at constant p.
rho_h_h : array-like,
The second-order derivative of rho with respect to h at
constant SA & p
Notes
-----
Note that this function uses the using the computationally-efficient
expression for specific volume (Roquet et al., 2015). There is an
alternative to calling this function, namely
gsw_rho_second_derivatives_wrt_enthalpy_CT_exact(SA,CT,p) which uses
the full Gibbs function (IOC et al., 2010).
This 75-term equation has been fitted in a restricted range of parameter
space, and is most accurate inside the "oceanographic funnel" described
in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.rho_second_derivatives_wrt_enthalpy(SA, CT, p)
rho_second_derivatives_wrt_enthalpy.types = _gsw_ufuncs.rho_second_derivatives_wrt_enthalpy.types
rho_second_derivatives_wrt_enthalpy = match_args_return(rho_second_derivatives_wrt_enthalpy)
[docs]
def rho_t_exact(SA, t, p):
"""
Calculates in-situ density of seawater from Absolute Salinity and
in-situ temperature. Note that the output, rho, is density,
not density anomaly; that is, 1000 kg/m^3 is not subtracted from it.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
rho_t_exact : array-like, kg/m^3
in-situ density (not density anomaly)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 2.8 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.rho_t_exact(SA, t, p)
rho_t_exact.types = _gsw_ufuncs.rho_t_exact.types
rho_t_exact = match_args_return(rho_t_exact)
[docs]
def SA_freezing_from_CT(CT, p, saturation_fraction):
"""
Calculates the Absolute Salinity of seawater at the freezing temperature.
That is, the output is the Absolute Salinity of seawater, with
Conservative Temperature CT, pressure p and the fraction
saturation_fraction of dissolved air, that is in equilibrium
with ice at the same in situ temperature and pressure. If the input
values are such that there is no positive value of Absolute Salinity for
which seawater is frozen, the output, SA_freezing, is made a NaN.
Parameters
----------
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
SA_freezing : array-like, g/kg
Absolute Salinity of seawater when it freezes, for
given input values of its Conservative Temperature,
pressure and air saturation fraction.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See section 3.33 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall, T.J., and S.J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.sa_freezing_from_ct(CT, p, saturation_fraction)
SA_freezing_from_CT.types = _gsw_ufuncs.sa_freezing_from_ct.types
SA_freezing_from_CT = match_args_return(SA_freezing_from_CT)
[docs]
def SA_freezing_from_CT_poly(CT, p, saturation_fraction):
"""
Calculates the Absolute Salinity of seawater at the freezing temperature.
That is, the output is the Absolute Salinity of seawater, with the
fraction saturation_fraction of dissolved air, that is in equilibrium
with ice at Conservative Temperature CT and pressure p. If the input
values are such that there is no positive value of Absolute Salinity for
which seawater is frozen, the output, SA_freezing, is put equal to NaN.
Parameters
----------
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
SA_freezing : array-like, g/kg
Absolute Salinity of seawater when it freezes, for
given input values of Conservative Temperature
pressure and air saturation fraction.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See section 3.33 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall T. J. and S. J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.sa_freezing_from_ct_poly(CT, p, saturation_fraction)
SA_freezing_from_CT_poly.types = _gsw_ufuncs.sa_freezing_from_ct_poly.types
SA_freezing_from_CT_poly = match_args_return(SA_freezing_from_CT_poly)
[docs]
def SA_freezing_from_t(t, p, saturation_fraction):
"""
Calculates the Absolute Salinity of seawater at the freezing temperature.
That is, the output is the Absolute Salinity of seawater, with the
fraction saturation_fraction of dissolved air, that is in equilibrium
with ice at in-situ temperature t and pressure p. If the input values
are such that there is no positive value of Absolute Salinity for which
seawater is frozen, the output, SA_freezing, is set to NaN.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
SA_freezing : array-like, g/kg
Absolute Salinity of seawater when it freezes, for
given input values of in situ temperature, pressure and
air saturation fraction.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See section 3.33 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall, T.J., and S.J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.sa_freezing_from_t(t, p, saturation_fraction)
SA_freezing_from_t.types = _gsw_ufuncs.sa_freezing_from_t.types
SA_freezing_from_t = match_args_return(SA_freezing_from_t)
[docs]
def SA_freezing_from_t_poly(t, p, saturation_fraction):
"""
Calculates the Absolute Salinity of seawater at the freezing temperature.
That is, the output is the Absolute Salinity of seawater, with the
fraction saturation_fraction of dissolved air, that is in equilibrium
with ice at in-situ temperature t and pressure p. If the input values
are such that there is no positive value of Absolute Salinity for which
seawater is frozen, the output, SA_freezing, is put equal to NaN.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
SA_freezing : array-like, g/kg
Absolute Salinity of seawater when it freezes, for
given input values of in situ temperature, pressure and
air saturation fraction.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See section 3.33 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
McDougall T. J. and S. J. Wotherspoon, 2014: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.sa_freezing_from_t_poly(t, p, saturation_fraction)
SA_freezing_from_t_poly.types = _gsw_ufuncs.sa_freezing_from_t_poly.types
SA_freezing_from_t_poly = match_args_return(SA_freezing_from_t_poly)
[docs]
def SA_from_rho(rho, CT, p):
"""
Calculates the Absolute Salinity of a seawater sample, for given values
of its density, Conservative Temperature and sea pressure (in dbar).
This function uses the computationally-efficient 75-term expression for
specific volume in terms of SA, CT and p (Roquet et al., 2015).
Parameters
----------
rho : array-like
Seawater density (not anomaly) in-situ, e.g., 1026 kg/m^3.
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
SA : array-like, g/kg
Absolute Salinity.
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 2.5 of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Millero, F.J., R. Feistel, D.G. Wright, and T.J. McDougall, 2008:
The composition of Standard Seawater and the definition of the
Reference-Composition Salinity Scale. Deep-Sea Res. I, 55, 50-72.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.sa_from_rho(rho, CT, p)
SA_from_rho.types = _gsw_ufuncs.sa_from_rho.types
SA_from_rho = match_args_return(SA_from_rho)
[docs]
def SA_from_SP(SP, p, lon, lat):
"""
Calculates Absolute Salinity from Practical Salinity. Since SP is
non-negative by definition, this function changes any negative input
values of SP to be zero.
Parameters
----------
SP : array-like
Practical Salinity (PSS-78), unitless
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
SA : array-like, g/kg
Absolute Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 2.5 and appendices A.4 and A.5 of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.sa_from_sp(SP, p, lon, lat)
SA_from_SP.types = _gsw_ufuncs.sa_from_sp.types
SA_from_SP = match_args_return(SA_from_SP)
[docs]
def SA_from_SP_Baltic(SP, lon, lat):
"""
Calculates Absolute Salinity in the Baltic Sea, from Practical Salinity.
Since SP is non-negative by definition, this function changes any
negative input values of SP to be zero.
Note. This programme will only produce Absolute Salinity values for the
Baltic Sea.
Parameters
----------
SP : array-like
Practical Salinity (PSS-78), unitless
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
SA_baltic : array-like, g kg^-1
Absolute Salinity in the Baltic Sea
References
----------
Feistel, R., S. Weinreben, H. Wolf, S. Seitz, P. Spitzer, B. Adel,
G. Nausch, B. Schneider and D. G. Wright, 2010: Density and Absolute
Salinity of the Baltic Sea 2006-2009. Ocean Science, 6, 3-24.
https://os.copernicus.org/articles/6/3/2010/os-6-3-2010.pdf
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.sa_from_sp_baltic(SP, lon, lat)
SA_from_SP_Baltic.types = _gsw_ufuncs.sa_from_sp_baltic.types
SA_from_SP_Baltic = match_args_return(SA_from_SP_Baltic)
[docs]
def SA_from_Sstar(Sstar, p, lon, lat):
"""
Calculates Absolute Salinity from Preformed Salinity.
Parameters
----------
Sstar : array-like
Preformed Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
SA : array-like, g/kg
Absolute Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.sa_from_sstar(Sstar, p, lon, lat)
SA_from_Sstar.types = _gsw_ufuncs.sa_from_sstar.types
SA_from_Sstar = match_args_return(SA_from_Sstar)
[docs]
def SAAR(p, lon, lat):
"""
Calculates the Absolute Salinity Anomaly Ratio, SAAR, in the open ocean
by spatially interpolating the global reference data set of SAAR to the
location of the seawater sample.
Parameters
----------
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
SAAR : array-like, unitless
Absolute Salinity Anomaly Ratio
Notes
-----
This function uses version 3.0 of the SAAR look up table (15th May 2011).
The Absolute Salinity Anomaly Ratio in the Baltic Sea is evaluated
separately, since it is a function of Practical Salinity, not of space.
The present function returns a SAAR of zero for data in the Baltic Sea.
The correct way of calculating Absolute Salinity in the Baltic Sea is by
calling gsw_SA_from_SP.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
See also gsw_SA_from_SP, gsw_deltaSA_atlas
Reference page in Help browser
<a href="matlab:doc gsw_SAAR">doc gsw_SAAR</a>
Note that this reference page includes the code contained in gsw_SAAR.
We have opted to encode this programme as it is a global standard and
such we cannot allow anyone to change it.
"""
return _gsw_ufuncs.saar(p, lon, lat)
SAAR.types = _gsw_ufuncs.saar.types
SAAR = match_args_return(SAAR)
[docs]
def seaice_fraction_to_freeze_seawater(SA, CT, p, SA_seaice, t_seaice):
"""
Calculates the mass fraction of sea ice (mass of sea ice divided by mass
of sea ice plus seawater), which, when melted into seawater having the
properties (SA,CT,p) causes the final seawater to be at the freezing
temperature. The other outputs are the Absolute Salinity and
Conservative Temperature of the final seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
SA_seaice : array-like
Absolute Salinity of sea ice: the mass fraction of salt
in sea ice, expressed in g of salt per kg of sea ice.
t_seaice : array-like
In-situ temperature of the sea ice at pressure p (ITS-90), degrees C
Returns
-------
SA_freeze : array-like, g/kg
Absolute Salinity of seawater after the mass fraction of
sea ice, w_seaice, at temperature t_seaice has melted into
the original seawater, and the final mixture is at the
freezing temperature of seawater.
CT_freeze : array-like, deg C
Conservative Temperature of seawater after the mass
fraction, w_seaice, of sea ice at temperature t_seaice has
melted into the original seawater, and the final mixture
is at the freezing temperature of seawater.
w_seaice : array-like, unitless
mass fraction of sea ice, at SA_seaice and t_seaice,
which, when melted into seawater at (SA,CT,p) leads to the
final mixed seawater being at the freezing temperature.
This output is between 0 and 1.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall T.J. and S.J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
See Eqn. (23) of this manuscript.
"""
return _gsw_ufuncs.seaice_fraction_to_freeze_seawater(SA, CT, p, SA_seaice, t_seaice)
seaice_fraction_to_freeze_seawater.types = _gsw_ufuncs.seaice_fraction_to_freeze_seawater.types
seaice_fraction_to_freeze_seawater = match_args_return(seaice_fraction_to_freeze_seawater)
[docs]
def sigma0(SA, CT):
"""
Calculates potential density anomaly with reference pressure of 0 dbar,
this being this particular potential density minus 1000 kg/m^3. This
function has inputs of Absolute Salinity and Conservative Temperature.
This function uses the computationally-efficient expression for
specific volume in terms of SA, CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
sigma0 : array-like, kg/m^3
potential density anomaly with
respect to a reference pressure of 0 dbar,
that is, this potential density - 1000 kg/m^3.
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (A.30.1) of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.sigma0(SA, CT)
sigma0.types = _gsw_ufuncs.sigma0.types
sigma0 = match_args_return(sigma0)
[docs]
def sigma1(SA, CT):
"""
Calculates potential density anomaly with reference pressure of 1000
dbar, this being this particular potential density minus 1000 kg/m^3.
This function has inputs of Absolute Salinity and Conservative
Temperature. This function uses the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
sigma1 : array-like, kg/m^3
potential density anomaly with
respect to a reference pressure of 1000 dbar,
that is, this potential density - 1000 kg/m^3.
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (A.30.1) of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.sigma1(SA, CT)
sigma1.types = _gsw_ufuncs.sigma1.types
sigma1 = match_args_return(sigma1)
[docs]
def sigma2(SA, CT):
"""
Calculates potential density anomaly with reference pressure of 2000
dbar, this being this particular potential density minus 1000 kg/m^3.
Temperature. This function uses the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
sigma2 : array-like, kg/m^3
potential density anomaly with
respect to a reference pressure of 2000 dbar,
that is, this potential density - 1000 kg/m^3.
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (A.30.1) of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.sigma2(SA, CT)
sigma2.types = _gsw_ufuncs.sigma2.types
sigma2 = match_args_return(sigma2)
[docs]
def sigma3(SA, CT):
"""
Calculates potential density anomaly with reference pressure of 3000
dbar, this being this particular potential density minus 1000 kg/m^3.
Temperature. This function uses the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
sigma3 : array-like, kg/m^3
potential density anomaly with
respect to a reference pressure of 3000 dbar,
that is, this potential density - 1000 kg/m^3.
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (A.30.1) of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.sigma3(SA, CT)
sigma3.types = _gsw_ufuncs.sigma3.types
sigma3 = match_args_return(sigma3)
[docs]
def sigma4(SA, CT):
"""
Calculates potential density anomaly with reference pressure of 4000
dbar, this being this particular potential density minus 1000 kg/m^3.
Temperature. This function uses the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
sigma4 : array-like, kg/m^3
potential density anomaly with
respect to a reference pressure of 4000 dbar,
that is, this potential density - 1000 kg/m^3.
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (A.30.1) of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.sigma4(SA, CT)
sigma4.types = _gsw_ufuncs.sigma4.types
sigma4 = match_args_return(sigma4)
[docs]
def sound_speed(SA, CT, p):
"""
Calculates the speed of sound in seawater. This function has inputs of
Absolute Salinity and Conservative Temperature. This function uses the
computationally-efficient expression for specific volume in terms of SA,
CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
sound_speed : array-like, m/s
speed of sound in seawater
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (2.17.1) of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.sound_speed(SA, CT, p)
sound_speed.types = _gsw_ufuncs.sound_speed.types
sound_speed = match_args_return(sound_speed)
[docs]
def sound_speed_ice(t, p):
"""
Calculates the compression speed of sound in ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
sound_speed_ice : array-like, m/s
compression speed of sound in ice
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.sound_speed_ice(t, p)
sound_speed_ice.types = _gsw_ufuncs.sound_speed_ice.types
sound_speed_ice = match_args_return(sound_speed_ice)
[docs]
def sound_speed_t_exact(SA, t, p):
"""
Calculates the speed of sound in seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
sound_speed_t_exact : array-like, m/s
speed of sound in seawater
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (2.17.1) of this TEOS-10 Manual.
"""
return _gsw_ufuncs.sound_speed_t_exact(SA, t, p)
sound_speed_t_exact.types = _gsw_ufuncs.sound_speed_t_exact.types
sound_speed_t_exact = match_args_return(sound_speed_t_exact)
[docs]
def SP_from_C(C, t, p):
"""
Calculates Practical Salinity, SP, from conductivity, C, primarily using
the PSS-78 algorithm. Note that the PSS-78 algorithm for Practical
Salinity is only valid in the range 2 < SP < 42. If the PSS-78
algorithm produces a Practical Salinity that is less than 2 then the
Practical Salinity is recalculated with a modified form of the Hill et
al. (1986) formula. The modification of the Hill et al. (1986)
expression is to ensure that it is exactly consistent with PSS-78
at SP = 2. Note that the input values of conductivity need to be in
units of mS/cm (not S/m).
Parameters
----------
C : array-like
Conductivity, mS/cm
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
SP : array-like, unitless
Practical Salinity on the PSS-78 scale
References
----------
Culkin and Smith, 1980: Determination of the Concentration of Potassium
Chloride Solution Having the Same Electrical Conductivity, at 15C and
Infinite Frequency, as Standard Seawater of Salinity 35.0000
(Chlorinity 19.37394), IEEE J. Oceanic Eng, 5, 22-23.
Hill, K.D., T.M. Dauphinee & D.J. Woods, 1986: The extension of the
Practical Salinity Scale 1978 to low salinities. IEEE J. Oceanic Eng.,
11, 109 - 112.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix E of this TEOS-10 Manual.
Unesco, 1983: Algorithms for computation of fundamental properties of
seawater. Unesco Technical Papers in Marine Science, 44, 53 pp.
"""
return _gsw_ufuncs.sp_from_c(C, t, p)
SP_from_C.types = _gsw_ufuncs.sp_from_c.types
SP_from_C = match_args_return(SP_from_C)
[docs]
def SP_from_SA(SA, p, lon, lat):
"""
Calculates Practical Salinity from Absolute Salinity.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
SP : array-like, unitless
Practical Salinity (PSS-78)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.sp_from_sa(SA, p, lon, lat)
SP_from_SA.types = _gsw_ufuncs.sp_from_sa.types
SP_from_SA = match_args_return(SP_from_SA)
[docs]
def SP_from_SA_Baltic(SA, lon, lat):
"""
Calculates Practical Salinity for the Baltic Sea, from a value computed
analytically from Absolute Salinity.
Note. This programme will only produce Practical Salinty values for the
Baltic Sea.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
SP_baltic : array-like, unitless
Practical Salinity
References
----------
Feistel, R., S. Weinreben, H. Wolf, S. Seitz, P. Spitzer, B. Adel,
G. Nausch, B. Schneider and D. G. Wright, 2010c: Density and Absolute
Salinity of the Baltic Sea 2006-2009. Ocean Science, 6, 3-24.
https://os.copernicus.org/articles/6/3/2010/os-6-3-2010.pdf
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.sp_from_sa_baltic(SA, lon, lat)
SP_from_SA_Baltic.types = _gsw_ufuncs.sp_from_sa_baltic.types
SP_from_SA_Baltic = match_args_return(SP_from_SA_Baltic)
[docs]
def SP_from_SK(SK):
"""
Calculates Practical Salinity from Knudsen Salinity.
Parameters
----------
SK : array-like
Knudsen Salinity, ppt
Returns
-------
SP : array-like, unitless
Practical Salinity (PSS-78)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Appendix A.3 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.sp_from_sk(SK)
SP_from_SK.types = _gsw_ufuncs.sp_from_sk.types
SP_from_SK = match_args_return(SP_from_SK)
[docs]
def SP_from_SR(SR):
"""
Calculates Practical Salinity from Reference Salinity.
Parameters
----------
SR : array-like
Reference Salinity, g/kg
Returns
-------
SP : array-like, unitless
Practical Salinity (PSS-78)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.sp_from_sr(SR)
SP_from_SR.types = _gsw_ufuncs.sp_from_sr.types
SP_from_SR = match_args_return(SP_from_SR)
[docs]
def SP_from_Sstar(Sstar, p, lon, lat):
"""
Calculates Practical Salinity from Preformed Salinity.
Parameters
----------
Sstar : array-like
Preformed Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
SP : array-like, unitless
Practical Salinity (PSS-78)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.sp_from_sstar(Sstar, p, lon, lat)
SP_from_Sstar.types = _gsw_ufuncs.sp_from_sstar.types
SP_from_Sstar = match_args_return(SP_from_Sstar)
[docs]
def SP_salinometer(Rt, t):
"""
Calculates Practical Salinity SP from a salinometer, primarily using the
PSS-78 algorithm. Note that the PSS-78 algorithm for Practical Salinity
is only valid in the range 2 < SP < 42. If the PSS-78 algorithm
produces a Practical Salinity that is less than 2 then the Practical
Salinity is recalculated with a modified form of the Hill et al. (1986)
formula. The modification of the Hill et al. (1986) expression is to
ensure that it is exactly consistent with PSS-78 at SP = 2.
Parameters
----------
Rt : array-like
C(SP,t_68,0)/C(SP=35,t_68,0), unitless
t : array-like
In-situ temperature (ITS-90), degrees C
Returns
-------
SP : array-like, unitless
Practical Salinity on the PSS-78 scale
t may have dimensions 1x1 or Mx1 or 1xN or MxN, where Rt is MxN.
Notes
-----
A laboratory salinometer has the ratio of conductivities, Rt, as an
output, and the present function uses this conductivity ratio and the
temperature t of the salinometer bath as the two input variables.
References
----------
Fofonoff, P. and R.C. Millard Jr. 1983: Algorithms for computation of
fundamental properties of seawater. Unesco Tech. Pap. in Mar. Sci., 44,
53 pp.
Hill, K.D., T.M. Dauphinee & D.J. Woods, 1986: The extension of the
Practical Salinity Scale 1978 to low salinities. IEEE J. Oceanic Eng.,
11, 109 - 112.
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix E of this TEOS-10 Manual, and in particular,
Eqns. (E.2.1) and (E.2.6).
"""
return _gsw_ufuncs.sp_salinometer(Rt, t)
SP_salinometer.types = _gsw_ufuncs.sp_salinometer.types
SP_salinometer = match_args_return(SP_salinometer)
[docs]
def specvol(SA, CT, p):
"""
Calculates specific volume from Absolute Salinity, Conservative
Temperature and pressure, using the computationally-efficient 75-term
polynomial expression for specific volume (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
specvol : array-like, m^3/kg
specific volume
Notes
-----
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmos. Ocean. Tech., 20,
730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.specvol(SA, CT, p)
specvol.types = _gsw_ufuncs.specvol.types
specvol = match_args_return(specvol)
[docs]
def specvol_alpha_beta(SA, CT, p):
"""
Calculates specific volume, the appropriate thermal expansion coefficient
and the appropriate saline contraction coefficient of seawater from
Absolute Salinity and Conservative Temperature. This function uses the
computationally-efficient expression for specific volume in terms of
SA, CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
specvol : array-like, m/kg
specific volume
alpha : array-like, 1/K
thermal expansion coefficient
with respect to Conservative Temperature
beta : array-like, kg/g
saline (i.e. haline) contraction
coefficient at constant Conservative Temperature
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix A.20 and appendix K of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.specvol_alpha_beta(SA, CT, p)
specvol_alpha_beta.types = _gsw_ufuncs.specvol_alpha_beta.types
specvol_alpha_beta = match_args_return(specvol_alpha_beta)
[docs]
def specvol_anom_standard(SA, CT, p):
"""
Calculates specific volume anomaly from Absolute Salinity, Conservative
Temperature and pressure. It uses the computationally-efficient
expression for specific volume as a function of SA, CT and p (Roquet
et al., 2015). The reference value to which the anomaly is calculated
has an Absolute Salinity of SSO and Conservative Temperature equal to
0 degrees C.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
specvol_anom : array-like, m^3/kg
specific volume anomaly
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqn. (3.7.3) of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.specvol_anom_standard(SA, CT, p)
specvol_anom_standard.types = _gsw_ufuncs.specvol_anom_standard.types
specvol_anom_standard = match_args_return(specvol_anom_standard)
[docs]
def specvol_first_derivatives(SA, CT, p):
"""
Calculates the following three first-order derivatives of specific
volume (v),
(1) v_SA, first-order derivative with respect to Absolute Salinity
at constant CT & p.
(2) v_CT, first-order derivative with respect to CT at
constant SA & p.
(3) v_P, first-order derivative with respect to P at constant SA
and CT.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
v_SA : array-like, (m^3/kg)(g/kg)^-1
The first derivative of specific volume with respect to
Absolute Salinity at constant CT & p.
v_CT : array-like, m^3/(K kg)
The first derivative of specific volume with respect to
CT at constant SA and p.
v_P : array-like, m^3/(Pa kg)
The first derivative of specific volume with respect to
P at constant SA and CT.
Notes
-----
Note that this function uses the using the computationally-efficient
75-term expression for specific volume (Roquet et al., 2015). There is
an alternative to calling this function, namely
gsw_specvol_first_derivatives_CT_exact(SA,CT,p) which uses the full
Gibbs function (IOC et al., 2010).
This 75-term equation has been fitted in a restricted range of parameter
space, and is most accurate inside the "oceanographic funnel" described
in McDougall et al. (2010). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.specvol_first_derivatives(SA, CT, p)
specvol_first_derivatives.types = _gsw_ufuncs.specvol_first_derivatives.types
specvol_first_derivatives = match_args_return(specvol_first_derivatives)
[docs]
def specvol_first_derivatives_wrt_enthalpy(SA, CT, p):
"""
Calculates the following two first-order derivatives of specific
volume (v),
(1) v_SA_wrt_h, first-order derivative with respect to Absolute Salinity
at constant h & p.
(2) v_h, first-order derivative with respect to h at
constant SA & p.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
v_SA_wrt_h : array-like, (m^3/kg)(g/kg)^-1
The first derivative of specific volume with respect to
Absolute Salinity at constant CT & p.
v_h : array-like, (m^3/kg)(J/kg)^-1
The first derivative of specific volume with respect to
SA and CT at constant p.
Notes
-----
Note that this function uses the using the computationally-efficient
75 term expression for specific volume (Roquet et al., 2015). There is
an alternative to calling this function, namely
gsw_specvol_first_derivatives_wrt_enthalpy_CT_exact(SA,CT,p) which uses
the full Gibbs function (IOC et al., 2010).
This 75-term equation has been fitted in a restricted range of parameter
space, and is most accurate inside the "oceanographic funnel" described
in McDougall et al. (2010). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.specvol_first_derivatives_wrt_enthalpy(SA, CT, p)
specvol_first_derivatives_wrt_enthalpy.types = _gsw_ufuncs.specvol_first_derivatives_wrt_enthalpy.types
specvol_first_derivatives_wrt_enthalpy = match_args_return(specvol_first_derivatives_wrt_enthalpy)
[docs]
def specvol_ice(t, p):
"""
Calculates the specific volume of ice.
Parameters
----------
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
specvol_ice : array-like, m^3/kg
specific volume
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.specvol_ice(t, p)
specvol_ice.types = _gsw_ufuncs.specvol_ice.types
specvol_ice = match_args_return(specvol_ice)
[docs]
def specvol_second_derivatives(SA, CT, p):
"""
Calculates the following five second-order derivatives of specific
volume (v),
(1) v_SA_SA, second-order derivative with respect to Absolute Salinity
at constant CT & p.
(2) v_SA_CT, second-order derivative with respect to SA & CT at
constant p.
(3) v_CT_CT, second-order derivative with respect to CT at constant SA
and p.
(4) v_SA_P, second-order derivative with respect to SA & P at
constant CT.
(5) v_CT_P, second-order derivative with respect to CT & P at
constant SA.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
v_SA_SA : array-like, (m^3/kg)(g/kg)^-2
The second derivative of specific volume with respect to
Absolute Salinity at constant CT & p.
v_SA_CT : array-like, (m^3/kg)(g/kg)^-1 K^-1
The second derivative of specific volume with respect to
SA and CT at constant p.
v_CT_CT : array-like, (m^3/kg) K^-2)
The second derivative of specific volume with respect to
CT at constant SA and p.
v_SA_P : array-like, (m^3/kg)(g/kg)^-1 Pa^-1
The second derivative of specific volume with respect to
SA and P at constant CT.
v_CT_P : array-like, (m^3/kg) K^-1 Pa^-1
The second derivative of specific volume with respect to
CT and P at constant SA.
Notes
-----
Note that this function uses the using the computationally-efficient
75-term expression for specific volume (Roquet et al., 2015). There is
an alternative to calling this function, namely
gsw_specvol_second_derivatives_CT_exact(SA,CT,p) which uses the full
Gibbs function (IOC et al., 2010).
Note that the 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.specvol_second_derivatives(SA, CT, p)
specvol_second_derivatives.types = _gsw_ufuncs.specvol_second_derivatives.types
specvol_second_derivatives = match_args_return(specvol_second_derivatives)
[docs]
def specvol_second_derivatives_wrt_enthalpy(SA, CT, p):
"""
Calculates the following three first-order derivatives of specific
volume (v) with respect to enthalpy,
(1) v_SA_SA_wrt_h, second-order derivative with respect to Absolute Salinity
at constant h & p.
(2) v_SA_h, second-order derivative with respect to SA & h at
constant p.
(3) v_h_h, second-order derivative with respect to h at
constant SA & p.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
v_SA_SA_wrt_h : array-like, (m^3/kg)(g/kg)^-2
The second-order derivative of specific volume with
respect to Absolute Salinity at constant h & p.
v_SA_h : array-like, (m^3/kg)(g/kg)^-1 (J/kg)^-1
The second-order derivative of specific volume with respect to
SA and h at constant p.
v_h_h : array-like, (m^3/kg)(J/kg)^-2
The second-order derivative with respect to h at
constant SA & p.
Notes
-----
Note that this function uses the using the computationally-efficient
75 term expression for specific volume (Roquet et al., 2015). There is
an alternative to calling this function, namely
gsw_specvol_second_derivatives_wrt_enthalpy_CT_exact(SA,CT,p) which uses
the full Gibbs function (IOC et al., 2010).
This 75-term equation has been fitted in a restricted range of parameter
space, and is most accurate inside the "oceanographic funnel" described
in McDougall et al. (2010). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.specvol_second_derivatives_wrt_enthalpy(SA, CT, p)
specvol_second_derivatives_wrt_enthalpy.types = _gsw_ufuncs.specvol_second_derivatives_wrt_enthalpy.types
specvol_second_derivatives_wrt_enthalpy = match_args_return(specvol_second_derivatives_wrt_enthalpy)
[docs]
def specvol_SSO_0(p):
"""
specific volume at (SSO,CT=0,p)
Parameters
----------
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
double, array
Notes
-----
sw_specvol_SSO_0 specific volume at (SSO,CT=0,p)
(75-term equation)
This function calculates specific volume at the Standard Ocean Salinity,
SSO, and at a Conservative Temperature of zero degrees C, as a function
of pressure, p, in dbar, using a streamlined version of the 75-term CT
version of specific volume, that is, a streamlined version of the code
"gsw_specvol(SA,CT,p)".
VERSION NUMBER: 3.06.12 (25th May, 2020)
References
----------
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.specvol_sso_0(p)
specvol_SSO_0.types = _gsw_ufuncs.specvol_sso_0.types
specvol_SSO_0 = match_args_return(specvol_SSO_0)
[docs]
def specvol_t_exact(SA, t, p):
"""
Calculates the specific volume of seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
specvol_t_exact : array-like, m^3/kg
specific volume
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 2.7 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.specvol_t_exact(SA, t, p)
specvol_t_exact.types = _gsw_ufuncs.specvol_t_exact.types
specvol_t_exact = match_args_return(specvol_t_exact)
[docs]
def spiciness0(SA, CT):
"""
Calculates spiciness from Absolute Salinity and Conservative
Temperature at a pressure of 0 dbar, as described by McDougall and
Krzysik (2015). This routine is based on the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
spiciness0 : array-like, kg/m^3
spiciness referenced to a pressure of 0 dbar,
i.e. the surface
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
McDougall, T.J., and O.A. Krzysik, 2015: Spiciness. Journal of Marine
Research, 73, 141-152.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.spiciness0(SA, CT)
spiciness0.types = _gsw_ufuncs.spiciness0.types
spiciness0 = match_args_return(spiciness0)
[docs]
def spiciness1(SA, CT):
"""
Calculates spiciness from Absolute Salinity and Conservative
Temperature at a pressure of 1000 dbar, as described by McDougall and
Krzysik (2015). This routine is based on the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
spiciness1 : array-like, kg/m^3
spiciness referenced to a pressure of 1000 dbar
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
McDougall, T.J., and O.A. Krzysik, 2015: Spiciness. Journal of Marine
Research, 73, 141-152.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.spiciness1(SA, CT)
spiciness1.types = _gsw_ufuncs.spiciness1.types
spiciness1 = match_args_return(spiciness1)
[docs]
def spiciness2(SA, CT):
"""
Calculates spiciness from Absolute Salinity and Conservative
Temperature at a pressure of 2000 dbar, as described by McDougall and
Krzysik (2015). This routine is based on the computationally-efficient
expression for specific volume in terms of SA, CT and p (Roquet et al.,
2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
Returns
-------
spiciness2 : array-like, kg/m^3
spiciness referenced to a pressure of 2000 dbar
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
McDougall, T.J., and O.A. Krzysik, 2015: Spiciness. Journal of Marine
Research, 73, 141-152.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.spiciness2(SA, CT)
spiciness2.types = _gsw_ufuncs.spiciness2.types
spiciness2 = match_args_return(spiciness2)
[docs]
def SR_from_SP(SP):
"""
Calculates Reference Salinity from Practical Salinity.
Parameters
----------
SP : array-like
Practical Salinity (PSS-78), unitless
Returns
-------
SR : array-like, g/kg
Reference Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.sr_from_sp(SP)
SR_from_SP.types = _gsw_ufuncs.sr_from_sp.types
SR_from_SP = match_args_return(SR_from_SP)
[docs]
def Sstar_from_SA(SA, p, lon, lat):
"""
Converts Preformed Salinity from Absolute Salinity.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
Sstar : array-like, g/kg
Preformed Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.sstar_from_sa(SA, p, lon, lat)
Sstar_from_SA.types = _gsw_ufuncs.sstar_from_sa.types
Sstar_from_SA = match_args_return(Sstar_from_SA)
[docs]
def Sstar_from_SP(SP, p, lon, lat):
"""
Calculates Preformed Salinity from Absolute Salinity.
Since SP is non-negative by definition, this function changes any
negative input values of SP to be zero.
Parameters
----------
SP : array-like
Practical Salinity (PSS-78), unitless
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lon : array-like
Longitude, -360 to 360 degrees
lat : array-like
Latitude, -90 to 90 degrees
Returns
-------
Sstar : array-like, g/kg
Preformed Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See section 2.5 and appendices A.4 and A.5 of this TEOS-10 Manual.
McDougall, T.J., D.R. Jackett, F.J. Millero, R. Pawlowicz and
P.M. Barker, 2012: A global algorithm for estimating Absolute Salinity.
Ocean Science, 8, 1123-1134.
https://os.copernicus.org/articles/8/1123/2012/os-8-1123-2012.pdf
"""
return _gsw_ufuncs.sstar_from_sp(SP, p, lon, lat)
Sstar_from_SP.types = _gsw_ufuncs.sstar_from_sp.types
Sstar_from_SP = match_args_return(Sstar_from_SP)
[docs]
def t_deriv_chem_potential_water_t_exact(SA, t, p):
"""
Calculates the temperature derivative of the chemical potential of water
in seawater so that it is valid at exactly SA = 0.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
t : array-like
In-situ temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
chem_potential_water_dt : array-like, J g^-1 K^-1
temperature derivative of the chemical
potential of water in seawater
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
"""
return _gsw_ufuncs.t_deriv_chem_potential_water_t_exact(SA, t, p)
t_deriv_chem_potential_water_t_exact.types = _gsw_ufuncs.t_deriv_chem_potential_water_t_exact.types
t_deriv_chem_potential_water_t_exact = match_args_return(t_deriv_chem_potential_water_t_exact)
[docs]
def t_freezing(SA, p, saturation_fraction):
"""
Calculates the in-situ temperature at which seawater freezes. The
in-situ temperature freezing point is calculated from the exact
in-situ freezing temperature which is found by a modified Newton-Raphson
iteration (McDougall and Wotherspoon, 2013) of the equality of the
chemical potentials of water in seawater and in ice.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
t_freezing : array-like, deg C
in-situ temperature at which seawater freezes.
(ITS-90)
Notes
-----
An alternative GSW function, gsw_t_freezing_poly, it is based on a
computationally-efficient polynomial, and is accurate to within -5e-4 K
and 6e-4 K, when compared with this function.
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall T.J., and S.J. Wotherspoon, 2013: A simple modification of
Newton's method to achieve convergence of order 1 + sqrt(2). Applied
Mathematics Letters, 29, 20-25.
"""
return _gsw_ufuncs.t_freezing(SA, p, saturation_fraction)
t_freezing.types = _gsw_ufuncs.t_freezing.types
t_freezing = match_args_return(t_freezing)
[docs]
def t_freezing_first_derivatives(SA, p, saturation_fraction):
"""
Calculates the first derivatives of the in-situ temperature at which
seawater freezes with respect to Absolute Salinity SA and pressure P (in
Pa). These expressions come from differentiating the expression that
defines the freezing temperature, namely the equality between the
chemical potentials of water in seawater and in ice.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
tfreezing_SA : array-like, K kg/g
the derivative of the in-situ freezing temperature
(ITS-90) with respect to Absolute Salinity at fixed
pressure [ K/(g/kg) ] i.e.
tfreezing_P : array-like, K/Pa
the derivative of the in-situ freezing temperature
(ITS-90) with respect to pressure (in Pa) at fixed
Absolute Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
"""
return _gsw_ufuncs.t_freezing_first_derivatives(SA, p, saturation_fraction)
t_freezing_first_derivatives.types = _gsw_ufuncs.t_freezing_first_derivatives.types
t_freezing_first_derivatives = match_args_return(t_freezing_first_derivatives)
[docs]
def t_freezing_first_derivatives_poly(SA, p, saturation_fraction):
"""
Calculates the first derivatives of the in-situ temperature at which
seawater freezes with respect to Absolute Salinity SA and pressure P (in
Pa). These expressions come from differentiating the expression that
defines the freezing temperature, namely the equality between the
chemical potentials of water in seawater and in ice.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
tfreezing_SA : array-like, K kg/g
the derivative of the in-situ freezing temperature
(ITS-90) with respect to Absolute Salinity at fixed
pressure [ K/(g/kg) ] i.e.
tfreezing_P : array-like, K/Pa
the derivative of the in-situ freezing temperature
(ITS-90) with respect to pressure (in Pa) at fixed
Absolute Salinity
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
"""
return _gsw_ufuncs.t_freezing_first_derivatives_poly(SA, p, saturation_fraction)
t_freezing_first_derivatives_poly.types = _gsw_ufuncs.t_freezing_first_derivatives_poly.types
t_freezing_first_derivatives_poly = match_args_return(t_freezing_first_derivatives_poly)
[docs]
def t_freezing_poly(SA, p, saturation_fraction):
"""
Calculates the in-situ temperature at which seawater freezes from a
comptationally efficient polynomial.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
saturation_fraction : array-like
Saturation fraction of dissolved air in seawater. (0..1)
Returns
-------
t_freezing : array-like, deg C
in-situ temperature at which seawater freezes.
(ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/.
See sections 3.33 and 3.34 of this TEOS-10 Manual.
McDougall, T.J., P.M. Barker, R. Feistel and B.K. Galton-Fenzi, 2014:
Melting of Ice and Sea Ice into Seawater and Frazil Ice Formation.
Journal of Physical Oceanography, 44, 1751-1775.
"""
return _gsw_ufuncs.t_freezing_poly(SA, p, saturation_fraction)
t_freezing_poly.types = _gsw_ufuncs.t_freezing_poly.types
t_freezing_poly = match_args_return(t_freezing_poly)
[docs]
def t_from_CT(SA, CT, p):
"""
Calculates in-situ temperature from the Conservative Temperature of
seawater.
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
t : array-like, deg C
in-situ temperature (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See sections 3.1 and 3.3 of this TEOS-10 Manual.
"""
return _gsw_ufuncs.t_from_ct(SA, CT, p)
t_from_CT.types = _gsw_ufuncs.t_from_ct.types
t_from_CT = match_args_return(t_from_CT)
[docs]
def t_from_pt0_ice(pt0_ice, p):
"""
Calculates in-situ temperature from the potential temperature of ice Ih
with reference pressure, p_ref, of 0 dbar (the surface), and the
in-situ pressure.
Parameters
----------
pt0_ice : array-like
Potential temperature of ice (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
t : array-like, deg C
in-situ temperature (ITS-90)
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See appendix I of this TEOS-10 Manual.
"""
return _gsw_ufuncs.t_from_pt0_ice(pt0_ice, p)
t_from_pt0_ice.types = _gsw_ufuncs.t_from_pt0_ice.types
t_from_pt0_ice = match_args_return(t_from_pt0_ice)
[docs]
def thermobaric(SA, CT, p):
"""
Calculates the thermobaric coefficient of seawater with respect to
Conservative Temperature. This routine is based on the
computationally-efficient expression for specific volume in terms of
SA, CT and p (Roquet et al., 2015).
Parameters
----------
SA : array-like
Absolute Salinity, g/kg
CT : array-like
Conservative Temperature (ITS-90), degrees C
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
Returns
-------
thermobaric : array-like, 1/(K Pa)
thermobaric coefficient with
respect to Conservative Temperature.
Notes
-----
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
See Eqns. (3.8.2) and (P.2) of this TEOS-10 manual.
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling., 90, pp. 29-43.
"""
return _gsw_ufuncs.thermobaric(SA, CT, p)
thermobaric.types = _gsw_ufuncs.thermobaric.types
thermobaric = match_args_return(thermobaric)
def z_from_p(p, lat, geo_strf_dyn_height, sea_surface_geopotential):
"""
Calculates height from sea pressure using the computationally-efficient
75-term expression for specific volume in terms of SA, CT and p
(Roquet et al., 2015). Dynamic height anomaly, geo_strf_dyn_height, if
provided, must be computed with its p_ref = 0 (the surface). Also if
provided, sea_surface_geopotental is the geopotential at zero sea
pressure. This function solves Eqn.(3.32.3) of IOC et al. (2010).
Parameters
----------
p : array-like
Sea pressure (absolute pressure minus 10.1325 dbar), dbar
lat : array-like
Latitude, -90 to 90 degrees
geo_strf_dyn_height : array-like
dynamic height anomaly, m^2/s^2
Note that the reference pressure, p_ref, of geo_strf_dyn_height must
be zero (0) dbar.
sea_surface_geopotential : array-like
geopotential at zero sea pressure, m^2/s^2
Returns
-------
z : array-like, m
height
Notes
-----
Note. Height z is NEGATIVE in the ocean. i.e. Depth is -z.
Depth is not used in the GSW computer software library.
Note that this 75-term equation has been fitted in a restricted range of
parameter space, and is most accurate inside the "oceanographic funnel"
described in McDougall et al. (2003). The GSW library function
"gsw_infunnel(SA,CT,p)" is available to be used if one wants to test if
some of one's data lies outside this "funnel".
References
----------
IOC, SCOR and IAPSO, 2010: The international thermodynamic equation of
seawater - 2010: Calculation and use of thermodynamic properties.
Intergovernmental Oceanographic Commission, Manuals and Guides No. 56,
UNESCO (English), 196 pp. Available from https://www.teos-10.org/
McDougall, T.J., D.R. Jackett, D.G. Wright and R. Feistel, 2003:
Accurate and computationally efficient algorithms for potential
temperature and density of seawater. J. Atmosph. Ocean. Tech., 20,
pp. 730-741.
Moritz, H., 2000: Geodetic reference system 1980. J. Geodesy, 74,
pp. 128-133.
Roquet, F., G. Madec, T.J. McDougall, P.M. Barker, 2015: Accurate
polynomial expressions for the density and specific volume of seawater
using the TEOS-10 standard. Ocean Modelling, 90, pp. 29-43.
This software is available from https://www.teos-10.org/
"""
return _gsw_ufuncs.z_from_p(p, lat, geo_strf_dyn_height, sea_surface_geopotential)
z_from_p.types = _gsw_ufuncs.z_from_p.types
z_from_p = match_args_return(z_from_p)