PCL 点云采样

news2025/1/8 4:25:53

一、简介

点云采样一般有三种方式,上采样,下采样,平均采样

原理介绍

下采样:

一般是采样是通过构建一个三维体素的格栅,然后在每个体素内用体素的重心近似的作为这个体素的整体特征,也就是说用这一个体素的重心来表示这个体素内的所有点。这样我们正在处理点云的过程中就会起到滤波的作用,同时也减少了很多数据在点云配准的过程当中大大加快了速度。

上采样:

类似于二维图像中的线性插值等,上采样是在增加点的个数,我们可以细想一下,一个点云中当点间距足够小的时候,点会连接起来这样的话就形参了一个曲面,因此上采样从另外一种程度上来说也可以说的是曲面重建的一种方式

有步骤如下

1、创建一个采样的对象

2、创建kdtree  

3、设置 kdtree 的搜索范围

4、设置采样对象的方法

5、设置采样对象的半径和步长

6、开始上采样

 

二、降(下)采样 

 

 

核心代码: 

    pcl::PointCloud<pcl::PointXYZ>::Ptr  newcloud(new  pcl::PointCloud<pcl::PointXYZ>);
     // 对这个点云进行下采样
    pcl::VoxelGrid<pcl::PointXYZ>  sor;
    sor.setInputCloud(m_current_cloud);
    sor.setLeafSize(0.1f,0.1f,0.1f); // 采样间隔
    sor.filter(*newcloud);  // 采样 并输出到新的点云里面

整体代码:


#if 1   //   点云下采样
int main()
{

    pcl::PointCloud<pcl::PointXYZ>::Ptr  m_current_cloud(new  pcl::PointCloud<pcl::PointXYZ>);
    if (-1 == pcl::io::loadPCDFile("empty desktop.pcd", *m_current_cloud))//放到与工程中的主.cpp同一位置的文件夹下
    {
        cout << "加载文件失败!" << endl;
        return -1;
    }
    cout << "原始点云的点数:  " << m_current_cloud->points.size() << endl;

    pcl::PointCloud<pcl::PointXYZ>::Ptr  newcloud(new  pcl::PointCloud<pcl::PointXYZ>);
     // 对这个点云进行下采样
    pcl::VoxelGrid<pcl::PointXYZ>  sor;
    sor.setInputCloud(m_current_cloud);
    sor.setLeafSize(0.1f,0.1f,0.1f); // 采样间隔
    sor.filter(*newcloud);  // 采样 并输出到新的点云里面

    cout <<"降采样之后的点云的点数:  " << newcloud->points.size() << endl;
    // 可视化
   // boost::shared_ptr<pcl::visualization::PCLVisualizer>viewer(new pcl::visualization::PCLVisualizer("Normal viewer"));
    pcl::visualization::PCLVisualizer viewer("demo");

    // 设置点云的显示两个点云到同一个viewer 中
    int v1(0);
    int v2(1);
    viewer.createViewPort(0.0, 0.0, 0.5, 1.0, v1);
    viewer.createViewPort(0.5, 0.0, 1.0, 1.0, v2);

    //  设置点云颜色
    float bckgr_gray_level = 0.0;  

    float txt_gray_lvl = 1.0 - bckgr_gray_level;

    // 显示原始点云
    pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> cloud_in_color_h(m_current_cloud, (int)255 * txt_gray_lvl, (int)255 * txt_gray_lvl, (int)255 * txt_gray_lvl);
    viewer.addPointCloud(m_current_cloud, cloud_in_color_h, "cloud_in_v1", v1);     

    //  显示降采样之后的滤波
    pcl::visualization::PointCloudColorHandlerCustom<pcl::PointXYZ> cloud_out_green(newcloud, 50, 180, 70);
    viewer.addPointCloud(newcloud, cloud_out_green, "cloud_out", v2);

    // 这种背景  只设置
    viewer.setBackgroundColor(bckgr_gray_level, bckgr_gray_level, bckgr_gray_level, v2);
     // 这种vtk窗口的大小
    viewer.setSize(1280, 1024);  
    // 点云显示
    while (!viewer.wasStopped())
    {
        viewer.spinOnce();
    }

    return 0;


}
#endif

