Function metaMDS performs Nonmetric Multidimensional Scaling (NMDS), and tries to find a stable solution using several random starts. In addition, it standardizes the scaling in the result, so that the configurations are easier to interpret, and adds species scores to the site ordination. The metaMDS function does not provide actual NMDS, but it calls another function for the purpose. Currently monoMDS is the default choice, and it is also possible to call the isoMDS (MASS package).

metaMDS(comm, distance = "bray", k = 2, try = 20, trymax = 20,
    engine = c("monoMDS", "isoMDS"), autotransform =TRUE,
    noshare = (engine == "isoMDS"), wascores = TRUE, expand = TRUE,
    trace = 1, plot = FALSE, previous.best,  ...)
# S3 method for metaMDS
plot(x, display = c("sites", "species"), choices = c(1, 2),
    type = "p", shrink = FALSE,  ...)
# S3 method for metaMDS
points(x, display = c("sites", "species"),
    choices = c(1,2), shrink = FALSE, select, ...)
# S3 method for metaMDS
text(x, display = c("sites", "species"), labels,
    choices = c(1,2), shrink = FALSE, select, ...)
# S3 method for metaMDS
scores(x, display = c("sites", "species"), shrink = FALSE,
    choices, ...)
metaMDSdist(comm, distance = "bray", autotransform = TRUE,
    noshare = TRUE, trace = 1, commname, zerodist = "ignore",
    distfun = vegdist, ...)
metaMDSiter(dist, k = 2, try = 20, trymax = 20, trace = 1, plot = FALSE,
    previous.best, engine = "monoMDS", maxit = 200,
    parallel = getOption("mc.cores"), ...)
initMDS(x, k=2)
postMDS(X, dist, pc=TRUE, center=TRUE, halfchange, threshold=0.8,
    nthreshold=10, plot=FALSE, ...)
metaMDSredist(object, ...)

Arguments

comm

Community data. Alternatively, dissimilarities either as a dist structure or as a symmetric square matrix. In the latter case all other stages are skipped except random starts and centring and pc rotation of axes.

distance

Dissimilarity index used in vegdist.

k

Number of dimensions. NB., the number of points \(n\) should be \(n > 2k + 1\), and preferably higher in global non-metric MDS, and still higher in local NMDS.

try, trymax

Minimum and maximum numbers of random starts in search of stable solution. After try has been reached, the iteration will stop when two convergent solutions were found or trymax was reached.

engine

The function used for MDS. The default is to use the monoMDS function in vegan, but for backward compatibility it is also possible to use isoMDS of MASS.

autotransform

Use simple heuristics for possible data transformation of typical community data (see below). If you do not have community data, you should probably set autotransform = FALSE.

noshare

Triggering of calculation step-across or extended dissimilarities with function stepacross. The argument can be logical or a numerical value greater than zero and less than one. If TRUE, extended dissimilarities are used always when there are no shared species between some sites, if FALSE, they are never used. If noshare is a numerical value, stepacross is used when the proportion of site pairs with no shared species exceeds noshare. The number of pairs with no shared species is found with no.shared function, and noshare has no effect if input data were dissimilarities instead of community data.

wascores

Calculate species scores using function wascores.

expand

Expand weighted averages of species in wascores.

trace

Trace the function; trace = 2 or higher will be more voluminous.

plot

Graphical tracing: plot interim results. You may want to set par(ask = TRUE) with this option.

previous.best

Start searches from a previous solution.

x

metaMDS result (or a dissimilarity structure for initMDS).

choices

Axes shown.

type

Plot type: "p" for points, "t" for text, and "n" for axes only.

display

Display "sites" or "species".

shrink

Shrink back species scores if they were expanded originally.

labels

Optional test to be used instead of row names.

select

Items to be displayed. This can either be a logical vector which is TRUE for displayed items or a vector of indices of displayed items.

X

Configuration from multidimensional scaling.

commname

The name of comm: should not be given if the function is called directly.

zerodist

Handling of zero dissimilarities: either "fail" or "add" a small positive value, or "ignore". monoMDS accepts zero dissimilarities and the default is zerodist = "ignore", but with isoMDS you may need to set zerodist = "add".

