#' Quasi Information Criterion
#'
#' Implementation based on MES::QIC.geeglm
#'
#' @param object is a \code{aftgee} fit
#'
#' @importFrom MASS ginv
#' @export
#' @importFrom stats predict resid
#'
#' @example inst/examples/ex_aftgee_QIC.R
QIC <- function (object) {
mu <- log(predict(object)$fit)
y <- log(object$data$y)
eres1 <- eResC(resid(object), object$data$d, object$data$w)
geefit0 <- geese.fit(object$data$x * sqrt(object$data$w),
y * sqrt(object$data$w), object$data$id,
corstr = "independence")
quasi <- sum(((y - mu)^2) / -2)
AIinverse <- ginv(geefit0$vbeta.naiv)
Vr <- geefit0$vbeta
trace <- sum(diag(AIinverse %*% Vr))
params <- length(object$coef.res)
kpm <- params + length(object$alpha)
QIC <- -2 * (quasi - trace)
QICu <- -2 * (quasi - params)
QICC <- QIC + (2 * kpm * (kpm + 1))/(length(resid(object)) - kpm - 1)
output <- c(QIC, QICu, quasi, trace, params, QICC)
names(output) <- c("QIC", "QICu", "Quasi Lik", "CIC", "params", "QICC")
return(output)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.