Advertisement

ubuntu18.04 编译HBA 并实例运行

阅读量:

HBA是一个激光点云层级式的全局优化的程序,他的论文题目是:HBA: A Globally Consistent and Efficient Large-Scale LiDAR Mapping Module,对应的github地址是:HKU-Mars-Lab · GitHub

学习本博客,可以学到gtsam安装,cmake高版本安装,ceres2.2.0的安装,以及一个HBA编译问题的解决,最后把HBA给编译成功.

(0)当遇到libqwayland-egl.so 文件不存在的问题

当遇到这个问题的时候:

The imported target "Qt5::Gui" references the file

"/usr/lib/x86_64-linux-gnu/qt5/plugins/platforms/libqwayland-egl.so"

but this file does not exist.

文件夹中不存在 libqwayland-egl.so 这个库文件,执行下面语句就可以消除该错误:

复制代码
    sudo apt install qtwayland5
    

(1)安装gtsam

1.首先安装 依赖

复制代码
 sudo apt-get install libtbb-dev

    
 sudo apt-get install libeigen3-dev
    
    
    
    

2.然后下载源代码

复制代码
    git clone https://bitbucket.org/gtborg/gtsam.git
    

3.编译安装

复制代码
 cd gtsam

    
 mkdir build && cd build
    
 cmake ..
    
 make
    
 sudo make install 
    
    
    
    

(2)安装cmake 大于3.10版本

安装ceres的时候,必须要求cmake在3.16-3.28之间,但是ros的cmake是3.10版本,因此需要单独安装cmake。参考网上教程可以发现,很多cmake安装 的第一行命令中,有autoremove,这是一个天坑安装cmake的方法,因为它会直接把ros给卸载了。

正确的安装方法如下:

1.下载cmake-3.18.5.tar.gz

Index of /files/v3.18

2. 解压并进入目录中

复制代码
 tar -xf cmake-3.18.5.tar.gz

    
 cd cmake-3.18.5/
    
    
    
    

3.执行配置、编译和安装命令

复制代码
 ./configure --prefix=/usr/local/cmake

    
 make 
    
 sudo make install
    
    
    
    

5.设置软连接

复制代码
    ln -s /usr/local/cmake/bin/cmake /usr/bin/cmake
    
    

如果执行上述命令报“ln: failed to create symbolic link ‘/usr/bin/cmake’: File exists”错误,显示已有软连接(‘/usr/bin/cmake’),则执行如下命令删除软链接(软连接’/usr/bin/cmake’仅为示例,请用户以实际情况为准):

复制代码
    rm -rf /usr/bin/cmake
    

6.检查cmake的版本

复制代码
    cmake --version
    

详细可参考 :ubuntu18.04安装cmake3.12.0步骤_ubuntu安装cmake3.12-博客

(3)安装ceres2.2.0

1.下载

GitHub - ceres-solver/ceres-solver: A large scale non-linear optimization library

2.安装官网教程

官网:Installation — Ceres Solver

2.1首先配置环境

复制代码
 sudo apt-get install libgoogle-glog-dev libgflags-dev

    
 # Use ATLAS for BLAS & LAPACK
    
 sudo apt-get install libatlas-base-dev
    
 # Eigen3
    
 sudo apt-get install libeigen3-dev
    
 # SuiteSparse (optional)
    
 sudo apt-get install libsuitesparse-dev
    
    
    
    

2.2然后构建和编译以及安装

复制代码
 tar zxf ceres-solver-2.2.0.tar.gz

    
 mkdir ceres-bin
    
 cd ceres-bin
    
 cmake ../ceres-solver-2.2.0
    
 make -j3
    
 make test
    
 # Optionally install Ceres, it can also be exported using CMake which
    
 # allows Ceres to be used without requiring installation, see the documentation
    
 # for the EXPORT_BUILD_DIR option for more information.
    
 make install
    
    
    
    

2.3最后可以用一个例子进行测试

复制代码
    bin/simple_bundle_adjuster ../ceres-solver-2.2.0/data/problem-16-22106-pre.txt
    
    

