如何在 python 中使没有簇质心的簇不可见?

How can i make invisible the clusters without cluster centroid in python?

我有一个包含 15 个簇的 kmeans 聚类对象。我重新排列了对象的 cluster_centers 并从该列表中删除了 5 个特定的聚类中心。现在我想可视化我的对象和聚类中心。但是我找不到让一些集群不可见的方法。

我最初的聚类数据是:

当我尝试使用新的簇质心可视化我的 kmeans 数据对象时,我得到了这个输出:

我想让上面没有“X”标记的簇不可见。我该怎么做?

我用这段代码绘制了上面的图:

plt.scatter(X_train[:,0], X_train[:,1],c=TrainData[1],cmap='gist_rainbow')
plt.scatter(new_centroids[:,0], new_centroids[:, 1],s = 150, c = 'black', label = 'Centroid', marker="x")
plt.show()

您可以构建一个过滤器来排除不需要的值。 您需要使用 np.array(TrainData[1]).

TrainData[1] 转换为 numpy 数组(如果尚未转换)

这是一个使用sklearns的例子KMeans:


import matplotlib.pyplot as plt
from sklearn.cluster import KMeans
import numpy as np

X_train = np.random.normal(size=(5000, 2))
kmeans_result = KMeans(n_clusters=15).fit(X_train)
new_centroids = kmeans_result.cluster_centers_
cluster_ids = kmeans_result.labels_
# cluster_ids = np.array(TrainData[1])

undesired1 = 3
undesired2 = 5
undesired3 = 7
filter = (cluster_ids != undesired1) & (cluster_ids != undesired2) & (cluster_ids != undesired3)
plt.scatter(X_train[filter, 0], X_train[filter, 1], c=cluster_ids[filter], cmap='gist_rainbow', alpha=0.4)
desired_centroid_ids = np.array([i for i in range(len(new_centroids)) if i not in [undesired1, undesired2, undesired3]])
plt.scatter(new_centroids[desired_centroid_ids, 0], new_centroids[desired_centroid_ids, 1], s=150, c='black',
            label='Centroid', marker="x")
plt.show()