R/showLables_sT.R

Defines functions showLabels1 showLabels_sT

showLabels_sT <- function(x, y, labels = NULL, id.method = "identify", id.n = length(x), id.cex = 1, 
    id.col = palette()[1], ...) {
    res <- NULL
    id.method <- if (is.list(id.method)) 
        id.method else list(id.method)
    for (meth in id.method) res <- c(res, showLabels1(x, y, labels, meth, id.n, id.cex, id.col, ...))
    return(if (is.null(res)) invisible(res) else res)
}

showLabels1 <- function(x, y, labels = NULL, id.method = "identify", id.n = length(x), id.cex = 1, 
    id.col = palette()[1], all = NULL, ...) {
    # If labels are NULL, try to get the labels from x:
    if (is.null(labels)) 
        labels <- names(x)
    if (is.null(labels)) 
        labels <- paste(seq_along(x))
    if (is.null(id.col)) 
        id.col <- palette()[1]
    # logged-axes?
    log.x <- par("xlog")
    log.y <- par("ylog")
    # id.method can be any of the following: --- a list of row numbers --- a list of labels --- a
    # vector of n numbers --- a text string: 'identify', 'x', 'y', 'mahal', 'r'
    idmeth <- pmatch(id.method[1], c("x", "y", "mahal", "identify", "r"))
    if (!is.na(idmeth)) 
        idmeth <- c("x", "y", "mahal", "identify", "r")[idmeth]
    # if idmeth is NA, then it must be <= n numbers or row names
    id.var <- NULL
    if (is.na(idmeth)) {
        if (is.null(all)) 
            all <- list(labels = labels, subs = rep(TRUE, length(labels)))
        names(all$labels) <- all$labels
        if (length(id.method) >= length(x)) {
            id.var <- id.method[which(all$subs)]
            id.n <- min(id.n, length(id.var))
        } else {
            id.var <- rep(0, length(x))
            names(id.var) <- labels
            inSubset <- all$labels[all$subs] %in% all$labels[id.method]
            id.var[inSubset] <- 1
            id.n <- sum(inSubset)
        }
    } else {
        # use identify?
        if (idmeth == "identify") {
            result <- labels[identify(x, y, labels, n = length(x), cex = id.cex, col = id.col, ...)]
            if (length(result) > 0) 
                return(unique(result)) else return(NULL)
        }
        # missing values need to be removed
        ismissing <- is.na(x) | is.na(y) | is.na(labels)
        if (any(ismissing)) {
            x <- x[!ismissing]
            y <- y[!ismissing]
            labels <- labels[!ismissing]
        }
        # other methods:
        id.var <- switch(id.method, x = if (log.x == TRUE) suppressWarnings(if (all(x) > 0) abs(log(x) - 
            mean(log(x))) else return(invisible(NULL))) else abs(x - mean(x)), y = if (log.y == TRUE) suppressWarnings(if (all(y) > 
            0) abs(log(y) - mean(log(y))) else return(invisible(NULL))) else abs(y - mean(y)), r = if (log.y == 
            TRUE) suppressWarnings(if (all(y) > 0) abs(log(y)) else return(invisible(NULL))) else abs(y), 
            mahal = if (log.x == TRUE & log.y == TRUE) {
                suppressWarnings(if (all(x) > 0 & all(y) > 0) rowSums(qr.Q(qr(cbind(1, log(x), log(y))))^2) else return(invisible(NULL)))
            } else {
                if (log.x == TRUE) {
                  suppressWarnings(if (all(x) > 0) rowSums(qr.Q(qr(cbind(1, log(x), y)))^2) else return(invisible(NULL)))
                } else {
                  if (log.y == TRUE) {
                    suppressWarnings(if (all(y) > 0) rowSums(qr.Q(qr(cbind(1, x, log(y))))^2) else return(invisible(NULL)))
                  } else {
                    rowSums(qr.Q(qr(cbind(1, x, y)))^2)
                  }
                }
            })
    }
    # require id.n positive
    if (id.n <= 0L) 
        return(invisible(NULL))
    # criterion
    ind <- order(id.var, decreasing = TRUE)[1L:min(length(id.var), id.n)]
    # position
    mid <- mean(if (par("xlog") == TRUE) 
        10^(par("usr")[1:2]) else par("usr")[1:2])
    labpos <- c(4, 2)[1 + as.numeric(x > mid)]
    # print
    for (i in ind) {
        text(x[i], y[i], labels[i], cex = id.cex, xpd = TRUE, col = id.col, pos = labpos[i], offset = 0.25, 
            ...)
    }
    names(ind) <- labels[ind]
    result <- ind
    if (length(result) == 0) 
        return(NULL) else return(result)
}

Try the statTarget package in your browser

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

statTarget documentation built on Nov. 8, 2020, 8:27 p.m.