SLAM十四讲学习笔记 第二期:部分课后实践代码

持续更新....

  • 前期准备
  • 第二讲
    • 实验一:简单输出
  • 第五讲
    • 任务一:imageBasics(Ubuntu配置opencv)
    • 任务二:双目匹配点云(Ubuntu配置pangolin)
      • 检验部分我认为可以加深对CMake的理解
    • 任务三:rgbd匹配点云(Ubuntu配置Sophus&fmt)
  • 第七讲:视觉惯性里程计
    • 课程笔记
      • ORB特征
        • FAST关键点
        • BRIEF描述子
      • 特征匹配
      • 2D-2D:对极几何
  • 跑ORB-SLAM3
    • 下载小六注释过的ORB_SLAM3代码
    • 配置boost
    • 安装ORB_SLAM3时遇到的问题
      • 配置opencv4
      • 配置realsense2
      • make过程中遇到"fatal error ... terminated program cc1plus"
    • 数据集测试
      • 1.数据集下载
      • 2.解压Vocabulary
      • 3A.按照格式执行mono_euroc【不用ROS,但是遇到了报错】
      • 3B.ROS在bashrc中添加ORB_SLAM路径【用ROS】
      • 4A. 打开可视化界面
      • 4B. 编译ROS文件【有报错】
      • 5B. 运行

最近在看SLAM十四讲相关内容,顺便跑一跑快半年没有开过的虚拟机
本期在Ubuntu20上跑一跑《视觉SLAM十四讲》中提到的代码,按照顺序,从第二讲开始

代码库
https://github.com/gaoxiang12/slambook2

本文在ROS上运行cpp代码,一方面ROS与后续内容兼容性强,另一方面ROS的cpp功能做得已经十分完善了。

颜色代码
蓝色
红色
绿色

前期准备

  • 有些Ubuntu相关的代码和ROS基础等,笔者放在了上一期:SLAM十四讲学习笔记 第一期:Ubuntu复健计划
  • 本期所有代码均放在主页面下的Slam_ws工作空间下
  • 将不同讲分类成了不同功能包

创建与编译工作空间

mkdir -p ~/Slam_ws/src
cd ~/Slam_ws/src
catkin_init_workspace 
cd ../
catkin_make

记得source!

第二讲

实验一:简单输出

创建功能包

cd ~/Slam_ws/src
catkin_create_pkg Lec2

新建hello.cpp

#include <iostream>

int main()
{
  std::cout << "Hello, SLAM!" << std::endl;
  return 0;
}

编辑CMakeLists.txt
打开CMakeLists.txt文件在最后面添加以下行:

此处暂时不需要添加库

add_executable(HelloSlam hello.cpp)
target_link_libraries(HelloSlam ${catkin_LIBRARIES})

编译后运行

cd ~/Slam_ws
catkin_make
source devel/setup.bash
rosrun Lec2 HelloSlam 

显示结果
在这里插入图片描述

第五讲

任务一:imageBasics(Ubuntu配置opencv)

配置opencv3.X
参考这篇文章 Ubuntu20安装OpenCV3(图解亲测)

检验是否配置成功

pkg-config opencv --modversion

在这里插入图片描述


创建功能包

cd ~/Slam_ws/src
catkin_create_pkg lec5  # 尽量选择小写,符合功能包命名标准

搬运源代码
将源代码中的三个小功能包搬过来,最后的结构如下:
在这里插入图片描述

修改主文件夹的CMakeLists.cpp
为了适配ROS环境(主要是加了一个catkin的包),对ROS自动生成的CMakeLists.txt稍加修改:

## Compile as C++11, supported in ROS Kinetic and newer
add_compile_options(-std=c++11)

# 其他地方不做修改
# ....
# ....
# ....
# ....
# 在最后面加上源代码在主功能包下的配置信息:

# Eigen
include_directories("/usr/include/eigen3")

# 寻找OpenCV库
find_package(OpenCV REQUIRED)
# 添加头文件
include_directories(${OpenCV_INCLUDE_DIRS})

add_subdirectory(imageBasics)
# add_subdirectory(stereo)
# add_subdirectory(rgbd)

修改undistortImage.cpp中读取图片的格式,使其和imageBasics.cpp一致

cv::Mat image = cv::imread(argv[1]);   // 图像是灰度图,CV_8UC1
// 判断图像文件是否正确读取
if (image.data == nullptr) { //数据不存在,可能是文件不存在
  cerr << "文件" << argv[1] << "不存在." << endl;
  return 0;
}

编译后运行

cd ~/Slam_ws
catkin_make
source devel/setup.bash

