平面分割--------PCL

平面分割

bool PclTool::planeSegmentation(pcl::PointCloud<pcl::PointXYZ>::Ptr cloud, pcl::ModelCoefficients::Ptr coefficients, pcl::PointIndices::Ptr inliers)
{std::cout << "Point cloud data: " << cloud->points.size() << " points" << std::endl;// 创建分割时所需要的模型系数对象,coefficients及存储内点的点索引集合对象inliers// pcl::ModelCoefficients::Ptr coefficients(new pcl::ModelCoefficients);// pcl::PointIndices::Ptr inliers(new pcl::PointIndices);// pcl::ModelCoefficients用于存储平面模型的系数(A、B、C和D)。// Model coefficients: 0 0 1 -1:平面模型的系数表示为[A, B, C, D],其中A、B、C表示平面的法向量,D表示平面到原点的距离。在这里,系数为[0, 0, 1, -1],表示平面的法向量在Z轴上,距离原点的距离为1,即平面方程为Z=1。// 而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及存储平面模型的系数coefficientsseg.segment(*inliers, *coefficients);if (inliers->indices.size() == 0){std::cout << "Could not estimate a planar model for the given dataset." << std::endl;return false;}return true;
}

测试代码

        // 平面分割pcl::PointCloud<pcl::PointXYZ>::Ptr planeSeg_cloud(new pcl::PointCloud<pcl::PointXYZ>);// 填充点云planeSeg_cloud->width = 15;planeSeg_cloud->height = 1;planeSeg_cloud->points.resize(planeSeg_cloud->width * planeSeg_cloud->height);// 生成数据,采用随机数填充点云的x,y坐标,都处于z为1的平面上for (size_t i = 0; i < planeSeg_cloud->points.size(); ++i){planeSeg_cloud->points[i].x = 1024 * rand() / (RAND_MAX + 1.0f);planeSeg_cloud->points[i].y = 1024 * rand() / (RAND_MAX + 1.0f);planeSeg_cloud->points[i].z = 1.0;}// 设置几个局外点,即重新设置几个点的z值,使其偏离z为1的平面planeSeg_cloud->points[0].z = 2.0;planeSeg_cloud->points[3].z = -2.0;planeSeg_cloud->points[6].z = 4.0;pcl::ModelCoefficients::Ptr coefficients(new pcl::ModelCoefficients);pcl::PointIndices::Ptr inliers(new pcl::PointIndices);PclTool::planeSegmentation(planeSeg_cloud, coefficients, inliers);if (inliers->indices.size() == 0){std::cout << "Could not estimate a planar model for the given dataset." << std::endl;}// 打印出平面模型std::cout << "Model coefficients: " << coefficients->values[0] << " " << coefficients->values[1] << " " << coefficients->values[2] << " " << coefficients->values[3] << std::endl;std::cout << "Model inliers: " << inliers->indices.size() << std::endl;for (size_t i = 0; i < inliers->indices.size(); ++i){std::cout << inliers->indices[i] << "\t" << planeSeg_cloud->points[inliers->indices[i]].x << " " << planeSeg_cloud->points[inliers->indices[i]].y << " " << planeSeg_cloud->points[inliers->indices[i]].z << std::endl;}return 0;

反馈结果

在这里插入图片描述

  • Model coefficients: 0 0 1 -1:平面模型的系数表示为[A, B, C, D],其中A、B、C表示平面的法向量,D表示平面到原点的距离。在这里,系数为[0, 0, 1, -1],表示平面的法向量在Z轴上,距离原点的距离为1,即平面方程为Z=1。
  • pcl::PointIndices用于存储内点的索引

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

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

相关文章

8.【Orangepi Zero2】UDEV的配置文件,自动挂载U盘

