当前位置: 首页 > article >正文

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

从编译错误到成功仿真记录我调试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可视化数据理解这些消息的流动对调试复杂问题非常有帮助。

相关文章:

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

从编译错误到成功仿真:记录我调试MIT Mini Cheetah源码时遇到的3个典型问题 调试MIT Mini Cheetah开源代码的过程,就像是在解一道复杂的数学题——每一步都可能隐藏着意想不到的陷阱。作为一个曾经在这个项目上耗费了整整两个周末的开发者,我…...

如何在一台电脑上实现多人分屏游戏:Nucleus Co-Op终极指南

如何在一台电脑上实现多人分屏游戏:Nucleus Co-Op终极指南 【免费下载链接】nucleuscoop Starts multiple instances of a game for split-screen multiplayer gaming! 项目地址: https://gitcode.com/gh_mirrors/nu/nucleuscoop 你是否曾梦想与朋友在同一台…...

verilog中的、、有什么区别和联系?

在 Verilog 中,&、&& 和 &&& 都是逻辑运算符,但它们在操作的对象和行为上有显著的不同。 1. & (按位与运算符,bitwise AND) 用途:& 是按位与运算符,用于对两个操作数的每一位执行 AND 运算。 操作对象:它对每个操作数的 每一位 执行逻…...

TPFanCtrl2:ThinkPad风扇控制的完整解决方案与配置指南

TPFanCtrl2:ThinkPad风扇控制的完整解决方案与配置指南 【免费下载链接】TPFanCtrl2 ThinkPad Fan Control 2 (Dual Fan) for Windows 10 and 11 项目地址: https://gitcode.com/gh_mirrors/tp/TPFanCtrl2 TPFanCtrl2是专为ThinkPad笔记本电脑设计的开源风扇…...

痞子衡嵌入式:turbo-spiboot - 一种基于MCUBoot协议的二级SPI加载APP提速方案必

前面我们对 Kafka 的整体架构和一些关键的概念有了一个基本的认知,本文主要介绍 Kafka 的一些配置参数。掌握这些参数的作用对我们的运维和调优工作还是非常有帮助的。 写在前面 Kafka 作为一个成熟的事件流平台,有非常多的配置参数。详细的参数列表可以…...

当压铸与挤出走向高端制造,真正的竞争不在设备,而在温控系统——模温机与超高温电加热导热油系统,正在成为设备配套的隐形核心

(星德温控技术研究中心-月生) 在过去相当长一段时间里,无论是橡塑挤出设备行业,还是压铸设备行业,行业的主流认知始终围绕“主机能力”展开——挤出领域拼螺杆结构、模头设计与自动化水平,压铸领域拼锁模力…...

高级算法面试五十题深度解析,算法工程师面试必备

高级算法工程师面试50题深度解析与举一反三 难度警告:本系列题目专为冲击顶级技术岗位(如L5及以上算法工程师、研究员)的候选人设计。题目深度结合前沿论文、复杂系统设计与高难度竞赛题,要求候选人不仅精通经典算法,更…...

STM32F407驱动4位数码管:从硬件连接到动态扫描编程实战

1. 硬件连接:从零搭建STM32F407与数码管的桥梁 第一次接触数码管驱动时,最让我头疼的就是硬件连线。记得当时拿着杜邦线在开发板和数码管模块之间来回比划,生怕接错线烧坏设备。其实只要理解几个关键点,连接过程会变得非常简单。…...

YOLOv8头部改进全攻略:从SEAM到MultiSEAM的代码实现与效果对比

YOLOv8头部改进全攻略:从SEAM到MultiSEAM的代码实现与效果对比 在目标检测领域,YOLO系列模型因其卓越的实时性能而广受欢迎。YOLOv8作为最新一代的代表,其头部结构的设计直接影响着检测精度与速度。本文将深入探讨两种创新性头部改进方案——…...

如何在不安装Steam的情况下获取创意工坊模组

如何在不安装Steam的情况下获取创意工坊模组 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 对于许多游戏爱好者来说,Steam创意工坊是一个宝库,里面充满…...

C语言文件操作实战:读写YOLOv12模型权重与配置

C语言文件操作实战:读写YOLOv12模型权重与配置 如果你正在用C或C捣鼓YOLOv12模型,尤其是在那些没有现成Python库的嵌入式或高性能计算环境里,那么你很可能需要自己动手,从最底层的文件读写开始,把模型权重和配置“喂”…...

WarcraftHelper 2024终极指南:让经典魔兽争霸III在现代电脑完美运行

WarcraftHelper 2024终极指南:让经典魔兽争霸III在现代电脑完美运行 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为经典魔兽争霸II…...

PaddlePaddle-v3.3功能体验:内置数据集与预训练模型,加速你的AI实验

PaddlePaddle-v3.3功能体验:内置数据集与预训练模型,加速你的AI实验 1. 引言:为什么你需要一个“开箱即用”的AI开发环境? 如果你尝试过从零搭建一个深度学习环境,大概率经历过这样的痛苦:花半天时间安装…...

【数据结构与算法】第38篇:图论(二):深度优先搜索(DFS)与广度优先搜索(BFS)

