The function fits environmental vectors or factors onto an ordination. The projections of points onto vectors have maximum correlation with corresponding environmental variables, and the factors show the averages of factor levels. For continuous varaibles this is equal to fitting a linear trend surface (plane in 2D) for a variable (see ordisurf); this trend surface can be presented by showing its gradient (direction of steepest increase) using an arrow. The environmental variables are the dependent variables that are explained by the ordination scores, and each dependent variable is analysed separately.

# S3 method for default
envfit(ord, env, permutations = 999, strata = NULL,
   choices=c(1,2),  display = "sites", w  = weights(ord, display),
   na.rm = FALSE, ...)
# S3 method for formula
envfit(formula, data, ...)
# S3 method for envfit
plot(x, choices = c(1,2), labels, arrow.mul, at = c(0,0),
   axis = FALSE, p.max = NULL, col = "blue", bg, add = TRUE, ...)
# S3 method for envfit
scores(x, display, choices, ...)
vectorfit(X, P, permutations = 0, strata = NULL, w, ...)
factorfit(X, P, permutations = 0, strata = NULL, w, ...)

Arguments

ord

An ordination object or other structure from which the ordination scores can be extracted (including a data frame or matrix of scores).

env

Data frame, matrix or vector of environmental variables. The variables can be of mixed type (factors, continuous variables) in data frames.

X

Matrix or data frame of ordination scores.

P

Data frame, matrix or vector of environmental variable(s). These must be continuous for vectorfit and factors or characters for factorfit.

permutations

a list of control values for the permutations as returned by the function how, or the number of permutations required, or a permutation matrix where each row gives the permuted indices. Set permutations = 0 to skip permutations.

formula, data

Model formula and data.

na.rm

Remove points with missing values in ordination scores or environmental variables. The operation is casewise: the whole row of data is removed if there is a missing value and na.rm = TRUE.

x

A result object from envfit. For ordiArrowMul and ordiArrowTextXY this must be a two-column matrix (or matrix-like object) containing the coordinates of arrow heads on the two plot axes, and other methods extract such a structure from the envfit results.

choices

Axes to plotted.

labels

Change plotting labels. The argument should be a list with elements vectors and factors which give the new plotting labels. If either of these elements is omitted, the default labels will be used. If there is only one type of elements (only vectors or only factors), the labels can be given as vector. The default labels can be displayed with labels command.

arrow.mul

Multiplier for vector lengths. The arrows are automatically scaled similarly as in plot.cca if this is not given and add = TRUE.

at

The origin of fitted arrows in the plot. If you plot arrows in other places then origin, you probably have to specify arrrow.mul.

axis

Plot axis showing the scaling of fitted arrows.

p.max

Maximum estimated \(P\) value for displayed variables. You must calculate \(P\) values with setting permutations to use this option.

col

Colour in plotting.

bg

Background colour for labels. If bg is set, the labels are displayed with ordilabel instead of text. See Examples for using semitransparent background.

add

Results added to an existing ordination plot.

strata

An integer vector or factor specifying the strata for permutation. If supplied, observations are permuted only within the specified strata.

display

In fitting functions these are ordinary site scores or linear combination scores ("lc") in constrained ordination (cca, rda, capscale). In scores function they are either "vectors" or "factors" (with synonyms "bp" or "cn", resp.).

w

Weights used in fitting (concerns mainly cca and decorana results which have nonconstant weights).

...

Parameters passed to scores.

Details

Function envfit finds vectors or factor averages of environmental variables. Function plot.envfit adds these in an ordination diagram. If X is a data.frame, envfit uses factorfit for factor variables and vectorfit for other variables. If X is a matrix or a vector, envfit uses only vectorfit. Alternatively, the model can be defined a simplified model formula, where the left hand side must be an ordination result object or a matrix of ordination scores, and right hand side lists the environmental variables. The formula interface can be used for easier selection and/or transformation of environmental variables. Only the main effects will be analysed even if interaction terms were defined in the formula.