这样就安装好了ceres2.2.0

(4)解决编译问题typedef struct LZ4_stream_t LZ4_stream_t’

在ceres也通过编译之后,会遇到:

/usr/include/lz4.h:196:57: error: conflicting declaration ‘typedef struct LZ4_stream_t LZ4_stream_t’

这时候使用

复制代码
 sudo mv /usr/include/flann/ext/lz4.h /usr/include/flann/ext/lz4.h.bak

    
 sudo mv /usr/include/flann/ext/lz4hc.h /usr/include/flann/ext/lz4hc.h.bak
    
  
    
 sudo ln -s /usr/include/lz4.h /usr/include/flann/ext/lz4.h
    
 sudo ln -s /usr/include/lz4hc.h /usr/include/flann/ext/lz4hc.h
    
    
    
    

(5)编译HBA程序

然后进入HBA的ws环境,进行catkin_make就可以编译成功.

(6)HBA运行park数据

1.下载数据和了解数据格式

首先下载github HBA工程中,提供的park和kitt7数据,加起来大约2G。

然后解压。以park数据为例子,目录结构是:

park

-pcd

-0.pcd

-1.pcd

-pose.json

其中pose.json中,每一行是按照 tx ty tz qw qx qy qz来排列的。

2.修改hba.launch的文件中对应的参数

要想使用hba进行优化,首先需要修改hba.launch文件中的文件夹路径和文件名的控制值

复制代码
 <launch>

    
   <node pkg="hba" type="hba" name="hba" output="screen">
    
     <param name="data_path" type="string" value="/home/zhu/park/"/>
    
     <param name="total_layer_num" type="int" value="3"/>
    
     <param name="pcd_name_fill_num" type="int" value="0"/> <!--set 5 for kitti07 and 0 for park-->
    
     <param name="thread_num" type="int" value="16"/>
    
   </node>
    
  
    
   <arg name="rviz" default="0"/>
    
   <group if="$(arg rviz)">
    
     <node launch-prefix="nice" pkg="rviz" type="rviz" name="rviz"
    
     args="-d $(find hba)/rviz_cfg/rosbag.rviz" />
    
   </group>
    
 </launch>
    
    
    
    

注意:

1.修改:data_path 就是park数据集的文件根目录, 在这里我的路径是/home/zhu/park/,

2.修改:pcd_name_fill_num 的value设置为0,表示没有格式控制,否则需要提供00000.pcd这样的命名格式。

3.修改visualize.launch中的参数的值

同样的也对visualize.launch 这两个位置进行修改。

复制代码
 <launch>

    
   <node pkg="hba" type="visualize_map" name="visualize_map" output="screen">
    
     <param name="file_path" type="string"
    
       value="/home/zhu/park/"/>
    
     <param name="downsample_size" type="double" value="0.1"/>
    
     <param name="pcd_name_fill_num" type="int" value="0"/> <!--set 5 for kitti07 and 0 for park-->
    
     <param name="marker_size" type="double" value="0.5"/>
    
   </node>
    
  
    
   <arg name="rviz" default="1"/>
    
   <group if="$(arg rviz)">
    
     <node launch-prefix="nice" pkg="rviz" type="rviz" name="rviz"
    
     args="-d $(find hba)/rviz_cfg/rosbag.rviz" />
    
   </group>
    
 </launch>
    
    
    
    

3.开始进行hba优化

复制代码
    roslaunch hba hba.launch
    

执行情况如下图:

执行结果最终保存出来了优化后的位姿,从截图上可以看出优化了3407个位姿。值得注意的是,执行完后,它写出的pose.json把park数据集目录下的pose.json给覆盖了,这有点猝不及防。

4.显示出来

复制代码
    roslaunch hba visualize.launch
    

就是把park数据集,按照优化后的pose.json中的位姿和 pcd中的文件,按照visualize.launch中的分辨率进行降采样,然后显示出来。

最后显示的结果是:

可以看到,周围的建筑物边缘对的并不齐,所以HBA还是有优化改进的空间。

显示路径

全部评论 (0)

还没有任何评论哟~