ORB-SLAM2详细安装教程(ubuntu18.04)

本文提供了一步一步的教程,详细介绍如何在Ubuntu18.04上安装ORB-SLAM2,包括安装Pangolin、OpenCV和Eigen等依赖库,以及处理安装过程中可能遇到的问题。作者还分享了使用Docker简化安装过程的经验,并提供了验证安装成功的示例。
摘要由CSDN通过智能技术生成

前言

paper:https://arxiv.org/pdf/1610.06475.pdf
githup::https://github.com/raulmur/ORB_SLAM2
提示:ORB-SLAM2源码作者推荐在Ubuntu 12.04, 14.04 和16.04上安装运行。
最近在ubuntu18.04上配置ORB-SLAM2运行环境时踩了很多坑,在这期间查阅了很多资料和博客,于是想对安装过程进行总结,方便自己反复查阅以及分享经验避免大家重复踩坑。
博主是用docker在ubuntu18.04容器中安装的ORB-SLAM2,已经打包成docker的镜像文件分享给大家。

# 查看ubuntu版本号
lsb_release -a


安装前的准备:安装cmake、git 、gcc 和g++

# 更新apt库,更新软件列表
sudo apt-get update

apt-get源修改参考

# 安装git,用于从Github上克隆项目到本地
sudo apt-get install git
# 安装cmake,用于程序的编译
sudo apt-get install cmake
# 安装gcc和g++,安装c和c++编译器
sudo apt-get install gcc g++

一、安装第三方库

# 建立一个ORB-SLAM2的文件夹,建议将所有的第三方库以及ORB-SLAM2源码都放入其中
mkdir ORB-SLAM2

可能需要安装百度云:

# 安装百度云,xxx.deb是自己下载的版本
sudo dpkg -i baidunetdisk_4.17.7_amd64.deb

1.安装Pangolin

Pangolin是对OpenGL进行封装的轻量级的OpenGL输入/输出和视频显示的库。
1.安装依赖项

sudo apt-get install libgl1-mesa-dev
sudo apt-get install libglew-dev
sudo apt-get install libboost-dev libboost-thread-dev libboost-filesystem-dev
sudo apt-get install libpython2.7-dev

2.安装 Pangolin
通过链接或通过git下载Pangolin源码(不推荐,问题很多)

# 需要科学上网
git clone --recursive https://github.com/stevenlovegrove/Pangolin.git

强烈推荐Pangolin 0.6(稳定版) 提取码:45bo

# 解压并重命名为Pangolin
unzip Pangolin-0.6.zip && mv Pangolin-0.6 Pangolin
# 开始编译和安装
cd Pangolin
mkdir build && cd build 
cmake -DCPP11_NO_BOOST=1 ..
sudo make install

3.验证安装是否完成

# 验证
cd ../examples/HelloPangolin
mkdir build && cd build
cmake ..
make
./HelloPangolin

若安装成功,则会弹出以下窗口:

2.安装OpenCV

可以参考该链接
1.安装依赖项

# 解决:Unmet dependencies.Try'apt--fix-broken install'with no packages(or specify a solution)
sudo apt --fix-broken install
sudo apt-get update
sudo apt-get upgrade

sudo apt-get install build-essential libgtk2.0-dev libavcodec-dev libavformat-dev libjpeg.dev
sudo apt-get install libtiff5.dev libswscale-dev

# 解决:add-apt-repository: command not found
sudo apt-get install software-properties-common

sudo apt-get update
sudo add-apt-repository "deb http://security.ubuntu.com/ubuntu xenial-security main"
sudo apt-get update
sudo apt-get install libjasper1 libjasper-dev

2.安装 OpenCV3.4.5
OpenCV3.4.5源码 提取码:m27t (OpenCV老版本可在Github仓库右侧的Releases里找)

