

   aov {base}                                   R Documentation

   FFiitt aann AAnnaallyyssiiss ooff VVaarriiaannccee MMooddeell

   DDeessccrriippttiioonn::

        Fit an analysis of variance model by a call to `lm' for
        each stratum.

   UUssaaggee::

        aov(formula, data=NULL, projections=FALSE, contrasts=NULL, ...)
        se.aov(object, n, type = "means")

   AArrgguummeennttss::

    formula: A formula specifying the model.

       data: A data frame in which the variables specified in
             the formula will be found. If missing, the vari-
             ables are searched for in the standard way.

   projections: Logical flag: should the projections be
             returned?

   contrasts: A list of contrasts to be used for some of the
             factors in the formula. These are not used for any
             `Error' term, and supplying contrasts for factors
             only in the `Error' term will give a warning.

        ...: Arguments to be passed to `lm', such as `subset'
             or `na.action'.

   DDeettaaiillss::

        This provides a wrapper to `lm' for fitting linear mod-
        els to balanced or unbalanced experimental designs.

        The main difference from `lm' is in the way `print',
        `summary' and so on handle the fit: this is expressed
        in the traditional language of the analysis of variance
        rather than of linear models.

        If the formula contains a single `Error' term, this is
        used to specify error strata, and appropriate models
        are fitted within each error stratum.

        The formula can specify multiple responses.

   VVaalluuee::

        An object of class `c("aov", "lm")' or for multiple
        responses of class `c("maov", "aov", "mlm", "lm")' or
        for multiple error strata of class `"aovlist"'.  There
        are `print' and `summary' methods available for these.

   AAuutthhoorr((ss))::

        B. D. Ripley

   SSeeee AAllssoo::

        `lm', `alias', `proj', `model.tables'

   EExxaammpplleess::

        ## From Venables and Ripley (1997) p.210.
        N <- c(0,1,0,1,1,1,0,0,0,1,1,0,1,1,0,0,1,0,1,0,1,1,0,0)
        P <- c(1,1,0,0,0,1,0,1,1,1,0,0,0,1,0,1,1,0,0,1,0,1,1,0)
        K <- c(1,0,0,1,0,1,1,0,0,1,0,1,0,1,1,0,0,0,1,1,1,0,1,0)
        yield <- c(49.5,62.8,46.8,57.0,59.8,58.5,55.5,56.0,62.8,55.8,69.5,55.0,
                   62.0,48.8,45.5,44.2,52.0,51.5,49.8,48.8,57.2,59.0,53.2,56.0)
        npk <- data.frame(block=gl(6,4), N=factor(N), P=factor(P),
                          K=factor(K), yield=yield)

        ( npk.aov <- aov(yield ~ block + N*P*K, npk) )
        summary(npk.aov)
        coefficients(npk.aov)

        ## as a test, not particularly sensible statistically
        op <- options(contrasts=c("contr.helmert", "contr.treatment"))
        npk.aovE <- aov(yield ~  N*P*K + Error(block), npk)
        npk.aovE
        summary(npk.aovE)
        options(op)# reset to previous