distfun

Dissimilarity function. Any function returning a dist object and accepting argument method can be used (but some extra arguments may cause name conflicts).

maxit

Maximum number of iterations in the single NMDS run; passed to the engine function monoMDS or isoMDS.

parallel

Number of parallel processes or a predefined socket cluster. If you use pre-defined socket clusters (say, clus), you must issue clusterEvalQ(clus, library(vegan)) to make available internal vegan functions. With parallel = 1 uses ordinary, non-parallel processing. The parallel processing is done with parallel package.

dist

Dissimilarity matrix used in multidimensional scaling.

pc

Rotate to principal components.

center

Centre the configuration.

halfchange

Scale axes to half-change units. This defaults TRUE when dissimilarities were evaluated within metaMDS and the dissimilarity index has an upper limit of \(1\). If FALSE, the ordination dissimilarities are scaled to the same range as the input dissimilarities.

threshold

Largest dissimilarity used in half-change scaling.

nthreshold

Minimum number of points in half-change scaling.

object

A result object from metaMDS.

...

Other parameters passed to functions. Function metaMDS passes all arguments to its component functions metaMDSdist, metaMDSiter, postMDS, and to distfun and engine.

Details

Non-metric Multidimensional Scaling (NMDS) is commonly regarded as the most robust unconstrained ordination method in community ecology (Minchin 1987). Function metaMDS is a wrapper function that calls several other functions to combine Minchin's (1987) recommendations into one command. The complete steps in metaMDS are:

  1. Transformation: If the data values are larger than common abundance class scales, the function performs a Wisconsin double standardization (wisconsin). If the values look very large, the function also performs sqrt transformation. Both of these standardizations are generally found to improve the results. However, the limits are completely arbitrary (at present, data maximum 50 triggers sqrt and \(>9\) triggers wisconsin). If you want to have a full control of the analysis, you should set autotransform = FALSE and standardize and transform data independently. The autotransform is intended for community data, and for other data types, you should set autotransform = FALSE. This step is perfomed using metaMDSdist, and the step is skipped if input were dissimilarities.

  2. Choice of dissimilarity: For a good result, you should use dissimilarity indices that have a good rank order relation to ordering sites along gradients (Faith et al. 1987). The default is Bray-Curtis dissimilarity, because it often is the test winner. However, any other dissimilarity index in vegdist can be used. Function rankindex can be used for finding the test winner for you data and gradients. The default choice may be bad if you analyse other than community data, and you should probably select an appropriate index using argument distance. This step is performed using metaMDSdist, and the step is skipped if input were dissimilarities.

  3. Step-across dissimilarities: Ordination may be very difficult if a large proportion of sites have no shared species. In this case, the results may be improved with stepacross dissimilarities, or flexible shortest paths among all sites. The default NMDS engine is monoMDS which is able to break tied values at the maximum dissimilarity, and this often is sufficient to handle cases with no shared species, and therefore the default is not to use stepacross with monoMDS. Function isoMDS does not handle tied values adequately, and therefore the default is to use stepacross always when there are sites with no shared species with engine = "isoMDS". The stepacross is triggered by option noshare. If you do not like manipulation of original distances, you should set noshare = FALSE. This step is skipped if input data were dissimilarities instead of community data. This step is performed using metaMDSdist, and the step is skipped always when input were dissimilarities.

  4. NMDS with random starts: NMDS easily gets trapped into local optima, and you must start NMDS several times from random starts to be confident that you have found the global solution. The strategy in metaMDS is to first run NMDS starting with the metric scaling (cmdscale which usually finds a good solution but often close to a local optimum), or use the previous.best solution if supplied, and take its solution as the standard (Run 0). Then metaMDS starts NMDS from several random starts (minimum number is given by try and maximum number by trymax). These random starts are generated by initMDS. If a solution is better (has a lower stress) than the previous standard, it is taken as the new standard. If the solution is better or close to a standard, metaMDS compares two solutions using Procrustes analysis (function procrustes with option symmetric = TRUE). If the solutions are very similar in their Procrustes rmse and the largest residual is very small, the solutions are regarded as convergent and the better one is taken as the new standard. The conditions are stringent, and you may have found good and relatively stable solutions although the function is not yet satisfied. Setting trace = TRUE will monitor the final stresses, and plot = TRUE will display Procrustes overlay plots from each comparison. This step is performed using metaMDSiter. This is the first step performed if input data (comm) were dissimilarities. Random starts can be run with parallel processing (argument parallel).

  5. Scaling of the results: metaMDS will run postMDS for the final result. Function postMDS provides the following ways of “fixing” the indeterminacy of scaling and orientation of axes in NMDS: Centring moves the origin to the average of the axes; Principal components rotate the configuration so that the variance of points is maximized on first dimension (with function MDSrotate you can alternatively rotate the configuration so that the first axis is parallel to an environmental variable); Half-change scaling scales the configuration so that one unit means halving of community similarity from replicate similarity. Half-change scaling is based on closer dissimilarities where the relation between ordination distance and community dissimilarity is rather linear (the limit is set by argument threshold). If there are enough points below this threshold (controlled by the parameter nthreshold), dissimilarities are regressed on distances. The intercept of this regression is taken as the replicate dissimilarity, and half-change is the distance where similarity halves according to linear regression. Obviously the method is applicable only for dissimilarity indices scaled to \(0 \ldots 1\), such as Kulczynski, Bray-Curtis and Canberra indices. If half-change scaling is not used, the ordination is scaled to the same range as the original dissimilarities. Half-change scaling is skipped by default if input were dissimilarities, but can be turned on with argument halfchange = TRUE. NB., The PC rotation only changes the directions of reference axes, and it does not influence the configuration or solution in general.

  6. Species scores: Function adds the species scores to the final solution as weighted averages using function wascores with given value of parameter expand. The expansion of weighted averages can be undone with shrink = TRUE in plot or scores functions, and the calculation of species scores can be suppressed with wascores = FALSE. This step is skipped if input were dissimilarities and community data were unavailable. However, the species scores can be added or replaced with sppscores.

