本文实例讲述了Python基于聚类算法实现密度聚类(DBSCAN)计算。分享给大家供大家参考,具体如下:

算法思想

基于密度的聚类算法从样本密度的角度考察样本之间的可连接性,并基于可连接样本不断扩展聚类簇得到最终结果。

几个必要概念:

ε-邻域:对于样本集中的xj, 它的ε-邻域为样本集中与它距离小于ε的样本所构成的集合。

核心对象:若xj的ε-邻域中至少包含MinPts个样本,则xj为一个核心对象。

密度直达:若xj位于xi的ε-邻域中,且xi为核心对象,则xj由xi密度直达。

密度可达:若样本序列p1, p2, ……, pn。pi+1由pi密度直达,则p1由pn密度可达。

大致思想如下:

1. 初始化核心对象集合T为空,遍历一遍样本集D中所有的样本,计算每个样本点的ε-邻域中包含样本的个数,如果个数大于等于MinPts,则将该样本点加入到核心对象集合中。初始化聚类簇数k = 0, 初始化未访问样本集和为P = D。

2. 当T集合中存在样本时执行如下步骤:

2.1记录当前未访问集合P_old = P

2.2从T中随机选一个核心对象o,初始化一个队列Q = [o]

2.3P = P-o(从T中删除o)

2.4当Q中存在样本时执行:

2.4.1取出队列中的首个样本q

2.4.2计算q的ε-邻域中包含样本的个数,如果大于等于MinPts,则令S为q的ε-邻域与P的交集,

Q = Q+S, P = P-S

2.5 k = k + 1,生成聚类簇为Ck = P_old - P

2.6 T = T - Ck

3. 划分为C= {C1, C2, ……, Ck}

Python代码实现

#-*- coding:utf-8 -*-

import math

import numpy as np

import pylab as pl

#数据集:每三个是一组分别是西瓜的编号,密度,含糖量

data = """

1,0.697,0.46,2,0.774,0.376,3,0.634,0.264,4,0.608,0.318,5,0.556,0.215,

6,0.403,0.237,7,0.481,0.149,8,0.437,0.211,9,0.666,0.091,10,0.243,0.267,

11,0.245,0.057,12,0.343,0.099,13,0.639,0.161,14,0.657,0.198,15,0.36,0.37,

16,0.593,0.042,17,0.719,0.103,18,0.359,0.188,19,0.339,0.241,20,0.282,0.257,

21,0.748,0.232,22,0.714,0.346,23,0.483,0.312,24,0.478,0.437,25,0.525,0.369,

26,0.751,0.489,27,0.532,0.472,28,0.473,0.376,29,0.725,0.445,30,0.446,0.459"""

#数据处理 dataset是30个样本(密度,含糖量)的列表

a = data.split(',')

dataset = [(float(a[i]), float(a[i+1])) for i in range(1, len(a)-1, 3)]

#计算欧几里得距离,a,b分别为两个元组

def dist(a, b):

return math.sqrt(math.pow(a[0]-b[0], 2)+math.pow(a[1]-b[1], 2))

#算法模型

def DBSCAN(D, e, Minpts):

#初始化核心对象集合T,聚类个数k,聚类集合C, 未访问集合P,

T = set(); k = 0; C = []; P = set(D)

for d in D:

if len([ i for i in D if dist(d, i) <= e]) >= Minpts:

T.add(d)

#开始聚类

while len(T):

P_old = P

o = list(T)[np.random.randint(0, len(T))]

P = P - set(o)

Q = []; Q.append(o)

while len(Q):

q = Q[0]

Nq = [i for i in D if dist(q, i) <= e]

if len(Nq) >= Minpts:

S = P & set(Nq)

Q += (list(S))

P = P - S

Q.remove(q)

k += 1

Ck = list(P_old - P)

T = T - set(Ck)

C.append(Ck)

return C

#画图

def draw(C):

colValue = ['r', 'y', 'g', 'b', 'c', 'k', 'm']

for i in range(len(C)):

coo_X = [] #x坐标列表

coo_Y = [] #y坐标列表

for j in range(len(C[i])):

coo_X.append(C[i][j][0])

coo_Y.append(C[i][j][1])

pl.scatter(coo_X, coo_Y, marker='x', color=colValue[i%len(colValue)], label=i)

pl.legend(loc='upper right')

pl.show()

C = DBSCAN(dataset, 0.11, 5)

draw(C)

本机测试运行结果图:

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

