R/symbox.R

Defines functions symbox.lm symbox.default symbox.formula symbox

Documented in symbox symbox.default symbox.formula symbox.lm

# 2010-09-05: J. Fox: allow xlab argument, pass through ...
# 2013-08-19: J. Fox: remove loading of stats package
# 2018-07-27: J. Fox: automatically generate start
# 2021-04-08: J. Fox: added symbox.lm() method.

symbox <- function(x, ...){
	UseMethod("symbox")
}

symbox.formula <- function(formula, data=NULL, subset, na.action=NULL, ylab, ...){
	variable <- all.vars(formula)
	if (length(variable) != 1) stop("the formula must specify one variable")
	m <- match.call(expand.dots = FALSE)
	if (is.matrix(eval(m$data, parent.frame()))) 
		m$data <- as.data.frame(data)
	m$ylab <- m$... <- NULL
	m$na.action <- na.action
	m[[1]] <- as.name("model.frame")
	mf <- eval(m, parent.frame())
	if (missing(ylab)) ylab <- paste("Transformations of", variable)
	symbox(as.vector(mf[[1]]), ylab=ylab, ...)
}

symbox.default <- function(x, powers = c(-1, -0.5, 0, 0.5, 1), start, trans=bcPower, 
		xlab="Powers", ylab, ...) {
    if (!(is.vector(x) && is.numeric(x))) stop("x should be a numeric vector.")
	if (missing(ylab)) ylab <- deparse(substitute(x))
	trans.name <- deparse(substitute(trans))
	if (missing(start)){
	  if (trans.name %in% c("bcPower", "bcnPower")){
	    if ((min.x <- min(x, na.rm=TRUE)) <= 0){
	      max.x <- max(x, na.rm=TRUE)
	      start <- abs(min.x) + 0.01*(max.x - min.x)
	      warning("start set to ", format(start))
	    } else {
	      start <- 0
	    }
	  } else {
	    start <- 0
	  }
	}
  x <- x + start
  if (trans.name == "bcnPower") trans <- function(x, lambda) bcnPower(x, lambda, gamma=start)
	result <- lapply(powers, function(lambda) trans(x, lambda))
	names <- as.character(powers)
	names[powers == 0] <- "log"
	names(result) <- names
	result <- as.data.frame(scale(do.call(cbind, result)))
    boxplot(result, xlab=xlab, ylab=ylab, yaxt="n", ...)
}

symbox.lm <- function(x, powers = c(-1, -0.5, 0, 0.5, 1), start, trans=bcPower, 
                      xlab, ylab="Studentized residuals", ...) {
  trans.name <- deparse(substitute(trans))
  if (missing(xlab)) xlab <- paste("Powers of:", responseName(x))
  y <- model.response(model.frame(x))
  if (missing(start)){
    if (trans.name %in% c("bcPower", "bcnPower")){
      if ((min.y <- min(y, na.rm=TRUE)) <= 0){
        max.y <- max(y, na.rm=TRUE)
        start <- abs(min.y) + 0.01*(max.y - min.y)
        warning("start set to ", format(start))
      } else {
        start <- 0
      }
    } else {
      start <- 0
    }
  }
  y <- y + start
  if (trans.name == "bcnPower") trans <- function(x, lambda) bcnPower(x, lambda, gamma=start)
  rstudents <- vector(length(powers), mode="list")
  names(rstudents) <- as.character(powers)
  Data <- na.omit(getModelData(x))
  for (power in powers){
    Data$.y. <- trans(y, power)
    m <- update(x, formula = .y. ~ ., data=Data)
    rstudents[[as.character(power)]] <- rstudent(m)
  }
  names <- names(rstudents)
  names[powers == 0] <- "log"
  names(rstudents) <- names
  rstudents <- as.data.frame(scale(do.call(cbind, rstudents)))
  boxplot(rstudents, xlab=xlab, ylab=ylab, yaxt="n", ...)
  invisible(rstudents)
}

Try the car package in your browser

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

car documentation built on Sept. 27, 2024, 9:06 a.m.