Joint Modeling of Longitudinal and Survival Data.
JM: Joint Models for Longitudinal and Survival Data using Maximum Likelihood
Description
This repository contains the source files for the R package JM. This package fits joint models for longitudinal and time-to-event data using maximum likelihood. These models are applicable in mainly two settings. First, when focus is on the survival outcome and we wish to account for the effect of an endogenous (aka internal) time-dependent covariates measured with error. Second, when focus is on the longitudinal outcome and we wish to correct for nonrandom dropout.
The basic joint-model-fitting function of the package is jointModel()
. This accepts as main arguments a linear mixed model fitted by function lme()
from the nlme package and a Cox model fitted using function coxph()
from the survival package.
Basic Features
It can fit joint models for a single continuous longitudinal outcome and a time-to-event outcome.
For the survival outcome a relative risk models is assumed. The
method
argument ofjointModel()
can be used to define the type of baseline hazard function. Options are a B-spline approximation, a piecewise-constant function, the Weibull hazard and a completely unspecified function (i.e., a discrete function with point masses at the unique event times).The user has now the option to define custom transformation functions for the terms of the longitudinal submodel that enter into the linear predictor of the survival submodel (arguments
derivForm
,parameterization
). For example, the current value of the longitudinal outcomes, the velocity of the longitudinal outcome (slope), the area under the longitudinal profile. From the aforementioned options, in each model up to two terms can be included. In addition, using argumentInterFact
interactions terms can be considered.
Dynamic predictions
Function
survfitJM()
computes dynamic survival probabilities.Function
predict()
computes dynamic predictions for the longitudinal outcome.Function
aucJM()
calculates time-dependent AUCs for joint models, and functionrocJM()
calculates the corresponding time-dependent sensitivities and specifies.Function
prederrJM()
calculates prediction errors for joint models.