crossdpcoa | R Documentation |
Crossed-DPCoA typically analyzes the phylogenetic or functional compositions of communities according to two factors affecting the communities (e.g. space and time; habitat and region)
The function crossdpcoa_maineffect
obtains the space of DPCoA (the double principal coordinate analysis) where species are placed according to their functional traits or phylogeny and communities are placed at the center of their species. Next, levels of each factor are placed at the center of their communities. The function crossdpcoa_maineffect
determines the principal axes of the positions of the levels of one of the factors in this space and projects species' points on
these principal axes. The main effect of the factor named facA
is analysed by this process (Pavoine et al. 2013).
The function crossdpcoa_version1
performs version 1 of the crossed DPCoA in Pavoine et al. (2013) where the effect of factor facA
on the diversity of communities, given factor facB
, is analysed.
The function crossdpcoa_version2
performs version 2 of the crossed DPCoA in Pavoine et al. (2013) where the effect of factor facA
on the diversity of communities, given factor facB
, is also analysed.
crossdpcoa_maineffect(df, facA, facB, dis = NULL,
scannf = TRUE, nf = 2, w = c("classic", "independence"),
tol = 1e-07)
crossdpcoa_version1(df, facA, facB, dis = NULL,
scannf = TRUE, nf = 2, w = c("classic", "independence"),
tol = 1e-07)
crossdpcoa_version2(df, facA, facB, dis = NULL,
scannf = TRUE, nf = 2, w = c("classic", "independence"),
tol = 1e-07)
df |
a data frame or a matrix of 0/1 or nonnegative values. As an exemple, I consider below a communities x species data frame or matrix with abundances as entries. |
facA |
a factor with the same length as the number of rows (communities) in df. |
facB |
another factor with the same length as the number of rows (communities) in df. |
dis |
an object of class |
scannf |
a logical value indicating whether the screeplot (with eigenvalues) should be displayed. |
nf |
if |
w |
either a string or a numeric vector of positive values that indicates how the rows of |
tol |
a numeric tolerance threshold: a value between - |
The functions crossdpcoa_maineffect
, crossdpcoa_version1
and crossdpcoa_version2
return a list containing the following information used for computing the crossed-DPCoA:
l1 |
coordinates of the columns of |
l2 |
coordinates of the levels of factor A. |
l3 |
(for functions |
eig |
the eigenvalues. |
lX |
the weights attributed to the columns of |
lA |
the weights attributed to the levels of factor A. |
lB |
the weights attributed to the levels of factor B. |
lC |
the weights attributed to the rows of |
div |
a numeric vector with the apportionment of Rao's quadratic diversity (APQE). |
call |
the |
Sandrine Pavoine sandrine.pavoine@mnhn.fr
Pavoine, S., Blondel, J., Dufour, A.-B., Gasc, A., Bonsall, M.B. (2013) A new technique for analysing interacting factors affecting biodiversity patterns: crossed-DPCoA. PloS One, 8, e54530.
## Not run:
if(require(ape) && require(phylobase) && require(adephylo)
&& require(adegraphics)){
O <- adegpar()$plabels$optim
adegpar("plabels.optim" = TRUE)
data(birdData)
phy <- read.tree(text=birdData$tre)
phydis <- sqrt(distTips(phy, method="nNodes")+1)
fau <- birdData$fau[, phy$tip.label]
facA <- birdData$facA
facB <- birdData$facB
#Here factor B is put first to analyze
#the main effect of the strata:
cd_mainB <- crossdpcoa_maineffect(fau, facB, facA, phydis, w=rep(1/30, 30), scannf = FALSE)
barplot(cd_mainB$eig)
cd_mainB$eig[1:2]/sum(cd_mainB$eig)
#Positions of the levels of factor B on its principal axes:
s.label(cd_mainB$l2)
# The "d" value on graphs indicates the length of the edge of a grid cell (scale of the graphic).
#The coordinates of the species on the same axes
# can be displayed in front of the phylogeny
# (several possibilities are provided below,
# the last one use package adephylo)):
mainBl1.4d <- phylo4d(phy, as.matrix(cd_mainB$l1))
dotp4d(mainBl1.4d, center = FALSE, scale = FALSE)
barp4d(mainBl1.4d, center = FALSE, scale = FALSE)
gridp4d(mainBl1.4d, center = FALSE, scale = FALSE)
parmar <- par()$mar
par(mar=rep(.1,4))
table.phylo4d(mainBl1.4d, show.node=FALSE, symbol="squares",
center=FALSE, scale=FALSE, cex.label=0.5, ratio.tree=0.7)
par(mar=parmar)
#If factor A is put first, the analysis focus
#on the main effect of the region:
cd_mainA <- crossdpcoa_maineffect(fau, facA, facB, phydis, w=rep(1/30, 30), scannf = FALSE)
barplot(cd_mainA$eig)
cd_mainA$eig[1:2]/sum(cd_mainA$eig)
#Positions of the levels of factor A on its principal axes:
s.label(cd_mainA$l2)
# The "d" value on graphs indicates the length of the edge of a grid cell (scale of the graphic).
#The coordinates of the species on the same axes
# can be displayed in front of the phylogeny
# (several possibilities are provided below,
# the last one use package adephylo)):
mainAl1.4d <- phylo4d(phy, as.matrix(cd_mainA$l1))
dotp4d(mainAl1.4d, center = FALSE, scale = FALSE)
barp4d(mainAl1.4d, center = FALSE, scale = FALSE)
gridp4d(mainAl1.4d, center = FALSE, scale = FALSE)
parmar <- par()$mar
par(mar=rep(.1,4))
table.phylo4d(mainAl1.4d, show.node=FALSE, symbol="squares",
center=FALSE, scale=FALSE, cex.label=0.5, ratio.tree=0.7)
par(mar=parmar)
#Crossed DPCoA Version 1
cd_v1 <- crossdpcoa_version1(fau, facA, facB, phydis, w=rep(1/30, 30), scannf = FALSE)
#Proportion of SS(A) expressed by the two first axes:
cd_v1$eig[1:2]/sum(cd_v1$eig)
#To view the positions of the locations on the first two axes, write:
s.label(cd_v1$l2)
#To view the positions of all communities on the first two axes, write:
s.label(cd_v1$l3)
#To view the positions of the species on the first two axes in front of the phylogeny, write:
v1l1.4d <- phylo4d(phy, as.matrix(cd_v1$l1))
# (then several functions can be used as shown below,
# the last function, table.phylo4d, is from package adephylo)):
dotp4d(v1l1.4d, center = FALSE, scale = FALSE)
barp4d(v1l1.4d, center = FALSE, scale = FALSE)
gridp4d(v1l1.4d, center = FALSE, scale = FALSE)
parmar <- par()$mar
par(mar=rep(.1,4))
table.phylo4d(v1l1.4d, show.node=FALSE, symbol="squares",
center=FALSE, scale=FALSE, cex.label=0.5, ratio.tree=0.7)
par(mar=parmar)
#Crossed DPCoA Version 2
#Crossed DPCoA version 2 can now be performed as follows:
cd_v2 <- crossdpcoa_version2(fau, facA, facB, phydis, w=rep(1/30, 30), scannf = FALSE)
#Proportion of variation among levels of factor A
#in the subspace orthogonal to the principal axes of B
#expressed by the two first axes:
cd_v2$eig[1:2]/sum(cd_v2$eig)
#To view the positions of the locations on the first two axes, write:
s.label(cd_v2$l2)
#To view the positions of all communities on the first two axes, write:
s.label(cd_v2$l3)
#To view the positions of the species on the first two axes in front of the phylogeny, write:
v2l1.4d <- phylo4d(phy, as.matrix(cd_v2$l1))
# (then several functions can be used as shown below,
# the last function, table.phylo4d, is from package adephylo)):
dotp4d(v2l1.4d, center = FALSE, scale = FALSE)
barp4d(v2l1.4d, center = FALSE, scale = FALSE)
gridp4d(v2l1.4d, center = FALSE, scale = FALSE)
parmar <- par()$mar
par(mar=rep(.1,4))
table.phylo4d(v2l1.4d, show.node=FALSE, symbol="squares",
center=FALSE, scale=FALSE, cex.label=0.5, ratio.tree=0.7)
par(mar=parmar)
adegpar("plabels.optim" = O)
}
## End(Not run)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.