Residual Plots and Curvature Tests for Linear Model Fits
Plots the residuals versus each term in a mean function and versus fitted values. Also computes a curvature test for each of the plots by adding a quadratic term and testing the quadratic to be zero. This is Tukey's test for nonadditivity when plotting against fitted values.
### This is a generic function with only one required argument: residualPlots (model, ...) ## S3 method for class 'default': residualPlots(model, terms = ~., layout = NULL, ask, main = "", fitted = TRUE, AsIs=TRUE, plot = TRUE, tests = TRUE, ...) ## S3 method for class 'lm': residualPlots(model, ...) ## S3 method for class 'glm': residualPlots(model, ...) ### residualPlots calls residualPlot, so these arguments can be ### used with either function residualPlot(model, ...) ## S3 method for class 'default': residualPlot(model, variable = "fitted", type = "pearson", plot = TRUE, quadratic = TRUE, smooth = FALSE, span = 1/2, smooth.lwd=lwd, smooth.lty=lty, smooth.col=col.lines, labels, id.method = "y", id.n = if(id.method=="identify") Inf else 0, id.cex=1, id.col=palette(), col = palette(), col.lines = palette(), xlab, ylab, lwd = 1, lty=1, grid=TRUE, ...) ## S3 method for class 'lm': residualPlot(model, ...) ## S3 method for class 'glm': residualPlot(model, variable = "fitted", type = "pearson", plot = TRUE, quadratic = FALSE, smooth = TRUE, ...)
- A regression object.
- A one-sided formula that specifies a subset of the predictors. One
residual plot is drawn for each specified. The default
~ .is to plot against all predictors. For example, the specification
terms = ~ . - X3would plot agai
- If set to a value like
c(4, 3), the layout of the graph will have this many rows and columns. If not set, the program will select an appropriate layout. If the number of graphs exceed nine, you must select the la
TRUE, ask the user before drawing the next plot; if
FALSE, don't ask.
- Main title for the graphs. The default is
main=""for no title.
TRUE, the default, include the plot against fitted values.
FALSE, terms that use the
Iare skipped; if
TRUE, the default, they are included.
TRUE, draw the plot(s).
TRUE, display the curvature tests.
- Additional arguments passed to
residualPlotand then to
- Quoted variable name for the horizontal axis, or
"fitted"to plot versus fitted values.
- Type of residuals to be used. Pearson residuals are
lmobjects since these are equivalent to ordinary residuals with ols and correctly weighted residuals with wls. Any quoted string that is an appropriate value of the
TRUE, fits the quadratic regression of the vertical axis on the horizontal axis and displays a lack of fit test. Default is
- if TRUE fits a loess smooth using the settings given below. Defaults to FALSE for lm objects and TRUE for glm objects.
- span, smooth.lwd, smooth.lty, smooth.col
- Should a lowess smooth be added to the figure? The
spanis the smoothing parameter for lowess,
smooth.colare, respectively, the width, type, and color of the line drawn o
- Arguments for the labelling of
points. The default is
id.n=0for labeling no points. See
showLabelsfor details of these arguments.
- default color for points
- default color for lines
- X-axis label. If not specified, a useful label is constructed by the function.
- Y-axis label. If not specified, a useful label is constructed by the function.
- line width for lines.
- line type for quadratic.
- If TRUE, the default, a light-gray background grid is put on the graph
residualPlots draws one or more residuals plots depending on the
value of the
fitted arguments. If
terms = ~ .,
the default, then a plot is produced of residuals versus each first-order
term in the formula used to create the model. Interaction terms, spline terms,
and polynomial terms of more than one predictor are
skipped. In addition terms that use the
will also be skipped unless you set the argument
AsIs=TRUE. A plot of
residuals versus fitted values is also included unless
In addition to plots, a table of curvature tests is displayed. For plots
against a term in the model formula, say
X1, the test displayed is
the t-test for for
I(X^2) in the fit of
update, model, ~. + I(X^2)).
Econometricians call this a specification test. For factors, the displayed
plot is a boxplot, and no curvature test is computed.
For fitted values, the test is Tukey's one-degree-of-freedom test for
nonadditivity. You can suppress the tests with the argument
residualPlot, which is called by
should be viewed as an internal function, and is included here to display its
arguments, which can be used with
residualPlots as well. The
residualPlot function returns the curvature test as an invisible result.
residCurvTest computes the curvature test only. For any factors a
boxplot will be drawn. For any polynomials, plots are against the linear term.
Other non-standard predictors like B-splines are skipped.
lmobjects, returns a data.frame with one row for each plot drawn, one column for the curvature test statistic, and a second column for the corresponding p-value. This function is used primarily for its side effect of drawing residual plots.
Fox, J. and Weisberg, S. (2011) An R Companion to Applied Regression, Second Edition. Sage. Weisberg, S. (2005) Applied Linear Regression, Third Edition, Wiley, Chapter 8