使用 R 和凝聚层次聚类 (AHC) 技术以及完整 link 方法绘制树状图

Drawing Dendogram using R with Agglomerative hierarchical clustering (AHC) techniques with Complete link method

我已经使用完整的 link 方法计算了距离矩阵,如下图所示:

簇之间的成对距离是

{0.5,1.12,1.5,3.61}

但是在 R 中使用以下代码实现相同的矩阵时:

矩阵

x1,x2,x3,x4,x5
0,0.5,2.24,3.35,3
0.5,0,2.5,3.61,3.04
2.24,2.5,0,1.12,1.41
3.35,3.61,1.12,0,1.5
3,3.04,1.41,1.5,0

实施:

library(cluster)
dt<-read.csv("cluster.csv")
df<-scale(dt[-1])
dc<-dist(df,method = "euclidean")
hc1 <- hclust(dc, method = "complete" )
plot(hc1, labels = c("x1", "x2","x3","x4","x5"), 
     hang = 0.1, 
     main = "Cluster dendrogram", sub = NULL,
     xlab = NULL, ylab = "Height")
abline(h = hc1$height, lty = 2, col = "lightgrey")
str(hc1)

str(hc1)

List of 7
 $ merge      : int [1:4, 1:2] -1 -3 -5 1 -2 -4 2 3
 $ height     : num [1:4] 0.444 1.516 1.851 3.753
 $ order      : int [1:5] 1 2 5 3 4
 $ labels     : NULL
 $ method     : chr "complete"
 $ call       : language hclust(d = dc, method = "complete")
 $ dist.method: chr "euclidean"
 - attr(*, "class")= chr "hclust"

我得到的身高是:0.444 1.516 1.851 3.753

这意味着树状图在两种情况下都会不同,为什么两种情况下都不同?可能是我在这两种方式的实施上都做错了什么?

由于提供的矩阵是欧氏距离矩阵,所以我不需要计算距离矩阵:我应该将 data.frame 转换为 dist.matrixas.dist(m).

下面的代码会给出从纸上计算得到的准确结果:

library(reshape)
dt<-read.csv("C:/Users/Aakash/Desktop/cluster.csv")
m <- as.matrix(dt)
hc1 <- hclust(as.dist(m), method = "complete" )
plot(hc1, labels = c("x1", "x2","x3","x4","x5"), 
     hang = 0.1, 
     main = "Complete Method Dendogram", sub = NULL,
     xlab = "Items", ylab = "Height")
abline(h = hc1$height, lty = 2, col = "lightgrey")
str(hc1)

height : num [1:4] 0.5 1.12 1.5 3.61

获得树状图: