保姆级避坑指南:在Ubuntu 20.04上搞定ego-planner与PX4仿真(解决eigen3版本冲突)

张开发
2026/4/19 19:09:24 15 分钟阅读

分享文章

保姆级避坑指南:在Ubuntu 20.04上搞定ego-planner与PX4仿真(解决eigen3版本冲突)
Ubuntu 20.04下ego-planner与PX4仿真的深度避坑手册当你在深夜的实验室里面对满屏红色报错信息时是否也曾怀疑人生作为过来人我完全理解那种在搭建ego-planner三维路径规划环境时的崩溃感。本文将带你穿越这片雷区从eigen3版本冲突到ceres兼容性问题手把手教你避开那些教科书上不会写的坑。1. 环境准备从零开始的正确姿势在开始之前我们需要明确几个关键点。Ubuntu 20.04作为长期支持版本其软件源中的默认库版本可能与ego-planner所需存在差异。以下是基础环境配置清单# 必备工具链安装 sudo apt update sudo apt install -y \ git cmake build-essential \ python3-dev python3-pip \ libblas-dev liblapack-dev \ libsuitesparse-dev常见误区警示直接使用apt安装eigen3会导致版本过低默认3.3.7忽略ROS Noetic与其他库的版本依赖关系未正确设置环境变量导致库路径混乱提示建议在全新系统上操作避免已有环境造成干扰。如果必须保留现有环境考虑使用Docker容器隔离。2. eigen3版本冲突的终极解决方案eigen库的版本问题堪称ego-planner环境搭建的第一大杀手。以下是经过实战验证的解决流程2.1 彻底清理旧版本# 查找并删除所有eigen3相关文件 sudo updatedb locate eigen3 | xargs sudo rm -rf # 验证清理结果应无输出 locate eigen32.2 源码编译安装eigen3.3.7wget https://gitlab.com/libeigen/eigen/-/archive/3.3.7/eigen-3.3.7.tar.gz tar xzf eigen-3.3.7.tar.gz cd eigen-3.3.7 mkdir build cd build cmake .. -DCMAKE_INSTALL_PREFIX/usr/local sudo make install # 关键步骤确保Eigen头文件被正确链接 sudo cp -r /usr/local/include/eigen3/Eigen /usr/local/include sudo ln -s /usr/local/include/eigen3 /usr/include/eigen3版本验证方法grep #define EIGEN_WORLD_VERSION /usr/local/include/eigen3/Eigen/src/Core/util/Macros.h3. ceres-solver的兼容性调优ceres-solver作为非线性优化库其与eigen3的配合至关重要。推荐以下配置方案参数推荐值说明Eigen版本3.3.7必须严格匹配ceres版本1.14.0验证稳定的版本LAPACK启用提升矩阵运算性能SuiteSparse启用提供稀疏矩阵支持编译命令示例git clone https://ceres-solver.googlesource.com/ceres-solver cd ceres-solver git checkout 1.14.0 mkdir build cd build cmake .. -DEIGEN_INCLUDE_DIR/usr/local/include/eigen3 \ -DBUILD_TESTINGOFF \ -DBUILD_EXAMPLESOFF make -j$(nproc) sudo make install4. XTDrone环境配置实战4.1 仿真模型适配在PX4仿真中相机模型的选择直接影响VINS-Fusion的表现!-- 修改iris_stereo_camera.sdf为iris_realsense_camera -- include urimodel://iris_realsense_camera/uri nameiris/name /include4.2 自动化启动脚本优化原生的plan.sh脚本可能存在时序问题改进版本如下#!/bin/bash # 增加错误检测和重试机制 function safe_launch() { local cmd$1 local retries3 while ((retries--)); do if eval $cmd; then return 0 fi sleep 2 done echo Failed to execute: $cmd 2 exit 1 } safe_launch roslaunch px4 indoor1.launch sleep 10 # 给PX4足够的启动时间 safe_launch bash ~/catkin_ws/scripts/xtdrone_run_vio.sh sleep 5 safe_launch python ~/XTDrone/sensing/slam/vio/vins_transfer.py iris 0 safe_launch roslaunch vins rtabmap_vins.launch ...5. 常见报错与快速修复指南5.1 Eigen相关错误症状error: ScalarBinaryOpTraits is not a member of Eigen解决方案# 检查头文件搜索路径 echo $C_INCLUDE_PATH echo $CPLUS_INCLUDE_PATH # 确保包含/usr/local/include export C_INCLUDE_PATH/usr/local/include:$C_INCLUDE_PATH export CPLUS_INCLUDE_PATH/usr/local/include:$CPLUS_INCLUDE_PATH5.2 ROS消息类型冲突症状[ERROR] [1623456789.123456]: Could not find a package configuration file provided by vins修复步骤检查~/.bashrc中的ROS环境变量确认所有工作空间已正确source重建ROS消息缓存rosdep install --from-paths src --ignore-src -r -y6. 性能优化与调试技巧6.1 实时性调优参数在ego_planner/launch/single_uav.launch中添加param nameplanner/optimization_time value0.05 / param namevisualization/draw_interval value0.1 /6.2 RViz可视化配置保存以下配置为ego_rviz.rvizVisualization Manager: Enabled: - name: Global Options Value: false - name: RobotModel Value: true - name: Planning Scene Value: true Views: Current: Target Frame: world Class: rviz/Orbit7. 进阶自定义仿真环境创建自定义世界的关键步骤复制empty.world模板cp ~/PX4_Firmware/Tools/sitl_gazebo/worlds/empty.world ~/custom.world添加障碍物模型model namebuilding1 pose5 5 0 0 0 0/pose statictrue/static link namelink collision namecollision geometry box size10 2 20/size /box /geometry /collision visual namevisual geometry box size10 2 20/size /box /geometry /visual /link /model在完成所有配置后记得先在小范围内测试路径规划效果。我曾在测试时发现当障碍物密度超过某个阈值时规划器会出现奇怪的绕行行为——后来发现是代价函数权重需要调整。这种细节问题往往需要结合具体场景反复调试。

更多文章