The ordination results are extracted with scores and all extra arguments are passed to the scores. The fitted models only apply to the results defined when extracting the scores when using envfit. For instance, scaling in constrained ordination (see scores.rda, scores.cca) must be set in the same way in envfit and in the plot or the ordination results (see Examples).

The printed output of continuous variables (vectors) gives the direction cosines which are the coordinates of the heads of unit length vectors. In plot these are scaled by their correlation (square root of the column r2) so that “weak” predictors have shorter arrows than “strong” predictors. You can see the scaled relative lengths using command scores. The plotted (and scaled) arrows are further adjusted to the current graph using a constant multiplier: this will keep the relative r2-scaled lengths of the arrows but tries to fill the current plot. You can see the multiplier using ordiArrowMul(result_of_envfit), and set it with the argument arrow.mul.

Functions vectorfit and factorfit can be called directly. Function vectorfit finds directions in the ordination space towards which the environmental vectors change most rapidly and to which they have maximal correlations with the ordination configuration. Function factorfit finds averages of ordination scores for factor levels. Function factorfit treats ordered and unordered factors similarly.

If permutations \(> 0\), the significance of fitted vectors or factors is assessed using permutation of environmental variables. The goodness of fit statistic is squared correlation coefficient (\(r^2\)). For factors this is defined as \(r^2 = 1 - ss_w/ss_t\), where \(ss_w\) and \(ss_t\) are within-group and total sums of squares. See permutations for additional details on permutation tests in Vegan.

User can supply a vector of prior weights w. If the ordination object has weights, these will be used. In practise this means that the row totals are used as weights with cca or decorana results. If you do not like this, but want to give equal weights to all sites, you should set w = NULL. The fitted vectors are similar to biplot arrows in constrained ordination only when fitted to LC scores (display = "lc") and you set scaling = "species" (see scores.cca). The weighted fitting gives similar results to biplot arrows and class centroids in cca.

The lengths of arrows for fitted vectors are automatically adjusted for the physical size of the plot, and the arrow lengths cannot be compared across plots. For similar scaling of arrows, you must explicitly set the arrow.mul argument in the plot command; see ordiArrowMul and ordiArrowTextXY.

The results can be accessed with scores.envfit function which returns either the fitted vectors scaled by correlation coefficient or the centroids of the fitted environmental variables.

Value

Functions vectorfit and factorfit return lists of classes vectorfit and factorfit which have a print method. The result object have the following items:

arrows

Arrow endpoints from vectorfit. The arrows are scaled to unit length.

centroids

Class centroids from factorfit.

r

Goodness of fit statistic: Squared correlation coefficient

permutations

Number of permutations.

control

A list of control values for the permutations as returned by the function how.

pvals

Empirical P-values for each variable.

Function envfit returns a list of class envfit with results of vectorfit and envfit as items. Function plot.envfit scales the vectors by correlation.

Note

Fitted vectors have become the method of choice in displaying environmental variables in ordination. Indeed, they are the optimal way of presenting environmental variables in Constrained Correspondence Analysis cca, since there they are the linear constraints. In unconstrained ordination the relation between external variables and ordination configuration may be less linear, and therefore other methods than arrows may be more useful. The simplest is to adjust the plotting symbol sizes (cex, symbols) by environmental variables. Fancier methods involve smoothing and regression methods that abound in R, and ordisurf provides a wrapper for some.

See also

A better alternative to vectors may be ordisurf.

Examples

