pcl点云聚类后的点云索引提取与输出pcd聚类结果

在完成PCL基于欧式聚类、区域增长、或者圆柱体分割等图像分割算法后,怎么样输出聚类,提取聚类
我的上一篇文章中,使用区域增长算法将兔子点云划分了22个区域PCL下使用区域增长算法进行点云平面分割的实现
划分完后,怎样将这些聚类的点云分别输出不同的pcd文件呢,先参考了这篇文章
pcl点云聚类方法

这篇文章完全是抄的点云库pcl教程里的例子,而且没抄全,书里是用cmake做,而我这里不是,故代码也不太一样,然后参考了PCL入门<六>使用Region growing进行平面分割
在PCL中实现欧氏聚类提取
这篇也写得不全,故决定自己写一段按照索引将点云聚类算法分割结果输出为不同的pcd文件

//迭代访问点云索引clusters,直到分割出所有聚类 
	int i= 0;
	for (std::vector<pcl::PointIndices>::const_iterator it = clusters.begin(); it != clusters.end(); ++it)
	{
		pcl::PointCloud<pcl::PointXYZ>::Ptr cluster(new pcl::PointCloud<pcl::PointXYZ>);

		//创建新的点云数据集cloud_cluster,将所有当前聚类写入到点云数据集中 

		for (std::vector<int>::const_iterator pit = it->indices.begin(); pit != it->indices.end(); ++pit)

		cluster->points.push_back(cloud->points[*pit]);
		cluster->width = cluster->points.size();
		cluster->height = 1;
		cluster->is_dense = true;

		//保存聚类结果
		if (cluster->points.size() <= 0)
			break;

		std::cout << "点云" << cluster->points.size() << "有这么多点" << std::endl;
		std::stringstream ss;
		ss << "索引" << j << ".pcd";
		pcl::io::savePCDFile(ss.str(), *cluster);


		i++;

	}

跑完这段代码,就会在当前文件夹下输出你聚类的结果。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

菜是菜人是真帅

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

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

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

打赏作者

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

抵扣说明:

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

余额充值