Title: | Modelling and Analysis of Leaf Gas Exchange Data |
---|---|
Description: | Coupled leaf gas exchange model, A-Ci curve simulation and fitting, Ball-Berry stomatal conductance models, leaf energy balance using Penman-Monteith, Cowan-Farquhar optimization, humidity unit conversions. See Duursma (2015) <doi:10.1371/journal.pone.0143346>. |
Authors: | Remko Duursma [aut, cre] |
Maintainer: | Remko Duursma <[email protected]> |
License: | GPL |
Version: | 1.4-6 |
Built: | 2025-01-12 04:35:16 UTC |
Source: | https://bitbucket.org/remkoduursma/plantecophys |
Coupled leaf gas exchange model, A-Ci curve simulation and fitting, Ball-Berry stomatal conductance models, leaf energy balance using Penman-Monteith, Cowan-Farquhar optimization, humidity unit conversions. See Duursma (2015) <doi:10.1371/journal.pone.0143346>.
The DESCRIPTION file:
Package: | plantecophys |
Type: | Package |
Title: | Modelling and Analysis of Leaf Gas Exchange Data |
Version: | 1.4-6 |
Authors@R: | person("Remko", "Duursma", role = c("aut", "cre"),email = "[email protected]") |
Description: | Coupled leaf gas exchange model, A-Ci curve simulation and fitting, Ball-Berry stomatal conductance models, leaf energy balance using Penman-Monteith, Cowan-Farquhar optimization, humidity unit conversions. See Duursma (2015) <doi:10.1371/journal.pone.0143346>. |
URL: | https://bitbucket.org/remkoduursma/plantecophys |
BugReports: | https://bitbucket.org/remkoduursma/plantecophys/issues |
Depends: | R (>= 3.3.0) |
Suggests: | nlstools, testthat, knitr, rmarkdown, DT |
License: | GPL |
LazyData: | yes |
RoxygenNote: | 7.1.1 |
VignetteBuilder: | knitr |
Repository: | https://remkoduursma.r-universe.dev |
RemoteUrl: | https://bitbucket.org/remkoduursma/plantecophys |
RemoteRef: | HEAD |
RemoteSha: | c9749828041f10ca47c6691436678e0a5632cfb8 |
Author: | Remko Duursma [aut, cre] |
Maintainer: | Remko Duursma <[email protected]> |
Index of help topics:
AciC4 C4 Photosynthesis FARAO FARquhar And Opti Photosyn Coupled leaf gas exchange model PhotosynEB Coupled leaf gas exchange model with energy balance PhotosynTuzet Coupled leaf gas exchange model with Tuzet stomatal conductance RHtoVPD Conversions between relative humidity, vapour pressure deficit and dewpoint acidata1 An example A-Ci curve findCiTransition Calculate transition points for fitted A-Ci curves fitBB Fit Ball-Berry type models of stomatal conductance fitBBs Fit Ball-Berry type models of stomatal conductance to many groups at once fitaci Fit the Farquhar-Berry-von Caemmerer model of leaf photosynthesis fitacis Fit multiple A-Ci curves at once manyacidat An example dataset with multiple A-Ci curves plantecophys-package Modelling and Analysis of Leaf Gas Exchange Data
The following functions are the main tools in plantecophys:
Photosyn
can be used to simulate A-Ci curves (or Aci
), and simulate from a coupled leaf gas exchange model.
fitBB
fits Ball-Berry-type stomatal conductance models to data.
FARAO
is an implementation of a numeric solution to Cowan-Farquhar optimization of stomatal conductance.
RHtoVPD
converts relative humidity to vapour pressure deficit (and more similar functions on that help page).
The package also includes the following example datasets:
acidata1
A dataset with a single A-Ci curve.
manyacidat
A dataset with many A-Ci curves.
Remko Duursma
Maintainer: Remko Duursma
Duursma, R.A., 2015. Plantecophys - An R Package for Analysing and Modelling Leaf Gas Exchange Data. PLoS ONE 10, e0143346. doi:10.1371/journal.pone.0143346
An implementation of the A-Ci curve for C4 plants, based on von Caemmerer et al. (2000)
AciC4( Ci, PPFD = 1500, Tleaf = 25, VPMAX25 = 120, JMAX25 = 400, Vcmax = 60, Vpr = 80, alpha = 0, gbs = 0.003, O2 = 210, x = 0.4, THETA = 0.7, Q10 = 2.3, RD0 = 1, RTEMP = 25, TBELOW = 0, DAYRESP = 1, Q10F = 2, FRM = 0.5, ... )
AciC4( Ci, PPFD = 1500, Tleaf = 25, VPMAX25 = 120, JMAX25 = 400, Vcmax = 60, Vpr = 80, alpha = 0, gbs = 0.003, O2 = 210, x = 0.4, THETA = 0.7, Q10 = 2.3, RD0 = 1, RTEMP = 25, TBELOW = 0, DAYRESP = 1, Q10F = 2, FRM = 0.5, ... )
Ci |
Intercellular CO2 concentration (ppm) |
PPFD |
Photosynthetic photon flux density (mu mol m-2 s-1) |
Tleaf |
Leaf temperature (C) |
VPMAX25 |
The maximum rate of PEP carboxylation (mu mol m-2 s-1) |
JMAX25 |
Maximum electron transport rate (at 25C) |
Vcmax |
Maximum rate of carboxylation (mu mol m-2 s-1) (at 25C) |
Vpr |
PEP regeneration (mu mol m-2 s-1) |
alpha |
Fraction of PSII activity in the bundle sheath (-) |
gbs |
Bundle sheath conductance (mol m-2 s-1) |
O2 |
Mesophyll O2 concentration |
x |
Partitioning factor for electron transport |
THETA |
Shape parameter of the non-rectangular hyperbola |
Q10 |
T-dependence parameter for Michaelis-Menten coefficients. |
RD0 |
Respiration at base temperature (RTEMP) (mu mol m-2 s-1) |
RTEMP |
Base leaf temperature for respiration (C) |
TBELOW |
Below this T, respiration is zero. |
DAYRESP |
Fraction respiration in the light vs. that measured in the dark |
Q10F |
T-dependence parameter of respiration |
FRM |
Fraction of day respiration that is mesophyll respiration (Rm) |
... |
Further arguments (currently ignored). |
Note that the temperature response parameters have been hardwired in this function, and are based on von Caemmerer (2000).
Note that it is not (yet) possible to fit this curve to observations of
photosynthesis (see fitaci
to fit the C3 model of photosynthesis).
Rhys Whitley
Caemmerer, S.V., 2000. Biochemical Models of Leaf Photosynthesis. Csiro Publishing.
# Simulate a C4 A-Ci curve. aci <- AciC4(Ci=seq(5,600, length=101)) with(aci, plot(Ci, ALEAF, type='l', ylim=c(0,max(ALEAF))))
# Simulate a C4 A-Ci curve. aci <- AciC4(Ci=seq(5,600, length=101)) with(aci, plot(Ci, ALEAF, type='l', ylim=c(0,max(ALEAF))))
CO2 response of leaf photosynthesis, as measured with a Licor6400.
CO2 concentration in cuvette (ppm)
Intercellular CO2 concentration (ppm)
Leaf temperature (deg C)
Net photosynthesis rate (mu mol m-2 s-1)
The numerical solution of the optimal stomatal conductance model, coupled with the Farquhar model of photosynthesis. The model of Medlyn et al. (2011) is an approximation to this full numeric solution.
FARAO( lambda = 0.002, Ca = 400, VPD = 1, photo = c("BOTH", "VCMAX", "JMAX"), energybalance = FALSE, C4 = FALSE, Tair = 25, Wind = 2, Wleaf = 0.02, StomatalRatio = 1, LeafAbs = 0.86, ... ) FARAO2(lambda = 0.002, Ca = 400, energybalance = FALSE, ...)
FARAO( lambda = 0.002, Ca = 400, VPD = 1, photo = c("BOTH", "VCMAX", "JMAX"), energybalance = FALSE, C4 = FALSE, Tair = 25, Wind = 2, Wleaf = 0.02, StomatalRatio = 1, LeafAbs = 0.86, ... ) FARAO2(lambda = 0.002, Ca = 400, energybalance = FALSE, ...)
lambda |
The marginal cost of water (mol mol-1) |
Ca |
The CO2 concentration. |
VPD |
Vapor pressure deficit (kPa) |
photo |
Which photosynthesis rate should stomata respond to? Defaults to 'BOTH', i.e. the minimum of Vcmax and Jmax limited rates. |
energybalance |
If TRUE (Default = FALSE), calculates leaf temperature from energy balance
(and its effects on photosynthesis as well as leaf transpiration), using |
C4 |
If TRUE, uses the C4 photosynthesis routine ( |
Tair |
Air temperature (deg C) |
Wind |
Wind speed (m s-1) (only used if energybalance=TRUE) |
Wleaf |
Leaf width (m) (only used if energybalance=TRUE) |
StomatalRatio |
The stomatal ratio (see |
LeafAbs |
Leaf absorptance (see |
... |
All other parameters are passed to |
This model finds the Ci that maximizes A - lambda*E (Cowan & Farquhar 1977, see also Medlyn et al. 2011). The new function FARAO2 is a much simpler (and probably more stable) implementation, based on Buckley et al. 2014 (P,C&E). Both functions are provided, as FARAO has a few more options than FARAO2, at the moment.
Remko Duursma
Buckley, T.N., Martorell, S., Diaz-Espejo, A., Tomas, M., Medrano, H., 2014. Is stomatal conductance optimized over both time and space in plant crowns? A field test in grapevine (Vitis vinifera). Plant Cell Environ doi:10.1111/pce.12343
Cowan, I. and G.D. Farquhar. 1977. Stomatal function in relation to leaf metabolism and environment. Symposia of the Society for Experimental Biology. 31:471-505.
Medlyn, B.E., R.A. Duursma, D. Eamus, D.S. Ellsworth, I.C. Prentice, C.V.M. Barton, K.Y. Crous, P. De Angelis, M. Freeman and L. Wingate. 2011. Reconciling the optimal and empirical approaches to modelling stomatal conductance. Global Change Biology. 17:2134-2144.
Calculates the Ci at the transition points between Ac & Aj (point 1), and Aj and Ap (point 2). The latter is not NA only when TPU was estimated (and estimable), see fitaci
, argument fitTPU
.
findCiTransition(object, ...)
findCiTransition(object, ...)
object |
Either an object returned by |
... |
Further arguments passed to the |
This function is also used by fitaci
, the results are stored in elements Ci_transition
and Ci_transition2
.
Fits the Farquhar-Berry-von Caemmerer model of photosynthesis to measurements of
photosynthesis and intercellular concentration (Ci). Estimates Jmax, Vcmax, Rd
and their standard errors. A simple plotting method is also included, as well as the function
fitacis
which quickly fits multiple A-Ci curves (see its help page). Temperature
dependencies of the parameters are taken into account following Medlyn et al. (2002), see
Photosyn
for more details.
fitaci( data, varnames = list(ALEAF = "Photo", Tleaf = "Tleaf", Ci = "Ci", PPFD = "PARi", Rd = "Rd"), Tcorrect = TRUE, Patm = 100, citransition = NULL, quiet = FALSE, startValgrid = TRUE, fitmethod = c("default", "bilinear", "onepoint"), algorithm = "default", fitTPU = FALSE, alphag = 0, useRd = FALSE, PPFD = NULL, Tleaf = NULL, alpha = 0.24, theta = 0.85, gmeso = NULL, EaV = 82620.87, EdVC = 0, delsC = 645.1013, EaJ = 39676.89, EdVJ = 2e+05, delsJ = 641.3615, GammaStar = NULL, Km = NULL, id = NULL, ... ) ## S3 method for class 'acifit' plot( x, what = c("data", "model", "none"), xlim = NULL, ylim = NULL, whichA = c("Ac", "Aj", "Amin", "Ap"), add = FALSE, pch = 19, addzeroline = TRUE, addlegend = !add, legendbty = "o", transitionpoint = TRUE, linecols = c("black", "blue", "red"), lwd = c(1, 2), lty = 1, ... )
fitaci( data, varnames = list(ALEAF = "Photo", Tleaf = "Tleaf", Ci = "Ci", PPFD = "PARi", Rd = "Rd"), Tcorrect = TRUE, Patm = 100, citransition = NULL, quiet = FALSE, startValgrid = TRUE, fitmethod = c("default", "bilinear", "onepoint"), algorithm = "default", fitTPU = FALSE, alphag = 0, useRd = FALSE, PPFD = NULL, Tleaf = NULL, alpha = 0.24, theta = 0.85, gmeso = NULL, EaV = 82620.87, EdVC = 0, delsC = 645.1013, EaJ = 39676.89, EdVJ = 2e+05, delsJ = 641.3615, GammaStar = NULL, Km = NULL, id = NULL, ... ) ## S3 method for class 'acifit' plot( x, what = c("data", "model", "none"), xlim = NULL, ylim = NULL, whichA = c("Ac", "Aj", "Amin", "Ap"), add = FALSE, pch = 19, addzeroline = TRUE, addlegend = !add, legendbty = "o", transitionpoint = TRUE, linecols = c("black", "blue", "red"), lwd = c(1, 2), lty = 1, ... )
data |
Dataframe with Ci, Photo, Tleaf, PPFD (the last two are optional). For |
varnames |
List of names of variables in the dataset (see Details). |
Tcorrect |
If TRUE, Vcmax and Jmax are corrected to 25C. Otherwise, Vcmax and Jmax are estimated at measurement temperature. Warning : since package version 1.4, the default parameters have been adjusted (see Details). |
Patm |
Atmospheric pressure (kPa) |
citransition |
If provided, fits the Vcmax and Jmax limited regions separately (see Details). |
quiet |
If TRUE, no messages are written to the screen. |
startValgrid |
If TRUE (the default), uses a fine grid of starting values to increase the chance of finding a solution. |
fitmethod |
Method to fit the A-Ci curve. Either 'default' (Duursma 2015), 'bilinear' (See Details), or 'onepoint' (De Kauwe et al. 2016). |
algorithm |
Passed to |
fitTPU |
Logical (default FALSE). Attempt to fit TPU limitation (fitmethod set to 'bilinear' automatically if used). See Details. |
alphag |
When estimating TPU limitation (with |
useRd |
If Rd provided in data, and useRd=TRUE (default is FALSE), uses measured Rd in fit. Otherwise it is estimated from the fit to the A-Ci curve. |
PPFD |
Photosynthetic photon flux density ('PAR') (mu mol m-2 s-1) |
Tleaf |
Leaf temperature (degrees C) |
alpha |
Quantum yield of electron transport (mol mol-1) |
theta |
Shape of light response curve. |
gmeso |
Mesophyll conductance (mol m-2 s-1 bar-1). If not NULL (the default), Vcmax and Jmax are chloroplastic rates. |
EaV , EdVC , delsC
|
Vcmax temperature response parameters |
EaJ , EdVJ , delsJ
|
Jmax temperature response parameters |
Km , GammaStar
|
Optionally, provide Michaelis-Menten coefficient for Farquhar model, and Gammastar. If not provided, they are calculated with a built-in function of leaf temperature. |
id |
Names of variables (quoted, can be a vector) in the original dataset to be stored
in the result. Most useful when using |
... |
Further arguments (ignored at the moment). |
x |
For plot.acifit, an object returned by |
what |
The default is to plot both the data and the model fit, or specify 'data' or 'model' to plot one of them, or 'none' for neither (only the plot region is set up) |
xlim |
Limits for the X axis, if left blank estimated from data |
ylim |
Limits for the Y axis, if left blank estimated from data |
whichA |
By default all photosynthetic rates are plotted (Aj=Jmax-limited (blue), Ac=Vcmax-limited (red), Hyperbolic minimum (black)), TPU-limited rate (Ap, if estimated in the fit). Or, specify one or two of them. |
add |
If TRUE, adds to the current plot |
pch |
The plotting symbol for the data |
addzeroline |
If TRUE, the default, adds a dashed line at y=0 |
addlegend |
If TRUE, adds a legend (by default does not add a legend if add=TRUE) |
legendbty |
Box type for the legend, passed to argument bty in |
transitionpoint |
For plot.acifit, whether to plot a symbol at the transition point. |
linecols |
Vector of three colours for the lines (limiting rate, Ac, Aj), if one value provided it is used for all three. |
lwd |
Line widths, can be a vector of length 2 (first element for Ac and Aj, second one for the limiting rate). |
lty |
Line type (only for Amin - the limiting rate). |
The default method to fit A-Ci curves (set by
fitmethod="default"
) uses non-linear regression to fit the A-Ci curve. No assumptions
are made on which part of the curve is Vcmax or Jmax limited. Normally, all three parameters
are estimated: Jmax, Vcmax and Rd, unless Rd is provided as measured (when useRd=TRUE
,
and Rd is contained in the data). This is the method as described by Duursma (2015, Plos One).
The 'bilinear' method to fit A-Ci curves (set by fitmethod="bilinear"
) linearizes
the Vcmax and Jmax-limited regions, and applies linear regression twice to estimate first
Vcmax and Rd, and then Jmax (using Rd estimated from the Vcmax-limited region). The transition
point is found as the one which gives the best overall fit to the data (i.e. all possible
transitions are tried out, similar to Gu et al. 2010, PCE). The advantage of this method is that
it always returns parameter estimates, so it should be used in cases where the default
method fails. Be aware, though, that the default method fails mostly when the curve contains
bad data (so check your data before believing the fitted parameters).
When citransition
is set, it splits the data into a Vcmax-limited (where Ci < citransition),
and Jmax-limited region (Ci > citransition). Both parameters are then estimated separately for
each region (Rd is estimated only for the Vcmax-limited region). Note that the actual
transition point as shown in the standard plot of the fitted A-Ci curve may be quite different
from that provided, since the fitting method simply decides which part of the dataset to use
for which limitation, it does not constrain the actual estimated transition point directly.
See the example below. If fitmethod="default"
, it applies non-linear regression to
both parts of the data, and when fitmethod="bilinear", it uses linear regression on the
linearized photosynthesis rate. Results will differ between the two methods (slightly).
The 'onepoint' fitting method is a very simple estimation of Vcmax and Jmax for every point
in the dataset, simply by inverting the photosynthesis equation. See De Kauwe et al. (2016)
for details. The output will give the original data with Vcmax and Jmax added (note you can
set Tcorrect
as usual!). For increased reliability, this method only works if
dark respiration (Rd) is included in the data (useRd
is set automatically when
setting fitmethod='one-point'
). This method is not recommended for full A-Ci curves,
but rather for spot gas exchange measurements, when a simple estimate of Vcmax or Jmax
is needed, for example when separating stomatal and non-stomatal drought effects on
photosynthesis (Zhou et al. 2013, AgForMet). The user will have to decide whether the Vcmax
or Jmax rates are used in further analyses. This fitting method can not be used in fitacis
,
because Vcmax and Jmax are already estimated for each point in the dataset.
Optionally, the fitaci
function estimates the triose-phosphate
utilization (TPU) rate. The TPU can act as another limitation on photosynthesis, and can be
recognized by a 'flattening out' of the A-Ci curve at high Ci. When fitTPU=TRUE
, the
fitting method used will always be 'bilinear'. The TPU is estimated by trying out whether the
fit improves when the last n points of the curve are TPU-limited (where n=1,2,...). When TPU is
estimated, it is possible (though rare) that no points are Jmax-limited (in which case estimated
Jmax will be NA). A minimum of two points is always reserved for the estimate of Vcmax and Rd.
An additional parameter (alphag
) can be set that affects the behaviour at high Ci (see
Ellsworth et al. 2015 for details, and also Photosyn
). See examples.
When Tcorrect=TRUE
(the default), Jmax and Vcmax
are re-scaled to 25C, using the temperature response parameters provided (but Rd is always
at measurement temperature). When Tcorrect=FALSE
, estimates of all parameters are at
measurement temperature. If TPU is fit, it is never corrected for temperature. Important
parameters to the fit are GammaStar and Km, both of which are calculated from leaf temperature
using standard formulations. Alternatively, they can be provided as known inputs. Warning :
since package version 1.4, the default parameters have been adjusted. The new parameter values
(EaV, EdVJ, delSJ, etc.) were based on a comprehensive literature review. See
vignette("new_T_responses")
or the article on remkoduursma.github.io/plantecophys.
It is possible to provide an estimate of the mesophyll
conductance as input (gmeso
), in which case the fitted Vcmax and Jmax are to be interpreted
as chloroplastic rates. When using gmeso, it is recommended to use the 'default' fitting
method (which will use the Ethier&Livingston equations inside Photosyn
). It is also
implemented with the 'bilinear' method but it requires more testing (and seems to give
some strange results). When gmeso is set to a relatively low value, the resulting fit
may be quite strange.
The A-Ci curve parameters depend on the values of a number
of other parameters. For Jmax, PPFD is needed in order to express it as the asymptote. If
PPFD is not provided in the dataset, it is assumed to equal 1800 mu mol m-2 s-1 (in which
case a warning is printed). It is possible to either provide PPFD as a variable in the
dataset (with the default name 'PARi', which can be changed), or as an argument to
the fitaci
directly.
The default plot of the fit is constructed
with plot.acifit
, see Examples below. When plotting the fit, the A-Ci curve
is simulated using the Aci
function, with leaf temperature (Tleaf) and PPFD
set to the mean value for the dataset. The coefficients estimated in the fit
(Vcmax, Jmax, and usually Rd) are extracted with coef
. The summary of the fit is
the same as the 'print' method, that is myfit
will give the same output as
summary(myfit)
(where myfit
is an object returned by fitaci
).
Because fitaci returns the fitted nls
object, more details on statistics of
the fit can be extracted with standard tools. The Examples below shows the use of the
nlstools to extract many details of the fit at once. The fit also includes the
root mean squared error (RMSE), which can be extracted as myfit$RMSE
. This
is a useful metric to compare the different fitting methods.
The fitted object contains two functions
that reproduce the fitted curve exactly. Suppose your object is called 'myfit', then
myfit$Photosyn(200)
will give the fitted rate of photosynthesis at a Ci of 200.
The inverse, calculating the Ci where some rate of photosynthesis is achieved, can be done with
myfit$Ci(10)
(find the Ci where net photosynthesis is ten). The (fitted!) CO2
compensation point can then be calculated with : myfit$Ci(0)
.
Note that atmospheric pressure (Patm) is taken into account, assuming the original data are in molar units (Ci in mu mol mol-1, or ppm). During the fit, Ci is converted to mu bar, and Km and Gammastar are recalculated accounting for the effects of Patm on the partial pressure of oxygen. When plotting the fit, though, molar units are shown on the X-axis. Thus, you should get (nearly) the same fitted curve when Patm was set to a value lower than 100kPa, but the fitted Vcmax and Jmax will be higher. This is because at low Patm, photosynthetic capacity has to be higher to achieve the same measured photosynthesis rate.
A list of class 'acifit', with the following components:
A dataframe with the original data, including the measured photosynthetic rate (Ameas), the fitted photosynthetic rate (Amodel), Jmax and Vcmax-limited gross rates (Aj, Ac), TPU-limited rate (Ap), dark respiration (Rd), leaf temperature (Tleaf), chloroplastic CO2 (Cc), PPFD, atmospheric pressure (Patm), and 'original Ci, i.e. the Ci used as input (which is different from the Ci used in fitting if Patm was not set to 100kPa)
Contains the parameter estimates and their approximate standard errors
The object returned by nls
, and contains more detail on
the quality of the fit
whether the temperature correction was applied (logical)
A copy of the Photosyn
function with the arguments adjusted for
the current fit. That is, Vcmax, Jmax and Rd are set to those estimated in the fit, and Tleaf and
PPFD are set to the mean value in the dataset. All other parameters that were set in fitaci are
also used (e.g. temperature dependency parameters, TPU, etc.).
As Photosyn, except the opposite: calculate the Ci where some rate of net photosynthesis is achieved.
The Ci at which photosynthesis transitions from Vcmax to Jmax limited photosynthesis.
The Ci at which photosynthesis transitions from Jmax to TPU limitation. Set to NA is either TPU was not estimated, or it could not be estimated from the data.
Logical - was Rd provided as measured input?
The value for GammaStar, either calculated or provided to the fit.
he value for Km, either calculated or provided to the fit.
Was Km provided as input? (If FALSE, it was calculated from Tleaf)
Was GammaStar provided as input? (If FALSE, it was calculated from Tleaf)
The fitmethod uses, either default or bilinear
The input citransition (NA if it was not provided as input)
The mesophyll conductance used in the fit (NA if it was not set)
Was TPU fit?
The value of alphag used in estimating TPU.
The Root-mean squared error, calculated as sqrt(sum((Ameas-Amodel)^2))
.
The data returned in the 'df' slot are ordered by Ci, but in rare cases the original order of the data contains information; 'runorder' is the order in which the data were provided.
Duursma, R.A., 2015. Plantecophys - An R Package for Analysing and Modelling Leaf Gas Exchange Data. PLoS ONE 10, e0143346. doi:10.1371/journal.pone.0143346
De Kauwe, M. G. et al. 2016. A test of the 'one-point method' for estimating maximum carboxylation capacity from field-measured, light-saturated photosynthesis. New Phytol 210, 1130-1144.
## Not run: # Fit an A-Ci curve on a dataframe that contains Ci, Photo and optionally Tleaf and PPFD. # Here, we use the built-in example dataset 'acidata1'. f <- fitaci(acidata1) # Note that the default behaviour is to correct Vcmax and Jmax for temperature, # so the estimated values are at 25C. To turn this off: f2 <- fitaci(acidata1, Tcorrect=FALSE) # To use different T response parameters (see ?Photosyn), f3 <- fitaci(acidata1, Tcorrect=TRUE, EaV=25000) # Make a standard plot plot(f) # Look at a summary of the fit summary(f) # Extract coefficients only coef(f) # The object 'f' also contains the original data with predictions. # Here, Amodel are the modelled (fitted) values, Ameas are the measured values. with(f$df, plot(Amodel, Ameas)) abline(0,1) # The fitted values can also be extracted with the fitted() function: fitted(f) # The non-linear regression (nls) fit is stored as well, summary(f$nlsfit) # Many more details can be extracted with the nlstools package library(nlstools) overview(f$nlsfit) # The curve generator is stored as f$Photosyn: # Calculate photosynthesis at some value for Ci, using estimated # parameters and mean Tleaf, PPFD for the dataset. f$Photosyn(Ci=820) # Photosynthetic rate at the transition point: f$Photosyn(Ci=f$Ci_transition)$ALEAF # Set the transition point; this will fit Vcmax and Jmax separately. Note that the *actual* # transition is quite different from that provided, this is perfectly fine : # in this case Jmax is estimated from the latter 3 points only (Ci>800), but the actual # transition point is at ca. 400ppm. g <- fitaci(acidata1, citransition=800) plot(g) g$Ci_transition # Use measured Rd instead of estimating it from the A-Ci curve. # The Rd measurement must be added to the dataset used in fitting, # and you must set useRd=TRUE. acidata1$Rd <- 2 f2 <- fitaci(acidata1, useRd=TRUE) f2 # Fit TPU limitation ftpu <- fitaci(acidata1, fitTPU=TRUE, PPFD=1800, Tcorrect=TRUE) plot(ftpu) ## End(Not run)
## Not run: # Fit an A-Ci curve on a dataframe that contains Ci, Photo and optionally Tleaf and PPFD. # Here, we use the built-in example dataset 'acidata1'. f <- fitaci(acidata1) # Note that the default behaviour is to correct Vcmax and Jmax for temperature, # so the estimated values are at 25C. To turn this off: f2 <- fitaci(acidata1, Tcorrect=FALSE) # To use different T response parameters (see ?Photosyn), f3 <- fitaci(acidata1, Tcorrect=TRUE, EaV=25000) # Make a standard plot plot(f) # Look at a summary of the fit summary(f) # Extract coefficients only coef(f) # The object 'f' also contains the original data with predictions. # Here, Amodel are the modelled (fitted) values, Ameas are the measured values. with(f$df, plot(Amodel, Ameas)) abline(0,1) # The fitted values can also be extracted with the fitted() function: fitted(f) # The non-linear regression (nls) fit is stored as well, summary(f$nlsfit) # Many more details can be extracted with the nlstools package library(nlstools) overview(f$nlsfit) # The curve generator is stored as f$Photosyn: # Calculate photosynthesis at some value for Ci, using estimated # parameters and mean Tleaf, PPFD for the dataset. f$Photosyn(Ci=820) # Photosynthetic rate at the transition point: f$Photosyn(Ci=f$Ci_transition)$ALEAF # Set the transition point; this will fit Vcmax and Jmax separately. Note that the *actual* # transition is quite different from that provided, this is perfectly fine : # in this case Jmax is estimated from the latter 3 points only (Ci>800), but the actual # transition point is at ca. 400ppm. g <- fitaci(acidata1, citransition=800) plot(g) g$Ci_transition # Use measured Rd instead of estimating it from the A-Ci curve. # The Rd measurement must be added to the dataset used in fitting, # and you must set useRd=TRUE. acidata1$Rd <- 2 f2 <- fitaci(acidata1, useRd=TRUE) f2 # Fit TPU limitation ftpu <- fitaci(acidata1, fitTPU=TRUE, PPFD=1800, Tcorrect=TRUE) plot(ftpu) ## End(Not run)
A convenient function to fit many curves at once, by calling fitaci
for
every group in the dataset. The data provided must include a variable that uniquely identifies each A-Ci curve.
fitacis( data, group, fitmethod = c("default", "bilinear"), progressbar = TRUE, quiet = FALSE, id = NULL, ... ) ## S3 method for class 'acifits' plot( x, how = c("manyplots", "oneplot"), highlight = NULL, ylim = NULL, xlim = NULL, add = FALSE, what = c("model", "data", "none"), colour_by_id = FALSE, id_legend = TRUE, linecol = "grey", linecol_highlight = "black", lty = 1, ... )
fitacis( data, group, fitmethod = c("default", "bilinear"), progressbar = TRUE, quiet = FALSE, id = NULL, ... ) ## S3 method for class 'acifits' plot( x, how = c("manyplots", "oneplot"), highlight = NULL, ylim = NULL, xlim = NULL, add = FALSE, what = c("model", "data", "none"), colour_by_id = FALSE, id_legend = TRUE, linecol = "grey", linecol_highlight = "black", lty = 1, ... )
data |
Dataframe with Ci, Photo, Tleaf, PPFD (the last two are optional). For |
group |
The name of the grouping variable in the dataframe (an A-Ci curve will be fit for each group separately). |
fitmethod |
Method to fit the A-Ci curve. Either 'default' (Duursma 2015), or 'bilinear'. See Details. |
progressbar |
Display a progress bar (default is TRUE). |
quiet |
If TRUE, no messages are written to the screen. |
id |
Names of variables (quoted, can be a vector) in the original dataset to return as part of the coef() statement. Useful for keeping track of species names, treatment levels, etc. See Details and Examples. |
... |
Further arguments passed to |
x |
For |
how |
If 'manyplots', produces a single plot for each A-Ci curve. If 'oneplot' overlays all of them. |
highlight |
If a name of a curve is given (check names(object), where object is returned by acifits), all curves are plotted in grey, with the highlighted one on top. |
xlim , ylim
|
The X and Y axis limits. |
add |
If TRUE, adds the plots to a current plot. |
what |
What to plot, either 'model' (the fitted curve), 'data' or 'none'. See examples. |
colour_by_id |
If TRUE, uses the 'id' argument to colour the curves in the standard plot (only works when |
id_legend |
If |
linecol |
Colour(s) to use for the non-highlighted curves (can be a vector). |
linecol_highlight |
Colour to use for the 'highlighted' curve. |
lty |
Line type(s), can be a vector (one for each level of the factor, will be recycled). |
Troubleshooting - When using the default fitting method (see fitaci
), it is common that
some curves cannot be fit. Usually this indicates that the curve is poor quality and should not be used to
estimate photosynthetic capacity, but there are exceptions. The fitacis
function now refits the
non-fitting curves with the 'bilinear' method (see fitaci
), which will always return parameter estimates
(for better or worse).
Summarizing and plotting - Like fitaci
, the batch utility fitacis
also has a standard
plotting method. By default, it will make a single plot for every curve that you fit (thus generating many plots).
Alternatively, use the setting how="oneplot"
(see Examples below) for a single plot. The fitted
coefficients are extracted with coef
, which gives a dataframe where each row represents
a fitted curve (the grouping label is also included).
Adding identifying variables - after fitting multiple curves, the most logical next step is to
analyze the coefficient by some categorical variable (species, treatment, location). You can use the
id
argument to store variables from the original dataset in the output. It is important that the
'id' variables take only one value per fitted curve, if this is not the case only the first value of the
curve will be stored (this will be rarely useful). See examples.
Duursma, R.A., 2015. Plantecophys - An R Package for Analysing and Modelling Leaf Gas Exchange Data. PLoS ONE 10, e0143346. doi:10.1371/journal.pone.0143346
## Not run: # Fit many curves (using an example dataset) # The bilinear method is much faster, but compare using 'default'! fits <- fitacis(manyacidat, "Curve", fitmethod="bilinear") with(coef(fits), plot(Vcmax, Jmax)) # The resulting object is a list, with each component an object as returned by fitaci # So, we can extract one curve: fits[[1]] plot(fits[[1]]) # Plot all curves in separate figures with plot(fits) # Or, in one plot: plot(fits, how="oneplot") # Note that parameters can be passed to plot.acifit. For example, plot(fits, how="oneplot", what="data", col="blue") plot(fits, how="oneplot", add=TRUE, what="model", lwd=c(1,1)) # Other elements can be summarized with sapply. For example, look at the RMSE: rmses <- sapply(fits, "[[", "RMSE") plot(rmses, type='h', ylab="RMSE", xlab="Curve nr") # And plot the worst-fitting curve: plot(fits[[which.max(rmses)]]) # It is very straightforward to summarize the coefficients by a factor variable # that was contained in the original data. In manyacidat, there is a factor variable # 'treatment'. # We first have to refit the curves, using the 'id' argument: fits <- fitacis(manyacidat, "Curve", fitmethod="bilinear", id="treatment") # And now use this to plot Vcmax by treatment. boxplot(Vcmax ~ treatment, data=coef(fits), ylim=c(0,130)) # As of package version 1.4-2, you can also use the id variable for colouring curves, # when plotting all fitted curves in one plot. # Set colours to be used. Also note that the 'id' variable has to be a factor, # colours will be set in order of the levels of the factor. # Set palette of colours: palette(rainbow(8)) # Use colours, add legend. plot(fits, how="oneplot", colour_by_id = TRUE, id_legend=TRUE) ## End(Not run)
## Not run: # Fit many curves (using an example dataset) # The bilinear method is much faster, but compare using 'default'! fits <- fitacis(manyacidat, "Curve", fitmethod="bilinear") with(coef(fits), plot(Vcmax, Jmax)) # The resulting object is a list, with each component an object as returned by fitaci # So, we can extract one curve: fits[[1]] plot(fits[[1]]) # Plot all curves in separate figures with plot(fits) # Or, in one plot: plot(fits, how="oneplot") # Note that parameters can be passed to plot.acifit. For example, plot(fits, how="oneplot", what="data", col="blue") plot(fits, how="oneplot", add=TRUE, what="model", lwd=c(1,1)) # Other elements can be summarized with sapply. For example, look at the RMSE: rmses <- sapply(fits, "[[", "RMSE") plot(rmses, type='h', ylab="RMSE", xlab="Curve nr") # And plot the worst-fitting curve: plot(fits[[which.max(rmses)]]) # It is very straightforward to summarize the coefficients by a factor variable # that was contained in the original data. In manyacidat, there is a factor variable # 'treatment'. # We first have to refit the curves, using the 'id' argument: fits <- fitacis(manyacidat, "Curve", fitmethod="bilinear", id="treatment") # And now use this to plot Vcmax by treatment. boxplot(Vcmax ~ treatment, data=coef(fits), ylim=c(0,130)) # As of package version 1.4-2, you can also use the id variable for colouring curves, # when plotting all fitted curves in one plot. # Set colours to be used. Also note that the 'id' variable has to be a factor, # colours will be set in order of the levels of the factor. # Set palette of colours: palette(rainbow(8)) # Use colours, add legend. plot(fits, how="oneplot", colour_by_id = TRUE, id_legend=TRUE) ## End(Not run)
Fits one of three versions of the Ball-Berry type stomatal conductance models to observations of stomatal conductance (gs), photosynthesis (A), atmospheric CO2 concentration (Ca) and vapour pressure deficit (VPD).
fitBB( data, varnames = list(ALEAF = "Photo", GS = "Cond", VPD = "VpdL", Ca = "CO2S", RH = "RH"), gsmodel = c("BBOpti", "BBLeuning", "BallBerry", "BBOptiFull"), fitg0 = FALSE, D0 = NULL )
fitBB( data, varnames = list(ALEAF = "Photo", GS = "Cond", VPD = "VpdL", Ca = "CO2S", RH = "RH"), gsmodel = c("BBOpti", "BBLeuning", "BallBerry", "BBOptiFull"), fitg0 = FALSE, D0 = NULL )
data |
Input dataframe, containing all variables needed to fit the model. |
varnames |
List of names of variables in the input dataframe. Relative humidity (RH) is only needed when the original Ball-Berry model is to be fit. |
gsmodel |
One of BBOpti (Medlyn et al. 2011), BBLeuning (Leuning 1995), BallBerry (Ball et al. 1987), or BBOptiFull (Medlyn et al. 2011 but with an extra parameter gk, see Duursma et al. 2013) |
fitg0 |
If TRUE, also fits the intercept term (g0, the 'residual conductance'). Default is FALSE. |
D0 |
If provided, fixes D0 for the BBLeuning model. Otherwise is estimated by the data. |
Note that unlike in some publications (e.g. Leuning et al. 1995), the models fit here do not include the CO2 compensation point. This correction may be necessary but can be added by the user (by replacing Ca with the corrected term).
Note that all models use atmospheric CO2 concentration (Ca) instead of, as sometimes argued, intercellular CO2 concentration (Ci). Using the latter makes these models far more difficult to use in practice, and we have found no benefit of using Ci instead of Ca (and Ca arises from an optimization argument, see Medlyn et al. 2011). The idea that we should use Ci because 'stomata sense Ci, not Ca' is probably not valid (or at least, not sufficient), and note that Ci plays a central role in the steady-state solution to stomatal conductance anyway (see Photosyn
).
To fit the Ball-Berry models for each group in a dataframe, for example species, see the fitBBs
function.
A list with several components, most notably fit
, the object returned by nls
. If the user needs more information on the goodness of fit etc, please further analyze this object. For example, use the broom package for quick summaries. Or use confint
to calculate confidence intervals on the fitted parameters.
Ball, J.T., Woodrow, I.E., Berry, J.A., 1987. A model predicting stomatal conductance and its contribution to the control of photosynthesis under different environmental conditions., in: Biggins, J. (Ed.), Progress in Photosynthesis Research. Martinus-Nijhoff Publishers, Dordrecht, the Netherlands, pp. 221-224.
Leuning, R. 1995. A critical-appraisal of a combined stomatal-photosynthesis model for C-3 plants. Plant Cell and Environment. 18:339-355.
Medlyn, B.E., R.A. Duursma, D. Eamus, D.S. Ellsworth, I.C. Prentice, C.V.M. Barton, K.Y. Crous, P. De Angelis, M. Freeman and L. Wingate. 2011. Reconciling the optimal and empirical approaches to modelling stomatal conductance. Global Change Biology. 17:2134-2144.
Duursma, R.A., Payton, P., Bange, M.P., Broughton, K.J., Smith, R.A., Medlyn, B.E., Tissue, D.T., 2013. Near-optimal response of instantaneous transpiration efficiency to vapour pressure deficit, temperature and [CO2] in cotton (Gossypium hirsutum L.). Agricultural and Forest Meteorology 168, 168-176. doi:10.1016/j.agrformet.2012.09.005
## Not run: # If 'mydfr' is a dataframe with 'Photo', 'Cond', 'VpdL' and 'CO2S', you can do: myfit <- fitBB(mydfr, gsmodel = "BBOpti") # Coefficients and a message: myfit # Coefficients only coef(myfit) # If you have a species variable, and would like to fit the model for each species, # use fitBBs (see its help page ?fitBBs) myfits <- fitBBs(mydfr, "species") ## End(Not run)
## Not run: # If 'mydfr' is a dataframe with 'Photo', 'Cond', 'VpdL' and 'CO2S', you can do: myfit <- fitBB(mydfr, gsmodel = "BBOpti") # Coefficients and a message: myfit # Coefficients only coef(myfit) # If you have a species variable, and would like to fit the model for each species, # use fitBBs (see its help page ?fitBBs) myfits <- fitBBs(mydfr, "species") ## End(Not run)
A batch utility for the fitBB
function, to fit the model for each group in a dataframe.
fitBBs(data, group, ...)
fitBBs(data, group, ...)
data |
Input dataframe, containing all variables needed to fit the model. |
group |
Name of the grouping variable in the dataframe (quoted), the model will be fit for each group defined by this variable. |
... |
Further parameters passed to |
## Not run: # If you have a factor variable in your dataset called 'species', and you # want to fit the Ball-Berry model for each of the species: myfits <- fitBBs(mydata, "species", model="BallBerry") # A dataframe with coefficients is returned by coef() coef(myfits) ## End(Not run)
## Not run: # If you have a factor variable in your dataset called 'species', and you # want to fit the Ball-Berry model for each of the species: myfits <- fitBBs(mydata, "species", model="BallBerry") # A dataframe with coefficients is returned by coef() coef(myfits) ## End(Not run)
CO2 response of leaf photosynthesis, as measured with a Licor6400, for multiple leaves.
An identifier for the A-Ci curve (28 curves in total, 13-14 points per curve)
Intercellular CO2 concentration (ppm)
Net photosynthesis rate (mu mol m-2 s-1)
Leaf temperature (deg C)
Photosynthetic photon flux density (mu mol m-2 s-1)
A coupled photosynthesis - stomatal conductance model, based on the Farquhar model of photosynthesis, and a Ball-Berry type model of stomatal conductance. Includes options for temperature sensitivity of photosynthetic parameters, day respiration (optionally calculated from leaf temperature), and mesophyll conductance.
Photosyn( VPD = 1.5, Ca = 400, PPFD = 1500, Tleaf = 25, Patm = 100, RH = NULL, gsmodel = c("BBOpti", "BBLeuning", "BallBerry", "BBdefine"), g1 = 4, g0 = 0, gk = 0.5, vpdmin = 0.5, D0 = 5, GS = NULL, BBmult = NULL, alpha = 0.24, theta = 0.85, Jmax = 100, Vcmax = 50, gmeso = NULL, TPU = 1000, alphag = 0, Rd0 = 0.92, Q10 = 1.92, Rd = NULL, TrefR = 25, Rdayfrac = 1, EaV = 58550, EdVC = 2e+05, delsC = 629.26, EaJ = 29680, EdVJ = 2e+05, delsJ = 631.88, GammaStar = NULL, Km = NULL, Ci = NULL, Tcorrect = TRUE, returnParsOnly = FALSE, whichA = c("Ah", "Amin", "Ac", "Aj") ) Aci(Ci, ...)
Photosyn( VPD = 1.5, Ca = 400, PPFD = 1500, Tleaf = 25, Patm = 100, RH = NULL, gsmodel = c("BBOpti", "BBLeuning", "BallBerry", "BBdefine"), g1 = 4, g0 = 0, gk = 0.5, vpdmin = 0.5, D0 = 5, GS = NULL, BBmult = NULL, alpha = 0.24, theta = 0.85, Jmax = 100, Vcmax = 50, gmeso = NULL, TPU = 1000, alphag = 0, Rd0 = 0.92, Q10 = 1.92, Rd = NULL, TrefR = 25, Rdayfrac = 1, EaV = 58550, EdVC = 2e+05, delsC = 629.26, EaJ = 29680, EdVJ = 2e+05, delsJ = 631.88, GammaStar = NULL, Km = NULL, Ci = NULL, Tcorrect = TRUE, returnParsOnly = FALSE, whichA = c("Ah", "Amin", "Ac", "Aj") ) Aci(Ci, ...)
VPD |
Vapour pressure deficit (kPa) (not needed when RH provided) |
Ca |
Atmospheric CO2 concentration (ppm) |
PPFD |
Photosynthetic photon flux density ('PAR') (mu mol m-2 s-1) |
Tleaf |
Leaf temperature (degrees C) |
Patm |
Atmospheric pressure (kPa) (but see warning below!) |
RH |
Relative humidity (in %) (not needed when VPD provided) |
gsmodel |
One of BBOpti (Medlyn et al. 2011), BBLeuning (Leuning 1995), BallBerry (Ball et al. 1987), or BBdefine (for full control; see Details). |
g0 , g1
|
Parameters of Ball-Berry type stomatal conductance models. |
gk |
Optional, exponent of VPD in gs model (Duursma et al. 2013) |
vpdmin |
Below vpdmin, VPD=vpdmin, to avoid very high gs. |
D0 |
Parameter for the BBLeuning stomatal conductance model. |
GS |
Optionally, stomatal conductance (to H2O). If provided, |
BBmult |
Optional, only used when |
alpha |
Quantum yield of electron transport (mol mol-1) |
theta |
Shape of light response curve. |
Jmax |
Maximum rate of electron transport at 25 degrees C (mu mol m-2 s-1) |
Vcmax |
Maximum carboxylation rate at 25 degrees C (mu mol m-2 s-1) |
gmeso |
Mesophyll conductance (mol m-2 s-1). If not NULL (the default), Vcmax and Jmax are chloroplastic rates. |
TPU |
Triose-phosphate utilization rate (mu mol m-2 s-1); optional. |
alphag |
Fraction of glycolate not returned to the chloroplast; parameter in TPU-limited photosynthesis (optional, only to be used when TPU is provided) (0 - 1) |
Rd0 |
Day respiration rate at reference temperature ( |
Q10 |
Temperature sensitivity of Rd. |
Rd |
Day respiration rate (mu mol m-2 s-1), optional (if not provided, calculated from Tleaf, Rd0, Q10 and TrefR). Must be a positive value (an error occurs when a negative value is supplied). |
TrefR |
Reference temperature for Rd (Celcius). |
Rdayfrac |
Ratio of Rd in the light vs. in the dark. |
EaV , EdVC , delsC
|
Vcmax temperature response parameters |
EaJ , EdVJ , delsJ
|
Jmax temperature response parameters |
Km , GammaStar
|
Optionally, provide Michaelis-Menten coefficient for Farquhar model, and Gammastar. If not provided, they are calculated with a built-in function of leaf temperature. |
Ci |
Optional, intercellular CO2 concentration (ppm). If not provided, calculated via gs model. |
Tcorrect |
If TRUE, corrects input Vcmax and Jmax for actual Tleaf (if FALSE, assumes the provided Vcmax and Jmax are at the Tleaf provided). Warning : since package version 1.4, the default parameters have been adjusted (see Details). |
returnParsOnly |
If TRUE, returns calculated Vcmax,Jmax,Km and GammaStar based on leaf temperature. |
whichA |
Which assimilation rate does gs respond to? |
... |
Further arguments passed to |
The coupled photosynthesis - stomatal conductance model finds the intersection between
the supply of CO2 by diffusion, and the demand for CO2 by photosynthesis. See Farquhar and
Sharkey (1982) for basic description of this type of model, Duursma (2015) for more details
on the implementation in the plantecophys
package, and Duursma et al. (2014) for an
example application (that uses this implementation).
Photosynthesis model and temperature response - The model of Farquhar et al. (1980) is used to estimate the dependence of leaf net photosynthesis rate (ALEAF) on intercellular CO2 concentration (Ci), accounting for all three limitations (electron transport, carboxylation, and TPU limitation). The equations for the temperature response of photosynthetic parameters, including Vcmax, Jmax, Gammastar, and Km follow Medlyn et al. (2002). However, note that the default temperature response parameter values are not taken from Medlyn, and likely will have to be adjusted for your situation. Warning : since package version 1.4, the default parameters have been adjusted. The new parameter values (EaV, EdVJ, delSJ, etc.) were based on a comprehensive literature review. See vignette("new_T_responses") or the article on remkoduursma.github.io/plantecophys.
#' By default, the Photosyn
function returns the hyperbolic minimum of Vcmax and
Jmax-limited photosynthetic rates, as well as the hyperbolic minimum of Jmax-limited and
TPU-limited rates. This approach avoids the discontinuity at the transition between the
two rates (thus allowing use of Photosyn
and fitaci
in optimization or
fitting routines). The individual rates (Ac, Aj and Ap) are also returned as output
should they be needed. Note that those rates are output as gross photosynthetic rates
(leaf respiration has to be subtracted to give net leaf photosynthesis).
Coupled leaf gas exchange
When Ci is not provided, Ci is calculated from the intersection between the 'supply' and
'demand', where 'demand' is given by the Farquhar model of photosynthesis (A=f(Ci)), and
supply by the stomatal conductance. The latter is, by default, estimated using the
stomatal conductance model of Medlyn et al. (2011), but two other models are provided
as well (Ball-Berry and Leuning, see gsmodel
argument). Otherwise, stomatal
conductance may be directly provided via the GS
argument.
Stomatal conductance models -
At the moment, three stomatal conductance models are implemented. The 'BBOpti' model
is a slightly more general form of the model of Medlyn et al. 2011 (see Duursma et al.
2013). It is given by (in notation of the parameters and output
variables of Photosyn
),
where gk = 0.5
if stomata behave optimally (cf. Medlyn et al. 2011).
The 'BBLeuning' model is that of Leuning (1995). It is given by,
Note that this model also uses the g1 parameter, but it needs to be set to a much higher value to be comparable in magnitude to the BBOpti model.
The 'BallBerry' model is that of Ball et al. (1987). It is given by,
Where RH is relative humidity. Again, the g1 value is not comparable to that used in the previous two models.
Finally, Photosyn
provides a very flexible Ball-Berry model, where
the multiplier has to be specified by the user, the model is:
This interface can be used to quickly simulate what happens if stomata do not respond to humidity at all (in which case BBmult=g1/Ca, or ca. 5/400), or to use the Tuzet model of stomatal conductance inside another model that provides the leaf water potential function.
For the full numerical solution to the Cowan-Farquhar optimization, use
the FARAO
function (which was used in Medlyn et al. 2011 for
comparison to the approximation there presented). See Duursma (2015) for more details.
Mesophyll conductance -
If the mesophyll conductance gmeso
is provided as an input, it is assumed
that Vcmax and Jmax are the chloroplastic rates, and leaf photosynthesis is
calculated following the equations from Ethier and Livingston (2004). When very
low mesophyll conductance rates are input, the model may return poor solutions
(and sometimes they may not exist).
Simulating A-Ci curves
If Ci is provided as an input, this function calculates an A-Ci curve. For
example, you may do Photosyn(Ci=300)
, for which the function Aci
is included as a shortcut (Aci(300)
).
Atmospheric pressure -
A correction for atmospheric pressure (Patm) is implemented in fitaci
,
but not in Photosyn. In fitaci
, the necessary corrections are applied
so that estimated Vcmax and Jmax are expressed at standard pressure (Patm=100kPa).
In Photosyn, however, the corrections are much more complicated and tend to be very
small, because effects of Patm on partial pressures are largely offset by increases
in diffusivity (Terashima et al. 1995, Gale 1973).
Note that Patm is an argument to the Photosyn function, but it only affects calculations of Km and GammaStar (as used by fitaci), and transpiration rate. Setting only Patm does not correct for atmospheric pressure effects on photosynthesis rates.
The simulation of limitation of the photosynthetic rate to triose-phosphate
utilization follows details in Ellsworth et al. (2015), their Eq. 7. Note that
the parameter alphag
is set to zero by default.
Returns a dataframe.
Duursma, R.A., Payton, P., Bange, M.P., Broughton, K.J., Smith, R.A., Medlyn, B.E., Tissue, D. T., 2013, Near-optimal response of instantaneous transpiration efficiency to vapour pressure deficit, temperature and [CO2] in cotton (Gossypium hirsutum L.). Agricultural and Forest Meteorology 168 : 168 - 176.
Duursma, R.A., Barton, C.V.M., Lin, Y.-S., Medlyn, B.E., Eamus, D., Tissue, D.T., Ellsworth, D.S., McMurtrie, R.E., 2014. The peaked response of transpiration rate to vapour pressure deficit in field conditions can be explained by the temperature optimum of photosynthesis. Agricultural and Forest Meteorology 189 - 190, 2-10. doi:10.1016/j.agrformet.2013.12.007
Duursma, R.A., 2015. Plantecophys - An R Package for Analysing and Modelling Leaf Gas Exchange Data. PLoS ONE 10, e0143346. doi:10.1371/journal.pone.0143346
Ellsworth, D.S., Crous, K.Y., Lambers, H., Cooke, J., 2015. Phosphorus recycling in photorespiration maintains high photosynthetic capacity in woody species. Plant Cell Environ 38, 1142-1156. doi:10.1111/pce.12468
Ethier, G. and N. Livingston. 2004. On the need to incorporate sensitivity to CO2 transfer conductance into the Farquhar von Caemmerer Berry leaf photosynthesis model. Plant, Cell & Environment. 27:137-153.
Farquhar, G.D., S. Caemmerer and J.A. Berry. 1980. A biochemical model of photosynthetic CO2 assimilation in leaves of C3 species. Planta. 149:78-90.
Farquhar, G. D., & Sharkey, T. D. (1982). Stomatal conductance and photosynthesis. Annual review of plant physiology, 33(1), 317-345.
Gale, J., 1972. Availability of Carbon Dioxide for Photosynthesis at High Altitudes: Theoretical Considerations. Ecology 53, 494-497. doi:10.2307/1934239
Leuning, R. 1995. A critical-appraisal of a combined stomatal-photosynthesis model for C-3 plants. Plant Cell and Environment. 18:339-355.
Medlyn, B.E., E. Dreyer, D. Ellsworth, M. Forstreuter, P.C. Harley, M.U.F. Kirschbaum, X. Le Roux, P. Montpied, J. Strassemeyer, A. Walcroft, K. Wang and D. Loustau. 2002. Temperature response of parameters of a biochemically based model of photosynthesis. II. A review of experimental data. Plant Cell and Environment. 25:1167-1179.
Medlyn, B.E., R.A. Duursma, D. Eamus, D.S. Ellsworth, I.C. Prentice, C.V.M. Barton, K.Y. Crous, P. De Angelis, M. Freeman and L. Wingate. 2011. Reconciling the optimal and empirical approaches to modelling stomatal conductance. Global Change Biology. 17:2134-2144.
Terashima, I., Masuzawa, T., Ohba, H., Yokoi, Y., 1995. Is photosynthesis suppressed at higher elevations due to low CO2 pressure? Ecology 76, 2663-2668. doi:10.2307/2265838
# Run the coupled leaf gas exchange model, set only a couple of parameters Photosyn(VPD=2, g1=4, Ca=500) # It is easy to set multiple values for inputs (and these can be mixed with single inputs); r <- Photosyn(VPD=seq(0.5, 4, length=25), Vcmax=50, Jmax=100) with(r, plot(VPD, ALEAF, type='l')) # Set the mesophyll conductance run1 <- Photosyn(PPFD=seq(50,1000,length=25), gmeso=0.15, Vcmax=40, Jmax=85) with(run1, plot(PPFD, GS, type='l')) # Run A-Ci curve only (provide Ci instead of calculating it). arun1 <- Aci(Ci=seq(50, 1200, length=101), Vcmax=40, Jmax=85) arun2 <- Aci(Ci=seq(50, 1200, length=101), Vcmax=30, Jmax=70) with(arun1, plot(Ci, ALEAF, type='l')) with(arun2, points(Ci, ALEAF, type='l', lty=5)) # Find the intersection between supply of CO2 and demand for CO2 (cf. Farquhar and Sharkey 1982). # Set some parameters gs <- 0.2 # stomatal conductance to H2O Ca <- 400 # ambient CO2 gctogw <- 1.57 # conversion gc <- gs / gctogw # stomatal conductance to CO2 # Demand curve (Farquhar model) p <- Aci(seq(60,500,length=101), Ca=400) # Provide stomatal conductance as input, gives intersection point. g <- Photosyn(GS=gs, Ca=Ca) # Intersection point visualized par(yaxs="i") with(p, plot(Ci, ALEAF, type='l', ylim=c(0,max(ALEAF)))) with(g, points(Ci, ALEAF, pch=19, col="red")) abline(gc * Ca, -gc, lty=5) legend("topleft", c(expression("Demand:"~~A==f(C[i])), expression("Supply:"~~A==g[c]*(C[a]-C[i])), "Operating point"), lty=c(1,5,-1),pch=c(-1,-1,19), col=c("black","black","red"), bty='n', cex=0.9)
# Run the coupled leaf gas exchange model, set only a couple of parameters Photosyn(VPD=2, g1=4, Ca=500) # It is easy to set multiple values for inputs (and these can be mixed with single inputs); r <- Photosyn(VPD=seq(0.5, 4, length=25), Vcmax=50, Jmax=100) with(r, plot(VPD, ALEAF, type='l')) # Set the mesophyll conductance run1 <- Photosyn(PPFD=seq(50,1000,length=25), gmeso=0.15, Vcmax=40, Jmax=85) with(run1, plot(PPFD, GS, type='l')) # Run A-Ci curve only (provide Ci instead of calculating it). arun1 <- Aci(Ci=seq(50, 1200, length=101), Vcmax=40, Jmax=85) arun2 <- Aci(Ci=seq(50, 1200, length=101), Vcmax=30, Jmax=70) with(arun1, plot(Ci, ALEAF, type='l')) with(arun2, points(Ci, ALEAF, type='l', lty=5)) # Find the intersection between supply of CO2 and demand for CO2 (cf. Farquhar and Sharkey 1982). # Set some parameters gs <- 0.2 # stomatal conductance to H2O Ca <- 400 # ambient CO2 gctogw <- 1.57 # conversion gc <- gs / gctogw # stomatal conductance to CO2 # Demand curve (Farquhar model) p <- Aci(seq(60,500,length=101), Ca=400) # Provide stomatal conductance as input, gives intersection point. g <- Photosyn(GS=gs, Ca=Ca) # Intersection point visualized par(yaxs="i") with(p, plot(Ci, ALEAF, type='l', ylim=c(0,max(ALEAF)))) with(g, points(Ci, ALEAF, pch=19, col="red")) abline(gc * Ca, -gc, lty=5) legend("topleft", c(expression("Demand:"~~A==f(C[i])), expression("Supply:"~~A==g[c]*(C[a]-C[i])), "Operating point"), lty=c(1,5,-1),pch=c(-1,-1,19), col=c("black","black","red"), bty='n', cex=0.9)
As Photosyn
, but calculates the leaf temperature based on the leaf's energy balance. Including sensible and long-wave heat loss, latent heat loss from evaporation, and solar radiation input.
#'Warning:Do not provide GS as an input to PhotosynEB
directly; the results will not be as expected (filed as issue #27)
PhotosynEB( Tair = 25, VPD = 1.5, Wind = 2, Wleaf = 0.02, StomatalRatio = 1, LeafAbs = 0.86, RH = NULL, ... ) FindTleaf(gs, Tair, ...)
PhotosynEB( Tair = 25, VPD = 1.5, Wind = 2, Wleaf = 0.02, StomatalRatio = 1, LeafAbs = 0.86, RH = NULL, ... ) FindTleaf(gs, Tair, ...)
Tair |
Air temperature (C) |
VPD |
The vapour pressure deficit of the air (i.e. not the leaf-to-air VPD) (kPa). |
Wind |
Wind speed (m s-1) |
Wleaf |
Leaf width (m) |
StomatalRatio |
The stomatal ratio (cf. Licor6400 terminology), if it is 1, leaves have stomata only on one side (hypostomatous), 2 for leaves with stomata on both sides (amphistomatous). |
LeafAbs |
Leaf absorptance of solar radiation (0-1). |
RH |
The relative humidity of the air (i.e. not calculated with leaf temperature) (in percent). |
... |
Further parameters passed to |
gs |
For |
Uses the Penman-Monteith equation to calculate the leaf transpiration rate, and finds Tleaf by solving the leaf energy balance iteratively. In the solution, it is accounted for that stomatal conductance (via the dependence of photosynthesis on Tleaf) and net radiation depend on Tleaf.
Also included is the function FindTleaf
, which calculates the leaf temperature if the stomatal conductance is known. The limitation to this function is that input stomatal conductance (gs) is not vectorized, i.e. you can only provide one value at a time.
An implementation of the coupled photosynthesis - stomatal conductance model, using the Tuzet et al. (2003) model of stomatal conductance. Accepts all arguments of Photosyn
(except gsmodel
, of course).
PhotosynTuzet(g1 = 8, Ca = 400, psis = 0, kl = 2, sf = 3, psif = -2, ...)
PhotosynTuzet(g1 = 8, Ca = 400, psis = 0, kl = 2, sf = 3, psif = -2, ...)
g1 |
The slope parameter. Note that the default value should be much higher than that used in the Medlyn et al. (2011) model to give comparable predictions. |
Ca |
Atmospheric CO2 concentration. |
psis |
Soil water potential (MPa). Note that soil-to-root hydraulic conductance is not implemented. |
kl |
Leaf-specific hydraulic conductance (mmol m-2 s-1 MPa-1) |
sf |
Shape parameter (-) of sigmoidal function of leaf water potential (see Tuzet et al. 2003) |
psif |
Leaf water potential at which stomatal conductance is 50% of maximum (MPa). |
... |
All other arguments in |
A collection of functions to convert between relative humidity (RH) (%),
vapour pressure deficit (VPD) (kPa),
dew point temperature, and leaf- or air temperature-based VPD or RH. To convert from
relative humidity to VPD,
use the RHtoVPD
function, use VPDtoRH
for the other way around. The water
vapor saturation pressure is
calculated with esat
. Use DewtoVPD
to
convert from dewpoint temperature to VPD. The functions VPDleafToAir
and VPDairToLeaf
convert VPD from a leaf temperature to an air-temperature basis and vice versa. The
functions RHleafToAir
a RHairToLeaf
do the same for relative humidity.
RHtoVPD(RH, TdegC, Pa = 101) VPDtoRH(VPD, TdegC, Pa = 101) esat(TdegC, Pa = 101) VPDtoDew(VPD, TdegC, Pa = 101) DewtoVPD(Tdew, TdegC, Pa = 101) VPDleafToAir(VPD, Tleaf, Tair, Pa = 101) VPDairToLeaf(VPD, Tair, Tleaf, Pa = 101) RHleafToAir(RH, Tleaf, Tair, Pa = 101) RHairToLeaf(RH, Tair, Tleaf, Pa = 101)
RHtoVPD(RH, TdegC, Pa = 101) VPDtoRH(VPD, TdegC, Pa = 101) esat(TdegC, Pa = 101) VPDtoDew(VPD, TdegC, Pa = 101) DewtoVPD(Tdew, TdegC, Pa = 101) VPDleafToAir(VPD, Tleaf, Tair, Pa = 101) VPDairToLeaf(VPD, Tair, Tleaf, Pa = 101) RHleafToAir(RH, Tleaf, Tair, Pa = 101) RHairToLeaf(RH, Tair, Tleaf, Pa = 101)
RH |
Relative humidity (%) |
TdegC |
Temperature (degrees C) (either leaf or air) |
Pa |
Atmospheric pressure (kPa) |
VPD |
Vapour pressure deficit (kPa) |
Tdew |
Dewpoint temperature (degrees C) |
Tleaf |
Leaf temperature (degrees C) |
Tair |
Air temperature (degrees C) |
The function describing saturated vapor pressure with temperature is taken from Jones (1992). All other calculations follow directly from the standard definitions, for which Jones (1992) may also be consulted.
Remko Duursma
Jones, H.G. 1992. Plants and microclimate: a quantitative approach to environmental plant physiology. 2nd Edition., 2nd Edn. Cambridge University Press, Cambridge. 428 p.