PCL学习笔记,区域生长分割(region growing segmentation)

2023-10-27

在本博文中,我主要介绍如何在pcl::RegionGrowing类中调用区域增长算法。首先注意一点,这里是region growing segmentation,不是color-based region growing segmentation.

算法核心:该算法是基于点法线之间角度的比较,企图将满足平滑约束的相邻点合并在一起,以一簇点集的形式输出。每簇点集被认为是属于相同平面。

工作原理:首先需要明白,区域增长是从有最小曲率值(curvature value)的点开始的。因此,我们必须计算出所有曲率值,并对它们进行排序。这是因为曲率最小的点位于平坦区域,而从最平坦的区域增长可以减少区域的总数。现在我们来具体描述这个过程:

1.点云中有未标记点,按照点的曲率值对点进行排序,找到最小曲率值点,并把它添加到种子点集;

2.对于每个种子点,算法都会发现周边的所有近邻点。1)计算每个近邻点与当前种子点的法线角度差(reg.setSmoothnessThreshold),如果差值小于设置的阈值,则该近邻点被重点考虑,进行第二步测试;2)该近邻点通过了法线角度差检验,如果它的曲率小于我们设定的阈值(reg.setCurvatureThreshold),这个点就被添加到种子点集,即属于当前平面。

3.通过两次检验的点,被从原始点云去除。

4.设置最小点簇的点数min(reg.setMinClusterSize),最大点簇为max(reg.setMaxClusterSize)。

4.重复1-3步,算法会生成点数在min和max的所有平面,并对不同平面标记不同颜色加以区分。

5.直到算法在剩余点中生成的点簇不能满足min,算法停止工作。

算法具体的伪码表示:http://pointclouds.org/documentation/tutorials/region_growing_segmentation.php#region-growing-segmentation

实现算法的工程文件中的代码,.cpp:

#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/passthrough.h>
#include <pcl/segmentation/region_growing.h>

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

  pcl::search::Search<pcl::PointXYZ>::Ptr tree = boost::shared_ptr<pcl::search::Search<pcl::PointXYZ> > (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::PassThrough<pcl::PointXYZ> pass;
  pass.setInputCloud (cloud);
  pass.setFilterFieldName ("z");
  pass.setFilterLimits (0.0, 1.0);
  pass.filter (*indices);

  pcl::RegionGrowing<pcl::PointXYZ, pcl::Normal> reg;
  reg.setMinClusterSize (50);
  reg.setMaxClusterSize (1000000);
  reg.setSearchMethod (tree);
  reg.setNumberOfNeighbours (30);
  reg.setInputCloud (cloud);
  //reg.setIndices (indices);
  reg.setInputNormals (normals);
  reg.setSmoothnessThreshold (3.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." << endl;
  std::cout << "These are the indices of the points of the initial" <<
    std::endl << "cloud that belong to the first cluster:" << std::endl;
  int 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);
}
注释:

      1.文件输入、输出最好使用绝对路径;

      2.代码中涉及到的参数:

             setKSearch(): 这是在计算点的法线时,设置邻域内需要多少点来模拟平面计算法线。法线计算:http://geometryhub.net/notes/pointcloudnormal

                       setMInClusterSize()   setMaxClusterSize() 原理中已经提到

                       setNumberOfneighbours() 指的是区域增长时种子点附近纳入检验的点数

                       setSmoothnessThreshold()  setCurvatureThreshold()   原理中已经提到。这两个阈值的设置尤其重要,它们是region growing segmentation的核心。

      3.注意,输入点点类型为 pcl::PointCloud<pcl::PointXYZ>,输出点为pcl::PointXYZRGB,因为分割完之后不同平面信息被 不同颜色标记,而被抛弃的点被红色标记。如下图所示。点类型根据读者输入的点云数据包含的列信息而定,在此不在详细解释。

            

       4.cmake文件参照如下:

              

cmake_minimum_required(VERSION 2.8 FATAL_ERROR)

project(region_growing_segmentation)

find_package(PCL 1.5 REQUIRED)

include_directories(${PCL_INCLUDE_DIRS})
link_directories(${PCL_LIBRARY_DIRS})
add_definitions(${PCL_DEFINITIONS})

add_executable (region_growing_segmentation region_growing_segmentation.cpp)
target_link_libraries (region_growing_segmentation ${PCL_LIBRARIES})
                

  最后,区域增长算法已经是比较老的平面分割算法。希望大家能提出更好的算法。
————————————————
版权声明:本文为CSDN博主「爱水人家」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/aishuirenjia/article/details/80239562

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

PCL学习笔记,区域生长分割(region growing segmentation) 的相关文章

  • Leetcode 122:买卖股票二

    题目描述 题目连接 与第一次的题目相比 可以多次买卖等情况 只要求出最大利润即可 可以将一次买卖分为过个过程即可 1 2 3 4 5 比如正常情况下是第一天买进 第五天卖出 但这个过程可以分解为多次买进卖出 在第一天买进 第二天卖出 获得利
  • Meshlab源码编译 VS2013+QT5.8.0

    有了前面的配置基础 VS2013 QT5 8 0配置 接下来我们来编译源码 1 下载meshlab源码 我以 meshlab 32bit v 1 3 3 为例 利用它的源代码 MeshLabSrc AllInc v133 tgz 详细给出编

