DBScan聚类算法Java实现

本文介绍了DBScan聚类算法的流程,通过Java代码实现了该算法,并展示了使用matlab绘制的聚类效果。提供了两种数据集的聚类结果,*标记为噪声点,不同颜色代表不同类别。完整代码可在GitHub找到。
摘要由CSDN通过智能技术生成

DBScan算法流程图

算法:DBScan,基于密度的聚类算法
输入:
   D:一个包含n个数据的数据集
   r:半径参数
   minPts:领域密度阈值
输出:基于密度的聚类集合
标记D中所有的点为unvisted
for each p in D
    if p.visit = unvisted
        找出与点p距离不大于r的所有点集合N
        If N.size() < minPts
           标记点p为噪声点
        Else
           for each p' in N
               If p'.visit == unvisted
                  找出与点p距离不大于r的所有点集合N'
                    If N'.size()>=minPts
                        将集合N'加入集合N中去
                    End if
                Else
                    If p'未被聚到某个簇
                        将p'聚到当前簇
                        If p'被标记为噪声点
                           将p'取消标记为噪声点
                        End If
                     End If
                 End If
             End for
         End if
     End if
End for

代码实现

Point.java 定义点,其中距离计算采用欧式距离

package Cluster.DBScan;

/**
 * Created by Jason on 2016/4/17.
 */
public class Point {
   
    private double x;
    private double y;
    private boolean isVisit;
    private int cluster;
    private boolean isNoised;

    public Point(double x,double y) {
        this.x = x;
        this.y = y;
        this.isVisit = false;
        this.cluster = 0;
        this.isNoised = false;
    }

    public double getDistance(Point point) {
        return Math.sqrt((x-point.x)*(x-point.x)+(y-point.y)*(y-point.y));
    }

    public void setX(double x) {
        this.x = x;
    }

    public
  • 12
    点赞
  • 56
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值