point 如何求elbow_如何选择kmeans中的k值——肘部法则–Elbow Method和轮廓系数–Silhouette Coefficient...

肘部法则–Elbow Method

我们知道k-means是以最小化样本与质点平方误差作为目标函数,将每个簇的质点与簇内样本点的平方距离误差和称为畸变程度(distortions),那么,对于一个簇,它的畸变程度越低,代表簇内成员越紧密,畸变程度越高,代表簇内结构越松散。 畸变程度会随着类别的增加而降低,但对于有一定区分度的数据,在达到某个临界点时畸变程度会得到极大改善,之后缓慢下降,这个临界点就可以考虑为聚类性能较好的点。

importpandas as pdfrom sklearn.cluster importKMeansimportmatplotlib.pyplot as plt

df_features= pd.read_csv(r'11111111.csv',encoding='gbk') #读入数据#print(df_features)

'利用SSE选择k'SSE= [] #存放每次结果的误差平方和

for k in range(1,9):

estimator= KMeans(n_clusters=k) #构造聚类器

estimator.fit(df_features[['0','1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16','17','18','19','20','21','22','23','24','25','26','27','28','29','30','31','32']])

SSE.append(estimator.inertia_)#estimator.inertia_获取聚类准则的总和

X = range(1,9)

plt.xlabel('k')

plt.ylabel('SSE')

plt.plot(X,SSE,'o-')

plt.show()

如上图所示,在k=xxxxxx时,畸变程度(y值)得到大幅改善,可以考虑选取k=xxxxx作为聚类数量 显然,肘部对于的k值为xxxxxx(曲率最高),故对于这个数据集的聚类而言,最佳聚类数应该选xxxxxxxx。

轮廓系数–Silhouette Coefficient

对于一个聚类任务,我们希望得到的簇中,簇内尽量紧密,簇间尽量远离,轮廓系数便是类的密集与分散程度的评价指标,公式表达如下: s=b−amax(a,b)s=b−amax(a,b) 其中a代表同簇样本到彼此间距离的均值,b代表样本到除自身所在簇外的最近簇的样本的均值,s取值在[-1, 1]之间。 如果s接近1,代表样本所在簇合理,若s接近-1代表s更应该分到其他簇中。

判断: 轮廓系数范围在[-1,1]之间。该值越大,越合理。 si接近1,则说明样本i聚类合理; si接近-1,则说明样本i更应该分类到另外的簇; 若si 近似为0,则说明样本i在两个簇的边界上。 所有样本的s i 的均值称为聚类结果的轮廓系数,是该聚类是否合理、有效的度量。 使用轮廓系数(silhouette coefficient)来确定,选择使系数较大所对应的k值

sklearn.metrics.silhouette_score sklearn中有对应的求轮廓系数的API

importnumpy as npfrom sklearn.cluster importKMeansfrom pylab import *

importcodecsimportmatplotlib.pyplot as pltfrom sklearn.metrics importcalinski_harabaz_scoreimportpandas as pdfrom numpy.random importrandomfrom sklearn importpreprocessingfrom sklearn importmetricsimportoperator

data=[]

labels=[]

number1=10with codecs.open("red_nopca_nolabel.txt", "r") as f:for line inf.readlines():

line1=line.strip()

line2= line1.split(',')

x2=[]for i inrange(0,number1):

x1=line2[i]

x2.append(float(x1))

data.append(x2)

x2=[]#label = line2[number1-1]

#labels.append(float(label))

datas =np.array(data)'''kmeans_model = KMeans(n_clusters=3, random_state=1).fit(datas)

labels = kmeans_model.labels_

a = metrics.silhouette_score(datas, labels, metric='euclidean')

print(a)'''silhouette_all=[]for k in range(2,25):

kmeans_model= KMeans(n_clusters=k, random_state=1).fit(datas)

labels=kmeans_model.labels_

a= metrics.silhouette_score(datas, labels, metric='euclidean')

silhouette_all.append(a)#print(a)

print('这个是k={}次时的轮廓系数:'.format(k),a)

dic={} #存放所有的互信息的键值对

mi_num=2

for i insilhouette_all:

dic['k={}时轮廓系数'.format(mi_num)]='{}'.format(i)

mi_num=mi_num+1

#print(dic)

rankdata=sorted(dic.items(),key=operator.itemgetter(1),reverse=True)print(rankdata)

实验结果部分插图

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值