gym-pybullet-drones

gym-pybullet-drones

轻量级无人机仿真环境 助力强化学习与控制算法研究

gym-pybullet-drones是基于PyBullet的轻量级无人机仿真环境,用于强化学习和控制算法研究。支持多机协同飞行、PID控制和下洗效应模拟,兼容Gymnasium、Stable-Baselines3等框架。集成SITL仿真和固件,为无人机算法开发和测试提供灵活高效的平台。

无人机强化学习PyBullet仿真控制Github开源项目

gym-pybullet-drones

这是对原始 gym-pybullet-drones 仓库的一个极简重构,旨在与 gymnasiumstable-baselines3 2.0 和 SITL betaflight/crazyflie-firmware 兼容。

注意:如果您更喜欢访问原始代码库(在2021年IROS会议上展示),请在克隆仓库后执行 git checkout [paper|master],并参考相应的 README.md 文件。

<img src="https://yellow-cdn.veclightyear.com/0a4dffa0/69362a74-b8bb-42f3-b269-c09df5a2ba38.gif" alt="编队飞行" width="325"> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/577d6021-d515-49eb-8ab4-4e0aa68345ef.png" alt="控制信息" width="425">

安装

在 Intel x64/Ubuntu 22.04 和 Apple Silicon/macOS 14.1 上测试通过。

git clone https://github.com/utiasDSL/gym-pybullet-drones.git cd gym-pybullet-drones/ conda create -n drones python=3.10 conda activate drones pip3 install --upgrade pip pip3 install -e . # 如果需要,执行 `sudo apt install build-essential` 以安装 `gcc` 并构建 `pybullet`

使用

PID控制示例

cd gym_pybullet_drones/examples/ python3 pid.py # 位置和速度参考 python3 pid_velocity.py # 期望速度参考

下洗效应示例

cd gym_pybullet_drones/examples/ python3 downwash.py

强化学习示例(SB3的PPO)

cd gym_pybullet_drones/examples/ python learn.py # 任务:单架无人机悬停在 z == 1.0 python learn.py --multiagent true # 任务:2架无人机分别悬停在 z == 1.2 和 0.7

<img src="https://yellow-cdn.veclightyear.com/0a4dffa0/3ed93cb8-2ecd-4101-af85-f5c1384c3e28.gif" alt="强化学习示例" width="375"> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/b3ea07f0-e1d8-470c-b6d2-4a08a11aeca8.gif" alt="多智能体强化学习示例" width="375">

utiasDSL pycffirmware Python绑定示例(跨平台,单无人机)

为Ubuntu、macOS或Windows安装 pycffirmware

cd gym_pybullet_drones/examples/ python3 cff-dsl.py

Betaflight SITL示例(仅限Ubuntu)

git clone https://github.com/betaflight/betaflight # 使用撰写时的 `master` 分支(未来4.5版本) cd betaflight/ make arm_sdk_install # 如果需要,执行 `apt install curl` make TARGET=SITL # 注释掉这一行:https://github.com/betaflight/betaflight/blob/master/src/main/main.c#L52 cp ~/gym-pybullet-drones/gym_pybullet_drones/assets/eeprom.bin ~/betaflight/ # 假设 gym-pybullet-drones/ 和 betaflight/ 都克隆在 ~/ 目录下 betaflight/obj/main/betaflight_SITL.elf

在另一个终端中运行示例

conda activate drones cd gym_pybullet_drones/examples/ python3 beta.py --num_drones 1 # 查看文件的文档字符串以了解如何使用多架无人机

引用

如果您愿意,请引用我们的 IROS 2021 论文以及原始代码库

@INPROCEEDINGS{panerati2021learning, title={学习飞行---一个基于PyBullet物理引擎的多智能体四旋翼飞行器控制强化学习Gym环境}, author={Jacopo Panerati 和 Hehui Zheng 和 SiQi Zhou 和 James Xu 和 Amanda Prorok 和 Angela P. Schoellig}, booktitle={2021年IEEE/RSJ智能机器人与系统国际会议(IROS)论文集}, year={2021}, volume={}, number={}, pages={7512-7519}, doi={10.1109/IROS51168.2021.9635857} }

参考文献

核心团队进行中的工作

  • 多无人机 crazyflie-firmware SITL 支持 (@spencerteetaert, @JacopoPan)
  • 使用可步进仿真的 SITL 服务 (@JacopoPan)

期望的贡献/拉取请求

  • 通过在 BaseAviary._dynamics() 中实现缓冲区来添加电机延迟、高级 ESC 建模
  • 通过编辑 BaseAviary._updateAndStoreKinematicInformation()BaseAviary._getDroneStateVector() 和相关子类的 .computeObs() 方法,用四元数替换 rpy(并用体速率替换 ang_vel

故障排除

  • 在 Ubuntu 系统上,如果您使用 NVIDIA 显卡并收到"无法创建 OpenGL 上下文"的消息,请启动 nvidia-settings,在"PRIME Profiles"下选择"NVIDIA(性能模式)",重启后再试。

从顶层文件夹运行所有测试:

pytest tests/

多伦多大学动态系统实验室 / Vector 研究所 / 剑桥大学Prorok 实验室

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

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

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多