DBSCAN算法原理

1. 密度聚类原理

        DBSCAN是一种基于密度的聚类算法,这类密度聚类算法一般假定类别可以通过样本分布的紧密程度决定。同一类别的样本,他们之间的紧密相连的,也就是说,在该类别任意样本周围不远处一定有同类别的样本存在。

        通过将紧密相连的样本划为一类,这样就得到了一个聚类类别。通过将所有各组紧密相连的样本划为各个不同的类别,则我们就得到了最终的所有聚类类别结果。

2. DBSCAN密度定义

        在上一节我们定性描述了密度聚类的基本思想,本节我们就看看DBSCAN是如何描述密度聚类的。DBSCAN是基于一组邻域来描述样本集的紧密程度的,参数(ϵ ϵ, MinPts)用来描述邻域的样本分布紧密程度。其中,ϵ ϵ描述了某一样本的邻域距离阈值,MinPts描述了某一样本的距离为ϵ ϵ的邻域中样本个数的阈值。

        假设我的样本集是D=(x 1 ,x 2 ,...,x m ) (x1,x2,...,xm),则DBSCAN具体的密度描述定义如下:

        1) ϵ ϵ-邻域:对于x j ∈D xj∈D,其ϵ ϵ-邻域包含样本集D中与x j xj的距离不大于ϵ ϵ的子样本集,即N ϵ (x j )={x i ∈D|distance(x i ,x j )≤ϵ} Nϵ(xj)={xi∈D|distance(xi,xj)≤ϵ}, 这个子样本集的个数记为|N ϵ (x j )| |Nϵ(xj)|

        2) 核心对象:对于任一样本x j ∈D xj∈D,如果其ϵ ϵ-邻域对应的N ϵ (x j ) Nϵ(xj)至少包含MinPts个样本,即如果|N ϵ (x j )|≥MinPts |Nϵ(xj)|≥MinPts,则x j xj是核心对象。

        3)密度直达:如果x i xi位于x j xj的ϵ ϵ-邻域中,且x j xj是核心对象,则称x i xi由x j xj密度直达。注意反之不一定成立,即此时不能说x j xj由x i xi密度直达, 除非且x i xi也是核心对象。

        4)密度可达:对于x i xi和x j xj,如果存在样本样本序列p 1 ,p 2 ,...,p T p1,p2,...,pT,满足p 1 =x i ,p T =x j p1=xi,pT=xj, 且p t+1 pt+1由p t pt密度直达,则称x j xj由x i xi密度可达。也就是说,密度可达满足传递性。此时序列中的传递样本p 1 ,p 2 ,...,p T−1 p1,p2,...,pT−1均为核心对象,因为只有核心对象才能使其他样本密度直达。注意密度可达也不满足对称性,这个可以由密度直达的不对称性得出。

        5)密度相连:对于x i xi和x j xj,如果存在核心对象样本x k xk,使x i xi和x j xj均由x k xk密度可达,则称x i xi和x j xj密度相连。注意密度相连关系是满足对称性的。

从下图可以很容易看出理解上述定义,图中MinPts=5,红色的点都是核心对象,因为其ϵ ϵ-邻域至少有5个样本。黑色的样本是非核心对象。所有核心对象密度直达的样本在以红色核心对象为中心的超球体内,如果不在超球体内,则不能密度直达。图中用绿色箭头连起来的核心对象组成了密度可达的样本序列。在这些密度可达的样本序列的ϵ ϵ-邻域内所有的样本相互都是密度相连的。


 3. DBSCAN密度聚类思想

        DBSCAN的聚类定义很简单:由密度可达关系导出的最大密度相连的样本集合,即为我们最终聚类的一个类别,或者说一个簇。

        这个DBSCAN的簇里面可以有一个或者多个核心对象。如果只有一个核心对象,则簇里其他的非核心对象样本都在这个核心对象的ϵ ϵ-邻域里;如果有多个核心对象,则簇里的任意一个核心对象的ϵ ϵ-邻域中一定有一个其他的核心对象,否则这两个核心对象无法密度可达。这些核心对象的ϵ ϵ-邻域里所有的样本的集合组成的一个DBSCAN聚类簇。

        那么怎么才能找到这样的簇样本集合呢?DBSCAN使用的方法很简单,它任意选择一个没有类别的核心对象作为种子,然后找到所有这个核心对象能够密度可达的样本集合,即为一个聚类簇。接着继续选择另一个没有类别的核心对象去寻找密度可达的样本集合,这样就得到另一个聚类簇。一直运行到所有核心对象都有类别为止。

        基本上这就是DBSCAN算法的主要内容了,是不是很简单?但是我们还是有三个问题没有考虑。     第一个是一些异常样本点或者说少量游离于簇外的样本点,这些点不在任何一个核心对象在周围,在DBSCAN中,我们一般将这些样本点标记为噪音点。

        第二个是距离的度量问题,即如何计算某样本和核心对象样本的距离。在DBSCAN中,一般采用最近邻思想,采用某一种距离度量来衡量样本距离,比如欧式距离。这和KNN分类算法的最近邻思想完全相同。对应少量的样本,寻找最近邻可以直接去计算所有样本的距离,如果样本量较大,则一般采用KD树或者球树来快速的搜索最近邻。如果大家对于最近邻的思想,距离度量,KD树和球树不熟悉,建议参考之前写的另一篇文章K近邻法(KNN)原理小结。

        第三种问题比较特殊,某些样本可能到两个核心对象的距离都小于ϵ ϵ,但是这两个核心对象由于不是密度直达,又不属于同一个聚类簇,那么如果界定这个样本的类别呢?一般来说,此时DBSCAN采用先来后到,先进行聚类的类别簇会标记这个样本为它的类别。也就是说DBSCAN的算法不是完全稳定的算法。

