Python聚类算法之基本K均值实例详解


Posted in Python onNovember 20, 2015

本文实例讲述了Python聚类算法之基本K均值运算技巧。分享给大家供大家参考,具体如下:

基本K均值 :选择 K 个初始质心,其中 K 是用户指定的参数,即所期望的簇的个数。每次循环中,每个点被指派到最近的质心,指派到同一个质心的点集构成一个。然后,根据指派到簇的点,更新每个簇的质心。重复指派和更新操作,直到质心不发生明显的变化。

# scoding=utf-8
import pylab as pl
points = [[int(eachpoint.split("#")[0]), int(eachpoint.split("#")[1])] for eachpoint in open("points","r")]
# 指定三个初始质心
currentCenter1 = [20,190]; currentCenter2 = [120,90]; currentCenter3 = [170,140]
pl.plot([currentCenter1[0]], [currentCenter1[1]],'ok')
pl.plot([currentCenter2[0]], [currentCenter2[1]],'ok')
pl.plot([currentCenter3[0]], [currentCenter3[1]],'ok')
# 记录每次迭代后每个簇的质心的更新轨迹
center1 = [currentCenter1]; center2 = [currentCenter2]; center3 = [currentCenter3]
# 三个簇
group1 = []; group2 = []; group3 = []
for runtime in range(50):
  group1 = []; group2 = []; group3 = []
  for eachpoint in points:
    # 计算每个点到三个质心的距离
    distance1 = pow(abs(eachpoint[0]-currentCenter1[0]),2) + pow(abs(eachpoint[1]-currentCenter1[1]),2)
    distance2 = pow(abs(eachpoint[0]-currentCenter2[0]),2) + pow(abs(eachpoint[1]-currentCenter2[1]),2)
    distance3 = pow(abs(eachpoint[0]-currentCenter3[0]),2) + pow(abs(eachpoint[1]-currentCenter3[1]),2)
    # 将该点指派到离它最近的质心所在的簇
    mindis = min(distance1,distance2,distance3)
    if(mindis == distance1):
      group1.append(eachpoint)
    elif(mindis == distance2):
      group2.append(eachpoint)
    else:
      group3.append(eachpoint)
  # 指派完所有的点后,更新每个簇的质心
  currentCenter1 = [sum([eachpoint[0] for eachpoint in group1])/len(group1),sum([eachpoint[1] for eachpoint in group1])/len(group1)]
  currentCenter2 = [sum([eachpoint[0] for eachpoint in group2])/len(group2),sum([eachpoint[1] for eachpoint in group2])/len(group2)]
  currentCenter3 = [sum([eachpoint[0] for eachpoint in group3])/len(group3),sum([eachpoint[1] for eachpoint in group3])/len(group3)]
  # 记录该次对质心的更新
  center1.append(currentCenter1)
  center2.append(currentCenter2)
  center3.append(currentCenter3)
# 打印所有的点,用颜色标识该点所属的簇
pl.plot([eachpoint[0] for eachpoint in group1], [eachpoint[1] for eachpoint in group1], 'or')
pl.plot([eachpoint[0] for eachpoint in group2], [eachpoint[1] for eachpoint in group2], 'oy')
pl.plot([eachpoint[0] for eachpoint in group3], [eachpoint[1] for eachpoint in group3], 'og')
# 打印每个簇的质心的更新轨迹
for center in [center1,center2,center3]:
  pl.plot([eachcenter[0] for eachcenter in center], [eachcenter[1] for eachcenter in center],'k')
pl.show()

运行效果截图如下:

Python聚类算法之基本K均值实例详解

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
Django框架中render_to_response()函数的使用方法
Jul 16 Python
浅谈Python数据类型之间的转换
Jun 08 Python
Python中标准库OS的常用方法总结大全
Jul 19 Python
Python+OpenCV人脸检测原理及示例详解
Oct 19 Python
Python中的TCP socket写法示例
May 11 Python
浅谈Python基础—判断和循环
Mar 22 Python
详解python-图像处理(映射变换)
Mar 22 Python
基于Python和PyYAML读取yaml配置文件数据
Jan 13 Python
Python基于Socket实现简单聊天室
Feb 17 Python
python读取yaml文件后修改写入本地实例
Apr 27 Python
OpenCV 之按位运算举例解析
Jun 19 Python
基于python实现简单C/S模式代码实例
Sep 14 Python
Python实现将xml导入至excel
Nov 20 #Python
使用PyCharm配合部署Python的Django框架的配置纪实
Nov 19 #Python
详解在Python程序中解析并修改XML内容的方法
Nov 16 #Python
Python通过DOM和SAX方式解析XML的应用实例分享
Nov 16 #Python
Python的Flask开发框架简单上手笔记
Nov 16 #Python
python实现mysql的单引号字符串过滤方法
Nov 14 #Python
浅析Python中signal包的使用
Nov 13 #Python
You might like
php实现可以设置中奖概率的抽奖程序代码分享
2014/01/19 PHP
smarty实现多级分类的方法
2014/12/05 PHP
php面向对象值单例模式
2016/05/03 PHP
php打乱数组二维数组多维数组的简单实例
2016/06/17 PHP
将CKfinder整合进CKEditor3.0的新方法
2010/01/10 Javascript
一些相见恨晚的 JavaScript 技巧
2010/04/25 Javascript
jquery一句话全选/取消全选
2011/03/01 Javascript
利用javascript打开模态对话框(示例代码)
2014/01/11 Javascript
JavaScript按值删除数组元素的方法
2015/04/24 Javascript
jQuery实现鼠标悬停显示提示信息窗口的方法
2015/04/30 Javascript
thinkjs之页面跳转同步异步操作
2017/02/05 Javascript
Vue下路由History模式打包后页面空白的解决方法
2018/06/29 Javascript
关于单文件组件.vue的使用
2018/09/20 Javascript
微信小程序实现时间预约功能
2018/11/27 Javascript
nodejs搭建本地服务器并访问文件操作示例
2019/05/11 NodeJs
如何提升vue.js中大型数据的性能
2019/06/21 Javascript
浅析Vue中拆分视图层代码的5点建议
2019/08/15 Javascript
python简单实现旋转图片的方法
2015/05/30 Python
Python判断值是否在list或set中的性能对比分析
2016/04/16 Python
Collatz 序列、逗号代码、字符图网格实例
2017/06/22 Python
读取本地json文件,解析json(实例讲解)
2017/12/06 Python
Python如何生成树形图案
2018/01/03 Python
对Python中创建进程的两种方式以及进程池详解
2019/01/14 Python
面向对象学习之pygame坦克大战
2019/09/11 Python
python3正则模块re的使用方法详解
2020/02/11 Python
TensorFlow获取加载模型中的全部张量名称代码
2020/02/11 Python
pytorch 实现在一个优化器中设置多个网络参数的例子
2020/02/20 Python
Python实现企业微信机器人每天定时发消息实例
2020/02/25 Python
为什么说python更适合树莓派编程
2020/07/20 Python
澳大利亚最受欢迎的美发和美容在线商店:Catwalk
2018/12/12 全球购物
学校安全工作制度
2014/01/19 职场文书
网上卖盒饭创业计划书
2014/01/26 职场文书
《小熊住山洞》教学反思
2014/02/21 职场文书
会计学习心得体会
2014/09/09 职场文书
2016年暑期社会实践活动总结报告
2016/04/06 职场文书
Python 视频画质增强
2022/04/28 Python