Convergence Problems

The function tries hard to find two convergent solutions, but it may fail. With default engine = "monoMDS" the function will tabulate the stopping criteria used, so that you can see which criterion should be made more stringent. The criteria can be given as arguments to metaMDS and their current values are described in monoMDS. In particular, if you reach the maximum number of iterations, you should increase the value of maxit. You may ask for a larger number of random starts without losing the old ones giving the previous solution in argument previous.best.

In addition to too slack convergence criteria and too low number of random starts, wrong number of dimensions (argument k) is the most common reason for not finding convergent solutions. NMDS is usually run with a low number dimensions (k=2 or k=3), and for complex data increasing k by one may help. If you run NMDS with much higher number of dimensions (say, k=10 or more), you should reconsider what you are doing and drastically reduce k. For very heterogeneous data sets with partial disjunctions, it may help to set stepacross, but for most data sets the default weakties = TRUE is sufficient.

Please note that you can give all arguments of other metaMDS* functions and NMDS engine (default monoMDS) in your metaMDS command,and you should check documentation of these functions for details.

Common Wrong Claims

NMDS is often misunderstood and wrong claims of its properties are common on the Web and even in publications. It is often claimed that the NMDS configuration is non-metric which means that you cannot fit environmental variables or species onto that space. This is a false statement. In fact, the result configuration of NMDS is metric, and it can be used like any other ordination result. In NMDS the rank orders of Euclidean distances among points in ordination have a non-metric monotone relationship to any observed dissimilarities. The transfer function from observed dissimilarities to ordination distances is non-metric (Kruskal 1964a, 1964b), but the ordination result configuration is metric and observed dissimilarities can be of any kind (metric or non-metric).

The ordination configuration is usually rotated to principal components in metaMDS. The rotation is performed after finding the result, and it only changes the direction of the reference axes. The only invariant feature in the NMDS solution is the rank order of Euclidean ordination distances, and this does not change in rotation. Similarly, the rank order of distances does not change in uniform scaling or centring of configuration of points.

Function stressplot displays the method graphically: it plots the observed dissimilarities against distances in ordination space, and also shows the non-metric monotone regression.

