R/addBarInference.R

Defines functions addBarCompLines addBarInference

addBarInference <- function(inflist, center, opts, zi) {
    if (is.null(inflist[[1]]$lower))
        return(NULL)

    bs <- attr(inflist, "bootstrap")
    col1 <- ifelse(bs, opts$inf.col.comp[2], opts$inf.col.comp[1])
    col2 <- ifelse(bs, opts$inf.col.conf[2], opts$inf.col.conf[1])

    if (is.null(zi))
        zi <- 1:ncol(inflist[[1]]$lower)

    ## Add vertical lines to bars
    lapply(c("conf", "comp"), function(n) {
        if (!is.null(inflist[[n]])) {
            low <- c(inflist[[n]]$lower[, zi])
            upp <- c(inflist[[n]]$upper[, zi])
            cis <- c(rbind(low, upp))

            grid.polyline(x = unit(rep(center, each = 2), "native"),
                          y = unit(cis, "native"),
                          id = rep(1:length(center), each = 2),
                          gp =
                          gpar(col = switch(n, 'comp' = col1, 'conf' = col2),
                               lwd = switch(n,
                                   'comp' = opts$inf.lwd.comp / sqrt(nrow(inflist[[n]]$lower)),
                                   'conf' = opts$inf.lwd.conf / sqrt(nrow(inflist[[n]]$lower))
                                   ),
                               lineend = "butt"))
        }
    })
}

addBarCompLines <- function(comp, bounds, phat, opts, zi) {

    ## Add horizontal comparison lines

    if (is.null(zi))
        zi <- 1:ncol(phat)

    n1 <- ncol(phat)
    n2 <- nrow(phat)



    if (n2 == 1) {
        x <- rep(range(bounds), n1 * 2)
    } else {
        x <- c(apply(apply(matrix(bounds, nrow = 2 * n2), 2, range),
                     2, rep, times = n2 * 2))
    }

    y <- rep(c(do.call(rbind, comp)[, zi]), each = 2)
    id <- rep(1:(n2 * n1 * 2), each = 2)

    grid.polyline(x = unit(x, "native"), y = unit(y, "native"),
                  id = id, gp = gpar(lty = 3, col = "grey50", lwd = 0.5))
}
iNZightVIT/iNZightPlots documentation built on May 4, 2024, 6:18 a.m.