一、图遍历的基本概念1.1 为什么需要遍历和树一样,图也需要一种方式“访问”所有顶点。但图可能有环,所以需要标记已访问的顶点,避免重复访问。1.2 两种遍历方式遍历方式核心思想数据结构DFS一条路走到底,回溯栈(递归&…...

Chandra OCR完整教程:从单图测试到企业级应用,全流程实战解析

Chandra OCR完整教程:从单图测试到企业级应用,全流程实战解析 1. Chandra OCR核心能力解析 Chandra OCR是Datalab.to在2025年开源的一款革命性文档识别工具,与传统OCR相比具有三大突破性优势: 布局感知:不仅能识别文…...

5分钟快速上手:抖音无水印批量下载工具完整指南

5分钟快速上手:抖音无水印批量下载工具完整指南 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support. 抖…...

CKA-2026-resources

您管理一个 WordPress 应用程序。由于资源请求过高,某些 Pod 无法启动。Taskrelative-fawn namespace 中的 WordPress 应用程序包含:l具有 3 个副本的 WordPress Deployment按如下方式调整所有 Pod 资源请求:l将节点资源平均分配给这 3 个 Po…...

CLIP-GmP-ViT-L-14模型蒸馏实战:基于STM32F103C8T6的轻量化部署探索

CLIP-GmP-ViT-L-14模型蒸馏实战:基于STM32F103C8T6的轻量化部署探索 1. 引言 想象一下,一个只有指甲盖大小、成本低廉的微控制器,能够理解一张图片和一段文字是否匹配。这听起来像是科幻电影里的场景,但今天,我们就要…...

【世纪龙科技】3D仿真还原真车,拆装检测步步有方

新能源汽车动力总成拆装与检测虚拟实训软件—— 虚实相融,赋能未来工匠的成长新范式在新能源汽车产业蓬勃发展的今天,职业院校作为技术技能人才的摇篮,正面临着“高压安全难保障、精密部件难拆装、大班教学难兼顾”的实训新挑战。如何让学生在…...

如何在 PHP 包含文件中动态排除当前页面对应的导航项

本文介绍如何通过 PHP 动态控制 include() 的执行时机,实现在侧边栏(如 aside.php)中自动隐藏当前页面对应的导航链接,无需额外语言或框架,纯 PHP 即可实现。 本文介绍如何通过 php 动态控制 include() 的执行时机…...

Go语言怎么防SQL注入_Go语言SQL注入防护教程【深入】

必须使用参数占位符(如?或$1)而非字符串拼接来防止SQL注入;sql.RawBytes仅用于读取二进制字段,不可用于拼接SQL;动态表名/字段名需白名单校验;ORM应禁用Raw()并启用PrepareStmt;JSON中的SQL片段…...

知识的基本特性:相对正确性、不确定性与可表示性

“知识”并不是对客观世界的简单照搬,也不是永远不变的绝对真理。它是在认识、概括、组织和应用过程中形成的结果,因此既具有稳定性,也具有条件性。理解知识的基本特性,有助于进一步理解:为什么知识需要表示&#xff0…...

语义网络表示法:从节点、关系到继承推理

在知识表示的发展过程中,语义网络表示法(Semantic Network Representation)是一种非常重要的方法。它用“节点—关系—节点”的结构来表示知识,把对象及其联系组织成有向图,因此比单纯的逻辑公式更直观,也更…...

Wand-Enhancer:3分钟解锁WeMod专业功能的终极指南

Wand-Enhancer:3分钟解锁WeMod专业功能的终极指南 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer 还在为WeMod的专业功能限制而烦恼吗&#…...

如何在Windows 11上运行Android应用:Windows Subsystem for Android完整指南

如何在Windows 11上运行Android应用:Windows Subsystem for Android完整指南 【免费下载链接】WSA Developer-related issues and feature requests for Windows Subsystem for Android 项目地址: https://gitcode.com/gh_mirrors/ws/WSA Windows Subsystem …...

零代码:CAM++说话人识别系统,可视化界面完成语音比对

零代码:CAM说话人识别系统,可视化界面完成语音比对 1. 系统概述 CAM说话人识别系统是一款基于深度学习的声纹识别工具,通过直观的可视化界面让用户无需编写代码即可完成语音比对和特征提取。该系统由开发者"科哥"基于阿里达摩院开…...

Phi-4-mini-reasoning 3.8B在VSCode中的智能编程应用:Codex风格体验

Phi-4-mini-reasoning 3.8B在VSCode中的智能编程应用:Codex风格体验 1. 轻量级AI编程助手的惊艳表现 在编程领域,AI辅助工具正变得越来越重要。Phi-4-mini-reasoning 3.8B作为一款轻量级模型,在VSCode中展现出了令人惊喜的智能编程能力。虽…...

第十六届 蓝桥杯嵌入式设计与开发 省赛 客观题

不定项选择,共10题 01.关于STM32时钟源的说法,错误的是() A.HSI精度高于HSE B.LSE常用于RTC模块 C.PLL可将外部或内部时钟倍频 D.切换系统时钟源或修改主频时,必须先进入停机模式 答案:AD A:HSI(内部高速时钟&#xff…...

文墨共鸣大模型Dify平台无缝集成:可视化构建AI文本处理应用

文墨共鸣大模型Dify平台无缝集成:可视化构建AI文本处理应用 你是不是也遇到过这样的场景:手头有一个很棒的AI大模型,比如文墨共鸣,但每次想用它做点事情,都得写代码、调接口,过程繁琐,门槛不低…...

macOS 强制运行拦截程序

当你从 Chrome、Safari 或其它网络渠道下载文件时,macOS 会自动给这个文件贴上一张“隐形贴纸”,名字就叫 com.apple.quarantine。系统的逻辑: 当你双击运行一个文件时,系统的 Gatekeeper会先检查有没有这张贴纸。拦截逻辑&#x…...