Skip to contents

Ordination methods cca, rda, dbrda and capscale return similar result objects. All these methods use the same internal function ordConstrained. They differ only in (1) initial transformation of the data and in defining inertia, (2) weighting, and (3) the use of rectangular rows \(\times\) columns data or symmetric rows \(\times\) rows dissimilarities: rda initializes data to give variance or correlations as inertia, cca is based on double-standardized data to give Chi-square inertia and uses row and column weights, capscale maps the real part of dissimilarities to rectangular data and performs RDA, and dbrda performs an RDA-like analysis directly on symmetric dissimilarities.

Function ordConstrained returns the same result components for all these methods, and the calling function may add some more components to the final result. However, you should not access these result components directly (using $): the internal structure is not regarded as stable application interface (API), but it can change at any release. If you access the results components directly, you take a risk of breakage at any vegan release. The vegan provides a wide set of accessor functions to those components, and these functions are updated when the result object changes. This documentation gives an overview of accessor functions to the cca result object.

Usage

ordConstrained(Y, X = NULL, Z = NULL, method = c("cca", "rda",
    "capscale", "dbrda", "pass"), arg = FALSE)
ordiYbar(x, model = c("CCA", "CA", "pCCA", "partial", "initial"))
# S3 method for class 'cca'
model.frame(formula, ...)
# S3 method for class 'cca'
model.matrix(object, ...)
# S3 method for class 'cca'
weights(object, display = "sites", ...)

Arguments

Y, X, Z

Input matrix of responses (Y) and model matrices of constraints (X) and conditions (Z). NULL matrices are ignored.

method

Ordination method. If "pass", method is defined by Y of fitted ordination model.

arg

Possible extra argument passed to method; in rda this is scale.

object, x, formula

A result object from cca, rda, dbrda, or capscale.

model

Show constrained ("CCA"), unconstrained ("CA") or conditioned “partial” ("pCCA") results. In ordiYbar the value can also be "initial" for the internal working input data, and "partial" for the internal working input data after removing the partial effects.

display

Display either "sites" or "species".

...

Other arguments passed to the the function.

Details

Function ordConstrained is used as the basic analysis engine in all [partial] constrained ordination methods (cca, rda, dbrda _etc_). Those higher-level functions set up the data for ordConstrained and add items used in printing or further analysis of the results. Function ordConstrained can also be called directly, but the user should be very careful in setting up the input arguments and in processing the result. All supported ordination methods have an initXXX function that transforms the data for analysis and sets data attributes for analytic steps. These arguments include attribute METHOD and for cca row and column weights (attributes RW and CW). These are used to select the branch of analysis in further steps. Argument method selects the ordination type. method = "pass" is used when the dependent matrix Y already was processed with an initXXX method. This allows embedding ordConstrained in other functions with any constrained ordination method or using your own initXXX method (see Examples). Dependent matrix Y must be supplied but conditions Z and constraints X can be NULL and then this analysis step is skipped (if both are NULL, unconstrained ordination is performed). Steps for conditions (partialling) and constraints return residuals of input Y for the next step, and all methods return their analysis results.

The internal (“working”) form of the dependent (community) data can be accessed with function ordiYbar. The form depends on the ordination method: for instance, in cca the data are weighted and Chi-square transformed, and in dbrda they are Gower-centred dissimilarities. The input data in the original (“response”) form can be accessed with fitted.cca and residuals.cca. Function predict.cca can return either working or response data, and also their lower-rank approximations.

The model matrix of independent data (“Constraints” and “Conditions”) can be extracted with model.matrix. In partial analysis, the function returns a list of design matrices called Conditions and Constraints. If either component was missing, a single matrix is returned. The redundant (aliased) terms do not appear in the model matrix. These terms can be found with alias.cca. Function model.frame tries to reconstruct the data frame from which the model matrices were derived. This is only possible if the original model was fitted with formula and data arguments, and still fails if the data are unavailable.

The number of observations can be accessed with nobs.cca, and the residual degrees of freedom with df.residual.cca. The information on observations with missing values can be accessed with na.action. The terms and formula of the fitted model can be accessed with formula and terms.

The weights used in cca can be accessed with weights. In unweighted methods (rda) all weights are equal.