4. DBSCAN聚类算法

下面我们对DBSCAN聚类算法的流程做一个总结。

        输入:样本集D=(x 1 ,x 2 ,...,x m ) (x1,x2,...,xm),邻域参数(ϵ,MinPts) (ϵ,MinPts), 样本距离度量方式             输出: 簇划分C.

        1)初始化核心对象集合Ω=∅ Ω=∅, 初始化聚类簇数k=0,初始化未访问样本集合Γ Γ = D, 簇划分C = ∅ ∅

        2) 对于j=1,2,...m, 按下面的步骤找出所有的核心对象:

                a) 通过距离度量方式,找到样本x j xj的ϵ ϵ-邻域子样本集N ϵ (x j ) Nϵ(xj)

                b) 如果子样本集样本个数满足|N ϵ (x j )|≥MinPts |Nϵ(xj)|≥MinPts, 将样本x j xj加入核心对象样本集合:Ω=Ω∪{x j } Ω=Ω∪{xj}

        3)如果核心对象集合Ω=∅ Ω=∅,则算法结束,否则转入步骤4.

        4)在核心对象集合Ω Ω中,随机选择一个核心对象o o,初始化当前簇核心对象队列Ω cur ={o} Ωcur={o}, 初始化类别序号k=k+1,初始化当前簇样本集合C k ={o} Ck={o}, 更新未访问样本集合Γ=Γ−{o} Γ=Γ−{o}

        5)如果当前簇核心对象队列Ω cur =∅ Ωcur=∅,则当前聚类簇C k Ck生成完毕, 更新簇划分C={C 1 ,C 2 ,...,C k } {C1,C2,...,Ck}, 更新核心对象集合Ω=Ω−C k Ω=Ω−Ck, 转入步骤3。

        6)在当前簇核心对象队列Ω cur Ωcur中取出一个核心对象o ′ o′,通过邻域距离阈值ϵ ϵ找出所有的ϵ ϵ-邻域子样本集N ϵ (o ′ ) Nϵ(o′),令Δ=N ϵ (o ′ )∩Γ Δ=Nϵ(o′)∩Γ, 更新当前簇样本集合C k =C k ∪Δ Ck=Ck∪Δ, 更新未访问样本集合Γ=Γ−Δ Γ=Γ−Δ, 更新Ω cur =Ω cur ∪(Δ∩Ω)−o ′ Ωcur=Ωcur∪(Δ∩Ω)−o′,转入步骤5.

        输出结果为: 簇划分C={C 1 ,C 2 ,...,C k } {C1,C2,...,Ck}

5. DBSCAN小结

        和传统的K-Means算法相比,DBSCAN最大的不同就是不需要输入类别数k,当然它最大的优势是可以发现任意形状的聚类簇,而不是像K-Means,一般仅仅使用于凸的样本集聚类。同时它在聚类的同时还可以找出异常点,这点和BIRCH算法类似。

        那么我们什么时候需要用DBSCAN来聚类呢?一般来说,如果数据集是稠密的,并且数据集不是凸的,那么用DBSCAN会比K-Means聚类效果好很多。如果数据集不是稠密的,则不推荐用DBSCAN来聚类。

        下面对DBSCAN算法的优缺点做一个总结。

        DBSCAN的主要优点有:

                1) 可以对任意形状的稠密数据集进行聚类,相对的,K-Means之类的聚类算法一般只适用于凸数据集。

                2) 可以在聚类的同时发现异常点,对数据集中的异常点不敏感。

                3) 聚类结果没有偏倚,相对的,K-Means之类的聚类算法初始值对聚类结果有很大影响。             DBSCAN的主要缺点有:

                1)如果样本集的密度不均匀、聚类间距差相差很大时,聚类质量较差,这时用DBSCAN聚类一般不适合。

                2) 如果样本集较大时,聚类收敛时间较长,此时可以对搜索最近邻时建立的KD树或者球树进行规模限制来改进。

                3) 调参相对于传统的K-Means之类的聚类算法稍复杂,主要需要对距离阈值ϵ ϵ,邻域样本数阈值MinPts联合调参,不同的参数组合对最后的聚类效果有较大影响。

参考:http://www.cnblogs.com/pinard/p/6208966.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351