点云降采样--VoxelGrid和ApproximateVoxelGrid降采样区别

1.版本要求

版本: >PCL1.0

2.简介

VoxelGrid体素降采样和ApproximateVoxelGrid体素降采样是PCL开源库中非常有效的点云降采样手段。
两者的区别在于:
VoxelGrid以体素栅格重心来代表这个立方体,下采样速度相比ApproximateVoxelGrid慢一些,但更好地保留了原始点云的局部形态特征。
ApproximateVoxelGrid以体素栅格中心点来代表这个立方体,下采样速度相比VoxelGrid快一些,但也损失了更多原始点云的局部形态特征。
ApproximateVoxelGrid降采样后点云数量比VoxelGrid降采样后点云数量多,造成这种结果的原因是ApproximateVoxelGrid是依据每一个体素的中心点来获取点云的,并不是依赖每个体素里面是否存在点云。

3.数据

本例中使用的点云数据(test.pcd)请见百度网盘分享。
链接:https://pan.baidu.com/s/1fNgXCpRwIcYSPxL1vGvt-g
提取码:dwkc

4.代码

#include <pcl/io/pcd_io.h>
#include <pcl/point_types.h>
#include <pcl/point_cloud.h>
#include <pcl/visualization/cloud_viewer.h>
#include <pcl/filters/voxel_grid.h>
#include <pcl/filters/approximate_voxel_grid.h>
#include <string>
#include <sstream>

int main(int argc, char**argv)
{
	//读入测试点云test.pcd
	pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);
	pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_VoxelGrid_downsample(new pcl::PointCloud<pcl::PointXYZ>);
	pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_ApproximateVoxelGrid_downsample(new pcl::PointCloud<pcl::PointXYZ>);
	pcl::io::loadPCDFile("test.pcd", *cloud);

	//创建VoxelGrid体素降采样对象
	pcl::VoxelGrid<pcl::PointXYZ> vg_01;
	vg_01.setInputCloud(cloud);
	vg_01.setLeafSize(0.15f, 0.15f, 0.15f);  //设置体素大小为0.15m x 0.15m x 0.15m
	vg_01.filter(*cloud_VoxelGrid_downsample);
	
	//创建ApproximateVoxelGrid体素降采样对象
	pcl::ApproximateVoxelGrid<pcl::PointXYZ> vg_02;
	vg_02.setInputCloud(cloud);
	vg_02.setLeafSize(0.15f, 0.15f, 0.15f);  //设置体素大小为0.15m x 0.15m x 0.15m
	vg_02.filter(*cloud_ApproximateVoxelGrid_downsample);

	//输出降采样前的点云数量和降采样后的点云数量
	std::cout << "points quantity before voxel downsample:" << cloud->size()<<std::endl
				<<"points quantity after VoxelGrid downsample:" << cloud_VoxelGrid_downsample->size() << std::endl
					<< "points quantity after ApproximateVoxelGrid downsample:" << cloud_ApproximateVoxelGrid_downsample->size() << std::endl;

	//对比显示两种体素降采样效果
	pcl::visualization::PCLVisualizer viewer("Cloud Viewer");
	int v1(0);  //创建左窗口显示VoxelGrid降采样结果
	viewer.createViewPort(0, 0, 0.5, 1.0, v1);  //左右窗口大小划分,1:1
	viewer.setBackgroundColor(0, 0, 0, v1);
	viewer.addText("VoxelGrid Downsample", 2, 2, "VoxelGrid Downsample", v1);
	pcl::visualization::PointCloudColorHandlerGenericField<pcl::PointXYZ> rgb1(cloud_VoxelGrid_downsample, "z");
	viewer.addPointCloud<pcl::PointXYZ>(cloud_VoxelGrid_downsample, rgb1, "VoxelGrid downsample", v1);
	viewer.setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE, 1, "VoxelGrid downsample", v1);
	viewer.addCoordinateSystem(1.0, "VoxelGrid downsample", v1);
	int v2(1);  //创建右窗口显示ApproximateVoxelGrid降采样结果
	viewer.createViewPort(0.5, 0, 1.0, 1.0, v2);  //左右窗口大小划分,1:1
	viewer.setBackgroundColor(0, 0, 0, v2);
	viewer.addText("ApproximateVoxelGrid Downsample", 2, 2, "ApproximateVoxelGrid Downsample", v2);
	pcl::visualization::PointCloudColorHandlerGenericField<pcl::PointXYZ> rgb2(cloud_ApproximateVoxelGrid_downsample, "z");
	viewer.addPointCloud<pcl::PointXYZ>(cloud_ApproximateVoxelGrid_downsample, rgb2, "ApproximateVoxelGrid downsample", v2);
	viewer.setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE, 1, "ApproximateVoxelGrid downsample", v2);
	viewer.addCoordinateSystem(1.0, "ApproximateVoxelGrid downsample", v2);

	viewer.spin();

	return 0;
}

5.效果

左图为VoxelGrid降采样结果,右图为ApproximateVoxelGrid降采结果。
在这里插入图片描述
原始点云数量,ApproximateVoxelGrid降采样后点云数量,VoxelGrid降采样后点云数量。可以看到ApproximateVoxelGrid降采样后点云数量比VoxelGrid降采样后点云数量多。
在这里插入图片描述

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
PCL(Point Cloud Library)是一个开源的点云处理库,提供了丰富的点云处理算法和工具。点云降采样点云处理中的一项重要任务,它可以减少点云数据的数量,从而降低计算和存储的成本,并且可以去除一些噪声点。 在PCL中,点云降采样可以通过使用VoxelGrid滤波器来实现。VoxelGrid滤波器将点云划分为一个个体素(或称为体素格子),然后对每个体素内的点进行采样,只保留一个代表性的点作为该体素的代表点。这样就可以将原始的稠密点云转换为稀疏的点云,从而实现降采样的效果。 以下是使用PCL进行点云降采样的步骤: 1. 创建一个VoxelGrid滤波器对象。 2. 设置滤波器的输入点云数据。 3. 设置滤波器的体素大小,即决定了降采样后的点云密度。 4. 调用滤波器的filter()函数进行降采样操作。 5. 获取滤波器的输出点云数据。 下面是一个示例代码片段,展示了如何使用PCL进行点云降采样: ```cpp #include <pcl/point_cloud.h> #include <pcl/filters/voxel_grid.h> int main() { // 创建点云对象 pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>); // 读取点云数据 // 创建VoxelGrid滤波器对象 pcl::VoxelGrid<pcl::PointXYZ> voxelGrid; // 设置输入点云数据 voxelGrid.setInputCloud(cloud); // 设置体素大小 voxelGrid.setLeafSize(0.01f, 0.01f, 0.01f); // 体素大小为1cm // 执行降采样操作 pcl::PointCloud<pcl::PointXYZ>::Ptr filteredCloud(new pcl::PointCloud<pcl::PointXYZ>); voxelGrid.filter(*filteredCloud); // 获取降采样后的点云数据 return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

恒怡爱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值