Go to file
邱棚 a92e8b2a9c feat:添加中文注释 2025-02-21 17:22:15 +08:00
common fix bug in common::Range 2021-07-06 00:01:19 +08:00
configs add lines in README 2021-07-06 00:01:12 +08:00
examples feat:添加中文注释 2025-02-21 10:36:49 +08:00
images add lines in README 2021-07-06 00:01:12 +08:00
oh_my_loam feat:添加中文注释 2025-02-21 17:22:15 +08:00
.clang-format add .clang-format 2021-07-06 00:01:22 +08:00
.gitignore add .clang-format 2021-07-06 00:01:22 +08:00
CMakeLists.txt add lines in README 2021-07-06 00:01:12 +08:00
LICENSE.txt add BSD license file 2022-05-10 09:33:20 +08:00
README.md update README 2022-05-10 09:35:51 +08:00

README.md

Oh-My-LOAM

Oh-My-LOAM is a ROS-free implementation of LOAM (J. Zhang and S. Singh. LOAM: Lidar Odometry and Mapping in Real-time). This implementation is modified from A-LOAM.

Comparing with A-LOAM, this implementation has following features:

  • ROS-free: it can run without ROS environment
  • Multi-threading instead of multi-process: more deterministic
  • Higher code quality: more readable and easier to understand/modify
nsh_indoor_outdoor

NOTE: This project is licensed under the terms of the BSD license.

How to run

BUILD

Install dependences (listed below).
Clone this repository
Compile:

mkdir build && cd build
cmake ..
make -j6

Run with ROS bag as input

Although Oh-My-LOAM is ROS-free, running it with ROS bag as input is the simplest way. We'll take nsh_indoor_outdoor.bag as example. You can download this bag from google drive or baidupan (提取码:9nf7).

Launch Oh-My-LOAM:

./devel/lib/oh_my_loam/main_rosbag ../configs/config_nsh_indoor_outdoor.yaml

Play ROS bag (in a new terminal):

ros play nsh_indoor_outdoor.bag

Run without ROS support

Launch Oh-My-LOAM:

./devel/lib/oh_my_loam/main_noros ../configs/config_nsh_indoor_outdoor.yaml xxxxxx

Please replace xxxxxx with the directory that contains the input point cloud files with tree structure like following:

xxxxxx
├── frame00000.pcd               
├── frame00001.pcd               
├── frame00002.pcd               
├── frame00003.pcd               
├── frame00004.pcd
├── ...          

Currently only .pcd format is supported. You can modify examples/main_noros.cc to add support for other point cloud formats.

Dependences

OS

Tested on ubuntu 16.04/18.04/20.04.

C++17

If cannot find std::filesystem error is encountered during your compiling, please upgrade your compiler. We recommend g++-9 (or higher version).

ROS

Only examples/main_rosbag.cc needs ROS. You can exclude it from compiling by modifying examples/CMakeLists.txt.

Eigen: linear algebra, quaternion

sudo apt install libeigen3-dev

pcl: point cloud processing

sudo apt install libpcl-dev

g3log: logging

Follow g3log to install.

yaml-cpp: yaml parsing

sudo apt install libyaml-cpp-dev

ceres: non-linear optimization

sudo apt install libceres-dev