sklearn:计算测试数据集上k-means的准确度得分

Mir*_*nda 5 python k-means scikit-learn

我正在对具有2个簇的30个样本的集合进行k-means聚类(我已经知道有两个类).我将我的数据分成训练和测试集,并尝试计算我的测试集上的准确度分数.但是有两个问题:首先我不知道我是否可以实际做到这一点(测试集的准确度得分)用于k-means聚类.第二:如果我被允许这样做,我的实现是写还是错.这是我尝试过的:

df_hist = pd.read_csv('video_data.csv')

y = df_hist['label'].values
del df_hist['label']
df_hist.to_csv('video_data1.csv')
X = df_hist.values.astype(np.float)

X_train, X_test,y_train,y_test =  cross_validation.train_test_split(X,y,test_size=0.20,random_state=70)
k_means = cluster.KMeans(n_clusters=2)
k_means.fit(X_train)
print(k_means.labels_[:])
print(y_train[:])

score = metrics.accuracy_score(y_test,k_means.predict(X_test))
print('Accuracy:{0:f}'.format(score))

k_means.predict(X_test)
print(k_means.labels_[:])
print(y_test[:])
Run Code Online (Sandbox Code Playgroud)

但是,当我打印K-装置,用于测试的一组标签(k_means.predict(X_test) 打印(k_means.labels_ [:]) )和y_test标签(打印(k_means.labels_ [:]) )在过去的三线,我得到的标签与我安装X-train时的标签相同,而不是为X-test生成的标签.知道我在这里做错了什么吗?我正在做什么来评估k-means的表现是否正确?谢谢!

lej*_*lot 15

在评估准确性方面.您应该记住k-means 不是分类工具,因此分析准确性不是一个好主意.你可以做到这一点,但这不是k-means的用途.它应该找到最大化群集间距离的数据分组,它不会使用您的标签进行训练.因此,像k-means这样的东西通常会用RandIndex和其他聚类指标来测试.为了最大化准确性,您应该适合实际的分类器,如kNN,逻辑回归,SVM等.

就代码本身而言,k_means.predict(X_test) 返回标签,它不会更新内部labels_字段,你应该这样做

print(k_means.predict(X_test))
Run Code Online (Sandbox Code Playgroud)

此外,在python中,您不必(也不应该)使用[:]打印数组,只需这样做

print(k_means.labels_)
print(y_test)
Run Code Online (Sandbox Code Playgroud)