• pcl基于颜色的区域增长点云分割


    在本教程中,我们将学习如何使用pcl::RegionGrowingRGB类实现的基于颜色的区域增长算法。该算法基于与区域增长分割教程pcl::RegionGrowing中描述的相同概念。

    基于颜色的算法有两个主要区别。第一个是它使用颜色而不是法线。第二个是它使用合并算法进行过分割和欠分割控制。让我们来看看它是如何完成的。分割后,尝试合并颜色相近的簇。将平均颜色差异较小的两个相邻簇合并在一起。然后进行第二个合并步骤。在此步骤中,每个集群都通过其包含的点数进行验证。如果此数字小于用户定义的值,则当前集群将与最近的相邻集群合并。

    源码:

    创建 region_growing_rgb_segmentation.cpp 文件

    1. 1#include <iostream>
    2. 2#include <thread>
    3. 3#include <vector>
    4. 4
    5. 5#include <pcl/point_types.h>
    6. 6#include <pcl/io/pcd_io.h>
    7. 7#include <pcl/search/search.h>
    8. 8#include <pcl/search/kdtree.h>
    9. 9#include <pcl/visualization/cloud_viewer.h>
    10. 10#include <pcl/filters/filter_indices.h> // for pcl::removeNaNFromPointCloud
    11. 11#include <pcl/segmentation/region_growing_rgb.h>
    12. 12
    13. 13using namespace std::chrono_literals;
    14. 14
    15. 15int
    16. 16main ()
    17. 17{
    18. 18 pcl::search::Search <pcl::PointXYZRGB>::Ptr tree (new pcl::search::KdTree<pcl::PointXYZRGB>);
    19. 19
    20. 20 pcl::PointCloud <pcl::PointXYZRGB>::Ptr cloud (new pcl::PointCloud <pcl::PointXYZRGB>);
    21. 21 if ( pcl::io::loadPCDFile <pcl::PointXYZRGB> ("region_growing_rgb_tutorial.pcd", *cloud) == -1 )
    22. 22 {
    23. 23 std::cout << "Cloud reading failed." << std::endl;
    24. 24 return (-1);
    25. 25 }
    26. 26
    27. 27 pcl::IndicesPtr indices (new std::vector <int>);
    28. 28 pcl::removeNaNFromPointCloud (*cloud, *indices);
    29. 29
    30. 30 pcl::RegionGrowingRGB<pcl::PointXYZRGB> reg;
    31. 31 reg.setInputCloud (cloud);
    32. 32 reg.setIndices (indices);
    33. 33 reg.setSearchMethod (tree);
    34. 34 reg.setDistanceThreshold (10);
    35. 35 reg.setPointColorThreshold (6);
    36. 36 reg.setRegionColorThreshold (5);
    37. 37 reg.setMinClusterSize (600);
    38. 38
    39. 39 std::vector <pcl::PointIndices> clusters;
    40. 40 reg.extract (clusters);
    41. 41
    42. 42 pcl::PointCloud <pcl::PointXYZRGB>::Ptr colored_cloud = reg.getColoredCloud ();
    43. 43 pcl::visualization::CloudViewer viewer ("Cluster viewer");
    44. 44 viewer.showCloud (colored_cloud);
    45. 45 while (!viewer.wasStopped ())
    46. 46 {
    47. 47 std::this_thread::sleep_for(100us);
    48. 48 }
    49. 49
    50. 50 return (0);
    51. 51}

    说明:
    1、相关的头文件

    1. 1#include <iostream>
    2. 2#include <thread>
    3. 3#include <vector>
    4. 4
    5. 5#include <pcl/point_types.h>
    6. 6#include <pcl/io/pcd_io.h>
    7. 7#include <pcl/search/search.h>
    8. 8#include <pcl/search/kdtree.h>
    9. 9#include <pcl/visualization/cloud_viewer.h>
    10. 10#include <pcl/filters/filter_indices.h> // for pcl::removeNaNFromPointCloud
    11. 11#include <pcl/segmentation/region_growing_rgb.h>
    12. 12
    13. 13using namespace std::chrono_literals;
    14. 14

    2、从 .pcd 文件加载云。注意点必须有颜色。

    1. pcl::PointCloud <pcl::PointXYZRGB>::Ptr cloud (new pcl::PointCloud <pcl::PointXYZRGB>);
    2. if ( pcl::io::loadPCDFile <pcl::PointXYZRGB> ("region_growing_rgb_tutorial.pcd", *cloud) == -1 )
    3. {
    4. std::cout << "Cloud reading failed." << std::endl;
    5. return (-1);
    6. }

    3、该行负责pcl::RegionGrowingRGB实例化。这个类有两个参数:

    • PointT - 要使用的点的类型(在给定的示例中是pcl::PointXYZRGB

    • NormalT - 要使用的法线类型。就pcl::RegionGrowingRGB派生自pcl::RegionGrowing而言,它可以同时使用两种测试:颜色测试和正常测试。给定的示例仅使用第一个,因此不使用法线类型。

     pcl::RegionGrowingRGB<pcl::PointXYZRGB> reg;

    4、这些行为实例提供了输入云、索引和搜索方法。

    1. reg.setInputCloud (cloud);
    2. reg.setIndices (indices);
    3. reg.setSearchMethod (tree);

    5、这里设置了距离阈值。它用于确定该点是否相邻。如果该点位于小于给定阈值的距离处,则认为它是相邻的。它用于集群邻居搜索。

      reg.setDistanceThreshold (10);

    6、此行设置颜色阈值。正如角度阈值用于测试点法线pcl::RegionGrowing 以确定该点是否属于集群一样,该值用于测试点颜色。

      reg.setPointColorThreshold (6);

    7、这里设置了集群的颜色阈值。此值与前一个值相似,但在合并过程发生时使用。

      reg.setRegionColorThreshold (5);

    8、该值类似于区域增长分割教程中使用的值。除此之外,它还用于开头提到的合并过程。如果集群的点数少于通过setMinClusterSize方法设置的点数,则它将与最近的邻居合并

      reg.setMinClusterSize (600);

    9、这里是启动算法的地方。当分割过程结束时,它将返回集群数组。

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

    10、剩余的行负责彩色云的可视化,其中每个集群都有自己的颜色。

    1. 42 pcl::PointCloud <pcl::PointXYZRGB>::Ptr colored_cloud = reg.getColoredCloud ();
    2. 43 pcl::visualization::CloudViewer viewer ("Cluster viewer");
    3. 44 viewer.showCloud (colored_cloud);
    4. 45 while (!viewer.wasStopped ())
    5. 46 {
    6. 47 std::this_thread::sleep_for(100us);
    7. 48 }

    编译和运行

    1、将以下行添加到 CMakeLists.txt 文件中:

    1. 1cmake_minimum_required(VERSION 3.5 FATAL_ERROR)
    2. 2
    3. 3project(region_growing_rgb_segmentation)
    4. 4
    5. 5find_package(PCL 1.5 REQUIRED)
    6. 6
    7. 7include_directories(${PCL_INCLUDE_DIRS})
    8. 8link_directories(${PCL_LIBRARY_DIRS})
    9. 9add_definitions(${PCL_DEFINITIONS})
    10. 10
    11. 11add_executable (region_growing_rgb_segmentation region_growing_rgb_segmentation.cpp)
    12. 12target_link_libraries (region_growing_rgb_segmentation ${PCL_LIBRARIES})

    2、运行

    $ ./region_growing_rgb_segmentation

    3、输出

     

  • 相关阅读:
    (25)Verilog实现三态门(inout)
    扬帆际海—shopee跨境店和本土店谁更有优势?
    matlab命令行窗口结果显示不全,解析式太长,输出不完整解决办法
    二十三种设计模式之工厂模式(含Java工厂模式的实现)
    Centos8怎么进行复位清屏? Centos8终端复位清屏的技巧
    专精特新!2024年湖北省专精特新中小企业申报奖励、申报条件整理
    Discrod账号为什么被封?怎么解封?
    solr配置账号权限登录
    vue基础-动态class、动态style、vue过滤器、vue计算属性vue基础-动态class、动态style、vue过滤器、vue计算属性
    机器学习和数据挖掘03-模型性能评估指标
  • 原文地址:https://blog.csdn.net/m0_50046535/article/details/125554177