Value

Function metaMDS returns an object of class metaMDS. The final site ordination is stored in the item points, and species ordination in the item species, and the stress in item stress (NB, the scaling of the stress depends on the engine: isoMDS uses percents, and monoMDS proportions in the range \(0 \ldots 1\)). The other items store the information on the steps taken and the items returned by the engine function. The object has print, plot, points and text methods. Functions metaMDSdist and metaMDSredist return vegdist objects. Function initMDS returns a random configuration which is intended to be used within isoMDS only. Functions metaMDSiter and postMDS returns the result of NMDS with updated configuration.

References

Faith, D. P, Minchin, P. R. and Belbin, L. (1987). Compositional dissimilarity as a robust measure of ecological distance. Vegetatio 69, 57--68.

Kruskal, J.B. (1964a). Multidimensional scaling by optimizing goodness-of-fit to a nonmetric hypothesis. Psychometrika 29, 1--28.

Kruskal, J.B. (1964b). Nonmetric multidimensional scaling: a numerical method. Psychometrika 29, 115--129.

Minchin, P.R. (1987). An evaluation of relative robustness of techniques for ecological ordinations. Vegetatio 69, 89--107.

Note

Function metaMDS is a simple wrapper for an NMDS engine (either monoMDS or isoMDS) and some support functions (metaMDSdist, stepacross, metaMDSiter, initMDS, postMDS, wascores). You can call these support functions separately for better control of results. Data transformation, dissimilarities and possible stepacross are made in function metaMDSdist which returns a dissimilarity result. Iterative search (with starting values from initMDS with monoMDS) is made in metaMDSiter. Processing of result configuration is done in postMDS, and species scores added by wascores. If you want to be more certain of reaching a global solution, you can compare results from several independent runs. You can also continue analysis from previous results or from your own configuration. Function may not save the used dissimilarity matrix (monoMDS does), but metaMDSredist tries to reconstruct the used dissimilarities with original data transformation and possible stepacross.

The metaMDS function was designed to be used with community data. If you have other type of data, you should probably set some arguments to non-default values: probably at least wascores, autotransform and noshare should be FALSE. If you have negative data entries, metaMDS will set the previous to FALSE with a warning.

Warning

metaMDS uses monoMDS as its NMDS engine from vegan version 2.0-0, when it replaced the isoMDS function. You can set argument engine to select the old engine.

See also

Examples

