简单易学的机器学习算法—基于密度的聚类算法DBSCAN
一、基于密度的聚类算法的概述
我想了解下基于密度的聚类算法,熟悉下基于密度的聚类算法与基于距离的聚类算法,如K-Means算法之间的区别。
   
基于密度的聚类算法主要的目标是寻找被低密度区域分离的高密度区域。与基于距离的聚类算法不同的是,基于距离的聚类算法的聚类结果是球状的簇,而基于密度的聚类算法可以发现任意形状的聚类,这对于带有噪音点的数据起着重要的作用。
二、DBSCAN算法的原理
1、基本概念
   
DBSCAN(Density-Based Spatial Clustering of Application with
Noise)是一种典型的基于密度的聚类算法,在DBSCAN算法中将数据点分为一下三类:
核心点。在半径Eps内含有超过MinPts数目的点
边界点。在半径Eps内点的数量小于MinPts,但是落在核心点的邻域内
噪音点。既不是核心点也不是边界点的点
在这里有两个量,一个是半径Eps,另一个是指定的数目MinPts。
   
一些其他的概念
Eps邻域。简单来讲就是与点p的距离小于等于Eps的所有的点的集合,可以表示为 。
。
直接密度可达。如果p在核心对象q的Eps邻域内,则称对象p从对象q出发是直接密度可达的。
密度可达。对于对象链: ,
, 是从
是从 关于Eps和MinPts直接密度可达的,则对象
关于Eps和MinPts直接密度可达的,则对象 是从对象
是从对象 关于Eps和MinPts密度可达的。
关于Eps和MinPts密度可达的。
2、算法流程

(流程)
三、实验仿真
   
在实验中使用了两个测试数据集,数据集的原始图像如下:

(数据集1)

(数据集2)
数据集1相对比较简单。显然我们可以发现数据集1共有两个类,数据集2有四个类,下面我们通过DBSCAN算法实现数据点的聚类:
MATLAB代码
主程序
[plain] view plain copy 在CODE上查看代码片派生到我的代码片
%% DBSCAN  
clear all;  
clc;  
 
%% 导入数据集  
% data = load('testData.txt');  
data = load('testData_2.txt');  
 
% 定义参数Eps和MinPts  
MinPts = 5;  
Eps = epsilon(data, MinPts);  
 
[m,n] = size(data);%得到数据的大小  
 
