『分割』 平面模型分割

news2024/11/24 10:56:34

PCL提供的几个常见模型:

  1. pcl::SACMODEL_PLANE:平面模型,用于拟合平面结构的点云数据。

  2. pcl::SACMODEL_SPHERE:球体模型,适用于拟合球体结构的点云数据。

  3. pcl::SACMODEL_CYLINDER:圆柱体模型,用于拟合圆柱体结构的点云数据。

  4. pcl::SACMODEL_LINE:直线模型,适用于拟合直线结构的点云数据。

  5. pcl::SACMODEL_NORMAL_PLANE:法线平面模型,用于拟合平面结构并考虑法线方向的点云数据。

  6. pcl::SACMODEL_NORMAL_SPHERE:法线球体模型,用于拟合球体结构并考虑法线方向的点云数据。

  7. pcl::SACMODEL_NORMAL_CYLINDER:法线圆柱体模型,适用于拟合圆柱体结构并考虑法线方向的点云数据。

一些样本一致性方法

  1. pcl::SAC_RANSAC:随机采样一致性(RANSAC)方法,是一种常用的模型拟合和离群点去除的方法。

  2. pcl::SAC_LMEDS:最小中值残差(LMEDS)方法,是一种鲁棒的模型拟合方法,能够对数据中的离群点具有较好的鲁棒性。

  3. pcl::SAC_MSAC:多样本一致性(MSAC)方法,通过随机抽取多个样本来进行一致性判断,相对于RANSAC具有更好的收敛性能。

  4. pcl::SAC_RRANSAC:重复随机采样一致性(RRANSAC)方法,是RANSAC方法的改进版,通过多次重复采样和模型拟合来提高鲁棒性。

  5. pcl::SAC_PROSAC:自适应随机一致性(PROSAC)方法,是一种自适应性优化的采样一致性方法。

代码:

#include <iostream>
#include <pcl/ModelCoefficients.h> // 模型系数
#include <pcl/io/pcd_io.h>

#include <pcl/point_types.h> // 点云数据类型
#include <pcl/sample_consensus/method_types.h> // 用于样本一致性算法的方法类型的定义。这些方法包括RANSAC、MSAC、LORANSAC等,用于拟合模型并去除离群点
#include <pcl/sample_consensus/model_types.h> // 用于样本一致性算法的模型类型的定义。这些模型类型包括平面、球体、圆柱体、线段等,可以选择合适的模型类型进行样本一致性拟合
#include <pcl/segmentation/sac_segmentation.h> // 于基于样本一致性的分割算法的类定义和函数。这个头文件中包含了SacSegmentation类,可以使用该类进行样本一致性分割,从给定的点云数据中提取出符合特定模型的物体分割结果

#include <pcl/visualization/pcl_visualizer.h>
int main(){
    // 创建点云容器
    pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);

    // 填充点云
    cloud->width = 15;
    cloud->height = 1;
    cloud->points.resize(cloud->width * cloud->height);

    // 生成数据
    for (size_t i = 0; i< cloud->points.size(); ++i){
        cloud->points[i].x = 1024 * rand() / (RAND_MAX + 1.0f);
        cloud->points[i].y = 1024 * rand() / (RAND_MAX + 1.0f);
        cloud->points[i].z = 1;
    }

    // 设置几个局外点,使其偏离z为1的平面
    cloud->points[0].z = 2.0;
    cloud->points[3].z = -2.0;
    cloud->points[6].z = 4.0;

    // 打印所有点
    std::cerr << "point cloud data: " << cloud->points.size() << " points" << std::endl;
    for (size_t i=0; i < cloud->points.size(); ++i)
        std::cerr << "        " << cloud->points[i].x << " "
                  << cloud->points[i].y << " "
                  << cloud->points[i].z <<std::endl;

    // 创建分割时所需要的模型系数对象,coefficiients及存储内点的点索引集合对象inliers
    pcl::ModelCoefficients::Ptr coefficients(new pcl::ModelCoefficients);
    pcl::PointIndices::Ptr inliers(new pcl::PointIndices);

    // 创建分割对象
    pcl::SACSegmentation<pcl::PointXYZ> seg;

    // 可选择配置,设置模型系数需要优化
    seg.setOptimizeCoefficients(true);
    // 必要的配置,设置分割的模型类型,所用的随机参数估计方法,距离阈值,输入点云
    seg.setModelType(pcl::SACMODEL_PLANE); // 设置模型类型
    seg.setMethodType(pcl::SAC_RANSAC); // 设置随机采样一致性方法类型
    seg.setDistanceThreshold(0.01); // 设置距离阈值,距离阈值决定了点被认为是局内点是必须满足的条件
                                    // 表示点到估计模型的距离最大值

    seg.setInputCloud(cloud);
    // 引发分割实现,存储分割结果到点集合inliers及存储平面模型的系数coefficients
    seg.segment(*inliers, *coefficients);

    if (inliers->indices.size() == 0){
        PCL_ERROR("Could not estimate a planar model for the given dataset.");
    }

    // 打印平面模型
    std::cerr << "Model coefficients: " << coefficients->values[0] << " "
              << coefficients->values[1] << " "
              << coefficients->values[2] << " "
              << coefficients->values[3] << std::endl;

    std::cerr << "Model inliers: " << inliers->indices.size() << std::endl;
    for (size_t i=0; i< inliers->indices.size(); ++i)
        std::cerr << inliers->indices[i] << "   " << cloud->points[inliers->indices[i]].x << " "
                  << cloud->points[inliers->indices[i]].y << " "
                  << cloud->points[inliers->indices[i]].z << std::endl;


    pcl::PointCloud<pcl::PointXYZ>::Ptr seg_result(new pcl::PointCloud<pcl::PointXYZ>);
    for (size_t i =0; i< inliers->indices.size(); ++i){
        seg_result->push_back(cloud->points[inliers->indices[i]]);
    }

    pcl::visualization::PCLVisualizer::Ptr viewer(new pcl::visualization::PCLVisualizer("viewer"));
