news 2026/5/3 17:00:38

第八课 Open3D点云数据处理:统计滤波

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
第八课 Open3D点云数据处理:统计滤波

1 统计滤波原理

2 参数说明

2.1 返回滤波后的点云和对应的索引

2.2 提取滤波后的点云(内点)

2.3 提取噪声点云(外点)

3 代码实现

3.1 直接编写代码行

3.2 封装为函数


1 统计滤波原理

三维点云统计滤波(Statistical Outlier Removal Filter)是一种基于统计学原理的滤波方法,其主要思想是使用指定的统计学模型(如高斯分布模型)对点云数据进行建模,并识别出不符合模型的异常点,从而实现去除噪声的效果。具体步骤如下:

对每一点的邻域进行统计分析,基于点到所有邻近点的距离分布特征,过滤掉一些不满足要求的离群点。该算法对整个输入进行两次迭代

在第一次迭代中,

2 参数说明

在Open3D中,可以使用remove_statistical_outlier函数来实现统计滤波。remove_statistical_outlier函数的参数及用法如下:

inlier_cloud, ind = open3d.geometry.PointCloud.remove_statistical_outlier(num_neighbors , std_ratio)

两个输入参数:num_neighborsstd_ratio
两个返回值:inlier_cloudind

其中,open3d.geometry.PointCloud为读取的点云对象pcd,num_neighbors为K近邻的点数;std_ratio为标准差系数。inlier_cloud为最终将滤波后的点云(内点),ind为内点在原始点云中的索引。

2.1 返回滤波后的点云和对应的索引

inlier_cloud, ind = pcd.remove_radius_outlier(num_neighbors , std_ratio)

2.2 提取滤波后的点云(内点)

其实,inlier_cloud就是滤波后的点云。当我们内点索引后,可以根据索引提取内点。

# invert 表示取反,默认False inlier_cloud= pcd.select_by_index(idx, invert = False) # 简写 inlier_cloud = pcd.select_by_index(idx)

2.3 提取噪声点云(外点)

# invert 表示取反,invert = True 时执行取反,即噪声点云 outlier_cloud= pcd.select_by_index(idx,invert = True)

3 代码实现

3.1 直接编写代码行

import open3d as o3d print("-> 正在加载点云...") pcd = o3d.io.read_point_cloud(r"H:\HTempWK\temp\open3d\pointdata\feiji.pcd") # 判断点云是否成功读取 if pcd.is_empty(): print("点云加载失败!") exit(0) print("原始点云:", pcd) # ========================= 统计滤波 ========================= print("-> 正在进行统计滤波...") num_neighbors = 20 # K 邻域点数 std_ratio = 2.0 # 标准差倍数 # 统计离群点移除 inlier_cloud, ind = pcd.remove_statistical_outlier( nb_neighbors=num_neighbors, std_ratio=std_ratio ) print("统计滤波后的点云:", inlier_cloud) # 内点(保留点)设为蓝色 inlier_cloud.paint_uniform_color([0, 0, 1]) # 外点(噪声点)提取 outlier_cloud = pcd.select_by_index(ind, invert=True) print("噪声点云:", outlier_cloud) # 外点设为红色 outlier_cloud.paint_uniform_color([1, 0, 0]) # =========================================================== # 可视化结果 o3d.visualization.draw_geometries( [inlier_cloud, outlier_cloud], window_name="统计滤波结果(蓝色:内点,红色:噪声)" )

3.2 封装为函数

为提高代码复用性,我们将可视化统计滤波后的结果点云和噪声点云封装为一个函数display_inlier_outlier,可以在需要的地方直接调用。

import open3d as o3d import numpy as np # @describe:可视化滤波后的结果点云(内点)和噪声点云(外点) # @param:cloud,原始点云 # @param:ind,内点索引 def display_inlier_outlier(cloud, ind): # 提取内点 inlier_cloud = cloud.select_by_index(ind) # 提取外点 outlier_cloud = cloud.select_by_index(ind, invert=True) # 结果展示 print("Showing outliers (red) and inliers (blue): ") outlier_cloud.paint_uniform_color([1, 0, 0]) inlier_cloud.paint_uniform_color([0, 0, 1]) o3d.visualization.draw_geometries([inlier_cloud, outlier_cloud]) if __name__ == "__main__": # 加载点云 pcd = o3d.io.read_point_cloud(r"H:\HTempWK\temp\open3d\pointdata\feiji.pcd") # 统计滤波 print("Statistical oulier removal") # K 近邻点数 nb_neighbors=20 # 标准差系数 std_ratio=2.0 inlier_cloud, ind = pcd.remove_statistical_outlier(nb_neighbors, std_ratio) display_inlier_outlier(pcd, ind)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:29:39

第十二课Open3D点云数据处理:半径-均值组合滤波

1 半径-均值组合滤波算法原理 1.1 半径滤波原理 1.2 均值滤波原理 2 代码实现 2.1 代码行实现 2.2 将半径-均值组合滤波实现封装到 pointCloud_radius_mean_filter() 函数中 1 半径-均值组合滤波算法原理 1.1 半径滤波原理 1.2 均值滤波原理 需要注意的一点是&#xff1a…

作者头像 李华
网站建设 2026/5/2 5:04:47

深度测评 8个一键生成论文工具:本科生毕业论文痛点全解析

深度测评 8个一键生成论文工具:本科生毕业论文痛点全解析 学术写作工具测评:为何需要一份靠谱的榜单? 随着人工智能技术的不断进步,越来越多的本科生开始依赖AI工具辅助毕业论文的撰写。然而,面对市场上种类繁多的一键…

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

AI一周大事盘点(2025年12月28日~2026年1月3日)

【摘要】2025年岁末至2026年新年伊始,全球AI产业展现出从“技术热点”向“系统性基础设施”深度融合的转型趋势。本周焦点集中于AI算力的硬件与能源创新,以OpenAI联手博通造芯和核能供电数据中心为代表。国内方面,政策治理持续细化&#xff0…

作者头像 李华
网站建设 2026/5/2 22:58:53

zotero7导入插件

从中文社区下载xpi 文件以后,直接导入就可以我们在抓取文献时,经常遇到标题全大写、首字母大小写不规范,或者缺省期刊缩写、大学地点格式不统一的情况。Linter for Zotero 是一个专门用于标准化这些信息的工具。它的核心功能是规范文献条目的…

作者头像 李华
网站建设 2026/5/2 8:51:17

springboot基于地图的智慧旅游景点推荐一体化服务系统vue

目录摘要开发技术核心代码参考示例1.建立用户稀疏矩阵,用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度总结源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!摘要 基于SpringBoot和Vue的智慧旅游景点推荐…

作者头像 李华
网站建设 2026/4/24 12:21:29

分布式计算:大数据领域的高性能解决方案

分布式计算:大数据领域的高性能解决方案 一、引言:当“大数据”遇到“计算瓶颈” 你有没有过这样的经历? 手里握着100GB的用户行为日志,想统计“每个用户的月活跃度”——用本地电脑跑Python脚本,3个小时过去了进度条…

作者头像 李华