三、上采样

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

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

相关文章

python 拆分pdf(有可执行文件exe)

1.背景 被那些软件pdf拆分整气死了&#xff0c;今天用python写一份pdf拆分的代码。 2.代码&#xff1a;&#xff08;计算机的可以去学习一下&#xff0c;自己改改&#xff09; pdf_split.py from PyPDF2 import PdfFileReader, PdfFileWriter# PDF文件分割 def split_pdf():…

pytorch nn.utils.rnn.pack_padded_sequence 分析

pack_padded_sequence 在nlp模型的forward方法中&#xff0c;可能有以下调用令读者疑惑 packed_embedded nn.utils.rnn.pack_padded_sequence(embedded, text_lengths, batch_firstTrue, enforce_sortedFalse)为什么要使用pack_padded_sequence&#xff1f; 参考 Pytorch中…

TDengine3.0:解决高基数问题的时序数据库设计思路

小 T 导读&#xff1a; 数据集的高基数&#xff08;High-Cardinality&#xff09;问题一直困扰着诸多主流的时序数据库&#xff08;Time Series Database&#xff0c;TSDB&#xff09;产品。一些数据库管理系统&#xff0c;在基数较低时表现良好&#xff1b;但是随着基数的增加…

vue2.x与vue3.x中自定义指令详解

&#x1f431;个人主页&#xff1a;不叫猫先生 &#x1f64b;‍♂️作者简介&#xff1a;前端领域新星创作者、华为云享专家、阿里云专家博主&#xff0c;专注于前端各领域技术&#xff0c;共同学习共同进步&#xff0c;一起加油呀&#xff01; &#x1f4ab;系列专栏&#xff…

m基于GA遗传算法的分件供送螺杆参数优化matlab仿真,优化参数包括螺杆总尺寸-最大圈数等

目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 首先介绍MATLAB部分的遗传算法的优化算法介绍&#xff1a; 遗传算法的原理 遗传算法GA把问题的解表示成“染色体”&#xff0c;在算法中也即是以二进制编码的串。并且&#xff0c;在执行遗传算法…

AI 对话模型被网友玩坏了!这次还可以运行 Docker 容器...

最近一款新的聊天 AI 被网友们玩疯了。它可以直接生成代码、可以给你的代码 debug 以及提出优化...可以模仿莎士比亚风格写作...还可以解答各种各样的问题&#xff0c;而且显然不只 10 岁小孩子的智商&#xff0c;感觉它已经把互联网上所有的公开资料都吸收并消化了。这就是 Op…

mssql(1433端口)介绍

mssql介绍 Microsoft SQL Server是一个关系型数据库&#xff0c;微软开发的管理系统。作为数据库服务器&#xff0c;它是一种软件产品&#xff0c;其主要功能是存储和检索其他软件应用程序所请求的数据&#xff0c;这些应用程序可以运行在同一台计算机上&#xff0c;也可以运行…

Java连接数据库(JDBC非常重要)

目录 一.数据库连接 1.1之前如何操作数据库 1.2.实际开发中如何操作数据库&#xff1f; 二.JDBC(Java Database Connectinity)(重要) 2.1.JDBC的概念 2.2 JDBC核心思想 2.2.1 MySQL数据库驱动 2.2.2 JDBC API 2.3JDBC 环境搭建 2.4准备一张表 2.4.1 创建student表 2.4.…

[附源码]Python计算机毕业设计Django三星小区车辆登记系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

Json简介与基本使用

前言 本文为Json简介与基本使用相关知识&#xff0c;下边具体将对什么是JSON&#xff0c;XML与JSON的区别&#xff0c;JSON的语法格式&#xff0c;JSON数据的转换&#xff08;包括&#xff1a;Java对象转换为JSON格式、JSON格式转换为Java对象&#xff09;等进行详尽介绍~ &am…