运行
【要在虚拟机运行,SSH远程连接无法直接在Windows端显示虚拟机中的新窗口】

rosrun lec5 imageBasics ~/Slam_ws/src/lec5/imageBasics/ubuntu.png
rosrun lec5 undistortImage ~/Slam_ws/src/lec5/imageBasics/ubuntu.png

在这里插入图片描述

任务二:双目匹配点云(Ubuntu配置pangolin)

配置pangolin
参考Ubuntu20.04 —— 新系统从头安装ORB-SLAM3过程(2022年)

大哥的这个文档里说Pangolin只有v0.6能用,事实上最新版也能用

如果在cmake时,遇到以下错误:在这里插入图片描述
是因为没有pybind11
事实上笔者只遇到了这一个问题,但是这个问题在网上没找到合适的解决方法

其实主要原因一句话就说明白了:库里的pybind是空的,需要另外下载后导入
可以看我的这篇博客Ubuntu20下载Pangolin

检验是否配置成功

检验部分我认为可以加深对CMake的理解

  • 进入Pangolin/examples/HelloPangolin/
  • 进行编译
    # 进入examples/HelloPangolin/目录下
    mkdir build && cd build
    cmake ..
    make
    
  • 运行
    ./HelloPangolin
    
  • 运行结果
    在这里插入图片描述
    可以看到,在v0.6和最新版都能运行起来

修改主文件夹的CMakeLists.cpp
把任务一中注释掉的

# add_subdirectory(stereo)

解注释即可

编译后运行

cd ~/Slam_ws
catkin_make
source devel/setup.bash

运行
【要进入stereo文件夹下,不然读不到图片】

cd ~/Slam_ws/src/lec5/stereo/
rosrun lec5 imageBasics ~/Slam_ws/src/lec5/imageBasics/ubuntu.png

在这里插入图片描述

任务三:rgbd匹配点云(Ubuntu配置Sophus&fmt)

配置sophus

本篇使用的方法是配置模板类【就是在/usr/local/include/sophus】,若要配置非模板类【就是在/usr/local/lib/libSophus.so】,可以参考
ubuntu下安装Sophus库出现问题及解决办法【原作者漏了最后的make install

参考ubuntu20.04 安装 Sophus库 slambook2

下文的CMakeLists.txt也是搬运自该文章

检验是否配置成功
查看/usr/local/include下是否已经有sophus文件夹
在这里插入图片描述

修改rgbd的CMakeLists.txt
完成配置后,仍不可直接catkin_make,需要修改CMakeLists.txt
全部替换为:

cmake_minimum_required( VERSION 2.8 )
project(rgbd)

##  使用模板类sophus
# set(Sophus_DIR "/usr/local/sophus-template/share/sophus/")
#或 
set(Sophus_INCLUDE_DIRS "/usr/local/sophus-template/include")
##set(Sophus_LIBS )

# 为使用 sophus,需要使用find_package命令找到它
find_package(Sophus REQUIRED)

find_package(Pangolin REQUIRED)
find_package(OpenCV REQUIRED)

include_directories(
	${Sophus_INCLUDE_DIRS}
	${OpenCV-INCLUDE_DIRS}
)
include_directories("/usr/local/include/eigen3")

add_executable(joinMap joinMap.cpp)
target_link_libraries(joinMap ${OpenCV_LIBS})
target_link_libraries(joinMap ${Pangolin_LIBRARIES})
target_link_libraries(joinMap ${Sophus_LIBS} fmt)

其作用是添加了eigon和fmt依赖。

修改主文件夹的CMakeLists.cpp
把任务一中注释掉的

# add_subdirectory(rgbd)

解注释即可

编译与运行

cd ~/Slam_ws
catkin_make
source devel/setup.bash

运行
【要进入rgbd文件夹下,不然读不到位置文件】

cd ~/Slam_ws/src/lec5/rgbd/
rosrun lec5 joinMap

在这里插入图片描述

第七讲:视觉惯性里程计

课程笔记

特征点关键点描述子两部分组成。
关键点是特征点在图像的位置和特征信息如朝向等
描述子通常是一个向量,描述了关键点周围像素的信息;常用来判断两个特征是否相似

ORB特征

ORB特征由关键点和描述子构成

FAST关键点

像素点和周围一圈n个像素的差异【至少有k(k<n)个点比该点大/小一个阈值】

BRIEF描述子

随机取【或者按照某个图案】取特征点附近图像上的两个点,进行比较

特征匹配

针对两张图的特征点的匹配
匹配方法包括暴力匹配筛选后的匹配【如特征点间的最大距离等等】

2D-2D:对极几何

