R/summary.Hist.R

Defines functions summary.Hist

Documented in summary.Hist

#' Summary of event histories
#' 
#' Describe events and censoring patterns of an event history.
#' 
#' 
#' @param object An object with class `Hist' derived with \code{\link{Hist}}
#' @param verbose Logical. If FALSE any printing is supressed.
#' @param \dots Not used
#' @return \code{NULL} for survival and competing risk models.  For other
#' multi-state models, it is a list with the following entries:
#' \item{states}{the states of the model} \item{transitions}{the transitions
#' between the states} \item{trans.frame}{a data.frame with the from and to
#' states of the transitions}
#' @author Thomas A. Gerds \email{tag@@biostat.ku.dk}
#' @seealso \code{\link{Hist}}, \code{\link{plot.Hist}}
#' @keywords survival
#' @examples
#' 
#' icensFrame <- data.frame(L=c(1,1,3,4,6),R=c(2,NA,3,6,9),event=c(1,1,1,2,2))
#' with(icensFrame,summary(Hist(time=list(L,R))))
#'
#' @export 
summary.Hist <- function(object, verbose=TRUE,...){
    D <- object[,"status",drop=TRUE]
    states <- attr(object,"states")
    cens.code <- attr(object,"cens.code")
    # {{{ resolving events and model states 
    model <- attr(object,"model")
    model.string <- paste("response of a", model,"model")
    if (model=="multi.states"){
        from <- object[,"from"]
        to <- object[,"to"]
        code.from <- getEvent(object,mode="factor",column="from")
        code.to <- getEvent(object,mode="factor",column="to")
        state.types <- factor(as.numeric(match(states,unique(code.from),nomatch=0)!=0) + 2*as.numeric(match(states,unique(code.to),nomatch=0)!=0),levels=c(1,2,3))
        names(state.types) <- states
        levels(state.types) <- c("initial","absorbing","transient")
        state.types <- table(state.types)
    }
    else{
        from <- rep("initial",NROW(object))
        code.to <- getEvent(object,mode="factor",column=ifelse(model=="survival","status","event"))
        code.from <- factor(from)
        state.types <- c(1,length(states))
        names(state.types) <- c("initial","absorbing")
    }
    # }}}
    # {{{ transition frame
    ##   trans.frame <- unique(data.frame(from=code.from,to=code.to),MARGIN=1)
    trans.frame <- data.frame(from=code.from,to=code.to)
    Transitions <- apply(cbind(as.character(code.from),as.character(code.to)),1,paste,collapse=" -> ")
    obnoxious.factor.levels <- unique(Transitions)
    Transitions <- factor(Transitions,obnoxious.factor.levels)
    transitions <- table(Transitions)
    summary.out <- list(states=state.types,transitions=transitions,trans.frame=trans.frame)
    if (verbose==TRUE){
        state.table <- as.matrix(transitions)
        colnames(state.table) <- c("Freq")
    }
    # }}}
    # {{{ resolving the censoring mechanism
    if (verbose==TRUE){
        ## event time
        cens.type <- attr(object,"cens.type")
        ## cens.string <- capitalize(cens.type)
        cens.string <- switch(cens.type,
                              "intervalCensored"="Interval-censored",
                              "rightCensored"="Right-censored",
                              "uncensored"="Uncensored")
        Observations <- switch(cens.type,
                               "intervalCensored"=factor(D,levels=c(1,2,0),labels=c("exact.time","interval-censored","right-censored")),
                               "rightCensored"=factor(D,levels=c(1,0),labels=c("event","right.censored")),
                               "uncensored"=factor(D,labels=c("event")))
        Freq <- table(Observations)
        ## entry time
        entry.type <- attr(object,"entry.type")
        if (entry.type!="")
            entry.string <- paste(" with ",entry.type," entry time",sep="")
        else
            entry.string <- ""
        ## stop time
        stop.time <- attr(object,"stop.time")
        if (is.null(stop.time))
            stop.string <- ""
        else
            stop.string <- paste(" stopped at time ",stop.time,sep="")
        cat("\n",
            cens.string,
            " ",
            model.string,
            entry.string,
            stop.string,
            "\n",
            sep="")
        cat("\nNo.Observations:",NROW(object),"\n\nPattern:\n")
        switch(model,"survival"={
                         prmatrix(cbind(names(Freq),Freq),
                                  quote=FALSE,
                                  rowlab=rep("",NROW(Freq)))},
               "competing.risks"={
                   events <- getEvent(object)
                   prout <- table("Cause"=events,as.character(Observations))
                   print(prout)
               },
               "multi.states"={
                   x=table(Transitions,Observations)
                   aaa=sapply(strsplit(rownames(x)," -> "),function(x)x[1])
                   bbb=sapply(strsplit(rownames(x)," -> "),function(x)x[1])
                   print(x[order(aaa,bbb),,drop=FALSE])
               })
    }
    # }}}
    invisible(summary.out)
}

## capitalize <- function(x) {
  ## s <- strsplit(x, " ")[[1]]
  ## paste(toupper(substring(s, 1,1)), substring(s, 2), sep="", collapse=" ")
## }

Try the prodlim package in your browser

Any scripts or data that you put into this service are public.

prodlim documentation built on Aug. 28, 2023, 5:07 p.m.