作者:
Xiangcheng HU、
Jin Wu、
Xieyuanli Chen
联系邮箱:xhubd@connect.ust.hk
面向激光雷达位姿图的离线手动闭环编辑与优化工具。
点击卡片可观看完整的 YouTube 演示视频。
本仓库将手动闭环工作流整理为一个独立项目,包含:
- 用于轨迹检查和点云辅助闭环编辑的 PyQt 图形界面
- 用于导出新位姿图和地图的 Python 优先离线优化后端
- 用于虚拟环境、Python GTSAM 检查、legacy 后端构建、环境检查和截图生成的辅助脚本
它面向已经导出以下结果的建图任务:
pose_graph.g2ooptimized_poses_tum.txtkey_point_frame/*.pcd
该图形界面支持轨迹检查、节点对和已有闭环边选择、source/target 点云预览、GICP 配准、手工新增或替换闭环约束、工作态位姿图管理,以及新优化地图导出。
在确认 GICP 结果后新增一条手工闭环边。
用更可靠的手工配准结果替换已有闭环边。
在重新优化前临时禁用已有闭环边。
| 功能 | 说明 |
|---|---|
| 内嵌式 PyQt + Open3D viewer | 在一个工作流中查看轨迹与点云 |
Working / Original 双轨迹对比 |
对比编辑图与基线图 |
| 手工新增、替换、禁用、恢复闭环边 | 显式控制 working session 中的闭环约束 |
| 点云视图中的 source 初值交互调整 | 在 GICP 前修正初始位姿 |
| 面向地面机器人的 Auto Yaw Sweep | 在最终配准前搜索 yaw 初值 |
导出新的 g2o、TUM、地图和轨迹 PCD |
在验证完成后输出优化结果 |
| 带撤销和改动跟踪的会话式图编辑 | 更可控地管理闭环边修改流程 |
cd ~/my_git/Mannual-Loop-Closure-Tools
make docker-build
xhost +local:docker
docker run --rm -it \
--net=host \
-e DISPLAY=$DISPLAY \
-e QT_X11_NO_MITSHM=1 \
-v /tmp/.X11-unix:/tmp/.X11-unix:rw \
-v /path/to/mapping_session:/data/session \
manual-loop-closure-tools:latest \
python launch_gui.py --session-root /data/session面向首次使用者的 Docker FAQ:
- 先执行显示权限放通:
xhost +local:docker - 把宿主机 session 目录挂载到
/data/session - 宿主机输出会落在
manual_loop_projects/、manual_loop_runs/和manual_loop_exports/ - 无图形界面环境可以直接使用 Python 优化器 CLI
- 详细说明见:docs/DOCKER.md
cd ~/my_git/Mannual-Loop-Closure-Tools
make venv
source .venv/bin/activate
make gtsam-python
python launch_gui.py --session-root /path/to/mapping_session对于大多数用户,到这里就够了。ROS、catkin 和 legacy C++ optimizer 都是可选项。
Python GTSAM 4.3 wrapper 现在可以通过仓库辅助脚本一键安装:
make gtsam-python- 或
bash scripts/install_gtsam_python.sh - 详细说明见:docs/INSTALL_GTSAM_PYTHON.md
也可以直接指定某个 g2o 文件:
python launch_gui.py --g2o /path/to/pose_graph.g2ocd ~/my_git/Mannual-Loop-Closure-Tools
conda env create -f environment.yml
conda activate manual-loop-closure
python launch_gui.py --session-root /path/to/mapping_session在重新审查位姿图优化链路并与当前 C++ 实现对照后,本仓库已经把 Python backend 作为当前验证过的手动闭环工作流的正常主路径。
legacy C++ optimizer 现在仅保留为:
- 开发者回退路径
- parity 对照参考
- 回归基线路径
普通安装和 GUI 使用都不再依赖它。
如果你仍然需要本地编译 legacy backend:
cd ~/my_git/Mannual-Loop-Closure-Tools
make backend默认情况下,GUI 现在只突出 Python-first 路径;legacy C++ 选择器仅在开发者显式开启时显示。
当前最重要的几个运行时选项如下:
Advanced中的Optimize- 默认模式是
Fast ISAM2,用于多轮图编辑时的快速更新。 Accurate LM仍保留为 batch 风格的精确参考求解。
- 默认模式是
Registration中的TgtVoxel- 默认值:
0.1 m - 影响预览和 GICP 使用的 target 子图密度。
- 默认值:
Advanced中的MapVoxel- 默认值:
0.1 m - 只影响
Export阶段最终全局地图的重建体素大小。
- 默认值:
建议用法:
- 在反复新增、替换、禁用或恢复闭环边时,优先使用
Fast ISAM2 - 在导出前或需要和 batch 基线对照时,可切回
Accurate LM - 点击
Add或Replace后,当前 GICP 候选会被消费,按钮会重新灰掉 - 如果你修改了初值、delta 或 target map 参数,需要重新运行 GICP 才能再次接受图改动
你可以通过下面的链接下载示例建图结果,快速验证工具流程:
当前仓库内容在 Ubuntu 20.04 环境下使用如下依赖版本进行了测试。Python-only 是主路径,ROS/catkin backend 保留为 fallback。
| Ubuntu | ROS | Python | catkin_tools | CMake | GCC / G++ |
|---|---|---|---|---|---|
| 20.04 | Noetic (fallback) | 3.10.16 | 0.9.4 | 3.25.0 | 9.4.0 |
| Open3D | PyQt5 | Qt | NumPy | SciPy | Matplotlib | OpenCV | PCL | GeographicLib | GTSAM |
|---|---|---|---|---|---|---|---|---|---|
| 0.19.0 | 5.15.10 | 5.15.2 | 1.24.4 | 1.14.1 | 3.10.8 | 4.2.0 | 1.10.0 | 1.50.1 | 4.3.0 |
工具现在把编辑状态、优化运行结果和最终导出清单分开保存:
| 位置 | 作用 | 主要文件 |
|---|---|---|
manual_loop_projects/<project_id>/ |
持久化编辑项目,便于恢复和复盘 | project_state.json, execution.log, operations.jsonl |
manual_loop_runs/<run_id>/ |
一次 Optimize 的真实输出 |
edited_input_pose_graph.g2o, manual_loop_constraints.csv, pose_graph.g2o, optimized_poses_tum.txt, pose_graph.png, manual_loop_report.json, run_context.json |
manual_loop_exports/<export_id>/ |
轻量级最终导出清单,不再重复复制整包 run 数据 | export_manifest.json, selected_run.txt, run 软链接 |
恢复逻辑:
Load Session会恢复该 session 当前最新的编辑项目。Resume Project可以通过选择某个project_state.json打开历史编辑项目。Optimize会立即更新 working graph 和优化后的 TUM,但默认不重建整张地图。Export会在写最终清单前按需生成global_map_manual_imu.pcd和trajectory.pcd。Export不再复制整包优化结果,而是写一个指向目标 run 的清单。
Python backend 已在多组真实 session 上与 legacy C++ optimizer 做过一致性验证。GUI 现在默认走 Python,只有在 Python 优化失败且本地存在 legacy 二进制时才会隐藏回退到 C++。
| Session | Constraints | Python time [s] | C++ time [s] | TUM max t err [m] | TUM max r err [rad] | g2o max t err [m] | g2o max r err [rad] | Map points Py / C++ |
|---|---|---|---|---|---|---|---|---|
office_fs_fastlio_saved |
1 | 10.193 | 2.096 | 5.20e-09 | 3.11e-06 | 6.85e-05 | 3.27e-06 | 4,850,749 / 4,850,749 |
floor34-1_fs_fastlio_saved |
1 | 16.335 | 3.827 | 1.00e-09 | 3.56e-06 | 6.83e-05 | 4.50e-06 | 13,771,605 / 13,771,605 |
dr_tunnel_2026_01_24_145439 |
0 | 12.112 | 2.909 | 2.49e-08 | 2.87e-09 | 4.99e-04 | 1.05e-06 | 2,139,789 / 2,139,789 |
说明:
optimized_poses_tum.txt已在1e-9 m到1e-8 m的平移量级和1e-6 rad的旋转量级上与 C++ 对齐。pose_graph.g2o的残余差异主要来自导出文本精度和四元数符号等价表示,而不是优化结果失配。
Mannual-Loop-Closure-Tools/
├── README.md
├── README.zh.md
├── CHANGELOG.md
├── CONTRIBUTING.md
├── LICENSE
├── Makefile
├── Dockerfile
├── requirements.txt
├── environment.yml
├── launch_gui.py
├── assets/
├── docs/
├── gui/
├── backend/
│ └── catkin_ws/
│ └── src/
│ ├── CMakeLists.txt
│ └── manual_loop_closure_backend/
├── scripts/
└── wiki/
make help
make gtsam-python
make check
make env-check
make optimizer-help
make docker-build
make backend
make assets SESSION_ROOT=/path/to/session本仓库聚焦于独立的手动闭环工具链,不包含完整的在线建图系统。
本项目源自并服务于更完整的 MS-Mapping 研究与代码体系:
如果你在学术工作中使用了本仓库,也请同时引用 MS-Mapping 论文:
@misc{hu2024msmapping,
title={MS-Mapping: An Uncertainty-Aware Large-Scale Multi-Session LiDAR Mapping System},
author={Xiangcheng Hu, Jin Wu, Jianhao Jiao, Binqian Jiang, Wei Zhang, Wenshuo Wang and Ping Tan},
year={2024},
eprint={2408.03723},
archivePrefix={arXiv},
primaryClass={cs.RO},
url={https://arxiv.org/abs/2408.03723},
}本独立仓库采用 GNU General Public License v3.0(GPLv3)。