特征匹配之后,得到了特征点之间的对应关系

  • 如果只有两个单目图像,得到2D-2D间的关系——对极几何
  • 如果匹配的是帧和地图,得到3D-2D间的关系——PnP
  • 如果匹配的是RGB-D图,得到3D-3D间的关系——ICP

跑ORB-SLAM3

这部分基本上参考了【ORB_SLAM】Ubuntu20.04 配置ORB_SLAM3)

下载小六注释过的ORB_SLAM3代码

本文把源码放到了桌面

cd ~/Desktop
git clone https://github.com/electech6/ORB_SLAM3_detailed_comments.git

配置boost

按照Ubuntu20.04 —— 新系统从头安装ORB-SLAM3过程(2022年)这里的配置走就好

安装ORB_SLAM3时遇到的问题

基本上没什么问题,但是:

  1. build.sh脚本文件报错了,是我自己手动执行的
  2. build.sh中,在最后编译整个包时【即倒数第二行(cmake .. -DCMAKE_BUILD_TYPE=Release)】,先后遇到了opencv要求版本4.4+缺少realsense2的问题【后来发现好像只用保证DBOW2和ROS和源码的cv库版本一样即可】

配置opencv4

最后的cmake遇到以下要求
在这里插入图片描述

在编译ORB_SLAM3
Ubuntu20安装OpenCV3(图解亲测)
如果前面已经配置过opencv3,那么opencv4按照这个博主的方法,执行到sudo make install即可。

可以通过下列指令进行验证

pkg-config --modversion opencv4

配置realsense2

解决opencv4的问题后,发现还缺依赖realsense2
在这里插入图片描述
需要下载:

sudo apt-get install ros-noetic-realsense2-camera  # Ubuntu20对应这个版本

至此,cmake .. -DCMAKE_BUILD_TYPE=Release顺利通过

make过程中遇到"fatal error … terminated program cc1plus"

原因是内存不够,可以通过以下指令查看内存

free -m

参考文章:C++: fatal error: Killed signal terminated program cc1plus的问题解决
尝试增加swap区

有一个小技巧,在make时遇到许多Warning,非常碍眼,可以这样:

make -j4 2>&1 | grep -iE 'error|%'  # 仅输出报错和百分号(进度)

按照原博主的方法,会说“打开’/swapfile’ 失败: 文本文件忙
因此稍加修改:

sudo swapoff /swapfile 
# 关掉交换文件
sudo dd if=/dev/zero of=/swapfile bs=512M count=10
# count的大小就是增加的swap空间的大小,bs是块大小为512M,所以空间大小是bs*count=5G
sudo mkswap /swapfile
# 把刚才空间格式化成swap格式
sudo chmod 0600 /swapfile  
# 更改交换文件的权限为只有root用户可读写
sudo swapon /swapfile
# 使用刚才创建的swap空间

完成后,可以通过以下命令释放内存:

sudo swapoff /swapfile

哥们内存是真不够,,,为了整这个ORB_SLAM,前前后后已经扩了15G了
在这里插入图片描述

数据集测试

1.数据集下载

下载地址:
The EuRoC MAV Dataset下载ASL格式
解压到某个地方【可以不在ORB文件夹下】

2.解压Vocabulary

进入ORB的Vocabulary/目录下,解压语义库

tar -xzvf ORBvoc.txt.tar.gz

3A.按照格式执行mono_euroc【不用ROS,但是遇到了报错】

参考主目录或者Examples/目录下的euroc_examples.sh文件;找到与数据集对应的指令,修改为匹配的路径
如【该指令仅供参考,路径因人而异】

cd ~/Desktop/ORB_SLAM3_detailed_comments/
./Examples/Monocular/mono_euroc ./Vocabulary/ORBvoc.txt ./Examples/Monocular/EuRoC.yaml ./datasets/MH05 ./Examples/Monocular/EuRoC_TimeStamps/MH05.txt

遇到报错如下:在这里插入图片描述
原因是储存文件名信息的.txt文件换行格式有误

3B.ROS在bashrc中添加ORB_SLAM路径【用ROS】

vim ~/.bashrc

然后在文档末尾输入:【路径要修改】

export ROS_PACKAGE_PATH="$ROS_PACKAGE_PATH:/home/szw【注意这里要修改】/Desktop/ORB_SLAM3_detailed_comments/Examples/ROS/ORB_SLAM3"
# vim 操作方法: 输入 按i
#              结束先按Esc ,再按 :wq

最后source一下环境

source ~/.bashrc

4A. 打开可视化界面

修改Examples/Monocular/mono_euroc.cc的第83行,将false改成true
在这里插入图片描述
回到主页面,重新编译

