PCL 点云滤波介绍(一)

** 由于采集的点云数据存在噪声,这些噪声不利于对点云后续特征的提取,因此需要通过相应的滤波算法去除噪声数据**

一、体素滤波

体素网格滤波用于对稠密点云进行降采样,其首先把 3D 空间划分成多个很小的体素, 然后将每个体素网格的中心点作为该网格内的唯一点,体素网格滤波可以在减少数据量的同时很好的保留原始点云的几何结构。 PCL 点云库中通过 VoxelGrid 函数进行体素网格滤波,使用 setLeafSize 函数来设置网格的大小, leafSize 越大表示每个网格的体积越大,保留的点云数量越少。

cpp 复制代码
#include <pcl/point_types_conversion.h>
#include <pcl/filters/voxel_grid.h>
 
void DownSample_Filter(pcl::PointCloud<pcl::PointXYZI>::Ptr cloud_in,
                       pcl::PointCloud<pcl::PointXYZI>::Ptr &cloud_downsize,
                       double downsize){
   pcl::VoxelGrid<pcl::PointXYZI> downsample_filter;
   downsample_filter.setLeafSize(downsize, downsize, downsize);
   downsample_filter.setDownsampleAllData(true);    //对全字段进行下采样;
   downsample_filter.setInputCloud(cloud_in);
   downsample_filter.filter(*cloud_downsize);
}

二、均匀采样滤波

均匀采样滤波基本上等同于体素滤波器,但是其不改变点的位置。下采样后,其点云分布基本均匀,但是其点云的准确度要好于体素滤波,因为没有移动点的位置。

cpp 复制代码
#include <pcl/keypoints/uniform_sampling.h>
 
void Uniform_Filter(pcl::PointCloud<pcl::PointXYZI>::Ptr cloud_input,
                    pcl::PointCloud<pcl::PointXYZI>::Ptr &result,
                    float radius)
{
  pcl::UniformSampling<pcl::PointXYZI> sor2;    // 创建均匀采样对象
  sor2.setInputCloud(cloud_input);             //设置需要过滤的点云
  sor2.setRadiusSearch(radius);      //设置滤波时创建的体素体积为1cm的立方体,radius=0.01f
  sor2.filter(*result);             //执行滤波处理,储存输出点云
}

三、双边滤波

双边滤波是一种非线性滤波器,它可以达到保持边缘、降噪平滑的效果。一定程度上拟补了高斯滤波的缺点。双边滤波对高斯噪声效果比较好。双边滤波从单纯的考虑空间域点的位置的高斯滤波上,又加上一个维度上的权重。在点云处理上,可以叫做为特征域,即当前点的法向量与临近点的法向量。

cpp 复制代码
#include <pcl/filters/fast_bilateral.h>
 
 
void Bilateral_Filter(pcl::PointCloud<pcl::PointXYZI>::Ptr cloud_input,
                      pcl::PointCloud<pcl::PointXYZI>::Ptr &result,
                      float sigma_s, float sigma_R )
{
  pcl::FastBilateralFilter<pcl::PointXYZI> filter;
  filter.setInputCloud(cloud_input);
  filter.setSigmaS(sigma_s);        //0.5 空间邻域/窗口设置双边滤波器使用的高斯标准差
  filter.setSigmaR(sigma_R);         //0.0004 设置高斯的标准偏差,用于控制由于强度差,而使相邻像素的权重降低的程度
  filter.applyFilter(*result);
}
相关推荐
向阳@向远方38 分钟前
第二章 简单程序设计
开发语言·c++·算法
Mr_Xuhhh1 小时前
信号与槽的总结
java·开发语言·数据库·c++·qt·系统架构
liulilittle1 小时前
VGW 虚拟网关用户手册 (PPP PRIVATE NETWORK 基础设施)
开发语言·网络·c++·网关·智能路由器·路由器·通信
ruanjiananquan992 小时前
c,c++语言的栈内存、堆内存及任意读写内存
java·c语言·c++
持梦远方3 小时前
C 语言基础入门:基本数据类型与运算符详解
c语言·开发语言·c++
江理不变情3 小时前
图像质量对比感悟
c++·人工智能
apocelipes4 小时前
记一次ADL导致的C++代码编译错误
c++·开发工具和环境
Code Warrior5 小时前
【每日算法】专题五_位运算
开发语言·c++
OneQ66610 小时前
C++讲解---创建日期类
开发语言·c++·算法
Coding小公仔12 小时前
C++ bitset 模板类
开发语言·c++