data(varespec, varechem) library(MASS) ord <- metaMDS(varespec)
#> Square root transformation #> Wisconsin double standardization #> Run 0 stress 0.1843196 #> Run 1 stress 0.1843197 #> ... Procrustes: rmse 0.0001047654 max resid 0.0004247604 #> ... Similar to previous best #> Run 2 stress 0.1955836 #> Run 3 stress 0.195049 #> Run 4 stress 0.2092456 #> Run 5 stress 0.2088297 #> Run 6 stress 0.182566 #> ... New best solution #> ... Procrustes: rmse 0.04155923 max resid 0.151358 #> Run 7 stress 0.18458 #> Run 8 stress 0.1843198 #> Run 9 stress 0.1974415 #> Run 10 stress 0.1948415 #> Run 11 stress 0.1843199 #> Run 12 stress 0.2079058 #> Run 13 stress 0.195584 #> Run 14 stress 0.2109005 #> Run 15 stress 0.2109001 #> Run 16 stress 0.2066184 #> Run 17 stress 0.1962451 #> Run 18 stress 0.1843196 #> Run 19 stress 0.2133667 #> Run 20 stress 0.2143638 #> *** No convergence -- monoMDS stopping criteria: #> 20: stress ratio > sratmax
(fit <- envfit(ord, varechem, perm = 999))
#> #> ***VECTORS #> #> NMDS1 NMDS2 r2 Pr(>r) #> N -0.05757 -0.99834 0.2534 0.043 * #> P 0.61974 0.78481 0.1940 0.092 . #> K 0.76668 0.64203 0.1810 0.114 #> Ca 0.68543 0.72813 0.4119 0.006 ** #> Mg 0.63271 0.77439 0.4269 0.001 *** #> S 0.19153 0.98149 0.1751 0.141 #> Al -0.87152 0.49036 0.5269 0.001 *** #> Fe -0.93570 0.35280 0.4449 0.005 ** #> Mn 0.79894 -0.60141 0.5231 0.001 *** #> Zn 0.61749 0.78658 0.1879 0.129 #> Mo -0.90354 0.42851 0.0610 0.533 #> Baresoil 0.92454 -0.38108 0.2508 0.051 . #> Humdepth 0.93276 -0.36050 0.5201 0.003 ** #> pH -0.64805 0.76160 0.2307 0.064 . #> --- #> Signif. codes: 0 ‘***’ 0.001 ‘**’ 0.01 ‘*’ 0.05 ‘.’ 0.1 ‘ ’ 1 #> Permutation: free #> Number of permutations: 999 #> #>
scores(fit, "vectors")
#> NMDS1 NMDS2 #> N -0.02898339 -0.5025909 #> P 0.27295984 0.3456610 #> K 0.32613416 0.2731129 #> Ca 0.43991047 0.4673159 #> Mg 0.41338731 0.5059551 #> S 0.08014405 0.4106893 #> Al -0.63259465 0.3559320 #> Fe -0.62414089 0.2353322 #> Mn 0.57782367 -0.4349644 #> Zn 0.26770206 0.3410058 #> Mo -0.22313263 0.1058215 #> Baresoil 0.46300376 -0.1908407 #> Humdepth 0.67268828 -0.2599856 #> pH -0.31127827 0.3658175
plot(ord)
plot(fit)
plot(fit, p.max = 0.05, col = "red")
## Adding fitted arrows to CCA. We use "lc" scores, and hope ## that arrows are scaled similarly in cca and envfit plots ord <- cca(varespec ~ Al + P + K, varechem) plot(ord, type="p")
fit <- envfit(ord, varechem, perm = 999, display = "lc") plot(fit, p.max = 0.05, col = "red")
## 'scaling' must be set similarly in envfit and in ordination plot plot(ord, type = "p", scaling = "sites")
fit <- envfit(ord, varechem, perm = 0, display = "lc", scaling = "sites") plot(fit, col = "red")
## Class variables, formula interface, and displaying the ## inter-class variability with ordispider, and semitransparent ## white background for labels (semitransparent colours are not ## supported by all graphics devices) data(dune) data(dune.env) ord <- cca(dune) fit <- envfit(ord ~ Moisture + A1, dune.env, perm = 0) plot(ord, type = "n")
with(dune.env, ordispider(ord, Moisture, col="skyblue"))
with(dune.env, points(ord, display = "sites", col = as.numeric(Moisture), pch=16))
plot(fit, cex=1.2, axis=TRUE, bg = rgb(1, 1, 1, 0.5))
## Use shorter labels for factor centroids labels(fit)
#> $vectors #> [1] "A1" #> #> $factors #> [1] "Moisture1" "Moisture2" "Moisture4" "Moisture5" #>
plot(ord)
plot(fit, labels=list(factors = paste("M", c(1,2,4,5), sep = "")), bg = rgb(1,1,0,0.5))