pint.p {PHENIX} | R Documentation |
Phenotypic integration index (by Wagner) significance test
Description
Estimates p-values for the phenotypic integration index described by Wagner (1984). For that, it generates a null distribution based on product–moment correlations.
Usage
pint.p(traits,n.replicates=1000,N.Pearson=15,plot="Results",tails=1)
Arguments
traits |
a dataframe or a matrix object containing traits as columns and individuals as rows |
n.replicates |
a numeric, number of randomizations to estimate the null distribution (1000 by default) |
N.Pearson |
a numeric (>2) to shape the distribution probability to sample the correlation matrix. See Details. |
plot |
a string. Possible values are "Results" or "R" to display the simulated null distribution and the observed value as a histogram; and "Pearson.distribution" or "P" to check the distribution generated by the N.Pearson parameter to produce the correlation matrix. Any other value will produce no plot. |
tails |
possible values are 1 and 2 to set the test for one or two tails. By default is set to 1, because values of integration are expected to be higher in the real than in the simulated dataset. |
Details
This function generates a set of theoretical correlation matrices, with as many rows and columns as the number of variables contained in 'traits'. Values in this matrix are randomly drawn using a Pearson product moment correlation coefficient distribution (as implemented in the SuppDists package). The distribution is shaped by the N.Pearson value as follows:
N.Pearson = 3 increases frequency for extreme values (that is -1 and +1).
N.Pearson = 4 generates a uniform distribution (similar probability for all values).
N.Pearson > 5 increases frequency for central values (that is, 0).
The option plot="Pearson.distribution" or plot="P" displays the distribution used to generate the theoretical correlation matrices. This plot produces an histogram with 100,000 observations taken from the distribution shaped by the N.Pearson value.
Value
A list with the following elements:
Simulated.cor |
The simulated theoretical correlation matrices. |
Simulated.int |
The phenotypic integration indices estimated on the simulated matrices. |
Simulated.Range |
The range (minimum-maximum) of phenotypic integration indices estimated on the simulated matrices. |
Simulated.Mean |
The mean of phenotypic integration indices estimated on the simulated matrices. |
Real.int |
The phenotypic integration indices estimated on the real dataset. |
Summary |
A data frame containing the integration indices (as rows) for the real and simulated dataset and the p-value (as columns) |
Author(s)
A.J. Muñoz-Pajares, R. Torices
References
Harder, L.D. 2009. Questions about floral (dis)integration. New Phytologist 183:247–248.
Ordano, M., Fornoni, J., Boege, K. & Domínguez, C.A. 2008. The adaptive value of phenotypic floral integration. New Phytologist 179:1183–1192.
Wagner, G.P. 1984. On the eigenvalue distribution of genetic and phenotypic dispersion matrices: evidence for a non-random organization of quantitative character variation. Journal of Mathematical Biology 21:77–95.
See Also
Examples
data(tussilago)
# Using a uniform distribution to generate the correlation matrices:
## A) Showing uniform distribution
unif1<-pint.p(traits=tussilago,n.replicates=1000, N.Pearson=4,plot="P")
## B) Showing the resulting null distribution and the real value (red line)
unif2<-pint.p(traits=tussilago,n.replicates=1000, N.Pearson=4,plot="R")
dev.new()
# Using a non-uniform distribution to generate the correlation matrices:
## A) Showing the Pearson product moment correlation coefficient distribution
prmo1<-pint.p(traits=tussilago,n.replicates=1000, N.Pearson=15,plot="P")
## B) Showing the resulting null distribution and the real value (red line)
prmo2<-pint.p(traits=tussilago,n.replicates=1000, N.Pearson=15,plot="R")
# Comparing the uniform and the non-uniform distributions
# as in Harder New Phytologist (2009) 183: 247-248
vari<-2 #variable to plot (INT.c)
toplot1<-unif2$Simulated.int[vari,]
toplot2<-prmo2$Simulated.int[vari,]
HIST<-hist(as.matrix(toplot2),plot=FALSE)
MaxY<-max(HIST$density)
Max<-max(toplot1,toplot2)
Min<-min(HIST$mids)
plot(c(1,2),xlim=c((Min-0.05*Max),(Max+0.05*Max)),ylim=c(0,(MaxY+0.05*MaxY)),
type="n",ylab="Density",xlab="Maximum integration (percentage)")
hist(as.matrix(toplot1),add=TRUE,freq=FALSE,breaks=28)
hist(as.matrix(toplot2),add=TRUE,freq=FALSE,col="grey",breaks=8)
# And the real value as a red line:
abline(v=prmo1$Real[vari],lty=2, col="red")