博客
关于我
【sklearn】KMeans 计算样本质心
阅读量:339 次
发布时间:2019-03-04

本文共 1269 字,大约阅读时间需要 4 分钟。

文章目录


KMeans质心介绍

一个簇中所有数据的均值μ(j),通常被称为这个簇的“质心(centroids)”,j表示第j个簇。在二维平面中,质心的坐标是该簇数据点坐标均值的合成。同理可推广至高维空间。

m一个簇中样本的个数,j每个样本的编号。这个公式被称为簇内平方和(cluster Sum of Square),又叫做 Inertia。将所有簇的簇内平方和相加得到Total InertiaTotal Inertia越小,数据聚类效果越好。

KMeans追求的是使Inertia最小化的质心。质心不断迭代更新时,Total Inertia逐渐减小。当Total Inertia达到最小值时,质心不再改变。这就将KMeans的求解过程转化为一个优化问题。


计算质心

质心的计算方法是对每个簇的数据点坐标分别求均值。例如,在二维平面中,质心的横坐标是该簇数据点横坐标的均值,纵坐标是纵坐标的均值。

def cal_Cmass(data):  
'''输入:数据样本 ndarray
输出:质心坐标 ndarray
'''
return np.mean(data, axis=0)

例如,计算质心:

cmass = cal_Cmass([[8,8,8], [7,7,7], [9,9,9]])  
# 返回值: [8. 8. 8.]

计算样本间距离

import numpy as np  
def distance(x, y, p=2):
'''输入:x(ndarray) - 第一个样本坐标
y(ndarray) - 第二个样本坐标
p(int):1为曼哈顿距离,2为欧氏距离
输出:距离 float
'''
dis2 = np.sum(np.abs(x - y) ** p)
dis = np.power(dis2, 1/p)
return dis

计算两点间距离的方法如下:


计算每个样本到质心的距离并排序

def sorted_list(data, Cmass):  
'''输入:data(ndarray) - 数据样本
Cmass(ndarray) - 数据样本质心
输出:距离列表 sorted_list(list) - 排序后的样本到质心的距离
'''
dis_list = []
for i in range(len(data)):
dis_list.append(distance(Cmass, data[i][:]))
dis_list = sorted(dis_list)
return dis_list

例如,计算各样本到质心的距离并排序:

list = sorted_list([[8,8,8],[7,7,7],[9,9,9]], cmass)  
# 返回值: [0.0, 1.7320508075688772, 1.7320508075688772]

转载地址:http://oueq.baihongyu.com/

你可能感兴趣的文章
npm ERR! fatal: unable to connect to github.com:
查看>>
npm ERR! Unexpected end of JSON input while parsing near '...on":"0.10.3","direc to'
查看>>
npm ERR! Unexpected end of JSON input while parsing near ‘...“:“^1.2.0“,“vue-html-‘ npm ERR! A comp
查看>>
npm error Missing script: “server“npm errornpm error Did you mean this?npm error npm run serve
查看>>
npm error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”。要解决此问题,1) 安装
查看>>
npm install CERT_HAS_EXPIRED解决方法
查看>>
npm install digital envelope routines::unsupported解决方法
查看>>
npm install 卡着不动的解决方法
查看>>
npm install 报错 EEXIST File exists 的解决方法
查看>>
npm install 报错 ERR_SOCKET_TIMEOUT 的解决方法
查看>>
npm install 报错 Failed to connect to github.com port 443 的解决方法
查看>>
npm install 报错 fatal: unable to connect to github.com 的解决方法
查看>>
npm install 报错 no such file or directory 的解决方法
查看>>
npm install 权限问题
查看>>
npm install报错,证书验证失败unable to get local issuer certificate
查看>>
npm install无法生成node_modules的解决方法
查看>>
npm install的--save和--save-dev使用说明
查看>>
npm node pm2相关问题
查看>>
npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
查看>>
npm run build报Cannot find module错误的解决方法
查看>>