PCL :实现快速双边滤波
下面是一个使用PCL库实现快速双边滤波的示例代码:
c++
#include <pcl/point_types.h>
#include <pcl/io/pcd_io.h>
#include <pcl/filters/fast_bilateral.h>
int main()
{
// 加载点云
pcl::PointCloud<pcl::PointXYZRGB>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZRGB>);
pcl::io::loadPCDFile<pcl::PointXYZRGB>("input_cloud.pcd", *cloud);
// 创建快速双边滤波器
pcl::FastBilateralFilter<pcl::PointXYZRGB> bilateralFilter;
bilateralFilter.setInputCloud(cloud);
// 设置参数
float sigmaS = 10.0f; // 空间域标准差
float sigmaR = 0.1f; // 强度域标准差
bilateralFilter.setSigmaS(sigmaS);
bilateralFilter.setSigmaR(sigmaR);
// 进行快速双边滤波
pcl::PointCloud<pcl::PointXYZRGB>::Ptr filteredCloud(new pcl::PointCloud<pcl::PointXYZRGB>);
b