Open3d之对点云进行DBSCAN 聚类

给定一个点云,比如深度传感器,我们想将局部的点分组/聚合在一起,这时我们就需要聚类算法。open3d实现了DBSCAN[Ester1996] 算法,这是一种基于密度的聚类算法。(百度百科链接具有对该算法的介绍,但建议看原论文)。该算法接口为cluster_dbscan,有两个必须的参数:eps表示聚类的领域距离,min_points表示聚类的最小点数。该函数返回一个label,其中label为-1表示为噪声。

代码展示

# -*-coding:utf-8 -*-
import os
import open3d as o3d
import matplotlib.pyplot as plt
import numpy as np

test_data_dir = '/home/pi/PycharmProjects/learn/Open3D/examples/test_data'
point_cloud_file_name = 'fragment.ply'
point_cloud_file_path = os.path.join(test_data_dir, point_cloud_file_name)
# 读取点云
pcd = o3d.io.read_point_cloud(point_cloud_file_path)

# 使用聚类算法
with o3d.utility.VerbosityContextManager(o3d.utility.VerbosityLevel.Debug) as cm:
    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],
                                  zoom=0.455,
                                  front=[-0.4999, -0.1659, -0.8499],
                                  lookat=[2.1813, 2.0619, 2.0999],
                                  up=[0.1204, -0.9852, 0.1215])

效果展示

 

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
点云DBSCAN聚类是一种常用的聚类方法,可以应用于三维点云数据。DBSCAN算法通过确定点的密度来进行聚类,具体实现方式可以使用Python库open3d中的cluster_dbscan函数。在该函数中,eps参数表示确定点密度时考虑的邻近点的距离大小,min_points参数表示组成一类最少需要的点的数量。运行该函数后,会返回聚类成功的类别,其中-1表示没有分到任何类中的点。 您可以使用以下代码实现点云DBSCAN聚类: ```python import open3d as o3d import numpy as np file_path = 'rabbit.pcd' pcd = o3d.io.read_point_cloud(file_path) pcd.paint_uniform_color([0.5, 0.5, 0.5]) # 指定显示为灰色 labels = np.array(pcd.cluster_dbscan(eps=0.25, min_points=16, print_progress=True)) max_label = np.max(labels) # 最大值相当于共有多少个类别 colors = np.random.randint(255, size=(max_label + 1, 3))/255. colors = colors # 没有分类成功的点设置为黑色 colors = 0 pcd.colors = o3d.utility.Vector3dVector(colors[:, :3]) o3d.visualization.draw_geometries([pcd], window_name="DBSCAN聚类", point_show_normal=False, width=800, height=600) ``` 上述代码中,首先使用open3d库的read_point_cloud函数读取点云数据。然后调用cluster_dbscan函数进行DBSCAN聚类,指定eps和min_points参数。最后根据聚类结果为点云赋予不同的颜色,并通过调用draw_geometries函数可视化点云。 这样,您就可以通过点云DBSCAN聚类方法对三维点云数据进行聚类分析了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [八种点云聚类方法(一)— DBSCAN](https://blog.csdn.net/suiyingy/article/details/124518507)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值