Title: | MCMC Sampling from 'TMB' Model Object using 'Stan' |
---|---|
Description: | Enables all 'rstan' functionality for a 'TMB' model object, in particular MCMC sampling and chain visualization. Sampling can be performed with or without Laplace approximation for the random effects. This is demonstrated in Monnahan & Kristensen (2018) <DOI:10.1371/journal.pone.0197954>. |
Authors: | Kasper Kristensen |
Maintainer: | Kasper Kristensen <[email protected]> |
License: | GPL (>= 3) |
Version: | 1.0.91 |
Built: | 2024-12-25 06:59:50 UTC |
Source: | CRAN |
Draw MCMC samples from a TMB model object using Stan
tmbstan( obj, ..., lower = numeric(0), upper = numeric(0), laplace = FALSE, silent = TRUE, debug = FALSE )
tmbstan( obj, ..., lower = numeric(0), upper = numeric(0), laplace = FALSE, silent = TRUE, debug = FALSE )
obj |
TMB model object. |
... |
Passed to |
lower |
Vector of lower parameter bounds. |
upper |
Vector of upper parameter bounds. |
laplace |
Apply the Laplace approximation to |
silent |
Be silent during samling ? |
debug |
Should not be used. |
tmbstan
works for models with or without random effects.
By default a full Bayesian analysis is carried out, i.e. both
parameters and random effects are sampled using MCMC. Models with
random effects will thus have the Laplace approximation disabled. It
is possible to mix the Laplace approximation with MCMC by setting
laplace=TRUE
.
All methods provided by the rstan
package can be applied to a
fitted object. Get a complete list using
methods(class="stanfit")
.
Lower and upper bounds can be set using lower
and upper
.
The bounds can be specified in one of two ways. Either in short
format, i.e. have the same length as obj$par
. Remaining
parameters (the random effects) are set as unbounded in this case.
Otherwise the bounds must be in long format, i.e. have the same
length as the full parameter vector obj$env$par
including the
random effects.
In both cases -Inf
and Inf
are valid components of
lower
and upper
respectively.
Note that initial values must be within the specified bounds.
The function arguments ...
are passed to rstan
's
fitting function, see ?rstan::sampling
.
A few notable arguments are:
chains
The number of chains.
iter
The number of iterations.
init
Initial values for the sampler.
Behaves like rstan
with some additions:
Default is "random"
- see ?stan
.
Special values 0
and "0"
are allowed - see ?stan
.
Additional special characters "par"
and "last.par.best"
are allowed
and will be looked up in the TMB model object.
The value "par"
signifies to start from the defaults of the model object.
If an optimization has been carried out, the intial value "last.par.best"
will start from the MLE.
We also allow to pass a single numeric vector, or a list of numeric vectors. List length must match the number of chains. Vector lengths must match the number of sampled parameters. Names are currently ignored.
Parameters
that do not follow the previous scheme (e.g. characters) are passed on
to rstan
unchanged. If in doubt, use rstan::get_inits
to inspect the
applied initial values.
seed
Random seed.
Object of class stanfit
TMB::runExample("simple") fit <- tmbstan(obj, chains=1) class(fit) ## "stanfit" ## The available methods are methods(class="stanfit") ## Not run: ## Pairs plot pairs(fit, pars=names(obj$par)) ## End(Not run) ## Trace plot traceplot(fit, pars=names(obj$par), inc_warmup=TRUE)
TMB::runExample("simple") fit <- tmbstan(obj, chains=1) class(fit) ## "stanfit" ## The available methods are methods(class="stanfit") ## Not run: ## Pairs plot pairs(fit, pars=names(obj$par)) ## End(Not run) ## Trace plot traceplot(fit, pars=names(obj$par), inc_warmup=TRUE)