PCl 区域增长算法

 一、区域增长算法(Region growing segmentation)

        在本教程中,我们将学习如何使用在 pcl::RegionGrowing 类中实现的区域增长算法。所述算法的目的是合并在平滑度约束方面足够接近的点。因此,此算法的输出是一组聚类,其中每个聚类是一组被视为同一光滑表面一部分的点。该算法的工作基于点法线之间角度的比较。

二、理论入门

        让我们来看看算法是如何工作的。

        首先,它根据曲率值对点进行排序。它需要完成,因为该区域从具有最小曲率值的点开始增长。这样做的原因是曲率最小的点位于平坦区域(从最平坦区域增长可以减少分段总数)。所以我们有分类的云。直到云中没有未标记的点,算法选择具有最曲率值小的点并开始区域的增长。这个过程发生如下:拾取的点被添加到称为种子的集合中。对于每个种子点,该算法都会找到它的相邻点。测试每个邻居的法线与当前种子点法线之间的角度。如果角度小于阈值,则将当前点添加到当前区域。之后,测试每个邻居的曲率值。如果曲率小于阈值,则将此点添加到种子中。从种子中删除当前种子。如果种子集变为空,则意味着算法已增大该区域,并且从头开始重复该过程。您可以在下面找到所述算法的伪代码。

Inputs

Initialize:

Algorithm:

三、代码 

#include <iostream>
#include <vector>
#include <pcl/point_types.h>
#include <pcl/io/pcd_io.h>
#include <pcl/search/search.h>
#include <pcl/search/kdtree.h>
#include <pcl/features/normal_3d.h>
#include <pcl/visualization/cloud_viewer.h>
#include <pcl/filters/filter_indices.h> // for pcl::removeNaNFromPointCloud
#include <pcl/segmentation/region_growing.h>

int
main ()
{
  pcl::PointCloud<pcl::PointXYZ>::Ptr cloud (new pcl::PointCloud<pcl::PointXYZ>);
  if ( pcl::io::loadPCDFile <pcl::PointXYZ> ("../nono_filtered_inliers.pcd", *cloud) == -1)
 {
   std::cout << "Cloud reading failed." << std::endl;
  return (-1);
 }

 pcl::search::Search<pcl::PointXYZ>::Ptr tree (new pcl::search::KdTree<pcl::PointXYZ>);
 pcl::PointCloud <pcl::Normal>::Ptr normals (new pcl::PointCloud <pcl::Normal>);
 pcl::NormalEstimation<pcl::PointXYZ, pcl::Normal> normal_estimator;
 normal_estimator.setSearchMethod (tree);
 normal_estimator.setInputCloud (cloud);
 normal_estimator.setKSearch (50);
 normal_estimator.compute (*normals);

 pcl::IndicesPtr indices (new std::vector <int>);
 pcl::removeNaNFromPointCloud(*cloud, *indices);

 pcl::RegionGrowing<pcl::PointXYZ, pcl::Normal> reg;
 reg.setMinClusterSize (1000);
 reg.setMaxClusterSize (1000000);
 reg.setSearchMethod (tree);
 reg.setNumberOfNeighbours (30);
 reg.setInputCloud (cloud);
 reg.setIndices (indices);
 reg.setInputNormals (normals);
 reg.setSmoothnessThreshold (4.0 / 180.0 * M_PI);
 reg.setCurvatureThreshold (1.0);

 std::vector <pcl::PointIndices> clusters;
  reg.extract (clusters);

  std::cout << "Number of clusters is equal to " << clusters.size () << std::endl;
 std::cout << "First cluster has " << clusters[0].indices.size () << " points." << std::endl;
 std::cout << "These are the indices of the points of the initial" <<
  std::endl << "cloud that belong to the first cluster:" << std::endl;
 std::size_t counter = 0;
 while (counter < clusters[0].indices.size ())
 {
    std::cout << clusters[0].indices[counter] << ", ";
   counter++;
    if (counter % 10 == 0)
     std::cout << std::endl;
 }
 std::cout << std::endl;

  pcl::PointCloud <pcl::PointXYZRGB>::Ptr colored_cloud = reg.getColoredCloud ();
 pcl::visualization::CloudViewer viewer ("Cluster viewer");
  viewer.showCloud(colored_cloud);
  while (!viewer.wasStopped ())
  {
  }

  return (0);
}

四、解释

  reg.setSmoothnessThreshold (4.0 / 180.0 * M_PI);
  reg.setCurvatureThreshold (1.0);

这两行是算法初始化中最重要的部分,因为它们负责上述平滑度约束。第一种方法设置弧度角度,该角度将用作法线偏差的允许范围。如果点法线之间的偏差小于平滑度阈值,则建议它们位于同一聚类中(新点 - 测试点 - 将添加到聚类中)。第二个负责曲率阈值。如果两个点的法线偏差很小,则测试它们曲率之间的差异。如果该值小于曲率阈值,则算法将使用新添加的点继续集群的增长。  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
PCL区域增长分割是一种基于点云数据的分割算法。该算法通过对点云数据进行聚类分析,将相邻的点分为同一区域,从而实现对点云的分割。 在PCL区域增长分割算法,首先需要定义种子点。种子点是用作分割起始点的点。可以根据点云数据的某些属性,比如颜色、法线等来选择种子点。然后,从种子点开始,利用邻域搜索的方法,逐步扩展分割区域。邻域搜索是指以种子点为心,搜索周围一定范围内的点。如果周围点与种子点相似,则将其归为同一区域PCL区域增长分割算法的核心在于如何确定相似性。一般地,通过计算两个点之间的相似度来判断它们是否属于同一区域。相似度可以由颜色、法线或距离等属性来衡量。具体选择哪些属性作为相似性的标准,取决于具体的应用场景。 PCL区域增长分割算法的优点是简单而高效。它可以应用于各种类型的点云数据,包括室内外场景、目标检测、三维重建等。此外,该算法还具有较好的鲁棒性,即使在存在噪声和部分点缺失的情况下,也能得到较好的分割结果。 总结起来,PCL区域增长分割是一种基于点云数据的分割算法,可以用于将相邻的点分为同一区域。它通过定义种子点、邻域搜索和相似度计算来实现分割。该算法简单高效,适用于各种点云数据处理的应用场景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小小蜗牛,大大梦想

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

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

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

打赏作者

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

抵扣说明:

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

余额充值