x = [(1:m)' data];  
[m,n] = size(x);%重新计算数据集的大小  
types = zeros(1,m);%用于区分核心点1,边界点0和噪音点-1  
dealed = zeros(m,1);%用于判断该点是否处理过,0表示未处理过  
dis = calDistance(x(:,2:n));  
number = 1;%用于标记类  
 
%% 对每一个点进行处理  
for i = 1:m  
    %找到未处理的点
 
    if dealed(i)
== 0  
       
xTemp = x(i,:);  
       
D = dis(i,:);%取得第i个点到其他所有点的距离  
       
ind = find(D<=Eps);%找到半径Eps内的所有点
 
        
 
       
%% 区分点的类型  
        
 
       
%边界点  
       
if length(ind) > 1
&& length(ind) <
MinPts 1  
           
types(i) = 0;  
           
class(i) = 0;  
       
end  
       
%噪音点  
       
if length(ind) == 1  
           
types(i) = -1;  
           
class(i) = -1;  
           
dealed(i) = 1;  
       
end  
       
%核心点(此处是关键步骤)  
       
if length(ind) >= MinPts 1  
           
types(xTemp(1,1)) = 1;  
           
class(ind) = number;  
            
 
           
% 判断核心点是否密度可达  
           
while ~isempty(ind)  
               
yTemp = x(ind(1),:);  
               
dealed(ind(1)) = 1;  
               
ind(1) = [];  
               
D = dis(yTemp(1,1),:);%找到与ind(1)之间的距离  
               
ind_1 = find(D<=Eps);  
                
 
               
if length(ind_1)>1%处理非噪音点  
                   
class(ind_1) = number;  
                   
if length(ind_1) >= MinPts 1
 
                       
types(yTemp(1,1)) = 1;  
                   
else  
                       
types(yTemp(1,1)) = 0;  
                   
end  
                    
 
                   
for j=1:length(ind_1)  
                      
if dealed(ind_1(j)) == 0  
                         
dealed(ind_1(j)) = 1;  
                         
ind=[ind
ind_1(j)];   
 
                         
class(ind_1(j))=number;  
                      
end                    
 
                  
end  
               
end  
           
end  
           
number = number 1;  
       
end  
    end
 
end  
 
% 最后处理所有未分类的点为噪音点  
ind_2 = find(class==0);  
class(ind_2) = -1;  
types(ind_2) = -1;  
 
%% 画出最终的聚类图  
hold on  
for i = 1:m  
    if class(i)
== -1  
       
plot(data(i,1),data(i,2),'.r');  
    elseif
class(i) == 1  
       
if types(i) == 1  
           
plot(data(i,1),data(i,2),' b');  
       
else  
           
plot(data(i,1),data(i,2),'.b');  
       
end  
    elseif
class(i) == 2  
       
if types(i) == 1  
           
plot(data(i,1),data(i,2),' g');  
       
else  
           
plot(data(i,1),data(i,2),'.g');  
       
end  
    elseif
class(i) == 3  
       
if types(i) == 1  
           
plot(data(i,1),data(i,2),' c');  
       
else  
           
plot(data(i,1),data(i,2),'.c');  
       
end  
    else
 
       
if types(i) == 1  
           
plot(data(i,1),data(i,2),' k');  
       
else  
           
plot(data(i,1),data(i,2),'.k');  
       
end  
    end
 
end  
hold off  
距离计算函数
[plain] view plain copy 在CODE上查看代码片派生到我的代码片
%% 计算矩阵中点与点之间的距离  
function [ dis ] = calDistance( x )  
    [m,n] =
size(x);  
    dis =
zeros(m,m);  
    
 
    for i = 1:m
 
       
for j = i:m  
           
%计算点i和点j之间的欧式距离  
           
tmp =0;  
           
for k = 1:n  
               
tmp = tmp (x(i,k)-x(j,k)).^2;  
           
end  
           
dis(i,j) = sqrt(tmp);  
           
dis(j,i) = dis(i,j);  
       
end  
    end
 
end  
epsilon函数
[plain] view plain copy 在CODE上查看代码片派生到我的代码片
function [Eps]=epsilon(x,k)  
 
% Function: [Eps]=epsilon(x,k)  
%  
% Aim:   
% Analytical way of estimating neighborhood radius for DBSCAN
 
%  
% Input:   
% x - data matrix (m,n); m-objects, n-variables
 
% k - number of objects in a neighborhood of an object
 
% (minimal number of objects considered as a cluster)
 
 
 
[m,n]=size(x);  
 
Eps=((prod(max(x)-min(x))*k*gamma(.5*n 1))/(m*sqrt(pi.^n))).^(1/n);
 
最终的结果

(数据集1的聚类结果)

(数据集2的聚类结果)
在上面的结果中,红色的点代表的是噪音点,点代表的是边界点,十字代表的是核心点。不同的颜色代表着不同的类。数据分析师培训
简单易学的机器学习算法—基于密度的聚类算法DBSCAN的更多相关文章
- 简单易学的机器学习算法——基于密度的聚类算法DBSCAN
		一.基于密度的聚类算法的概述 最近在Science上的一篇基于密度的聚类算法<Clustering by fast search and find of density peaks> ... 
- 【机器学习】DBSCAN Algorithms基于密度的聚类算法
		一.算法思想: DBSCAN(Density-Based Spatial Clustering of Applications with Noise)是一个比较有代表性的基于密度的聚类算法.与划分和层 ... 
- 基于密度的聚类之Dbscan算法
		一.算法概述 DBSCAN(Density-Based Spatial Clustering of Applications with Noise)是一个比较有代表性的基于密度的聚类算法.与划分和层次 ... 
- DBSCAN聚类︱scikit-learn中一种基于密度的聚类方式
		一.DBSCAN聚类概述 基于密度的方法的特点是不依赖于距离,而是依赖于密度,从而克服基于距离的算法只能发现"球形"聚簇的缺点. DBSCAN的核心思想是从某个核心点出发,不断向密 ... 
- 简单易学的机器学习算法——EM算法
		简单易学的机器学习算法——EM算法 一.机器学习中的参数估计问题 在前面的博文中,如“简单易学的机器学习算法——Logistic回归”中,采用了极大似然函数对其模型中的参数进行估计,简单来讲即对于一系 ... 
- 简单易学的机器学习算法—SVD奇异值分解
		简单易学的机器学习算法-SVD奇异值分解 一.SVD奇异值分解的定义 假设M是一个的矩阵,如果存在一个分解: 其中的酉矩阵,的半正定对角矩阵,的共轭转置矩阵,且为的酉矩阵.这样的分解称为M的奇 ... 
- 聚类:层次聚类、基于划分的聚类(k-means)、基于密度的聚类、基于模型的聚类
		一.层次聚类 1.层次聚类的原理及分类 1)层次法(Hierarchicalmethods)先计算样本之间的距离.每次将距离最近的点合并到同一个类.然后,再计算类与类之间的距离,将距离最近的类合并为一 ... 
