当前位置: 首页 > news >正文

Open3D 基于曲率大小的特征点提取

目录

一、概述

1.1原理

1.2实现步骤

1.3应用场景

二、代码实现

三、实现效果

3.1原始点云

3.2提取特征点


Open3D点云算法汇总及实战案例汇总的目录地址:

Open3D点云算法与点云深度学习案例汇总(长期更新)-CSDN博客


一、概述

        基于曲率大小的特征点提取是一种常见的点云处理方法,用于识别和提取点云中具有显著几何特征的关键点。通过计算点云中每个点的曲率,并选择曲率较大的点作为特征点,可以在点云中保留那些具有明显形状变化的区域,如边缘、角点等。这种方法在三维重建、物体识别和特征匹配等领域有广泛的应用。

1.1原理

        曲率反映了点云表面局部区域的弯曲程度,是描述几何特征的重要指标。在曲率特征点提取中,首先计算每个点的曲率值,然后根据设定的阈值选择曲率较大的点作为特征点。曲率的计算基于每个点的法向量和其邻域点的分布,通常采用协方差矩阵的特征值分解来实现。

1.2实现步骤

  1. 加载点云数据: 使用 Open3D 加载点云文件。
  2. 法向量估计: 通过 K 近邻搜索计算每个点的法向量。
  3. 计算曲率: 计算每个点的曲率值,并保存在一个数组中。
  4. 提取特征点: 根据设定的曲率阈值,选择曲率较大的点作为特征点。
  5. 特征点放大和颜色区分: 将特征点的坐标略微放大,并使用鲜艳颜色标记,以便与原始点云区分。
  6. 可视化结果: 显示原始点云和特征点,便于比较和分析。

1.3应用场景

  • 三维重建: 提取点云中的特征点用于物体的三维重建,提高重建精度。
  • 物体识别: 基于特征点的分布,进行物体识别和匹配。
  • 特征匹配: 提取特征点用于点云的配准和特征匹配,尤其在多视角点云合成中应用广泛。

二、代码实现

import open3d as o3d
import numpy as np# 加载点云数据
pcd = o3d.io.read_point_cloud("person2.pcd")# 显示原始点云
print("Displaying original point cloud...")
o3d.visualization.draw_geometries([pcd], window_name="Original Point Cloud", width=800, height=600)# 估计法向量
pcd.estimate_normals(search_param=o3d.geometry.KDTreeSearchParamHybrid(radius=0.1, max_nn=30))# 计算每个点的曲率
pcd_tree = o3d.geometry.KDTreeFlann(pcd)
curvatures = np.zeros(len(pcd.points))for i in range(len(pcd.points)):[_, idx, _] = pcd_tree.search_knn_vector_3d(pcd.points[i], 30)neighbors = np.asarray(pcd.points)[idx, :]covariance_matrix = np.cov(neighbors.T)eigenvalues, _ = np.linalg.eigh(covariance_matrix)curvatures[i] = eigenvalues[0] / np.sum(eigenvalues)# 根据曲率提取特征点
curvature_threshold = 0.1  # 设置曲率阈值
indices = np.where(curvatures > curvature_threshold)[0]
feature_pcd = pcd.select_by_index(indices)# 将特征点放大以便区分
feature_points = np.asarray(feature_pcd.points)
feature_points_scaled = feature_points * 1.02  # 略微放大特征点位置# 创建放大的特征点点云
feature_pcd_scaled = o3d.geometry.PointCloud()
feature_pcd_scaled.points = o3d.utility.Vector3dVector(feature_points_scaled)
feature_pcd_scaled.paint_uniform_color([1, 0, 0])  # 红色显示特征点# 灰色显示原始点云
pcd.paint_uniform_color([0.5, 0.5, 0.5])# 可视化特征点与原始点云
print("Displaying feature points based on curvature...")
o3d.visualization.draw_geometries([pcd, feature_pcd_scaled], window_name="Feature Points", width=800, height=600)

三、实现效果

3.1原始点云

3.2提取特征点


http://www.mrgr.cn/news/19221.html

相关文章:

  • 深度学习从入门到精通——yolov1
  • 【kubernetes】持久化存储 —— nfs,emptyDir,hostPath
  • Linux编程学习记录
  • ffmpeg音视频开发从入门到精通——ffmpeg实现音频抽取
  • c++ 156函数
  • MySQL高阶语句(一)
  • DrissionPage设置启动浏览器为edge
  • C高级编程 第十四天
  • 编译工具链【持续更新中】
  • mac 安装brew并配置国内源
  • Linux【1】基础
  • windows11交叉编译ffmpeg的android版本库
  • AFFiNE简介
  • 深入理解 JavaScript DOM 操作
  • LLM agentic模式之multi-agent: ChatDev,MetaGPT, AutoGen思路
  • Xilinx系FPGA学习笔记(三)Vivado的仿真及ILA使用
  • 科研绘图系列:python语言制标准差的直方图(STD histogram plot)
  • 域名证书,泛域名证书,sni
  • 解释 JVM 的内存模型(堆、栈、方法区等),并简述如何通过调整 JVM 参数来优化应用程序的性能?
  • 深度学习从入门到精通——yolov3算法介绍