Title: | Multi-State Markov and Hidden Markov Models in Continuous Time |
---|---|
Description: | Functions for fitting continuous-time Markov and hidden Markov multi-state models to longitudinal data. Designed for processes observed at arbitrary times in continuous time (panel data) but some other observation schemes are supported. Both Markov transition rates and the hidden Markov output process can be modelled in terms of covariates, which may be constant or piecewise-constant in time. |
Authors: | Christopher Jackson [aut, cre] |
Maintainer: | Christopher Jackson <[email protected]> |
License: | GPL (>= 2) |
Version: | 1.8.2 |
Built: | 2025-01-07 06:48:42 UTC |
Source: | CRAN |
msm: Functions for fitting continuous-time Markov and hidden Markov multi-state models to longitudinal data. Designed for processes observed at arbitrary times in continuous time (intermittently observed or panel data) but some other observation schemes are supported. Both Markov transition rates and the hidden Markov output process can be modelled in terms of covariates, which may be constant or piecewise-constant in time.
Maintainer: Christopher Jackson [email protected]
Useful links:
Report bugs at https://github.com/chjackson/msm/issues
This dataset contains longitudinal measurements of grades of aortic aneurysms, measured by ultrasound examination of the diameter of the aorta.
A data frame containing 4337 rows, with each row corresponding to an ultrasound scan from one of 838 men over 65 years of age.
ptnum |
(numeric) | Patient identification number |
age |
(numeric) | Recipient age at examination (years) |
diam |
(numeric) | Aortic diameter |
state
|
(numeric) | State of aneurysm. |
The states represent successive degrees of aneurysm severity, as indicated by the aortic diameter.
State 1 | Aneurysm-free | < 30 cm |
State 2 | Mild aneurysm | 30-44 cm |
State 3 | Moderate aneurysm | 45-54 cm |
State 4 | Severe aneurysm | > 55 cm |
683 of these men were aneurysm-free at age 65 and were re-screened every two years. The remaining men were aneurysmal at entry and had successive screens with frequency depending on the state of the aneurysm. Severe aneurysms are repaired by surgery.
The Chichester, U.K. randomised controlled trial of screening for abdominal aortic aneurysms by ultrasonography.
Jackson, C.H., Sharples, L.D., Thompson, S.G. and Duffy, S.W. and Couto, E. Multi-state Markov models for disease progression with classification error. The Statistician, 52(2): 193–209 (2003)
Couto, E. and Duffy, S. W. and Ashton, H. A. and Walker, N. M. and Myles, J. P. and Scott, R. A. P. and Thompson, S. G. (2002) Probabilities of progression of aortic aneurysms: estimates and implications for screening policy Journal of Medical Screening 9(1):40–42
Draw a number of bootstrap resamples, refit a msm
model to the
resamples, and calculate statistics on the refitted models.
boot.msm( x, stat = pmatrix.msm, B = 1000, file = NULL, cores = NULL, remove.errors = TRUE )
boot.msm( x, stat = pmatrix.msm, B = 1000, file = NULL, cores = NULL, remove.errors = TRUE )
x |
A fitted msm model, as output by |
stat |
A function to call on each refitted msm model. By default this
is |
B |
Number of bootstrap resamples. |
file |
Name of a file in which to save partial results after each
replicate. This is saved using |
cores |
Number of processor cores to use for parallel processing.
Requires the doParallel package to be installed. If not specified,
parallel processing is not used. If |
remove.errors |
If |
The bootstrap datasets are computed by resampling independent pairs of observations at successive times (for non-hidden models without censoring), or independent individual series (for hidden models or models with censoring). Therefore this approach doesn't work if, for example, the data for a HMM consist of a series of observations from just one individual, and is inaccurate for small numbers of independent transitions or individuals.
Confidence intervals or standard errors for the corresponding statistic can
be calculated by summarising the returned list of B
replicated
outputs. This is currently implemented for most the output functions
qmatrix.msm
, ematrix.msm
,
qratio.msm
, pmatrix.msm
,
pmatrix.piecewise.msm
, totlos.msm
and
prevalence.msm
. For other outputs, users will have to write
their own code to summarise the output of boot.msm
.
Most of msm's output functions present confidence intervals based on
asymptotic standard errors calculated from the Hessian. These are expected
to be underestimates of the true standard errors (Cramer-Rao lower bound).
Some of these functions use a further approximation, the delta method (see
deltamethod
) to obtain standard errors of transformed
parameters. Bootstrapping should give a more accurate estimate of the
uncertainty.
An alternative method which is less accurate though faster than
bootstrapping, but more accurate than the delta method, is to draw a sample
from the asymptotic multivariate normal distribution implied by the maximum
likelihood estimates (and covariance matrix), and summarise the transformed
estimates. See pmatrix.msm
.
All objects used in the original call to msm
which produced
x
, such as the qmatrix
, should be in the working environment,
or else boot.msm
will produce an “object not found” error.
This enables boot.msm
to refit the original model to the replicate
datasets. However there is currently a limitation. In the original call to
msm
, the "formula"
argument should be specified directly, as,
for example,
msm(state ~ time, data = ...)
and not, for example,
form = data$state ~ data$time
msm(formula=form, data = ...)
otherwise boot.msm
will be unable to draw the replicate datasets.
boot.msm
will also fail with an incomprehensible error if the
original call to msm used a used-defined object whose name is the same as a
built-in R object, or an object in any other loaded package. For example,
if you have called a Q matrix q
, when q()
is the built-in
function for quitting R.
If stat
is NULL
, then B
different msm
model
objects will be stored in memory. This is unadvisable, as msm
objects
tend to be large, since they contain the original data used for the
msm
fit, so this will be wasteful of memory.
To specify more than one statistic, write a function consisting of a list of different function calls, for example,
stat = function(x) list (pmatrix.msm(x, t=1), pmatrix.msm(x, t=2))
A list with B
components, containing the result of calling
function stat
on each of the refitted models. If stat
is
NULL
, then each component just contains the refitted model. If one
of the B
model fits was unsuccessful and resulted in an error, then
the corresponding list component will contain the error message.
C.H.Jackson <[email protected]>
Efron, B. and Tibshirani, R.J. (1993) An Introduction to the Bootstrap, Chapman and Hall.
qmatrix.msm
, qratio.msm
,
sojourn.msm
, ematrix.msm
,
pmatrix.msm
, pmatrix.piecewise.msm
,
totlos.msm
, prevalence.msm
.
## Not run: ## Psoriatic arthritis example data(psor) psor.q <- rbind(c(0,0.1,0,0),c(0,0,0.1,0),c(0,0,0,0.1),c(0,0,0,0)) psor.msm <- msm(state ~ months, subject=ptnum, data=psor, qmatrix = psor.q, covariates = ~ollwsdrt+hieffusn, constraint = list(hieffusn=c(1,1,1),ollwsdrt=c(1,1,2)), control = list(REPORT=1,trace=2), method="BFGS") ## Bootstrap the baseline transition intensity matrix. This will take a long time. q.list <- boot.msm(psor.msm, function(x)x$Qmatrices$baseline) ## Manipulate the resulting list of matrices to calculate bootstrap standard errors. apply(array(unlist(q.list), dim=c(4,4,5)), c(1,2), sd) ## Similarly calculate a bootstrap 95% confidence interval apply(array(unlist(q.list), dim=c(4,4,5)), c(1,2), function(x)quantile(x, c(0.025, 0.975))) ## Bootstrap standard errors are larger than the asymptotic standard ## errors calculated from the Hessian psor.msm$QmatricesSE$baseline ## End(Not run)
## Not run: ## Psoriatic arthritis example data(psor) psor.q <- rbind(c(0,0.1,0,0),c(0,0,0.1,0),c(0,0,0,0.1),c(0,0,0,0)) psor.msm <- msm(state ~ months, subject=ptnum, data=psor, qmatrix = psor.q, covariates = ~ollwsdrt+hieffusn, constraint = list(hieffusn=c(1,1,1),ollwsdrt=c(1,1,2)), control = list(REPORT=1,trace=2), method="BFGS") ## Bootstrap the baseline transition intensity matrix. This will take a long time. q.list <- boot.msm(psor.msm, function(x)x$Qmatrices$baseline) ## Manipulate the resulting list of matrices to calculate bootstrap standard errors. apply(array(unlist(q.list), dim=c(4,4,5)), c(1,2), sd) ## Similarly calculate a bootstrap 95% confidence interval apply(array(unlist(q.list), dim=c(4,4,5)), c(1,2), function(x)quantile(x, c(0.025, 0.975))) ## Bootstrap standard errors are larger than the asymptotic standard ## errors calculated from the Hessian psor.msm$QmatricesSE$baseline ## End(Not run)
A dataset containing histories of bronchiolitis obliterans syndrome (BOS) from lung transplant recipients. BOS is a chronic decline in lung function, often observed after lung transplantation. The condition is classified into four stages of severity: none, mild, moderate and severe.
A data frame containing 638 rows, grouped by patient, including histories of 204 patients. The first observation for each patient is defined to be stage 1, no BOS, at six months after transplant. Subsequent observations denote the entry times into stages 2, 3, 4, representing mild, moderate and severe BOS respectively, and stage 5, representing death.
ptnum |
(numeric) | Patient identification number |
time |
(numeric) | Months after transplant |
state |
(numeric) | BOS state entered at this time |
The entry time of each patient into each stage of BOS was estimated by clinicians, based on their history of lung function measurements and acute rejection and infection episodes. BOS is only assumed to occur beyond six months after transplant. In the first six months the function of each patient's new lung stabilises. Subsequently BOS is diagnosed by comparing the lung function against the "baseline" value.
The objects bos3
and bos4
contain the same data, but with
mild/moderate/severe combined, and moderate/severe combined, to give 3 and
4-state representations respectively.
Papworth Hospital, U.K.
Heng. D. et al. (1998). Bronchiolitis Obliterans Syndrome: Incidence, Natural History, Prognosis, and Risk Factors. Journal of Heart and Lung Transplantation 17(12)1255–1263.
A series of approximately yearly angiographic examinations of heart transplant recipients. The state at each time is a grade of cardiac allograft vasculopathy (CAV), a deterioration of the arterial walls.
A data frame containing 2846 rows. There are 622 patients, the rows are grouped by patient number and ordered by years after transplant, with each row representing an examination and containing additional covariates.
PTNUM |
(numeric) | Patient identification number |
age |
(numeric) | Recipient age at examination (years) |
years |
(numeric) | Examination time (years after transplant) |
dage |
(numeric) | Age of heart donor (years) |
sex |
(numeric) | sex (0=male, 1=female) |
pdiag
|
(factor) | Primary diagnosis (reason for transplant) |
IHD=ischaemic heart disease, IDC=idiopathic dilated cardiomyopathy. | ||
cumrej |
(numeric) | Cumulative number of acute rejection episodes |
state |
(numeric) | State at the examination. |
State 1 represents no CAV, state 2 is mild/moderate CAV | ||
and state 3 is severe CAV. State 4 indicates death. | ||
firstobs |
(numeric) | 0 = record represents an angiogram or date of death. |
1 = record represents transplant (patient's first observation) | ||
statemax |
(numeric) | Maximum observed state so far for this patient (added in version 1.5.1) |
Papworth Hospital, U.K.
Sharples, L.D. and Jackson, C.H. and Parameshwar, J. and Wallwork, J. and Large, S.R. (2003). Diagnostic accuracy of coronary angiopathy and risk factors for post-heart-transplant cardiac allograft vasculopathy. Transplantation 76(4):679-82
A list giving information about censored states, their labels in the data and what true states they represent.
ncens |
The number of distinct values used for censored
observations in the |
censor |
A vector of length |
states |
A vector obtained by
|
index |
Index into |
Extract the estimated log transition intensities and the corresponding linear effects of each covariate.
## S3 method for class 'msm' coef(object, ...)
## S3 method for class 'msm' coef(object, ...)
object |
A fitted multi-state model object, as returned by
|
... |
(unused) further arguments passed to or from other methods. |
If there is no misclassification, coef.msm
returns a list of
matrices. The first component, labelled logbaseline
, is a matrix
containing the estimated transition intensities on the log scale with any
covariates fixed at their means in the data. Each remaining component is a
matrix giving the linear effects of the labelled covariate on the matrix of
log intensities.
For misclassification models, coef.msm
returns a list of lists. The
first component, Qmatrices
, is a list of matrices as described in the
previous paragraph. The additional component Ematrices
is a list of
similar format containing the logit-misclassification probabilities and any
estimated covariate effects.
C. H. Jackson [email protected]
Calculates crude initial values for transition intensities by assuming that the data represent the exact transition times of the Markov process.
crudeinits.msm( formula, subject, qmatrix, data = NULL, censor = NULL, censor.states = NULL )
crudeinits.msm( formula, subject, qmatrix, data = NULL, censor = NULL, censor.states = NULL )
formula |
A formula giving the vectors containing the observed states and the corresponding observation times. For example,
Observed states should be in the set |
subject |
Vector of subject identification numbers for the data
specified by |
qmatrix |
Matrix of indicators for the allowed transitions. An initial
value will be estimated for each value of qmatrix that is greater than zero.
Transitions are taken as disallowed for each entry of |
data |
An optional data frame in which the variables represented by
|
censor |
A state, or vector of states, which indicates censoring. See
|
censor.states |
Specifies the underlying states which censored
observations can represent. See |
Suppose we want a crude estimate of the transition intensity
from state
to state
. If we observe
transitions from state
to state
, and a
total of
transitions from state
, then
can be estimated by
. Then, given a total of
years spent in state
, the mean sojourn time
can be estimated
as
. Thus,
is a crude
estimate of
.
If the data do represent the exact transition times of the Markov process, then these are the exact maximum likelihood estimates.
Observed transitions which are incompatible with the given qmatrix
are ignored. Censored states are ignored.
The estimated transition intensity matrix. This can be used as the
qmatrix
argument to msm
.
C. H. Jackson [email protected]
data(cav) twoway4.q <- rbind(c(-0.5, 0.25, 0, 0.25), c(0.166, -0.498, 0.166, 0.166), c(0, 0.25, -0.5, 0.25), c(0, 0, 0, 0)) statetable.msm(state, PTNUM, data=cav) crudeinits.msm(state ~ years, PTNUM, data=cav, qmatrix=twoway4.q)
data(cav) twoway4.q <- rbind(c(-0.5, 0.25, 0, 0.25), c(0.166, -0.498, 0.166, 0.166), c(0, 0.25, -0.5, 0.25), c(0, 0, 0, 0)) statetable.msm(state, PTNUM, data=cav) crudeinits.msm(state ~ years, PTNUM, data=cav, qmatrix=twoway4.q)
Delta method for approximating the standard error of a transformation
of a random variable
, given estimates of the mean and covariance matrix of
.
deltamethod(g, mean, cov, ses = TRUE)
deltamethod(g, mean, cov, ses = TRUE)
g |
A formula representing the transformation. The variables must be
labelled
If the transformation returns a vector, then a list of formulae representing
(
|
mean |
The estimated mean of |
cov |
The estimated covariance matrix of |
ses |
If |
The delta method expands a differentiable function of a random variable
about its mean, usually with a first-order Taylor approximation, and then
takes the variance. For example, an approximation to the covariance matrix
of is given by
where is an estimate of the mean of
. This function
uses symbolic differentiation via
deriv
.
A limitation of this function is that variables created by the user are not
visible within the formula g
. To work around this, it is necessary
to build the formula as a string, using functions such as sprintf
,
then to convert the string to a formula using as.formula
. See the
example below.
If you can spare the computational time, bootstrapping is a more accurate
method of calculating confidence intervals or standard errors for
transformations of parameters. See boot.msm
. Simulation from
the asymptotic distribution of the MLEs (see e.g. Mandel 2013) is also a
convenient alternative.
A vector containing the standard errors of or a matrix containing the covariance of
.
C. H. Jackson [email protected]
Oehlert, G. W. (1992) A note on the delta method. American Statistician 46(1).
Mandel, M. (2013) Simulation based confidence intervals for functions with complicated derivatives. The American Statistician 67(2):76-81.
## Simple linear regression, E(y) = alpha + beta x x <- 1:100 y <- rnorm(100, 4*x, 5) toy.lm <- lm(y ~ x) estmean <- coef(toy.lm) estvar <- summary(toy.lm)$cov.unscaled * summary(toy.lm)$sigma^2 ## Estimate of (1 / (alphahat + betahat)) 1 / (estmean[1] + estmean[2]) ## Approximate standard error deltamethod (~ 1 / (x1 + x2), estmean, estvar) ## We have a variable z we would like to use within the formula. z <- 1 ## deltamethod (~ z / (x1 + x2), estmean, estvar) will not work. ## Instead, build up the formula as a string, and convert to a formula. form <- sprintf("~ %f / (x1 + x2)", z) form deltamethod(as.formula(form), estmean, estvar)
## Simple linear regression, E(y) = alpha + beta x x <- 1:100 y <- rnorm(100, 4*x, 5) toy.lm <- lm(y ~ x) estmean <- coef(toy.lm) estvar <- summary(toy.lm)$cov.unscaled * summary(toy.lm)$sigma^2 ## Estimate of (1 / (alphahat + betahat)) 1 / (estmean[1] + estmean[2]) ## Approximate standard error deltamethod (~ 1 / (x1 + x2), estmean, estvar) ## We have a variable z we would like to use within the formula. z <- 1 ## deltamethod (~ z / (x1 + x2), estmean, estvar) will not work. ## Instead, build up the formula as a string, and convert to a formula. form <- sprintf("~ %f / (x1 + x2)", z) form deltamethod(as.formula(form), estmean, estvar)
A modification of Akaike's information criterion, and a leave-one-out likelihood cross-validation criterion, for comparing the predictive ability of two Markov multi-state models with nested state spaces. This is evaluated based on the restricted or aggregated data which the models have in common.
draic.msm( msm.full, msm.coarse, likelihood.only = FALSE, information = c("expected", "observed"), tl = 0.95 ) drlcv.msm( msm.full, msm.coarse, tl = 0.95, cores = NULL, verbose = TRUE, outfile = NULL )
draic.msm( msm.full, msm.coarse, likelihood.only = FALSE, information = c("expected", "observed"), tl = 0.95 ) drlcv.msm( msm.full, msm.coarse, tl = 0.95, cores = NULL, verbose = TRUE, outfile = NULL )
msm.full |
Model on the bigger state space. |
msm.coarse |
Model on the smaller state space. The two models must both be non-hidden Markov models without censored states. The two models must be fitted to the same datasets, except that the state
space of the coarse model must be an aggregated version of the state space
of the full model. That is, every state in the full dataset must correspond
to a unique state in the coarse dataset. For example, for the full state
variable The structure of allowed transitions in the coarse model must also be a collapsed version of the big model structure, but no check is currently made for this in the code. To use these functions, all objects which were used in the calls to fit
|
likelihood.only |
Don't calculate Hessians and trace term (DRAIC). |
information |
Use observed or expected information in the DRAIC trace
term. Expected is the default, and much faster, though is only available
for models fitted to pure panel data (all |
tl |
Width of symmetric tracking interval, by default 0.95 for a 95% interval. |
cores |
Number of processor cores to use in |
verbose |
Print intermediate results of each iteration of cross-validation to the console while running. May not work with parallel processing. |
outfile |
Output file to print intermediate results of cross-validation. Useful to track execution speed when using parallel processing, where output to the console may not work. |
Note that standard AIC can be computed for one or more fitted msm
models x,y,...
using AIC(x,y,...)
, and this can be used
to compare models fitted to the same data. draic.msm
and
drlcv.msm
are designed for models fitted to data with
differently-aggregated state spaces.
The difference in restricted AIC (Liquet and Commenges, 2011), as computed by this function, is defined as
where and
are the maximum likelihood
estimates of the smaller and bigger models, fitted to the smaller and bigger
data, respectively.
represents the likelihood of the
simpler model evaluated on the restricted data.
represents the likelihood of the
complex model evaluated on the restricted data. This is a hidden Markov
model, with a misclassification matrix and initial state occupancy
probabilities as described by Thom et al (2014).
are the corresponding (expected or observed, as specified by the
user) information matrices.
is the expanded data, to which the bigger model was
originally fitted, and
is the data to which the
smaller model was originally fitted.
is the
restricted data which the two models have in common.
in this implementation, so the models are nested.
The difference in likelihood cross-validatory criteria (Liquet and Commenges, 2011) is defined as
where and
are the maximum likelihood
estimates from the smaller and bigger models fitted to datasets with subject
left out,
and
are the densities of the
corresponding models, and
is the restricted data from subject
.
Tracking intervals are analogous to confidence intervals, but not strictly the same, since the quantity which D_RAIC aims to estimate, the difference in expected Kullback-Leibler discrepancy for predicting a replicate dataset, depends on the sample size. See the references.
Positive values for these criteria indicate the coarse model is preferred, while negative values indicate the full model is preferred.
A list containing (
draic.msm
) or
(
drlcv.msm
), its component terms, and tracking
intervals.
C. H. Jackson [email protected], H. H. Z. Thom [email protected]
Thom, H. and Jackson, C. and Commenges, D. and Sharples, L. (2015) State selection in multistate models with application to quality of life in psoriatic arthritis. Statistics In Medicine 34(16) 2381 - 2480.
Liquet, B. and Commenges D. (2011) Choice of estimators based on different observations: Modified AIC and LCV criteria. Scandinavian Journal of Statistics; 38:268-287.
A list representing the model for covariates on misclassification probabilities.
npars |
Number of covariate effect parameters. This is defined as the number of covariates on misclassification (with factors expanded as contrasts) multiplied by the number of allowed misclassifications in the model. |
ndpars |
Number of distinct covariate effect parameters, as
|
ncovs |
Number of covariates on misclassification, with factors expanded as contrasts. |
constr |
List of equality constraints on these
covariate effects, as supplied in the |
covlabels |
Names / labels of these covariates in
the model matrix (see |
inits |
Initial
values for these covariate effects, as a vector formed from the
|
covmeans |
Means of these covariates in the data (excluding data not required to fit the model, such as observations with missing data in other elements or subjects' last observations). This includes means of 0/1 factor contrasts as well as continuous covariates (for historic reasons, which may not be sensible). |
Expected time until first reaching a particular state or set of states in a Markov model.
efpt.msm( x = NULL, qmatrix = NULL, tostate, start = "all", covariates = "mean", ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, ... )
efpt.msm( x = NULL, qmatrix = NULL, tostate, start = "all", covariates = "mean", ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, ... )
x |
A fitted multi-state model, as returned by |
qmatrix |
Instead of |
tostate |
State, or set of states supplied as a vector, for which to estimate the first passage time into. Can be integer, or character matched to the row names of the Q matrix. |
start |
Starting state (integer). By default ( Alternatively, this can be used to obtain the expected first passage time
from a set of states, rather than single states. To achieve this,
|
covariates |
Covariate values defining the intensity matrix for the
fitted model |
ci |
If If If |
cl |
Width of the symmetric confidence interval, relative to 1. |
B |
Number of bootstrap replicates. |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
... |
Arguments to pass to |
The expected first passage times from each of a set of states
to to the remaining set of states
in the state space, for a model with
transition intensity matrix
, are
where is a vector of ones, and
is the square subset of
pertaining to states
.
It is equal to the sum of mean sojourn times for all states between the
"from" and "to" states in a unidirectional model. If there is non-zero
chance of reaching an absorbing state before reaching tostate
, then
it is infinite. It is trivially zero if the "from" state equals
tostate
.
This function currently only handles time-homogeneous Markov models. For
time-inhomogeneous models it will assume that equals the average
intensity matrix over all times and observed covariates. Simulation might
be used to handle time dependence.
Note this is the expectation of first passage time, and the
confidence intervals are CIs for this mean, not predictive intervals for the
first passage time. The full distribution of the first passage time to a
set of states can be obtained by setting the rows of the intensity matrix
corresponding to that set of states to zero to make a model where
those states are absorbing. The corresponding transition probability matrix
then gives the probabilities of having hit or passed that
state by a time
(see the example below). This is implemented in
ppass.msm
.
A vector of expected first passage times, or "hitting times", from each state to the desired state.
C. H. Jackson [email protected]
Norris, J. R. (1997) Markov Chains. Cambridge University Press.
sojourn.msm
, totlos.msm
,
boot.msm
.
twoway4.q <- rbind(c(-0.5, 0.25, 0, 0.25), c(0.166, -0.498, 0.166, 0.166), c(0, 0.25, -0.5, 0.25), c(0, 0, 0, 0)) efpt.msm(qmatrix=twoway4.q, tostate=3) # given in state 1, expected time to reaching state 3 is infinite # since may die (state 4) before entering state 3 # If we remove the death state from the model, EFPTs become finite Q <- twoway4.q[1:3,1:3]; diag(Q) <- 0; diag(Q) <- -rowSums(Q) efpt.msm(qmatrix=Q, tostate=3) # Suppose we cannot die or regress while in state 2, can only go to state 3 Q <- twoway4.q; Q[2,4] <- Q[2,1] <- 0; diag(Q) <- 0; diag(Q) <- -rowSums(Q) efpt.msm(qmatrix=Q, tostate=3) # The expected time from 2 to 3 now equals the mean sojourn time in 2. -1/Q[2,2] # Calculate cumulative distribution of the first passage time # into state 3 for the following three-state model Q <- twoway4.q[1:3,1:3]; diag(Q) <- 0; diag(Q) <- -rowSums(Q) # Firstly form a model where the desired hitting state is absorbing Q[3,] <- 0 MatrixExp(Q, t=10)[,3] ppass.msm(qmatrix=Q, tot=10) # Given in state 1 at time 0, P(hit 3 by time 10) = 0.479 MatrixExp(Q, t=50)[,3] # P(hit 3 by time 50) = 0.98 ppass.msm(qmatrix=Q, tot=50)
twoway4.q <- rbind(c(-0.5, 0.25, 0, 0.25), c(0.166, -0.498, 0.166, 0.166), c(0, 0.25, -0.5, 0.25), c(0, 0, 0, 0)) efpt.msm(qmatrix=twoway4.q, tostate=3) # given in state 1, expected time to reaching state 3 is infinite # since may die (state 4) before entering state 3 # If we remove the death state from the model, EFPTs become finite Q <- twoway4.q[1:3,1:3]; diag(Q) <- 0; diag(Q) <- -rowSums(Q) efpt.msm(qmatrix=Q, tostate=3) # Suppose we cannot die or regress while in state 2, can only go to state 3 Q <- twoway4.q; Q[2,4] <- Q[2,1] <- 0; diag(Q) <- 0; diag(Q) <- -rowSums(Q) efpt.msm(qmatrix=Q, tostate=3) # The expected time from 2 to 3 now equals the mean sojourn time in 2. -1/Q[2,2] # Calculate cumulative distribution of the first passage time # into state 3 for the following three-state model Q <- twoway4.q[1:3,1:3]; diag(Q) <- 0; diag(Q) <- -rowSums(Q) # Firstly form a model where the desired hitting state is absorbing Q[3,] <- 0 MatrixExp(Q, t=10)[,3] ppass.msm(qmatrix=Q, tot=10) # Given in state 1 at time 0, P(hit 3 by time 10) = 0.479 MatrixExp(Q, t=50)[,3] # P(hit 3 by time 50) = 0.98 ppass.msm(qmatrix=Q, tot=50)
Extract the estimated misclassification probability matrix, and corresponding confidence intervals, from a fitted multi-state model at a given set of covariate values.
ematrix.msm( x, covariates = "mean", ci = c("delta", "normal", "bootstrap", "none"), cl = 0.95, B = 1000, cores = NULL )
ematrix.msm( x, covariates = "mean", ci = c("delta", "normal", "bootstrap", "none"), cl = 0.95, B = 1000, cores = NULL )
x |
A fitted multi-state model, as returned by |
covariates |
The covariate values for which to estimate the misclassification probability
matrix. This can either be: the string the number or a list of values, with optional names. For example
where the order of the list follows the order of the covariates originally given in the model formula, or a named list,
|
ci |
If If If |
cl |
Width of the symmetric confidence interval to present. Defaults to 0.95. |
B |
Number of bootstrap replicates, or number of normal simulations from the distribution of the MLEs |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
Misclassification probabilities and covariate effects are estimated on the
multinomial-logit scale by msm
. A covariance matrix is
estimated from the Hessian of the maximised log-likelihood. From these, the
delta method can be used to obtain standard errors of the probabilities on
the natural scale at arbitrary covariate values. Confidence intervals are
estimated by assuming normality on the multinomial-logit scale.
A list with components:
estimate |
Estimated misclassification probability matrix. The rows correspond to true states, and columns observed states. |
SE |
Corresponding approximate standard errors. |
L |
Lower confidence limits. |
U |
Upper confidence limits. |
Or if ci="none"
, then ematrix.msm
just returns the estimated
misclassification probability matrix.
The default print method for objects returned by ematrix.msm
presents estimates and confidence limits. To present estimates and standard
errors, do something like
ematrix.msm(x)[c("estimates","SE")]
C. H. Jackson [email protected]
A list giving information about the misclassifications assumed in a
multi-state model fitted with the ematrix
argument of
msm
. Returned in a fitted msm
model object.
This information is converted internally to a hmodel
object (see
hmodel.object
) for use in likelihood computations.
nstates |
Number of states (same as |
npars |
Number of allowed misclassifications, equal to
|
imatrix |
Indicator matrix for allowed
misclassifications. This has |
ematrix |
Matrix of initial values for the
misclassification probabilities, supplied as the |
inits |
Vector of these initial values, reading
across rows of |
constr |
Indicators for equality constraints on baseline
misclassification probabilities, taken from the |
ndpars |
Number of distinct misclassification probabilities, after applying equality constraints. |
nipars |
Number of initial state
occupancy probabilities being estimated. This is zero if
|
initprobs |
Initial state occupancy probabilities, as supplied to
|
est.initprobs |
Are initial state
occupancy probabilities estimated ( |
msm.object
,qmodel.object
,
hmodel.object
.
A series of measurements of the forced expiratory volume in one second (FEV1) from lung transplant recipients, from six months onwards after their transplant.
A data frame containing 5896 rows. There are 204 patients, the rows are grouped by patient number and ordered by days after transplant. Each row represents an examination and containing an additional covariate.
ptnum |
(numeric) | Patient identification number. |
days |
(numeric) | Examination time (days after transplant). |
fev |
(numeric) | Percentage of baseline FEV1. A code of 999 indicates the patient's date of death. |
acute |
(numeric) | 0/1 indicator for whether the patient suffered an acute infection or rejection |
within 14 days of the visit. | ||
A baseline "normal" FEV1 for each individual is calculated using measurements from the first six months after transplant. After six months, as presented in this dataset, FEV1 is expressed as a percentage of the baseline value.
FEV1 is monitored to diagnose bronchiolitis obliterans syndrome (BOS), a long-term lung function decline, thought to be a form of chronic rejection. Acute rejections and infections also affect the lung function in the short term.
Papworth Hospital, U.K.
Jackson, C.H. and Sharples, L.D. Hidden Markov models for the onset and progression of bronchiolitis obliterans syndrome in lung transplant recipients Statistics in Medicine, 21(1): 113–128 (2002).
Hazard ratios are computed by exponentiating the estimated covariate effects
on the log-transition intensities. This function is called by
summary.msm
.
hazard.msm(x, hazard.scale = 1, cl = 0.95)
hazard.msm(x, hazard.scale = 1, cl = 0.95)
x |
Output from |
hazard.scale |
Vector with same elements as number of covariates on transition rates. Corresponds to the increase in each covariate used to calculate its hazard ratio. Defaults to all 1. |
cl |
Width of the symmetric confidence interval to present. Defaults to 0.95. |
A list of tables containing hazard ratio estimates, one table for each covariate. Each table has three columns, containing the hazard ratio, and an approximate upper and lower confidence limit respectively (assuming normality on the log scale), for each Markov chain transition intensity.
C. H. Jackson [email protected]
These functions are used to specify the distribution of the response
conditionally on the underlying state in a hidden Markov model. A list of
these function calls, with one component for each state, should be used for
the hmodel
argument to msm
. The initial values for the
parameters of the distribution should be given as arguments. Note the
initial values should be supplied as literal values - supplying them as
variables is currently not supported.
hmmCat(prob, basecat) hmmIdent(x) hmmUnif(lower, upper) hmmNorm(mean, sd) hmmLNorm(meanlog, sdlog) hmmExp(rate) hmmGamma(shape, rate) hmmWeibull(shape, scale) hmmPois(rate) hmmBinom(size, prob) hmmBetaBinom(size, meanp, sdp) hmmNBinom(disp, prob) hmmBeta(shape1, shape2) hmmTNorm(mean, sd, lower = -Inf, upper = Inf) hmmMETNorm(mean, sd, lower, upper, sderr, meanerr = 0) hmmMEUnif(lower, upper, sderr, meanerr = 0) hmmT(mean, scale, df)
hmmCat(prob, basecat) hmmIdent(x) hmmUnif(lower, upper) hmmNorm(mean, sd) hmmLNorm(meanlog, sdlog) hmmExp(rate) hmmGamma(shape, rate) hmmWeibull(shape, scale) hmmPois(rate) hmmBinom(size, prob) hmmBetaBinom(size, meanp, sdp) hmmNBinom(disp, prob) hmmBeta(shape1, shape2) hmmTNorm(mean, sd, lower = -Inf, upper = Inf) hmmMETNorm(mean, sd, lower, upper, sderr, meanerr = 0) hmmMEUnif(lower, upper, sderr, meanerr = 0) hmmT(mean, scale, df)
prob |
( |
basecat |
( |
x |
( |
lower |
( |
upper |
( |
mean |
( |
sd |
( |
meanlog |
( |
sdlog |
( |
rate |
( |
shape |
( |
scale |
( |
size |
Order of a Binomial distribution (see |
meanp |
Mean outcome probability in a beta-binomial distribution |
sdp |
Standard deviation describing the overdispersion of the outcome probability in a beta-binomial distribution |
disp |
Dispersion parameter of a negative binomial distribution, also
called |
shape1 , shape2
|
First and second parameters of a beta distribution (see
|
sderr |
( |
meanerr |
( |
df |
Degrees of freedom of the Student t distribution. |
hmmCat
represents a categorical response distribution on the set
1, 2, ...{}, length(prob)
. The Markov model with misclassification
is an example of this type of model. The categories in this case are (some
subset of) the underlying states.
The hmmIdent
distribution is used for underlying states which are
observed exactly without error. For hidden Markov models with multiple
outcomes, (see hmmMV
), the outcome in the data which takes the
special hmmIdent
value must be the first of the multiple outcomes.
hmmUnif
, hmmNorm
, hmmLNorm
, hmmExp
,
hmmGamma
, hmmWeibull
, hmmPois
, hmmBinom
,
hmmTNorm
, hmmNBinom
and hmmBeta
represent Uniform,
Normal, log-Normal, exponential, Gamma, Weibull, Poisson, Binomial,
truncated Normal, negative binomial and beta distributions, respectively,
with parameterisations the same as the default parameterisations in the
corresponding base R distribution functions.
hmmT
is the Student t distribution with general mean ,
scale
and degrees of freedom
df
. The variance is
. Note the t distribution in
base R
dt
is a standardised one with mean 0 and scale 1.
These allow any positive (integer or non-integer) df
. By default,
all three parameters, including df
, are estimated when fitting a
hidden Markov model, but in practice, df
might need to be fixed for
identifiability - this can be done using the fixedpars
argument to
msm
.
The hmmMETNorm
and hmmMEUnif
distributions are truncated
Normal and Uniform distributions, but with additional Normal measurement
error on the response. These are generalisations of the distributions
proposed by Satten and Longini (1996) for modelling the progression of CD4
cell counts in monitoring HIV disease. See medists
for
density, distribution, quantile and random generation functions for these
distributions. See also tnorm
for density, distribution,
quantile and random generation functions for the truncated Normal
distribution.
See the PDF manual ‘msm-manual.pdf’ in the ‘doc’ subdirectory for algebraic definitions of all these distributions. New hidden Markov model response distributions can be added to msm by following the instructions in Section 2.17.1.
Parameters which can be modelled in terms of covariates, on the scale of a link function, are as follows.
PARAMETER NAME | LINK FUNCTION |
mean |
identity |
meanlog |
identity |
rate |
log |
scale |
log |
meanerr |
identity |
meanp |
logit |
prob |
logit or multinomial logit |
Parameters basecat, lower, upper, size, meanerr
are fixed at their
initial values. All other parameters are estimated while fitting the hidden
Markov model, unless the appropriate fixedpars
argument is supplied
to msm
.
For categorical response distributions (hmmCat)
the outcome
probabilities initialized to zero are fixed at zero, and the probability
corresponding to basecat
is fixed to one minus the sum of the
remaining probabilities. These remaining probabilities are estimated, and
can be modelled in terms of covariates via multinomial logistic regression
(relative to basecat
).
Each function returns an object of class hmmdist
, which is a
list containing information about the model. The only component which may
be useful to end users is r
, a function of one argument n
which returns a random sample of size n
from the given distribution.
C. H. Jackson [email protected]
Satten, G.A. and Longini, I.M. Markov chains with measurement error: estimating the 'true' course of a marker of the progression of human immunodeficiency virus disease (with discussion) Applied Statistics 45(3): 275-309 (1996).
Jackson, C.H. and Sharples, L.D. Hidden Markov models for the onset and progresison of bronchiolitis obliterans syndrome in lung transplant recipients Statistics in Medicine, 21(1): 113–128 (2002).
Jackson, C.H., Sharples, L.D., Thompson, S.G. and Duffy, S.W. and Couto, E. Multi-state Markov models for disease progression with classification error. The Statistician, 52(2): 193–209 (2003).
Constructor for a a multivariate hidden Markov model (HMM) where each of the
n
variables observed at the same time has a (potentially different)
standard univariate distribution conditionally on the underlying state. The
n
outcomes are independent conditionally on the hidden state.
hmmMV(...)
hmmMV(...)
... |
The number of arguments supplied should equal the maximum number
of observations made at one time. Each argument represents the univariate
distribution of that outcome conditionally on the hidden state, and should
be the result of calling a univariate hidden Markov model constructor (see
|
If a particular state in a HMM has such an outcome distribution, then a call
to hmmMV
is supplied as the corresponding element of the
hmodel
argument to msm
. See Example 2 below.
A multivariate HMM where multiple outcomes at the same time are generated
from the same distribution is specified in the same way as the
corresponding univariate model, so that hmmMV
is not required.
The outcome data are simply supplied as a matrix instead of a vector. See
Example 1 below.
The outcome data for such models are supplied as a matrix, with number of
columns equal to the maximum number of arguments supplied to the
hmmMV
calls for each state. If some but not all of the
variables are missing (NA
) at a particular time, then the observed
data at that time still contribute to the likelihood. The missing data are
assumed to be missing at random. The Viterbi algorithm may be used to
predict the missing values given the fitted model and the observed data.
Typically the outcome model for each state will be from the same family or set of families, but with different parameters. Theoretically, different numbers of distributions may be supplied for different states. If a particular state has fewer outcomes than the maximum, then the data for that state are taken from the first columns of the response data matrix. However this is not likely to be a useful model, since the number of observations will probably give information about the underlying state, violating the missing at random assumption.
Models with outcomes that are dependent conditionally on the hidden state (e.g. correlated multivariate normal observations) are not currently supported.
A list of objects, each of class hmmdist
as returned by the
univariate HMM constructors documented in hmm-dists
. The
whole list has class hmmMVdist
, which inherits from hmmdist
.
C. H. Jackson [email protected]
Jackson, C. H., Su, L., Gladman, D. D. and Farewell, V. T. (2015) On modelling minimal disease activity. Arthritis Care and Research (early view).
## Simulate data from a Markov model nsubj <- 30; nobspt <- 5 sim.df <- data.frame(subject = rep(1:nsubj, each=nobspt), time = seq(0, 20, length=nobspt)) set.seed(1) two.q <- rbind(c(-0.1, 0.1), c(0, 0)) dat <- simmulti.msm(sim.df[,1:2], qmatrix=two.q, drop.absorb=FALSE) ### EXAMPLE 1 ## Generate two observations at each time from the same outcome ## distribution: ## Bin(40, 0.1) for state 1, Bin(40, 0.5) for state 2 dat$obs1[dat$state==1] <- rbinom(sum(dat$state==1), 40, 0.1) dat$obs2[dat$state==1] <- rbinom(sum(dat$state==1), 40, 0.1) dat$obs1[dat$state==2] <- rbinom(sum(dat$state==2), 40, 0.5) dat$obs2[dat$state==2] <- rbinom(sum(dat$state==2), 40, 0.5) dat$obs <- cbind(obs1 = dat$obs1, obs2 = dat$obs2) ## Fitted model should approximately recover true parameters msm(obs ~ time, subject=subject, data=dat, qmatrix=two.q, hmodel = list(hmmBinom(size=40, prob=0.2), hmmBinom(size=40, prob=0.2))) ### EXAMPLE 2 ## Generate two observations at each time from different ## outcome distributions: ## Bin(40, 0.1) and Bin(40, 0.2) for state 1, dat$obs1 <- dat$obs2 <- NA dat$obs1[dat$state==1] <- rbinom(sum(dat$state==1), 40, 0.1) dat$obs2[dat$state==1] <- rbinom(sum(dat$state==1), 40, 0.2) ## Bin(40, 0.5) and Bin(40, 0.6) for state 2 dat$obs1[dat$state==2] <- rbinom(sum(dat$state==2), 40, 0.6) dat$obs2[dat$state==2] <- rbinom(sum(dat$state==2), 40, 0.5) dat$obs <- cbind(obs1 = dat$obs1, obs2 = dat$obs2) ## Fitted model should approximately recover true parameters msm(obs ~ time, subject=subject, data=dat, qmatrix=two.q, hmodel = list(hmmMV(hmmBinom(size=40, prob=0.3), hmmBinom(size=40, prob=0.3)), hmmMV(hmmBinom(size=40, prob=0.3), hmmBinom(size=40, prob=0.3))), control=list(maxit=10000))
## Simulate data from a Markov model nsubj <- 30; nobspt <- 5 sim.df <- data.frame(subject = rep(1:nsubj, each=nobspt), time = seq(0, 20, length=nobspt)) set.seed(1) two.q <- rbind(c(-0.1, 0.1), c(0, 0)) dat <- simmulti.msm(sim.df[,1:2], qmatrix=two.q, drop.absorb=FALSE) ### EXAMPLE 1 ## Generate two observations at each time from the same outcome ## distribution: ## Bin(40, 0.1) for state 1, Bin(40, 0.5) for state 2 dat$obs1[dat$state==1] <- rbinom(sum(dat$state==1), 40, 0.1) dat$obs2[dat$state==1] <- rbinom(sum(dat$state==1), 40, 0.1) dat$obs1[dat$state==2] <- rbinom(sum(dat$state==2), 40, 0.5) dat$obs2[dat$state==2] <- rbinom(sum(dat$state==2), 40, 0.5) dat$obs <- cbind(obs1 = dat$obs1, obs2 = dat$obs2) ## Fitted model should approximately recover true parameters msm(obs ~ time, subject=subject, data=dat, qmatrix=two.q, hmodel = list(hmmBinom(size=40, prob=0.2), hmmBinom(size=40, prob=0.2))) ### EXAMPLE 2 ## Generate two observations at each time from different ## outcome distributions: ## Bin(40, 0.1) and Bin(40, 0.2) for state 1, dat$obs1 <- dat$obs2 <- NA dat$obs1[dat$state==1] <- rbinom(sum(dat$state==1), 40, 0.1) dat$obs2[dat$state==1] <- rbinom(sum(dat$state==1), 40, 0.2) ## Bin(40, 0.5) and Bin(40, 0.6) for state 2 dat$obs1[dat$state==2] <- rbinom(sum(dat$state==2), 40, 0.6) dat$obs2[dat$state==2] <- rbinom(sum(dat$state==2), 40, 0.5) dat$obs <- cbind(obs1 = dat$obs1, obs2 = dat$obs2) ## Fitted model should approximately recover true parameters msm(obs ~ time, subject=subject, data=dat, qmatrix=two.q, hmodel = list(hmmMV(hmmBinom(size=40, prob=0.3), hmmBinom(size=40, prob=0.3)), hmmMV(hmmBinom(size=40, prob=0.3), hmmBinom(size=40, prob=0.3))), control=list(maxit=10000))
A list giving information about the models for the outcome data
conditionally on the states of a hidden Markov model. Used in internal
computations, and returned in a fitted msm
model object.
hidden |
|
nstates |
Number of states, the same as
|
fitted |
|
models |
The outcome distribution for each hidden
state. A vector of length |
labels |
String
identifying each distribution in |
npars |
Vector of
length |
nipars |
Number of initial
state occupancy probabilities being estimated. This is zero if
|
totpars |
Total number of parameters, equal to |
pars |
A vector of length |
plabs |
List
with the names of the parameters in |
parstate |
A vector
of length |
firstpar |
A vector of length
|
locpars |
Index in |
initprobs |
Initial state occupancy
probabilities, as supplied to |
est.initprobs |
Are initial
state occupancy probabilities estimated ( |
ncovs |
Number of covariate effects per parameter in |
coveffect |
Vector of covariate
effects, of length |
covlabels |
Labels of these effects. |
coveffstate |
Vector indicating state corresponding to each
element of |
ncoveffs |
Number of covariate effects on
HMM outcomes, equal to |
nicovs |
Vector of length
|
icoveffect |
Vector of length |
nicoveffs |
Number
of covariate effects on initial state occupancy probabilities, equal to
|
constr |
Constraints on (baseline) hidden Markov
model outcome parameters, as supplied in the |
covconstr |
Vector of
constraints on covariate effects in hidden Markov outcome models, as
supplied in the |
ranges |
Matrix of range restrictions for
HMM parameters, including those given to the |
foundse |
|
initpmat |
Matrix of initial state
occupancy probabilities with one row for each subject (estimated if
|
ci |
Confidence intervals for baseline HMM outcome parameters. |
covci |
Confidence intervals for covariate effects in HMM outcome models. |
msm.object
,qmodel.object
,
emodel.object
.
Convert a hmodel object to HMM constructor function calls
hmodel2list(hmodel, hmmdist = TRUE)
hmodel2list(hmodel, hmmdist = TRUE)
hmodel |
A list of class |
hmmdist |
|
If hmmdist=TRUE
, returns a list of objects of class hmmdist
.
These are the kind of objects
returned by HMM constructor functions such
as hmmNorm
, hmmPois
etc. Therefore the list can be
passed as the hmodel
argument to msm
.
If hmmdist=FALSE
, returns a list comprised of the corresponding input
arguments for the constructor functions, i.e. parameter values of HMM emission
distributions. The list has one element per state. Each of these elements
has one element per parameter (for univariate HMMs), or one element per outcome
distribution, which in turn has one element per parameter (for multivariate HMMs).
Will Hulme https://github.com/wjchulme
and Chris Jackson.
Extract the log-likelihood and the number of parameters of a model fitted
with msm
.
## S3 method for class 'msm' logLik(object, by.subject = FALSE, ...)
## S3 method for class 'msm' logLik(object, by.subject = FALSE, ...)
object |
A fitted multi-state model object, as returned by
|
by.subject |
Return vector of subject-specific log-likelihoods, which should sum to the total log-likelihood. |
... |
(unused) further arguments passed to or from other methods. |
The log-likelihood of the model represented by 'object' evaluated at the maximum likelihood estimates.
Akaike's information criterion can also be computed using
AIC(object)
.
C. H. Jackson [email protected]
Likelihood ratio test between two or more fitted multi-state models
lrtest.msm(...)
lrtest.msm(...)
... |
Two or more fitted multi-state models, as returned by
|
A matrix with three columns, giving the likelihood ratio statistic, difference in degrees of freedom and the chi-squared p-value for a comparison of the first model supplied with each subsequent model.
The comparison between models will only be valid if they are fitted to the same dataset. This may be a problem if there are missing values and R's default of 'na.action = na.omit' is used.
The likelihood ratio statistic only has the indicated chi-squared
distribution if the models are nested. An alternative for comparing
non-nested models is Akaike's information criterion. This can be computed
for one or more fitted msm
models x,y,...
using
AIC(x,y,...)
.
Calculates the exponential of a square matrix.
MatrixExp(mat, t = 1, method = NULL, ...)
MatrixExp(mat, t = 1, method = NULL, ...)
mat |
A square matrix |
t |
An optional scaling factor for |
method |
Under the default of Otherwise, for backwards compatibility, the following options, which use
code in the msm package, are available: |
... |
Arguments to pass to |
See the expm
documentation for details of the algorithms
it uses.
Generally the exponential of a square matrix
can often be
calculated as
where is a diagonal matrix with the eigenvalues of
on the
diagonal,
is a diagonal matrix with the exponentiated
eigenvalues of
on the diagonal, and
is a matrix whose
columns are the eigenvectors of
.
This method of calculation is used if "pade"
or "series"
is
supplied but has distinct eigenvalues. I If
has repeated
eigenvalues, then its eigenvector matrix may be non-invertible. In this
case, the matrix exponential is calculated using the Pade approximation
defined by Moler and van Loan (2003), or the less robust power series
approximation,
For a continuous-time homogeneous Markov process with transition intensity
matrix , the probability of occupying state
at time
conditional on occupying state
at time
is given by the
entry of the matrix
.
If mat
is a valid transition intensity matrix for a continuous-time
Markov model (i.e. diagonal entries non-positive, off-diagonal entries
non-negative, rows sum to zero), then for certain simpler model structures,
there are analytic formulae for the individual entries of the exponential of
mat
. These structures are listed in the PDF manual and the formulae
are coded in the msm source file src/analyticp.c
. These
formulae are only used if method="analytic"
. This is more efficient,
but it is not the default in MatrixExp
because the code is not robust
to extreme values. However it is the default when calculating likelihoods
for models fitted by msm
.
The implementation of the Pade approximation used by method="pade"
was taken from JAGS by Martyn Plummer
(https://mcmc-jags.sourceforge.io).
The exponentiated matrix . Or, if
t
is a vector of length 2 or more, an array of exponentiated matrices.
Cox, D. R. and Miller, H. D. The theory of stochastic processes, Chapman and Hall, London (1965)
Moler, C and van Loan, C (2003). Nineteen dubious ways to compute the exponential of a matrix, twenty-five years later. SIAM Review 45, 3–49.
Truncated Normal and Uniform distributions, where the response is also subject to a Normally distributed measurement error.
dmenorm( x, mean = 0, sd = 1, lower = -Inf, upper = Inf, sderr = 0, meanerr = 0, log = FALSE ) pmenorm( q, mean = 0, sd = 1, lower = -Inf, upper = Inf, sderr = 0, meanerr = 0, lower.tail = TRUE, log.p = FALSE ) qmenorm( p, mean = 0, sd = 1, lower = -Inf, upper = Inf, sderr = 0, meanerr = 0, lower.tail = TRUE, log.p = FALSE ) rmenorm(n, mean = 0, sd = 1, lower = -Inf, upper = Inf, sderr = 0, meanerr = 0) dmeunif(x, lower = 0, upper = 1, sderr = 0, meanerr = 0, log = FALSE) pmeunif( q, lower = 0, upper = 1, sderr = 0, meanerr = 0, lower.tail = TRUE, log.p = FALSE ) qmeunif( p, lower = 0, upper = 1, sderr = 0, meanerr = 0, lower.tail = TRUE, log.p = FALSE ) rmeunif(n, lower = 0, upper = 1, sderr = 0, meanerr = 0)
dmenorm( x, mean = 0, sd = 1, lower = -Inf, upper = Inf, sderr = 0, meanerr = 0, log = FALSE ) pmenorm( q, mean = 0, sd = 1, lower = -Inf, upper = Inf, sderr = 0, meanerr = 0, lower.tail = TRUE, log.p = FALSE ) qmenorm( p, mean = 0, sd = 1, lower = -Inf, upper = Inf, sderr = 0, meanerr = 0, lower.tail = TRUE, log.p = FALSE ) rmenorm(n, mean = 0, sd = 1, lower = -Inf, upper = Inf, sderr = 0, meanerr = 0) dmeunif(x, lower = 0, upper = 1, sderr = 0, meanerr = 0, log = FALSE) pmeunif( q, lower = 0, upper = 1, sderr = 0, meanerr = 0, lower.tail = TRUE, log.p = FALSE ) qmeunif( p, lower = 0, upper = 1, sderr = 0, meanerr = 0, lower.tail = TRUE, log.p = FALSE ) rmeunif(n, lower = 0, upper = 1, sderr = 0, meanerr = 0)
x , q
|
vector of quantiles. |
mean |
vector of means. |
sd |
vector of standard deviations. |
lower |
lower truncation point. |
upper |
upper truncation point. |
sderr |
Standard deviation of measurement error distribution. |
meanerr |
Optional shift for the measurement error distribution. |
log , log.p
|
logical; if TRUE, probabilities |
lower.tail |
logical; if TRUE (default), probabilities are |
p |
vector of probabilities. |
n |
number of observations. If |
The normal distribution with measurement error has density
where
is the mean of the original Normal distribution before
truncation,
is the corresponding standard deviation,
is the upper truncation point,
is the lower
truncation point,
is the standard deviation
of the additional measurement error,
is the
mean of the measurement error (usually 0).
is the
density of the corresponding normal distribution, and
is the distribution function of the corresponding
normal distribution.
The uniform distribution with measurement error has density
These are calculated from the original truncated Normal or Uniform density
functions as
If sderr
and meanerr
are not specified they assume the default
values of 0, representing no measurement error variance, and no constant
shift in the measurement error, respectively.
Therefore, for example with no other arguments, dmenorm(x)
, is simply
equivalent to dtnorm(x)
, which in turn is equivalent to
dnorm(x)
.
These distributions were used by Satten and Longini (1996) for CD4 cell counts conditionally on hidden Markov states of HIV infection, and later by Jackson and Sharples (2002) for FEV1 measurements conditionally on states of chronic lung transplant rejection.
These distribution functions are just provided for convenience, and are not
optimised for numerical accuracy or speed. To fit a hidden Markov model
with these response distributions, use a hmmMETNorm
or
hmmMEUnif
constructor. See the hmm-dists
help
page for further details.
dmenorm
, dmeunif
give the density, pmenorm
,
pmeunif
give the distribution function, qmenorm
,
qmeunif
give the quantile function, and rmenorm
,
rmeunif
generate random deviates, for the Normal and Uniform versions
respectively.
C. H. Jackson [email protected]
Satten, G.A. and Longini, I.M. Markov chains with measurement error: estimating the 'true' course of a marker of the progression of human immunodeficiency virus disease (with discussion) Applied Statistics 45(3): 275-309 (1996)
Jackson, C.H. and Sharples, L.D. Hidden Markov models for the onset and progression of bronchiolitis obliterans syndrome in lung transplant recipients Statistics in Medicine, 21(1): 113–128 (2002).
## what does the distribution look like? x <- seq(50, 90, by=1) plot(x, dnorm(x, 70, 10), type="l", ylim=c(0,0.06)) ## standard Normal lines(x, dtnorm(x, 70, 10, 60, 80), type="l") ## truncated Normal ## truncated Normal with small measurement error lines(x, dmenorm(x, 70, 10, 60, 80, sderr=3), type="l")
## what does the distribution look like? x <- seq(50, 90, by=1) plot(x, dnorm(x, 70, 10), type="l", ylim=c(0,0.06)) ## standard Normal lines(x, dtnorm(x, 70, 10, 60, 80), type="l") ## truncated Normal ## truncated Normal with small measurement error lines(x, dmenorm(x, 70, 10, 60, 80, sderr=3), type="l")
msm
objects.Extract the data from a multi-state model fitted with msm
.
## S3 method for class 'msm' model.frame(formula, agg = FALSE, ...) ## S3 method for class 'msm' model.matrix(object, model = "intens", state = 1, ...)
## S3 method for class 'msm' model.frame(formula, agg = FALSE, ...) ## S3 method for class 'msm' model.matrix(object, model = "intens", state = 1, ...)
formula |
A fitted multi-state model object, as returned by
|
agg |
Return the model frame in the efficient aggregated form used to
calculate the likelihood internally for non-hidden Markov models. This has
one row for each unique combination of from-state, to-state, time lag,
covariate value and observation type. The variable named |
... |
Further arguments (not used). |
object |
A fitted multi-state model object, as returned by
|
model |
|
state |
State corresponding to the required covariate design matrix in a hidden Markov model. |
model.frame
returns a data frame with all the original
variables used for the model fit, with any missing data removed (see
na.action
in msm
). The state, time, subject,
obstype
and obstrue
variables are named "(state)"
,
"(time)"
, "(subject)"
, "(obstype)"
and
"(obstrue)"
respectively (note the brackets). A variable called
"(obs)"
is the observation number from the original data before any
missing data were dropped. The variable "(pcomb)"
is used for
computing the likelihood for hidden Markov models, and identifies which
distinct time difference, obstype
and covariate values (thus which
distinct interval transition probability matrix) each observation
corresponds to.
The model frame object has some other useful attributes, including
"usernames"
giving the user's original names for these variables
(used for model refitting, e.g. in bootstrapping or cross validation) and
"covnames"
identifying which ones are covariates.
model.matrix
returns a design matrix for a part of the model that
includes covariates. The required part is indicated by the "model"
argument.
For time-inhomogeneous models fitted with "pci"
, these datasets will
have imputed observations at each time change point, indicated where the
variable "(pci.imp)"
in the model frame is 1. The model matrix for
intensities will have factor contrasts for the timeperiod
covariate.
C. H. Jackson [email protected]
msm
, model.frame
,
model.matrix
.
Fit a continuous-time Markov or hidden Markov multi-state model by maximum likelihood. Observations of the process can be made at arbitrary times, or the exact times of transition between states can be known. Covariates can be fitted to the Markov chain transition intensities or to the hidden Markov observation process.
msm( formula, subject = NULL, data = list(), qmatrix, gen.inits = FALSE, ematrix = NULL, hmodel = NULL, obstype = NULL, obstrue = NULL, covariates = NULL, covinits = NULL, constraint = NULL, misccovariates = NULL, misccovinits = NULL, miscconstraint = NULL, hcovariates = NULL, hcovinits = NULL, hconstraint = NULL, hranges = NULL, qconstraint = NULL, econstraint = NULL, initprobs = NULL, est.initprobs = FALSE, initcovariates = NULL, initcovinits = NULL, deathexact = NULL, death = NULL, exacttimes = FALSE, censor = NULL, censor.states = NULL, pci = NULL, phase.states = NULL, phase.inits = NULL, subject.weights = NULL, cl = 0.95, fixedpars = NULL, center = TRUE, opt.method = "optim", hessian = NULL, use.deriv = TRUE, use.expm = TRUE, analyticp = TRUE, na.action = na.omit, ... )
msm( formula, subject = NULL, data = list(), qmatrix, gen.inits = FALSE, ematrix = NULL, hmodel = NULL, obstype = NULL, obstrue = NULL, covariates = NULL, covinits = NULL, constraint = NULL, misccovariates = NULL, misccovinits = NULL, miscconstraint = NULL, hcovariates = NULL, hcovinits = NULL, hconstraint = NULL, hranges = NULL, qconstraint = NULL, econstraint = NULL, initprobs = NULL, est.initprobs = FALSE, initcovariates = NULL, initcovinits = NULL, deathexact = NULL, death = NULL, exacttimes = FALSE, censor = NULL, censor.states = NULL, pci = NULL, phase.states = NULL, phase.inits = NULL, subject.weights = NULL, cl = 0.95, fixedpars = NULL, center = TRUE, opt.method = "optim", hessian = NULL, use.deriv = TRUE, use.expm = TRUE, analyticp = TRUE, na.action = na.omit, ... )
formula |
A formula giving the vectors containing the observed states and the corresponding observation times. For example,
Observed states should be numeric variables in the set The times can indicate different types of observation scheme, so be careful
to choose the correct For hidden Markov models, |
subject |
Vector of subject identification numbers for the data
specified by |
data |
Optional data frame in which to interpret the variables supplied
in |
qmatrix |
Matrix which indicates the allowed transitions in the
continuous-time Markov chain, and optionally also the initial values of
those transitions. If an instantaneous transition is not allowed from state
If supplying initial values yourself, then the non-zero entries should be
those values. If using For example,
represents a 'health - disease - death' model, with initial transition intensities 0.1 from health to disease, 0.01 from health to death, 0.1 from disease to health, and 0.2 from disease to death. If the states represent ordered levels of severity of a disease, then this
matrix should usually only allow transitions between adjacent states. For
example, if someone was observed in state 1 ("mild") at their first
observation, followed by state 3 ("severe") at their second observation,
they are assumed to have passed through state 2 ("moderate") in between, and
the 1,3 entry of The initial intensities given here are with any covariates set to their
means in the data (or set to zero, if |
gen.inits |
If |
ematrix |
If misclassification between states is to be modelled, this
should be a matrix of initial values for the misclassification
probabilities. The rows represent underlying states, and the columns
represent observed states. If an observation of state
represents a model in which misclassifications are only permitted between adjacent states. If any probabilities are constrained to be equal using For an alternative way of specifying misclassification models, see
|
hmodel |
Specification of the hidden Markov model (HMM). This should
be a list of return values from HMM constructor functions. Each element of
the list corresponds to the outcome model conditionally on the corresponding
underlying state. Univariate constructors are described in
the For example, consider a three-state hidden Markov model. Suppose the observations in underlying state 1 are generated from a Normal distribution with mean 100 and standard deviation 16, while observations in underlying state 2 are Normal with mean 54 and standard deviation 18. Observations in state 3, representing death, are exactly observed, and coded as 999 in the data. This model is specified as
The mean and standard deviation parameters are estimated starting from these
initial values. If multiple parameters are constrained to be equal using
See the A misclassification model, that is, a hidden Markov model where the outcomes
are misclassified observations of the underlying states, can either be
specified using a list of For example,
is equivalent to
|
obstype |
A vector specifying the observation scheme for each row of
the data. This can be included in the data frame
If This is a generalisation of the
|
obstrue |
In misclassification models specified with In HMMs specified with HMMs where the true state is known to be within a specific set at specific
times can be defined with a combination of |
covariates |
A formula or a list of formulae representing the covariates on the transition intensities via a log-linear model. If a single formula is supplied, like
then these covariates are assumed to apply to all intensities. If a named list is supplied, then this defines a potentially different model for each named intensity. For example,
specifies an age effect on the state 1 - state 2 transition, additive age
and treatment effects on the state 2 - state 3 transition, but no covariates
on any other transitions that are allowed by the If covariates are time dependent, they are assumed to be constant in between
the times they are observed, and the transition probability between a pair
of times |
covinits |
Initial values for log-linear effects of covariates on the transition intensities. This should be a named list with each element corresponding to a covariate. A single element contains the initial values for that covariate on each transition intensity, reading across the rows in order. For a pair of effects constrained to be equal, the initial value for the first of the two effects is used. For example, for a model with the above For factor covariates, name each level by concatenating the name of the
covariate with the level name, quoting if necessary. For example, for a
covariate
If not specified or wrongly specified, initial values are assumed to be zero. |
constraint |
A list of one numeric vector for each named covariate. The
vector indicates which covariate effects on intensities are constrained to
be equal. Take, for example, a model with five transition intensities and
two covariates. Specifying
constrains the effect of age to be equal for the first three intensities, and equal for the fourth and fifth. The effect of treatment is assumed to be different for each intensity. Any vector of increasing numbers can be used as indicators. The intensity parameters are assumed to be ordered by reading across the rows of the transition matrix, starting at the first row, ignoring the diagonals. Negative elements of the vector can be used to indicate that particular covariate effects are constrained to be equal to minus some other effects. For example:
constrains the second and third age effects to be equal, the first effect to be minus the second, and the fifth age effect to be minus the fourth. For example, it may be realisitic that the effect of a covariate on the "reverse" transition rate from state 2 to state 1 is minus the effect on the "forward" transition rate, state 1 to state 2. Note that it is not possible to specify exactly which of the covariate effects are constrained to be positive and which negative. The maximum likelihood estimation chooses the combination of signs which has the higher likelihood. For categorical covariates, defined as factors, specify constraints as
follows:
where Make sure the
sets the first (baseline) level of unordered factors to zero, then the baseline level is ignored in this specification. To assume no covariate effect on a certain transition, use the
|
misccovariates |
A formula representing the covariates on the
misclassification probabilities, analogously to This must be a single formula - lists are not supported, unlike
|
misccovinits |
Initial values for the covariates on the
misclassification probabilities, defined in the same way as |
miscconstraint |
A list of one vector for each named covariate on
misclassification probabilities. The vector indicates which covariate
effects on misclassification probabilities are constrained to be equal,
analogously to |
hcovariates |
List of formulae the same length as |
hcovinits |
Initial values for the hidden Markov model covariate
effects. A list of the same length as |
hconstraint |
A named list. Each element is a vector of constraints on the named hidden Markov model parameter. The vector has length equal to the number of times that class of parameter appears in the whole model. For example consider the three-state hidden Markov model described above,
with normally-distributed outcomes for states 1 and 2. To constrain the
outcome variance to be equal for states 1 and 2, and to also constrain the
effect of
Note this excludes initial state occupancy probabilities and covariate effects on those probabilities, which cannot be constrained. |
hranges |
Range constraints for hidden Markov model parameters.
Supplied as a named list, with each element corresponding to the named
hidden Markov model parameter. This element is itself a list with two
elements, vectors named "lower" and "upper". These vectors each have length
equal to the number of times that class of parameter appears in the whole
model, and give the corresponding mininum amd maximum allowable values for
that parameter. Maximum likelihood estimation is performed with these
parameters constrained in these ranges (through a log or logit-type
transformation). Lower bounds of For example, in the three-state model above, to constrain the mean for state 1 to be between 0 and 6, and the mean of state 2 to be between 7 and 12, supply
These default to the natural ranges, e.g. the positive real line for
variance parameters, and [0,1] for probabilities. Therefore Initial values should be strictly within any ranges, and not on the range boundary, otherwise optimisation will fail with a "non-finite value" error. |
qconstraint |
A vector of indicators specifying which baseline transition intensities are equal. For example,
constrains the third and fourth intensities to be equal, in a model with
four allowed instantaneous transitions. When there are covariates on the
intensities and |
econstraint |
A similar vector of indicators specifying which baseline
misclassification probabilities are constrained to be equal. Only used if
the model is specified using |
initprobs |
Only used in hidden Markov models. Underlying state
occupancy probabilities at each subject's first observation. Can either be
a vector of If these are estimated (see |
est.initprobs |
Only used in hidden Markov models. If Note that the free parameters during this estimation exclude the state 1 occupancy probability, which is fixed at one minus the sum of the other probabilities. |
initcovariates |
Formula representing covariates on the initial state
occupancy probabilities, via multinomial logistic regression. The linear
effects of these covariates, observed at the individual's first observation
time, operate on the log ratio of the state |
initcovinits |
Initial values for the covariate effects
|
deathexact |
Vector of indices of absorbing states whose time of entry
is known exactly, but the individual is assumed to be in an unknown
transient state ("alive") at the previous instant. This is the usual
situation for times of death in chronic disease monitoring data. For
example, if you specify See the The Note that you do not always supply a |
death |
Old name for the |
exacttimes |
By default, the transitions of the Markov process are
assumed to take place at unknown occasions in between the observation times.
If Note that the complete history of the multi-state process is known with this type of data. The models which msm fits have the strong assumption of constant (or piecewise-constant) transition rates. Knowing the exact transition times allows more realistic models to be fitted with other packages. For example parametric models with sojourn distributions more flexible than the exponential can be fitted with the flexsurv package, or semi-parametric models can be implemented with survival in conjunction with mstate. |
censor |
A state, or vector of states, which indicates censoring.
Censoring means that the observed state is known only to be one of a
particular set of states. For example, Note that in contrast to the usual terminology of survival analysis, here it
is the state which is considered to be censored, rather than the
event time. If at the end of a study, an individual has not died,
but their true state is known, then For hidden Markov models, censoring may indicate either a set of possible
observed states, or a set of (hidden) true states. The later case is
specified by setting the relevant elements of Note in particular that general time-inhomogeneous Markov models with
piecewise constant transition intensities can be constructed using the
Not supported for multivariate hidden Markov models specified with
|
censor.states |
Specifies the underlying states which censored
observations can represent. If
means that observations coded 99 represent either state 2 or state 3, while observations coded 999 are really either state 3 or state 4. |
pci |
Model for piecewise-constant intensities. Vector of cut points defining the times, since the start of the process, at which intensities change for all subjects. For example
specifies that the intensity changes at time points 5 and 10. This will
automatically construct a model with a categorical (factor) covariate called
Thus if To assume piecewise constant intensities for some transitions but not others
with Internally, this works by inserting censored observations in the data at times when the intensity changes but the state is not observed. If the supplied times are outside the range of the time variable in the
data, After fitting a time-inhomogeneous model,
This facility does not support interactions between time and other
covariates. Such models need to be specified "by hand", using a state
variable with censored observations inserted. Note that the Note that you do not need to use
|
phase.states |
Indices of states which have a two-phase sojourn distribution. This defines a semi-Markov model, in which the hazard of an onward transition depends on the time spent in the state. This uses the technique described by Titman and Sharples (2009). A hidden Markov model is automatically constructed on an expanded state space, where the phases correspond to the hidden states. The "tau" proportionality constraint described in this paper is currently not supported. Covariates, constraints, Hidden Markov models can additionally be given phased states. The user
supplies an outcome distribution for each original state using
Output functions are presented as it were a hidden Markov model on the expanded state space, for example, transition probabilities between states, covariate effects on transition rates, or prevalence counts, are not aggregated over the hidden phases. Numerical estimation will be unstable when there is weak evidence for a two-phase sojourn distribution, that is, if the model is close to Markov. See This is an experimental feature, and some functions are not implemented. Please report any experiences of using this feature to the author! |
phase.inits |
Initial values for phase-type models. A list with one component for each "two-phased" state. Each component is itself a list of two elements. The first of these elements is a scalar defining the transition intensity from phase 1 to phase 2. The second element is a matrix, with one row for each potential destination state from the two-phased state, and two columns. The first column is the transition rate from phase 1 to the destination state, and the second column is the transition rate from phase 2 to the destination state. If there is only one destination state, then this may be supplied as a vector. In phase type models, the initial values for transition rates out of
non-phased states are taken from the |
subject.weights |
Name of a variable in the data (unquoted) giving weights to apply to each subject in the data when calculating the log-likelihood as a weighted sum over subjects. These are taken from the first observation for each subject, and any weights supplied for subsequent observations are not used. Weights at the observation level are not supported. |
cl |
Width of symmetric confidence intervals for maximum likelihood estimates, by default 0.95. |
fixedpars |
Vector of indices of parameters whose values will be fixed at their initial values during the optimisation. These are given in the order: transition intensities (reading across rows of the transition matrix), covariates on intensities (ordered by intensities within covariates), hidden Markov model parameters, including misclassification probabilities or parameters of HMM outcome distributions (ordered by parameters within states), hidden Markov model covariate parameters (ordered by covariates within parameters within states), initial state occupancy probabilities (excluding the first probability, which is fixed at one minus the sum of the others). If there are equality constraints on certain parameters, then
To fix all parameters, specify This can be useful for profiling likelihoods, and building complex models stage by stage. |
center |
If |
opt.method |
If "optim", "nlm" or "bobyqa", then the corresponding R
function will be used for maximum likelihood estimation.
If "fisher", then a specialised Fisher scoring method is used (Kalbfleisch
and Lawless, 1985) which can be faster than the generic methods, though less
robust. This is only available for Markov models with panel data
( |
hessian |
If If |
use.deriv |
If |
use.expm |
If |
analyticp |
By default, the likelihood for certain simpler 3, 4 and 5
state models is calculated using an analytic expression for the transition
probability (P) matrix. For all other models, matrix exponentiation is used
to obtain P. To revert to the original method of using the matrix
exponential for all models, specify |
na.action |
What to do with missing data: either |
... |
Optional arguments to the general-purpose optimisation routine,
It is often worthwhile to normalize the optimisation using
If 'false' convergence is reported and the standard errors cannot be
calculated due to a non-positive-definite Hessian, then consider tightening
the tolerance criteria for convergence. If the optimisation takes a long
time, intermediate steps can be printed using the For the Fisher scoring method, a |
For full details about the methodology behind the msm package, refer to the PDF manual ‘msm-manual.pdf’ in the ‘doc’ subdirectory of the package. This includes a tutorial in the typical use of msm. The paper by Jackson (2011) in Journal of Statistical Software presents the material in this manual in a more concise form.
msm was designed for fitting continuous-time Markov models,
processes where transitions can occur at any time. These models are defined
by intensities, which govern both the time spent in the current state
and the probabilities of the next state. In discrete-time models,
transitions are known in advance to only occur at multiples of some time
unit, and the model is purely governed by the probability distributions of
the state at the next time point, conditionally on the state at the current
time. These can also be fitted in msm, assuming that there is a
continuous-time process underlying the data. Then the fitted transition
probability matrix over one time period, as returned by
pmatrix.msm(...,t=1)
is equivalent to the matrix that governs the
discrete-time model. However, these can be fitted more efficiently using
multinomial logistic regression, for example, using multinom
from the
R package nnet (Venables and Ripley, 2002).
For simple continuous-time multi-state Markov models, the likelihood is
calculated in terms of the transition intensity matrix . When the
data consist of observations of the Markov process at arbitrary times, the
exact transition times are not known. Then the likelihood is calculated
using the transition probability matrix
, where
is the matrix exponential. If state
is observed at time
and state
is observed at time
,
then the contribution to the likelihood from this pair of observations is
the
element of
. See, for example, Kalbfleisch and
Lawless (1985), Kay (1986), or Gentleman et al. (1994).
For hidden Markov models, the likelihood for an individual with
observations is calculated directly by summing over the unknown state at
each time, producing a product of
matrices. The calculation is a
generalisation of the method described by Satten and Longini (1996), and
also by Jackson and Sharples (2002), and Jackson et al. (2003).
There must be enough information in the data on each state to estimate each transition rate, otherwise the likelihood will be flat and the maximum will not be found. It may be appropriate to reduce the number of states in the model, the number of allowed transitions, or the number of covariate effects, to ensure convergence. Hidden Markov models, and situations where the value of the process is only known at a series of snapshots, are particularly susceptible to non-identifiability, especially when combined with a complex transition matrix. Choosing an appropriate set of initial values for the optimisation can also be important. For flat likelihoods, 'informative' initial values will often be required. See the PDF manual for other tips.
To obtain summary information from models fitted by the
msm
function, it is recommended to use extractor functions
such as qmatrix.msm
, pmatrix.msm
,
sojourn.msm
, msm.form.qoutput
. These provide
estimates and confidence intervals for quantities such as transition
probabilities for given covariate values.
For advanced use, it may be necessary to directly use information stored in
the object returned by msm
. This is documented in the help
page msm.object
.
Printing a msm
object by typing the object's name at the command line
implicitly invokes print.msm
. This formats and prints the
important information in the model fit, and also returns that information in
an R object. This includes estimates and confidence intervals for the
transition intensities and (log) hazard ratios for the corresponding
covariates. When there is a hidden Markov model, the chief information in
the hmodel
component is also formatted and printed. This includes
estimates and confidence intervals for each parameter.
C. H. Jackson [email protected]
Jackson, C.H. (2011). Multi-State Models for Panel Data: The msm Package for R., Journal of Statistical Software, 38(8), 1-29. URL http://www.jstatsoft.org/v38/i08/.
Kalbfleisch, J., Lawless, J.F., The analysis of panel data under a Markov assumption Journal of the Americal Statistical Association (1985) 80(392): 863–871.
Kay, R. A Markov model for analysing cancer markers and disease states in survival studies. Biometrics (1986) 42: 855–865.
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.
Satten, G.A. and Longini, I.M. Markov chains with measurement error: estimating the 'true' course of a marker of the progression of human immunodeficiency virus disease (with discussion) Applied Statistics 45(3): 275-309 (1996)
Jackson, C.H. and Sharples, L.D. Hidden Markov models for the onset and progression of bronchiolitis obliterans syndrome in lung transplant recipients Statistics in Medicine, 21(1): 113–128 (2002).
Jackson, C.H., Sharples, L.D., Thompson, S.G. and Duffy, S.W. and Couto, E. Multi-state Markov models for disease progression with classification error. The Statistician, 52(2): 193–209 (2003)
Titman, A.C. and Sharples, L.D. Semi-Markov models with phase-type sojourn distributions. Biometrics 66, 742-752 (2009).
Venables, W.N. and Ripley, B.D. (2002) Modern Applied Statistics with S, second edition. Springer.
simmulti.msm
, plot.msm
,
summary.msm
, qmatrix.msm
,
pmatrix.msm
, sojourn.msm
.
### Heart transplant data ### For further details and background to this example, see ### Jackson (2011) or the PDF manual in the doc directory. print(cav[1:10,]) twoway4.q <- rbind(c(-0.5, 0.25, 0, 0.25), c(0.166, -0.498, 0.166, 0.166), c(0, 0.25, -0.5, 0.25), c(0, 0, 0, 0)) statetable.msm(state, PTNUM, data=cav) crudeinits.msm(state ~ years, PTNUM, data=cav, qmatrix=twoway4.q) cav.msm <- msm( state ~ years, subject=PTNUM, data = cav, qmatrix = twoway4.q, deathexact = 4, control = list ( trace = 2, REPORT = 1 ) ) cav.msm qmatrix.msm(cav.msm) pmatrix.msm(cav.msm, t=10) sojourn.msm(cav.msm)
### Heart transplant data ### For further details and background to this example, see ### Jackson (2011) or the PDF manual in the doc directory. print(cav[1:10,]) twoway4.q <- rbind(c(-0.5, 0.25, 0, 0.25), c(0.166, -0.498, 0.166, 0.166), c(0, 0.25, -0.5, 0.25), c(0, 0, 0, 0)) statetable.msm(state, PTNUM, data=cav) crudeinits.msm(state ~ years, PTNUM, data=cav, qmatrix=twoway4.q) cav.msm <- msm( state ~ years, subject=PTNUM, data = cav, qmatrix = twoway4.q, deathexact = 4, control = list ( trace = 2, REPORT = 1 ) ) cav.msm qmatrix.msm(cav.msm) pmatrix.msm(cav.msm, t=10) sojourn.msm(cav.msm)
Extract estimates and confidence intervals for transition intensities (or
misclassification probabilities), and their covariate effects, in a tidy
matrix format with one row per transition. This is used by the print method
(print.msm
) for msm
objects. Covariate effects are
returned as hazard or odds ratios, not on the log scale.
msm.form.qoutput(x, covariates = "mean", cl = 0.95, digits = 4, ...) msm.form.eoutput(x, covariates = "mean", cl = 0.95, digits = 4, ...)
msm.form.qoutput(x, covariates = "mean", cl = 0.95, digits = 4, ...) msm.form.eoutput(x, covariates = "mean", cl = 0.95, digits = 4, ...)
x |
A fitted multi-state model object, as returned by
|
covariates |
Covariate values defining the "baseline" parameters (see
|
cl |
Width of the symmetric confidence interval to present. Defaults to 0.95. |
digits |
Minimum number of significant digits for the formatted
character matrix returned as an attribute. This is passed to
|
... |
Other arguments to be passed to |
A numeric matrix with one row per transition, and one column for
each estimate or confidence limit. The "formatted"
attribute
contains the same results formatted for pretty printing.
msm.form.qoutput
returns the transition intensities and their
covariates, and msm.form.eoutput
returns the misclassification
probabilities and their covariates.
C. H. Jackson [email protected]
The msm
function returns a list with the following components.
These are intended for developers and confident users. To extract results
from fitted model objects, functions such as qmatrix.msm
or
print.msm
should be used instead.
call |
The original call to |
Qmatrices |
A list of matrices. The first
component, labelled |
QmatricesSE |
The standard error matrices corresponding to
|
QmatricesL , QmatricesU
|
Corresponding lower and
upper symmetric confidence limits, of width 0.95 unless specified otherwise
by the |
Ematrices |
A list of matrices. The first
component, labelled |
EmatricesSE |
The standard error matrices corresponding to
|
EmatricesL , EmatricesU
|
Corresponding lower and
upper symmetric confidence limits, of width 0.95 unless specified otherwise
by the |
minus2loglik |
Minus twice the maximised log-likelihood. |
deriv |
Derivatives of the minus twice log-likelihood at its maximum. |
estimates |
Vector of untransformed maximum likelihood estimates
returned from |
estimates.t |
Vector of transformed maximum likelihood estimates with intensities and probabilities on their natural scales. |
fixedpars |
Indices of |
center |
Indicator for whether the estimation was performed with covariates centered on their means in the data. |
covmat |
Covariance matrix corresponding to |
ci |
Matrix of confidence intervals corresponding to
|
opt |
Return value from the optimisation routine (such as
|
foundse |
Logical value indicating whether the Hessian was positive-definite at the supposed maximum of the likelihood. If not, the covariance matrix of the parameters is unavailable. In these cases the optimisation has probably not converged to a maximum. |
data |
A list giving the data used for the model fit, for use in
post-processing. To extract it, use the methods
The format of this element changed in version 1.4 of msm, so that it
now contains a |
qmodel |
A list of objects representing the
transition matrix structure and options for likelihood calculation. See
|
emodel |
A list of objects representing the misclassification model
structure, for models specified using the |
qcmodel |
A list
of objects representing the model for covariates on transition intensities.
See |
ecmodel |
A list of objects
representing the model for covariates on transition intensities. See
|
hmodel |
A list of objects representing
the hidden Markov model structure. See |
cmodel |
A list giving information about censored states. See
|
pci |
Cut points for time-varying
intensities, as supplied to |
paramdata |
A list giving
information about the parameters of the multi-state model. See
|
cl |
Confidence interval width, as
supplied to |
covariates |
Formula for covariates on
intensities, as supplied to |
misccovariates |
Formula for covariates on misclassification
probabilities, as supplied to |
hcovariates |
Formula
for covariates on hidden Markov model outcomes, as supplied to
|
initcovariates |
Formula for covariates on initial
state occupancy probabilities in hidden Markov models, as supplied to
|
sojourn |
A list as returned by
|
Converts longitudinal data for a msm
model fit, where
observations represent the exact transition times of the process, to
counting process data. This enables, for example, flexible parametric
multi-state models to be fitted with flexsurvreg
from the flexsurv package, or semiparametric models to be implemented
with coxph
and the mstate package.
msm2Surv(data, subject, time, state, covs = NULL, Q)
msm2Surv(data, subject, time, state, covs = NULL, Q)
data |
Data frame in the format expected by a |
subject |
Name of the subject ID in the data (character format, i.e. quoted). |
time |
Name of the time variable in the data (character). |
state |
Name of the state variable in the data (character). |
covs |
Vector of covariate names to carry through (character). If not supplied, this is taken to be all remaining variables in the data. |
Q |
Transition intensity matrix. This should have number of rows and
number of columns both equal to the number of states. If an instantaneous
transition is not allowed from state |
For example, if the data supplied to msm
look like this:
subj |
days |
status |
age |
treat |
1 | 0 | 1 | 66 | 1 |
1 | 27 | 2 | 66 | 1 |
1 | 75 | 3 | 66 | 1 |
1 | 97 | 4 | 66 | 1 |
1 | 1106 | 4 | 69 | 1 |
2 | 0 | 1 | 49 | 0 |
2 | 90 | 2 | 49 | 0 |
2 | 1037 | 2 | 51 | 0 |
then the output of msm2Surv
will be a data frame looking like
this:
id |
from |
to |
Tstart |
Tstop |
time |
status |
age |
treat |
trans
|
1 | 1 | 2 | 0 | 27 | 27 | 1 | 66 | 1 | 1 |
1 | 1 | 4 | 0 | 27 | 27 | 0 | 66 | 1 | 2 |
1 | 2 | 3 | 27 | 75 | 48 | 1 | 66 | 1 | 3 |
1 | 2 | 4 | 27 | 75 | 48 | 0 | 66 | 1 | 4 |
1 | 3 | 4 | 75 | 97 | 22 | 1 | 69 | 1 | 5 |
2 | 1 | 2 | 0 | 90 | 90 | 1 | 49 | 0 | 1 |
2 | 1 | 4 | 0 | 90 | 90 | 0 | 49 | 0 | 2 |
2 | 2 | 3 | 90 | 1037 | 947 | 0 | 49 | 0 | 3 |
2 | 2 | 4 | 90 | 1037 | 947 | 0 | 49 | 0 | 4 |
At 27 days, subject 1 is observed to move from state 1 to state 2 (first row, status 1), which means that their potential transition from state 1 to state 4 is censored (second row, status 0).
See the mstate package and the references below for more details of this data format and using it for semi-parametric multi-state modelling.
A data frame of class "msdata"
, with rows representing
observed or censored transitions. There will be one row for each observed
transition in the original data, and additional rows for every potential
transition that could have occurred out of each observed state.
The data frame will have columns called:
id |
Subject ID |
from |
Starting state of the transition |
to |
Finishing state of the transition |
Tstart |
The starting time of the transition |
Tstop |
The finishing time of the transition |
time |
The time difference = |
status |
Event or censoring indicator, with 1 indicating an observed transition, and 0 indicating censoring |
trans |
Transition number |
and any remaining columns will represent covariates. Any covariates whose
names clash with the standard variables in the returned data ("id"
,
"from"
, "to"
, "Tstart"
, "Tstop"
, "time"
,
"status"
or "trans"
) have ".2"
appended to their names.
The transition matrix in mstate format is stored in the trans
attribute of the returned object. See the example code below.
C. H. Jackson [email protected]
Putter H, Fiocco M, Geskus RB (2007). Tutorial in biostatistics: Competing risks and multi-state models. Statistics in Medicine 26: 2389-2430.
Liesbeth C. de Wreede, Marta Fiocco, Hein Putter (2011). mstate: An R Package for the Analysis of Competing Risks and Multi-State Models. Journal of Statistical Software, 38(7), 1-30.
Jackson, C. H. (2014). flexsurv: Flexible parametric survival and multi-state models. R package version 0.5.
msprep
, in mstate, which produces data
in a similar format, given data in "wide" format with one row per subject.
msmdat <- data.frame( subj = c(1, 1, 1, 1, 1, 2, 2, 2), days = c(0, 27, 75, 97, 1106, 0, 90, 1037), status = c(1, 2, 3, 4, 4, 1, 2, 2), age = c(66, 66, 66, 66, 69, 49, 49, 51), treat = c(1, 1, 1, 1, 1, 0, 0, 0) ) # transitions only allowed to next state up or state 4 Q <- rbind(c(1, 1, 0, 1), c(0, 1, 1, 1), c(0, 0, 1, 1), c(0, 0, 0, 0)) dat <- msm2Surv(data=msmdat, subject="subj", time="days", state="status", Q=Q) dat attr(dat, "trans")
msmdat <- data.frame( subj = c(1, 1, 1, 1, 1, 2, 2, 2), days = c(0, 27, 75, 97, 1106, 0, 90, 1037), status = c(1, 2, 3, 4, 4, 1, 2, 2), age = c(66, 66, 66, 66, 69, 49, 49, 51), treat = c(1, 1, 1, 1, 1, 0, 0, 0) ) # transitions only allowed to next state up or state 4 Q <- rbind(c(1, 1, 0, 1), c(0, 1, 1, 1), c(0, 0, 1, 1), c(0, 0, 0, 0)) dat <- msm2Surv(data=msmdat, subject="subj", time="days", state="status", Q=Q) dat attr(dat, "trans")
Odds ratios are computed by exponentiating the estimated covariate effects on the logit-misclassification probabilities.
odds.msm(x, odds.scale = 1, cl = 0.95)
odds.msm(x, odds.scale = 1, cl = 0.95)
x |
Output from |
odds.scale |
Vector with same elements as number of covariates on misclassification probabilities. Corresponds to the increase in each covariate used to calculate its odds ratio. Defaults to all 1. |
cl |
Width of the symmetric confidence interval to present. Defaults to 0.95. |
A list of tables containing odds ratio estimates, one table for each covariate. Each table has three columns, containing the odds ratio, and an approximate upper 95% and lower 95% confidence limit respectively (assuming normality on the log scale), for each misclassification probability.
C. H. Jackson [email protected]
An object giving information about the parameters of the multi-state model.
Used internally during maximum likelihood estimation and arranging results.
Returned as the paramdata
component of a fitted msm
model object.
inits |
Vector of initial values for distinct parameters which are being estimated. These have been transformed to the real line (e.g. by log), and exclude parameters being fixed at their initial values, parameters defined to be always fixed (e.g. binomial denominators) and parameters constrained to equal previous ones. |
plabs |
Names of parameters in
|
allinits |
Vector of parameter values before estimation, including those which are fixed or constrained to equal other parameters, and transformed to the real line. |
hmmpars |
Indices of
|
fixed |
|
fixedpars |
Indices of parameters in
|
notfixed |
Indices of parameters which are not fixed by the definition
of |
optpars |
Indices of parameters in
|
auxpars |
Indices of "auxiliary" parameters which are always fixed, for
example, binomial denominators ( |
constr |
Vector of integers, of
length |
npars |
Total number of
parameters, equal to |
nfix |
Number of fixed
parameters, equal to |
nopt |
Number of
parameters being estimated, equal to |
ndup |
Number of parameters defined as duplicates of previous parameters by equality constraints (currently unused). |
ranges |
Matrix of defined ranges for each parameter on the natural scale (e.g. 0 to infinity for rate parameters). |
opt |
Object
returned by the optimisation routine (such as |
foundse |
|
lik |
Minus twice the log likelihood at the parameter estimates. |
deriv |
Derivatives of the minus twice log likelihood at the parameter estimates, if available. |
information |
Corresponding expected information matrix at the parameter estimates, if available. |
params |
Vector of parameter values after maximum likelihood
estimation, corresponding to |
covmat |
Covariance matrix corresponding to
|
ci |
Matrix of confidence intervals corresponding to
|
estimates.t |
Vector of parameter
estimates, as |
Pearson-type goodness-of-fit test for multi-state models fitted to panel-observed data.
pearson.msm( x, transitions = NULL, timegroups = 3, intervalgroups = 3, covgroups = 3, groups = NULL, boot = FALSE, B = 500, next.obstime = NULL, N = 100, indep.cens = TRUE, maxtimes = NULL, pval = TRUE )
pearson.msm( x, transitions = NULL, timegroups = 3, intervalgroups = 3, covgroups = 3, groups = NULL, boot = FALSE, B = 500, next.obstime = NULL, N = 100, indep.cens = TRUE, maxtimes = NULL, pval = TRUE )
x |
A fitted multi-state model, as returned by |
transitions |
This should be an integer vector indicating which interval transitions should be grouped together in the contingency table. Its length should be the number of allowed interval transitions, excluding transitions from absorbing states to absorbing states. The allowed interval transitions are the set of pairs of states Then, to group transitions 1-1,1-2 together, and transitions 2-2,2-3 together, specify
Only transitions from the same state may be grouped. By default, each interval transition forms a separate group. |
timegroups |
Number of groups based on quantiles of the time since the start of the process. |
intervalgroups |
Number of groups based on quantiles of the time interval between observations, within time groups |
covgroups |
Number of groups based on quantiles of Thus For time-inhomogeneous models specified using the |
groups |
A vector of arbitrary groups in which to categorise each transition. This can be an integer vector or a factor. This can be used to diagnose specific areas of poor fit. For example, the contingency table might be grouped by arbitrary combinations of covariates to detect types of individual for whom the model fits poorly. The length of |
boot |
Estimate an "exact" p-value using a parametric bootstrap. All objects used in the original call to Note that |
B |
Number of bootstrap replicates. |
next.obstime |
This is a vector of length For individuals who died (entered an absorbing state) before the next
scheduled observation, and the time of death is known exactly,
If the individual did not die, and a scheduled observation did follow that
time point,
If |
N |
Number of imputations for the estimation of the distribution of the next scheduled observation time, when there are exact death times. |
indep.cens |
If |
maxtimes |
A vector of length |
pval |
Calculate a p-value using the improved approximation of Titman
(2009). This is optional since it is not needed during bootstrapping, and
it is computationally non-trivial. Only available currently for non-hidden
Markov models for panel data without exact death times. Also not available
for models with censoring, including time-homogeneous models fitted with the
|
This method (Aguirre-Hernandez and Farewell, 2002) is intended for data
which represent observations of the process at arbitrary times ("snapshots",
or "panel-observed" data). For data which represent the exact transition
times of the process, prevalence.msm
can be used to assess
fit, though without a formal test.
When times of death are known exactly, states are misclassified, or an individual's final observation is a censored state, the modification by Titman and Sharples (2008) is used. The only form of censoring supported is a state at the end of an individual's series which represents an unknown transient state (i.e. the individual is only known to be alive at this time). Other types of censoring are omitted from the data before performing the test.
See the references for further details of the methods. The method used for censored states is a modification of the method in the appendix to Titman and Sharples (2008), described at https://chjackson.github.io/msm/misc/robustcensoring.pdf (Titman, 2007).
Groupings of the time since initiation, the time interval and the impact of covariates are based on equally-spaced quantiles. The number of groups should be chosen that there are not many cells with small expected numbers of transitions, since the deviance statistic will be unstable for sparse contingency tables. Ideally, the expected numbers of transitions in each cell of the table should be no less than about 5. Conversely, the power of the test is reduced if there are too few groups. Therefore, some sensitivity analysis of the test results to the grouping is advisable.
Saved model objects fitted with previous versions of R (versions less than
1.2) will need to be refitted under the current R for use with
pearson.msm
.
A list whose first two elements are contingency tables of observed
transitions and expected transitions
, respectively, for each
combination of groups. The third element is a table of the deviances
multiplied by the sign of
. If the expected
number of transitions is zero then the deviance is zero. Entries in the
third matrix will be bigger in magnitude for groups for which the model fits
poorly.
list("\"test\"") |
the fourth element of the list, is a data frame with
one row containing the Pearson-type goodness-of-fit test statistic
For these models, for comparison with older versions of the package,
|
list("\"intervalq\"") |
(not printed by default) contains the definition of the grouping of the intervals between observations. These groups are defined by quantiles within the groups corresponding to the time since the start of the process. |
list("\"sim\"") |
If there are exact death times, this contains simulations of the contingency tables and test statistics for each imputation of the next scheduled sampling time. These are averaged over to produce the presented tables and test statistic. This element is not printed by default. With exact death times, the null variance of the test statistic (formed by
taking mean of simulated test statistics) is less than twice the mean
(Titman, 2008), and the null distribution is not
chi-squared. In this case, |
list("\"boot\"") |
If the bootstrap has been used, the element will contain the bootstrap replicates of the test statistics (not printed by default). |
list("\"lambda\"") |
If the Titman (2009) p-value has been calculated, this contains the weights defining the null distribution of the test statistic as a weighted sum of chi-squared(1) random variables (not printed by default). |
Andrew Titman [email protected], Chris Jackson [email protected]
Aguirre-Hernandez, R. and Farewell, V. (2002) A Pearson-type goodness-of-fit test for stationary and time-continuous Markov regression models. Statistics in Medicine 21:1899-1911.
Titman, A. and Sharples, L. (2008) A general goodness-of-fit test for Markov and hidden Markov models. Statistics in Medicine 27(12):2177-2195
Titman, A. (2009) Computation of the asymptotic null distribution of goodness-of-fit tests for multi-state models. Lifetime Data Analysis 15(4):519-533.
Titman, A. (2008) Model diagnostics in multi-state models of biological systems. PhD thesis, University of Cambridge.
msm
, prevalence.msm
,
scoreresid.msm
,
psor.q <- rbind(c(0,0.1,0,0),c(0,0,0.1,0),c(0,0,0,0.1),c(0,0,0,0)) psor.msm <- msm(state ~ months, subject=ptnum, data=psor, qmatrix = psor.q, covariates = ~ollwsdrt+hieffusn, constraint = list(hieffusn=c(1,1,1),ollwsdrt=c(1,1,2))) pearson.msm(psor.msm, timegroups=2, intervalgroups=2, covgroups=2) # More 1-2, 1-3 and 1-4 observations than expected in shorter time # intervals - the model fits poorly. # A random effects model might accommodate such fast progressors.
psor.q <- rbind(c(0,0.1,0,0),c(0,0,0.1,0),c(0,0,0,0.1),c(0,0,0,0)) psor.msm <- msm(state ~ months, subject=ptnum, data=psor, qmatrix = psor.q, covariates = ~ollwsdrt+hieffusn, constraint = list(hieffusn=c(1,1,1),ollwsdrt=c(1,1,2))) pearson.msm(psor.msm, timegroups=2, intervalgroups=2, covgroups=2) # More 1-2, 1-3 and 1-4 observations than expected in shorter time # intervals - the model fits poorly. # A random effects model might accommodate such fast progressors.
Density, distribution function, quantile function and random generation for a generalisation of the exponential distribution, in which the rate changes at a series of times.
dpexp(x, rate = 1, t = 0, log = FALSE) ppexp(q, rate = 1, t = 0, lower.tail = TRUE, log.p = FALSE) qpexp(p, rate = 1, t = 0, lower.tail = TRUE, log.p = FALSE) rpexp(n = 1, rate = 1, t = 0, start = min(t))
dpexp(x, rate = 1, t = 0, log = FALSE) ppexp(q, rate = 1, t = 0, lower.tail = TRUE, log.p = FALSE) qpexp(p, rate = 1, t = 0, lower.tail = TRUE, log.p = FALSE) rpexp(n = 1, rate = 1, t = 0, start = min(t))
x , q
|
vector of quantiles. |
rate |
vector of rates. |
t |
vector of the same length as |
log , log.p
|
logical; if TRUE, probabilities p are given as log(p), or log density is returned. |
lower.tail |
logical; if TRUE (default), probabilities are P[X <= x], otherwise, P[X > x]. |
p |
vector of probabilities. |
n |
number of observations. If |
start |
numeric scalar; delayed entry time. The random deviates will be left truncated from this start time. |
Consider the exponential distribution with rates changing at times
, with
. Suppose
is
the maximum
such that
. The density of
this distribution at
is
for
, and
for k > 1.
where and
are the distribution and density functions of
the standard exponential distribution.
If rate
is of length 1, this is just the standard exponential
distribution. Therefore, for example, dpexp(x)
, with no other
arguments, is simply equivalent to dexp(x)
.
Only rpexp
is used in the msm
package, to simulate from Markov
processes with piecewise-constant intensities depending on time-dependent
covariates. These functions are merely provided for completion, and are not
optimized for numerical stability or speed.
dpexp
gives the density, ppexp
gives the distribution
function, qpexp
gives the quantile function, and rpexp
generates random deviates.
C. H. Jackson [email protected]
x <- seq(0.1, 50, by=0.1) rate <- c(0.1, 0.2, 0.05, 0.3) t <- c(0, 10, 20, 30) ## standard exponential distribution plot(x, dexp(x, 0.1), type="l") ## distribution with piecewise constant rate lines(x, dpexp(x, rate, t), type="l", lty=2) ## standard exponential distribution plot(x, pexp(x, 0.1), type="l") ## distribution with piecewise constant rate lines(x, ppexp(x, rate, t), type="l", lty=2)
x <- seq(0.1, 50, by=0.1) rate <- c(0.1, 0.2, 0.05, 0.3) t <- c(0, 10, 20, 30) ## standard exponential distribution plot(x, dexp(x, 0.1), type="l") ## distribution with piecewise constant rate lines(x, dpexp(x, rate, t), type="l", lty=2) ## standard exponential distribution plot(x, pexp(x, 0.1), type="l") ## distribution with piecewise constant rate lines(x, ppexp(x, rate, t), type="l", lty=2)
Parameters of fitted two-phase models, in mixture model parameterisation.
phasemeans.msm( x, covariates = "mean", ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL )
phasemeans.msm( x, covariates = "mean", ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL )
x |
A fitted multi-state model, as returned by |
covariates |
Covariate values, see |
ci |
If |
cl |
Width of the symmetric confidence interval, relative to 1. |
B |
Number of bootstrap replicates, or number of normal simulations from the distribution of the MLEs. |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
Matrix with one row for each state that has a two-phase
distribution, and three columns: the short-stay mean, long-stay mean and
long-stay probability. These are functions of the transition intensities of
the expanded hidden Markov model, defined in d2phase
.
C. H. Jackson [email protected]
This produces a plot of the expected probability of survival against time, from each transient state. Survival is defined as not entering an absorbing state.
## S3 method for class 'msm' plot( x, from = NULL, to = NULL, range = NULL, covariates = "mean", legend.pos = NULL, xlab = "Time", ylab = "Fitted survival probability", lwd = 1, ... )
## S3 method for class 'msm' plot( x, from = NULL, to = NULL, range = NULL, covariates = "mean", legend.pos = NULL, xlab = "Time", ylab = "Fitted survival probability", lwd = 1, ... )
x |
Output from |
from |
States from which to consider survival. Defaults to the complete set of transient states. |
to |
Absorbing state to consider. Defaults to the highest-labelled absorbing state. |
range |
Vector of two elements, giving the range of times to plot for. |
covariates |
Covariate values for which to evaluate the expected
probabilities. This can either be: the string the number or a list of values, with optional names. For example
where the order of the list follows the order of the covariates originally given in the model formula, or a named list,
|
legend.pos |
Vector of the |
xlab |
x axis label. |
ylab |
y axis label. |
lwd |
Line width. See |
... |
Other arguments to be passed to the generic |
Note that while this function is only relevant to models with absorbing states, models in msm can have any transition structure and do not necessarily have to have an absorbing state.
C. H. Jackson [email protected]
Provides a rough indication of goodness of fit of a multi-state model, by estimating the observed numbers of individuals occupying a state at a series of times, and plotting these against forecasts from the fitted model, for each state. Observed prevalences are indicated as solid lines, expected prevalences as dashed lines.
## S3 method for class 'prevalence.msm' plot( x, mintime = NULL, maxtime = NULL, timezero = NULL, initstates = NULL, interp = c("start", "midpoint"), censtime = Inf, subset = NULL, covariates = "population", misccovariates = "mean", piecewise.times = NULL, piecewise.covariates = NULL, xlab = "Times", ylab = "Prevalence (%)", lwd.obs = 1, lwd.exp = 1, lty.obs = 1, lty.exp = 2, col.obs = "blue", col.exp = "red", legend.pos = NULL, ... )
## S3 method for class 'prevalence.msm' plot( x, mintime = NULL, maxtime = NULL, timezero = NULL, initstates = NULL, interp = c("start", "midpoint"), censtime = Inf, subset = NULL, covariates = "population", misccovariates = "mean", piecewise.times = NULL, piecewise.covariates = NULL, xlab = "Times", ylab = "Prevalence (%)", lwd.obs = 1, lwd.exp = 1, lty.obs = 1, lty.exp = 2, col.obs = "blue", col.exp = "red", legend.pos = NULL, ... )
x |
A fitted multi-state model produced by |
mintime |
Minimum time at which to compute the observed and expected prevalences of states. |
maxtime |
Maximum time at which to compute the observed and expected prevalences of states. |
timezero |
Initial time of the Markov process. Expected values are forecasted from here. Defaults to the minimum of the observation times given in the data. |
initstates |
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. |
interp |
Interpolation method for observed states, see
|
censtime |
Subject-specific maximum follow-up times, see
|
subset |
Vector of the subject identifiers to calculated observed prevalences for. |
covariates |
Covariate values for which to forecast expected state
occupancy. See |
misccovariates |
(Misclassification models only) Values of covariates
on the misclassification probability matrix. See
|
piecewise.times |
Times at which piecewise-constant intensities change.
See |
piecewise.covariates |
Covariates on which the piecewise-constant
intensities depend. See |
xlab |
x axis label. |
ylab |
y axis label. |
lwd.obs |
Line width for observed prevalences. See |
lwd.exp |
Line width for expected prevalences. See |
lty.obs |
Line type for observed prevalences. See |
lty.exp |
Line type for expected prevalences. See |
col.obs |
Line colour for observed prevalences. See |
col.exp |
Line colour for expected prevalences. See |
legend.pos |
Vector of the |
... |
Further arguments to be passed to the generic |
See prevalence.msm
for details of the assumptions underlying
this method.
Observed prevalences are plotted with a solid line, and expected prevalences with a dotted line.
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.
Plot a Kaplan-Meier estimate of the survival probability and compare it with
the fitted survival probability from a msm
model.
## S3 method for class 'survfit.msm' plot( x, from = 1, to = NULL, range = NULL, covariates = "mean", interp = c("start", "midpoint"), ci = c("none", "normal", "bootstrap"), B = 100, legend.pos = NULL, xlab = "Time", ylab = "Survival probability", lty = 1, lwd = 1, col = "red", lty.ci = 2, lwd.ci = 1, col.ci = "red", mark.time = TRUE, col.surv = "blue", lty.surv = 2, lwd.surv = 1, survdata = FALSE, ... )
## S3 method for class 'survfit.msm' plot( x, from = 1, to = NULL, range = NULL, covariates = "mean", interp = c("start", "midpoint"), ci = c("none", "normal", "bootstrap"), B = 100, legend.pos = NULL, xlab = "Time", ylab = "Survival probability", lty = 1, lwd = 1, col = "red", lty.ci = 2, lwd.ci = 1, col.ci = "red", mark.time = TRUE, col.surv = "blue", lty.surv = 2, lwd.surv = 1, survdata = FALSE, ... )
x |
Output from |
from |
Non-absorbing state from which to consider survival. Defaults
to state 1. The fitted probabilities will then be calculated as the
transition probabilities from this state to |
to |
Absorbing state to consider. Defaults to the highest-labelled absorbing state. |
range |
Vector of two elements, giving the range of times to plot for. |
covariates |
Covariate values for which to evaluate the expected
probabilities. This can either be: the string the number or a list of values, with optional names. For example
where the order of the list follows the order of the covariates originally given in the model formula, or a named list,
but note the empirical curve is plotted for the full population. To
consider subsets for the empirical curve, set |
interp |
If If |
ci |
If |
B |
Number of bootstrap or normal replicates for the confidence interval. The default is 100 rather than the usual 1000, since these plots are for rough diagnostic purposes. |
legend.pos |
Vector of the |
xlab |
x axis label. |
ylab |
y axis label. |
lty |
Line type for the fitted curve. See |
lwd |
Line width for the fitted curve. See |
col |
Colour for the fitted curve. See |
lty.ci |
Line type for the fitted curve confidence limits. See
|
lwd.ci |
Line width for the fitted curve confidence limits. See
|
col.ci |
Colour for the fitted curve confidence limits. See
|
mark.time |
Mark the empirical survival curve at each censoring point,
see |
col.surv |
Colour for the empirical survival curve, passed to
|
lty.surv |
Line type for the empirical survival curve, passed to
|
lwd.surv |
Line width for the empirical survival curve, passed to
|
survdata |
Set to |
... |
Other arguments to be passed to the |
If the data represent observations of the process at arbitrary times, then the first occurrence of the absorbing state in the data will usually be greater than the actual first transition time to that state. Therefore the Kaplan-Meier estimate of the survival probability will be an overestimate.
The method of Turnbull (1976) could be used to give a non-parametric estimate of the time to an interval-censored event, and compared to the equivalent estimate from a multi-state model. This is implemented in the CRAN package interval (Fay and Shaw 2010).
This currently only handles time-homogeneous models.
Turnbull, B. W. (1976) The empirical distribution function with arbitrarily grouped, censored and truncated data. J. R. Statist. Soc. B 38, 290-295.
Fay, MP and Shaw, PA (2010). Exact and Asymptotic Weighted Logrank Tests for Interval Censored Data: The interval R package. Journal of Statistical Software. http://www.jstatsoft.org/v36/ i02/. 36 (2):1-34.
survfit
,
plot.survfit
, plot.prevalence.msm
Compute and plot Kaplan-Meier estimates of the probability that each successive state has not occurred yet.
plotprog.msm( formula, subject, data, legend.pos = NULL, xlab = "Time", ylab = "1 - incidence probability", lwd = 1, xlim = NULL, mark.time = TRUE, ... )
plotprog.msm( formula, subject, data, legend.pos = NULL, xlab = "Time", ylab = "1 - incidence probability", lwd = 1, xlim = NULL, mark.time = TRUE, ... )
formula |
A formula giving the vectors containing the observed states and the corresponding observation times. For example,
Observed states should be in the set |
subject |
Vector of subject identification numbers for the data
specified by |
data |
An optional data frame in which the variables represented by
|
legend.pos |
Vector of the |
xlab |
x axis label. |
ylab |
y axis label. |
lwd |
Line width. See |
xlim |
x axis limits, e.g. c(0,10) for an axis ranging from 0 to 10. Default is the range of observation times. |
mark.time |
Mark the empirical survival curve at each censoring point,
see |
... |
Other arguments to be passed to the |
If the data represent observations of the process at arbitrary times, then
the first occurrence of the state in the data will usually be greater than
the actual first transition time to that state. Therefore the probabilities
plotted by plotprog.msm
will be overestimates.
Extract the estimated transition probability matrix from a fitted continuous-time multi-state model for a given time interval, at a given set of covariate values.
pmatrix.msm( x = NULL, t = 1, t1 = 0, covariates = "mean", ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, qmatrix = NULL, ... )
pmatrix.msm( x = NULL, t = 1, t1 = 0, covariates = "mean", ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, qmatrix = NULL, ... )
x |
A fitted multi-state model, as returned by |
t |
The time interval to estimate the transition probabilities for, by default one unit. |
t1 |
The starting time of the interval. Used for models |
covariates |
The covariate values at which to estimate the transition
probabilities. This can either be: the string the number or a list of values, with optional names. For example
where the order of the list follows the order of the covariates originally given in the model formula, or a named list,
If some covariates are specified but not others, the missing ones default to zero. For time-inhomogeneous models fitted using the For time-inhomogeneous models fitted "by hand" by using a time-dependent
covariate in the |
ci |
If If If |
cl |
Width of the symmetric confidence interval, relative to 1. |
B |
Number of bootstrap replicates, or number of normal simulations from the distribution of the MLEs |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
qmatrix |
A transition intensity matrix. Either this or a fitted model
|
... |
Optional arguments to be passed to |
For a continuous-time homogeneous Markov process with transition intensity
matrix , the probability of occupying state
at time
conditionally on occupying state
at time
is given by the
entry of the matrix
, where
is the matrix exponential.
For non-homogeneous processes, where covariates and hence the transition
intensity matrix are piecewise-constant in time, the transition
probability matrix is calculated as a product of matrices over a series of
intervals, as explained in
pmatrix.piecewise.msm
.
The pmatrix.piecewise.msm
function is only necessary for
models fitted using a time-dependent covariate in the covariates
argument to msm
. For time-inhomogeneous models fitted using
"pci", pmatrix.msm
can be used, with arguments t
and
t1
, to calculate transition probabilities over any time period.
The matrix of estimated transition probabilities in the
given time. Rows correspond to "from-state" and columns to "to-state".
Or if ci="normal"
or ci="bootstrap"
, pmatrix.msm
returns a list with components estimates
and ci
, where
estimates
is the matrix of estimated transition probabilities, and
ci
is a list of two matrices containing the upper and lower
confidence limits.
C. H. Jackson [email protected].
Mandel, M. (2013). "Simulation based confidence intervals for functions with complicated derivatives." The American Statistician 67(2):76-81
qmatrix.msm
, pmatrix.piecewise.msm
,
boot.msm
Extract the estimated transition probability matrix from a fitted
non-time-homogeneous multi-state model for a given time interval. This is a
generalisation of pmatrix.msm
to models with time-dependent
covariates. Note that pmatrix.msm
is sufficient to calculate
transition probabilities for time-inhomogeneous models fitted using the
pci
argument to msm
.
pmatrix.piecewise.msm( x = NULL, t1, t2, times, covariates = NULL, ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, qlist = NULL, ... )
pmatrix.piecewise.msm( x = NULL, t1, t2, times, covariates = NULL, ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, qlist = NULL, ... )
x |
A fitted multi-state model, as returned by |
t1 |
The start of the time interval to estimate the transition probabilities for. |
t2 |
The end of the time interval to estimate the transition probabilities for. |
times |
Cut points at which the transition intensity matrix changes. |
covariates |
A list with number of components one greater than the
length of
(assuming that all elements of |
ci |
If If If |
cl |
Width of the symmetric confidence interval, relative to 1. |
B |
Number of bootstrap replicates, or number of normal simulations from the distribution of the MLEs |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
qlist |
A list of transition intensity matrices, of length one greater
than the length of |
... |
Optional arguments to be passed to |
Suppose a multi-state model has been fitted, in which the transition
intensity matrix is modelled in terms of time-dependent
covariates
. The transition probability matrix
for the time interval
cannot be calculated from the estimated intensity matrix as
, because
varies within
the interval
. However, if the covariates are
piecewise-constant, or can be approximated as piecewise-constant, then we
can calculate
by multiplying together
individual matrices
, calculated over intervals where Q is constant:
The matrix of estimated transition probabilities for the
time interval
[t1, tn]
. That is, the probabilities of occupying
state at time
conditionally on occupying state
at time
. Rows correspond to "from-state" and columns to
"to-state".
C. H. Jackson [email protected]
## Not run: ## In a clinical study, suppose patients are given a placebo in the ## first 5 weeks, then they begin treatment 1 at 5 weeks, and ## a combination of treatments 1 and 2 from 10 weeks. ## Suppose a multi-state model x has been fitted for the patients' ## progress, with treat1 and treat2 as time dependent covariates. ## Cut points for when treatment covariate changes times <- c(0, 5, 10) ## Indicators for which treatments are active in the four intervals ## defined by the three cut points covariates <- list( list (treat1=0, treat2=0), list (treat1=0, treat2=0), list(treat1=1, treat2=0), list(treat1=1, treat2=1) ) ## Calculate transition probabilities from the start of the study to 15 weeks pmatrix.piecewise.msm(x, 0, 15, times, covariates) ## End(Not run)
## Not run: ## In a clinical study, suppose patients are given a placebo in the ## first 5 weeks, then they begin treatment 1 at 5 weeks, and ## a combination of treatments 1 and 2 from 10 weeks. ## Suppose a multi-state model x has been fitted for the patients' ## progress, with treat1 and treat2 as time dependent covariates. ## Cut points for when treatment covariate changes times <- c(0, 5, 10) ## Indicators for which treatments are active in the four intervals ## defined by the three cut points covariates <- list( list (treat1=0, treat2=0), list (treat1=0, treat2=0), list(treat1=1, treat2=0), list(treat1=1, treat2=1) ) ## Calculate transition probabilities from the start of the study to 15 weeks pmatrix.piecewise.msm(x, 0, 15, times, covariates) ## End(Not run)
Compute a matrix of the probability of each state being the next
state of the process after each state
. Together with the mean
sojourn times in each state (
sojourn.msm
), these fully define
a continuous-time Markov model.
pnext.msm( x, covariates = "mean", ci = c("normal", "bootstrap", "delta", "none"), cl = 0.95, B = 1000, cores = NULL )
pnext.msm( x, covariates = "mean", ci = c("normal", "bootstrap", "delta", "none"), cl = 0.95, B = 1000, cores = NULL )
x |
A fitted multi-state model, as returned by |
covariates |
The covariate values at which to estimate the intensities.
This can either be: the string the number or a list of values, with optional names. For example
where the order of the list follows the order of the covariates originally given in the model formula, or a named list,
|
ci |
If If If |
cl |
Width of the symmetric confidence interval to present. Defaults to 0.95. |
B |
Number of bootstrap replicates, or number of normal simulations from the distribution of the MLEs. |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
For a continuous-time Markov process in state , the probability that
the next state is
is
, where
is
the transition intensity (
qmatrix.msm
).
A continuous-time Markov model is fully specified by these probabilities
together with the mean sojourn times in each state
.
This gives a more intuitively meaningful description of a model than the
intensity matrix.
Remember that msm deals with continuous-time, not discrete-time
models, so these are not the same as the probability of observing
state at a fixed time in the future. Those probabilities are given
by
pmatrix.msm
.
The matrix of probabilities that the next move of a process in state
(rows) is to state
(columns).
C. H. Jackson [email protected]
qmatrix.msm
,pmatrix.msm
,qratio.msm
Probabilities of having visited each state by a particular time in a continuous time Markov model.
ppass.msm( x = NULL, qmatrix = NULL, tot, start = "all", covariates = "mean", piecewise.times = NULL, piecewise.covariates = NULL, ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, ... )
ppass.msm( x = NULL, qmatrix = NULL, tot, start = "all", covariates = "mean", piecewise.times = NULL, piecewise.covariates = NULL, ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, ... )
x |
A fitted multi-state model, as returned by |
qmatrix |
Instead of |
tot |
Finite time to forecast the passage probabilites for. |
start |
Starting state (integer). By default ( Alternatively, this can be used to obtain passage probabilities from a
set of states, rather than single states. To achieve this,
|
covariates |
Covariate values defining the intensity matrix for the
fitted model |
piecewise.times |
For models with time-dependent covariates,
this defines the cut points in time at which the transition
intensity matrix changes. This is not required for models fitted
with the |
piecewise.covariates |
For models with time-dependent
covariates, this is the list of covariates for each time period
defined by |
ci |
If If If |
cl |
Width of the symmetric confidence interval, relative to 1. |
B |
Number of bootstrap replicates. |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
... |
Arguments to pass to |
The passage probabilities to state are computed by setting the
th row of the transition intensity matrix
to zero, giving an
intensity matrix
for a simplified model structure where state
is absorbing. The probabilities of passage are then equivalent to
row
of the transition probability matrix
(
pmatrix.msm
) under this
simplified model for tot
.
For time-inhomogenous models,
this process is generalised by calculating an intensity matrix for each
time period, zeroing the appropriate row of each, and calculating and multiplying
transition probability matrices as in pmatrix.piecewise.msm
.
Note this is different from the probability of occupying each state at
exactly time , given by
pmatrix.msm
. The passage
probability allows for the possibility of having visited the state before
, but then occupying a different state at
.
The mean of the passage distribution is the expected first passage time,
efpt.msm
.
A matrix whose entry is the probability of having visited
state
at least once before time
, given the state at time
is
. The diagonal entries should all be 1.
C. H. Jackson [email protected] with contributions from Jon Fintzi.
Norris, J. R. (1997) Markov Chains. Cambridge University Press.
efpt.msm
, totlos.msm
,
boot.msm
.
Q <- rbind(c(-0.5, 0.25, 0, 0.25), c(0.166, -0.498, 0.166, 0.166), c(0, 0.25, -0.5, 0.25), c(0, 0, 0, 0)) ## ppass[1,2](t) converges to 0.5 with t, since given in state 1, the ## probability of going to the absorbing state 4 before visiting state ## 2 is 0.5, and the chance of still being in state 1 at t decreases. ppass.msm(qmatrix=Q, tot=2) ppass.msm(qmatrix=Q, tot=20) ppass.msm(qmatrix=Q, tot=100) Q <- Q[1:3,1:3]; diag(Q) <- 0; diag(Q) <- -rowSums(Q) ## Probability of about 1/2 of visiting state 3 by time 10.5, the ## median first passage time ppass.msm(qmatrix=Q, tot=10.5) ## Mean first passage time from state 2 to state 3 is 10.02: similar ## to the median efpt.msm(qmatrix=Q, tostate=3)
Q <- rbind(c(-0.5, 0.25, 0, 0.25), c(0.166, -0.498, 0.166, 0.166), c(0, 0.25, -0.5, 0.25), c(0, 0, 0, 0)) ## ppass[1,2](t) converges to 0.5 with t, since given in state 1, the ## probability of going to the absorbing state 4 before visiting state ## 2 is 0.5, and the chance of still being in state 1 at t decreases. ppass.msm(qmatrix=Q, tot=2) ppass.msm(qmatrix=Q, tot=20) ppass.msm(qmatrix=Q, tot=100) Q <- Q[1:3,1:3]; diag(Q) <- 0; diag(Q) <- -rowSums(Q) ## Probability of about 1/2 of visiting state 3 by time 10.5, the ## median first passage time ppass.msm(qmatrix=Q, tot=10.5) ## Mean first passage time from state 2 to state 3 is 10.02: similar ## to the median efpt.msm(qmatrix=Q, tostate=3)
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, ... )
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, ... )
x |
A fitted multi-state model produced by |
times |
Series of times at which to compute the observed and expected prevalences of states. |
timezero |
Initial time of the Markov process. Expected values are forecasted from here. Defaults to the minimum of the observation times given in the data. |
initstates |
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. |
covariates |
Covariate values for which to forecast expected state
occupancy. With the default Predictions for fixed covariates can be obtained by supplying covariate
values in the standard way, as in This argument is ignored if |
misccovariates |
(Misclassification models only) Values of covariates
on the misclassification probability matrix for converting expected true to
expected misclassified states. Ignored if |
piecewise.times |
Times at which piecewise-constant intensities change.
See |
piecewise.covariates |
Covariates on which the piecewise-constant
intensities depend. See |
ci |
If If If |
cl |
Width of the symmetric confidence interval, relative to 1 |
B |
Number of bootstrap replicates |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
interp |
Suppose an individual was observed in states If If |
censtime |
Adjustment to the observed prevalences to account for limited follow-up in the data. If the time is greater than This can be supplied as a single value, or as a vector with one element per
subject (after any This is ignored if it is less than the subject's maximum observation time. |
subset |
Subset of subjects to calculate observed prevalences for. |
plot |
Generate a plot of observed against expected prevalences. See
|
... |
Further arguments to pass to |
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 at time
after the start, the number
of individuals under observation at time
(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
. 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).
A list of matrices, with components:
Observed |
Table of observed numbers of individuals in each state at each time |
Observed percentages |
Corresponding percentage of the individuals at risk at each time. |
Expected |
Table of corresponding expected numbers. |
Expected percentages |
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.
C. H. Jackson [email protected]
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.
Print a fitted msm model object
## S3 method for class 'msm' print(x, covariates = NULL, digits = 4, ...) printnew.msm(x, covariates = NULL, digits = 4, ...)
## S3 method for class 'msm' print(x, covariates = NULL, digits = 4, ...) printnew.msm(x, covariates = NULL, digits = 4, ...)
x |
Output from |
covariates |
Covariates for which to print “baseline” transition
intensities or misclassification probabilities. See
|
digits |
Minimum number of significant digits, passed to
|
... |
Other arguments to be passed to |
This is the new method of formatting msm objects for printing. The old method was based on printing lists of matrices. That produced a lot of wasted space for parameters which were zero, and it was difficult to match corresponding numbers between matrices. The new method presents all the transition intensities and covariate effects as a single compact table, and likewise for misclassification matrices.
Also in the old method, covariate effects were presented as log hazard ratios or log odds ratios. The log scale is more convenient mathematically, but unnatural to interpret. The new method presents hazard ratios for covariates on transition intensities and odds ratios for misclassification probabilities.
printnew.msm
is an alias for print.msm
.
The object returned by print.msm
is a numeric matrix with one
column for each estimate or confidence limit for intensities and their
covariates, in the same arrangement as printed, but with the underlying
numbers in full precision. The results formatted for printing are stored in
the "formatted"
attribute of the object, as a character matrix.
These can alternatively be produced by msm.form.qoutput
, which
has no printing side-effect. msm.form.eoutput
produces the
same arrangement for misclassification probabilities instead of intensities.
C. H. Jackson [email protected]
msm
, printold.msm
,
msm.form.qoutput
.
Print a fitted msm model object (in old format, from msm 1.3.1 and earlier)
printold.msm(x, ...)
printold.msm(x, ...)
x |
Output from |
... |
Other arguments to be passed to |
See print.msm
for a better and cleaner output format, and an
explanation of the change.
C. H. Jackson [email protected]
A series of observations of grades of psoriatic arthritis, as indicated by numbers of damaged joints.
A data frame containing 806 observations, representing visits to a psoriatic arthritis (PsA) clinic from 305 patients. The rows are grouped by patient number and ordered by examination time. Each row represents an examination and contains additional covariates.
ptnum |
(numeric) | Patient identification number |
months |
(numeric) | Examination time in months |
state |
(numeric) | Clinical state of PsA. Patients in states 1, 2, 3 and 4 |
have 0, 1 to 4, 5 to 9 and 10 or more damaged joints, | ||
respectively. | ||
hieffusn |
(numeric) | Presence of five or more effusions |
ollwsdrt |
(character) | Erythrocyte sedimentation rate of less than 15 mm/h |
Gladman, D. D. and Farewell, V.T. (1999) Progression in psoriatic arthritis: role of time-varying clinical indicators. J. Rheumatol. 26(11):2409-13
## Four-state progression-only model with high effusion and low ## sedimentation rate as covariates on the progression rates. High ## effusion is assumed to have the same effect on the 1-2, 2-3, and 3-4 ## progression rates, while low sedimentation rate has the same effect ## on the 1-2 and 2-3 intensities, but a different effect on the 3-4. data(psor) psor.q <- rbind(c(0,0.1,0,0),c(0,0,0.1,0),c(0,0,0,0.1),c(0,0,0,0)) psor.msm <- msm(state ~ months, subject=ptnum, data=psor, qmatrix = psor.q, covariates = ~ollwsdrt+hieffusn, constraint = list(hieffusn=c(1,1,1),ollwsdrt=c(1,1,2)), fixedpars=FALSE, control = list(REPORT=1,trace=2), method="BFGS") qmatrix.msm(psor.msm) sojourn.msm(psor.msm) hazard.msm(psor.msm)
## Four-state progression-only model with high effusion and low ## sedimentation rate as covariates on the progression rates. High ## effusion is assumed to have the same effect on the 1-2, 2-3, and 3-4 ## progression rates, while low sedimentation rate has the same effect ## on the 1-2 and 2-3 intensities, but a different effect on the 3-4. data(psor) psor.q <- rbind(c(0,0.1,0,0),c(0,0,0.1,0),c(0,0,0,0.1),c(0,0,0,0)) psor.msm <- msm(state ~ months, subject=ptnum, data=psor, qmatrix = psor.q, covariates = ~ollwsdrt+hieffusn, constraint = list(hieffusn=c(1,1,1),ollwsdrt=c(1,1,2)), fixedpars=FALSE, control = list(REPORT=1,trace=2), method="BFGS") qmatrix.msm(psor.msm) sojourn.msm(psor.msm) hazard.msm(psor.msm)
A list representing the model for covariates on transition intensities
npars |
Number of covariate effect parameters. This is defined as the number of covariates on intensities (with factors expanded as contrasts) multiplied by the number of allowed transitions in the model. Note if This also includes any |
ndpars |
Number of distinct covariate effect parameters, as
|
ncovs |
Number of covariates on intensities, with factors expanded as contrasts. |
constr |
List of equality constraints on these covariate
effects, as supplied in the |
covlabels |
Names / labels of these covariates in
the model matrix (see |
inits |
Initial
values for these covariate effects, as a vector formed from the
|
covmeans |
Means of these covariates in the data (excluding data not required to fit the model, such as observations with missing data in other elements or subjects' last observations). This includes means of 0/1 factor contrasts as well as continuous covariates (for historic reasons, which may not be sensible). |
Generic function to find the quantiles of a distribution, given the equivalent probability distribution function.
qgeneric(pdist, p, special = NULL, ...)
qgeneric(pdist, p, special = NULL, ...)
pdist |
Probability distribution function, for example,
|
p |
Vector of probabilities to find the quantiles for. |
special |
Vector of character strings naming arguments of the
distribution function that should not be vectorised over. Used, for example,
for the |
... |
The remaining arguments define parameters of the distribution
This may also contain the standard arguments If the distribution is bounded above or below, then this should contain
arguments |
This function is intended to enable users to define "q"
functions for
new distributions, in cases where the distribution function pdist
is
available analytically, but the quantile function is not.
It works by finding the root of the equation .
Starting from the interval
, the interval width is expanded by
50% until
is of opposite sign at either end. The root is then
found using
uniroot
.
This assumes a suitably smooth, continuous distribution.
An identical function is provided in the flexsurv package.
Vector of quantiles of the distribution at p
.
Christopher Jackson <[email protected]>
qnorm(c(0.025, 0.975), 0, 1) qgeneric(pnorm, c(0.025, 0.975), mean=0, sd=1) # must name the arguments
qnorm(c(0.025, 0.975), 0, 1) qgeneric(pnorm, c(0.025, 0.975), mean=0, sd=1) # must name the arguments
Extract the estimated transition intensity matrix, and the corresponding standard errors, from a fitted multi-state model at a given set of covariate values.
qmatrix.msm( x, covariates = "mean", sojourn = FALSE, ci = c("delta", "normal", "bootstrap", "none"), cl = 0.95, B = 1000, cores = NULL )
qmatrix.msm( x, covariates = "mean", sojourn = FALSE, ci = c("delta", "normal", "bootstrap", "none"), cl = 0.95, B = 1000, cores = NULL )
x |
A fitted multi-state model, as returned by |
covariates |
The covariate values at which to estimate the intensity
matrix. This can either be: the string the number or a list of values, with optional names. For example
where the order of the list follows the order of the covariates originally given in the model formula. Or more clearly, a named list,
If some covariates are specified but not others, the missing ones default to zero. With |
sojourn |
Set to TRUE if the estimated sojourn times and their standard errors should also be returned. |
ci |
If If If |
cl |
Width of the symmetric confidence interval to present. Defaults to 0.95. |
B |
Number of bootstrap replicates, or number of normal simulations from the distribution of the MLEs. |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
Transition intensities and covariate effects are estimated on the log scale
by msm
. A covariance matrix is estimated from the Hessian of
the maximised log-likelihood.
A more practically meaningful parameterisation of a continuous-time Markov
model with transition intensities is in terms of the mean
sojourn times
in each state
and the probabilities
that the next move of the process when in state
is to state
,
.
A list with components:
estimate |
Estimated transition intensity matrix. |
SE |
Corresponding approximate standard errors. |
L |
Lower confidence limits |
U |
Upper confidence limits |
Or if ci="none"
, then qmatrix.msm
just returns the estimated
transition intensity matrix.
If sojourn
is TRUE
, extra components called sojourn
,
sojournSE
, sojournL
and sojournU
are included,
containing the estimates, standard errors and confidence limits,
respectively, of the mean sojourn times in each transient state.
The default print method for objects returned by qmatrix.msm
presents estimates and confidence limits. To present estimates and standard
errors, do something like
qmatrix.msm(x)[c("estimates","SE")]
C. H. Jackson [email protected]
pmatrix.msm
, sojourn.msm
,
deltamethod
, ematrix.msm
A list giving information about the structure of states and allowed
transitions in a multi-state model, and options for likelihood calculation.
Used in internal computations, and returned in a fitted msm
model object.
nstates |
Number of states |
iso |
Label for which basic
structure the model is isomorphic to in the list of structures for which
analytic formulae for the transition probabilities are implemented in the
source file
|
perm |
Permutation required to convert the base isomorphism into the
structure of this model. A vector of integers whose |
qperm |
Inverse permutation: vector whose |
npars |
Number of allowed
instantaneous transitions, equal to |
imatrix |
Indicator matrix for allowed instantaneous transitions. This
has |
qmatrix |
Matrix of initial values for the
transition intensities, supplied as the |
inits |
Vector of these initial values, reading
across rows of |
constr |
Indicators for equality constraints on baseline
intensities, taken from the |
ndpars |
Number of distinct allowed instantaneous transitions, after applying equality constraints. |
expm |
Use expm package to
calculate matrix exponentials for likelihoods, as supplied to the
|
msm.object
,emodel.object
,
hmodel.object
.
Compute the estimate and approximate standard error of the ratio of two estimated transition intensities from a fitted multi-state model at a given set of covariate values.
qratio.msm( x, ind1, ind2, covariates = "mean", ci = c("delta", "normal", "bootstrap", "none"), cl = 0.95, B = 1000, cores = NULL )
qratio.msm( x, ind1, ind2, covariates = "mean", ci = c("delta", "normal", "bootstrap", "none"), cl = 0.95, B = 1000, cores = NULL )
x |
A fitted multi-state model, as returned by |
ind1 |
Pair of numbers giving the indices in the intensity matrix of
the numerator of the ratio, for example, |
ind2 |
Pair of numbers giving the indices in the intensity matrix of
the denominator of the ratio, for example, |
covariates |
The covariate values at which to estimate the intensities.
This can either be: the string the number or a list of values, with optional names. For example
where the order of the list follows the order of the covariates originally given in the model formula, or a named list,
|
ci |
If If If |
cl |
Width of the symmetric confidence interval to present. Defaults to 0.95. |
B |
Number of bootstrap replicates, or number of normal simulations from the distribution of the MLEs |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
For example, we might want to compute the ratio of the progression rate and
recovery rate for a fitted model disease.msm
with a health state
(state 1) and a disease state (state 2). In this case, the progression rate
is the (1,2) entry of the intensity matrix, and the recovery rate is the
(2,1) entry. Thus to compute this ratio with covariates set to their means,
we call
qratio.msm(disease.msm, c(1,2), c(2,1))
.
Standard errors are estimated by the delta method. Confidence limits are estimated by assuming normality on the log scale.
A named vector with elements estimate
, se
, L
and U
containing the estimate, standard error, lower and upper
confidence limits, respectively, of the ratio of intensities.
C. H. Jackson [email protected]
Converts the data
element of msm objects to the old format.
recreate.olddata(x)
recreate.olddata(x)
x |
Object returned by the |
This is just provided for convenience and to illustrate the changes. It is
not guaranteed to be complete, and is liable to be withdrawn. Users who
were relying on the previous undocumented format are advised to upgrade
their code to use the new format, which uses model frames and model design
matrices in the standard format used in version 1.4, based on
model.frame
and model.matrix
.
A list of vectors and matrices in the undocumented ad-hoc format
used for the data
component of msm
objects in msm
versions 1.3.1 and earlier.
Score residuals for detecting outlying subjects.
scoreresid.msm(x, plot = FALSE)
scoreresid.msm(x, plot = FALSE)
x |
A fitted multi-state model, as returned by |
plot |
If |
The score residual for a single subject is
where is the vector of first derivatives of the
log-likelihood for that subject at maximum likelihood estimates
, and
is the observed Fisher
information matrix, that is, the matrix of second derivatives of minus the
log-likelihood for that subject at theta.
Subjects with a higher influence on the maximum likelihood estimates will have higher score residuals.
These are only available for models with analytic derivatives (which includes all non-hidden and most hidden Markov models).
Vector of the residuals, named by subject identifiers.
Andrew Titman [email protected] (theory), Chris Jackson [email protected] (code)
Simulate one realisation from a continuous-time Markov process up to a given time.
sim.msm( qmatrix, maxtime, covs = NULL, beta = NULL, obstimes = 0, start = 1, mintime = 0 )
sim.msm( qmatrix, maxtime, covs = NULL, beta = NULL, obstimes = 0, start = 1, mintime = 0 )
qmatrix |
The transition intensity matrix of the Markov process. The
diagonal of
|
maxtime |
Maximum time for the simulated process. |
covs |
Matrix of time-dependent covariates, with one row for each observation time and one column for each covariate. |
beta |
Matrix of linear covariate effects on log transition intensities. The rows correspond to different covariates, and the columns to the transition intensities. The intensities are ordered by reading across rows of the intensity matrix, starting with the first, counting the positive off-diagonal elements of the matrix. |
obstimes |
Vector of times at which the covariates are observed. |
start |
Starting state of the process. Defaults to 1. |
mintime |
Starting time of the process. Defaults to 0. |
The effect of time-dependent covariates on the transition intensity matrix for an individual is determined by assuming that the covariate is a step function which remains constant in between the individual's observation times.
A list with components,
states |
Simulated states through which the process moves. This ends
with either an absorption before |
times |
Exact times at which the process changes to the corresponding states |
qmatrix |
The given transition intensity matrix |
C. H. Jackson [email protected]
qmatrix <- rbind( c(-0.2, 0.1, 0.1 ), c(0.5, -0.6, 0.1 ), c(0, 0, 0) ) sim.msm(qmatrix, 30)
qmatrix <- rbind( c(-0.2, 0.1, 0.1 ), c(0.5, -0.6, 0.1 ), c(0, 0, 0) ) sim.msm(qmatrix, 30)
Simulate a dataset from a Markov model fitted using msm
, using
the maximum likelihood estimates as parameters, and the same observation
times as in the original data.
simfitted.msm(x, drop.absorb = TRUE, drop.pci.imp = TRUE)
simfitted.msm(x, drop.absorb = TRUE, drop.pci.imp = TRUE)
x |
A fitted multi-state model object as returned by |
drop.absorb |
Should repeated observations in an absorbing state be
omitted. Use the default of |
drop.pci.imp |
In time-inhomogeneous models fitted using the |
This function is a wrapper around simmulti.msm
, and only
simulates panel-observed data. To generate datasets with the exact times of
transition, use the lower-level sim.msm
.
Markov models with misclassified states fitted through the ematrix
option to msm
are supported, but not general hidden Markov
models with hmodel
. For misclassification models, this function
includes misclassification in the simulated states.
This function is used for parametric bootstrapping to estimate the null
distribution of the test statistic in pearson.msm
.
A dataset with variables as described in simmulti.msm
.
C. H. Jackson [email protected]
simmulti.msm
, sim.msm
,
pearson.msm
, msm
.
Simulate a number of individual realisations from a continuous-time Markov process. Observations of the process are made at specified arbitrary times for each individual, giving panel-observed data.
simmulti.msm( data, qmatrix, covariates = NULL, death = FALSE, start, ematrix = NULL, misccovariates = NULL, hmodel = NULL, hcovariates = NULL, censor.states = NULL, drop.absorb = TRUE )
simmulti.msm( data, qmatrix, covariates = NULL, death = FALSE, start, ematrix = NULL, misccovariates = NULL, hmodel = NULL, hcovariates = NULL, censor.states = NULL, drop.absorb = TRUE )
data |
A data frame with a mandatory column named |
qmatrix |
The transition intensity matrix of the Markov process, with
any covariates set to zero. The diagonal of
|
covariates |
List of linear covariate effects on log transition intensities. Each element is a vector of the effects of one covariate on all the transition intensities. The intensities are ordered by reading across rows of the intensity matrix, starting with the first, counting the positive off-diagonal elements of the matrix. For example, for a multi-state model with three transition intensities, and
two covariates
|
death |
Vector of indices of the death states. A death state is an
absorbing state whose time of entry is known exactly, but the individual is
assumed to be in an unknown transient state ("alive") at the previous
instant. This is the usual situation for times of death in chronic disease
monitoring data. For example, if you specify
|
start |
A vector with the same number of elements as there are distinct subjects in the data, giving the states in which each corresponding individual begins. Or a single number, if all of these are the same. Defaults to state 1 for each subject. |
ematrix |
An optional misclassification matrix for generating observed
states conditionally on the simulated true states. As defined in
|
misccovariates |
Covariate effects on misclassification probabilities
via multinomial logistic regression. Linear effects operate on the log of
each probability relative to the probability of classification in the
correct state. In same format as |
hmodel |
An optional hidden Markov model for generating observed
outcomes conditionally on the simulated true states. As defined in
|
hcovariates |
List of the same length as
|
censor.states |
Set of simulated states which should be replaced by a censoring indicator at censoring times. By default this is all transient states (representing alive, with unknown state). |
drop.absorb |
Drop repeated observations in the absorbing state, retaining only one. |
sim.msm
is called repeatedly to produce a simulated trajectory
for each individual. The state at each specified observation time is then
taken to produce a new column state
. The effect of time-dependent
covariates on the transition intensity matrix for an individual is
determined by assuming that the covariate is a step function which remains
constant in between the individual's observation times. If the subject
enters an absorbing state, then only the first observation in that state is
kept in the data frame. Rows corresponding to future observations are
deleted. The entry times into states given in death
are assumed to
be known exactly.
A data frame with columns,
subject |
Subject identification indicators |
time |
Observation times |
state |
Simulated (true) state at the corresponding time |
obs |
Observed outcome at the
corresponding time, if |
keep |
Row numbers of the original data. Useful when
|
plus any supplied covariates.
C. H. Jackson [email protected]
### Simulate 100 individuals with common observation times sim.df <- data.frame(subject = rep(1:100, rep(13,100)), time = rep(seq(0, 24, 2), 100)) qmatrix <- rbind(c(-0.11, 0.1, 0.01 ), c(0.05, -0.15, 0.1 ), c(0.02, 0.07, -0.09)) simmulti.msm(sim.df, qmatrix)
### Simulate 100 individuals with common observation times sim.df <- data.frame(subject = rep(1:100, rep(13,100)), time = rep(seq(0, 24, 2), 100)) qmatrix <- rbind(c(-0.11, 0.1, 0.01 ), c(0.05, -0.15, 0.1 ), c(0.02, 0.07, -0.09)) simmulti.msm(sim.df, qmatrix)
Estimate the mean sojourn times in the transient states of a multi-state model and their confidence limits.
sojourn.msm( x, covariates = "mean", ci = c("delta", "normal", "bootstrap", "none"), cl = 0.95, B = 1000 )
sojourn.msm( x, covariates = "mean", ci = c("delta", "normal", "bootstrap", "none"), cl = 0.95, B = 1000 )
x |
A fitted multi-state model, as returned by |
covariates |
The covariate values at which to estimate the mean sojourn
times. This can either be: the string the number a list of values, with optional names. For example,
|
ci |
If If If |
cl |
Width of the symmetric confidence interval to present. Defaults to 0.95. |
B |
Number of bootstrap replicates, or number of normal simulations from the distribution of the MLEs |
The mean sojourn time in a transient state is estimated by
, where
is the
th entry on the diagonal of the
estimated transition intensity matrix.
A continuous-time Markov model is fully specified by the mean sojourn times
and the probability that each state is next (pnext.msm
). This
is a more intuitively meaningful description of a model than the transition
intensity matrix (qmatrix.msm
).
Time dependent covariates, or time-inhomogeneous models, are not supported. This would require the mean of a piecewise exponential distribution, and the package author is not aware of any general analytic form for that.
A data frame with components:
estimates |
Estimated mean sojourn times in the transient states. |
SE |
Corresponding standard errors. |
L |
Lower confidence limits. |
U |
Upper confidence limits. |
C. H. Jackson [email protected]
Calculates a frequency table counting the number of times each pair of states were observed in successive observation times. This can be a useful way of summarising multi-state data.
statetable.msm(state, subject, data = NULL)
statetable.msm(state, subject, data = NULL)
state |
Observed states, assumed to be ordered by time within each subject. |
subject |
Subject identification numbers corresponding to |
data |
An optional data frame in which the variables represented by
|
If the data are intermittently observed (panel data) this table should not
be used to decide what transitions should be allowed in the matrix,
which works in continuous time. This function counts the transitions
between states over a time interval, not in real time. There can be
observed transitions between state
and
over an interval even
if
, because the process may have passed through one or more
intermediate states in the middle of the interval.
A frequency table with starting states as rows and finishing states as columns.
C. H. Jackson [email protected]
## Heart transplant data data(cav) ## 148 deaths from state 1, 48 from state 2 and 55 from state 3. statetable.msm(state, PTNUM, data=cav)
## Heart transplant data data(cav) ## 148 deaths from state 1, 48 from state 2 and 55 from state 3. statetable.msm(state, PTNUM, data=cav)
Summary method for fitted msm
models. This is simply a wrapper
around prevalence.msm
which produces a table of observed and
expected state prevalences for each time, and for models with covariates,
hazard.msm
to print hazard ratios with 95% confidence
intervals for covariate effects.
## S3 method for class 'msm' summary(object, hazard.scale = 1, ...)
## S3 method for class 'msm' summary(object, hazard.scale = 1, ...)
object |
A fitted multi-state model object, as returned by
|
hazard.scale |
Vector with same elements as number of covariates on transition rates. Corresponds to the increase in each covariate used to calculate its hazard ratio. Defaults to all 1. |
... |
Further arguments passed to |
A list of class summary.msm
, with components:
prevalences |
Output from |
hazard |
Output from |
hazard.scale |
Value of the |
C. H. Jackson [email protected]
msm
,prevalence.msm
,
hazard.msm
Plot the log-likelihood surface with respect to two parameters.
surface.msm( x, params = c(1, 2), np = 10, type = c("contour", "filled.contour", "persp", "image"), point = NULL, xrange = NULL, yrange = NULL, ... ) ## S3 method for class 'msm' contour(x, ...) ## S3 method for class 'msm' persp(x, ...) ## S3 method for class 'msm' image(x, ...)
surface.msm( x, params = c(1, 2), np = 10, type = c("contour", "filled.contour", "persp", "image"), point = NULL, xrange = NULL, yrange = NULL, ... ) ## S3 method for class 'msm' contour(x, ...) ## S3 method for class 'msm' persp(x, ...) ## S3 method for class 'msm' image(x, ...)
x |
Output from |
|||||||||
params |
Integer vector with two elements, giving the indices of the
parameters to vary. All other parameters will be fixed. Defaults to
|
|||||||||
np |
Number of grid points to use in each direction, by default 10. An
|
|||||||||
type |
Character string specifying the type of plot to produce.
|
|||||||||
point |
Vector of length |
|||||||||
xrange |
Range to plot for the first varied parameter. Defaults to plus and minus two standard errors, obtained from the Hessian at the maximum likelihood estimate. |
|||||||||
yrange |
Range to plot for the second varied parameter. Defaults to plus and minus two standard errors, obtained from the Hessian at the maximum likelihood estimate. |
|||||||||
... |
Further arguments to be passed to the plotting function. |
Draws a contour or perspective plot. Useful for diagnosing irregularities
in the likelihood surface. If you want to use these plots before running
the maximum likelihood estimation, then just run msm
with all
estimates fixed at their initial values.
contour.msm
just calls surface.msm with type = "contour"
.
persp.msm
just calls surface.msm with type = "persp"
.
image.msm
just calls surface.msm with type = "image"
.
As these three functions are methods of the generic functions
contour
, persp
and image
, they can be invoked as
contour(x)
, persp(x)
or image(x)
, where x
is a
fitted msm
object.
C. H. Jackson [email protected]
msm
, contour
,
filled.contour
, persp
, image
.
Tidy the parameter estimates from an msm model
## S3 method for class 'msm' tidy(x, ...)
## S3 method for class 'msm' tidy(x, ...)
x |
Object returned by |
... |
Other arguments (currently unused). |
A "tibble", with one row for each parameter and the following columns describing the parameter.
parclass
: Class of parameters: intens
(transition intensities), hr
(hazard ratios representing effects of covariates on intensities), and
their transformed versions logintens
(log intensities) and loghr
(log
hazard ratios).
For "misclassification" models fitted with the ematrix
argument to msm
,
other classes of parameters include misc
(misclassification
probabilities), logitmisc
(misclassification log odds), or_misc
and
logor_misc
(effects of covariates on misclassification probabilities, as
odds ratios or log odds ratios, with the first state as the reference
category).
For hidden Markov models fitted with the hmodel
argument to msm
, the
parameter class called hmm
comprises the parameters of the distributions
of the outcome conditionally on the hidden state. Covariates on the
location parameter of these distributions are included in class hmmcov
.
If initial state occupancy probabilities are estimated, these are included
in class initp
(or initlogodds
for the log odds transforms of these),
and any covariates on these probabilities are included in class initpcov
.
state
: Starting state of the transition for transition intensities, and
true state for misclassification probabilities or hidden Markov model parameters.
tostate
: Ending state of the transition for transition intensities, and
observed state for misclassification probabilities
term
: Name of the covariate for covariate effects, or "baseline" for the
baseline intensity or analogous parameter value.
Note that the "baseline" parameters are the parameters with covariates
set to their mean values in the data (stored in e.g. x$qcmodel$covmeans
),
unless msm
was called with center=FALSE
.
estimate
, std.error
, conf.low
, conf.high
: Parameter estimate,
standard error, and lower and upper confidence limits.
statistic
, p.value
: For covariate effects, the Z-test statistic and p-value
for a test of the null hypothesis that the covariate effect is zero, based
on the estimate and standard error.
This is the method for the generic 'tidy' function that is
used for tidying the output of qmatrix.msm
, pmatrix.msm
,
ematrix.msm
, pnext.msm
or ppass.msm
.
This should be called as
tidy()
, not tidy.msm.est()
or tidy.qmatrix()
or anything else.
## S3 method for class 'msm.est' tidy(x, ...)
## S3 method for class 'msm.est' tidy(x, ...)
x |
Output of |
... |
Further arguments (unused). |
Note this should be called as tidy()
not tidy.msm.totlos()
or anything else, as this is
a method for the generic tidy()
function.
## S3 method for class 'msm.estbystate' tidy(x, ...)
## S3 method for class 'msm.estbystate' tidy(x, ...)
x |
Output of |
... |
Further arguments (unused). |
A tibble with one row per state, and columns for the estimate, and confidence intervals if available.
Note this should be called as tidy()
not tidy.msm.prevalence()
or anything else, as this is
a method for the generic tidy()
function.
## S3 method for class 'msm.prevalence' tidy(x, ...)
## S3 method for class 'msm.prevalence' tidy(x, ...)
x |
Output of |
... |
Further arguments (unused). |
A tibble with one row per combination of output type (count or percentage) and state, and columns for observed value, expected value and confidence limits for the expected value (if available).
Density, distribution function, quantile function and random generation for
the truncated Normal distribution with mean equal to mean
and
standard deviation equal to sd
before truncation, and truncated on
the interval [lower, upper]
.
dtnorm(x, mean = 0, sd = 1, lower = -Inf, upper = Inf, log = FALSE) ptnorm( q, mean = 0, sd = 1, lower = -Inf, upper = Inf, lower.tail = TRUE, log.p = FALSE ) qtnorm( p, mean = 0, sd = 1, lower = -Inf, upper = Inf, lower.tail = TRUE, log.p = FALSE ) rtnorm(n, mean = 0, sd = 1, lower = -Inf, upper = Inf)
dtnorm(x, mean = 0, sd = 1, lower = -Inf, upper = Inf, log = FALSE) ptnorm( q, mean = 0, sd = 1, lower = -Inf, upper = Inf, lower.tail = TRUE, log.p = FALSE ) qtnorm( p, mean = 0, sd = 1, lower = -Inf, upper = Inf, lower.tail = TRUE, log.p = FALSE ) rtnorm(n, mean = 0, sd = 1, lower = -Inf, upper = Inf)
x , q
|
vector of quantiles. |
mean |
vector of means. |
sd |
vector of standard deviations. |
lower |
lower truncation point. |
upper |
upper truncation point. |
log |
logical; if TRUE, return log density or log hazard. |
lower.tail |
logical; if TRUE (default), probabilities are P[X <= x], otherwise, P[X > x]. |
log.p |
logical; if TRUE, probabilities p are given as log(p). |
p |
vector of probabilities. |
n |
number of observations. If |
The truncated normal distribution has density
for , and 0 otherwise.
is the mean of the original Normal distribution before
truncation,
is the corresponding standard deviation,
is the upper truncation point,
is the lower
truncation point,
is the density of the
corresponding normal distribution, and
is the
distribution function of the corresponding normal distribution.
If mean
or sd
are not specified they assume the default values
of 0
and 1
, respectively.
If lower
or upper
are not specified they assume the default
values of -Inf
and Inf
, respectively, corresponding to no
lower or no upper truncation.
Therefore, for example, dtnorm(x)
, with no other arguments, is simply
equivalent to dnorm(x)
.
Only rtnorm
is used in the msm
package, to simulate from
hidden Markov models with truncated normal distributions. This uses the
rejection sampling algorithms described by Robert (1995).
These functions are merely provided for completion, and are not optimized
for numerical stability or speed. To fit a hidden Markov model with a
truncated Normal response distribution, use a hmmTNorm
constructor. See the hmm-dists
help page for further details.
dtnorm
gives the density, ptnorm
gives the
distribution function, qtnorm
gives the quantile function, and
rtnorm
generates random deviates.
C. H. Jackson [email protected]
Robert, C. P. Simulation of truncated normal variables. Statistics and Computing (1995) 5, 121–125
x <- seq(50, 90, by=1) plot(x, dnorm(x, 70, 10), type="l", ylim=c(0,0.06)) ## standard Normal distribution lines(x, dtnorm(x, 70, 10, 60, 80), type="l") ## truncated Normal distribution
x <- seq(50, 90, by=1) plot(x, dnorm(x, 70, 10), type="l", ylim=c(0,0.06)) ## standard Normal distribution lines(x, dtnorm(x, 70, 10, 60, 80), type="l") ## truncated Normal distribution
Estimate the expected total length of stay, or the expected number of visits, in each state, for an individual in a given period of evolution of a multi-state model.
totlos.msm( x, start = 1, end = NULL, fromt = 0, tot = Inf, covariates = "mean", piecewise.times = NULL, piecewise.covariates = NULL, num.integ = FALSE, discount = 0, env = FALSE, ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, ... ) envisits.msm( x = NULL, start = 1, end = NULL, fromt = 0, tot = Inf, covariates = "mean", piecewise.times = NULL, piecewise.covariates = NULL, num.integ = FALSE, discount = 0, ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, ... )
totlos.msm( x, start = 1, end = NULL, fromt = 0, tot = Inf, covariates = "mean", piecewise.times = NULL, piecewise.covariates = NULL, num.integ = FALSE, discount = 0, env = FALSE, ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, ... ) envisits.msm( x = NULL, start = 1, end = NULL, fromt = 0, tot = Inf, covariates = "mean", piecewise.times = NULL, piecewise.covariates = NULL, num.integ = FALSE, discount = 0, ci = c("none", "normal", "bootstrap"), cl = 0.95, B = 1000, cores = NULL, ... )
x |
A fitted multi-state model, as returned by |
start |
Either a single number giving the state at the beginning of the period, or a vector of probabilities of being in each state at this time. |
end |
States to estimate the total length of stay (or number of visits) in. Defaults to all states. This is deprecated, since with the analytic solution (see "Details") it doesn't save any computation to only estimate for a subset of states. |
fromt |
Time from which to estimate. Defaults to 0, the beginning of the process. |
tot |
Time up to which the estimate is made. Defaults to infinity,
giving the expected time spent in or number of visits to the state until
absorption. However, the calculation will be much more efficient if a finite
(potentially large) time is specified: see the "Details" section. For
models without an absorbing state, |
covariates |
The covariate values to estimate for. This can either
be: the string the number or a list of values, with optional names. For example
where the order of the list follows the order of the covariates originally given in the model formula, or a named list,
|
piecewise.times |
Times at which piecewise-constant intensities change.
See |
piecewise.covariates |
Covariates on which the piecewise-constant
intensities depend. See |
num.integ |
Use numerical integration instead of analytic solution (see below). |
discount |
Discount rate in continuous time. |
env |
Supplied to |
ci |
If If If |
cl |
Width of the symmetric confidence interval, relative to 1 |
B |
Number of bootstrap replicates |
cores |
Number of cores to use for bootstrapping using parallel
processing. See |
... |
Further arguments to be passed to the |
The expected total length of stay in state between times
and
, from the point of view of an individual in state
at
time 0, is defined by the integral from
to
of the
entry of the transition probability matrix
,
where
is the transition intensity matrix.
The corresponding expected number of visits to state (excluding the
stay in the current state at time 0) is
, where
is the expected amount of time spent in state
.
More generally, suppose that is the vector of
probabilities of being in each state at time 0, supplied in
start
,
and we want the vector giving the expected lengths of
stay in each state. The corresponding integral has the following solution
(van Loan 1978; van Rosmalen et al. 2013)
where
is the row vector of initial state probabilities supplied
in
start
, is the row vector of K zeros,
is the discount rate,
is the K x K identity matrix,
and
is the matrix exponential.
Alternatively, the integrals can be calculated numerically, using the
integrate
function. This may take a long time for models with
many states where is expensive to calculate. This is required
where
tot = Inf
, since the package author is not aware of any
analytic expression for the limit of the above formula as goes to
infinity.
With the argument num.integ=TRUE
, numerical integration is used even
where the analytic solution is available. This facility is just provided for
checking results against versions 1.2.4 and earlier, and will be removed
eventually. Please let the package maintainer know if any results are
different.
For a model where the individual has only one place to go from each state, and each state is visited only once, for example a progressive disease model with no recovery or death, these are equal to the mean sojourn time in each state. However, consider a three-state health-disease-death model with transitions from health to disease, health to death, and disease to death, where everybody starts healthy. In this case the mean sojourn time in the disease state will be greater than the expected length of stay in the disease state. This is because the mean sojourn time in a state is conditional on entering the state, whereas the expected total time diseased is a forecast for a healthy individual, who may die before getting the disease.
In the above formulae, is assumed to be constant over time, but the
results generalise easily to piecewise-constant intensities. This function
automatically handles models fitted using the
pci
option to
msm
. For any other inhomogeneous models, the user must specify
piecewise.times
and piecewise.covariates
arguments to
totlos.msm
.
A vector of expected total lengths of stay
(totlos.msm
), or expected number of visits
(envisits.msm
), for each transient state.
C. H. Jackson [email protected]
C. van Loan (1978). Computing integrals involving the matrix exponential. IEEE Transactions on Automatic Control 23(3)395-404.
J. van Rosmalen, M. Toy and J.F. O'Mahony (2013). A mathematical approach for evaluating Markov models in continuous time without discrete-event simulation. Medical Decision Making 33:767-779.
sojourn.msm
, pmatrix.msm
,
integrate
, boot.msm
.
Returns the transient and absorbing states of either a fitted model or a transition intensity matrix.
transient.msm(x = NULL, qmatrix = NULL) absorbing.msm(x = NULL, qmatrix = NULL)
transient.msm(x = NULL, qmatrix = NULL) absorbing.msm(x = NULL, qmatrix = NULL)
x |
A fitted multi-state model as returned by |
qmatrix |
A transition intensity matrix. The diagonal is ignored and taken to be minus the sum of the rest of the row. |
A vector of the ordinal indices of the transient or absorbing states.
C. H. Jackson [email protected]
Density, distribution, quantile functions and other utilities for the Coxian phase-type distribution with two phases.
d2phase(x, l1, mu1, mu2, log = FALSE) p2phase(q, l1, mu1, mu2, lower.tail = TRUE, log.p = FALSE) q2phase(p, l1, mu1, mu2, lower.tail = TRUE, log.p = FALSE) r2phase(n, l1, mu1, mu2) h2phase(x, l1, mu1, mu2, log = FALSE)
d2phase(x, l1, mu1, mu2, log = FALSE) p2phase(q, l1, mu1, mu2, lower.tail = TRUE, log.p = FALSE) q2phase(p, l1, mu1, mu2, lower.tail = TRUE, log.p = FALSE) r2phase(n, l1, mu1, mu2) h2phase(x, l1, mu1, mu2, log = FALSE)
x , q
|
vector of quantiles. |
l1 |
Intensity for transition between phase 1 and phase 2. |
mu1 |
Intensity for transition from phase 1 to exit. |
mu2 |
Intensity for transition from phase 2 to exit. |
log |
logical; if TRUE, return log density or log hazard. |
lower.tail |
logical; if TRUE (default), probabilities are P[X <= x], otherwise, P[X > x]. |
log.p |
logical; if TRUE, probabilities p are given as log(p). |
p |
vector of probabilities. |
n |
number of observations. If |
This is the distribution of the time to reach state 3 in a continuous-time
Markov model with three states and transitions permitted from state 1 to
state 2 (with intensity ) state 1 to state 3
(intensity
) and state 2 to state 3 (intensity
). States 1 and 2 are the two "phases" and state 3 is the
"exit" state.
The density is
if , and
otherwise. The distribution function is
if , and
otherwise. Quantiles are calculated by numerically inverting the distribution function.
The mean is .
The variance is .
If it reduces to an exponential distribution with
rate
, and the parameter
is redundant.
Or also if
.
The hazard at is
, and smoothly increasing if
. If
it increases to an asymptote of
, and if
it increases to an
asymptote of
. The hazard is decreasing if
, to an asymptote of
.
d2phase
gives the density, p2phase
gives the
distribution function, q2phase
gives the quantile function,
r2phase
generates random deviates, and h2phase
gives the
hazard.
An individual following this distribution can be seen as coming from a mixture of two populations:
1) "short stayers" whose mean sojourn time is and sojourn
distribution is exponential with rate
.
2) "long stayers" whose mean sojourn time and sojourn
distribution is the sum of two exponentials with rate
and
respectively. The
individual is a "long stayer" with probability
.
Thus a two-phase distribution can be more intuitively parameterised by the
short and long stay means and the long stay probability
. Given these parameters, the transition intensities are
,
, and
. This can be useful for choosing
intuitively reasonable initial values for procedures to fit these models to
data.
The hazard is increasing at least if , and also
only if
.
For increasing hazards with , the maximum hazard ratio between any time
and time 0 is
.
For increasing hazards with , the maximum hazard ratio is
. This is the minimum hazard ratio for
decreasing hazards.
C. H. Jackson [email protected]
C. Dutang, V. Goulet and M. Pigeon (2008). actuar: An R Package for Actuarial Science. Journal of Statistical Software, vol. 25, no. 7, 1-37. URL http://www.jstatsoft.org/v25/i07
Update the maximum likelihood estimates in a fitted model object. Intended for developer use only.
updatepars.msm(x, pars)
updatepars.msm(x, pars)
x |
A fitted multi-state model object, as returned by
|
pars |
Vector of new parameters, in their untransformed real-line
parameterisations, to substitute for the maximum likelihood estimates
corresponding to those in the |
An updated msm
model object with the updated maximum
likelihood estimates, but with the covariances / standard errors unchanged.
Point estimates from output functions such as qmatrix.msm
,
pmatrix.msm
, or any related function, can then be evaluated
with the new parameters, and at arbitrary covariate values.
This function is used, for example, when computing confidence intervals from
pmatrix.msm
, and related functions, using the
ci="normal"
method.
C. H. Jackson [email protected]
For a fitted hidden Markov model, or a model with censored state observations, the Viterbi algorithm recursively constructs the path with the highest probability through the underlying states. The probability of each hidden state is also computed for hidden Markov models, using the forward-backward algorithm.
viterbi.msm(x, normboot = FALSE, newdata = NULL)
viterbi.msm(x, normboot = FALSE, newdata = NULL)
x |
A fitted hidden Markov multi-state model, or a model with censored
state observations, as produced by |
normboot |
If |
newdata |
An optional data frame containing observations on which to
construct the Viterbi path and forward-backward probabilities. It must be in
the same format as the data frame used to fit |
A data frame with columns:
subject
= subject identification numbers
time
= times of observations
observed
= corresponding observed states
fitted
= corresponding fitted states found by Viterbi recursion. If
the model is not a hidden Markov model, and there are no censored state
observations, this is just the observed states.
For hidden Markov models, an additional matrix pstate
is also
returned inside the data frame, giving the probability of each hidden state
at each point, conditionally on all the data. This is computed by the
forward/backward algorithm.
C. H. Jackson [email protected]
Durbin, R., Eddy, S., Krogh, A. and Mitchison, G. Biological sequence analysis, Cambridge University Press, 1998.