Title: | Extended Joint Models for Longitudinal and Time-to-Event Data |
---|---|
Description: | Fit joint models for longitudinal and time-to-event data under the Bayesian approach. Multiple longitudinal outcomes of mixed type (continuous/categorical) and multiple event times (competing risks and multi-state processes) are accommodated. Rizopoulos (2012, ISBN:9781439872864). |
Authors: | Dimitris Rizopoulos [aut, cre] , Grigorios Papageorgiou [aut], Pedro Miranda Afonso [aut] |
Maintainer: | Dimitris Rizopoulos <[email protected]> |
License: | GPL (>= 3) |
Version: | 0.5-1 |
Built: | 2025-01-16 04:23:31 UTC |
Source: | https://github.com/drizopoulos/jmbayes2 |
Using the available longitudinal information up to a starting time point, these functions compute estimates of the ROC curve and the AUC, the Brier score and expected predictive cross-entropy at a horizon time point based on joint models.
tvROC(object, newdata, Tstart, ...) ## S3 method for class 'jm' tvROC(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, type_weights = c("model-based", "IPCW"), ...) tvAUC(object, newdata, Tstart, ...) ## S3 method for class 'jm' tvAUC(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, type_weights = c("model-based", "IPCW"), ...) ## S3 method for class 'tvROC' tvAUC(object, ...) calibration_plot(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, df_ns = 3, plot = TRUE, add_density = TRUE, col = "red", lty = 1, lwd = 1, col_dens = "grey", xlab = "Predicted Probabilities", ylab = "Observed Probabilities", main = "", ...) calibration_metrics(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, df_ns = 3, ...) tvBrier(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, integrated = FALSE, type_weights = c("model-based", "IPCW"), model_weights = NULL, eventData_fun = NULL, parallel = c("snow", "multicore"), cores = parallelly::availableCores(omit = 1L), ...) tvEPCE(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, eps = 0.001, model_weights = NULL, eventData_fun = NULL, parallel = c("snow", "multicore"), cores = parallelly::availableCores(omit = 1L), ...) create_folds(data, V = 5, id_var = "id", strata = NULL, seed = 123L)
tvROC(object, newdata, Tstart, ...) ## S3 method for class 'jm' tvROC(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, type_weights = c("model-based", "IPCW"), ...) tvAUC(object, newdata, Tstart, ...) ## S3 method for class 'jm' tvAUC(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, type_weights = c("model-based", "IPCW"), ...) ## S3 method for class 'tvROC' tvAUC(object, ...) calibration_plot(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, df_ns = 3, plot = TRUE, add_density = TRUE, col = "red", lty = 1, lwd = 1, col_dens = "grey", xlab = "Predicted Probabilities", ylab = "Observed Probabilities", main = "", ...) calibration_metrics(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, df_ns = 3, ...) tvBrier(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, integrated = FALSE, type_weights = c("model-based", "IPCW"), model_weights = NULL, eventData_fun = NULL, parallel = c("snow", "multicore"), cores = parallelly::availableCores(omit = 1L), ...) tvEPCE(object, newdata, Tstart, Thoriz = NULL, Dt = NULL, eps = 0.001, model_weights = NULL, eventData_fun = NULL, parallel = c("snow", "multicore"), cores = parallelly::availableCores(omit = 1L), ...) create_folds(data, V = 5, id_var = "id", strata = NULL, seed = 123L)
object |
an object inheriting from class |
newdata |
a data.frame that contains the longitudinal and covariate information for the subjects for which prediction of survival probabilities is required. The names of the variables in this data.frame must be the same as in the data.frames that were used to fit the linear mixed effects and the event process model that were supplied as the two first argument of |
Tstart |
numeric scalar denoting the time point up to which longitudinal information is to be used to derive predictions. |
Thoriz |
numeric scalar denoting the time point for which a prediction of the survival status is of interest; |
Dt |
numeric scalar denoting the length of the time interval of prediction; either |
integrated |
logical; if |
type_weights |
character string denoting the type of weights to use to account for censorting. Options are model-based (default) and inverse probability of censoring weighting (using the Kaplan-Meier estimate of the censoring distribution). |
eps |
numeric scalar used in the approximation of the hazard function. |
model_weights |
a numeric vector of weights to combine predictions when |
eventData_fun |
a function that takes as input the |
parallel |
character string; what type of parallel computing to use. |
cores |
integer denoting the number of cores to be used when a library of joint models has been provided in
|
df_ns |
the degrees of freedom for the natural cubic spline of the cloglog transformation of the predicted probabilities used in the Cox model that assess calibration. |
plot |
logical; should a plot be produced. If |
add_density |
logical; should the kernal density estimation of the predicted probabilities be superimposed in the calibration plot. |
col , lwd , lty , col_dens , xlab , ylab , main
|
graphical parameters. |
data |
the data.frame to split in folds. |
V |
numeric scalar denoting the number of folds. |
id_var |
character string denoting the name of the subject id variable in |
strata |
character vector with the names of stratifying variables. |
seed |
integer denoting the seed. |
... |
additional arguments passed to |
A list of class tvAUC
with components:
auc |
a numeric scalar denoting the estimated prediction error. |
Tstart |
a copy of the |
Thoriz |
a copy of the |
nr |
a numeric scalar denoting the number of subjects at risk at time |
classObject |
the class of |
nameObject |
the name of |
A list of class tvROC
with components:
TP , FP , nTP , nFN , nTN , qSN , qSP , qOverall
|
accuracy indexes. |
F1score , Youden
|
numeric scalars with the optimal cut-point using the F1 score and the Youden index. |
thr |
numeric vector of thresholds. |
Tstart |
a copy of the |
Thoriz |
a copy of the |
nr |
a numeric scalar denoting the number of subjects at risk at time |
classObject |
the class of |
nameObject |
the name of |
Dimitris Rizopoulos [email protected]
Antolini, L., Boracchi, P., and Biganzoli, E. (2005). A time-dependent discrimination index for survival data. Statistics in Medicine 24, 3927–3944.
Commenges, D., Liquet, B., and Proust-Lima, C. (2012). Choice of prognostic estimators in joint models by estimating differences of expected conditional Kullback-Leibler risks. Biometrics 68, 380–387.
Harrell, F., Kerry, L. and Mark, D. (1996). Multivariable prognostic models: issues in developing models, evaluating assumptions and adequacy, and measuring and reducing errors. Statistics in Medicine 15, 361–387.
Heagerty, P. and Zheng, Y. (2005). Survival model predictive accuracy and ROC curves. Biometrics 61, 92–105.
Rizopoulos, D. (2016). The R package JMbayes for fitting joint models for longitudinal and time-to-event data using MCMC. Journal of Statistical Software 72(7), 1–45. doi:10.18637/jss.v072.i07.
Rizopoulos, D. (2012) Joint Models for Longitudinal and Time-to-Event Data: with Applications in R. Boca Raton: Chapman and Hall/CRC.
Rizopoulos, D. (2011). Dynamic predictions and prospective accuracy in joint models for longitudinal and time-to-event data. Biometrics 67, 819–829.
Rizopoulos, D., Molenberghs, G. and Lesaffre, E.M.E.H. (2017). Dynamic predictions with time-dependent covariates in survival analysis using joint modeling and landmarking. Biometrical Journal 59, 1261–1276.
# We fit a multivariate joint model pbc2.id$status2 <- as.numeric(pbc2.id$status != 'alive') CoxFit <- coxph(Surv(years, status2) ~ sex, data = pbc2.id) fm1 <- lme(log(serBilir) ~ ns(year, 3) * sex, data = pbc2, random = ~ ns(year, 3) | id, control = lmeControl(opt = 'optim')) fm2 <- lme(prothrombin ~ ns(year, 2) * sex, data = pbc2, random = ~ ns(year, 2) | id, control = lmeControl(opt = 'optim')) fm3 <- mixed_model(ascites ~ year * sex, data = pbc2, random = ~ year | id, family = binomial()) jointFit <- jm(CoxFit, list(fm1, fm2, fm3), time_var = "year", n_chains = 1L) roc <- tvROC(jointFit, newdata = pbc2, Tstart = 4, Dt = 3, cores = 1L) roc tvAUC(roc) plot(roc, legend = TRUE, optimal_cutoff = "Youden")
# We fit a multivariate joint model pbc2.id$status2 <- as.numeric(pbc2.id$status != 'alive') CoxFit <- coxph(Surv(years, status2) ~ sex, data = pbc2.id) fm1 <- lme(log(serBilir) ~ ns(year, 3) * sex, data = pbc2, random = ~ ns(year, 3) | id, control = lmeControl(opt = 'optim')) fm2 <- lme(prothrombin ~ ns(year, 2) * sex, data = pbc2, random = ~ ns(year, 2) | id, control = lmeControl(opt = 'optim')) fm3 <- mixed_model(ascites ~ year * sex, data = pbc2, random = ~ year | id, family = binomial()) jointFit <- jm(CoxFit, list(fm1, fm2, fm3), time_var = "year", n_chains = 1L) roc <- tvROC(jointFit, newdata = pbc2, Tstart = 4, Dt = 3, cores = 1L) roc tvAUC(roc) plot(roc, legend = TRUE, optimal_cutoff = "Youden")
A randomized clinical trial in which both longitudinal and survival data were collected to compare the efficacy and safety of two antiretroviral drugs in treating patients who had failed or were intolerant of zidovudine (AZT) therapy.
A data frame with 1408 observations on the following 9 variables.
patient
patients identifier; in total there are 467 patients.
Time
the time to death or censoring.
death
a numeric vector with 0 denoting censoring and 1 death.
CD4
the CD4 cells count.
obstime
the time points at which the CD4 cells count was recorded.
drug
a factor with levels ddC
denoting zalcitabine and ddI
denoting didanosine.
gender
a factor with levels female
and male
.
prevOI
a factor with levels AIDS
denoting previous opportunistic infection (AIDS
diagnosis) at study entry, and noAIDS
denoting no previous infection.
AZT
a factor with levels intolerance
and failure
denoting AZT intolerance and
AZT failure, respectively.
The data frame aids.id
contains the first CD4 cell count measurement for each patient. This data frame is used to
fit the survival model.
Goldman, A., Carlin, B., Crane, L., Launer, C., Korvick, J., Deyton, L. and Abrams, D. (1996) Response of CD4+ and clinical consequences to treatment using ddI or ddC in patients with advanced HIV infection. Journal of Acquired Immune Deficiency Syndromes and Human Retrovirology 11, 161–169.
Guo, X. and Carlin, B. (2004) Separate and joint modeling of longitudinal and event time data using standard computer packages. The American Statistician 58, 16–24.
In a competing risks setting this function expands the data frame with a single row per subject to a data frame in the long format in which each subject has as many rows as the number of competing events.
crisk_setup(data, statusVar, censLevel, nameStrata = "strata", nameStatus = "status2")
crisk_setup(data, statusVar, censLevel, nameStrata = "strata", nameStatus = "status2")
data |
the data frame containing the competing risk data with a single row per subject. |
statusVar |
a character string denoting the name of the variable in
|
censLevel |
a character string or a scalar denoting the censoring level
in the |
nameStrata |
a character string denoting the variable that will be added
in the long version of |
nameStatus |
a character string denoting the variable that will be added
in the long version of |
A data frame in the long format with multiple rows per subject.
Dimitris Rizopoulos [email protected]
Rizopoulos, D. (2012) Joint Models for Longitudinal and Time-to-Event Data: with Applications in R. Boca Raton: Chapman and Hall/CRC.
Putter, H., Fiocco, M., and Geskus, R. (2007). Tutorial in biostatistics: Competing risks and multi-state models. Statistics in Medicine 26, 2389–2430.
head(crisk_setup(pbc2.id, "status", "alive"))
head(crisk_setup(pbc2.id, "status", "alive"))
Fits multivariate joint models for longitudinal and time-to-event data.
jm(Surv_object, Mixed_objects, time_var, recurrent = FALSE, functional_forms = NULL, which_independent = NULL, data_Surv = NULL, id_var = NULL, priors = NULL, control = NULL, ...) value(x) coefs(x, zero_ind = NULL) slope(x, eps = 0.001, direction = "both") velocity(x, eps = 0.001, direction = "both") acceleration(x) area(x, time_window = NULL) vexpit(x) Dexpit(x) vexp(x) Dexp(x) vabs(x) vlog(x) vlog2(x) vlog10(x) vsqrt(x) poly2(x) poly3(x) poly4(x) tv(x, knots = NULL, ord = 2L)
jm(Surv_object, Mixed_objects, time_var, recurrent = FALSE, functional_forms = NULL, which_independent = NULL, data_Surv = NULL, id_var = NULL, priors = NULL, control = NULL, ...) value(x) coefs(x, zero_ind = NULL) slope(x, eps = 0.001, direction = "both") velocity(x, eps = 0.001, direction = "both") acceleration(x) area(x, time_window = NULL) vexpit(x) Dexpit(x) vexp(x) Dexp(x) vabs(x) vlog(x) vlog2(x) vlog10(x) vsqrt(x) poly2(x) poly3(x) poly4(x) tv(x, knots = NULL, ord = 2L)
Surv_object |
an object:
|
Mixed_objects |
a
|
time_var |
a |
recurrent |
a |
functional_forms |
a |
which_independent |
a numeric indicator matrix denoting which outcomes are independent. It can also be the character string |
data_Surv |
the |
id_var |
a |
priors |
a named
|
control |
a list of control values with components:
|
x |
a numeric input variable. |
knots |
a numeric vector of knots. |
ord |
an integer denoting the order of the spline. |
zero_ind |
a list with integer vectors indicating which coefficients are set to zero in the calculation of the value term. This can be used to include for example only the random intercept; default is |
eps |
numeric scalar denoting the step-size for the finite difference approximation. |
direction |
character string for the direction of the numerical derivative, options are |
time_window |
numeric scalar denoting the lower limit for calculating the integral. |
... |
arguments passed to |
The mathematical details regarding the definition of the multivariate joint model, and the capabilities of the package can be found in the vignette in the doc directory.
Notes:
The ordering of the subjects in the datasets used to fit the mixed and Cox regression models needs to be the same.
The units of the time variables in the mixed and Cox models need to be the same.
A list of class jm
with components:
mcmc |
a |
acc_rates |
a |
logLik |
a |
mlogLik |
a |
running_time |
an object of class |
statistics |
a |
fit_stats |
a |
model_data |
a |
model_info |
a |
initial_values |
a |
control |
a copy of the |
priors |
a copy of the |
call |
the matched call. |
Dimitris Rizopoulos [email protected]
################################################################################ ############################################## # Univariate joint model for serum bilirubin # # 1 continuous outcome # ############################################## # [1] Fit the mixed model using lme(). fm1 <- lme(fixed = log(serBilir) ~ year * sex + I(year^2) + age + prothrombin, random = ~ year | id, data = pbc2) # [2] Fit a Cox model, specifying the baseline covariates to be included in the # joint model. fCox1 <- coxph(Surv(years, status2) ~ drug + age, data = pbc2.id) # [3] The basic joint model is fitted using a call to jm() i.e., joint_model_fit_1 <- jm(fCox1, fm1, time_var = "year", n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) summary(joint_model_fit_1) traceplot(joint_model_fit_1) ################################################################################ ########################################################################## # Multivariate joint model for serum bilirubin, hepatomegaly and ascites # # 1 continuous outcome, 2 categorical outcomes # ########################################################################## # [1] Fit the mixed-effects models using lme() for continuous # outcomes and mixed_model() for categorical outcomes. fm1 <- lme(fixed = log(serBilir) ~ year * sex, random = ~ year | id, data = pbc2) fm2 <- mixed_model(hepatomegaly ~ sex + age + year, data = pbc2, random = ~ year | id, family = binomial()) fm3 <- mixed_model(ascites ~ year + age, data = pbc2, random = ~ year | id, family = binomial()) # [2] Save all the fitted mixed-effects models in a list. Mixed <- list(fm1, fm2, fm3) # [3] Fit a Cox model, specifying the baseline covariates to be included in the # joint model. fCox1 <- coxph(Surv(years, status2) ~ drug + age, data = pbc2.id) # [4] The joint model is fitted using a call to jm() i.e., joint_model_fit_2 <- jm(fCox1, Mixed, time_var = "year", n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) summary(joint_model_fit_2) traceplot(joint_model_fit_2) ################################################################################ ###################### # Slope & Area Terms # ###################### # We extend model 'joint_model_fit_2' by including the value and slope term for # bilirubin, the area term for hepatomegaly (in the log-odds scale), and the # value and area term for spiders (in the log-odds scale). # To include these terms into the model, we specify the 'functional_forms' # argument. This should be a list of right side formulas. Each component of the # list should have as name the name of the corresponding outcome variable. In # the right side formula we specify the functional form of the association using # functions 'value()', 'slope()' and 'area()'. # Notes: (1) For terms not specified in the 'functional_forms' list, the default # value functional form is used. # [1] Fit the mixed-effects models using lme() for continuous outcomes # and mixed_model() for categorical outcomes. fm1 <- lme(fixed = log(serBilir) ~ year * sex, random = ~ year | id, data = pbc2) fm2 <- mixed_model(hepatomegaly ~ sex + age + year, data = pbc2, random = ~ year | id, family = binomial()) fm3 <- mixed_model(ascites ~ year + age, data = pbc2, random = ~ year | id, family = binomial()) # [2] Save all the fitted mixed-effects models in a list. Mixed <- list(fm1, fm2, fm3) # [3] Fit a Cox model, specifying the baseline covariates to be included in the # joint model. fCox1 <- coxph(Surv(years, status2) ~ drug + age, data = pbc2.id) # [4] Specify the list of formulas to be passed to the functional_forms argument # of jm(). fForms <- list("log(serBilir)" = ~ value(log(serBilir)) + slope(log(serBilir)), "hepatomegaly" = ~ area(hepatomegaly), "ascites" = ~ value(ascites) + area(ascites)) # [5] The joint model is fitted using a call to jm() and passing the list # to the functional_forms argument. joint_model_fit_2 <- jm(fCox1, Mixed, time_var = "year", functional_forms = fForms, n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) summary(joint_model_fit_2)
################################################################################ ############################################## # Univariate joint model for serum bilirubin # # 1 continuous outcome # ############################################## # [1] Fit the mixed model using lme(). fm1 <- lme(fixed = log(serBilir) ~ year * sex + I(year^2) + age + prothrombin, random = ~ year | id, data = pbc2) # [2] Fit a Cox model, specifying the baseline covariates to be included in the # joint model. fCox1 <- coxph(Surv(years, status2) ~ drug + age, data = pbc2.id) # [3] The basic joint model is fitted using a call to jm() i.e., joint_model_fit_1 <- jm(fCox1, fm1, time_var = "year", n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) summary(joint_model_fit_1) traceplot(joint_model_fit_1) ################################################################################ ########################################################################## # Multivariate joint model for serum bilirubin, hepatomegaly and ascites # # 1 continuous outcome, 2 categorical outcomes # ########################################################################## # [1] Fit the mixed-effects models using lme() for continuous # outcomes and mixed_model() for categorical outcomes. fm1 <- lme(fixed = log(serBilir) ~ year * sex, random = ~ year | id, data = pbc2) fm2 <- mixed_model(hepatomegaly ~ sex + age + year, data = pbc2, random = ~ year | id, family = binomial()) fm3 <- mixed_model(ascites ~ year + age, data = pbc2, random = ~ year | id, family = binomial()) # [2] Save all the fitted mixed-effects models in a list. Mixed <- list(fm1, fm2, fm3) # [3] Fit a Cox model, specifying the baseline covariates to be included in the # joint model. fCox1 <- coxph(Surv(years, status2) ~ drug + age, data = pbc2.id) # [4] The joint model is fitted using a call to jm() i.e., joint_model_fit_2 <- jm(fCox1, Mixed, time_var = "year", n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) summary(joint_model_fit_2) traceplot(joint_model_fit_2) ################################################################################ ###################### # Slope & Area Terms # ###################### # We extend model 'joint_model_fit_2' by including the value and slope term for # bilirubin, the area term for hepatomegaly (in the log-odds scale), and the # value and area term for spiders (in the log-odds scale). # To include these terms into the model, we specify the 'functional_forms' # argument. This should be a list of right side formulas. Each component of the # list should have as name the name of the corresponding outcome variable. In # the right side formula we specify the functional form of the association using # functions 'value()', 'slope()' and 'area()'. # Notes: (1) For terms not specified in the 'functional_forms' list, the default # value functional form is used. # [1] Fit the mixed-effects models using lme() for continuous outcomes # and mixed_model() for categorical outcomes. fm1 <- lme(fixed = log(serBilir) ~ year * sex, random = ~ year | id, data = pbc2) fm2 <- mixed_model(hepatomegaly ~ sex + age + year, data = pbc2, random = ~ year | id, family = binomial()) fm3 <- mixed_model(ascites ~ year + age, data = pbc2, random = ~ year | id, family = binomial()) # [2] Save all the fitted mixed-effects models in a list. Mixed <- list(fm1, fm2, fm3) # [3] Fit a Cox model, specifying the baseline covariates to be included in the # joint model. fCox1 <- coxph(Surv(years, status2) ~ drug + age, data = pbc2.id) # [4] Specify the list of formulas to be passed to the functional_forms argument # of jm(). fForms <- list("log(serBilir)" = ~ value(log(serBilir)) + slope(log(serBilir)), "hepatomegaly" = ~ area(hepatomegaly), "ascites" = ~ value(ascites) + area(ascites)) # [5] The joint model is fitted using a call to jm() and passing the list # to the functional_forms argument. joint_model_fit_2 <- jm(fCox1, Mixed, time_var = "year", functional_forms = fForms, n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) summary(joint_model_fit_2)
Methods for an object of class "jm"
for diagnostic functions.
traceplot(object, ...) ## S3 method for class 'jm' traceplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), ...) ggtraceplot(object, ...) ## S3 method for class 'jm' ggtraceplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), size = 1, alpha = 0.8, theme = c('standard', 'catalog', 'metro', 'pastel', 'beach', 'moonlight', 'goo', 'sunset', 'custom'), grid = FALSE, gridrows = 3, gridcols = 1, custom_theme = NULL, ...) gelman_diag(object, ...) ## S3 method for class 'jm' gelman_diag(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), ...) densplot(object, ...) ## S3 method for class 'jm' densplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), ...) ggdensityplot(object, ...) ## S3 method for class 'jm' ggdensityplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), size = 1, alpha = 0.6, theme = c('standard', 'catalog', 'metro', 'pastel', 'beach', 'moonlight', 'goo', 'sunset', 'custom'), grid = FALSE, gridrows = 3, gridcols = 1, custom_theme = NULL, ...) cumuplot(object, ...) ## S3 method for class 'jm' cumuplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), ...)
traceplot(object, ...) ## S3 method for class 'jm' traceplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), ...) ggtraceplot(object, ...) ## S3 method for class 'jm' ggtraceplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), size = 1, alpha = 0.8, theme = c('standard', 'catalog', 'metro', 'pastel', 'beach', 'moonlight', 'goo', 'sunset', 'custom'), grid = FALSE, gridrows = 3, gridcols = 1, custom_theme = NULL, ...) gelman_diag(object, ...) ## S3 method for class 'jm' gelman_diag(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), ...) densplot(object, ...) ## S3 method for class 'jm' densplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), ...) ggdensityplot(object, ...) ## S3 method for class 'jm' ggdensityplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), size = 1, alpha = 0.6, theme = c('standard', 'catalog', 'metro', 'pastel', 'beach', 'moonlight', 'goo', 'sunset', 'custom'), grid = FALSE, gridrows = 3, gridcols = 1, custom_theme = NULL, ...) cumuplot(object, ...) ## S3 method for class 'jm' cumuplot(object, parm = c("all", "betas", "sigmas", "D", "bs_gammas", "tau_bs_gammas", "gammas", "alphas"), ...)
object |
an object inheriting from class |
parm |
a character string specifying which parameters of the joint model to plot. Possible options are |
size |
the width of the traceplot line in mm. Defaults to 1. |
alpha |
the opacity level of the traceplot line. Defaults to 0.8. |
theme |
a character string specifying the color theme to be used. Possible options are |
grid |
logical; defaults to |
gridrows |
number of rows per page for the grid. Only relevant when using |
gridcols |
number of columns per page for the grid. Only relevant when using |
custom_theme |
A named character vector with elements equal to the number of chains ( |
... |
further arguments passed to the corresponding function from the coda package. |
traceplot()
Plots the evolution of the estimated parameter vs. iterations in a fitted joint model.
ggtraceplot()
Plots the evolution of the estimated parameter vs. iterations in a fitted joint model using ggplot2.
gelman_diag()
Calculates the potential scale reduction factor for the estimated parameters in a fitted joint model, together with the upper confidence limits.
densplot()
Plots the density estimate for the estimated parameters in a fitted joint model.
ggdensityplot()
Plots the evolution of the estimated parameter vs. iterations in a fitted joint model using ggplot2.
cumuplot()
Plots the evolution of the sample quantiles vs. iterations in a fitted joint model.
Dimitris Rizopoulos [email protected]
# linear mixed model fits fit_lme1 <- lme(log(serBilir) ~ year:sex + age, random = ~ year | id, data = pbc2) fit_lme2 <- lme(prothrombin ~ sex, random = ~ year | id, data = pbc2) # cox model fit fit_cox <- coxph(Surv(years, status2) ~ age, data = pbc2.id) # joint model fit fit_jm <- jm(fit_cox, list(fit_lme1, fit_lme2), time_var = "year", n_chains = 1L) # trace plot for the fixed effects in the linear mixed submodels traceplot(fit_jm, parm = "betas") # density plot for the fixed effects in the linear mixed submodels densplot(fit_jm, parm = "betas") # cumulative quantile plot for the fixed effects in the linear mixed submodels cumuplot(fit_jm, parm = "betas") # trace plot for the fixed effects in the linear mixed submodels ggtraceplot(fit_jm, parm = "betas") ggtraceplot(fit_jm, parm = "betas", grid = TRUE) ggtraceplot(fit_jm, parm = "betas", custom_theme = c('1' = 'black')) # trace plot for the fixed effects in the linear mixed submodels ggdensityplot(fit_jm, parm = "betas") ggdensityplot(fit_jm, parm = "betas", grid = TRUE) ggdensityplot(fit_jm, parm = "betas", custom_theme = c('1' = 'black'))
# linear mixed model fits fit_lme1 <- lme(log(serBilir) ~ year:sex + age, random = ~ year | id, data = pbc2) fit_lme2 <- lme(prothrombin ~ sex, random = ~ year | id, data = pbc2) # cox model fit fit_cox <- coxph(Surv(years, status2) ~ age, data = pbc2.id) # joint model fit fit_jm <- jm(fit_cox, list(fit_lme1, fit_lme2), time_var = "year", n_chains = 1L) # trace plot for the fixed effects in the linear mixed submodels traceplot(fit_jm, parm = "betas") # density plot for the fixed effects in the linear mixed submodels densplot(fit_jm, parm = "betas") # cumulative quantile plot for the fixed effects in the linear mixed submodels cumuplot(fit_jm, parm = "betas") # trace plot for the fixed effects in the linear mixed submodels ggtraceplot(fit_jm, parm = "betas") ggtraceplot(fit_jm, parm = "betas", grid = TRUE) ggtraceplot(fit_jm, parm = "betas", custom_theme = c('1' = 'black')) # trace plot for the fixed effects in the linear mixed submodels ggdensityplot(fit_jm, parm = "betas") ggdensityplot(fit_jm, parm = "betas", grid = TRUE) ggdensityplot(fit_jm, parm = "betas", custom_theme = c('1' = 'black'))
Methods for object of class "jm"
for standard generic functions.
coef(object, ...) ## S3 method for class 'jm' coef(object, ...) fixef(object, ...) ## S3 method for class 'jm' fixef(object, outcome = Inf, ...) ranef(object, ...) ## S3 method for class 'jm' ranef(object, outcome = Inf, post_vars = FALSE, ...) terms(x, ...) ## S3 method for class 'jm' terms(x, process = c("longitudinal", "event"), type = c("fixed", "random"), ...) model.frame(formula, ...) ## S3 method for class 'jm' model.frame(formula, process = c("longitudinal", "event"), type = c("fixed", "random"), ...) model.matrix(object, ...) ## S3 method for class 'jm' model.matrix(object, ...) family(object, ...) ## S3 method for class 'jm' family(object, ...) compare_jm(..., type = c("marginal", "conditional"), order = c("WAIC", "DIC", "LPML", "none"))
coef(object, ...) ## S3 method for class 'jm' coef(object, ...) fixef(object, ...) ## S3 method for class 'jm' fixef(object, outcome = Inf, ...) ranef(object, ...) ## S3 method for class 'jm' ranef(object, outcome = Inf, post_vars = FALSE, ...) terms(x, ...) ## S3 method for class 'jm' terms(x, process = c("longitudinal", "event"), type = c("fixed", "random"), ...) model.frame(formula, ...) ## S3 method for class 'jm' model.frame(formula, process = c("longitudinal", "event"), type = c("fixed", "random"), ...) model.matrix(object, ...) ## S3 method for class 'jm' model.matrix(object, ...) family(object, ...) ## S3 method for class 'jm' family(object, ...) compare_jm(..., type = c("marginal", "conditional"), order = c("WAIC", "DIC", "LPML", "none"))
object , x , formula
|
object inheriting from class |
outcome |
the index of the linear mixed submodel to extract the estimated fixed effects. If greater than the total number of submodels, extracts from all of them. |
post_vars |
logical; if |
process |
which submodel(s) to extract the terms:
|
type |
in
in
|
... |
further arguments; currently, none is used. |
order |
which criteria use to sort the models in the output. |
coef()
Extracts estimated fixed effects for the event process from a fitted joint model.
fixef()
Extracts estimated fixed effects for the longitudinal processes from a fitted joint model.
ranef()
Extracts estimated random effects from a fitted joint model.
terms()
Extracts the terms object(s) from a fitted joint model.
model.frame()
Creates the model frame from a fitted joint model.
model.matrix()
Creates the design matrices for linear mixed submodels from a fitted joint model.
family()
Extracts the error distribution and link function used in the linear mixed submodel(s) from a fitted joint model.
compare_jm()
Compares two or more fitted joint models using the criteria WAIC, DIC, and LPML.
coef()
a list with the elements:
gammas
: estimated baseline fixed effects, and
association
: estimated association parameters.
fixef()
a numeric vector of the estimated fixed effects for the outcome
selected. If the outcome
is greater than the number of linear mixed submodels, it returns a list of numeric vectors for all outcomes.
ranef()
a numeric matrix with rows denoting the individuals and columns the random effects. If postVar = TRUE
, the numeric matrix has the extra attribute "postVar".
terms()
if process = "longitudinal"
, a list of the terms object(s) for the linear mixed model(s).
if process = "event"
, the terms object for the survival model.
model.frame()
if process = "longitudinal"
, a list of the model frames used in the linear mixed model(s).
if process = "event"
, the model frame used in the survival model.
model.matrix()
a list of the design matrix(ces) for the linear mixed submodel(s).
family()
a list of family
objects.
compare_jm()
a list with the elements:
table
: a table with the criteria calculated for each joint model, and
type
: the log-likelihood function used to calculate the criteria.
Dimitris Rizopoulos [email protected]
# linear mixed model fits fit_lme1 <- lme(log(serBilir) ~ year:sex + age, random = ~ year | id, data = pbc2) fit_lme2 <- lme(prothrombin ~ sex, random = ~ year | id, data = pbc2) # cox model fit fit_cox <- coxph(Surv(years, status2) ~ age, data = pbc2.id) # joint model fit fit_jm <- jm(fit_cox, list(fit_lme1, fit_lme2), time_var = "year", n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) # coef(): fixed effects for the event process coef(fit_jm) # fixef(): fixed effects for the first linear mixed submodel fixef(fit_jm, outcome = 1) # ranef(): random effects from all linear mixed submodels head(ranef(fit_jm)) # terms(): random effects terms for the first linear mixed submodel terms(fit_jm, process = "longitudinal", type = "random")[[1]] # mode.frame(): model frame for the fixed effects in the second # linear mixed submodel head(model.frame(fit_jm, process = "longitudinal", type = "fixed")[[2]]) # model.matrix(): fixed effects design matrix for the first linear # mixed submodel head(model.matrix(fit_jm)[[1]]) # family(): family objects from both linear mixed submodels family(fit_jm) # compare_jm(): compare two fitted joint models fit_lme1b <- lme(log(serBilir) ~ 1, random = ~ year | id, data = pbc2) fit_jm2 <- jm(fit_cox, list(fit_lme1b, fit_lme2), time_var = "year", n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) compare_jm(fit_jm, fit_jm2)
# linear mixed model fits fit_lme1 <- lme(log(serBilir) ~ year:sex + age, random = ~ year | id, data = pbc2) fit_lme2 <- lme(prothrombin ~ sex, random = ~ year | id, data = pbc2) # cox model fit fit_cox <- coxph(Surv(years, status2) ~ age, data = pbc2.id) # joint model fit fit_jm <- jm(fit_cox, list(fit_lme1, fit_lme2), time_var = "year", n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) # coef(): fixed effects for the event process coef(fit_jm) # fixef(): fixed effects for the first linear mixed submodel fixef(fit_jm, outcome = 1) # ranef(): random effects from all linear mixed submodels head(ranef(fit_jm)) # terms(): random effects terms for the first linear mixed submodel terms(fit_jm, process = "longitudinal", type = "random")[[1]] # mode.frame(): model frame for the fixed effects in the second # linear mixed submodel head(model.frame(fit_jm, process = "longitudinal", type = "fixed")[[2]]) # model.matrix(): fixed effects design matrix for the first linear # mixed submodel head(model.matrix(fit_jm)[[1]]) # family(): family objects from both linear mixed submodels family(fit_jm) # compare_jm(): compare two fitted joint models fit_lme1b <- lme(log(serBilir) ~ 1, random = ~ year | id, data = pbc2) fit_jm2 <- jm(fit_cox, list(fit_lme1b, fit_lme2), time_var = "year", n_chains = 1L, n_iter = 11000L, n_burnin = 1000L) compare_jm(fit_jm, fit_jm2)
Fit joint models for longitudinal and time-to-event data under the Bayesian approach. Multiple longitudinal outcomes of mixed type (continuous/categorical) and multiple event times (competing risks and multi-state processes) are accommodated.
Package: | JMbayes2 |
Type: | Package |
Version: | 0.5-1 |
Date: | 2024-06-05 |
License: | GPL (>=3) |
This package fits joint models for longitudinal and time-to-event data. It can accommodate multiple longitudinal outcomes of different type (e.g., continuous, dichotomous, ordinal, counts), and assuming different distributions, i.e., Gaussian, Student's-t, Gamma, Beta, unit Lindley, censored Normal, Binomial, Poisson, Negative Binomial, and Beta-Binomial. For the event time process, right, left and interval censored data can be handled, while competing risks and multi-sate processes are also covered.
JMbayes2 fits joint models using Markov chain Monte Carlo algorithms implemented in C++. The package also offers several utility functions that can extract useful information from fitted joint models. The most important of those are included in the See also Section below.
Dimitris Rizopoulos, Grigorios Papageorgiou, Pedro Miranda Afonso
Maintainer: Dimitris Rizopoulos <[email protected]>
Rizopoulos, D. (2012). Joint Models for Longitudinal and Time-to-Event Data With Applications in R. Boca Raton: Chapman & Hall/CRC.
jm
,
methods.jm
,
coda_methods.jm
Follow up of 312 randomised patients with primary biliary cirrhosis, a rare autoimmune liver disease, at Mayo Clinic.
A data frame with 1945 observations on the following 20 variables.
id
patients identifier; in total there are 312 patients.
years
number of years between registration and the earlier of death, transplantion, or study analysis time.
status
a factor with levels alive
, transplanted
and dead
.
drug
a factor with levels placebo
and D-penicil
.
age
at registration in years.
sex
a factor with levels male
and female
.
year
number of years between enrollment and this visit date, remaining values on the line of data refer to this visit.
ascites
a factor with levels No
and Yes
.
hepatomegaly
a factor with levels No
and Yes
.
spiders
a factor with levels No
and Yes
.
edema
a factor with levels No edema
(i.e., no edema and no diuretic therapy for edema),
edema no diuretics
(i.e., edema present without diuretics, or edema resolved by diuretics), and
edema despite diuretics
(i.e., edema despite diuretic therapy).
serBilir
serum bilirubin in mg/dl.
serChol
serum cholesterol in mg/dl.
albumin
albumin in g/dl.
alkaline
alkaline phosphatase in U/liter.
SGOT
SGOT in U/ml.
platelets
platelets per cubic ml / 1000.
prothrombin
prothrombin time in seconds.
histologic
histologic stage of disease.
status2
a numeric vector with the value 1 denoting if the patient was dead, and 0 if the patient was alive or transplanted.
The data frame pbc2.id
contains the first measurement for each patient. This data frame is used to
fit the survival model.
Fleming, T. and Harrington, D. (1991) Counting Processes and Survival Analysis. Wiley, New York.
Therneau, T. and Grambsch, P. (2000) Modeling Survival Data: Extending the Cox Model. Springer-Verlag, New York.
Predict method for object of class "jm"
.
## S3 method for class 'jm' predict(object, newdata = NULL, newdata2 = NULL, times = NULL, process = c("longitudinal", "event"), type_pred = c("response", "link"), type = c("subject_specific", "mean_subject"), control = NULL, ...) ## S3 method for class 'predict_jm' plot(x, x2 = NULL, subject = 1, outcomes = 1, fun_long = NULL, fun_event = NULL, CI_long = TRUE, CI_event = TRUE, xlab = "Follow-up Time", ylab_long = NULL, ylab_event = "Cumulative Risk", main = "", lwd_long = 2, lwd_event = 2, ylim_event = c(0, 1), ylim_long_outcome_range = TRUE, col_line_long = "#0000FF", col_line_event = c("#FF0000", "#03BF3D", "#8000FF"), pch_points = 16, col_points = "blue", cex_points = 1, fill_CI_long = "#0000FF4D", fill_CI_event = c("#FF00004D", "#03BF3D4D", "#8000FF4D"), cex_xlab = 1, cex_ylab_long = 1, cex_ylab_event = 1, cex_main = 1, cex_axis = 1, col_axis = "black", pos_ylab_long = c(0.1, 2, 0.08), bg = "white", ...) ## S3 method for class 'jmList' predict(object, weights, newdata = NULL, newdata2 = NULL, times = NULL, process = c("longitudinal", "event"), type_pred = c("response", "link"), type = c("subject_specific", "mean_subject"), control = NULL, ...)
## S3 method for class 'jm' predict(object, newdata = NULL, newdata2 = NULL, times = NULL, process = c("longitudinal", "event"), type_pred = c("response", "link"), type = c("subject_specific", "mean_subject"), control = NULL, ...) ## S3 method for class 'predict_jm' plot(x, x2 = NULL, subject = 1, outcomes = 1, fun_long = NULL, fun_event = NULL, CI_long = TRUE, CI_event = TRUE, xlab = "Follow-up Time", ylab_long = NULL, ylab_event = "Cumulative Risk", main = "", lwd_long = 2, lwd_event = 2, ylim_event = c(0, 1), ylim_long_outcome_range = TRUE, col_line_long = "#0000FF", col_line_event = c("#FF0000", "#03BF3D", "#8000FF"), pch_points = 16, col_points = "blue", cex_points = 1, fill_CI_long = "#0000FF4D", fill_CI_event = c("#FF00004D", "#03BF3D4D", "#8000FF4D"), cex_xlab = 1, cex_ylab_long = 1, cex_ylab_event = 1, cex_main = 1, cex_axis = 1, col_axis = "black", pos_ylab_long = c(0.1, 2, 0.08), bg = "white", ...) ## S3 method for class 'jmList' predict(object, weights, newdata = NULL, newdata2 = NULL, times = NULL, process = c("longitudinal", "event"), type_pred = c("response", "link"), type = c("subject_specific", "mean_subject"), control = NULL, ...)
object |
an object inheriting from class |
weights |
a numeric vector of model weights. |
newdata , newdata2
|
data.frames. |
times |
a numeric vector of future times to calculate predictions. |
process |
for which process to calculation predictions, for the longitudinal outcomes or the event times. |
type |
level of predictions; only relevant when |
type_pred |
type of predictions; options are |
control |
a named
.
|
x , x2
|
objects returned by |
subject |
when multiple subjects are included in the data.frames |
outcomes |
when multiple longitudinal outcomes are included in the data.frames |
fun_long , fun_event
|
function to apply to the predictions for the longitudinal and event outcomes, respectively. When multiple longitudinal outcomes are plotted, |
CI_long , CI_event
|
logical; should credible interval areas be plotted. |
xlab , ylab_long , ylab_event
|
characture strings or a chracter vector for |
lwd_long , lwd_event , col_line_long , col_line_event , main , fill_CI_long , fill_CI_event , cex_xlab , cex_ylab_long , cex_ylab_event , cex_main , cex_axis , pch_points , col_points , cex_points , col_axis , bg
|
graphical parameters; see |
pos_ylab_long |
controls the position of the y-axis labels when multiple longitudinal outcomes are plotted. |
ylim_event |
the |
ylim_long_outcome_range |
logical; if |
... |
aguments passed to control. |
A detailed description of the methodology behind these predictions is given here: https://drizopoulos.github.io/JMbayes2/articles/Dynamic_Predictions.html.
Method predict()
returns a list or a data.frame (if return_newdata
was set to TRUE
) with the predictions.
Method plot()
produces figures of the predictions from a single subject.
Dimitris Rizopoulos [email protected]
# We fit a multivariate joint model pbc2.id$status2 <- as.numeric(pbc2.id$status != 'alive') CoxFit <- coxph(Surv(years, status2) ~ sex, data = pbc2.id) fm1 <- lme(log(serBilir) ~ ns(year, 3) * sex, data = pbc2, random = ~ ns(year, 3) | id, control = lmeControl(opt = 'optim')) fm2 <- lme(prothrombin ~ ns(year, 2) * sex, data = pbc2, random = ~ ns(year, 2) | id, control = lmeControl(opt = 'optim')) fm3 <- mixed_model(ascites ~ year * sex, data = pbc2, random = ~ year | id, family = binomial()) jointFit <- jm(CoxFit, list(fm1, fm2, fm3), time_var = "year", n_chains = 1L) # we select the subject for whom we want to calculate predictions # we use measurements up to follow-up year 3; we also set that the patients # were alive up to this time point t0 <- 3 ND <- pbc2[pbc2$id %in% c(2, 25), ] ND <- ND[ND$year < t0, ] ND$status2 <- 0 ND$years <- t0 # predictions for the longitudinal outcomes using newdata predLong1 <- predict(jointFit, newdata = ND, return_newdata = TRUE) # predictions for the longitudinal outcomes at future time points # from year 3 to 10 predLong2 <- predict(jointFit, newdata = ND, times = seq(t0, 10, length.out = 51), return_newdata = TRUE) # predictions for the event outcome at future time points # from year 3 to 10 predSurv <- predict(jointFit, newdata = ND, process = "event", times = seq(t0, 10, length.out = 51), return_newdata = TRUE) plot(predLong1) # for subject 25, outcomes in reverse order plot(predLong2, outcomes = 3:1, subject = 25) # prediction for the event outcome plot(predSurv) # combined into one plot, the first longitudinal outcome and cumulative risk plot(predLong2, predSurv, outcomes = 1) # the first two longitudinal outcomes plot(predLong1, predSurv, outcomes = 1:2) # all three longitudinal outcomes, we display survival probabilities instead # of cumulative risk, and we transform serum bilirubin to the original scale plot(predLong2, predSurv, outcomes = 1:3, fun_event = function (x) 1 - x, fun_long = list(exp, identity, identity), ylab_event = "Survival Probabilities", ylab_long = c("Serum Bilirubin", "Prothrombin", "Ascites"), pos_ylab_long = c(1.9, 1.9, 0.08))
# We fit a multivariate joint model pbc2.id$status2 <- as.numeric(pbc2.id$status != 'alive') CoxFit <- coxph(Surv(years, status2) ~ sex, data = pbc2.id) fm1 <- lme(log(serBilir) ~ ns(year, 3) * sex, data = pbc2, random = ~ ns(year, 3) | id, control = lmeControl(opt = 'optim')) fm2 <- lme(prothrombin ~ ns(year, 2) * sex, data = pbc2, random = ~ ns(year, 2) | id, control = lmeControl(opt = 'optim')) fm3 <- mixed_model(ascites ~ year * sex, data = pbc2, random = ~ year | id, family = binomial()) jointFit <- jm(CoxFit, list(fm1, fm2, fm3), time_var = "year", n_chains = 1L) # we select the subject for whom we want to calculate predictions # we use measurements up to follow-up year 3; we also set that the patients # were alive up to this time point t0 <- 3 ND <- pbc2[pbc2$id %in% c(2, 25), ] ND <- ND[ND$year < t0, ] ND$status2 <- 0 ND$years <- t0 # predictions for the longitudinal outcomes using newdata predLong1 <- predict(jointFit, newdata = ND, return_newdata = TRUE) # predictions for the longitudinal outcomes at future time points # from year 3 to 10 predLong2 <- predict(jointFit, newdata = ND, times = seq(t0, 10, length.out = 51), return_newdata = TRUE) # predictions for the event outcome at future time points # from year 3 to 10 predSurv <- predict(jointFit, newdata = ND, process = "event", times = seq(t0, 10, length.out = 51), return_newdata = TRUE) plot(predLong1) # for subject 25, outcomes in reverse order plot(predLong2, outcomes = 3:1, subject = 25) # prediction for the event outcome plot(predSurv) # combined into one plot, the first longitudinal outcome and cumulative risk plot(predLong2, predSurv, outcomes = 1) # the first two longitudinal outcomes plot(predLong1, predSurv, outcomes = 1:2) # all three longitudinal outcomes, we display survival probabilities instead # of cumulative risk, and we transform serum bilirubin to the original scale plot(predLong2, predSurv, outcomes = 1:3, fun_event = function (x) 1 - x, fun_long = list(exp, identity, identity), ylab_event = "Survival Probabilities", ylab_long = c("Serum Bilirubin", "Prothrombin", "Ascites"), pos_ylab_long = c(1.9, 1.9, 0.08))
A randomized trial on 488 liver cirrhosis patients.
Two data frames with the following variables.
id
patients identifier; in total there are 467 patients.
pro
prothrobin measurements.
time
for data frame prothro
the time points at which the prothrobin measurements were taken;
for data frame prothros
the time to death or censoring.
death
a numeric vector with 0 denoting censoring and 1 death.
treat
randomized treatment; a factor with levels "placebo" and "prednisone".
http://www.gllamm.org/books/readme.html#14.6.
Andersen, P. K., Borgan, O., Gill, R. D. and Keiding, N. (1993). Statistical Models Based on Counting Processes. New York: Springer.
This function combines two data frames, the recurring-event and terminal-event/competing-risks datasets, into one. Each subject has as many rows in the new data frame as the number of recurrent risk periods plus one for each terminal event/competing risk.
rc_setup(rc_data, trm_data, idVar = "id", statusVar = "status", startVar = "start", stopVar = "stop", trm_censLevel, nameStrata = "strata", nameStatus = "status")
rc_setup(rc_data, trm_data, idVar = "id", statusVar = "status", startVar = "start", stopVar = "stop", trm_censLevel, nameStrata = "strata", nameStatus = "status")
rc_data |
the data frame containing the recurring-event data with multiple rows per subject. |
trm_data |
the data frame containing the terminal-event/competing-risks data with a single row per subject. |
idVar |
a character string denoting the name of the variable in
|
statusVar |
a character string denoting the name of the variable in
|
startVar |
a character string denoting the name of the variable in
|
stopVar |
a character string denoting the name of the variable in
|
trm_censLevel |
a character string or a scalar denoting the censoring
level in the statusVar variable of |
nameStrata |
a character string denoting the variable that will be added
in the long version of |
nameStatus |
a character string denoting the variable that will be added
in the long version of |
A data frame in the long format with multiple rows per subject.
Pedro Miranda Afonso [email protected]