- SIGAI机器学习第二十四集 聚类算法1
		讲授聚类算法的基本概念,算法的分类,层次聚类,K均值算法,EM算法,DBSCAN算法,OPTICS算法,mean shift算法,谱聚类算法,实际应用. 大纲: 聚类问题简介聚类算法的分类层次聚类算法 ... 
- 密度峰值聚类算法(DPC)
		密度峰值聚类算法(DPC) 凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 1. 简介 基于密度峰值的聚类算法全称为基于快速搜索和发现密度峰值的聚类算法(cl ... 
随机推荐
- github 拷贝项目到本地
			第一步,git config --global --list 验证邮箱 第二步,git config --global user.name "yourname",git confi ... 
- VS2010-MFC(常用控件:列表视图控件List Control 下)
			转自:http://www.jizhuomi.com/software/197.html 上一节是关于列表视图控件List Control的上半部分,简单介绍了列表视图控件,其通知消息的处理和有关结构 ... 
- HTML <body>的常用属性
			bgColor : 网页背景色 如 <body bgColor="red"> Background : 网页背景图片的地址 如 <body background ... 
- Linux 中执行Shell 脚本的方式(三种方法)
			Shell 脚本的执行方式通常有如下三种: (1)bash script-name 或者 sh script-name:(2)path/script-name或者./script-name:(3)so ... 
- shell常用命令及正则辅助日志分析统计
			https://www.cnblogs.com/wj033/p/3451618.html 正则日志分析统计 3 grep 'onerror' v3-0621.log | egrep -v '(\d ... 
- node环境下安装vue-cli
			一. node安装 1)如果不确定自己是否安装了node,可以在命令行工具内执行: node -v (检查一下 版本): 2)如果 执行结果显示: xx 不是内部命令,说明你还没有安装node , ... 
- Java中循环体的初步了解以及另一种随机数的获取方法
			Math中的相关操作 随机数 Java中除了可以直接导入Random类,获取随机数,还可以通过本身自带的Math方法去获取随机数.Math.random()可以产生随机小数,区间范围为[0.0,1.0 ... 
- 2018-11-19-WPF-在image控件用鼠标拖拽出矩形
			title author date CreateTime categories WPF 在image控件用鼠标拖拽出矩形 lindexi 2018-11-19 15:35:13 +0800 2018- ... 
- 【学术篇】状态压缩动态规划——POJ3254/洛谷1879 玉米田Corn Field
			我要开状压dp的坑了..直播从入门到放弃系列.. 那就先拿一道状压dp的水题练练手吧.. 然后就找到了这一道..这道题使我清醒地认识到阻碍我的不是算法,而是视力= = 传送门: poj:http:// ... 
- drupal-note2  drush运行make文件
			进入durpal项目的根目录中执行 drush make build-openpublic.make /path/to/webroot 参考: Managing Drush make files fo ... 