cd ORB_SLAM3_detailed_comments/build
cmake ..
make -j

4B. 编译ROS文件【有报错】

cd ORB_SLAM3_detailed_comments/Examples/ROS/ORB_SLAM3
mkdir build
cd build
cmake ..
make -j

cmake ..如果遇到问题,大概率是上面的ROS_PACKAGE_PATH配错了

报错:qtmd,爱咋咋地吧
在这里插入图片描述

5B. 运行

# 运行代码之前记得source一下
cd orb_slam3/ORB_SLAM3_detailed_comments/Examples/ROS/ORB_SLAM3/build
source devel/setup.bash
# 终端1
roscore
# 终端2
rosrun ORB_SLAM3 Mono_Inertial /home/robot/orb_slam3/ORB_SLAM3_detailed_comments/Vocabulary/ORBvoc.txt /home/robot/orb_slam3/ORB_SLAM3_detailed_comments/Examples/Monocular-Inertial/EuRoC.yaml

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

10*1000【2】

知识: -----------金融科技背后的技术---------------- -------------三个数字化趋势 1.数据爆炸&#xff1a;internet of everything&#xff08;iot&#xff09;&#xff1b;实时贡献数据&#xff1b;公有云服务->提供了灵活的计算和存储。 2.由计算能力驱动的&#x…

Android Xfermode 使用解析

