TMB Documentation
v1.9.11
|
The underlying framework is the same for all cases listed in this section. [ Description of general framework FIXME ]
For models that does not include random effects the calculations can be simplified greatly.
This example shows how standardized residuals can be calculated within the template code and reported back to R using the REPORT
function in TMB.
Assuming that the model parameters have been fitted, and the model object is called obj
, the standardized residuals can now be extracted from the model object usinig the report()
function and inspected for normality as follows:
We now consider situations where the error distribution is continuous but not Gaussian. Residuals that are standard normal distributed given that the model is correct, can be obtained be using the "transformation trick", here illustrated using a model that fits a gamma distribution.
For discrete probability distributions the transformation trick can also be used, but an element of randomization must be added in order to obtain residuals that are truly Gaussian.
Assume that you have a series of observed counts y
and you have fitted some TMB model using a Poisson likelihood, and the predicted values from that model have been reported and saved in a vector called mu
.
Model validation using residuals is considerably more complicated for random effect models. Further information can be found in [] FIXME: not generating reference.
Other names are one step prediction errors, forecast pseudo-residuals, and recursive residuals. These residuals can be computed using the oneStepPredict
function. There are several methods available within this function, and it is the responsibility of the user to ensure that an appropriate method is chosen for a given model.
The following examples of its use are availabe in the tmb_examples/validation
folder.
Example | Description |
---|---|
validation/MVRandomWalkValidation.cpp | Estimate and validate a multivariate random walk model with correlated increments and correlated observations. |
validation/randomwalkvalidation.cpp | Estimate and validate a random walk model with and without drift |
validation/rickervalidation.cpp | Estimate and validate a Ricker model based on data simulated from the logistic map |
An alternative (and faster) method is based on a single sample of the random effects from the their posterior distribution given the data. For state space models we can derive both process- and observation errors from the single sample and the observations, and compare these with the assumptions in the model.
An example can be found at the end of the randomwalkvalidation.R
file in the tmb_examples/validation
folder
FIXME: