rl-mpc-locomotion

rl-mpc-locomotion

强化学习与模型预测控制结合的四足机器人运动框架

这个项目为四足机器人运动任务开发了一个快速仿真和强化学习训练框架。它采用分层控制结构,结合高层策略网络和低层模型预测控制器。其MPC控制器基于Cheetah Software改写,便于移植到主流仿真平台。项目利用NVIDIA Isaac Gym进行并行训练,使用Unitree Robotics的Aliengo模型,并实现了从仿真到实物的迁移。该框架适用于多种四足机器人类型和步态,为相关研究提供了有力支持。

RL MPC Locomotion四足机器人强化学习模型预测控制Isaac GymGithub开源项目

RL MPC 运动控制

本仓库旨在通过动态预测MPC控制器的权重参数,为四足机器人运动控制任务提供快速仿真和强化学习训练框架。控制框架是一个分层控制器,由高层策略网络和低层模型预测控制器组成。

MPC控制器参考了Cheetah Software,但用Python重写,并完全开放了传感器数据和电机命令之间的接口,因此控制器可以轻松移植到任何主流仿真器中。

强化学习训练利用NVIDIA Isaac Gym并行进行,使用Unitree Robotics Aliengo模型,并将其从仿真转移到真实的Aliengo机器人上(本代码库不包含仿真到现实的部分)。

框架

<img src="https://yellow-cdn.veclightyear.com/0a4dffa0/c786d3d1-44de-4501-acb2-b90624edcb11.png" width=700>

依赖

安装

  1. 克隆此仓库
    git clone git@github.com:silvery107/rl-mpc-locomotion.git
  2. 初始化子模块
    git submodule update --init
    或在第1步克隆时使用--recurse选项同时克隆子模块。
  3. 创建conda环境:
    conda env create -f environment.yml
  4. <extern>文件夹下安装commit为2ad79cfrsl_rl
    cd extern/rsl_rl pip install -e .
  5. 编译MPC求解器的Python绑定:
    pip install -e .

快速开始

  1. 在Aliengo上运行MPC控制器:

    python RL_MPC_Locomotion.py --robot=Aliengo

    所有支持的机器人类型有Go1A1Aliengo

    注意,你需要插入类Xbox的游戏手柄来控制它,或者传入--disable-gamepad。 控制器模式默认为Fsm(有限状态机),你也可以尝试Min模式,即不带FSM的最小MPC控制器。

    • 游戏手柄按键映射

      LBTrotWalkBound步态之间切换。

      RBLocomotionRecovery Stand FSM状态之间切换。

  2. 训练新策略:

    cd RL_Environment python train.py task=Aliengo headless=False

    v键禁用查看器更新,再次按下恢复。 设置headless=True可以在不渲染的情况下训练。

    支持Tensorboard,运行tensorboard --logdir runs

  3. 加载预训练检查点:

    python train.py task=Aliengo checkpoint=runs/Aliengo/nn/Aliengo.pth test=True num_envs=4

    设置test=False可以继续训练。

  4. 在Aliengo上运行预训练的MPC控制器权重策略: 在<MPC_Controller/Parameters.py>中将bridge_MPC_to_RL设置为False

    python RL_MPC_Locomotion.py --robot=Aliengo --mode=Policy --checkpoint=path/to/ckpt

    如果未给出checkpoint,将加载最新的运行结果。

路线图

<img src="https://yellow-cdn.veclightyear.com/0a4dffa0/8d9c3fd6-ef22-4fd1-ba71-42825e7b4622.png" width=600> - [x] **MPC控制器** - [四足机器人](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/common/Quadruped.py, - [机器人运行器](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/robot_runner/RobotRunnerFSM.py -> - [腿部控制器](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/common/LegController.py, - [状态估计器](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/common/StateEstimator.py, - [控制有限状态机](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/FSM_states/ControlFSM.py -> - [FSM状态恢复站立](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/FSM_states/FSM_State_RecoveryStand.py, - [FSM状态运动](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/FSM_states/FSM_State_Locomotion.py -> - [凸优化MPC运动](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/convex_MPC/ConvexMPCLocomotion.py -> - [足部摆动轨迹](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/common/FootSwingTrajectory.py, - [步态](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/convex_MPC/Gait.py, - [C语言MPC求解器](https://github.com/silvery107/rl-mpc-locomotion/blob/main/MPC_Controller/convex_MPC/mpc_osqp.cc <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/6a0e607f-a0e0-47e5-adc6-937f8dc697b3.png" width=400>

用户说明

图库

<img src="https://yellow-cdn.veclightyear.com/0a4dffa0/9f2c32c4-569c-47ac-b074-6d168f9de20b.gif" width=500> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/f09f3a0c-8869-4e78-bf2d-25230abf4728.gif" width=500> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/350969de-b220-45f8-a144-f904ce00635c.gif" width=500> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/1d44f642-5cc6-438e-8a7f-88b02a08ec84.gif" width=500 tag> <a name="sim2real_anchor"></a>

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多