# 解压并重命名为opencv
tar -xvf opencv-3.4.5.tar.gz && mv opencv-3.4.5 opencv
# 开始编译和安装
cd opencv
mkdir build && cd build 
cmake -D CMAKE_BUILD_TYPE=Release -D CMAKE_INSTALL_PREFIX=/usr/local ..
# 4线程数量,根据电脑性能选择合适的数字
make -j4
sudo make install

3.验证安装是否完成

# 查询OpenCV版本
pkg-config --modversion opencv
# 查询OpenCV库
pkg-config --cflags opencv
# 查询头文件目录
pkg-config --libs   opencv

# 验证
cd opencv/samples/cpp/example_cmake
cmake .
make
./opencv_example

若安装成功,则会弹出以下窗口:

3.安装Eigen

1.安装 Eigen3.3.7
建议源码安装可以下载任意版本对应的文件。

# 解压并重命名为eigen
tar -xvf eigen-3.3.7.tar.gz && mv eigen-3.3.7 eigen
# 开始编译和安装
cd eigen
mkdir build && cd build
cmake ..
make
sudo make install

# 在很多程序中include时经常使用#include <Eigen/Dense>而不是使用#include <eigen3/Eigen/Dense>
# 因此安装后需要将头文件从 /usr/local/include/eigen3/ 复制到 /usr/local/include
# 后续小节会有C++测试代码说明
sudo cp -r /usr/local/include/eigen3/Eigen /usr/local/include

2.测试eigen库安装完成
在home目录下新建一个test.cp 文件用以测试。

# 建立 test 测试文件
touch test_eigen.cpp
# 用gedit打开此测试文件,添加C++代码用于测试
gedit test_eigen.cpp
# 编译后生成一个test_eigen的可执行文件
g++ test_eigen.cpp -o test_eigen
# 在test_eigen可执行文件目录下执行以下命令,证明eigen库安装完成
./test_eigen

在test_eigen.cpp文件中添加的C++测试代码。

#include <iostream>
//需要将头文件从 /usr/local/include/eigen3/ 复制到 /usr/local/include
#include <Eigen/Dense>
//using Eigen::MatrixXd;
using namespace Eigen;
using namespace Eigen::internal;
using namespace Eigen::Architecture;
using namespace std;
int main()
{
        cout<<"*******************1D-object****************"<<endl;
        Vector4d v1;
        v1<< 1,2,3,4;
        cout<<"v1=\n"<<v1<<endl;
 
        VectorXd v2(3);
        v2<<1,2,3;
        cout<<"v2=\n"<<v2<<endl;
 
        Array4i v3;
        v3<<1,2,3,4;
        cout<<"v3=\n"<<v3<<endl;
 
        ArrayXf v4(3);
        v4<<1,2,3;
        cout<<"v4=\n"<<v4<<endl;
}

二、安装以及运行ORB-SLAM2

1.安装编译ORB-SLAM2

# 通过git下载ORB_SLAM2源码,需要科学上网
git clone https://github.com/raulmur/ORB_SLAM2.git ORB_SLAM2
cd ORB_SLAM2
# 赋予shell文件运行权限
chmod +x build.sh
# 需要科学上网
# 博主根据个人电脑性能将build.sh里的make -j 修改为 make -j8
./build.sh

常见的错误

编译时如果有如下错误,在对应的头文件中加上 #include <unistd.h>

# 下列是需要加上#include <unistd.h>的c++文件
# 在ORB_SLAM2/src文件夹下
LocalMapping.cc	
LoopClosing.cc
System.cc	
Tracking.cc
Viewer.cc
# 在ORB_SLAM2/Examples/RGB-D文件夹下
rgbd_tum.cc
# 在ORB_SLAM2/Examples/Monocular文件夹下
mono_kitti.cc
mono_euroc.cc
mono_tum.cc
# 在ORB_SLAM2/Examples/Stereo/文件夹下
stereo_euroc.cc
stereo_kitti.cc

或者直接在 ORB_SLAM2/include/System.h 中加上 #include <unistd.h> (强烈推荐)

