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);
}
相关推荐
minji...1 分钟前
linux 进程控制(一) (fork进程创建,exit进程终止)
linux·运维·服务器·c++·git·算法
埃伊蟹黄面2 分钟前
双指针算法
数据结构·c++·算法
Elias不吃糖5 分钟前
Leetcode-10.正则表达式匹配(暴力 或 记忆暴力)
数据结构·c++·算法·leetcode·深度优先
小年糕是糕手7 分钟前
【C++】类和对象(四) -- 取地址运算符重载、构造函数plus
c语言·开发语言·数据结构·c++·算法·leetcode·蓝桥杯
LXS_35713 分钟前
Day 15 C++之文件操作
开发语言·c++·学习方法·改行学it
无限进步_19 分钟前
基于单向链表的C语言通讯录实现分析
c语言·开发语言·数据结构·c++·算法·链表·visual studio
FMRbpm25 分钟前
栈练习--------有效的括号(LeetCode 20)
数据结构·c++·leetcode·新手入门
獭.獭.31 分钟前
C++ -- STL【list的模拟实现】
c++·stl·list
再睡一夏就好35 分钟前
进程调度毫秒之争:详解Linux O(1)调度与进程切换
linux·运维·服务器·c++·算法·哈希算法
无限进步_37 分钟前
C语言双向循环链表实现详解:哨兵位与循环结构
c语言·开发语言·数据结构·c++·后端·算法·链表