news 2026/4/22 15:36:03

第十一课Open3D点云数据处理:中值滤波

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
第十一课Open3D点云数据处理:中值滤波

1 中值滤波原理

2 与均值滤波对比

3 中值滤波代码实现

3.1 代码行实现

3.2 将中值滤波的实现封装到函数 pointCloud_median_filter() 中


1 中值滤波原理

点云中值滤波是将空间中每个点的值替换为其邻域点值的中位数。具体来说,对于给定点云中的每个点,我们考虑它的邻域,即以该点为中心的一定大小的球体,然后将该球体内所有点的xyz三个方向的值分别进行排序,分别计算三个方向的中位数来代替该点的坐标值。

中值滤波会丢失一些细节信息,因为它只考虑了每个点周围的点,而没有利用全局信息。同时,窗口大小的选取也很重要,过大的窗口,排序的点数增多,运算时间也会增加,并且会导致平滑效果过于明显,过小的窗口则可能无法去除噪声。因此,在实际应用中需要根据具体情况进行调整。

需要注意的一点是:中值滤波后,点云中点的总数并不会发生变化,只是点的位置发生改变。

2 与均值滤波对比

  • 原理不同:均值滤波取平均值,中值滤波取中位数。
  • 滤波效果不同:均值滤波适用于去除较为平稳的噪声,能够在一定程度上对点云数据进行平滑处理,但会损失部分细节信息;中值滤波更适用于去除非均匀性噪声,能够保留更多的细节信息。
  • 适用范围不同:均值滤波适用于处理较小的噪声,窗口大小较小;中值滤波适用于处理较大的噪声,窗口大小较大。

3 中值滤波代码实现

关键代码:

# 计算邻域内所有点的坐标中位数 median = np.median(np.asarray(pcd.points)[idx], axis=0)

3.1 代码行实现

import open3d as o3d import numpy as np # 读取点云文件 pcd = o3d.io.read_point_cloud(r"H:\HTempWK\temp\open3d\pointdata\feiji.pcd") # 定义中值滤波半径 radius = 0.05 # 构建kdtree进行邻域搜索 kdtree = o3d.geometry.KDTreeFlann(pcd) np_points = np.array(pcd.points) # 遍历点云 for i in range(len(pcd.points)): # 获取当前点的坐标 point = pcd.points[i] # 使用kdtree搜索当前点的邻域 [k, idx, _] = kdtree.search_radius_vector_3d(point, radius) # 如果邻域内没有点,则跳过 if k < 1: continue # 计算邻域内所有点的坐标中位数 median = np.median(np.asarray(pcd.points)[idx], axis=0) # 更新当前点的坐标 np_points[i] = median # 创建点云对象,存放滤波结果 pcd_median = o3d.geometry.PointCloud() pcd_median.points = o3d.utility.Vector3dVector(np_points) # 打印点云信息 print('原始点云:',pcd) print('滤波点云:',pcd_median) # 可视化滤波结果 pcd.paint_uniform_color([1,0,0]) pcd_median.paint_uniform_color([0,1,0]) o3d.visualization.draw_geometries([pcd,pcd_median], width=1200, height=800, window_name = '中值滤波-原始点云(红),滤波点云(绿)')

3.2 将中值滤波的实现封装到函数pointCloud_median_filter()

import open3d as o3d import numpy as np """ @describe: 点云中值滤波 @param[I]: pointCloud, 待滤波点云 @param[I]: radius, 滤波窗口半径 @return: pointCloud_median: 中值滤波结果点云 """ def pointCloud_median_filter(pointCloud,radius): # 构建kdtree进行邻域搜索 kdtree = o3d.geometry.KDTreeFlann(pointCloud) np_points = np.array(pointCloud.points) # 遍历点云 for i in range(len(pointCloud.points)): # 获取当前点的坐标 point = pointCloud.points[i] # 使用kdtree搜索当前点的邻域 [k, idx, _] = kdtree.search_radius_vector_3d(point, radius) # 如果邻域内没有点,则跳过 if k < 1: continue # 计算邻域内所有点的坐标中位数 median = np.median(np.asarray(pcd.points)[idx], axis=0) # 更新当前点的坐标 np_points[i] = median # 创建点云对象,存放滤波结果 pointCloud_median= o3d.geometry.PointCloud() pointCloud_median.points = o3d.utility.Vector3dVector(np_points) # 返回滤波结果点云 return pointCloud_median if __name__ == "__main__": # 读取点云文件 pcd = o3d.io.read_point_cloud("data\desk.pcd") # 定义中值滤波窗口半径 radius = 0.05 # 创建点云对象,存放滤波结果 pcd_median = o3d.geometry.PointCloud() # 执行中值滤波 pcd_median = pointCloud_median_filter(pcd,radius) # 打印点云信息 print('原始点云:',pcd) print('滤波点云:',pcd_median) # 可视化滤波结果 pcd.paint_uniform_color([1,0,0]) pcd_median.paint_uniform_color([0,1,0]) o3d.visualization.draw_geometries([pcd,pcd_median], width=1200, height=800, window_name = '中值滤波-原始点云(红),滤波点云(绿)')
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 9:10:22

英伟达AI帝国:揭秘其重要创业投资组合

没有哪家公司比英伟达更能从AI革命中获得巨大收益。自三年前ChatGPT推出以来&#xff0c;该公司的营收、盈利能力和现金储备都大幅飙升&#xff0c;众多竞争性生成式AI服务也相继推出。其股价飞涨&#xff0c;使其成为市值4.6万亿美元的公司。这家全球领先的高性能GPU制造商利用…

作者头像 李华
网站建设 2026/4/23 11:27:09

2核2G配置的Linux云服务器能同时跑Nginx、MySQL和PHP吗?

2核2GB内存的Linux云服务器理论上可以同时运行 Nginx、MySQL 和 PHP&#xff08;如 PHP-FPM&#xff09;&#xff0c;但实际是否稳定、可用&#xff0c;取决于具体使用场景和负载强度。以下是详细分析&#xff1a; 原文地址&#xff1a;https://zestb.com/109422.html ✅ 可行…

作者头像 李华
网站建设 2026/4/23 12:54:36

雷家林(レイ・ジアリン)詩歌集録 その三

青史青史はいつも青々としており、古往今来は同じです。砂を洗い流す東の流水は、海の中の雲から来ています。潇湘瀟湘の水の中で画舸は軽やかに進み、無数の山が遠くに見え、水と雲の中を進んでいます。寒い風が去りつつあり、杜鵑が咲き始め、山一面が赤と緑で覆われ、まるで…

作者头像 李华
网站建设 2026/4/18 4:52:41

《Python 正则表达式完全指南:从入门到精通》(AI版)

一、引言 正则表达式(Regular Expression,简称 regex 或 regexp)是一种用于匹配字符串中字符组合的模式。在文本处理、数据清洗、网络爬虫、日志分析等领域,正则表达式都是不可或缺的利器。 Python 通过内置的 re 模块提供了对正则表达式的支持,同时也有第三方库如 regex…

作者头像 李华
网站建设 2026/3/14 5:55:39

360度VR全景设备技术测评与行业应用分析

1、三维空间数据采集的技术分野当前&#xff0c;360度VR全景设备已分化为多条清晰的技术路径&#xff0c;其差异远不止于分辨率高低&#xff0c;更在于核心工作原理、最终数据形态及适用的工程化场景。从基于AI的视觉重建&#xff0c;到依赖主动测距的精密扫描&#xff0c;不同…

作者头像 李华