R/plot.gam.R

#' Plot Components of a GAM Object
#' 
#' A plot method for GAM objects, which can be used on GLM and LM objects as
#' well. It focuses on terms (main-effects), and produces a suitable plot for
#' terms of different types
#' 
#' 
#' @aliases plot.Gam preplot.Gam plot.preplot.Gam
#' @param x a \code{Gam} object, or a \code{preplot.Gam} object. The
#'   first thing \code{plot.Gam()} does is check if \code{x} has a
#'   component called \code{preplot}; if not, it computes one using
#'   \code{preplot.Gam()}. Either way, it is this \code{preplot.Gam}
#'   object that is required for plotting a \code{Gam} object.
#' @param object same as \code{x}
#' @param residuals if \code{TRUE}, partial deviance residuals are
#'   plotted along with the fitted terms---default is \code{FALSE}. If
#'   \code{residuals} is a vector with the same length as each fitted
#'   term in \code{x}, then these are taken to be the overall
#'   residuals to be used for constructing the partial residuals.
#' @param rugplot if \code{TRUE} (the default), a univariate histogram
#'   or \code{rugplot} is displayed along the base of each plot,
#'   showing the occurrence of each `x`; ties are broken by jittering.
#' @param se if \code{TRUE}, upper and lower pointwise
#'   twice-standard-error curves are included for each plot. The
#'   default is \code{FALSE}.
#' @param scale a lower limit for the number of units covered by the
#'   limits on the `y` for each plot. The default is \code{scale=0},
#'   in which case each plot uses the range of the functions being
#'   plotted to create their \code{ylim}. By setting \code{scale} to
#'   be the maximum value of \code{diff(ylim)} for all the plots, then
#'   all subsequent plots will produced in the same vertical
#'   units. This is essential for comparing the importance of fitted
#'   terms in additive models.
#' @param ask if `TRUE`, `plot.Gam()` operates in interactive mode.
#' @param newdata if supplied to `preplot.Gam`, the preplot object is based on them rather than the original.
#' @param terms subsets of the terms can be selected
#' @param \dots Additonal plotting arguments, not all of which will
#'   work (like xlim)
#' @return a plot is produced for each of the terms in the object
#'   \code{x}. The function currently knows how to plot all
#'   main-effect functions of one or two predictors. So in particular,
#'   interactions are not plotted. An appropriate `x-y` is produced to
#'   display each of the terms, adorned with residuals, standard-error
#'   curves, and a rugplot, depending on the choice of options.  The
#'   form of the plot is different, depending on whether the `x`-value
#'   for each plot is numeric, a factor, or a matrix.
#' 
#' When \code{ask=TRUE}, rather than produce each plot sequentially,
#' \code{plot.Gam()} displays a menu listing all the terms that can be plotted,
#' as well as switches for all the options.
#' 
#' A \code{preplot.Gam} object is a list of precomputed terms. Each such term
#' (also a \code{preplot.Gam} object) is a list with components \code{x},
#' \code{y} and others---the basic ingredients needed for each term plot. These
#' are in turn handed to the specialized plotting function \code{gplot()},
#' which has methods for different classes of the leading \code{x} argument. In
#' particular, a different plot is produced if \code{x} is numeric, a category
#' or factor, a matrix, or a list. Experienced users can extend this range by
#' creating more \code{gplot()} methods for other classes.  Graphical
#' parameters (see \code{\link{par}}) may also be supplied as arguments to this
#' function. This function is a method for the generic function \code{plot()}
#' for class \code{"Gam"}.
#' 
#' It can be invoked by calling \code{plot(x)} for an object \code{x} of the
#' appropriate class, or directly by calling \code{plot.Gam(x)} regardless of
#' the class of the object.
#' @author Written by Trevor Hastie, following closely the design in the
#' "Generalized Additive Models" chapter (Hastie, 1992) in Chambers and Hastie
#' (1992).
#' @seealso \code{\link{preplot}}, \code{\link{predict.Gam}}
#' @references Hastie, T. J. (1992) \emph{Generalized additive models.} Chapter
#' 7 of \emph{Statistical Models in S} eds J. M. Chambers and T. J. Hastie,
#' Wadsworth & Brooks/Cole.
#' 
#' Hastie, T. and Tibshirani, R. (1990) \emph{Generalized Additive Models.}
#' London: Chapman and Hall.
#' @keywords models regression nonparametric smooth
#' @examples
#' 
#' data(gam.data)
#' Gam.object <- gam(y ~ s(x,6) + z,data=gam.data)
#' plot(Gam.object,se=TRUE)
#' data(gam.newdata)
#' preplot(Gam.object,newdata=gam.newdata)
#' 
#' @method plot Gam
#' @export
#' @export plot.Gam
"plot.Gam" <-
  function(x,  residuals = NULL, rugplot = TRUE, se = FALSE, scale = 0, ask = FALSE,
terms=labels.Gam(x), ...)
{

  if(!is.null(x$na.action))
    x$na.action <- NULL
  preplot.object <- x$preplot
  if(is.null(preplot.object))
    preplot.object <- preplot.Gam(x,terms=terms)
  x$preplot <- preplot.object
  Residuals <- resid(x)
  if(!is.null(residuals)) {
    if(length(residuals) == 1)
      if(residuals)
        residuals <- Residuals
      else residuals <- NULL
    else Residuals <- residuals
  }
  if(!ask) {
    plot.preplot.Gam(preplot.object, residuals = residuals, rugplot
                     = rugplot, scale = scale, se = se, fit = TRUE, ...)
    invisible(x)
  }
  else{
    nterms <- names(preplot.object)
    tterms <- substring(nterms, 1, 40)
                                        #truncate long names
    residualsmenu <- if(!is.null(residuals)) "residuals off" else
    "residuals on"
    rugmenu <- if(rugplot) "rug off" else "rug on"
    semenu <- if(se) "se off" else "se on"
    scalemenu <- paste("scale (", round(scale, 1), ")", sep = "")
    scales <- numeric()
    tmenu <- c(paste("plot:", tterms), "plot all terms", residualsmenu,
               rugmenu, semenu, scalemenu)
    tnames <- character()
    pick <- 1
    while(pick > 0 && pick <= length(tmenu)) {
      pick <- menu(tmenu, title =
                   "Make a plot selection (or 0 to exit):\n")
      if(pick > 0 && pick <= length(nterms)) {
        tscale <- plot.preplot.Gam(preplot.object[[pick]],
                                   residuals = residuals, rugplot = rugplot, scale
                                   = scale, se = se, fit = TRUE, ...)
        names(tscale) <- nterms[pick]
        scales <- c(scales, tscale)
        cat("Plots performed:\n ")
        print(scales)
      }
      else switch(pick - length(nterms),
                  {
                    scales <- plot.preplot.Gam(
                                               preplot.object, residuals =
                                               residuals, rugplot = rugplot,
                                               scale = scale, se = se, fit =
                                               TRUE, ...)
                    print(scales)
                  }
                  ,
                  {
                    residuals <- if(is.null(residuals))
                      Residuals else NULL
                    residualsmenu <- if(!is.null(residuals)
                                        ) "residuals off" else
                    "residuals on"
                  }
                  ,
                  {
                    rugplot <- !rugplot
                    rugmenu <- if(rugplot) "rug off" else
                    "rug on"
                  }
                  ,
                  {
                    se <- !se
                    semenu <- if(se) "se off" else "se on"
                  }
                  ,
                  {
                    cat("Type in a new scale\n")
                    scale <- eval(parse(n=1))
                    scalemenu <- paste("scale (", round(
                                                        scale, 1), ")", sep = "")
                  }
                  ,
                  invisible(return(x)))
      tmenu <- c(paste("plot:", tterms), "plot all terms",
                 residualsmenu, rugmenu, semenu, scalemenu)
    }
    invisible(x)
  }
}

Try the gam package in your browser

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

gam documentation built on March 31, 2023, 9:10 p.m.