python 密度聚类_Python基于聚类算法实现密度聚类(DBSCAN)计算【测试可用】相关推荐

  1. 【数据聚类】基于蝙蝠算法实现数据聚类附matlab代码

    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信.

  2. [Python]profile优化实践(基于A*算法)

    本文由恋花蝶发表于http://blog.csdn.net/lanphaday 欢迎转载,但敬请保留全文完整,并包含本声明. [Python]profile优化实践(基于A*算法) 在<用pro ...

  3. [Python]profile优化实践(基于A*算法) 1

    本文由恋花蝶发表于http://blog.csdn.net/lanphaday 欢迎转载,但敬请保留全文完整,并包含本声明. [Python]profile优化实践(基于A*算法) 在<用pro ...

  4. Python数据分析之双色球基于线性回归算法预测

    @本文来源于公众号:csdn2299,喜欢可以关注公众号 程序员学府 本文实例讲述了Python数据分析之双色球基于线性回归算法预测下期中奖结果.分享给大家供大家参考,具体如下: 前面讲述了关于双色球 ...

  5. python谱聚类算法_Python机器学习高级算法!谱聚类(Spectal Clustering)算法分析和实例详解...

    谱聚类(Spectal Clustering)算法是聚类算法的一种,比起传统的K-Means聚类算法,谱聚类算法的效果更优秀,其计算量也小很多,除了谱聚类和K-Means聚类算法,另外还有密度聚类和层 ...

  6. 基于多种算法实现鸢尾花聚类

    基于多种聚类算法实现鸢尾花聚类 描述 聚类(Clustering)属于无监督学习的一种,聚类算法是根据数据的内在特征,将数据进行分组(即"内聚成类"),本任务我们通过实现鸢尾花聚类 ...

  7. Python实现一条基于POS算法的区块链

    最新内容会更新在主站深入浅出区块链社区 原文链接:用Python从零开始创建区块链 区块链中的共识算法 在比特币公链架构解析中,就曾提到过为了实现去中介化的设计,比特币设计了一套共识协议,并通过此协议 ...

  8. 【项目实战】Python基于KMeans算法进行文本聚类项目实战

    说明:这是一个机器学习实战项目(附带数据+代码+文档+视频讲解),如需数据+代码+文档+视频讲解可以直接到文章最后获取. 1.项目背景 随着计算机技术的发展.Web 应用的逐步普及,大量的电子文本已经 ...

  9. python加密解密算法_Python基于DES算法加密解密实例

    #coding=utf-8 from functools import partial import base64 class DES(object): """ DES加 ...

  10. python文本聚类分析_python机器学习kmeans算法——对文本进行聚类分析

    #!/usr/bin/env python#-*- coding: utf-8 -*-#@File : kmeans.py#@Author: 田智凯#@Date : 2020/3/19#@Desc : ...

最新文章

  1. HDFS源码分析心跳汇报之BPServiceActor工作线程运行流程
  2. ARP病毒查找与防范
  3. java access dbq_java连接access数据库
  4. java 树面试题_java——二叉树面试题
  5. 如何在OpenJDK中使用ECC
  6. CentOS7入门_安装并配置mysql5.7.18
  7. ugui unity3d 仪表盘_Unity3D---UGUI---UI创建以及Canvas设置
  8. 8Manage微信CRM:打破传统企业营销套路
  9. 值类型、引用类型 再次理解
  10. 帆软高级函数应用之层次坐标函数
  11. Ubuntu用Apache2快速搭建一个HTTP文件服务器
  12. 王者服务器维护11月,11月17日体验服停机更新公告
  13. git 查看修改明细_Git(查看修改记录)
  14. 炮灰模型:对女生选择追求者的数学模型的建立-转
  15. Hadoop HA 高可用
  16. Greenplum 分布键 distribute hash分布和随机分布
  17. MySQL【数据类型】
  18. setFocus不能生效的问题
  19. GO语言-自定义error
  20. 什么是单反相机,和普通相机有什么区别

热门文章

  1. MATLAB希尔伯特变换
  2. 基于java自行车租赁管理系统
  3. 什么是网络割接【转自红茶三杯】
  4. 光环PMP 串讲课--项目整合管理
  5. 请问如何查一篇外文文献的DOI号?
  6. Spring Boot LiveReload 插件使用
  7. 苹果CMSV10红色自适应网站模板
  8. 【Activity】Activity的启动模式:SingleTask
  9. 力士乐驱动器原理图_力士乐驱动器参考手册大全
  10. 无穷积分 ∫sinx/xdx 的几种巧妙解法