随机推荐

  • 关于TypeError: decode() argument ‘encoding‘ must be str, not None 的三种解决方法

    使用Scrapy Redis时 有一个常见的错误可能会让你烦恼不已 TypeError decode argument encoding must be str not None 这是因为Scrapy Redis在从Redis队列中读取请求
  • Fiddler新版全平台适配抓包,关键还免费,再也不用费劲找破解版了

    Fiddler Everywhere是适用于macOS Windows和Linux的安全且现代化的web调试代理 他可以捕获 检查 监视计算机与Internet之间的所有HTTP S 流量 并且可以mock请求 并诊断网络问题 这种方法既简
  • 水仙花数(c语言程序实现)

    描述 请判断一个数是不是水仙花数 其中水仙花数定义各个位数立方和等于它本身的三位数 输入 有多组测试数据 每组测试数据以包含一个整数n 100 lt n lt 1000 输入0表示程序输入结束 输出 如果n是水仙花数就输出Yes 否则输出N
  • 里面如何配置库_沙龙回顾

    随着自动驾驶技术不断发展 Apollo 已经从研发走向量产产品落地 作为 Apollo 开源软件平台的一部分 Apollo Cyber RT处于底层的实时操作系统 RTOS 和算法模块之间 能够在保证高吞吐的情况下 又能低延迟的实时响应上层
  • thinkbook14+(thinkbook16+) 屏幕亮度忽明忽暗

    thinkbook14 thinkbook16 在断开电源线的情况下 屏幕会时不时忽明忽暗 非常恶心 查了半天 才在贴吧找到如何解决这个问题 开始菜单里搜索英特尔显卡控制中心 在系统选项里有个功率 功率里有个显示器节能 关掉就好了
  • Hyperledger Fabric 入门笔记(三)Fabric V2.4 环境搭建

    文章目录 前言 一 基本概念 1 1 虚拟机 1 2 虚拟机软件 二 虚拟机相关 2 1 VirualBox7安装Ubuntu 2 2 Vmware安装Ubuntu 2 3 Ubuntu的使用 2 3 1 软件包管理器 2 3 1 1 yu
  • vue汉字转拼音-pinyin.js

    需求 用户在输入姓和名字的时候 由于姓 拼音 和名 拼音 为字母 容易输错 于是就有了自动生成拼音这个需求 npm install安装的四种用法 save和 save dev npm install xxx 安装项目到项目目录下 不会将模块
  • 软件工程基础知识-软件质量

    软件质量是指反映软件系统或软件产品满足规定或隐含要求的能力的特征和特性全体 软件质量保证是为保证软件系统或软件产品充分满足用户要求的质量而进行的有计划 有组织的活动 其目的是生产该质量的软件 一 软件质量特性 二 软件质量保证 三 软件评审
  • spring集成Junit4配置

    这两天做Web开发 发现通过Spring进行对象管理之后 做测试变得复杂了 因为所有的Bean都需要在applicationContext xml中加载好 之后再通过 Resource去取得 如果每次都要整个业务流做的差不多了再去测试 这样
  • OpenCV-Python图形图像处理专栏文章目录

    前往老猿Python博客 https blog csdn net LaoYuanPython 注 1 部分文章前面标星号表示文章为付费专栏文章 2 本专栏的伴生付费专栏 https blog csdn net LaoYuanPython a
  • hadoop实践(三)hadoop 集群配置

    第一步 集群规划 master 192 168 136 140 slave1 192 168 136 151 slave2 192 168 136 152 第二步 配置环境变量 1 vi etc profile 在最后面添加如下代码 exp
  • 【定量分析、量化金融与统计学】R语言方差分析ANOVA(F检验)

    目录 一 前言 Fixed effects models Random effects models Mixed effects models 二 ANOVA使用的前提假设与假设检验 三 ANOVA的计算原理 四 事后检验与交叉图 五 R语
  • vue添加公用方法及使用

    为vue添加公用方法 vue添加通用方法 common js var common function return f1 function console log this is common f1 f2 function console
  • Windows共享文件夹,让你的文件可以通过网络访问

    Windows共享文件夹 让你的文件可以通过网络访问 以windows11为例 现在有两台windows电脑A和B B想通过网络访问A的某个文件 首先保证B是可以ping的通A的 比如共享A的D盘文件夹给B访问 下面是详细步骤 A电脑的操作
  • 等价类划分法

    一 什么是等价类划分法 1 等价类划分法是一种重要的 常用的黑盒测试方法 它将不能穷举的测试过程进行合理分类 从而保证设计出来的测试用例具有完整性和代表性 2 等价类划分法是把所有可能的输入数据 即程序的输入划分成若干部分 子集 然后从每一
  • YOLOv1的原理及实现过程

    YOLO v1的原理及实现过程 目标检测是一件比较实际的且具有挑战性的计算机视觉任务 其可以看成图像分类与定位的结合 给定一张图片 目标检测系统要能够识别出图片的目标并给出其位置 由于图片中目标数是不定的 且要给出目标的精确位置 目标检测相
  • C# EntityFrameworkCore 分页

    使用 public static PagedList
  • 深入浅出分析Electron自动升级electron-updater + electron-builder配置

    自动升级的方式有很多种 我们公司第一版是使用fs做文件的下载和替换 但是存在C programfile的权限问题 因此只好更换技术方案 使用Electron builder结合updater实现自动升级功能 一 electron build
  • mysql 取绝对值_自学MySQL第六天

    今天先学习了一些内置的numeric function 第一个ROUND 顾名思义近似 四舍五入的方式呈现数值 可以选保留几位小数 如图所示 第二个TRUNCATE 不用四舍五入 强行取指定位数小数 如图 第三个CEILING 返回大于括号
  • PCL学习笔记,区域生长分割(region growing segmentation)

    在本博文中 我主要介绍如何在pcl RegionGrowing类中调用区域增长算法 首先注意一点 这里是region growing segmentation 不是color based region growing segmentatio