8.UDEV的配置文件&#xff0c;自动挂载U盘 UDEV的配置文件udev 规则的匹配键挂载U盘手动挂载U盘自动挂载usbpan.rules tree命令 UDEV的配置文件 参考文章&#xff1a;Linux 基础 – udev 和 rules 使用规则5 规则文件是 udev 里最重要的部分&#xff0c;默认是存放在 /etc/ud…

CVE-2019-19945漏洞复现 Openwrt针对uhttpd漏洞利用

根据官方漏洞的文档&#xff0c;该漏洞的复现工作我会基于openwrt的18.06.4这个版本进行测试。我选取的环境是渗透测试常用的kali-Linux系统&#xff0c;然后在其中搭建docker环境来完成相应的实验环境的部署。我通过这个核心命令获取docker环境&#xff1a; sudo docker impo…

OSINT技术情报精选·2024年4月第4周

OSINT技术情报精选2024年4月第4周 2024.4.30版权声明&#xff1a;本文为博主chszs的原创文章&#xff0c;未经博主允许不得转载。 1、山西证券&#xff1a;《边缘AI行业深度&#xff1a;边缘AI硬件&#xff0c;引领硬件创新时代》 边缘 AI 是云端算力的有效补充&#xff0c;…

自己写了一个jq的toast弹窗框架引入之后调用报错$.toast is not a function

