Title: | Integrative Survival Modeling |
---|---|
Description: | Contains implementations of integrative survival analysis routines, including regular Cox cure rate model proposed by Kuk and Chen (1992) <doi:10.1093/biomet/79.3.531> via an EM algorithm proposed by Sy and Taylor (2000) <doi:10.1111/j.0006-341X.2000.00227.x>, regularized Cox cure rate model with elastic net penalty following Masud et al. (2018) <doi:10.1177/0962280216677748>, and Zou and Hastie (2005) <doi:10.1111/j.1467-9868.2005.00503.x>, and weighted concordance index for cure models proposed by Asano and Hirakawa (2017) <doi:10.1080/10543406.2017.1293082>. |
Authors: | Wenjie Wang [aut, cre] , Kun Chen [ths] , Jun Yan [ths] |
Maintainer: | Wenjie Wang <[email protected]> |
License: | GPL (>= 3) |
Version: | 0.2.3.9000 |
Built: | 2025-01-05 04:47:50 UTC |
Source: | https://github.com/wenjie2wang/intsurv |
The package intsurv provides implementations of
integrative Cox model with uncertain event times (Wang et al., 2020)
Cox cure rate model with uncertain event status (Wang et al., 2020)
It also contains other survival analysis routines, including regular Cox cure rate model, regularized Cox cure rate model with elastic net penalty, and weighted concordance index.
Wang, W., Aseltine, R. H., Chen, K., & Yan, J. (2020). Integrative Survival Analysis with Uncertain Event Times in Application to A Suicide Risk Study. Annals of Applied Statistics, 14(1), 51–73.
Wang, W., Luo, C., Aseltine, R. H., Wang, F., Yan, J., & Chen, K. (2020). Suicide Risk Modeling with Uncertain Diagnostic Records. arXiv preprint arXiv:2009.02597.
Compute Bayesian information criterion (BIC) or Schwarz's Bayesian criterion (SBC) for possibly one or several objects.
## S3 method for class 'cox_cure' BIC(object, ..., method = c("obs", "effective")) ## S3 method for class 'cox_cure_uncer' BIC(object, ..., method = c("obs", "certain-event"))
## S3 method for class 'cox_cure' BIC(object, ..., method = c("obs", "effective")) ## S3 method for class 'cox_cure_uncer' BIC(object, ..., method = c("obs", "certain-event"))
object |
An object for a fitted model. |
... |
Other objects of the same class. |
method |
A character string specifying the method for computing the BIC
values. Notice that this argument is placed after |
Volinsky, C. T., & Raftery, A. E. (2000). Bayesian information criterion for censored survival models. Biometrics, 56(1), 256–262.
## See examples of function 'cox_cure'.
## See examples of function 'cox_cure'.
Compute Bayesian information criterion (BIC) or Schwarz's Bayesian criterion (SBC) from a fitted solution path.
## S3 method for class 'cox_cure_net' BIC(object, ..., method = c("obs", "effective")) ## S3 method for class 'cox_cure_net_uncer' BIC(object, ..., method = c("obs", "certain-event"))
## S3 method for class 'cox_cure_net' BIC(object, ..., method = c("obs", "effective")) ## S3 method for class 'cox_cure_net_uncer' BIC(object, ..., method = c("obs", "certain-event"))
object |
An object for a fitted solution path. |
... |
Other arguments for future usage. A warning message will be thrown for any invalid argument. |
method |
A character string specifying the method for computing the BIC
values. Notice that this argument is placed after |
Volinsky, C. T., & Raftery, A. E. (2000). Bayesian information criterion for censored survival models. Biometrics, 56(1), 256–262.
## See examples of function 'cox_cure_net'.
## See examples of function 'cox_cure_net'.
For iCoxph-class
object, add (or update) standard error (SE)
estimates through bootstrap methods, or compute the coefficient estimates
from the given number of bootstrap samples.
bootSe( object, B = 50, se = c("inter-quartile", "mad", "sd"), return_beta = FALSE, ... )
bootSe( object, B = 50, se = c("inter-quartile", "mad", "sd"), return_beta = FALSE, ... )
object |
|
B |
A positive integer specifying number of bootstrap samples used for
SE estimates. A large number, such as 200, is often needed for a more
reliable estimation in practice. If |
se |
A character value specifying the way computing SE from bootstrap samples. The default method is based on median absolute deviation and the second method is based on inter-quartile, both of which are based on normality of the bootstrap estimates and provides robust estimates for SE. The third method estimates SE by the standard deviation of the bootstrap estimates. |
return_beta |
A logical value. If |
... |
Other arguments for future usage. A warning will be thrown if any invalid argument is specified. |
Three different methods are available for computing SE from bootstrap
samples through argument se
. Given the fact that the bootstrap
method is computationally intensive, the function returns the coefficient
estimates in a matrix from the given number of bootstrap samples when
return_beta = TRUE)
is specified, which can be used in parallel
computing or high performance computing (HPC) cluster. The SE estimates can
be further computed based on estimates from bootstrap samples by users on
their own. The return_beta = TRUE
is implied, when B = 1
is
specified.
iCoxph-class
object or a numeric matrix that contains
the covariate coefficient estimates from the given number of bootstrap
samples in rows.
iCoxph
for fitting integrative Cox model.
## See examples of function 'iCoxph'.
## See examples of function 'iCoxph'.
Compute concordance index (C-index or C-statistic) that allows weights for right-censored survival data. For example, Asano and Hirakawa (2017) proposed cure status weighting for cure models, which reduces to Harrell's C-index if weighs are all ones.
cIndex(time, event = NULL, risk_score, weight = NULL)
cIndex(time, event = NULL, risk_score, weight = NULL)
time |
A numeric vector for observed times |
event |
A numeric vector for event indicators. If it is |
risk_score |
A numeric vector representing the risk scores of events. |
weight |
A optional numeric vector for weights. If it is |
Let ,
, and
denote the risk score, observed
time, and event indicator of
-th subject. The pair of
and
, where
, are defined
to be comparable if
or
. In the context of survival analysis,
the risk scores of a comparable pair are said to be concordant with the
survival outcomes if
. The C-index is defined as the
proportion of the concordant pairs among the comparable pairs. For
comparable pair satisfying
, we count 0.5 in the
numerator of the concordance index for tied risk scores (
).
A named numeric vector that consists of
index
: the concordance index.
concordant
: the number of concordant pairs.
comparable
: the number of comparable pairs.
tied_tisk
: the number of comparable pairs having tied risks.
Asano, J., & Hirakawa, A. (2017). Assessing the prediction accuracy of a cure model for censored survival data with long-term survivors: Application to breast cancer data. Journal of Biopharmaceutical Statistics, 27(6), 918–932.
Harrell, F. E., Lee, K. L., & Mark, D. B. (1996). Multivariable prognostic models: Issues in developing models, evaluating assumptions and adequacy, and measuring and reducing errors. Statistics in medicine, 15(4), 361–387.
## See examples of function 'cox_cure'.
## See examples of function 'cox_cure'.
coef,iCoxph-method
is an S4 class method that extracts covariate
coefficient estimates from iCoxph-class
object from function
iCoxph
.
## S4 method for signature 'iCoxph' coef(object, ...)
## S4 method for signature 'iCoxph' coef(object, ...)
object |
|
... |
Other arguments for future usage. |
A named numeric vector.
iCoxph
for fitting integrative Cox model;
summary,iCoxph-method
for summary of a fitted model.
## See examples of function iCoxph.
## See examples of function iCoxph.
Extract the covariate coefficient estimates from a fitted Cox cure rate model with possible uncertain event status.
## S3 method for class 'cox_cure' coef(object, part = c("both", "survival", "cure"), ...) ## S3 method for class 'cox_cure_uncer' coef(object, part = c("both", "survival", "cure"), ...)
## S3 method for class 'cox_cure' coef(object, part = c("both", "survival", "cure"), ...) ## S3 method for class 'cox_cure_uncer' coef(object, part = c("both", "survival", "cure"), ...)
object |
Object representing a fitted model. |
part |
A character string specifying the coefficient estimates from a
particular model part. The available options are |
... |
Other arguments for future usage. |
If part = "both"
, this function returns a list that consists
of the following named elements
surv
: the coefficient estimates of survival model part.
cure
: the coefficient estimates of cure rate model part.
Otherwise, a named numeric vector representing the coefficient estimates of the specified model part will be returned.
Extract the covariate coefficient estimates from a solution path of regularized Cox cure rate model.
## S3 method for class 'cox_cure_net' coef(object, naive_en = FALSE, selection = c("bic1", "bic2", "all"), ...) ## S3 method for class 'cox_cure_net_uncer' coef(object, naive_en = FALSE, selection = c("bic1", "bic2", "all"), ...)
## S3 method for class 'cox_cure_net' coef(object, naive_en = FALSE, selection = c("bic1", "bic2", "all"), ...) ## S3 method for class 'cox_cure_net_uncer' coef(object, naive_en = FALSE, selection = c("bic1", "bic2", "all"), ...)
object |
Object representing a fitted solution path. |
naive_en |
A logical value specifying whether to return naive elastic
net estimates. If |
selection |
A character string for specifying the criterion for
selection of coefficient estimates. The available options are
|
... |
Other arguments for future usage. |
A list that consists of the following named elements:
surv
: the selected coefficient estimates of survival model
part.
cure
: the selected coefficient estimates of cure rate model
part.
## see examples of function `cox_cure_net`
## see examples of function `cox_cure_net`
For right-censored data, fit a regular Cox cure rate model (Kuk and Chen, 1992; Sy and Taylor, 2000) via an EM algorithm. For right-censored data with uncertain event status, fit the Cox cure model proposed by Wang et al. (2020).
cox_cure( surv_formula, cure_formula, time, event, data, subset, contrasts = NULL, bootstrap = 0, firth = FALSE, surv_start = NULL, cure_start = NULL, surv_offset = NULL, cure_offset = NULL, em_max_iter = 200, em_rel_tol = 1e-05, surv_max_iter = 30, surv_rel_tol = 1e-05, cure_max_iter = 30, cure_rel_tol = 1e-05, tail_completion = c("zero", "exp", "zero-tau"), tail_tau = NULL, pmin = 1e-05, early_stop = TRUE, verbose = FALSE, ... ) cox_cure.fit( surv_x, cure_x, time, event, cure_intercept = TRUE, bootstrap = 0, firth = FALSE, surv_start = NULL, cure_start = NULL, surv_offset = NULL, cure_offset = NULL, surv_standardize = TRUE, cure_standardize = TRUE, em_max_iter = 200, em_rel_tol = 1e-05, surv_max_iter = 30, surv_rel_tol = 1e-05, cure_max_iter = 30, cure_rel_tol = 1e-05, tail_completion = c("zero", "exp", "zero-tau"), tail_tau = NULL, pmin = 1e-05, early_stop = TRUE, verbose = FALSE, ... )
cox_cure( surv_formula, cure_formula, time, event, data, subset, contrasts = NULL, bootstrap = 0, firth = FALSE, surv_start = NULL, cure_start = NULL, surv_offset = NULL, cure_offset = NULL, em_max_iter = 200, em_rel_tol = 1e-05, surv_max_iter = 30, surv_rel_tol = 1e-05, cure_max_iter = 30, cure_rel_tol = 1e-05, tail_completion = c("zero", "exp", "zero-tau"), tail_tau = NULL, pmin = 1e-05, early_stop = TRUE, verbose = FALSE, ... ) cox_cure.fit( surv_x, cure_x, time, event, cure_intercept = TRUE, bootstrap = 0, firth = FALSE, surv_start = NULL, cure_start = NULL, surv_offset = NULL, cure_offset = NULL, surv_standardize = TRUE, cure_standardize = TRUE, em_max_iter = 200, em_rel_tol = 1e-05, surv_max_iter = 30, surv_rel_tol = 1e-05, cure_max_iter = 30, cure_rel_tol = 1e-05, tail_completion = c("zero", "exp", "zero-tau"), tail_tau = NULL, pmin = 1e-05, early_stop = TRUE, verbose = FALSE, ... )
surv_formula |
A formula object starting with |
cure_formula |
A formula object starting with |
time |
A numeric vector for the observed survival times. |
event |
A numeric vector for the event indicators. |
data |
An optional data frame, list, or environment that contains the
covariates and response variables ( |
subset |
An optional logical vector specifying a subset of observations to be used in the fitting process. |
contrasts |
An optional list, whose entries are values (numeric
matrices or character strings naming functions) to be used as
replacement values for the contrasts replacement function and whose
names are the names of columns of data containing factors. See
|
bootstrap |
An integer representing the number of bootstrap samples for
estimating standard errors of the coefficient estimates. The bootstrap
procedure will not run with |
firth |
A logical value indicating whether to use Firth's
bias-reduction method (Firth, 1993) in the logistic model component.
The default value is |
surv_start , cure_start
|
An optional numeric vector representing the
starting values for the survival model component or the incidence model
component. If |
surv_offset , cure_offset
|
An optional numeric vector representing the
offset term in the survival model compoent or the incidence model
component. The function will internally try to find values of the
specified variable in the |
em_max_iter |
A positive integer specifying the maximum iteration
number of the EM algorithm. The default value is |
em_rel_tol |
A positive number specifying the tolerance that determines
the convergence of the EM algorithm in terms of the convergence of the
covariate coefficient estimates. The tolerance is compared with the
relative change between estimates from two consecutive iterations, which
is measured by ratio of the L1-norm of their difference to the sum of
their L1-norm. The default value is |
surv_max_iter , cure_max_iter
|
A positive integer specifying the maximum
iteration number of the M-step routine related to the survival model
component or the incidence model component. The default value is
|
surv_rel_tol , cure_rel_tol
|
A positive number specifying the tolerance
that determines the convergence of the M-step related to the survival
model component or the incidence model component in terms of the
convergence of the covariate coefficient estimates. The tolerance is
compared with the relative change between estimates from two consecutive
iterations, which is measured by ratio of the L1-norm of their
difference to the sum of their L1-norm. The default value is
|
tail_completion |
A character string specifying the tail completion
method for conditional survival function. The available methods are
|
tail_tau |
A numeric number specifying the time of zero-tail
completion. It will be used only if |
pmin |
A numeric number specifying the minimum value of probabilities
for sake of numerical stability. The default value is |
early_stop |
A logical value specifying whether to stop the iteration
once the negative log-likelihood unexpectedly increases, which may
suggest convergence on likelihood, or indicate numerical issues or
implementation bugs. The default value is |
verbose |
A logical value. If |
... |
Other arguments for future usage. A warning will be thrown if any invalid argument is specified. |
surv_x |
A numeric matrix for the design matrix of the survival model component. |
cure_x |
A numeric matrix for the design matrix of the cure rate model
component. The design matrix should exclude an intercept term unless we
want to fit a model only including the intercept term. In that case, we
need further set |
cure_intercept |
A logical value specifying whether to add an intercept
term to the cure rate model component. If |
surv_standardize |
A logical value specifying whether to standardize
the covariates for the survival model part. If |
cure_standardize |
A logical value specifying whether to standardize
the covariates for the cure rate model part. If |
cox_cure
object for regular Cox cure rate model or
cox_cure_uncer
object for Cox cure rate model with uncertain events.
Firth, D. (1993). Bias reduction of maximum likelihood estimates. Biometrika, 80(1), 27–38.
Kuk, A. Y. C., & Chen, C. (1992). A mixture model combining logistic regression with proportional hazards regression. Biometrika, 79(3), 531–541.
Peng, Y. (2003). Estimating baseline distribution in proportional hazards cure models. Computational Statistics & Data Analysis, 42(1-2), 187–201.
Sy, J. P., & Taylor, J. M. (2000). Estimation in a Cox proportional hazards cure model. Biometrics, 56(1), 227–236.
Wang, W., Luo, C., Aseltine, R. H., Wang, F., Yan, J., & Chen, K. (2020). Suicide Risk Modeling with Uncertain Diagnostic Records. arXiv preprint arXiv:2009.02597.
cox_cure_net
for regularized Cox cure rate model with
elastic-net penalty.
library(intsurv) ### regular Cox cure rate model ====================================== ## 1. simulate right-censored data with a cure fraction set.seed(123) n_obs <- 2e2 p <- 5 x_mat <- matrix(rnorm(n_obs * p), nrow = n_obs, ncol = p) colnames(x_mat) <- paste0("x", seq_len(p)) cure_beta <- rep(0.5, p) b0 <- - 1 expit <- binomial()$linkinv ncure_prob <- expit(as.numeric(b0 + x_mat %*% cure_beta)) is_cure <- 1 - rbinom(n_obs, size = 1, prob = ncure_prob) surv_beta <- rep(0.5, p) risk_score <- as.numeric(x_mat %*% surv_beta) event_time <- rexp(n_obs, exp(as.numeric(x_mat %*% surv_beta))) censor_time <- 10 event <- ifelse(event_time < censor_time & ! is_cure, 1, 0) obs_time <- ifelse(event > 0, event_time, censor_time) ## model-fitting from given design matrices fit1 <- cox_cure.fit(x_mat, x_mat, obs_time, event, bootstrap = 30) summary(fit1) ## coefficient estimates from both model parts coef(fit1) ## or a particular part coef(fit1, "surv") coef(fit1, "cure") ## weighted concordance index (C-index) fit1$model$c_index ## which also can be computed as follows cIndex(time = obs_time, event = event, risk_score = fit1$fitted$surv_xBeta, weight = ifelse(event > 0, 1, fit1$fitted$susceptible_prob)) ## 2. create a toy dataset toy_dat <- data.frame(time = obs_time, status = event) toy_dat$group <- cut(abs(x_mat[, 1L]), breaks = c(0, 0.5, 1, 3, Inf), labels = LETTERS[1:4]) toy_dat <- cbind(toy_dat, as.data.frame(x_mat[, - 1L, drop = FALSE])) ## model-fitting from given model formula fit2 <- cox_cure(~ x3 + x4 + group, ~ group + x3 + offset(x2), time = time, event = status, surv_offset = x2, data = toy_dat, subset = group != "D", bootstrap = 30) summary(fit2) ## get BIC's BIC(fit1) BIC(fit2) BIC(fit1, fit2) ### Cox cure rate model with uncertain event status ================== ## simulate sample data sim_dat <- simData4cure(nSubject = 200, max_censor = 10, lambda_censor = 0.1, survMat = x_mat, cureMat = x_mat, b0 = 1) table(sim_dat$case) table(sim_dat$obs_event, useNA = "ifany") ## use formula fit3 <- cox_cure(~ x1 + x2 + x3, ~ z1 + z2 + z3, time = obs_time, event = obs_event, data = sim_dat) summary(fit3) ## use design matrix fit4 <- cox_cure.fit(x_mat, x_mat, time = sim_dat$obs_time, event = sim_dat$obs_event) summary(fit4) ## get BIC's BIC(fit3, fit4)
library(intsurv) ### regular Cox cure rate model ====================================== ## 1. simulate right-censored data with a cure fraction set.seed(123) n_obs <- 2e2 p <- 5 x_mat <- matrix(rnorm(n_obs * p), nrow = n_obs, ncol = p) colnames(x_mat) <- paste0("x", seq_len(p)) cure_beta <- rep(0.5, p) b0 <- - 1 expit <- binomial()$linkinv ncure_prob <- expit(as.numeric(b0 + x_mat %*% cure_beta)) is_cure <- 1 - rbinom(n_obs, size = 1, prob = ncure_prob) surv_beta <- rep(0.5, p) risk_score <- as.numeric(x_mat %*% surv_beta) event_time <- rexp(n_obs, exp(as.numeric(x_mat %*% surv_beta))) censor_time <- 10 event <- ifelse(event_time < censor_time & ! is_cure, 1, 0) obs_time <- ifelse(event > 0, event_time, censor_time) ## model-fitting from given design matrices fit1 <- cox_cure.fit(x_mat, x_mat, obs_time, event, bootstrap = 30) summary(fit1) ## coefficient estimates from both model parts coef(fit1) ## or a particular part coef(fit1, "surv") coef(fit1, "cure") ## weighted concordance index (C-index) fit1$model$c_index ## which also can be computed as follows cIndex(time = obs_time, event = event, risk_score = fit1$fitted$surv_xBeta, weight = ifelse(event > 0, 1, fit1$fitted$susceptible_prob)) ## 2. create a toy dataset toy_dat <- data.frame(time = obs_time, status = event) toy_dat$group <- cut(abs(x_mat[, 1L]), breaks = c(0, 0.5, 1, 3, Inf), labels = LETTERS[1:4]) toy_dat <- cbind(toy_dat, as.data.frame(x_mat[, - 1L, drop = FALSE])) ## model-fitting from given model formula fit2 <- cox_cure(~ x3 + x4 + group, ~ group + x3 + offset(x2), time = time, event = status, surv_offset = x2, data = toy_dat, subset = group != "D", bootstrap = 30) summary(fit2) ## get BIC's BIC(fit1) BIC(fit2) BIC(fit1, fit2) ### Cox cure rate model with uncertain event status ================== ## simulate sample data sim_dat <- simData4cure(nSubject = 200, max_censor = 10, lambda_censor = 0.1, survMat = x_mat, cureMat = x_mat, b0 = 1) table(sim_dat$case) table(sim_dat$obs_event, useNA = "ifany") ## use formula fit3 <- cox_cure(~ x1 + x2 + x3, ~ z1 + z2 + z3, time = obs_time, event = obs_event, data = sim_dat) summary(fit3) ## use design matrix fit4 <- cox_cure.fit(x_mat, x_mat, time = sim_dat$obs_time, event = sim_dat$obs_event) summary(fit4) ## get BIC's BIC(fit3, fit4)
For right-censored data, fit a regularized Cox cure rate model through elastic-net penalty following Masud et al. (2018), and Zou and Hastie (2005). For right-censored data with uncertain event status, fit the regularized Cox cure model proposed by Wang et al. (2020). Without regularization, the model reduces to the regular Cox cure rate model (Kuk and Chen, 1992; Sy and Taylor, 2000)
cox_cure_net( surv_formula, cure_formula, time, event, data, subset, contrasts = NULL, surv_lambda = NULL, surv_alpha = 1, surv_nlambda = 10, surv_lambda_min_ratio = 0.1, surv_l1_penalty_factor = NULL, cure_lambda = NULL, cure_alpha = 1, cure_nlambda = 10, cure_lambda_min_ratio = 0.1, cure_l1_penalty_factor = NULL, cv_nfolds = 0, surv_start = NULL, cure_start = NULL, surv_offset = NULL, cure_offset = NULL, surv_standardize = TRUE, cure_standardize = TRUE, em_max_iter = 200, em_rel_tol = 1e-05, surv_max_iter = 10, surv_rel_tol = 1e-05, cure_max_iter = 10, cure_rel_tol = 1e-05, tail_completion = c("zero", "exp", "zero-tau"), tail_tau = NULL, pmin = 1e-05, early_stop = TRUE, verbose = FALSE, ... ) cox_cure_net.fit( surv_x, cure_x, time, event, cure_intercept = TRUE, surv_lambda = NULL, surv_alpha = 1, surv_nlambda = 10, surv_lambda_min_ratio = 0.1, surv_l1_penalty_factor = NULL, cure_lambda = NULL, cure_alpha = 1, cure_nlambda = 10, cure_lambda_min_ratio = 0.1, cure_l1_penalty_factor = NULL, cv_nfolds = 0, surv_start = NULL, cure_start = NULL, surv_offset = NULL, cure_offset = NULL, surv_standardize = TRUE, cure_standardize = TRUE, em_max_iter = 200, em_rel_tol = 1e-05, surv_max_iter = 10, surv_rel_tol = 1e-05, cure_max_iter = 10, cure_rel_tol = 1e-05, tail_completion = c("zero", "exp", "zero-tau"), tail_tau = NULL, pmin = 1e-05, early_stop = TRUE, verbose = FALSE, ... )
cox_cure_net( surv_formula, cure_formula, time, event, data, subset, contrasts = NULL, surv_lambda = NULL, surv_alpha = 1, surv_nlambda = 10, surv_lambda_min_ratio = 0.1, surv_l1_penalty_factor = NULL, cure_lambda = NULL, cure_alpha = 1, cure_nlambda = 10, cure_lambda_min_ratio = 0.1, cure_l1_penalty_factor = NULL, cv_nfolds = 0, surv_start = NULL, cure_start = NULL, surv_offset = NULL, cure_offset = NULL, surv_standardize = TRUE, cure_standardize = TRUE, em_max_iter = 200, em_rel_tol = 1e-05, surv_max_iter = 10, surv_rel_tol = 1e-05, cure_max_iter = 10, cure_rel_tol = 1e-05, tail_completion = c("zero", "exp", "zero-tau"), tail_tau = NULL, pmin = 1e-05, early_stop = TRUE, verbose = FALSE, ... ) cox_cure_net.fit( surv_x, cure_x, time, event, cure_intercept = TRUE, surv_lambda = NULL, surv_alpha = 1, surv_nlambda = 10, surv_lambda_min_ratio = 0.1, surv_l1_penalty_factor = NULL, cure_lambda = NULL, cure_alpha = 1, cure_nlambda = 10, cure_lambda_min_ratio = 0.1, cure_l1_penalty_factor = NULL, cv_nfolds = 0, surv_start = NULL, cure_start = NULL, surv_offset = NULL, cure_offset = NULL, surv_standardize = TRUE, cure_standardize = TRUE, em_max_iter = 200, em_rel_tol = 1e-05, surv_max_iter = 10, surv_rel_tol = 1e-05, cure_max_iter = 10, cure_rel_tol = 1e-05, tail_completion = c("zero", "exp", "zero-tau"), tail_tau = NULL, pmin = 1e-05, early_stop = TRUE, verbose = FALSE, ... )
surv_formula |
A formula object starting with |
cure_formula |
A formula object starting with |
time |
A numeric vector for the observed survival times. |
event |
A numeric vector for the event indicators. |
data |
An optional data frame, list, or environment that contains the
covariates and response variables ( |
subset |
An optional logical vector specifying a subset of observations to be used in the fitting process. |
contrasts |
An optional list, whose entries are values (numeric
matrices or character strings naming functions) to be used as
replacement values for the contrasts replacement function and whose
names are the names of columns of data containing factors. See
|
surv_lambda , cure_lambda
|
A numeric vector consists of nonnegative values representing the tuning parameter sequence for the survival model part or the incidence model part. |
surv_alpha , cure_alpha
|
A number between 0 and 1 for tuning the elastic net penalty for the survival model part or the incidence model part. If it is one, the elastic penalty will reduce to the well-known lasso penalty. If it is zero, the ridge penalty will be used. |
surv_nlambda , cure_nlambda
|
A positive number specifying the number of
|
surv_lambda_min_ratio , cure_lambda_min_ratio
|
The ratio of the minimum
|
surv_l1_penalty_factor , cure_l1_penalty_factor
|
A numeric vector that
consists of nonnegative penalty factors (or weights) on L1-norm for the
coefficient estimate vector in the survival model part or the incidence
model part. The penalty is applied to the coefficient estimate divided
by the specified weights. The specified weights are re-scaled
internally so that their summation equals the length of coefficients.
If |
cv_nfolds |
An non-negative integer specifying number of folds in
cross-validation (CV). The default value is |
surv_start |
An optional numeric vector representing the
starting values for the survival model component or the incidence model
component. If |
cure_start |
An optional numeric vector representing the
starting values for the survival model component or the incidence model
component. If |
surv_offset |
An optional numeric vector representing the
offset term in the survival model compoent or the incidence model
component. The function will internally try to find values of the
specified variable in the |
cure_offset |
An optional numeric vector representing the
offset term in the survival model compoent or the incidence model
component. The function will internally try to find values of the
specified variable in the |
surv_standardize , cure_standardize
|
A logical value specifying whether
to standardize the covariates for the survival model part or the
incidence model part. If |
em_max_iter |
A positive integer specifying the maximum iteration
number of the EM algorithm. The default value is |
em_rel_tol |
A positive number specifying the tolerance that determines
the convergence of the EM algorithm in terms of the convergence of the
covariate coefficient estimates. The tolerance is compared with the
relative change between estimates from two consecutive iterations, which
is measured by ratio of the L1-norm of their difference to the sum of
their L1-norm. The default value is |
surv_max_iter , cure_max_iter
|
A positive integer specifying the maximum
iteration number of the M-step routine related to the survival model
component or the incidence model component. The default value is
|
surv_rel_tol |
A positive number specifying the tolerance
that determines the convergence of the M-step related to the survival
model component or the incidence model component in terms of the
convergence of the covariate coefficient estimates. The tolerance is
compared with the relative change between estimates from two consecutive
iterations, which is measured by ratio of the L1-norm of their
difference to the sum of their L1-norm. The default value is
|
cure_rel_tol |
A positive number specifying the tolerance
that determines the convergence of the M-step related to the survival
model component or the incidence model component in terms of the
convergence of the covariate coefficient estimates. The tolerance is
compared with the relative change between estimates from two consecutive
iterations, which is measured by ratio of the L1-norm of their
difference to the sum of their L1-norm. The default value is
|
tail_completion |
A character string specifying the tail completion
method for conditional survival function. The available methods are
|
tail_tau |
A numeric number specifying the time of zero-tail
completion. It will be used only if |
pmin |
A numeric number specifying the minimum value of probabilities
for sake of numerical stability. The default value is |
early_stop |
A logical value specifying whether to stop the iteration
once the negative log-likelihood unexpectedly increases, which may
suggest convergence on likelihood, or indicate numerical issues or
implementation bugs. The default value is |
verbose |
A logical value. If |
... |
Other arguments for future usage. A warning will be thrown if any invalid argument is specified. |
surv_x |
A numeric matrix for the design matrix of the survival model component. |
cure_x |
A numeric matrix for the design matrix of the cure rate model
component. The design matrix should exclude an intercept term unless we
want to fit a model only including the intercept term. In that case, we
need further set |
cure_intercept |
A logical value specifying whether to add an intercept
term to the cure rate model component. If |
The model estimation procedure follows expectation maximization (EM) algorithm. Variable selection procedure through regularization by elastic net penalty is developed based on cyclic coordinate descent and majorization-minimization (MM) algorithm.
cox_cure_net
object for regular Cox cure rate model or
cox_cure_net_uncer
object for Cox cure rate model with uncertain
events.
Kuk, A. Y. C., & Chen, C. (1992). A mixture model combining logistic regression with proportional hazards regression. Biometrika, 79(3), 531–541.
Masud, A., Tu, W., & Yu, Z. (2018). Variable selection for mixture and promotion time cure rate models. Statistical methods in medical research, 27(7), 2185–2199.
Peng, Y. (2003). Estimating baseline distribution in proportional hazards cure models. Computational Statistics & Data Analysis, 42(1-2), 187–201.
Sy, J. P., & Taylor, J. M. (2000). Estimation in a Cox proportional hazards cure model. Biometrics, 56(1), 227–236.
Wang, W., Luo, C., Aseltine, R. H., Wang, F., Yan, J., & Chen, K. (2020). Suicide Risk Modeling with Uncertain Diagnostic Records. arXiv preprint arXiv:2009.02597.
Zou, H., & Hastie, T. (2005). Regularization and variable selection via the elastic net. Journal of the Royal Statistical Society: Series B (Statistical Methodology), 67(2), 301–320.
cox_cure
for regular Cox cure rate model.
library(intsurv) ### regularized Cox cure rate model ================================== ## simulate a toy right-censored data with a cure fraction set.seed(123) n_obs <- 100 p <- 10 x_mat <- matrix(rnorm(n_obs * p), nrow = n_obs, ncol = p) colnames(x_mat) <- paste0("x", seq_len(p)) surv_beta <- c(rep(0, p - 5), rep(1, 5)) cure_beta <- c(rep(1, 2), rep(0, p - 2)) dat <- simData4cure(nSubject = n_obs, lambda_censor = 0.01, max_censor = 10, survMat = x_mat, survCoef = surv_beta, cureCoef = cure_beta, b0 = 0.5, p1 = 1, p2 = 1, p3 = 1) ## model-fitting from given design matrices fit1 <- cox_cure_net.fit(x_mat, x_mat, dat$obs_time, dat$obs_event, surv_nlambda = 10, cure_nlambda = 10, surv_alpha = 0.8, cure_alpha = 0.8) ## model-fitting from given model formula fm <- paste(paste0("x", seq_len(p)), collapse = " + ") surv_fm <- as.formula(sprintf("~ %s", fm)) cure_fm <- surv_fm fit2 <- cox_cure_net(surv_fm, cure_fm, data = dat, time = obs_time, event = obs_event, surv_alpha = 0.5, cure_alpha = 0.5) ## summary of BIC's BIC(fit1) BIC(fit2) ## list of coefficient estimates based on BIC coef(fit1) coef(fit2) ### regularized Cox cure model with uncertain event status =========== ## simulate a toy data set.seed(123) n_obs <- 100 p <- 10 x_mat <- matrix(rnorm(n_obs * p), nrow = n_obs, ncol = p) colnames(x_mat) <- paste0("x", seq_len(p)) surv_beta <- c(rep(0, p - 5), rep(1, 5)) cure_beta <- c(rep(1, 2), rep(0, p - 2)) dat <- simData4cure(nSubject = n_obs, lambda_censor = 0.01, max_censor = 10, survMat = x_mat, survCoef = surv_beta, cureCoef = cure_beta, b0 = 0.5, p1 = 0.95, p2 = 0.95, p3 = 0.95) ## model-fitting from given design matrices fit1 <- cox_cure_net.fit(x_mat, x_mat, dat$obs_time, dat$obs_event, surv_nlambda = 5, cure_nlambda = 5, surv_alpha = 0.8, cure_alpha = 0.8) ## model-fitting from given model formula fm <- paste(paste0("x", seq_len(p)), collapse = " + ") surv_fm <- as.formula(sprintf("~ %s", fm)) cure_fm <- surv_fm fit2 <- cox_cure_net(surv_fm, cure_fm, data = dat, time = obs_time, event = obs_event, surv_nlambda = 5, cure_nlambda = 5, surv_alpha = 0.5, cure_alpha = 0.5) ## summary of BIC's BIC(fit1) BIC(fit2) ## list of coefficient estimates based on BIC coef(fit1) coef(fit2)
library(intsurv) ### regularized Cox cure rate model ================================== ## simulate a toy right-censored data with a cure fraction set.seed(123) n_obs <- 100 p <- 10 x_mat <- matrix(rnorm(n_obs * p), nrow = n_obs, ncol = p) colnames(x_mat) <- paste0("x", seq_len(p)) surv_beta <- c(rep(0, p - 5), rep(1, 5)) cure_beta <- c(rep(1, 2), rep(0, p - 2)) dat <- simData4cure(nSubject = n_obs, lambda_censor = 0.01, max_censor = 10, survMat = x_mat, survCoef = surv_beta, cureCoef = cure_beta, b0 = 0.5, p1 = 1, p2 = 1, p3 = 1) ## model-fitting from given design matrices fit1 <- cox_cure_net.fit(x_mat, x_mat, dat$obs_time, dat$obs_event, surv_nlambda = 10, cure_nlambda = 10, surv_alpha = 0.8, cure_alpha = 0.8) ## model-fitting from given model formula fm <- paste(paste0("x", seq_len(p)), collapse = " + ") surv_fm <- as.formula(sprintf("~ %s", fm)) cure_fm <- surv_fm fit2 <- cox_cure_net(surv_fm, cure_fm, data = dat, time = obs_time, event = obs_event, surv_alpha = 0.5, cure_alpha = 0.5) ## summary of BIC's BIC(fit1) BIC(fit2) ## list of coefficient estimates based on BIC coef(fit1) coef(fit2) ### regularized Cox cure model with uncertain event status =========== ## simulate a toy data set.seed(123) n_obs <- 100 p <- 10 x_mat <- matrix(rnorm(n_obs * p), nrow = n_obs, ncol = p) colnames(x_mat) <- paste0("x", seq_len(p)) surv_beta <- c(rep(0, p - 5), rep(1, 5)) cure_beta <- c(rep(1, 2), rep(0, p - 2)) dat <- simData4cure(nSubject = n_obs, lambda_censor = 0.01, max_censor = 10, survMat = x_mat, survCoef = surv_beta, cureCoef = cure_beta, b0 = 0.5, p1 = 0.95, p2 = 0.95, p3 = 0.95) ## model-fitting from given design matrices fit1 <- cox_cure_net.fit(x_mat, x_mat, dat$obs_time, dat$obs_event, surv_nlambda = 5, cure_nlambda = 5, surv_alpha = 0.8, cure_alpha = 0.8) ## model-fitting from given model formula fm <- paste(paste0("x", seq_len(p)), collapse = " + ") surv_fm <- as.formula(sprintf("~ %s", fm)) cure_fm <- surv_fm fit2 <- cox_cure_net(surv_fm, cure_fm, data = dat, time = obs_time, event = obs_event, surv_nlambda = 5, cure_nlambda = 5, surv_alpha = 0.5, cure_alpha = 0.5) ## summary of BIC's BIC(fit1) BIC(fit2) ## list of coefficient estimates based on BIC coef(fit1) coef(fit2)
Fit an integrative Cox model proposed by Wang et al. (2020) for right-censored survival data with uncertain event times due to imperfect data integration.
iCoxph( formula, data, subset, na.action, contrasts = NULL, start = iCoxph.start(), control = iCoxph.control(), ... )
iCoxph( formula, data, subset, na.action, contrasts = NULL, start = iCoxph.start(), control = iCoxph.control(), ... )
formula |
|
data |
An optional data frame, list, or environment that contains the
covariates and response variables included in the model. If not found in
data, the variables are taken from |
subset |
An optional logical vector specifying a subset of observations to be used in the fitting process. |
na.action |
An optional function that indicates what should the
procedure do if the data contains |
contrasts |
An optional list, whose entries are values (numeric
matrices or character strings naming functions) to be used as
replacement values for the contrasts replacement function and whose
names are the names of columns of data containing factors. See
|
start |
A list returned by function |
control |
A list returned by function |
... |
Other arguments for future usage. A warning will be thrown if any invalid argument is specified. |
An iCoxph-class
object, whose slots include
call
: Function call.
formula
: Formula used in the model fitting.
data
: A processed data frame used for model fitting.
nObs
: Number of observation.
estimates
:
beta
: Coefficient estimates.
pi
: Estimated parameters in prior multinomial
distribution indicating the probabilities of corresponding
record being true.
baseline
: A data frame that contains estimated
baseline hazard function with columns named time
and
h0
.
start
: The initial guesses beta_mat
and
pi_mat
specified for the parameters to be estimated,
and the set of initial guess beta_start
and pi_start
that resulted in the largest objective function, i.e.,
the observed-data likelihood function.
control
: The control list specified for model fitting.
na.action
: The procedure specified to deal with
missing values in the covariate.
xlevels
: A list that records the levels in
each factor variable.
contrasts
: Contrasts specified and used for each
factor variable.
convergeCode
: code
returned by function
nlm
, which is an integer indicating why the
optimization process terminated. help(nlm)
for details.
logL
: A numeric vector containing the observed-data
log-likelihood over iterations.
Wang, W., Aseltine, R. H., Chen, K., & Yan, J. (2020). Integrative Survival Analysis with Uncertain Event Times in Application to A Suicide Risk Study. Annals of Applied Statistics, 14(1), 51–73.
iCoxph.start
and iCoxph.control
, respectively,
for starting and controlling iCoxph fitting;
summary,iCoxph-method
for summary of fitted model;
coef,iCoxph-method
for estimated covariate coefficients;
bootSe
for SE estimates from bootstrap methods.
library(intsurv) ## generate simulated survival data with uncertain records set.seed(123) simuDat <- simData4iCoxph(nSubject = 200) ## fit the integertive Cox model fit <- iCoxph(Survi(ID, time, event) ~ x1 + x2 + x3 + x4, data = simuDat, start = iCoxph.start(methods = "nearest"), control = iCoxph.control(tol_beta = 1e-5)) ## estimated covariate coefficients coef(fit) ## get SE estimates by bootstrap fit <- bootSe(fit, B = 30) ## summary of the fitted model summary(fit)
library(intsurv) ## generate simulated survival data with uncertain records set.seed(123) simuDat <- simData4iCoxph(nSubject = 200) ## fit the integertive Cox model fit <- iCoxph(Survi(ID, time, event) ~ x1 + x2 + x3 + x4, data = simuDat, start = iCoxph.start(methods = "nearest"), control = iCoxph.control(tol_beta = 1e-5)) ## estimated covariate coefficients coef(fit) ## get SE estimates by bootstrap fit <- bootSe(fit, B = 30) ## summary of the fitted model summary(fit)
The iCoxph
class is an S4 class that represents a fitted model.
Function iCoxph
produces objects of this class. See “Slots”
for details.
call
Function call.
formula
Model formula.
nObs
A positive integer.
data
A data frame.
estimates
A list.
start
A list.
control
A list.
na.action
A length-one character vector.
xlevels
A list.
contrasts
A list.
convergeCode
A non-negative integer.
logL
A numeric value.
iCoxph
for details of slots.
Auxiliary function for iCoxph
that enable users to specify the
control parameters of the model estimation procedure. Internally, the
arguments cm_gradtol
, cm_stepmax
, cm_steptol
, and
cm_max_iter
are passed to function nlm
as
gradtol
, stepmax
, steptol
, and iterlim
,
respectively.
iCoxph.control( tol_beta = 1e-06, tol_pi = 1e-08, cm_gradtol = 1e-06, cm_stepmax = 100, cm_steptol = 1e-06, cm_max_iter = 100, ecm_max_iter = 200, ... )
iCoxph.control( tol_beta = 1e-06, tol_pi = 1e-08, cm_gradtol = 1e-06, cm_stepmax = 100, cm_steptol = 1e-06, cm_max_iter = 100, ecm_max_iter = 200, ... )
tol_beta |
A positive value specifying the tolerance that concludes the
convergence of the covariate coefficient estimates. The tolerance is
compared with the relative change between the estimates from two
consecutive iterations that is measured by ratio of the L2-norm of their
difference to the sum of their L2-norm. The default value is
|
tol_pi |
A positive value specifying the tolerance that concludes the
convergence of the probability estimates of uncertain records being
true. The tolerance is compared with the relative change between the
estimates from two consecutive iterations measured by ratio of L2-norm
of their difference to the L2-norm of their sum. The default value is
|
cm_gradtol |
A positive scalar giving the tolerance at which the scaled
gradient is considered close enough to zero to terminate CM steps. The
default value is |
cm_stepmax |
A positive scalar that gives the maximum allowable scaled
step length in CM steps. The default value is |
cm_steptol |
A positive scalar providing the minimum allowable relative
step length in CM step. The default value is |
cm_max_iter |
A positive integer specifying the maximum number of
iterations to be performed before each CM step is terminated. The
default value is |
ecm_max_iter |
A positive integer specifying the maximum number of
iterations to be performed before the ECM algorithm is terminated. The
default value is |
... |
Other arguments for future usage. A warning will be thrown if any invalid argument is specified. |
A list of class intsurv-iCoxph.control
containing all
specified control parameters.
iCoxph
for fitting integrative Cox model.
## See examples of function 'iCoxph'.
## See examples of function 'iCoxph'.
Auxiliary function for iCoxph
that enable users
to specify the starting values of the model estimation procedure.
iCoxph.start( beta_vec = NULL, beta_mat = NULL, methods = c("nearest_hazard", "unit_hazard"), ... )
iCoxph.start( beta_vec = NULL, beta_mat = NULL, methods = c("nearest_hazard", "unit_hazard"), ... )
beta_vec |
A numeric vector for starting values of coefficient estimates. The default values are the coefficient estimates from the regular Cox model only fitting on records without uncertainty. If censoring rate among subjects having unique certain records is extremely high (> 99 indicator and one predictor, the starting values will be reset to be all zeros. |
beta_mat |
A numeric matrix that consists of additional starting values
of coefficient estimates in columns. The default value is |
methods |
A character vector specifying the initialization methods for
probabilities of uncertain records being true. The available methods
are |
... |
Other arguments for future usage. A warning will be thrown if any invalid argument is specified. |
A list of class intsurv-iCoxph.start
containing all specified
starting values of the parameters to be estimated from the model.
iCoxph
for fitting integrative Cox model.
## See examples of function 'iCoxph'.
## See examples of function 'iCoxph'.
S4 class methods that display or summarize certain objects.
## S4 method for signature 'iCoxph' show(object) ## S4 method for signature 'summary.iCoxph' show(object)
## S4 method for signature 'iCoxph' show(object) ## S4 method for signature 'summary.iCoxph' show(object)
object |
An object used to dispatch a method. |
For iCoxph-class
object, it prints out a brief summary
of the fitted model.
For summary.iCoxph-class
object, it prints out summary
of a fitted model.
object input (invisibly).
Simulate Data from Cox Cure Model with Uncertain Event Status
simData4cure( nSubject = 1000, shape = 2, scale = 0.1, lambda_censor = 1, max_censor = Inf, p1 = 0.9, p2 = 0.9, p3 = 0.9, survMat, cureMat = survMat, b0 = stats::binomial()$linkfun(0.7), survCoef = rep(1, ncol(survMat)), cureCoef = rep(1, ncol(cureMat)), ... )
simData4cure( nSubject = 1000, shape = 2, scale = 0.1, lambda_censor = 1, max_censor = Inf, p1 = 0.9, p2 = 0.9, p3 = 0.9, survMat, cureMat = survMat, b0 = stats::binomial()$linkfun(0.7), survCoef = rep(1, ncol(survMat)), cureCoef = rep(1, ncol(cureMat)), ... )
nSubject |
A positive integer specifying number of subjects. |
shape |
A positive number specifying the shape parameter of the distribution of the event times. |
scale |
A positive number specifying the scale parameter of the distribution of the event times. |
lambda_censor |
A positive number specifying the rate parameter of the exponential distribution for generating censoring times. |
max_censor |
A positive number specifying the largest censoring time. |
p1 |
A number between 0 and 1 specifying the probability of simulating events with observed event indicators given the simulated event times. |
p2 |
A number between 0 and 1 specifying the probability of simulating susceptible censoring times with observed event status given the simulated susceptible censoring times. |
p3 |
A number between 0 and 1 specifying the probability of simulating cured censoring times with observed event status given the simulated cured censoring times. |
survMat |
A numeric matrix representing the design matrix of the survival model part. |
cureMat |
A numeric matrix representing the design matrix excluding intercept of the cure rate model part. |
b0 |
A number representing the intercept term for the cure rate model part. |
survCoef |
A numeric vector for the covariate coefficients of the survival model part. |
cureCoef |
A numeric vector for the covariate coefficients of the cure model part. |
... |
Other arguments not used currently. |
A data.frame with the following columns:
obs_time
: Observed event/survival times.
obs_event
: Observed event status.
event_time
: Underlying true event times.
censor_time
: underlying true censoring times.
oracle_event
: underlying true event indicators.
oracle_cure
: underlying true cure indicators.
case
: underlying true case labels.
Wang, W., Luo, C., Aseltine, R. H., Wang, F., Yan, J., & Chen, K. (2020). Suicide Risk Modeling with Uncertain Diagnostic Records. arXiv preprint arXiv:2009.02597.
## see examples of function cox_cure
## see examples of function cox_cure
Generate survival data with uncertain records. An integrative Cox model can
be fitted for the simulated data by function iCoxph
.
simData4iCoxph( nSubject = 1000, beta0Vec, xMat, maxNum = 2, nRecordProb = c(0.9, 0.1), matchCensor = 0.1, matchEvent = 0.1, censorMin = 0.5, censorMax = 12.5, lambda = 0.005, rho = 0.7, fakeLambda1 = lambda * exp(-3), fakeRho1 = rho, fakeLambda2 = lambda * exp(3), fakeRho2 = rho, mixture = 0.5, randomMiss = TRUE, eventOnly = FALSE, ... )
simData4iCoxph( nSubject = 1000, beta0Vec, xMat, maxNum = 2, nRecordProb = c(0.9, 0.1), matchCensor = 0.1, matchEvent = 0.1, censorMin = 0.5, censorMax = 12.5, lambda = 0.005, rho = 0.7, fakeLambda1 = lambda * exp(-3), fakeRho1 = rho, fakeLambda2 = lambda * exp(3), fakeRho2 = rho, mixture = 0.5, randomMiss = TRUE, eventOnly = FALSE, ... )
nSubject |
Number of subjects. |
beta0Vec |
Time-invariant covariate coefficients. |
xMat |
Design matrix. By default, three continuous variables following standard normal distribution and one binary variable following Bernoulli distribution with equal probability are used. |
maxNum |
Maximum number of uncertain records. |
nRecordProb |
Probability of the number of uncertain records. |
matchCensor |
The matching rate for subjects actually having censoring times. |
matchEvent |
The matching rate for subjects actually having event times. |
censorMin |
The lower boundary of the uniform distribution for generating censoring time. |
censorMax |
The upper boundary of the uniform distribution for generating censoring time. |
lambda |
A positive number, scale parameter in baseline rate function for true event times. |
rho |
A positive number, shape parameter in baseline rate function for true event times. |
fakeLambda1 |
A positive number, scale parameter in baseline rate function for fake event times from one distribution. |
fakeRho1 |
A positive number, shape parameter in baseline rate function for fake event times from one distribution. |
fakeLambda2 |
A positive number, scale parameter in baseline rate function for fake event times from another distribution. |
fakeRho2 |
A positive number, shape parameter in baseline rate function for fake event times from another distribution. |
mixture |
The mixture weights, i.e., the probabilities (summing up to one) of fake event times coming from different mixture components. |
randomMiss |
A logical value specifying whether the labels of the true
records are missing completely at random (MCAR) or missing not at random
(MNAR). The default value is |
eventOnly |
A logical value specifying whether the uncertain records
only include possible events. The default value is |
... |
Other arguments for future usage. |
The event times are simulated from a Weibull proportional hazard model of given shape and baseline scale. The censoring times follow uniform distribution of specified boundaries.
A data frame with the following columns,
ID
: subject ID
time
: observed event times
event
: event indicators
isTure
: latent labels indicating the true records
and the corresponding covariates.
## See examples of function iCoxph
## See examples of function iCoxph
For iCoxph
object, the function returns a
summary.iCoxph
object whose slots include
call
: Function call of model fitting.
coefMat
: Estimated covariate coefficients.
logL
: Log-likelihood under observed data.
## S4 method for signature 'iCoxph' summary(object, showCall = TRUE, ...)
## S4 method for signature 'iCoxph' summary(object, showCall = TRUE, ...)
object |
|
showCall |
A logic value with default |
... |
Other arguments for future usage. |
summary.iCoxph
class object.
iCoxph
for model fitting;
coef,iCoxph-method
for coefficient estimates.
## See examples of function iCoxph
## See examples of function iCoxph
Summarize a fitted Cox cure rate model with possible uncertain event status.
## S3 method for class 'cox_cure' summary(object, ...) ## S3 method for class 'cox_cure_uncer' summary(object, ...)
## S3 method for class 'cox_cure' summary(object, ...) ## S3 method for class 'cox_cure_uncer' summary(object, ...)
object |
Object representing a fitted model. |
... |
Other arguments for future usage. A warning will be thrown if any invalid argument is specified. |
The summary.intsurv
class is an S4 class that represents a summarized
model. Function summary,iCoxph-method
produces objects of
this class. See “Slots” for details.
call
Function call.
coefMat
A matrix.
logL
A numeric value.
summary,iCoxph-method
for meaning of slots.
Survi
returns an S4 class that represents formula response for
survival data with uncertain records due to imperfect data integration. The
last letter 'i' in Survi
represents 'integration'.
Survi(ID, time, event, check = TRUE, ...)
Survi(ID, time, event, check = TRUE, ...)
ID |
Identificator of each subject. |
time |
Event times (whether certain or uncertain) or censoring times. |
event |
The status indicator, 0 = censored, 1 = event. |
check |
A logical value specifying whether to perform check on input data. |
... |
Other arguments for future usage. A warning will be thrown if any invalid argument is specified. |
Survi
object. See Survi-class
for details.
## See examples of function 'iCoxph'
## See examples of function 'iCoxph'
An S4 Class Representing Formula Response
.Data
A numeric matrix object.
ID
Identificator of each subject.