//    viewer->setBackgroundColor(0.0,0,0);
    viewer->addCoordinateSystem(1.0);
    viewer->addPointCloud(cloud, "cloud");
    viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE, 3, "cloud");
//    viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_COLOR, 1.0, 0, 0, "cloud");

//    viewer->addPointCloud(seg_result, "result");
//    viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_POINT_SIZE, 3, "result");
//    viewer->setPointCloudRenderingProperties(pcl::visualization::PCL_VISUALIZER_COLOR, 0, 1.0,  0, "result");
    while (!viewer->wasStopped()) {

    }


    return 0;
}

输出信息

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/749424.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一个四年Android程序猿的2023上半年总结

一晃就做了四年的Android开发了&#xff0c;时光飞逝啊&#xff5e; 工作的时间飞快&#xff0c;感觉每一天都很充实&#xff0c;但是大多数都是重复的样子。 去年的目标达成&#xff1a; 去年的目标就是学习学习&#xff0c;涨薪涨薪。上家公司的同事氛围很不错&#xff0…

一篇文章了解Redis分布式锁

Redis分布式锁 什么是分布式锁&#xff1f; ​ redis分布式锁是一种基于redis实现的锁机制&#xff0c;它用于在多并发分布式环境下控制并发访问共享资源。在多个应用程序或是进程访问共享资源时&#xff0c;分布式锁可以确保只有一个进程可以访问该资源&#xff0c;不会发生…

采用555时基电路的简易/可调定时长延时电路设计

采用 555 时基电路的简易长延时电路 本电路和一般的定时电路相比是通过在 555 时基电路的 5 脚处加了一个二极管 VD1&#xff0c;使得定时时间延长的特点。 一、电路工作原理 电路原理如图 11 所示。 当按下按钮SB时&#xff0c;12V的电源通过电阻器Rt向电容器Ct充电&#…

弹性IP和公网IP有什么区别?哪个好

​  弹性IP和公网IP有什么区别?哪个好。IP是服务器重要的组成资源&#xff0c;一台云服务器实例一般分为公网IP和内网IP&#xff0c;公网IP指的是对外访问的IP地址&#xff0c;是针对公众用户的IP&#xff0c;这是网站绑定的服务器IP地址。而内网IP顾名思义就是内部的网络IP…

Android Monkey稳定性测试

l 命令样例&#xff1a; adb shell monkey -p packagename --ignore-timeouts --ignore-crashes -v -v --throttle 200 1000000 各个参数的意义如下&#xff1a; -p 用此参数指定一个或多个包&#xff08;Package&#xff09;。指定包之后&#xff0c;Monkey将只允许系统启…

cmake多文件、多文件夹编译(2)

一、同级文件夹下代码调用问题 目录如下&#xff1a; ./testCMake&#xff08;根目录&#xff09;&#xff1a; /build&#xff1a; /MyClass: CMakeLists.txt MyClass.cpp MyClass.h /MyFunction: CMakeLists.txt MyFunction.cpp MyFunction.h CMakeLists.txt main.cpp 上述…

day35-Postman/ajax

0目录 1.postman 2.ajax 1.Postman 1.1 定义&#xff1a;postman用于测试http协议接口&#xff0c;无论是开发还是测试人员 1.2 Servlet中的doGet&#xff08;&#xff09;/daPost…

基于JavasSwing+MySQL的医药销售管理系统

点击以下链接获取源码&#xff1a; https://download.csdn.net/download/qq_64505944/87987881?spm1001.2014.3001.5503 功能&#xff1a;管理员与普通用户两个角色登录&#xff0c;可以增删改查用户&#xff0c;增删改查药品等功能 JDK1.8 MySQL5.7

微信小程序——开发入门

