#' @export
met.corr <-
function(object,site,faN=1,kn=NULL,plot=TRUE){ # ,faRS=1
#require(amap)
#require(corrgram)
if(is.null(kn)) kn=3
n<-nlevels(site)
varcomp<-summary(object)$varcomp['component']
vcn<-row.names(varcomp)
aimn<-vcn[grep('fa\\(.*,.*\\)',vcn)]
varcomp1<-varcomp[aimn,]
#vect1<-summary(object)$varcomp$component[faRS:(n+faRS-1)]
vect1<-varcomp1[1:n]
w.var<-diag(vect1)
#vect2<-summary(object)$varcomp$component[(n+faRS):((1+faN)*n+faRS-1)]
vect2<-varcomp1[(n+1):((1+faN)*n)]
L.var<-matrix(vect2,nrow=n)
wL.var<-L.var%*%t(L.var)+w.var
df<-wL.var
for(i in 1:(n-1)){
for(j in 2:n){
if(i<j){df[i,j]<-df[j,i]/(sqrt(df[i,i]*df[j,j]))
j<-j+1}
}
i<-i+1
}
rownames(df)<-c(paste("S",levels(site),sep='')) # might be some problem
colnames(df)<-c(paste("S",levels(site),sep=''))
df.2<-df
for(i in 1:(n-1)){
for(j in 2:n){
if(i<j){df[j,i]<-df[i,j]
j<-j+1}
}
i<-i+1
}
diag(df)<-1
if(plot==TRUE){
chcluster <- amap::hclusterpar(na.omit(df), method="manhattan")
#windows(10,8)
plot(chcluster, main="Fig.1 Cluster of different sites",hang=-1) # labels=F
rect.hclust(chcluster, k=kn)
cat("Site cluster results:\n")
print(tree.id<-cutree(chcluster,k=kn))
#if(n<16){
# windows(10,8)
# corrgram::corrgram(df, type="cor",order=T, lower.panel=panel.pie,
# upper.panel=panel.conf, text.panel=panel.txt,
# main="Fig.2 Correlogram of different sites")
#}
}
cat("\nCov\\Var\\Corr matrix\n\n")
#rownames(df.2)<-c(paste("S",levels(site),sep=''))
#colnames(df.2)<-c(paste("S",levels(site),sep=''))
print(round(df.2,3))
cat("\n")
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.