如果又有如下错误,可以使用gedit打开或者执行以下命令安装xterm

sudo apt-get update
sudo apt-get upgrade
sudo apt-get install xterm

2.单目模式运行演示案例

TUM 数据集
数据下载链接,下载如下数据集

# 解压数据集
tar -xvf rgbd_dataset_freiburg1_desk.tgz

根据数据集要求: Examples/Monocular/TUM1.yaml 对应 freiburg1

执行以下命令显示效果

./Examples/Monocular/mono_tum Vocabulary/ORBvoc.txt Examples/Monocular/TUM1.yaml /root/Downloads/rgbd_dataset_freiburg1_desk/

3.RGBD模式模式运行演示案例

需额外下载associate.py添加到数据文件夹下

个人理解:作用是使RGD和depth的数据做一个对齐,一 一对应。

注意:只能在Python2 环境下运行

# associate.py需要numoy包
sudo apt-get install python-pip
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple numpy

# 在数据文件夹里执行命令
python associate.py rgb.txt depth.txt > associate.txt
python associate.py associate.txt groundtruth.txt > associate_with_groundtruth.txt


执行以下命令显示效果

./Examples/RGB-D/rgbd_tum Vocabulary/ORBvoc.txt Examples/RGB-D/TUM1.yaml /root/Downloads/rgbd_dataset_freiburg1_desk/ /root/Downloads/rgbd_dataset_freiburg1_desk/associate.txt

总结

尽可能简单、详细的介绍ORB-SLAM2的安装流程以及解决了安装过程中可能存在的问题。后续会根据自己学到的知识结合个人理解讲解ORB-SLAM2的原理和代码。

要安装ORB_SLAM2,您可以按照以下步骤进行操作: 1. 首先,安装git,可以使用以下命令进行安装: ``` sudo apt-get install git ``` 2. 克隆ORB_SLAM2的代码库,可以使用以下命令进行克隆: ``` git clone https://github.com/raulmur/ORB_SLAM2 ``` 3. 进入克隆的ORB_SLAM2文件夹,可以找到安装所需的文件: ``` cd ORB_SLAM2 ``` 4. 编译ORB_SLAM2,首先编译总的ORB_SLAM2,然后再编译ROS。可以使用以下命令进行编译: ``` chmod +x build_ros.sh export ROS_PACKAGE_PATH=${ROS_PACKAGE_PATH}:~/catkin_ws/src/ORB_SLAM2/Examples/ROS ./build_ros.sh ``` 5. 如果您之前在工作空间外编译过ORB_SLAM2,请先删除原来的build文件夹: ``` cd ~/catkin_ws/src/ORB_SLAM2/ rm -r build ``` 6. 创建一个新的build文件夹,并进入该文件夹: ``` mkdir build cd build ``` 7. 使用cmake命令生成Makefile: ``` cmake .. ``` 8. 使用make命令进行编译: ``` make ``` 9. 接下来,单独编译ROS部分,返回主目录: ``` cd //回到主目录 ``` 10. 进入ROS示例文件夹,并创建一个新的build文件夹,并进入该文件夹: ``` cd ~/catkin_ws/src/ORB_SLAM2/Examples/ROS/ORB_SLAM2/ mkdir build cd build ``` 11. 使用cmake命令生成Makefile: ``` cmake .. ``` 12. 使用make命令进行编译: ``` make ``` 这样,您就完成了ORB_SLAM2的安装过程。请注意,以上步骤仅供参考,具体的安装过程可能会因您的系统环境而有所不同。 #### 引用[.reference_title] - *1* [slam系列之ORB_SLAM2安装](https://blog.csdn.net/qq_42650246/article/details/126004388)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [[详细教程]ORB-SLAM2安装教程](https://blog.csdn.net/weixin_45617478/article/details/109813027)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Ubuntu18.04安装和配置ORB_SLAM2(非ROS、ROS环境)](https://blog.csdn.net/m0_65009717/article/details/123885882)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 31
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值