My R program looks like this:
hcluster <- function(dmatrix) { imatrix <- NULL hc <- hclust(dist(dmatrix), method="average") for(h in sort(unique(hc$height))) { hc.index <- c(h,as.vector(cutree(hc,h=h))) imatrix <- cbind(imatrix, hc.index) } return(imatrix) } dmatrix_file = commandArgs(trailingOnly = TRUE)[1] print(paste('Reading distance matrix from', dmatrix_file)) dmatrix <- as.matrix(read.csv(dmatrix_file,header=FALSE)) imatrix <- hcluster(dmatrix) imatrix_file = paste("results",dmatrix_file,sep="-") print(paste('Wrinting results to', imatrix_file)) write.table(imatrix, file=imatrix_file, sep=",", quote=FALSE, row.names=FALSE, col.names=FALSE) print('done!')
My input is a distance matrix (of course, symmetric). When I execute on a program with a distance matrix more than about a thousand records (nothing happens in a few hundred), this gave me an error message:
Error in cutree(hc, h = h) : the 'height' component of 'tree' is not sorted (increasingly); consider applying as.hclust() first Calls: hcluster -> as.vector -> cutree Execution halted
My machine has about 16 GB of RAM and 4CPU, so this is not a resource problem.
Can someone please let me know what the problem is? Thanks!!
Kevin source share