This provides a rough indication of the goodness of fit of a multi-state model, by estimating the observed numbers of individuals occupying each state at a series of times, and comparing these with forecasts from the fitted model.
prevalence.msm(x, times=NULL, timezero=NULL, initstates=NULL, covariates="population",
misccovariates="mean", piecewise.times=NULL, piecewise.covariates=NULL,
ci=c("none","normal","bootstrap"), cl=0.95, B=1000, cores=NULL,
interp=c("start","midpoint"), censtime=Inf, subset=NULL, plot=FALSE, ...)
A list of matrices, with components:
Table of observed numbers of individuals in each state at each time
Corresponding percentage of the individuals at risk at each time.
Table of corresponding expected numbers.
Corresponding percentage of the individuals at risk at each time.
Or if ci.boot = TRUE
, the component Expected
is a list
with components estimates
and ci
.
estimates
is a matrix of the expected prevalences, and
ci
is a list of two matrices, containing the confidence limits.
The component
Expected percentages
has a similar format.
A fitted multi-state model produced by msm
.
Series of times at which to compute the observed and expected prevalences of states.
Initial time of the Markov process. Expected values are forecasted from here. Defaults to the minimum of the observation times given in the data.
Optional vector of the same length as the number of states. Gives the numbers of individuals occupying each state at the initial time, to be used for forecasting expected prevalences. The default is those observed in the data. These should add up to the actual number of people in the study at the start.
Covariate values for which to forecast expected
state occupancy. With the default covariates="population"
,
expected prevalences are produced by summing model predictions over
the covariates observed in the original data, for a fair comparison
with the observed prevalences. This may be slow, particularly with
continuous covariates.
Predictions for fixed covariates can be obtained by supplying
covariate values in the standard way, as in
qmatrix.msm
. Therefore if
covariates="population"
is too slow, using the mean observed
values through covariates="mean"
may give a reasonable
approximation.
This argument is ignored if piecewise.times
is specified. If
there are a mixture of time-constant and time-dependent covariates,
then the values for all covariates should be supplied in
piecewise.covariates
.
(Misclassification models only)
Values of covariates on the misclassification probability matrix
for converting expected true to expected misclassified states.
Ignored if covariates="population"
, otherwise
defaults to the mean values of the covariates in the data set.
Times at which piecewise-constant intensities
change. See pmatrix.piecewise.msm
for how
to specify this. Ignored if covariates="population"
.
This is only required for time-inhomogeneous
models specified using explicit time-dependent covariates, and
should not be used for models specified using "pci".
Covariates on which the piecewise-constant
intensities depend. See pmatrix.piecewise.msm
for how
to specify this. Ignored if covariates="population"
.
If "normal"
, then calculate a confidence interval for
the expected prevalences by simulating B
random vectors
from the asymptotic multivariate normal distribution implied by the
maximum likelihood estimates (and covariance matrix) of the log
transition intensities and covariate effects, then calculating the
expected prevalences for each replicate.
If "bootstrap"
then calculate a confidence interval by
non-parametric bootstrap refitting. This is 1-2 orders of magnitude
slower than the "normal"
method, but is expected to be more
accurate. See boot.msm
for more details of
bootstrapping in msm.
If "none"
(the default) then no confidence interval is
calculated.
Width of the symmetric confidence interval, relative to 1
Number of bootstrap replicates
Number of cores to use for bootstrapping using parallel
processing. See boot.msm
for more details.
Suppose an individual was observed in states \(S_{r-1}\) and \(S_r\) at two consecutive times \(t_{r-1}\) and \(t_r\), and we want to estimate 'observed' prevalences at a time \(t\) between \(t_{r-1}\) and \(t_r\).
If interp="start"
, then individuals are assumed to be in
state \(S_{r-1}\) at time \(t\), the same state as they were at \(t_{r-1}\).
If interp="midpoint"
then if \(t <= (t_{r-1} + t_r) / 2\),
the midpoint of \(t_{r-1}\) and \(t_r\), the state at \(t\)
is assumed to be \(S_{r-1}\), otherwise \(S_{r}\). This is
generally more reasonable for "progressive" models.
Adjustment to the observed prevalences to account for limited follow-up in the data.
If the time is greater than censtime
and the
patient has reached an absorbing state, then that subject will be
removed from the risk set. For example, if patients have died but
would only have been observed up to this time, then this avoids
overestimating the proportion of people who are dead at later
times.
This can be supplied as a single value, or as a vector with one
element per subject (after any subset
has been taken), in
the same order as the original data. This vector also only
includes subjects with complete data, thus it excludes for example
subjects with only one observation (thus no observed transitions),
and subjects for whom every observation has missing values.
(Note, to help construct this, the complete data used for the model
fit can be accessed with model.frame(x)
, where x
is the
fitted model object)
This is ignored if it is less than the subject's maximum observation time.
Subset of subjects to calculate observed prevalences for.
Generate a plot of observed against expected
prevalences. See plot.prevalence.msm
Further arguments to pass to plot.prevalence.msm
.
C. H. Jackson chris.jackson@mrc-bsu.cam.ac.uk
The fitted transition probability matrix is used to forecast expected prevalences from the state occupancy at the initial time. To produce the expected number in state \(j\) at time \(t\) after the start, the number of individuals under observation at time \(t\) (including those who have died, but not those lost to follow-up) is multiplied by the product of the proportion of individuals in each state at the initial time and the transition probability matrix in the time interval \(t\). The proportion of individuals in each state at the "initial" time is estimated, if necessary, in the same way as the observed prevalences.
For misclassification models (fitted using an ematrix
), this
aims to assess the fit of the full model for the observed
states. That is, the combined Markov progression model for the true
states and the misclassification model. Thus, expected prevalences of true
states are estimated from the assumed proportion
occupying each state at the initial time using the fitted transition
probabiliy matrix. The vector of expected prevalences of true states
is then multiplied by the fitted misclassification probability matrix
to obtain the expected prevalences of observed states.
For general hidden Markov models, the observed state is taken to be the
predicted underlying state from the Viterbi algorithm
(viterbi.msm
). The goodness of fit of
these states to the underlying Markov model is tested.
In any model, if there are censored states, then these are replaced by imputed values of highest probability from the Viterbi algorithm in order to calculate the observed state prevalences.
For an example of this approach, see Gentleman et al. (1994).
Gentleman, R.C., Lawless, J.F., Lindsey, J.C. and Yan, P. Multi-state Markov models for analysing incomplete disease history data with illustrations for HIV disease. Statistics in Medicine (1994) 13(3): 805--821.
Titman, A.C., Sharples, L. D. Model diagnostics for multi-state models. Statistical Methods in Medical Research (2010) 19(6):621-651.
msm
, summary.msm