从编译错误到成功仿真:记录我调试MIT Mini Cheetah源码时遇到的3个典型问题

news2026/4/11 8:51:00
从编译错误到成功仿真记录我调试MIT Mini Cheetah源码时遇到的3个典型问题调试MIT Mini Cheetah开源代码的过程就像是在解一道复杂的数学题——每一步都可能隐藏着意想不到的陷阱。作为一个曾经在这个项目上耗费了整整两个周末的开发者我深刻理解那种被编译错误困扰的挫败感。本文将分享我在搭建Mini Cheetah仿真环境时遇到的三个最具代表性的编译错误以及最终找到的解决方案。不同于简单的步骤罗列我会深入分析每个错误背后的原因并提供多种验证有效的解决思路帮助你从根本上理解问题所在。1. Qt5Gamepad路径错误当CMake找不到游戏手柄库时第一次运行cmake ..命令时最常遇到的错误就是关于Qt5Gamepad的路径问题。错误信息通常会显示Could not find a package configuration file provided by Qt5Gamepad。这看似简单的问题背后实际上反映了CMake查找机制与Qt安装路径之间的不匹配。1.1 错误根源分析Qt5Gamepad是Qt框架中处理游戏手柄输入的模块而Mini Cheetah的仿真界面需要这个库来处理用户输入。问题通常出现在以下两种情况Qt未正确安装Gamepad组件在安装Qt时很多人会选择默认组件而Gamepad模块可能未被包含。CMake搜索路径不正确即使安装了Gamepad模块CMake也可能无法自动找到它特别是当Qt被安装在非标准路径时。1.2 多种解决方案对比根据不同的情况我尝试并验证了以下几种解决方法方法一修改CMakeLists.txt文件这是最直接的解决方案。在sim/CMakeLists.txt文件中找到关于Qt5Gamepad的部分将其修改为显式指定路径# 原始代码可能存在问题 find_package(Qt5Gamepad REQUIRED) # 修改后代码替换为你的实际Qt安装路径 set(Qt5Gamepad_DIR /opt/Qt5.14.0/5.14.0/gcc_64/lib/cmake/Qt5Gamepad) find_package(Qt5Gamepad REQUIRED)方法二通过系统包管理器安装对于Ubuntu用户可以尝试通过apt安装系统提供的Qt5Gamepadsudo apt install libqt5gamepad5-dev这种方法简单快捷但可能版本与项目要求不完全匹配。方法三调整find_qt_path.sh脚本最新版的Mini Cheetah代码使用scripts/find_qt_path.sh脚本来定位Qt安装路径。如果Qt安装在非默认位置如/opt而非~/Qt需要修改这个脚本#!/bin/bash # 原始脚本假设Qt安装在home目录 QT_VER$(ls ~/Qt/ | grep 5 -m1) printf ${HOME}/Qt/${QT_VER}/gcc_64/ # 修改后脚本指定实际安装路径 printf /opt/Qt5.14.0/5.14.0/gcc_64/提示无论采用哪种方法修改后都需要清除build目录并重新运行cmake以确保更改生效。1.3 预防措施与最佳实践为了避免将来再次遇到类似问题我总结了以下几点经验记录Qt安装路径安装Qt时记下确切的安装路径和版本号统一安装位置建议将Qt安装在标准位置如/opt/Qt验证组件安装安装Qt时确保勾选了Gamepad模块2. Eigen3头文件缺失当编译器找不到数学库时第二个常见错误发生在make阶段错误信息通常类似于fatal error: Eigen/Dense: No such file or directory。这个问题看似简单却可能让开发者花费数小时寻找解决方案。2.1 问题本质探究Eigen是一个C模板库用于线性代数运算。Mini Cheetah的运动控制算法大量依赖这个库进行矩阵运算。错误的发生通常有以下原因Eigen未安装系统缺少Eigen库安装位置不匹配编译器在非预期位置查找Eigen头文件版本冲突安装了多个版本的Eigen导致混淆2.2 系统性的解决方案基础解决方案确保Eigen已安装首先确认Eigen是否已正确安装sudo apt install libeigen3-dev安装后头文件通常位于/usr/include/eigen3。进阶解决方案处理路径不匹配问题有时编译器会在/usr/local/include查找Eigen而实际安装在/usr/include。解决方法sudo cp -r /usr/include/eigen3 /usr/local/include/eigen3或者更优雅的方式是修改CMakeLists.txt显式指定Eigen路径include_directories(/usr/include/eigen3)开发环境配置建议对于长期开发建议设置环境变量export EIGEN3_INCLUDE_DIR/usr/include/eigen3并在CMakeLists.txt中使用find_package(Eigen3 REQUIRED) include_directories(${EIGEN3_INCLUDE_DIR})2.3 版本管理与冲突解决当系统中存在多个Eigen版本时可能导致难以排查的问题。建议移除旧版本sudo apt remove libeigen3-dev后重新安装源码安装最新版从官网下载编译安装使用虚拟环境在Docker或conda环境中隔离不同项目的依赖3. 内存不足导致编译中断当系统资源成为瓶颈时第三个典型问题是编译过程中突然终止错误信息为c: internal compiler error: Killed (program cc1plus)。这实际上是系统内存不足的表现。3.1 资源需求分析Mini Cheetah的代码库相对庞大编译过程中内存消耗完整编译可能需要4GB以上内存CPU负载使用多线程编译如make -j4会显著增加内存需求交换空间当物理内存不足时系统会使用交换空间但速度极慢3.2 多种应对策略即时解决方案调整编译参数最简单的解决方法是减少并行编译线程数make -j2 # 使用2个线程而非4个或者完全禁用并行编译make # 单线程编译系统级优化增加可用资源对于长期开发者建议增加物理内存虚拟机用户可调整分配的内存大小优化交换空间sudo fallocate -l 4G /swapfile sudo chmod 600 /swapfile sudo mkswap /swapfile sudo swapon /swapfile选择性编译只编译必要的模块高级技巧CCache加速安装ccache可以显著加快重复编译速度sudo apt install ccache export CCccache gcc export CXXccache g3.3 编译效率优化矩阵下表对比了不同编译配置下的时间和资源消耗配置编译时间内存峰值CPU利用率适用场景make -j415min8GB400%高性能工作站make -j225min4GB200%中等配置PCmake50min2GB100%资源有限环境make -j4 ccache5min(二次编译)8GB400%频繁修改代码时4. 调试技巧与预防性措施解决了上述三个主要问题后我还想分享一些在整个过程中积累的调试技巧和预防性措施这些经验可以帮助你更高效地处理类似情况。4.1 系统化的调试方法当遇到编译错误时建议按照以下步骤排查精确阅读错误信息注意第一行错误和关键路径隔离问题尝试最小化复现搜索解决方案使用错误信息中的关键词搜索系统检查验证依赖项是否完整环境对比与已知能工作的环境比较差异4.2 预防性开发环境配置为了避免将来遇到类似问题可以采取以下预防措施使用Docker容器创建可重复的开发环境FROM ubuntu:20.04 RUN apt update apt install -y \ build-essential \ cmake \ libeigen3-dev \ libqt5gamepad5-dev记录环境配置维护一个setup脚本定期更新代码从官方仓库获取最新修复4.3 性能与稳定性平衡在资源有限的情况下需要在编译速度和系统稳定性之间找到平衡点。以下是一些实用建议监控系统资源使用htop观察内存和CPU使用情况分批编译先编译核心模块再编译其他部分使用tmpfs将编译目录挂载到内存中如果有足够内存sudo mount -t tmpfs -o size8G tmpfs /path/to/build5. 从错误中学习理解Mini Cheetah的构建系统经历了这些编译错误并成功解决后我对Mini Cheetah的构建系统有了更深入的理解。这部分将分享一些关于项目架构的见解帮助你更好地理解整个系统。5.1 CMake架构解析Mini Cheetah使用CMake作为构建系统其结构大致如下Cheetah-Software/ ├── CMakeLists.txt # 根配置文件 ├── sim/ │ ├── CMakeLists.txt # 仿真器配置 ├── scripts/ │ ├── find_qt_path.sh # Qt路径查找脚本 ├── common/ # 公共库关键CMake模块包括Qt5用于图形界面Eigen3数学运算核心LCM轻量级通信库IPOPT优化求解器5.2 依赖管理策略项目采用混合依赖管理方式系统级依赖通过apt安装如Eigen3源码级依赖直接包含在项目中如部分第三方库脚本管理通过shell脚本辅助配置如find_qt_path.sh5.3 构建流程优化建议基于对构建系统的理解我总结了几点优化建议统一依赖版本在团队中固定各库的版本号模块化编译先编译基础库再编译上层应用持续集成设置自动化构建测试文档记录维护构建配置变更日志6. 成功编译后的下一步验证与开发成功编译只是第一步接下来需要验证仿真环境是否正常工作并开始实际开发。这部分将介绍一些关键的验证步骤和开发建议。6.1 基本功能验证编译完成后建议按顺序运行以下测试启动仿真界面./sim/sim检查基本运动验证机器人能否站立和简单移动测试传感器数据确认IMU和关节状态信息正常6.2 常见运行问题排查即使编译成功运行时仍可能遇到问题缺少动态库使用ldd检查依赖ldd ./sim/sim权限问题确保对设备文件有访问权限配置错误检查配置文件路径和内容6.3 开发工作流建议为了高效开发建议建立以下工作流程代码版本控制创建自己的开发分支增量编译只重新编译修改过的模块单元测试为新增功能编写测试用例性能分析定期进行性能剖析# 性能分析示例 valgrind --toolcallgrind ./sim/sim kcachegrind callgrind.out.*7. 深入Mini Cheetah理解其软件架构成功搭建开发环境后是时候深入了解Mini Cheetah的软件架构了。这部分将简要介绍其主要组件和工作原理为后续开发打下基础。7.1 核心组件概述Mini Cheetah的软件栈主要包括实时控制系统处理传感器数据和电机控制运动规划算法生成步态和轨迹仿真环境用于算法验证用户界面提供可视化交互7.2 关键数据结构理解以下核心数据结构对开发至关重要RobotState封装机器人当前状态GaitScheduler管理步态周期LegController处理腿部控制DesiredStateCommand存储目标状态7.3 通信机制项目使用LCM进行模块间通信主要消息类型包括robot_state_t机器人状态leg_control_data_t腿部控制命令visualization_data_t可视化数据理解这些消息的流动对调试复杂问题非常有帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2505628.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…