CIF logistic for propodds=1 default CIF Fine-Gray (cloglog) regression for propodds=NULL

cifreg(
  formula,
  data = data,
  cause = 1,
  cens.code = 0,
  cens.model = ~1,
  weights = NULL,
  offset = NULL,
  Gc = NULL,
  propodds = 1,
  ...
)

Arguments

formula

formula with 'Event' outcome

data

data frame

cause

of interest

cens.code

code of censoring

cens.model

for stratified Cox model without covariates

weights

weights for FG score equations

offset

offsets for FG model

Gc

censoring weights for time argument, default is to calculate these with a Kaplan-Meier estimator, should then give G_c(T_i-)

propodds

1 is logistic model, NULL is fine-gray model

...

Additional arguments to lower level funtions

Details

For FG model: $$ \int (X - E ) Y_1(t) w(t) dM_1 $$ is computed and summed over clusters and returned multiplied with inverse of second derivative as iid.naive. Where $$w(t) = G(t) (I(T_i \wedge t < C_i)/G_c(T_i \wedge t))$$ and $$E(t) = S_1(t)/S_0(t)$$ and $$S_j(t) = \sum X_i^j Y_{i1}(t) w_i(t) \exp(X_i^T \beta)$$

The iid decomposition of the beta's, however, also have a censoring term that is also is computed and added to UUiid (still scaled with inverse second derivative) $$ \int (X - E ) Y_1(t) w(t) dM_1 + \int q(s)/p(s) dM_c $$ and returned as iid

For logistic link standard errors are slightly to small since uncertainty from recursive baseline is not considered, so for smaller data-sets it is recommended to use the prop.odds.subdist of timereg that is also more efficient due to use of different weights for the estimating equations. Alternatively, one can also bootstrap the standard errors.

Author

Thomas Scheike

Examples

## data with no ties
data(bmt,package="timereg")
bmt$time <- bmt$time+runif(nrow(bmt))*0.01
bmt$id <- 1:nrow(bmt)

## logistic link  OR interpretation
ll=cifreg(Event(time,cause)~tcell+platelet+age,data=bmt,cause=1)
summary(ll)
#> 
#>    n events
#>  408    161
#> 
#>  408 clusters
#> coeffients:
#>           Estimate      S.E.   dU^-1/2 P-value
#> tcell    -0.709571  0.331975  0.274926  0.0326
#> platelet -0.455403  0.236000  0.187919  0.0536
#> age       0.391199  0.098039  0.083671  0.0001
#> 
#> exp(coeffients):
#>          Estimate    2.5%  97.5%
#> tcell     0.49186 0.25660 0.9428
#> platelet  0.63419 0.39934 1.0072
#> age       1.47875 1.22024 1.7920
#> 
#> 
plot(ll)

nd <- data.frame(tcell=c(1,0),platelet=0,age=0)
pll <- predict(ll,nd)
plot(pll)


## Fine-Gray model
fg=cifreg(Event(time,cause)~tcell+platelet+age,data=bmt,cause=1,propodds=NULL)
summary(fg)
#> 
#>    n events
#>  408    161
#> 
#>  408 clusters
#> coeffients:
#>           Estimate      S.E.   dU^-1/2 P-value
#> tcell    -0.596909  0.270443  0.275782  0.0273
#> platelet -0.426076  0.180702  0.187722  0.0184
#> age       0.343769  0.080270  0.086283  0.0000
#> 
#> exp(coeffients):
#>          Estimate    2.5%  97.5%
#> tcell     0.55051 0.32401 0.9353
#> platelet  0.65307 0.45829 0.9306
#> age       1.41025 1.20496 1.6505
#> 
#> 
plot(fg)

nd <- data.frame(tcell=c(1,0),platelet=0,age=0)
pfg <- predict(fg,nd)
plot(pfg)


## not run to avoid timing issues
## gofFG(Event(time,cause)~tcell+platelet+age,data=bmt,cause=1)

sfg <- cifreg(Event(time,cause)~strata(tcell)+platelet+age,data=bmt,cause=1,propodds=NULL)
summary(sfg)
#> 
#>    n events
#>  408    161
#> 
#>  408 clusters
#> coeffients:
#>           Estimate      S.E.   dU^-1/2 P-value
#> platelet -0.424692  0.180787  0.187823  0.0188
#> age       0.341928  0.079862  0.086283  0.0000
#> 
#> exp(coeffients):
#>          Estimate    2.5%  97.5%
#> platelet  0.65397 0.45885 0.9321
#> age       1.40766 1.20370 1.6462
#> 
#> 
plot(sfg)


### predictions with CI based on iid decomposition of baseline and beta
fg <- cifreg(Event(time,cause)~tcell+platelet+age,data=bmt,cause=1,propodds=NULL,cox.prep=TRUE)
Biid <- IIDbaseline.cifreg(fg,time=20)
FGprediid(Biid,bmt[1:5,])
#>           pred     se-log     lower     upper
#> [1,] 0.4564377 0.07253850 0.3959466 0.5261703
#> [2,] 0.5072693 0.07328040 0.4394021 0.5856187
#> [3,] 0.6064814 0.08621969 0.5121854 0.7181379
#> [4,] 0.6027029 0.08565847 0.5095545 0.7128791
#> [5,] 0.4288373 0.07564702 0.3697445 0.4973744