自定义绘制之图片 canvar.drawBitmap() ,BitMapFactory private fun getBitmap(width: Int): Bitmap? {val option BitmapFactory.Options()option.inJustDecodeBounds trueBitmapFactory.decodeResource(resources, R.mipmap.android111,option)option.inJustDecodeBounds…

Oracle数据库快速入门

前言&#xff1a; 我想现在很多人的入门数据库都是mysql&#xff0c;但是由于工作中会接触到Oracle数据库&#xff0c;如果你有MySQL的基础的话&#xff0c;这篇文章能让你很快掌握Oracle。 目录 1.体系结构 2.创建用户和表空间 2.1.创建表空间 2.2.创建用户 3.数据类型…

Jvm之JIT优化详细解释

文章目录 一、JIT 产生的背景二、HotSpot虚拟机内置JIT编译器1. Client Compiler2. Server Compiler3. 查看本地编译器模式 三、常见热点探测技术1. 基于计数器的热点探测2. 基于采样的热点探测2.1 方法调用计数器2.2 回边计数器 四、常见JIT优化手段1. 公共子表达式消除2. 方法…

NGINX的速率限制(限流)

NGINX 的速率限制&#xff08;限流&#xff09; NGINX最有用但经常被误解和配置错误的功能之一是限流。它允许您限制用户在给定时间段内可以发出的HTTP请求量。 限流可以用于安全目的&#xff0c;例如减慢暴力破解密码的攻击。它可以通过限制请求速率为真实用户的典型值来帮助…

OpenAI推出GPT-3.5Turbo微调功能并更新API;Midjourney更新局部绘制功能

&#x1f989; AI新闻 &#x1f680; OpenAI推出GPT-3.5Turbo微调功能并更新API&#xff0c;将提供GPT-4微调功能 摘要&#xff1a;OpenAI宣布推出GPT-3.5Turbo微调功能&#xff0c;并更新API&#xff0c;使企业和开发者能够定制ChatGPT&#xff0c;达到或超过GPT-4的能力。通…

c语言每日一练(11)

前言&#xff1a;每日一练系列&#xff0c;每一期都包含5道选择题&#xff0c;2道编程题&#xff0c;博主会尽可能详细地进行讲解&#xff0c;令初学者也能听的清晰。每日一练系列会持续更新&#xff0c;暑假时三天之内必有一更&#xff0c;到了开学之后&#xff0c;将看学业情…

C#-集合小例子

目录 背景&#xff1a; 过程: 1.添加1-100数: 2.求和: 3.平均值: 4.代码:​ 总结: 背景&#xff1a; 往集合里面添加100个数&#xff0c;首先得有ArrayList导入命名空间&#xff0c;这个例子分为3步&#xff0c;1.添加1-100个数2.进行1-100之间的总和3.求总和的平均值&…

安全帽穿戴检测人脸闸机联动

安全帽穿戴检测人脸闸机联动系统实通过yolov8网络深度学习算法模型&#xff0c;安全帽穿戴检测人脸闸机联动系统现对进入工地施工区域人员是否穿戴安全帽进行精准监测和身份识别&#xff0c;只有在满足这两个条件的情况下&#xff0c;闸机才会打开&#xff0c;允许其进入工地施…

ICT产教融合创新实训基地物联网实训室建设方案

一、概述 1.1物联网定义 物联网工程&#xff08;Internet of Things Engineering&#xff09;是一种以信息技术&#xff08;IT&#xff09;来改善实体世界中人们生活方式的新兴学科&#xff0c;它利用互联网技术为我们的日常生活活动提供服务和增益&#xff0c;从而让各种智能…

怎么借助ChatGPT处理数据结构的问题

目录 使用ChatGPT进行数据格式化转换 代码示例 ChatGPT格式化数据提示语 代码示例 批量格式化数据提示语 代码示例 ChatGPT生成的格式化批处理代码 使用ChatGPT合并不同数据源的数据 合并数据提示语 自动合并数据提示语 ChatGPT生成的自动合并代码 结论 数据合并是…

软件设计师学习笔记6-存储系统

1.层次化存储体系 1.1层次化存储结构 局部性原理是层次化存储结构的支持 时空局部性&#xff1a;刚被访问的内容&#xff0c;立即又被访问(eg: 循环体 ) 空间局部性&#xff1a;刚被访问的内容&#xff0c;临近的空间很快被访问(eg:数组) 1.2层次化存储结构的分类 DRAM&…

VAE原理 代码详解 pin_memory

VAE代码 import torch from torch import nn import torch.nn.functional as F class VAE(nn.Module):def __init__(self, input_dim784, h_dim400, z_dim20): # 28x28784,20可能是这个手写体一共有20类&#xff1f;super(VAE, self).__init__()self.input_dim input_dimsel…

微信开放注册微信小号功能,工作人群福音!

微信&#xff0c;这个坐拥数亿用户的社交巨头&#xff0c;最近终于开放了注册微信小号的功能。这个功能对于需要多个微信账号进行工作的人来说&#xff0c;无疑是一场及时雨&#xff0c;极大地提高了工作便利性。 在之前的版本中&#xff0c;每个微信账号都绑定了一个手机号&am…

主从、哨兵、集群模式有什么区别 ?

目录 1.Redis 多机部署的方式 2.主从、哨兵、集群模式有什么区别 2.1 主从同步 2.2 哨兵模式 2.3 集群模式 1.Redis 多机部署的方式 Redis 多机部署主要有 3 种方式&#xff1a; 1. 主从同步&#xff1a;主要存储数据的节点叫做主节点&#xff08;master&#xff09;&…

限时 180 天,微软为 RHEL 9 和 Ubuntu 22.04 推出 SQL Server 2022 预览评估版

导读近日消息&#xff0c;微软公司今天发布新闻稿&#xff0c;宣布面向 Red Hat Enterprise Linux&#xff08;RHEL&#xff09;9 和 Ubuntu 22.04 两大发行版&#xff0c;以预览模式推出 SQL Server 2022 评估版。 近日消息&#xff0c;微软公司今天发布新闻稿&#xff0c;宣布…

网络安全(黑客)零基础自学

网络安全是什么&#xff1f; 网络安全&#xff0c;顾名思义&#xff0c;网络上的信息安全。 随着信息技术的飞速发展和网络边界的逐渐模糊&#xff0c;关键信息基础设施、重要数据和个人隐私都面临新的威胁和风险。 网络安全工程师要做的&#xff0c;就是保护网络上的信息安…

数字 IC 设计职位经典笔/面试题(三)

共100道经典笔试、面试题目&#xff08;文末可全领&#xff09; 1. IC 设计中同步复位与异步复位的区别&#xff1f; 同步复位在时钟沿变化时&#xff0c;完成复位动作。异步复位不管时钟&#xff0c;只要复位信号满足条件&#xff0c;就完成复位动作。异步复位对复位信号要求…

开始MySQL之路——MySQL的DataGrip图形化界面

下载DataGrip 下载地址&#xff1a;Download DataGrip: Cross-Platform IDE for Databases & SQL 安装DataGrip 准备好一个文件夹&#xff0c;不要中文和空格 C:\Develop\DataGrip 激活DataGrip 激活码&#xff1a; VPQ9LWBJ0Z-eyJsaWNlbnNlSWQiOiJWUFE5TFdCSjBaIiwibGl…

用 Audacity 比较两段音频差异

工作中遇到相同的处理流程&#xff0c;处理同一段音频&#xff0c;看看处理结果是否一致&#xff0c;可以用audacity来处理。 假设待比较的音频分别为 1.wav 2.wav 1、用Audacity打开1.wav 2、用Audacity打开2.wav&#xff0c;选中音频&#xff0c;然后用 效果 -> 反向&am…