在Python中使用KMedoids聚类提取带有数据点的质心?

2024-04-25 07:47:17 发布

您现在位置:Python中文网/ 问答频道 /正文

我在1D数组X中有一些数据,其中包含10个元素。我在这个数据上应用了KMedoids聚类,其中3个作为多个聚类。应用KMedoids之后,我得到了每个集群的集群标签(id)和质心

from sklearn.metrics import silhouette_samples
from sklearn_extra.cluster import KMedoids
import pandas as pd
import numpy as np

X = np.array([0.85142858, 0.85566274, 0.85364912, 0.81536489, 0.84929932, 
              0.85042336, 0.84899714, 0.82019115, 0.86112067, 0.8312496 ])
X = X.reshape(-1, 1)

model1 = KMedoids(n_clusters=3, random_state=0).fit(X)
cluster_labels = model1.predict(X)  
clusters, counts = np.unique(cluster_labels[cluster_labels>=0], 
                             return_counts=True)
centroids = np.array(model1.cluster_centers_)

print("For centroids", centroids) 
print("***************")
for i in range(len(X)):
    print(i, X[i])

此代码的结果如下所示

For centroids [[0.85566274]
     [0.85042336]
     [0.82019115]]
    ***************
    0 [0.85142858]
    1 [0.85566274]
    2 [0.85364912]
    3 [0.81536489]
    4 [0.84929932]
    5 [0.85042336]
    6 [0.84899714]
    7 [0.82019115]
    8 [0.86112067]
    9 [0.8312496]

但是,我想用它的数据点显示质心。例如

For centroids [[0.85566274] , 1 [0.85566274]
For centroids [0.85042336]  , 5 [0.85042336]
For centroids [0.82019115]] , 7 [0.82019115]

我怎样才能做到这一点


Tags: 数据fromimportforlabelsnp集群聚类
1条回答
网友
1楼 · 发布于 2024-04-25 07:47:17

可以将带有标签、MEDOID和索引的表打印为以下列:

import numpy as np
from sklearn_extra.cluster import KMedoids

X = np.array([[0.85142858],
              [0.85566274],
              [0.85364912],
              [0.81536489],
              [0.84929932],
              [0.85042336],
              [0.84899714],
              [0.82019115],
              [0.86112067],
              [0.8312496 ]])

kmedoids = KMedoids(n_clusters=3, random_state=0).fit(X)

print('Label   Medoid        Index')
print('             -')
for index in kmedoids.medoid_indices_:
    label = kmedoids.labels_[index]
    medoid = X[index]
    print(f'{label:<7} {medoid}  {index}')

输出

Label   Medoid        Index
             -
0       [0.85566274]  1
1       [0.85042336]  5
2       [0.82019115]  7

或者,您可以根据自己的请求将结果存储在数据框中:

import pandas as pd

df = pd.DataFrame({'label': kmedoids.labels_[kmedoids.medoid_indices_],
                   'medoid': np.squeeze(X[kmedoids.medoid_indices_]),
                   'index': kmedoids.medoid_indices_})
print(df)

输出

   label    medoid  index
0      0  0.855663      1
1      1  0.850423      5
2      2  0.820191      7

相关问题 更多 >