The ordination results are saved in separate components for partial terms, constraints and residual unconstrained ordination. There is no guarantee that these components will have the same internal names as currently, and you should be cautious when developing scripts and functions that directly access these components.

The constrained ordination algorithm is based on QR decomposition of constraints and conditions (environmental data), and the QR component is saved separately for partial and constrained components. The QR decomposition of constraints can be accessed with qr.cca. This will also include the residual effects of partial terms (Conditions), and it should be used together with ordiYbar(x, "partial"). The environmental data are first centred in rda or weighted and centred in cca. The QR decomposition is used in many functions that access cca results, and it can be used to find many items that are not directly stored in the object. For examples, see coef.cca, coef.rda, vif.cca, permutest.cca, predict.cca, predict.rda, calibrate.cca. See qr for other possible uses of this component. For instance, the rank of the constraints can be found from the QR decomposition.

The eigenvalues of the solution can be accessed with eigenvals.cca. Eigenvalues are not evaluated for partial component, and they will only be available for constrained and residual components.

The ordination scores are internally stored as (weighted) orthonormal scores matrices. These results can be accessed with scores.cca and scores.rda functions. The ordination scores are scaled when accessed with scores functions, but internal (weighted) orthonormal scores can be accessed by setting scaling = FALSE. Unconstrained residual component has species and site scores, and constrained component has also fitted site scores or linear combination scores for sites and biplot scores and centroids for constraint variables. The biplot scores correspond to the model.matrix, and centroids are calculated for factor variables when they were used. The scores can be selected by defining the axes, and there is no direct way of accessing all scores of a certain component. The number of dimensions can be assessed from eigenvals. In addition, some other types can be derived from the results although not saved in the results. For instance, regression scores and model coefficients can be accessed with scores and coef functions. Partial component will have no scores.

Distance-based methods (dbrda, capscale) can have negative eigenvalues and associated imaginary axis scores. In addition, species scores are initially missing in dbrda and they are accessory and found after analysis in capscale (and may be misleading). Function sppscores can be used to add species scores or replace them with more meaningful ones.

See also

The core function is ordConstrained which is called by cca, rda, dbrda, capscale as well as by unconstrained methods pca, ca and pco. The basic class is "cca" for all methods, and the following functions are defined for this class: add1.cca, alias.cca, anova.cca, as.mlm.cca, biplot.cca, bstick.cca, calibrate.cca, coef.cca, cooks.distance.cca, deviance.cca, df.residual.cca, drop1.cca, eigenvals.cca, extractAIC.cca, fitted.cca, goodness.cca, hatvalues.cca, influence.cca, labels.cca, model.frame.cca, model.matrix.cca, nobs.cca, permutest.cca, plot.cca, points.cca, predict.cca, print.cca, qr.cca, residuals.cca, RsquareAdj.cca, rstandard.cca, rstudent.cca, scores.cca, screeplot.cca, sigma.cca, simulate.cca, SSD.cca, stressplot.cca, summary.cca, text.cca, tolerance.cca, vcov.cca, weights.cca . Other functions handling "cca" objects include inertcomp, intersetcor, mso, ordistep, ordiR2step and vif.cca. Functions that can be regarded as special cases of "cca" methods include adonis2 and varpart.

Note

The latest large change of result object was made in release 2.5-1 in 2016. You can modernize ancient stray results with modernobject <- update(ancientobject).

References

Legendre, P. and Legendre, L. (2012) Numerical Ecology. 3rd English ed. Elsevier.

Author

Jari Oksanen

Examples

  data(dune, dune.env)
  mod0 <- cca(dune ~ Management + Moisture, dune.env)
  ## refit the model in ordConstrained
  mrefit <- ordConstrained(ordiYbar(mod0, "initial"),
                         model.matrix(mod0),
                         NULL,
                         "pass")

  ## implement weighted RDA (weights w)
  initWPCA <- function(Y, w) {
    Y <- as.matrix(Y)
    Y <- .Call("do_wcentre", Y, w)
    attr(Y, "RW") <- w
    attr(Y, "METHOD") <- "WPCA"
    Y
  }
  mod <- rda(dune ~ Management + Moisture, dune.env)
  mod