toast.js (function($) { $.toast function(message) {var toast $(#toast);toast.find(.toast-message).text(message);toast.fadeIn(function () {setTimeout(function () {toast.fadeOut();}, 3000); // 持续时间3秒})toast.click(function(){toast.fadeOut();}) } }) 页…

SDWebImage源码分析

[TOC](SDWebImage源码分析 基本框架UIKit层工具层SDWebImageManagerSDImageCacheSDWebImageDownloaderdownloadImageWithURL 基本框架 SDWebImage作为一个著名的iOS图像加载库&#xff0c;其源码主要包括以下几个核心部分&#xff1a; 图片下载管理&#xff1a;SDWebImageMan…

微信答题链接怎么做_新手也能快速上手制作

在数字营销日新月异的今天&#xff0c;如何有效吸引用户参与、提升品牌曝光度&#xff0c;成为了每一个营销人都在思考的问题。而微信答题链接&#xff0c;作为一种新兴的互动营销方式&#xff0c;正以其独特的魅力&#xff0c;在营销界掀起一股新的热潮。今天&#xff0c;就让…

从C向C++16——常见容器2

一.stack容器 1.stack理解 概念&#xff1a; stack是一种先进后出的数据结构&#xff0c;它只有一个出口。 它在C中也叫栈&#xff0c;类似于我们在《数据结构和算法》里面的栈&#xff0c;只不过在C中把其封装成库&#xff0c;我们可以直接使用。 注意&#xff1a;栈中只有…

【精品毕设推荐】搜索引擎的设计与实现

点击免费下载原文及代码 摘要 我们处在一个大数据的时代&#xff0c;伴随着网络信息资源的庞大&#xff0c;人们越来越多地注重怎样才能快速有效地从海量的网络信息中&#xff0c;检索出自己需要的、潜在的、有价值的信息&#xff0c;从而可以有效地在日常工作和生活中发挥作…

typescript中的BigInt,展开运算符,解构和可选链运算

BigInt&#xff0c;展开运算符&#xff0c;解构和可选链运算 BigInt javascript中支持两种数据类型&#xff0c; Number类型和BigInt类型。 JavaScript的七种原始数据类型&#xff0c;Undefined,Null,Boolean,String,Symbol,Number,BigInt JavaScript使用双精度64位浮点数格式…

【UnityRPG游戏制作】Unity_RPG项目之场景环境搭建和解析

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…

事件知识图谱 - EventKGE_Event knowledge graph embedding with event causal transfer

EventKGE: Event knowledge graph embedding with event causal transfer 作者&#xff1a;Daiyi Li&#xff08;南航&#xff09; 来源&#xff1a;2023 Knowledge-Based Systems&#xff08;中科院一区&#xff0c;影响因子8.8&#xff09; 论文&#xff1a;[ScienceDirec…

开源聊天软件和 php版本的开源聊天软件的介绍

开源聊天软件 php 开源的PHP聊天软件有很多&#xff0c;这里我会列举几个常见的&#xff1a; Pidgin: 这是一个跨平台的即时消息客户端&#xff0c;它支持各种协议&#xff0c;包括XMPP协议。虽然它本身不是一个聊天软件&#xff0c;但它可以用来编写XMPP协议的聊天软件。 …

Linux中gcc/g++的使用

文章目录 前言gcc/g 前言 gcc和g即为编译器。其中gcc为c语言的编译器&#xff0c;只能编译c语言&#xff1b;g为c的编译器&#xff0c;既能编译c语言&#xff0c;又能编译c。 在前面的文章中&#xff0c;我们提到代码转换成可执行程序需要经过 预处理&#xff08;进行宏替换)…

一、Vagrant搭建相关环境

目录 一、创建Vagrant相关环境1.下载安装VirtualBox2.在BlOS中设置CPU虚拟化3.使用Vagrant新建linux虚拟机3.1下载Vagrant3.2Vagrant官方镜像仓库3.3使用Vagrant初始化一个centos7的虚拟机 4.设置固定ip地址 二、安装docker1.按照docker 三、docker安装一些中间件1.mysql安装2.…

从零开始学AI绘画,万字Stable Diffusion终极教程(六)

【第6期】知识补充 欢迎来到SD的终极教程&#xff0c;这是我们的第六节课&#xff0c;也是最后一节课 这套课程分为六节课&#xff0c;会系统性的介绍sd的全部功能&#xff0c;让你打下坚实牢靠的基础 1.SD入门 2.关键词 3.Lora模型 4.图生图 5.controlnet 6.知识补充 …

Linux环境创建普通用户,授权root权限。报错:usermod: group ‘sudo‘ does not exist

在Linux环境下&#xff0c;创建普通用户并授权root权限需要以下步骤&#xff1a; 1. 以root用户登录终端。 2. 执行以下命令创建一个新的用户&#xff0c;其中username为你想要创建的用户名&#xff0c;可根据实际情况自行更改。 adduser username 3. 设置该用户的密码&…

Stylus的引入

Stylus是一个CSS预处理器&#xff0c;它允许开发者使用更高级的语法来编写CSS&#xff0c;并提供了一些额外的功能来简化和增强CSS的编写过程。以下是关于Stylus的详解和引入方法的详细介绍&#xff1a; 一、Stylus的详解 特点和功能&#xff1a; 变量&#xff1a;允许你定义…

【C++】vector类的增删改查模拟实现(图例超详细解析!!!)

目录 一、前言 二、源码引入 三、vector的模拟实现 ✨实现框架 ✨前情提要 ✨Member functions —— 成员函数 ⚡构造函数 ⭐无参构造 ⭐迭代器区间构造 ⭐n个值构造 ⚡拷贝构造 ⚡运算符赋值重载 ⚡析构函数 ✨Element access —— 元素访问 ⚡operator[ ] …

springcloud整合nacos实现相同版本实例相互调用

springcloud整合nacos实现相同版本实例相互调用 注: 本文为自己学习研究总结&#xff0c;仅供参考&#xff0c;若有侵权&#xff0c;请及时联系本人 业务场景 有时候一些新的业务或者修改后的功能只开放给部分人访问&#xff0c;那么可以新老版本都部署&#xff0c;对于大多…

[AHK V2]WinEvent - 简单的检测窗口打开关闭、移动、最大化、最小化等

WinEvent简介 WinEvent 可以监视所有窗口或特定窗口的窗口事件。目前支持以下事件&#xff1a;显示、创建、关闭、激活、非激活、移动、开始移动、结束移动、最小化、还原、最大化。有关详细信息&#xff0c;请参见库中函数的注释。 该库最新版可在Git Hub上获得。 WinEvent.a…