首页 > 其他分享 >3d激光雷达开发(icp匹配)

3d激光雷达开发(icp匹配)

时间:2022-11-23 23:00:21浏览次数:69  
标签:cout closest point iterative 激光雷达 pcl icp cloud 3d



        所谓匹配,其实就是看两个点云数据里面,哪些关键点是一样的。这样就可以把一个点云移动到另外合适的位置,组成一个新的点云。一般来说,单个机器人上面,3d激光扫描到的空间总是有限的,有了这个匹配算法,就可以把所有的点云组合成一个完整的3d地图了。参考的代码原来链接在这,​​https://pcl.readthedocs.io/projects/tutorials/en/master/iterative_closest_point.html#iterative-closest-point​

        在pcl库里面,这个匹配过程称之为registration,有一点拗口,不清楚为什么取这个名字。

1、准备iterative_closest_point.cpp

#include <iostream>
#include <pcl/io/pcd_io.h>
#include <pcl/point_types.h>
#include <pcl/registration/icp.h>

int
main (int argc, char** argv)
{
pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_in (new pcl::PointCloud<pcl::PointXYZ>(5,1));
pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_out (new pcl::PointCloud<pcl::PointXYZ>);

// Fill in the CloudIn data
for (auto& point : *cloud_in)
{
point.x = 1024 * rand() / (RAND_MAX + 1.0f);
point.y = 1024 * rand() / (RAND_MAX + 1.0f);
point.z = 1024 * rand() / (RAND_MAX + 1.0f);
}

std::cout << "Saved " << cloud_in->size () << " data points to input:" << std::endl;

for (auto& point : *cloud_in)
std::cout << point << std::endl;

*cloud_out = *cloud_in;

std::cout << "size:" << cloud_out->size() << std::endl;
for (auto& point : *cloud_out)
point.z += 0.7f;

std::cout << "Transformed " << cloud_in->size () << " data points:" << std::endl;

for (auto& point : *cloud_out)
std::cout << point << std::endl;

pcl::IterativeClosestPoint<pcl::PointXYZ, pcl::PointXYZ> icp;
icp.setInputSource(cloud_in);
icp.setInputTarget(cloud_out);

pcl::PointCloud<pcl::PointXYZ> Final;
icp.align(Final);

std::cout << "has converged:" << icp.hasConverged() << " score: " <<
icp.getFitnessScore() << std::endl;
std::cout << icp.getFinalTransformation() << std::endl;

return (0);
}

2、准备CMakeLists.txt文件

cmake_minimum_required(VERSION 2.8 FATAL_ERROR)

project(iterative_closest_point)

find_package(PCL 1.2 REQUIRED)

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

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

3、生成sln工程,开始编译

3d激光雷达开发(icp匹配)_算法

4、执行iterative_closest_point.exe

3d激光雷达开发(icp匹配)_蓝桥杯_02

 

5、补充怎么从旋转矩阵获取yaw/pitch/roll/x/y/z

 

3d激光雷达开发(icp匹配)_c++_03

 

标签:cout,closest,point,iterative,激光雷达,pcl,icp,cloud,3d
From: https://blog.51cto.com/feixiaoxing/5881897

相关文章

  • ASW3642pin√pin替代TS3DV642无需更改电路
    TS3DV642是一种12通道1:2或2:1双向多路替代器/多路解复用器。TS3DV642接入2.6V至4.5V的电源供电,适用于电池供电。电阻(RON)最小和I/O电容较小,能够实现典型值高达7.5GHz的带宽......
  • 3DMAX2018安装
    1.下载3DMAX2018安装包并解压2.打开解压后的文件点击Setup选择语言和安装位置点击下一步安装完成后点击enteraserialnumber输入序列号066-66666666,密钥128J1后点......
  • 2022 ICPC沈阳合肥游记
    选赛区的时候很争议,除了沈阳是确定要选,队友对于合肥新赛区的看法很质疑,但我想选合肥,一是觉得人少,二是觉得强队会少,因为隔壁CCPC。然后就选了合肥,看情况选合肥确实很对。一......
  • ICP经营许可证和EDI许可证之间的区别有哪些?
    当我们都熟知了icp和edi这两种许可证后,但是还是难免会出现一些疑问,众所周知,从事不同的行业就需要取得不同的资质,在互联网行业同样如此,所以会有很多种互联网资质类型,难免会有......
  • 大咖说·先临三维|技术入云塑造3D视觉行业新模式
    高精度3D视觉技术主要的工作原理是什么?它的开发难度在哪里?数字化技术对其有何助力?本期大咖说,看先临三维副总裁兼研究院副院长江腾飞如何分享。嘉宾介绍江腾飞:先......
  • Matplotlib数据可视化——3D视图
    """绘制三维图形"""importnumpyasnpimportmatplotlib.pyplotaspltfrommpl_toolkits.mplot3dimportAxes3Dfig=plt.figure()ax=Axes3D(fig)X=np.ara......
  • Android实现3D页面加载进度条动画
    一.概述最近在研究公司的代码,发现每次切换页面时做的进度条效果还挺不错的,所以想深入研究一下,今天就带大家来看看到底是如何实现的,首先上效果图二.实现上面的进度条最大的......
  • ICPC2022-合肥赛区 SZTU_AtDawn队总结
    比赛前一天先简单聊聊热身赛,因为开始思路的局限,最简单的枚举题最后也没写出来,不过写出来了一个分块的数据结构。赛后发现枚举其实很简单的思路,赛时想了些复杂度很怪的东西......
  • 在博客园随笔中插入3D分子模型
    技术背景博主对前端技术不甚了解,只是想在博客中直接展示一些已有的分子结构,而且需要是可以交互的。而我们了解到通过3Dmol这样的前端工具可以实现,通过在博客园随笔中直接......
  • Cesium关于3Dtiles的细节分享
    介绍介绍一下Cesium中有关3dTiles的奇淫技巧,存在一些埋坑的地方,以下内容仅为自己摸索的细节和方法,仅供参考,若有更好的办法欢迎讨论通用快速获取feature中包含的属性信息......