open3d DBSCAN 聚类

DBSCAN 聚类

一、算法原理

1.密度聚类

介绍

基于密度的噪声应用空间聚类(DBSCAN):是一种无监督的ML聚类算法。无监督的意思是它不使用预先标记的目标来聚类数据点。聚类是指试图将相似的数据点分组到人工确定的组或簇中。另一方面,DBSCAN不要求我们指定集群的数量,避免了异常值,并且在任意形状和大小的集群中工作得非常好。它没有质心,聚类簇是通过将相邻的点连接在一起的过程形成的。

原理

首先,选择一个在其半径内至少有minPts的随机点。然后对核心点的邻域内的每个点进行评估,以确定它是否在epsilon距离内有minPts (minPts包括点本身)。如果该点满足minPts标准,它将成为另一个核心点,集群将扩展。如果一个点不满足minPts标准,它成为边界点。随着过程的继续,算法开始发展成为核心点"a"是"b"的邻居,而"b"又是"c"的邻居,以此类推。当集群被边界点包围时,这个聚类簇已经搜索完全,因为在距离内没有更多的点。选择一个新的随机点,并重复该过程以识别下一个簇。

2、主要函数
python 复制代码
pcd.cluster_dbscan(eps=0.02,   # 邻域距离
                       min_points=10,  # 最小点数目
                             print_progress=True)  # 进度条展示

参数

首先,让我们定义Epsilon和最小点、应用DBSCAN算法时需要的两个参数以及一些额外的参数。

  1. **Epsilon (ɛ)(eps):**社区的最大半径。如果数据点的相互距离小于或等于指定的epsilon,那么它们将是同一类的。换句话说,它是DBSCAN用来确定两个点是否相似和属于同一类的距离。更大的epsilon将产生更大的簇(包含更多的数据点),更小的epsilon将构建更小的簇。一般来说,我们喜欢较小的值是因为我们只需要很小一部分的数据点在彼此之间的距离内。但是如果太小,您会将集群分割的越来越小。
  2. **最小点(minPts)(min_points):**在一个邻域的半径内minPts数的邻域被认为是一个簇。请记住,初始点包含在minPts中。一个较低的minPts帮助算法建立更多的集群与更多的噪声或离群值。较高的minPts将确保更健壮的集群,但如果集群太大,较小的集群将被合并到较大的集群中。

如果"最小点"= 4,则在彼此距离内的任意4个或4个以上的点都被认为是一个簇。

二、代码

python 复制代码
import open3d as o3d
import numpy as np
import matplotlib.pyplot as plt
if __name__ == '__main__':

    pcd = o3d.io.read_point_cloud('res/monkey.ply')
    # 使用 DBSCAN 算法对点云进行聚类
    labels = np.array(pcd.cluster_dbscan(eps=0.02,   # 邻域距离
                                         min_points=10,  # 最小点数目
                                         print_progress=True))  # 进度条展示

    # 获取聚类数目
    max_label = labels.max()
    print(f"point cloud has {max_label + 1} clusters")

    # 根据聚类标签给点云上色
    colors = plt.get_cmap("tab20")(labels / (max_label if max_label > 0 else 1))
    colors[labels < 0] = 0
    pcd.colors = o3d.utility.Vector3dVector(colors[:, :3])
    # 可视化
    o3d.visualization.draw_geometries([pcd])

三、结果

原点云

DBSCAN 聚类

四、相关数据

点云密度计算:open3d 计算点云密度-CSDN博客

百度网盘数据集:

包括 obj,pcd,las,png,ply等

百度网盘链接:https://pan.baidu.com/s/1JFxKUk_xMcEmpfBHtuC-Pg

提取码:cpev

相关推荐
烛阴1 小时前
简单入门Python装饰器
前端·python
YuTaoShao1 小时前
【LeetCode 热题 100】48. 旋转图像——转置+水平翻转
java·算法·leetcode·职场和发展
超龄超能程序猿1 小时前
(三)PS识别:基于噪声分析PS识别的技术实现
图像处理·人工智能·计算机视觉
好开心啊没烦恼1 小时前
Python 数据分析:numpy,说人话,说说数组维度。听故事学知识点怎么这么容易?
开发语言·人工智能·python·数据挖掘·数据分析·numpy
生态遥感监测笔记2 小时前
GEE利用已有土地利用数据选取样本点并进行分类
人工智能·算法·机器学习·分类·数据挖掘
面朝大海,春不暖,花不开2 小时前
使用 Python 实现 ETL 流程:从文本文件提取到数据处理的全面指南
python·etl·原型模式
Tony沈哲2 小时前
macOS 上为 Compose Desktop 构建跨架构图像处理 dylib:OpenCV + libraw + libheif 实践指南
opencv·算法
刘海东刘海东3 小时前
结构型智能科技的关键可行性——信息型智能向结构型智能的转变(修改提纲)
人工智能·算法·机器学习
2301_805054563 小时前
Python训练营打卡Day59(2025.7.3)
开发语言·python