news 2026/2/19 12:00:50

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

作者头像

张小明

前端开发工程师

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

1 均值滤波原理

2 与中值滤波对比

3 均值滤波代码实现

3.1 代码行实现

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


1 均值滤波原理

点云均值滤波是将空间中每个点的值替换为其周围点的坐标平均值。具体来说,对于给定点云中的每个点,我们考虑它的邻域,即以该点为中心的一定大小的球体,然后计算该球体内所有点的坐标平均值,最后将该点的坐标值替换为该平均值。这个过程可以重复进行多次,以进一步平滑点云数据。点云均值滤波可以有效地去除噪声和平滑点云数据。

2 与中值滤波对比

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

3 均值滤波代码实现

# axis=0表示对点云取质心,返回一个三维坐标 mean = np.mean(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 # 计算邻域内所有点的坐标平均值 mean = np.mean(np.asarray(pcd.points)[idx], axis=0) # 更新当前点的坐标 np_points[i] = mean # 创建点云对象,存放滤波结果 pcd_mean = o3d.geometry.PointCloud() pcd_mean.points = o3d.utility.Vector3dVector(np_points) # 打印点云信息 print('原始点云:',pcd) print('滤波点云:',pcd_mean) # 可视化滤波结果 pcd.paint_uniform_color([1,0,0]) pcd_mean.paint_uniform_color([0,1,0]) o3d.visualization.draw_geometries([pcd,pcd_mean], width=1200, height=800, window_name = '均值滤波-原始点云(红),滤波点云(绿)')

3.2 将均值滤波的实现封装到函数pointCloud_mean_filter()

import open3d as o3d import numpy as np """ @describe: 点云均值滤波 @param[I]: pointCloud, 待滤波点云 @param[I]: radius, 滤波窗口半径 @return: pointCloud_mean: 均值滤波结果点云 """ def pointCloud_mean_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 # 计算邻域内所有点的坐标平均值 mean = np.mean(np.asarray(pcd.points)[idx], axis=0) # 更新当前点的坐标 np_points[i] = mean # 创建点云对象,存放滤波结果 pointCloud_mean= o3d.geometry.PointCloud() pointCloud_mean.points = o3d.utility.Vector3dVector(np_points) # 返回滤波结果点云 return pointCloud_mean if __name__ == "__main__": # 读取点云文件 pcd = o3d.io.read_point_cloud("data\desk.pcd") # 定义均值滤波窗口半径 radius = 0.05 # 创建点云对象,存放滤波结果 pcd_mean = o3d.geometry.PointCloud() # 执行均值滤波 pcd_mean = pointCloud_mean_filter(pcd,radius) # 打印点云信息 print('原始点云:',pcd) print('滤波点云:',pcd_mean) # 可视化滤波结果 pcd.paint_uniform_color([1,0,0]) pcd_mean.paint_uniform_color([0,1,0]) o3d.visualization.draw_geometries([pcd,pcd_mean], width=1200, height=800, window_name = '均值滤波-原始点云(红),滤波点云(绿)')
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/18 7:39:57

基于Android的宠物社区app设计与实现(源码+lw+部署文档+讲解等)

课题介绍本课题聚焦宠物主人社交需求分散、宠物养护知识获取不系统、宠物相关服务对接不畅等痛点&#xff0c;设计并实现一款基于Android的宠物社区APP&#xff0c;旨在为宠物主人搭建集中化的交流互动平台&#xff0c;同时整合宠物相关资源&#xff0c;提供全面的宠物服务支持…

作者头像 李华
网站建设 2026/2/16 3:35:23

Memcached单条数据极限有多大?内存数据库的存储边界解析

文章目录Memcached 最大能存储多大的单个 Item&#xff1f;前言第一部分&#xff1a;Memcached 是什么&#xff1f;第二部分&#xff1a;Memcached 的内存分配机制SlabAllocator 是什么&#xff1f;Slab 分类第三部分&#xff1a;单个 Item 的最大存储容量默认情况下的限制如何…

作者头像 李华
网站建设 2026/2/19 4:37:08

Agentic AI开发工具对比:提示工程架构师的选择指南,前景与挑战

Agentic AI开发工具对比&#xff1a;提示工程架构师的选择指南&#xff0c;前景与挑战 引言 背景介绍 在人工智能飞速发展的当下&#xff0c;Agentic AI&#xff08;具身智能体人工智能&#xff09;逐渐崭露头角。Agentic AI强调智能体能够自主地感知环境、做出决策并采取行动&…

作者头像 李华
网站建设 2026/2/13 14:12:47

一棵树里藏了多少“自己人”?——聊聊《统计同值子树》背后的递归哲学

一棵树里藏了多少“自己人”?——聊聊《统计同值子树》背后的递归哲学 大家好,我是 Echo_Wish。 今天咱不聊分布式、不聊大模型,回到一个看似朴素、但非常能体现算法功力的题目: 👉 统计同值子树(Count Univalue Subtrees) 这道题在 LeetCode 上不算“天花板难度”,…

作者头像 李华
网站建设 2026/2/17 12:07:55

提示工程架构师必收藏:安全标准实施框架

提示工程架构师必看:安全标准实施框架设计与落地指南 副标题:从风险识别到持续运营的全流程实践 摘要/引言 当我们用提示工程(Prompt Engineering)构建LLM应用时,“安全”往往是最容易被忽略却最致命的环节: 攻击者可以用“忽略之前的指令”这样的Prompt Injection篡改…

作者头像 李华