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 小时前
AI 数学辅导老师项目构想和初始化
前端·后端·python
用户0332126663672 小时前
将 PDF 文档转换为图片【Python 教程】
python
CoovallyAIHub3 小时前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
悟空爬虫3 小时前
UV实战教程,我啥要从Anaconda切换到uv来管理包?
python
SparkX开源AI知识库3 小时前
手摸手带你安装OpenClaw并对接飞书
算法·架构
dev派3 小时前
AI Agent 系统中的常用 Workflow 模式(1)
python·langchain
一语07163 小时前
3分钟搞懂深度学习AI:实操篇:卷积层
人工智能·算法
明月_清风5 小时前
从“能用”到“专业”:构建生产级装饰器与三层逻辑拆解
后端·python
曲幽14 小时前
数据库实战:FastAPI + SQLAlchemy 2.0 + Alembic 从零搭建,踩坑实录
python·fastapi·web·sqlalchemy·db·asyncio·alembic