`D.index` <-
function(x, surv.time, surv.event, weights, strat, alpha=0.05, method.test=c("logrank", "likelihood.ratio", "wald"), na.rm=FALSE, ...) {
strata <- survival::strata
#require(SuppDists)
method.test <- match.arg(method.test)
if(!missing(weights)) {
if(length(weights) != length(x)) { stop("bad length for parameter weights!") }
## remove weights=0 because the coxph function does not deal with them properly
iix <- weights <= 0
if(any(iix)) { warning("samples with weight<=0 are discarded") }
weights[iix] <- NA
} else { weights <- rep(1, length(x)) }
if(!missing(strat)) {
if(length(strat) != length(x)) { stop("bad length for parameter strat!") }
} else { strat <- rep(1, length(x)) }
cc.ix <- complete.cases(x, surv.time, surv.event, weights, strat)
if(sum(cc.ix) < 3) {
## not enough observations
data <- list("x"=x, "z"=rep(NA, length(x)), "surv.time"=surv.time, "surv.event"=surv.event, "weights"=weights, "strat"=strat)
return(list("d.index"=NA, "coef"=NA, "se"=NA, "lower"=NA, "upper"=NA, "p.value"=NA, "n"=sum(cc.ix), "coxm"=NA, "data"=data))
}
if(any(!cc.ix) & !na.rm) { stop("NA values are present!") }
sx <- x[cc.ix]
oo <- order(sx, decreasing=FALSE)
sx <- sx[oo]
stime <- surv.time[cc.ix][oo]
sevent <- surv.event[cc.ix][oo]
sweights <- weights[cc.ix][oo]
sstrat <- strat[cc.ix][oo]
kap <- sqrt(8/pi)
z <- kap^-1 * SuppDists::normOrder(N=length(sx))
#ties?
dup <- duplicated(sx)
if(any(dup)) {
udup <- unique(sx[dup])
for(i in 1:length(udup)) { z[sx == udup[i]] <- mean(z[sx == udup[i]]) }
}
z2 <- x
z2[!cc.ix] <- NA
z2[cc.ix] <- z[match(1:length(sx), oo)]
data <- list("x"=x, "z"=z2, "surv.time"=surv.time, "surv.event"=surv.event, "weights"=weights, "strat"=strat)
#fit the cox model
options(warn=2)
rr <- try(coxph(Surv(stime, sevent) ~ strata(sstrat) + z, weights=sweights, ...))
options(warn=0)
if(class(rr) == "try-error") {
res <- list("d.index"=NA, "coef"=NA, "se"=NA, "lower"=NA, "upper"=NA, "p.value"=NA, "n"=sum(cc.ix), "coxm"=NA, "data"=data)
} else {
dicoef <- rr$coefficients
dise <- sqrt(drop(rr$var))
names(dicoef) <- names(dise) <- NULL
mystat <- NA
switch(method.test,
"logrank"={
mystat <- rr$score
},
"likelihood.ratio"={
mysat <- 2 * (rr$loglik[2] - rr$loglik[1])
},
"wald"={
mystats <- rr$wald.test
##(hrcoef / hrse)^2
})
mypp <- pchisq(mystat, df=1, lower.tail=FALSE)
res <- list("d.index"=exp(dicoef), "coef"=dicoef, "se"=dise, "lower"=exp(dicoef - qnorm(alpha / 2, lower.tail=FALSE) * dise), "upper"=exp(dicoef + qnorm(alpha / 2, lower.tail=FALSE) * dise), "p.value"=mypp, "n"=rr$n, "coxm"=rr, "data"=data)
}
return(res)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.