IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> ORB-SLAM2栅格地图构建 -> 正文阅读

[人工智能]ORB-SLAM2栅格地图构建

ORB-SLAM2栅格地图构建

过程

栅格地图的构建是基于稠密点云地图的构建和保存实现的,需要了解可以看我们前面的博客

基于ORB-SLAM2实时构建稠密点云

在点云地图的基础上构建包含占据信息的八叉树地图和二维栅格地图,便于后续避障、导航等功能的实现

点云转八叉树可以参考下面的文章

(1条消息) Octomap 在ROS环境下实时显示_熊猫飞天的博客-CSDN博客_rviz显示map

中间可能遇到的问题:

  1. 点云与grid垂直
  2. 八叉树地图显示不完整
  3. 地面也显示为占据状态

对应的解决可以参考下面的文章

https://blog.csdn.net/sylin211/article/details/93743724

注意下面的几个点

  • yaml文件应为深度相机的参数,因为计算世界坐标用的是深度图
  • 点云拼接后显示时需要翻转,绕X轴旋转-pi/2使得Z轴朝上
  • 实际转化Octomap时一定要注意remap的topic是自己发布点云信息的topic
  • Octomap无法显示的时候检查各个话题的Publisher和Subscriber是否正确
  • /pointcloud_output的Publisher应为PointCloud节点,Subscriber应为octomap_server节点
  • 实际在Rviz中显示时,OccupancyGrid的话题应为/octomap_binary或是/octomap_full

我的转化代码:

#include <iostream>
#include <sensor_msgs/PointCloud2.h>
#include <pcl_conversions/pcl_conversions.h>
#include <pcl-1.7/pcl/io/pcd_io.h>

#include <ros/ros.h>
#include <Eigen/Geometry>
#include <pcl/common/transforms.h>

using namespace std;

int main(int argc,char** argv)
{
    ros::init(argc,argv,"PointCloud");
    ros::NodeHandle nh;

    ros::Publisher pcl_pub = nh.advertise<sensor_msgs::PointCloud2>("/pointcloud_output",10);

    //加载点云图像
    pcl::PointCloud<pcl::PointXYZRGB> cloud;
    sensor_msgs::PointCloud2 output;
    pcl::io::loadPCDFile("/home/redwall/ORB_SLAM2_modified/map/pointcloud/map.pcd",cloud);
    
    //旋转点云
    Eigen::Affine3f transform = Eigen::Affine3f::Identity();
    transform.rotate(Eigen::AngleAxisf(-M_PI/2,Eigen::Vector3f(1,0,0)));     //-M_PI*5/12
    pcl::transformPointCloud(cloud,cloud,transform);

    //将PCL点云转化为ROS消息的格式
    pcl::toROSMsg(cloud,output);    
    output.header.stamp = ros::Time::now();
    output.header.frame_id = "world";

    double dt=0.1;
    ros::Rate loop_rate(1/dt);
    while(ros::ok())
    {
        cout<<"output pointclud height:"<<output.height<<endl;
        cout<<"output pointcloud width:"<<output.width<<endl<<endl;
        pcl_pub.publish(output);
        ros::spinOnce();
        loop_rate.sleep();
    }

    return 0;
}

我的octomap_server launch文件如下:

<?xml version="1.0"?>
<launch>
    <node pkg="octomap_server" type="octomap_server_node" name="octomap_server">

    <param name="frame_id" type="string" value="/world"/>

    <param name="resolution" value="0.05"/>

    <param name="sensor_model/max_range" value="1000.0"/>
    <param name="latch" value="true"/>

    <param name="pointcloud_max_z" value="1000.0"/>
    <param name="pointcloud_min_z" value="-0.1"/>

    <remap from="/cloud_in" to="/pointcloud_output"/>

    </node>   
</launch>

octomap_server生成二维栅格地图可以参考下面的文章

octomap_server使用--生成二维占据栅格地图和三维概率地图_sru_alo的博客-CSDN博客_点云地图转换成二维栅格地图

结果

首先查看生成的pcd点云图,如下请添加图片描述只跑了实验室的一个角落

在Rviz中查看八叉树和栅格地图
请添加图片描述
注意:

  • 点云需要旋转,将相机的Z轴与Octomap的Z轴对齐,不然会影响栅格地图的生成
  • 地面点云不应被投影,故应该设置好pointcloud_min_z值
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-04-26 11:41:49  更:2022-04-26 11:41:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 22:47:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码