注册小程序 微信公众平台 设置相关信息 设置好之后需要去获取appID和秘钥&#xff0c;后序开发需要用到。 下载开发工具并安装 微信开发者工具&#xff08;稳定版 Stable Build&#xff09;下载地址与更新日志 | 微信开放文档 创建项目 打开开发者工具创建一个新项目并如下…

使用 ONLYOFFICE 宏检索网站详细信息

在上一篇文章中&#xff0c;我们基于一位用户发送的 VBA 参考构建了一个功能完善的 ONLYOFFICE 宏。今天&#xff0c;我们想再进一步&#xff0c;为其添加一些 Whois API 功能。 什么是 ONLYOFFICE 宏 如果您是一名资深 Microsoft Excel 用户&#xff0c;那么相信您已对于 VBA…

Nacos(服务注册与发现)+SpringBoot+openFeign项目集成

&#x1f4dd; 学技术、更要掌握学习的方法&#xff0c;一起学习&#xff0c;让进步发生 &#x1f469;&#x1f3fb; 作者&#xff1a;一只IT攻城狮 &#xff0c;关注我&#xff0c;不迷路 。 &#x1f490;学习建议&#xff1a;1、养成习惯&#xff0c;学习java的任何一个技术…

分割1——图像分割的前世今生

首先讲讲&#xff1a;什么是计算机视觉&#xff1f; 计算机视觉是一门让计算机学会“看”的学科&#xff0c;研究如何自动理解图像和视频中的内容。 其次讲讲&#xff1a;计算机视觉有哪些任务&#xff1f;我们所要讲的图像分割位于什么地位&#xff1f; 计算机视觉的三大经典…

计算机体系结构基础知识介绍之使用动态调度、多重问题和推测来利用流水线

我们已经了解了动态调度、多发射和推测等单独的机制是如何工作的。&#xff08;具体请参见本人前几篇博客&#xff09; 现在我们把这三种机制结合起来&#xff0c;得到一种和现代微处理器非常相似的微架构。为了简单起见&#xff0c;我们只考虑每个时钟周期发射两条指令的情况…

《算法竞赛·快冲300题》每日一题:“窗户”

《算法竞赛快冲300题》将于2024年出版&#xff0c;是《算法竞赛》的辅助练习册。 所有题目放在自建的OJ New Online Judge。 用C/C、Java、Python三种语言给出代码&#xff0c;以中低档题为主&#xff0c;适合入门、进阶。 文章目录 题目描述题解C代码Java代码Python代码 “ 窗…

es6 数组操作个人总结

es6 数组操作个人总结 动机数组数组生成可枚举对象转数组箭头函数筛选判断所有元素枚举循环 小结 动机 es6 &#xff0c;说白了&#xff0c;就是增强版本的 js 。。。。。嗯&#xff0c;说到底&#xff0c;还是原生 js 罢了&#xff0c;不过比原有的 js 多了一些属性、类型、指…

【c++修行之路】智能指针

文章目录 前言为什么用智能指针智能指针简单实现unique_ptrshared_ptr 循环引用和weak_ptr的引入循环引用weak_ptr 定制删除器 前言 大家好久不见&#xff0c;今天来学习有关智能指针的内容~ 为什么用智能指针 假如我们有如下场景&#xff1a; double Div() {int x, y;cin …

Clion 配置Mingw64的 c++开发环境

1、Mingw64的安装与环境变量的配置 Mingw64文件下载 Mingw64下载地址&#xff1a;https://sourceforge.net/projects/mingw-w64/files/ posix相比win32拥有C 11多线程特性&#xff0c;sjlj和seh对应异常处理特性&#xff0c;sjlj较为古老&#xff0c;所以选择seh 配置环境变…

MongoDB踩过的坑

目录 启动MongoDB服务 可视化工具&#xff1a;MongoDB Compass 由于目标计算机积极拒绝&#xff0c;无法连接 BSONObj size: xxxx is invalid. Size must be between 0 and 16793600 (16MB) 启动MongoDB服务 1. 打开CMD 2. 进入安装MongoDB文件夹中的bin目录 3. mongod -…

mapBox 绘制多边形无法设置 边框宽度 解决方法

目录 一、问题 二、解决方法 三、总结 tips:如嫌繁琐&#xff0c;直接看有颜色的文字即可&#xff01; 一、问题 1.使用mapBox在地图上绘制点、线、面。绘制多边形的时候发现 直接用 zh(一家提供地图引擎的公司),提供的绘制多边形的方法无法设置边框颜色和边框宽度。很是离…

龙蜥社区 6 月技术委员会会议召开!欢迎 5 位开放原子 TOC 导师加入

2023 年 6 月 16 日上午 10 点召开了龙蜥社区 6 月技术委员会线上会议&#xff0c;共计 38 人参会。本次会议由联通肖微主持&#xff0c;会议也荣幸的邀请到了开放原子 TOC 导师线上参会&#xff0c;技术委员们来自阿里云、统信、飞腾、中科方德、红旗、万里红、Intel、Arm、龙…