学习 MySQL:什么是分页

在本文中&#xff0c;我将解释在MySQL中&#xff0c;什么是分页以及我们如何实现它。当我们从 MySQL 数据库填充大型数据集时&#xff0c;读取同一页面上的所有记录并不容易。使用分页&#xff0c;我们可以将结果集划分为多个页面&#xff0c;这增加了结果集的可读性。在本文中…

协议-序列化-http-Cookie-Session-https

文章目录再谈协议什么是序列化&#xff0c;什么是反序列化&#xff1f;为什么要进行序列化和反序列化&#xff1f;怎么进行序列化和反序列化呢&#xff1f;网络计算器版本总结http协议httpurlencode&urldecode一. 格式认识二 代码实现一个http协议下的服务器安装telnet服务…

javaScript 进阶之路 --- 《加深理解回调函数》

前言&#xff1a; 回想当初第一次看到“回调函数”这个名词的时候&#xff0c;真的快把我难哭了。所有视频教程在讲到某个知识点的时候&#xff0c;大概都会说一句&#xff1a;“啊&#xff0c;这里怎么办呢&#xff1f;这里我们就需要用到一个回调函数...”。 等等&#xff0…

校园论坛(Java)—— 数据报表模块

校园论坛&#xff08;Java&#xff09;—— 数据报表模块 文章目录校园论坛&#xff08;Java&#xff09;—— 数据报表模块1、写在前面2、系统结构设计2.1 各个页面之间的调用关系2.2.3、数据报表设计3.1 数据报表主界面的实现3.2 发表数Top5的普通帖子3.3 回帖数Top5的普通帖…

技术人员创业的第一步分析(续,可听音频)

概述&#xff1a;昨天的文章发布以后&#xff0c;在腾讯云TVP专家群里和多个技术群里都引起了一些讨论&#xff0c;基于这些讨论&#xff0c;有了今天的这篇续章。里面谈到了这次创业中&#xff0c;青润经历过的几次生死关头&#xff0c;是真的差点离开人世&#xff0c;而不是想…

2022年物联卡的发展前景如何

在这个万物互联的时代&#xff0c;针对于企业设备联网的物联卡就显得格外重要了&#xff0c;而共享单车&#xff0c;移动支付&#xff0c;智慧城市&#xff0c;自动售卖机等企业采购物联卡会面临着各种问题&#xff0c;低价陷阱&#xff0c;流量虚假&#xff0c;管理混乱&#…

JMeter 做性能测试,YYDS!

2. JMeter下载和安装 JMeter可以在JMeter的官方网站下载&#xff0c;下载链接如下图所示&#xff0c;xmeter君写本文的时候&#xff08;2016/11&#xff09;可以下载到的最新的版本是3.0。 下载后解压到你系统下的任意目录&#xff0c;我们称该目录为%JMETER_HOME%&#xff0c;…

Dart语言简介

简单介绍Dart语言 Dart是一种针对客户优化的语言&#xff0c;亦可在任何平台上快速开发的应用陈旭。 目标是为多平台开发提供最高效的变成语言&#xff0c;并为应用程序框架搭配了领会的运行时执行平台。 Dart特点 Dart语言 类型安全&#xff0c;使用静态型检查来确保变量的…

Linux命令之常用基础命令备查手册

一、前言 家里领导因公司系统部署国产化发展趋势&#xff0c;需要学习Linux。作为Linux初学者&#xff0c;希望能有一篇博文提供学习快速学习和掌握Linux系统的常用基础命令。为了满足领导要求&#xff0c;特编写此博文&#xff0c;尽量将常用Linux命令囊括进来&#xff0c;以示…

基于ssm的宠物商城网站设计与实现

项目描述 临近学期结束&#xff0c;还是毕业设计&#xff0c;你还在做java程序网络编程&#xff0c;期末作业&#xff0c;老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据疫情当下&#xff0c;你想解决的问…