#> 
#> Call: rda(formula = dune ~ Management + Moisture, data = dune.env)
#> 
#>               Inertia Proportion Rank
#> Total         84.1237     1.0000     
#> Constrained   46.4249     0.5519    6
#> Unconstrained 37.6988     0.4481   13
#> 
#> Inertia is variance
#> 
#> Eigenvalues for constrained axes:
#>   RDA1   RDA2   RDA3   RDA4   RDA5   RDA6 
#> 21.588 14.075  4.123  3.163  2.369  1.107 
#> 
#> Eigenvalues for unconstrained axes:
#>   PC1   PC2   PC3   PC4   PC5   PC6   PC7   PC8   PC9  PC10  PC11  PC12  PC13 
#> 8.241 7.138 5.355 4.409 3.143 2.770 1.878 1.741 0.952 0.909 0.627 0.311 0.227 
#> 
  w <- rowSums(dune)/sum(dune)
  adjust <- 1 + 1/(nrow(dune) - 1)
  wmod <- ordConstrained(initWPCA(dune, w * adjust),
                         model.matrix(~ Management + Moisture,dune.env)[,-1],
                         NULL, "pass")
  class(wmod) <- c("wrda", "cca") # for clean print.cca
  wmod
#> 
#> Call: ordConstrained(Y = initWPCA(dune, w * adjust), X =
#> model.matrix(~Management + Moisture, dune.env)[, -1], Z = NULL, method =
#> "pass")
#> 
#>               Inertia Proportion Rank
#> Total         84.2528     1.0000     
#> Constrained   47.8693     0.5682    6
#> Unconstrained 36.3836     0.4318   13
#> 
#> Inertia is
#> 
#> Eigenvalues for constrained axes:
#>      1      2      3      4      5      6 
#> 22.766 13.150  5.332  3.279  2.400  0.941 
#> 
#> Eigenvalues for unconstrained axes:
#>     1     2     3     4     5     6     7     8     9    10    11    12    13 
#> 8.208 7.795 5.218 3.585 2.950 2.417 1.911 1.560 0.920 0.703 0.577 0.326 0.214 
#> 

  ## CCA as weighted RDA (species scores differ, though).
  dchi <- decostand(dune, "chi.sq")
  ccmod <- ordConstrained(initWPCA(dchi, w), model.matrix(mod),
                          NULL, "pass")
  class(ccmod) <- c("wrda", "cca")
  ccmod # wrda
#> 
#> Call: ordConstrained(Y = initWPCA(dchi, w), X = model.matrix(mod), Z =
#> NULL, method = "pass")
#> 
#>               Inertia Proportion Rank
#> Total          2.1153     1.0000     
#> Constrained    1.0024     0.4739    6
#> Unconstrained  1.1129     0.5261   13
#> 
#> Inertia is
#> 
#> Eigenvalues for constrained axes:
#>      1      2      3      4      5      6 
#> 0.4458 0.2887 0.1124 0.0717 0.0494 0.0344 
#> 
#> Eigenvalues for unconstrained axes:
#>      1      2      3      4      5      6      7      8      9     10     11 
#> 0.3504 0.1521 0.1251 0.1098 0.0922 0.0771 0.0594 0.0478 0.0370 0.0223 0.0207 
#>     12     13 
#> 0.0108 0.0083 
#> 
  mod0  # cca
#> 
#> Call: cca(formula = dune ~ Management + Moisture, data = dune.env)
#> 
#>               Inertia Proportion Rank
#> Total          2.1153     1.0000     
#> Constrained    1.0024     0.4739    6
#> Unconstrained  1.1129     0.5261   13
#> 
#> Inertia is scaled Chi-square
#> 
#> Eigenvalues for constrained axes:
#>   CCA1   CCA2   CCA3   CCA4   CCA5   CCA6 
#> 0.4458 0.2887 0.1124 0.0717 0.0494 0.0344 
#> 
#> Eigenvalues for unconstrained axes:
#>    CA1    CA2    CA3    CA4    CA5    CA6    CA7    CA8    CA9   CA10   CA11 
#> 0.3504 0.1521 0.1251 0.1098 0.0922 0.0771 0.0594 0.0478 0.0370 0.0223 0.0207 
#>   CA12   CA13 
#> 0.0108 0.0083 
#>