首页
/ ArtPlanner 项目使用教程

ArtPlanner 项目使用教程

2024-09-12 09:07:24作者:晏闻田Solitary

1. 项目介绍

ArtPlanner 是一个专为足式机器人设计的本地导航规划器。该项目由 ETH Zurich 的 Lorenz Wellhausen 和 Marco Hutter 开发,旨在为足式机器人提供在复杂地形中的导航能力。ArtPlanner 基于采样方法,结合了学习到的足迹评分和运动成本,以确保机器人在不同地形中的安全导航。

主要特点

  • 采样路径规划:基于采样方法,适用于复杂地形。
  • 学习到的运动成本:使用神经网络计算运动成本,优化路径选择。
  • ROS 接口:提供 ROS 接口,方便集成到现有的 ROS 系统中。

2. 项目快速启动

2.1 环境准备

在开始之前,请确保您的系统已经安装了以下依赖:

  • ROS Noetic
  • Git LFS
  • OMPL (v1.4.2)
  • OpenCV
  • grid_map_core

2.2 克隆项目

首先,确保您已经安装了 Git LFS:

sudo apt install git-lfs
git lfs install

然后,克隆 ArtPlanner 项目:

git clone https://github.com/leggedrobotics/art_planner.git
cd art_planner

2.3 安装依赖

安装 ROS 依赖:

sudo apt install ros-noetic-ompl ros-noetic-grid-map-core

安装 Python 依赖:

pip3 install opencv-python rospkg torch torchvision torchaudio

2.4 启动项目

使用提供的启动文件启动 ArtPlanner:

roslaunch art_planner_ros art_planner.launch

如果需要使用路径跟随器,可以手动启动:

rosrun art_planner_ros path_follower.py

3. 应用案例和最佳实践

3.1 案例一:ANYmal 机器人导航

ANYmal 机器人是 ArtPlanner 的主要应用对象之一。通过 ArtPlanner,ANYmal 能够在复杂地形中进行自主导航,避开障碍物并选择最优路径。

3.2 案例二:自定义机器人导航

如果您有自定义的足式机器人,可以通过调整配置文件和训练新的运动成本模型来适应 ArtPlanner。虽然官方提供了 ANYmal 的模型,但您可以根据自己的机器人特性进行定制。

3.3 最佳实践

  • 配置文件调整:根据机器人的特性和环境,调整 art_planner_ros/config/params.yaml 文件中的参数。
  • 高度图输入:推荐使用 elevation_mapping_cupy 包生成高度图,以提高导航的准确性。

4. 典型生态项目

4.1 elevation_mapping_cupy

elevation_mapping_cupy 是一个高度图生成工具,能够为 ArtPlanner 提供精确的地形信息。它通过 CUDA 加速,提高了高度图的生成效率。

4.2 OMPL

OMPL (Open Motion Planning Library) 是一个开源的运动规划库,ArtPlanner 基于 OMPL 实现了路径规划功能。OMPL 提供了多种规划算法,适用于不同的应用场景。

4.3 ROS

ROS (Robot Operating System) 是机器人开发的标准框架,ArtPlanner 提供了完整的 ROS 接口,方便集成到现有的 ROS 项目中。

通过以上模块的介绍和实践,您可以快速上手并应用 ArtPlanner 项目,为足式机器人提供强大的导航能力。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
179
263
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
871
515
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
131
184
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
346
380
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
334
1.09 K
harmony-utilsharmony-utils
harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
ArkTS
31
0
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
kernelkernel
deepin linux kernel
C
22
5
WxJavaWxJava
微信开发 Java SDK,支持微信支付、开放平台、公众号、视频号、企业微信、小程序等的后端开发,记得关注公众号及时接受版本更新信息,以及加入微信群进行深入讨论
Java
829
22
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
603
58