## The recommended way of running NMDS (Minchin 1987) ## data(dune) # Global NMDS using monoMDS sol <- metaMDS(dune)
#> Run 0 stress 0.1192678 #> Run 1 stress 0.1183186 #> ... New best solution #> ... Procrustes: rmse 0.02026285 max resid 0.0649233 #> Run 2 stress 0.119268 #> Run 3 stress 0.1900948 #> Run 4 stress 0.1183186 #> ... Procrustes: rmse 3.288415e-05 max resid 7.399109e-05 #> ... Similar to previous best #> Run 5 stress 0.1183186 #> ... Procrustes: rmse 5.857758e-05 max resid 0.0001866239 #> ... Similar to previous best #> Run 6 stress 0.1183186 #> ... New best solution #> ... Procrustes: rmse 0.0001201461 max resid 0.0003864476 #> ... Similar to previous best #> Run 7 stress 0.1183187 #> ... Procrustes: rmse 0.0001878157 max resid 0.000545781 #> ... Similar to previous best #> Run 8 stress 0.1192684 #> Run 9 stress 0.1192682 #> Run 10 stress 0.1809577 #> Run 11 stress 0.2069997 #> Run 12 stress 0.1192678 #> Run 13 stress 0.1183186 #> ... New best solution #> ... Procrustes: rmse 4.870482e-05 max resid 0.0001572191 #> ... Similar to previous best #> Run 14 stress 0.1183186 #> ... Procrustes: rmse 3.876641e-05 max resid 0.0001226919 #> ... Similar to previous best #> Run 15 stress 0.1183186 #> ... Procrustes: rmse 2.340273e-05 max resid 6.370759e-05 #> ... Similar to previous best #> Run 16 stress 0.1192678 #> Run 17 stress 0.119269 #> Run 18 stress 0.1192681 #> Run 19 stress 0.2035424 #> Run 20 stress 0.1192679 #> *** Solution reached
sol
#> #> Call: #> metaMDS(comm = dune) #> #> global Multidimensional Scaling using monoMDS #> #> Data: dune #> Distance: bray #> #> Dimensions: 2 #> Stress: 0.1183186 #> Stress type 1, weak ties #> Two convergent solutions found after 20 tries #> Scaling: centring, PC rotation, halfchange scaling #> Species: expanded scores based on ‘dune’ #>
plot(sol, type="t")
## Start from previous best solution sol <- metaMDS(dune, previous.best = sol)
#> Starting from 2-dimensional configuration #> Run 0 stress 0.1183186 #> Run 1 stress 0.188964 #> Run 2 stress 0.2034981 #> Run 3 stress 0.119268 #> Run 4 stress 0.1808911 #> Run 5 stress 0.2086845 #> Run 6 stress 0.1192685 #> Run 7 stress 0.1889654 #> Run 8 stress 0.1192678 #> Run 9 stress 0.2035424 #> Run 10 stress 0.1183186 #> ... Procrustes: rmse 3.651113e-05 max resid 0.0001292105 #> ... Similar to previous best #> Run 11 stress 0.1192678 #> Run 12 stress 0.1183186 #> ... Procrustes: rmse 0.000123018 max resid 0.0003426392 #> ... Similar to previous best #> Run 13 stress 0.1183186 #> ... Procrustes: rmse 7.257479e-06 max resid 2.233966e-05 #> ... Similar to previous best #> Run 14 stress 0.1192678 #> Run 15 stress 0.1192678 #> Run 16 stress 0.204213 #> Run 17 stress 0.1183186 #> ... Procrustes: rmse 5.84309e-05 max resid 0.0001821227 #> ... Similar to previous best #> Run 18 stress 0.1192678 #> Run 19 stress 0.1192679 #> Run 20 stress 0.1192683 #> *** Solution reached
## Local NMDS and stress 2 of monoMDS sol2 <- metaMDS(dune, model = "local", stress=2)
#> Run 0 stress 0.1928489 #> Run 1 stress 0.1928552 #> ... Procrustes: rmse 0.002023839 max resid 0.005834021 #> ... Similar to previous best #> Run 2 stress 0.1928587 #> ... Procrustes: rmse 0.002433556 max resid 0.006918491 #> ... Similar to previous best #> Run 3 stress 0.1928475 #> ... New best solution #> ... Procrustes: rmse 0.0004598212 max resid 0.00131996 #> ... Similar to previous best #> Run 4 stress 0.1928513 #> ... Procrustes: rmse 0.001057736 max resid 0.003041677 #> ... Similar to previous best #> Run 5 stress 0.1928503 #> ... Procrustes: rmse 0.0008821211 max resid 0.002551715 #> ... Similar to previous best #> Run 6 stress 0.1928496 #> ... Procrustes: rmse 0.0007569097 max resid 0.002191488 #> ... Similar to previous best #> Run 7 stress 0.1928484 #> ... Procrustes: rmse 0.0004957777 max resid 0.001433017 #> ... Similar to previous best #> Run 8 stress 0.1928475 #> ... New best solution #> ... Procrustes: rmse 7.18271e-05 max resid 0.0002241139 #> ... Similar to previous best #> Run 9 stress 0.1928525 #> ... Procrustes: rmse 0.001150305 max resid 0.003223645 #> ... Similar to previous best #> Run 10 stress 0.19285 #> ... Procrustes: rmse 0.000733306 max resid 0.002097207 #> ... Similar to previous best #> Run 11 stress 0.1928537 #> ... Procrustes: rmse 0.001354286 max resid 0.00380084 #> ... Similar to previous best #> Run 12 stress 0.1928475 #> ... Procrustes: rmse 0.0001217324 max resid 0.0003645841 #> ... Similar to previous best #> Run 13 stress 0.1928545 #> ... Procrustes: rmse 0.001438897 max resid 0.004031714 #> ... Similar to previous best #> Run 14 stress 0.1928545 #> ... Procrustes: rmse 0.001439891 max resid 0.004097307 #> ... Similar to previous best #> Run 15 stress 0.1928525 #> ... Procrustes: rmse 0.001171334 max resid 0.003280753 #> ... Similar to previous best #> Run 16 stress 0.1928476 #> ... Procrustes: rmse 0.0001680328 max resid 0.0004898915 #> ... Similar to previous best #> Run 17 stress 0.1928581 #> ... Procrustes: rmse 0.001821345 max resid 0.005157531 #> ... Similar to previous best #> Run 18 stress 0.1928487 #> ... Procrustes: rmse 0.0005026738 max resid 0.001451174 #> ... Similar to previous best #> Run 19 stress 0.1928535 #> ... Procrustes: rmse 0.001286957 max resid 0.003690688 #> ... Similar to previous best #> Run 20 stress 0.1928543 #> ... Procrustes: rmse 0.001416456 max resid 0.00396482 #> ... Similar to previous best #> *** Solution reached
sol2
#> #> Call: #> metaMDS(comm = dune, model = "local", stress = 2) #> #> local Multidimensional Scaling using monoMDS #> #> Data: dune #> Distance: bray #> #> Dimensions: 2 #> Stress: 0.1928475 #> Stress type 2, weak ties #> Two convergent solutions found after 20 tries #> Scaling: centring, PC rotation, halfchange scaling #> Species: expanded scores based on ‘dune’ #>
## Use Arrhenius exponent 'z' as a binary dissimilarity measure sol <- metaMDS(dune, distfun = betadiver, distance = "z")
#> Run 0 stress 0.1067169 #> Run 1 stress 0.18118 #> Run 2 stress 0.1073148 #> Run 3 stress 0.1073148 #> Run 4 stress 0.1067169 #> ... New best solution #> ... Procrustes: rmse 6.601443e-06 max resid 1.69716e-05 #> ... Similar to previous best #> Run 5 stress 0.1067169 #> ... Procrustes: rmse 2.581342e-06 max resid 5.921236e-06 #> ... Similar to previous best #> Run 6 stress 0.1067169 #> ... Procrustes: rmse 7.838933e-06 max resid 1.66233e-05 #> ... Similar to previous best #> Run 7 stress 0.107471 #> Run 8 stress 0.1067169 #> ... Procrustes: rmse 1.664908e-05 max resid 4.231844e-05 #> ... Similar to previous best #> Run 9 stress 0.1073149 #> Run 10 stress 0.1073148 #> Run 11 stress 0.1067169 #> ... Procrustes: rmse 3.672607e-06 max resid 9.771668e-06 #> ... Similar to previous best #> Run 12 stress 0.1808874 #> Run 13 stress 0.1069788 #> ... Procrustes: rmse 0.00685006 max resid 0.02420664 #> Run 14 stress 0.1067169 #> ... Procrustes: rmse 9.179744e-06 max resid 1.857877e-05 #> ... Similar to previous best #> Run 15 stress 0.1067169 #> ... Procrustes: rmse 2.106148e-05 max resid 5.46519e-05 #> ... Similar to previous best #> Run 16 stress 0.1815482 #> Run 17 stress 0.1067169 #> ... Procrustes: rmse 2.159491e-05 max resid 5.284808e-05 #> ... Similar to previous best #> Run 18 stress 0.171178 #> Run 19 stress 0.1067169 #> ... Procrustes: rmse 3.880136e-06 max resid 9.71969e-06 #> ... Similar to previous best #> Run 20 stress 0.1073148 #> *** Solution reached
sol
#> #> Call: #> metaMDS(comm = dune, distance = "z", distfun = betadiver) #> #> global Multidimensional Scaling using monoMDS #> #> Data: dune #> Distance: beta.z #> #> Dimensions: 2 #> Stress: 0.1067169 #> Stress type 1, weak ties #> Two convergent solutions found after 20 tries #> Scaling: centring, PC rotation, halfchange scaling #> Species: expanded scores based on ‘dune’ #>