Title: | Joint Modeling of Traditional and Environmental DNA Survey Data in a Bayesian Framework |
---|---|
Description: | Models integrate environmental DNA (eDNA) detection data and traditional survey data to jointly estimate species catch rate (see package vignette: <https://ednajoint.netlify.app/>). Models can be used with count data via traditional survey methods (i.e., trapping, electrofishing, visual) and replicated eDNA detection/nondetection data via polymerase chain reaction (i.e., PCR or qPCR) from multiple survey locations. Estimated parameters include probability of a false positive eDNA detection, a site-level covariates that scale the sensitivity of eDNA surveys relative to traditional surveys, and catchability coefficients for traditional gear types. Models are implemented with a Bayesian framework (Markov chain Monte Carlo) using the 'Stan' probabilistic programming language. |
Authors: | Abigail G. Keller [aut, cre], Ryan P. Kelly [ctb], Chitra M. Saraswati [rev], Saras M. Windecker [rev] |
Maintainer: | Abigail G. Keller <[email protected]> |
License: | GPL-3 |
Version: | 0.2 |
Built: | 2024-12-13 06:14:52 UTC |
Source: | https://github.com/ropensci/eDNAjoint |
Models integrate environmental DNA (eDNA) detection data and traditional survey data to jointly estimate species catch rate (see Package Vignette). Models can be used with count data via traditional survey methods (i.e., trapping, electrofishing, visual) and replicated eDNA detection/nondetection data via polymerase chain reaction (i.e., PCR or qPCR) from multiple survey locations. Estimated parameters include probability of a false positive eDNA detection, a site-level covariates that scale the sensitivity of eDNA surveys relative to traditional surveys, and catchability coefficients for traditional gear types. Models are implemented with a Bayesian framework (Markov chain Monte Carlo) using the 'Stan' probabilistic programming language.
Maintainer: Abigail G. Keller [email protected]
Other contributors:
Ryan P. Kelly [email protected] [contributor]
Chitra M. Saraswati [reviewer]
Saras M. Windecker [reviewer]
Stan Development Team (NA). RStan: the R interface to Stan. https://mc-stan.org
Useful links:
Report bugs at https://github.com/ropensci/eDNAjoint/issues
This function calculates the number of survey effort units to necessary detect species presence using median estimated parameter values from jointModel(). Detecting species presence is defined as producing at least one true positive eDNA detection or catching at least one individual. See more examples in the Package Vignette.
detectionCalculate(modelfit, mu, cov.val = NULL, probability = 0.9, qPCR.N = 3)
detectionCalculate(modelfit, mu, cov.val = NULL, probability = 0.9, qPCR.N = 3)
modelfit |
An object of class |
mu |
A numeric vector of species densities/capture rates. If multiple traditional gear types are represented in the model, mu is the catch rate of gear type 1. |
cov.val |
A numeric vector indicating the values of site-level covariates to use for prediction. Default is NULL. |
probability |
A numeric value indicating the probability of detecting presence. The default is 0.9. |
qPCR.N |
An integer indicating the number of qPCR replicates per eDNA sample. The default is 3. |
A summary table of survey efforts necessary to detect species presence, given mu, for each survey type.
Before fitting the model, this function checks to ensure that the function is possible given the inputs. These checks include:
Input model fit is an object of class 'stanfit'.
Input mu is a numeric vector.
Input probability is a univariate numeric value.
If model fit contains alpha, cov.val must be provided.
Input cov.val is numeric.
Input cov.val is the same length as the number of estimated covariates.
Input model fit has converged (i.e. no divergent transitions after warm-up).
If any of these checks fail, the function returns an error message.
# Ex. 1: Calculating necessary effort for detection with site-level # covariates # Load data data(gobyData) # Fit a model including 'Filter_time' and 'Salinity' site-level covariates fit.cov <- jointModel(data = gobyData, cov = c('Filter_time','Salinity'), family = "poisson", p10priors = c(1,20), q = FALSE, multicore = FALSE) # Calculate at the mean covariate values # (covariates are standardized, so mean = 0) detectionCalculate(fit.cov$model, mu = seq(from = 0.1, to = 1, by = 0.1), cov.val = c(0,0), qPCR.N = 3) # Calculate mu_critical at salinity 0.5 z-scores greater than the mean detectionCalculate(fit.cov$model, mu = seq(from = 0.1, to = 1, by = 0.1), cov.val = c(0,0.5), qPCR.N = 3) # Ex. 2: Calculating necessary effort for detection with multiple traditional # gear types # Load data data(greencrabData) # Fit a model with no site-level covariates fit.q <- jointModel(data = greencrabData, cov = NULL, family = "negbin", p10priors = c(1,20), q = TRUE, multicore = FALSE) # Calculate detectionCalculate(fit.q$model, mu = seq(from = 0.1, to = 1, by = 0.1), cov.val = NULL, qPCR.N = 3) # Change probability of detecting presence to 0.95 detectionCalculate(fit.q$model, mu = 0.1, cov.val = NULL, probability = 0.95, qPCR.N = 3)
# Ex. 1: Calculating necessary effort for detection with site-level # covariates # Load data data(gobyData) # Fit a model including 'Filter_time' and 'Salinity' site-level covariates fit.cov <- jointModel(data = gobyData, cov = c('Filter_time','Salinity'), family = "poisson", p10priors = c(1,20), q = FALSE, multicore = FALSE) # Calculate at the mean covariate values # (covariates are standardized, so mean = 0) detectionCalculate(fit.cov$model, mu = seq(from = 0.1, to = 1, by = 0.1), cov.val = c(0,0), qPCR.N = 3) # Calculate mu_critical at salinity 0.5 z-scores greater than the mean detectionCalculate(fit.cov$model, mu = seq(from = 0.1, to = 1, by = 0.1), cov.val = c(0,0.5), qPCR.N = 3) # Ex. 2: Calculating necessary effort for detection with multiple traditional # gear types # Load data data(greencrabData) # Fit a model with no site-level covariates fit.q <- jointModel(data = greencrabData, cov = NULL, family = "negbin", p10priors = c(1,20), q = TRUE, multicore = FALSE) # Calculate detectionCalculate(fit.q$model, mu = seq(from = 0.1, to = 1, by = 0.1), cov.val = NULL, qPCR.N = 3) # Change probability of detecting presence to 0.95 detectionCalculate(fit.q$model, mu = 0.1, cov.val = NULL, probability = 0.95, qPCR.N = 3)
This function plots the number of survey effort units to necessary detect species presence, calculated using median estimated parameter values from jointModel(). Detecting species presence is defined as producing at least one true positive eDNA detection or catching at least one individual. See more examples in the Package Vignette.
detectionPlot( modelfit, mu.min, mu.max, cov.val = NULL, probability = 0.9, qPCR.N = 3 )
detectionPlot( modelfit, mu.min, mu.max, cov.val = NULL, probability = 0.9, qPCR.N = 3 )
modelfit |
An object of class |
mu.min |
A value indicating the minimum expected species catch rate for plotting. If multiple traditional gear types are represented in the model, mu is the catch rate of gear type 1. |
mu.max |
A value indicating the maximum expected species catch rate for plotting. If multiple traditional gear types are represented in the model, mu is the catch rate of gear type 1. |
cov.val |
A numeric vector indicating the values of site-level covariates to use for prediction. Default is NULL. |
probability |
A numeric value indicating the probability of detecting presence. The default is 0.9. |
qPCR.N |
An integer indicating the number of qPCR replicates per eDNA sample. The default is 3. |
A plot displaying survey efforts necessary to detect species presence, given mu, for each survey type.
Before fitting the model, this function checks to ensure that the function is possible given the inputs. These checks include:
Input model fit is an object of class 'stanfit'.
Input mu.min is a numeric value greater than 0.
Input mu.max is a numeric value.
If model fit contains alpha, cov.val must be provided.
Input cov.val is numeric.
Input cov.val is the same length as the number of estimated covariates.
Input probability is a univariate numeric value.
Input model fit has converged (i.e. no divergent transitions after warm-up).
If any of these checks fail, the function returns an error message.
# Ex. 1: Calculating necessary effort for detection with site-level # covariates # Load data data(gobyData) # Fit a model including 'Filter_time' and 'Salinity' site-level covariates fit.cov <- jointModel(data = gobyData, cov = c('Filter_time','Salinity'), family = "poisson", p10priors = c(1,20), q = FALSE, multicore = FALSE) # Plot at the mean covariate values (covariates are standardized, so mean=0) detectionPlot(fit.cov$model, mu.min = 0.1, mu.max = 1, cov.val = c(0,0), qPCR.N = 3) # Calculate mu_critical at salinity 0.5 z-scores greater than the mean detectionPlot(fit.cov$model, mu.min = 0.1, mu.max = 1, cov.val = c(0,0.5), qPCR.N = 3) # Ex. 2: Calculating necessary effort for detection with multiple # traditional gear types # Load data data(greencrabData) # Fit a model with no site-level covariates fit.q <- jointModel(data = greencrabData, cov = NULL, family = "negbin", p10priors = c(1,20), q = TRUE, multicore = FALSE) # Calculate detectionPlot(fit.q$model, mu.min = 0.1, mu.max = 1, cov.val = NULL, qPCR.N = 3) # Change probability of detecting presence to 0.95 detectionPlot(fit.q$model, mu.min = 0.1, mu.max = 1, cov.val = NULL, probability = 0.95, qPCR.N = 3)
# Ex. 1: Calculating necessary effort for detection with site-level # covariates # Load data data(gobyData) # Fit a model including 'Filter_time' and 'Salinity' site-level covariates fit.cov <- jointModel(data = gobyData, cov = c('Filter_time','Salinity'), family = "poisson", p10priors = c(1,20), q = FALSE, multicore = FALSE) # Plot at the mean covariate values (covariates are standardized, so mean=0) detectionPlot(fit.cov$model, mu.min = 0.1, mu.max = 1, cov.val = c(0,0), qPCR.N = 3) # Calculate mu_critical at salinity 0.5 z-scores greater than the mean detectionPlot(fit.cov$model, mu.min = 0.1, mu.max = 1, cov.val = c(0,0.5), qPCR.N = 3) # Ex. 2: Calculating necessary effort for detection with multiple # traditional gear types # Load data data(greencrabData) # Fit a model with no site-level covariates fit.q <- jointModel(data = greencrabData, cov = NULL, family = "negbin", p10priors = c(1,20), q = TRUE, multicore = FALSE) # Calculate detectionPlot(fit.q$model, mu.min = 0.1, mu.max = 1, cov.val = NULL, qPCR.N = 3) # Change probability of detecting presence to 0.95 detectionPlot(fit.q$model, mu.min = 0.1, mu.max = 1, cov.val = NULL, probability = 0.95, qPCR.N = 3)
gobyData
gobyData
gobyData
A list with four matrices representing eDNA sampling data (qPCR.N and qPCR.K), seine sampling data (count), and site-level covariate data (site.cov).
Total number of eDNA qPCR replicates at each site (row) and eDNA sample replicate (column). Data includes 39 total sites and a maximum of 22 eDNA sample replicates. NA indicates that fewer eDNA samples were collected than the maximum at a site.
Total number of positive eDNA qPCR detections at each site (row) and eDNA sample replicate (column). Data includes 39 total sites and a maximum of 22 eDNA sample replicates. NA indicates that fewer eDNA samples were collected than the maximum at a site.
Count of goby individuals in seine samples at each site (row) and seine sample replicate (column). Data includes 39 total sites and a maximum of 22 seine replicates. NA indicates that fewer seine samples were collected than the maximum at a site.
Data representing site-level covariates at each site (row). Data includes mean salinity at a site ('Salinity'), mean time to filter eDNA samples ('Filter_time'), density of other fish species ('Other_fishes'), size of habitat ('Hab_size'), and presence of vegetation ('Veg'). All non-integer covariate data is standardized.
https://datadryad.org/stash/dataset/doi:10.5061/dryad.6rs23
Schmelzle, M.C. and Kinziger, A.P. (2016). Using occupancy modelling to compare environmental DNA to traditional field methods for regional-scale monitoring of an endangered aquatic species. Molecular Ecology Resources. 16(4): 895-908.
greencrabData
greencrabData
greencrabData
A list with four matrices representing eDNA sampling data (qPCR.N and qPCR.K) and trap sampling data (count and count.type).
Total number of eDNA qPCR replicates at each site (row) and eDNA sample replicate (column). Data includes 20 total sites and 5 eDNA sample replicates.
Total number of positive eDNA qPCR detections at each site (row) and eDNA sample replicate (column). Data includes 20 total sites and 5 eDNA sample replicates.
Count of green crab individuals in trap samples at each site (row) and trap sample replicate (column). Data includes 20 total sites and a maximum of 420 trap replicates. NA indicates that fewer trap samples were collected than the maximum at a site.
Integer indicating the traditional gear type used at each site (row) and trap sample replicate (column). '1' refers to Fukui traps, and '2' refers to Minnow traps. Data includes 20 total sites and a maximum of 420 trap replicates. NA indicates that fewer trap samples were collected than the maximum at a site.
doi:10.6084/m9.figshare.15117102.v2
Keller, A.G., Grason, E.W., McDonald, P.S., Ramon-Laca, A., Kelly, R.P. (2022). Tracking an invasion front with environmental DNA. Ecological Applications. 32(4): e2561. https://doi.org/10.1002/eap.2561
This function implements a Bayesian model that integrates data from paired
eDNA and traditional surveys, as described in Keller et al. (2022)
<doi.org/10.1002/eap.2561>. The model estimates parameters including
the expected species catch rate and the probability of false positive eDNA
detection. This function allows for optional model variations, like inclusion
of site-level covariates that scale the sensitivity of eDNA sampling relative
to traditional sampling, as well as estimation of gear scaling coefficients
that scales the relative catchability of multiple traditional gear types.
Model is implemented using Bayesian inference using the rstan
package,
which uses Hamiltonian Monte Carlo to simulate the posterior distributions.
See more examples in the
Package
Vignette.
jointModel( data, cov = NULL, family = "poisson", p10priors = c(1, 20), q = FALSE, phipriors = NULL, multicore = FALSE, initial_values = NULL, n.chain = 4, n.iter.burn = 500, n.iter.sample = 2500, thin = 1, adapt_delta = 0.9, verbose = TRUE, seed = NULL )
jointModel( data, cov = NULL, family = "poisson", p10priors = c(1, 20), q = FALSE, phipriors = NULL, multicore = FALSE, initial_values = NULL, n.chain = 4, n.iter.burn = 500, n.iter.sample = 2500, thin = 1, adapt_delta = 0.9, verbose = TRUE, seed = NULL )
data |
A list containing data necessary for model fitting. Valid tags
are |
cov |
A character vector indicating the site-level covariates to include in the model. Default value is NULL. |
family |
The distribution class used to model traditional survey count data. Options include poisson ('poisson'), negative binomial ('negbin'), and gamma ('gamma'). Default value is 'poisson'. |
p10priors |
A numeric vector indicating beta distribution hyperparameters (alpha, beta) used as the prior distribution for the eDNA false positive probability (p10). Default vector is c(1,20). |
q |
A logical value indicating whether to estimate gear scaling coefficients, q, for traditional survey gear types (TRUE) or to not estimate gear scaling coefficients, q, for traditional survey gear types (FALSE). Default value is FALSE. |
phipriors |
A numeric vector indicating gamma distribution hyperparameters (shape, rate) used as the prior distribution for phi, the overdispersion in the negative binomial distribution for traditional survey gear data. Used when family = 'negbin.' If family = 'negbin', then default vector is c(0.25,0.25), otherwise, default is NULL. |
multicore |
A logical value indicating whether to parallelize chains with multiple cores. Default is FALSE. |
initial_values |
A list of lists of initial values to use in MCMC. The length should equal the number of MCMC chains. Initial values can be provided for parameters: beta, p10 (log-scale), mu, q, alpha. If no initial values are provided, default random values are drawn. |
n.chain |
Number of MCMC chains. Default value is 4. |
n.iter.burn |
Number of warm-up MCMC iterations. Default value is 500. |
n.iter.sample |
Number of sampling MCMC iterations. Default value is 2500. |
thin |
A positive integer specifying the period for saving samples. Default value is 1. |
adapt_delta |
Numeric value between 0 and 1 indicating target average
acceptance probability used in |
verbose |
Logical value controlling the verbosity of output (i.e., warnings, messages, progress bar). Default is TRUE. |
seed |
A positive integer seed used for random number generation in MCMC. Default is NULL, which means the seed is generated from 1 to the maximum integer supported by R. |
A list of:
a model object of class stanfit
returned by rstan::sampling
initial values used in MCMC
Before fitting the model, this function checks to ensure that the model specification is possible given the data files. These checks include:
All tags in data are valid (i.e., include qPCR.N, qPCR.K, count, count.type, and site.cov).
Dimensions of qPCR.N and qPCR.K are equal, and dimensions of count and count.type are equal (if count.type provided).
Number of sites in qPCR and count data are equal.
All data are numeric (i.e., integer or NA).
Empty data cells (NA) match in qPCR.N and qPCR.K and in count and count.type.
family is either 'poisson', 'negbin', or 'gamma'.
p10priors and phipriors (if used) is a vector of two numeric values.
site.cov has same number of rows as qPCR.N and count, if present
site.cov is numeric, if present
cov values match column names in site.cov, if present
If any of these checks fail, the function returns an error message.
# Ex. 1: Implementing the joint model # Load data data(gobyData) # Examine data in list names(gobyData) # Note that the surveyed sites (rows) should match in all data dim(gobyData$qPCR.N)[1] dim(gobyData$count)[1] # Fit a basic model with paired eDNA and traditional survey data. # Count data is modeled using a poisson distribution. fit <- jointModel(data = gobyData, family = "poisson", p10priors = c(1,20), multicore = FALSE) # Ex. 2: Implementing the joint model with site-level covariates # With the same data, fit a model including 'Filter_time' and 'Salinity' # site-level covariates # These covariates will scale the sensitivity of eDNA sampling relative to # traditional surveys # Count data is modeled using a poisson distribution. fit.cov <- jointModel(data = gobyData, cov = c('Filter_time','Salinity'), family = "poisson", p10priors = c(1,20), multicore = FALSE) # Ex. 3: Implementing the joint model with multiple traditional gear types # Load data data(greencrabData) # Examine data in list names(greencrabData) # Note that the surveyed sites (rows) should match in all data dim(greencrabData$qPCR.N)[1] dim(greencrabData$count)[1] # Fit a model estimating a gear scaling coefficient for traditional survey # gear types. # This model does not assume all traditional survey methods have the same # catchability. # Count data is modeled using a negative binomial distribution. fit.q <- jointModel(data = greencrabData, cov = NULL, family = "negbin", p10priors = c(1,20), q = TRUE, phipriors = c(0.25,0.25), multicore = FALSE, initial_values = NULL, n.chain = 4, n.iter.burn = 500, n.iter.sample = 2500, thin = 1, adapt_delta = 0.9, verbose = TRUE, seed = 123)
# Ex. 1: Implementing the joint model # Load data data(gobyData) # Examine data in list names(gobyData) # Note that the surveyed sites (rows) should match in all data dim(gobyData$qPCR.N)[1] dim(gobyData$count)[1] # Fit a basic model with paired eDNA and traditional survey data. # Count data is modeled using a poisson distribution. fit <- jointModel(data = gobyData, family = "poisson", p10priors = c(1,20), multicore = FALSE) # Ex. 2: Implementing the joint model with site-level covariates # With the same data, fit a model including 'Filter_time' and 'Salinity' # site-level covariates # These covariates will scale the sensitivity of eDNA sampling relative to # traditional surveys # Count data is modeled using a poisson distribution. fit.cov <- jointModel(data = gobyData, cov = c('Filter_time','Salinity'), family = "poisson", p10priors = c(1,20), multicore = FALSE) # Ex. 3: Implementing the joint model with multiple traditional gear types # Load data data(greencrabData) # Examine data in list names(greencrabData) # Note that the surveyed sites (rows) should match in all data dim(greencrabData$qPCR.N)[1] dim(greencrabData$count)[1] # Fit a model estimating a gear scaling coefficient for traditional survey # gear types. # This model does not assume all traditional survey methods have the same # catchability. # Count data is modeled using a negative binomial distribution. fit.q <- jointModel(data = greencrabData, cov = NULL, family = "negbin", p10priors = c(1,20), q = TRUE, phipriors = c(0.25,0.25), multicore = FALSE, initial_values = NULL, n.chain = 4, n.iter.burn = 500, n.iter.sample = 2500, thin = 1, adapt_delta = 0.9, verbose = TRUE, seed = 123)
This function performs leave one out cross validation of a list of model
fits using functions in the loo
package, as described in Vehtari, Gelman,
and Gabry (2017) doi:10.1007/s11222-016-9696-4. Compare models fit using
jointModel()
or models fits using traditionalModel()
. See more examples
in the Package
Vignette.
jointSelect(modelfits)
jointSelect(modelfits)
modelfits |
A list containing model fits of class |
A matrix of delta elpd (expected log pointwise predictive density)
between model fits. Function is performed using the loo
package.
Before model selection, this function makes the following check:
Input is a list of model fits of class 'stanfit'.
All models compared were fit wither either jointModel()
or all with
traditionalModel().
If any of these checks fail, the function returns an error message.
data(greencrabData) # Fit a model without estimating a gear scaling coefficient for traditional # survey gear types. # This model assumes all traditional survey methods have the same # catchability. # Count data is modeled using a poisson distribution. fit.no.q <- jointModel(data = greencrabData, family = "poisson", p10priors = c(1,20), q = FALSE, multicore = FALSE) # Fit a model estimating a gear scaling coefficient for traditional # survey gear types. # This model does not assume all traditional survey methods have the # same catchability. # Gear type 1 is used as the reference gear type. # Count data is modeled using a negative binomial distribution. fit.q <- jointModel(data = greencrabData, family = "negbin", p10priors = c(1,20), q = TRUE, multicore = FALSE) # Perform model selection jointSelect(modelfits = list(fit.no.q$model, fit.q$model))
data(greencrabData) # Fit a model without estimating a gear scaling coefficient for traditional # survey gear types. # This model assumes all traditional survey methods have the same # catchability. # Count data is modeled using a poisson distribution. fit.no.q <- jointModel(data = greencrabData, family = "poisson", p10priors = c(1,20), q = FALSE, multicore = FALSE) # Fit a model estimating a gear scaling coefficient for traditional # survey gear types. # This model does not assume all traditional survey methods have the # same catchability. # Gear type 1 is used as the reference gear type. # Count data is modeled using a negative binomial distribution. fit.q <- jointModel(data = greencrabData, family = "negbin", p10priors = c(1,20), q = TRUE, multicore = FALSE) # Perform model selection jointSelect(modelfits = list(fit.no.q$model, fit.q$model))
This function summarizes the posterior distributions of specified parameters from a model fit. Summary includes mean, sd, and specified quantiles, as well as effective sample size (n_eff) and Rhat for estimated parameters. See more examples in the Package Vignette.
jointSummarize(modelfit, par = "all", probs = c(0.025, 0.975), digits = 3)
jointSummarize(modelfit, par = "all", probs = c(0.025, 0.975), digits = 3)
modelfit |
An object of class |
par |
A character vector of parameter names. The default is 'all'. |
probs |
A numeric vector of quantiles of interest. The default is c(0.025,0.975). |
digits |
An integer indicating the number of decimal places to round values in summary table. Default value is 3. |
A summary table of parameter estimates.
Before fitting the model, this function checks to ensure that the function is possible given the inputs. These checks include:
Input model fit is an object of class 'stanfit'.
Input probs is a numeric vector.
Input par is a character vector.
Input par are present in fitted model.
Input model fit has converged (i.e. no divergent transitions after warm-up).
If any of these checks fail, the function returns an error message.
data(greencrabData) # Fit a model modelfit <- jointModel(data = greencrabData, family = "negbin", q = TRUE, multicore = FALSE) # Create summary table of all parameters jointSummarize(modelfit$model) # Summarize just 'p10' parameter jointSummarize(modelfit$model, par = "p10", probs = c(0.025, 0.975), digits = 3)
data(greencrabData) # Fit a model modelfit <- jointModel(data = greencrabData, family = "negbin", q = TRUE, multicore = FALSE) # Create summary table of all parameters jointSummarize(modelfit$model) # Summarize just 'p10' parameter jointSummarize(modelfit$model, par = "p10", probs = c(0.025, 0.975), digits = 3)
This function uses the full posterior distributions of parameters estimated
by jointModel()
to calculate mu_critical, or the expected catch rate at
which the probabilities of a false positive eDNA detection and true positive
eDNA detection are equal. See more examples in the
Package
Vignette.
muCritical(modelfit, cov.val = NULL, ci = 0.9)
muCritical(modelfit, cov.val = NULL, ci = 0.9)
modelfit |
An object of class |
cov.val |
A numeric vector indicating the values of site-level covariates to use for prediction. Default is NULL. |
ci |
Credible interval calculated using highest density interval (HDI). Default is 0.9 (i.e., 90% credible interval). |
A list with median mu_critical and lower and upper bounds on the credible interval. If multiple gear types are used, a table of mu_critical and lower and upper credible interval bounds is returned with one column for each gear type.
Before fitting the model, this function checks to ensure that the function is possible given the inputs. These checks include:
Input model fit is an object of class 'stanfit'.
Input credible interval is a univariate numeric value greater than 0 and less than 1.
Input model fit contains p10 parameter.
If model fit contains alpha, cov.val must be provided.
Input cov.val is numeric.
Input cov.val is the same length as the number of estimated covariates.
Input model fit has converged (i.e. no divergent transitions after warm-up).
If any of these checks fail, the function returns an error message.
# Ex. 1: Calculating mu_critical with site-level covariates # Load data data(gobyData) # Fit a model including 'Filter_time' and 'Salinity' site-level covariates fit.cov <- jointModel(data = gobyData, cov = c('Filter_time','Salinity'), family = "poisson", p10priors = c(1,20), q = FALSE, multicore = FALSE) # Calculate mu_critical at the mean covariate values (covariates are # standardized, so mean = 0) muCritical(fit.cov$model, cov.val = c(0,0), ci = 0.9) # Calculate mu_critical at habitat size 0.5 z-scores greater than the mean muCritical(fit.cov$model, cov.val = c(0,0.5), ci = 0.9) # Ex. 2: Calculating mu_critical with multiple traditional gear types # Load data data(greencrabData) # Fit a model with no site-level covariates fit.q <- jointModel(data = greencrabData, cov = NULL, family = "negbin", p10priors = c(1,20), q = TRUE, multicore = FALSE) # Calculate mu_critical muCritical(fit.q$model, cov.val = NULL, ci = 0.9)
# Ex. 1: Calculating mu_critical with site-level covariates # Load data data(gobyData) # Fit a model including 'Filter_time' and 'Salinity' site-level covariates fit.cov <- jointModel(data = gobyData, cov = c('Filter_time','Salinity'), family = "poisson", p10priors = c(1,20), q = FALSE, multicore = FALSE) # Calculate mu_critical at the mean covariate values (covariates are # standardized, so mean = 0) muCritical(fit.cov$model, cov.val = c(0,0), ci = 0.9) # Calculate mu_critical at habitat size 0.5 z-scores greater than the mean muCritical(fit.cov$model, cov.val = c(0,0.5), ci = 0.9) # Ex. 2: Calculating mu_critical with multiple traditional gear types # Load data data(greencrabData) # Fit a model with no site-level covariates fit.q <- jointModel(data = greencrabData, cov = NULL, family = "negbin", p10priors = c(1,20), q = TRUE, multicore = FALSE) # Calculate mu_critical muCritical(fit.q$model, cov.val = NULL, ci = 0.9)
This function implements a Bayesian model that estimates expected species
catch rate using count data from traditional, non eDNA surveys. When
multiple traditional gear types are used, an optional variation allows
estimation of gear scaling coefficients, which scale the catchability of
gear types relative to the expected catch rate of a reference gear type.
Model is implemented using Bayesian inference using the rstan
package,
which uses Hamiltonian Monte Carlo to simulate the posterior distributions.
See more examples in the
Package
Vignette.
traditionalModel( data, family = "poisson", q = FALSE, phipriors = NULL, multicore = FALSE, initial_values = NULL, n.chain = 4, n.iter.burn = 500, n.iter.sample = 2500, thin = 1, adapt_delta = 0.9, verbose = TRUE, seed = NULL )
traditionalModel( data, family = "poisson", q = FALSE, phipriors = NULL, multicore = FALSE, initial_values = NULL, n.chain = 4, n.iter.burn = 500, n.iter.sample = 2500, thin = 1, adapt_delta = 0.9, verbose = TRUE, seed = NULL )
data |
A list containing data necessary for model fitting. Valid tags
are |
family |
The distribution class used to model traditional survey count data. Options include poisson ('poisson'), negative binomial ('negbin'), and gamma ('gamma'). Default value is 'poisson'. |
q |
A logical value indicating whether to estimate gear scaling coefficients, q, for traditional survey gear types (TRUE) or to not estimate gear scaling coefficients, q, for traditional survey gear types (FALSE). Default value is FALSE. |
phipriors |
A numeric vector indicating gamma distribution hyperparameters (shape, rate) used as the prior distribution for phi, the overdispersion in the negative binomial distribution for traditional survey gear data. Used when family = 'negbin.' If family = 'negbin', then default vector is c(0.25,0.25), otherwise, default is NULL. |
multicore |
A logical value indicating whether to parallelize chains with multiple cores. Default is FALSE. |
initial_values |
A list of lists of initial values to use in MCMC. The length should equal the number of MCMC chains. Initial values can be provided for parameters: mu and q. If no initial values are provided, default random values are drawn. |
n.chain |
Number of MCMC chains. Default value is 4. |
n.iter.burn |
Number of warm-up MCMC iterations. Default value is 500. |
n.iter.sample |
Number of sampling MCMC iterations. Default value is 2500. |
thin |
A positive integer specifying the period for saving samples. Default value is 1. |
adapt_delta |
Numeric value between 0 and 1 indicating target average
acceptance probability used in |
verbose |
Logical value controlling the verbosity of output (i.e., warnings, messages, progress bar). Default is TRUE. |
seed |
A positive integer seed used for random number generation in MCMC. Default is NULL, which means the seed is generated from 1 to the maximum integer supported by R. |
A list of:
a model object of class stanfit
returned by rstan::sampling
initial values used in MCMC
Before fitting the model, this function checks to ensure that the model specification is possible given the data files. These checks include:
All tags in data are valid (i.e., include count and count.type).
Number of sites in count and count type data are equal.
All data are numeric (i.e., integer or NA).
Empty data cells (NA) match in count and count.type.
family is 'poisson', 'negbin', or 'gamma'.
phipriors (if used) is a vector of two numeric values.
If any of these checks fail, the function returns an error message.
# Load data data(greencrabData) # Examine data in list # This function uses only traditional survey count data and optionally # the count type data names(greencrabData) # Note that the surveyed sites (rows) should match in the data dim(greencrabData$count)[1] dim(greencrabData$count.type)[1] # Fit a model without estimating a gear scaling coefficient for traditional # survey gear types. # This model assumes all traditional survey methods have the same # catchability. # Count data is modeled using a poisson distribution. fit.no.q <- traditionalModel(data = greencrabData, family = "poisson", q = FALSE, phipriors = NULL, multicore = FALSE, verbose = TRUE) # Fit a model estimating a gear scaling coefficient for traditional survey # gear types. # This model does not assume all traditional survey methods have the same # catchability. # Count data is modeled using a negative binomial distribution. fit.q <- traditionalModel(data = greencrabData, family = "negbin", q = TRUE, phipriors = c(0.25,0.25), multicore = FALSE, initial_values = NULL, n.chain = 4, n.iter.burn = 500, n.iter.sample = 2500, thin = 1, adapt_delta = 0.9, verbose = TRUE, seed = 123)
# Load data data(greencrabData) # Examine data in list # This function uses only traditional survey count data and optionally # the count type data names(greencrabData) # Note that the surveyed sites (rows) should match in the data dim(greencrabData$count)[1] dim(greencrabData$count.type)[1] # Fit a model without estimating a gear scaling coefficient for traditional # survey gear types. # This model assumes all traditional survey methods have the same # catchability. # Count data is modeled using a poisson distribution. fit.no.q <- traditionalModel(data = greencrabData, family = "poisson", q = FALSE, phipriors = NULL, multicore = FALSE, verbose = TRUE) # Fit a model estimating a gear scaling coefficient for traditional survey # gear types. # This model does not assume all traditional survey methods have the same # catchability. # Count data is modeled using a negative binomial distribution. fit.q <- traditionalModel(data = greencrabData, family = "negbin", q = TRUE, phipriors = c(0.25,0.25), multicore = FALSE, initial_values = NULL, n.chain = 4, n.iter.burn = 500, n.iter.sample = 2500, thin = 1, adapt_delta = 0.9, verbose = TRUE, seed = 123)