【详解算法流程+程序】DBSCAN基于密度的聚类算法+源码-用K-means和DBSCAN算法对银行数据进行聚类并完成用户画像数据分析课设源码资料包

算法流程

(1)圆心标记为聚类点画圈+判断临近点是否列入种子队列

        选取一个点,以eps为半径,画一个圈,看圈内有几个临近点,临近点个数如果大于某个阈值min_points, 则认为该点为某一簇的点;如果小于 min_points,则被标记为噪声点。

        如下图,选择点1为圆心画圈,这种画圈和数数的过程实际上就是求1点的密度了,如果圈内的点足够多则1这个点的密度就足够大。下图中点1的临近点为点4,7,9,10。将点1的临近点作为种子点: seeds = [
4,7,9,10]

        如下图中点5就是噪声点

(2)依次遍历所有种子点

1.遍历所有种子点,如果该点被标为
噪声点,则重标为聚类点 ;如果该点没有被标记过,则标记为
聚类点。如果该点已经被标记过了,则
不再遍历该点,跳过该点去处理下一个。

        接下来以点4(聚类点)举例,其中min_points以3为举例,如下图中(红色)表示聚类点。

2.并且聚类点点4为圆心,以eps为半径再次画一个圈。如果圈内点数大于min_points,将圈内点,添加到种子中seeds =
[4,7,9,10,1,7,9,16]    (点4为圆心的圈中有临近点1,7,9,16)

过程:

  • 首先标记点4为聚类点
  • 然后画圈数临近点个数,判断临近点个数大于/小于min_points
  • 临近点个数大于min_points则添加到种子队列

(3) 重复步骤2,直到遍历完所有的种子点

1.在上面步骤2中已经遍历完了4这个点,接下来遍历点7。

首先标记点7为聚类点(红色),seeds =
[4,7,9,10,1,7,9,16]

然后画圈数数,点7的周围有点12, 4 少于 min_points(以min_points=3举例),因此seed 不扩展

2.处理点9

首先标记点9为聚类点,seeds = [4,7,9,10,1,7,9,16]

然后以点9为中心画一个圈。点9周围有1,4,3三个数,min_points=3所以可以添加到种子队列里,添加1,4,3点,种子更新为seeds = [4,7,9,10,1,7,9,16,1,4,3]

3.处理点10

首先标记点10为聚类点

然后画圈数数,点10的周围有点1,6,7

将点1,6,7添加到种子队列中,seeds =
[4,7,9,10,1,7,9,16,1,4,3,1,6,7]

4.继续顺序处理后面的点

1 已经标记过,继续下个点

seeds = [4,7,9,10,1,7,9,16,1,4,3,1,6,7] 7 已经标记过,继续下个点 seeds = [4,7,9,10,1,7,9,16,1,4,3,1,6,7] 9 已经标记过,继续下个点seeds = [4,7,9,10,1,7,9,16,1,4,3,1,6,7] 16 周围点过少seeds = [4,7,9,10,1,7,9,16,1,4,3,1,6,7]

……

……

依次类推,直到遍历完所有的种子点

(4) 标记完一簇后(红色的为一簇),寻找一个未被标记的点,开始新的一轮聚类

找到点5 ,周围点过少,标记为 NOISE噪声

找到点15, 周围点过少,标记为NOISE噪声

找到点 19 开始新的一轮聚类

最后,所有点标记完,聚类结束,形成了两蔟,红色一簇和蓝色一簇

编程实现 源码下载  

聚类效果:

源码下载地址:

https://download.csdn.net/download/m0_61712829/89103298icon-default.png?t=N7T8https://download.csdn.net/download/m0_61712829/89103298

本资源包含本文聚类算法代码实现的源码,此外,还有数据分析综合课程设计,包含:SIR过程模拟与节点排序、用k-means和DBSCAN算法对银行数据进行聚类并完成用户画像、决策树与随机森林、基于奇异值分解的评分预测算法实现

版权声明:本文为博主作者:阿齐Archie原创文章,版权归属原作者,如果侵权,请联系我们删除!

原文链接:https://blog.csdn.net/m0_61712829/article/details/137520032

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
乘风的头像乘风管理团队
上一篇 2024年4月16日
下一篇 2024年4月16日

相关推荐