0

0

ROS、OpenAI和Gazebo机器人与人工智能仿真与实践教研杂记(一)安装配置

爱谁谁

爱谁谁

发布时间:2025-07-12 10:18:16

|

992人浏览过

|

来源于php中文网

原创

ROS、OpenAI和Gazebo机器人与人工智能仿真与实践教研杂记(一)安装配置
ROS、OpenAI和Gazebo机器人与人工智能仿真与实践教研杂记(一)安装配置

课程教学实践环境:

系统:Ubuntu 18.04.2 LTS + ROS Melodic(1.0)1.14.3 ~ 1943 + ROS  Crystal(2.0)0.6.1 ~ 541 etc.

仿真:Gazebo 9.8.0 + V-Rep 3.6.1 + Webots 2019a.1 etc.

实物:Cozmo/Vector + Leap Motion + Joystick + Camera + Microphone + Speaker + Phone(ios&android)+ Arduino etc.

镜像:ROS2Go ver2.0 + 实验楼ROS + Exbot ROS iso indigo&kinetic etc.

书籍:ROS机器人高效编程 + ROS机器人项目开发11例 etc.

编程:Matlab 2018a + Python 2.7 + Python 3.6 + C++ etc.

智能:Tensorflow + Caffe + OpenAI etc.

语音:科大讯飞 + 百度语音 + Sphinx etc.

2015-2019全部涉及软硬件平台更多,均在博客中有记录和介绍,此处不再赘述。

先以gym-gazebo为例,简要说明一下:

测试和调试环境:Ubuntu 18.04.2 LTS,其余如上文所述。

gym-gazebo支持ROS Melodic(1.0),gym-gazebo2支持ROS Crystal(2.0)

ROS、OpenAI和Gazebo机器人与人工智能仿真与实践教研杂记(一)安装配置

版本问题:将gazebo-8代码替换给gezbo-9:

Could not open file[/usr/share/gazebo-8/worlds/empty_bullet.world]

ROS、OpenAI和Gazebo机器人与人工智能仿真与实践教研杂记(一)安装配置
ROS、OpenAI和Gazebo机器人与人工智能仿真与实践教研杂记(一)安装配置
ROS、OpenAI和Gazebo机器人与人工智能仿真与实践教研杂记(一)安装配置

使用Gazebo的Open gym扩展,下面以ROS Melodic为例介绍:

An OpenAI gym extension for using Gazebo known as gym-gazebo

This work presents an extension of the initial OpenAI gym for robotics using ROS and Gazebo. A whitepaper about this work is available at https://arxiv.org/abs/1608.05742. Please use the following BibTex entry to cite our work:

代码语言:javascript代码运行次数:0运行复制
@article{zamora2016extending,  title={Extending the OpenAI Gym for robotics: a toolkit for reinforcement learning using ROS and Gazebo},  author={Zamora, Iker and Lopez, Nestor Gonzalez and Vilches, Victor Mayoral and Cordero, Alejandro Hernandez},  journal={arXiv preprint arXiv:1608.05742},  year={2016}}

论文发表和简要介绍如上。

gym-gazebo is a complex piece of software for roboticists that puts together simulation tools, robot middlewares (ROS, ROS 2), machine learning and reinforcement learning techniques. All together to create an environment whereto benchmark and develop behaviors with robots. Setting up gym-gazebo appropriately requires relevant familiarity with these tools.

Code is available "as it is" and currently it's not supported by any specific organization. Community support is available here. Pull requests and contributions are welcomed.

gym-gazebo是一个复杂的机器人软件软件,它将模拟仿真工具,机器人中间件(ROS,ROS 2),机器学习和强化学习技术结合在一起。共同创造一个环境,用机器人来评估和开发行为。正确设置gym-gazebo需要熟悉这些工具。

目录环境安装用法

安装

Ubuntu 18.04Ubuntu 16.04(已弃用)Ubuntu 14.04(已弃用)Docker(已弃用)Ubuntu 18.04

基本要求

ViiTor实时翻译
ViiTor实时翻译

AI实时多语言翻译专家!强大的语音识别、AR翻译功能。

下载
ROS Melodic:推荐使用Desktop-Full Install,包括Gazebo 9.0.0(http://wiki.ros.org/melodic/Installation/Ubuntu)。Gazebo 9.0.0

ROS Melodic相关的依赖

代码语言:javascript代码运行次数:0运行复制
sudo apt-get install \python-pip python3-vcstool python3-pyqt4 \pyqt5-dev-tools \libbluetooth-dev libspnav-dev \pyqt4-dev-tools libcwiid-dev \cmake gcc g++ qt4-qmake libqt4-dev \libusb-dev libftdi-dev \python3-defusedxml python3-vcstool \ros-melodic-octomap-msgs        \ros-melodic-joy                 \ros-melodic-geodesy             \ros-melodic-octomap-ros         \ros-melodic-control-toolbox     \ros-melodic-pluginlib       \ros-melodic-trajectory-msgs     \ros-melodic-control-msgs       \ros-melodic-std-srvs        \ros-melodic-nodelet       \ros-melodic-urdf       \ros-melodic-rviz       \ros-melodic-kdl-conversions     \ros-melodic-eigen-conversions   \ros-melodic-tf2-sensor-msgs     \ros-melodic-pcl-ros \ros-melodic-navigation \ros-melodic-sophus

安装Python包:

代码语言:javascript代码运行次数:0运行复制
sudo pip install gymsudo apt-get install python-skimagesudo pip install h5pypip install tensorflow-gpu (if you have a gpu if not then just pip install tensorflow)sudo pip install keras

安装gym-gazebo:

代码语言:javascript代码运行次数:0运行复制
cd ~git clone https://github.com/erlerobot/gym-gazebocd gym-gazebosudo pip install -e .

运行bash文件,构建ros工作区:

代码语言:javascript代码运行次数:0运行复制
cd gym-gazebo/gym_gazebo/envs/installationbash setup_melodic.bash

执行示例

运行qlearn的示例:

终端1

代码语言:javascript代码运行次数:0运行复制
cd gym-gazebo/gym_gazebo/envs/installation/bash turtlebot_setup.bash

终端2

代码语言:javascript代码运行次数:0运行复制
cd gym-gazebo/examples/turtlebotpython circuit_turtlebot_lidar_qlearn.py

运行dqn的示例:

终端1

代码语言:javascript代码运行次数:0运行复制
cd gym-gazebo/gym_gazebo/envs/installation/bash turtlebot_nn_setup.bash

终端2

代码语言:javascript代码运行次数:0运行复制
cd gym-gazebo/examples/turtlebotpython circuit_turtlebot_lidar_qlearn.py
用法建造并安装gym-gazebo

库的根目录中:

代码语言:javascript代码运行次数:0运行复制
sudo pip install -e .
运行环境加载与要启动的机器人对应的环境变量。例如加载Turtlebot:代码语言:javascript代码运行次数:0运行复制
cd gym_gazebo/envs/installationbash turtlebot_setup.bash

注意:所有设置脚本都可用 gym_gazebo/envs/installation

运行可用的任何示例examples/。例如:代码语言:javascript代码运行次数:0运行复制
cd examples/turtlebotpython circuit2_turtlebot_lidar_qlearn.py
显示仿真模拟

要在模拟过程中查看Gazebo中发生的情况,请运行gazebo客户端。为了启动gzclient并能够将其连接到运行gzserver

打开一个新终端。获取相应的设置脚本,这将更新GAZEBO_MODEL_PATH变量:例如source setup_turtlebot.bash导出gazebo_env提供的GAZEBO_MASTER_URI。您将看到在每个脚本执行开始时打印的变量。例如export GAZEBO_MASTER_URI=http://localhost:13853

注意:现在需要此指令,因为gazebo_env为GAZEBO_MASTER_URI创建了一个随机端口,允许同时运行多个模拟实例。如果您不打算启动多个实例,可以从环境中删除以下两行:

代码语言:javascript代码运行次数:0运行复制
os.environ [ “ ROS_MASTER_URI ” ] = “ http:// localhost:” + self.portos.environ [ “ GAZEBO_MASTER_URI ” ] = “ http:// localhost:” + self.port_gazebo

最后,启动gzclient。

代码语言:javascript代码运行次数:0运行复制
gzclient
显示奖励细节

通过运行以下脚本显示显示当前奖励历史记录的图表:

代码语言:javascript代码运行次数:0运行复制
cd examples/utilitiespython display_plot.py

提示:使用--helpflag来获得更多选项。

ROS、OpenAI和Gazebo机器人与人工智能仿真与实践教研杂记(一)安装配置
杀死后台进程

有时,在结束或杀死模拟gzserverrosmaster留在后台后,请确保在开始新测试之前结束它们。

我们建议创建一个别名来终止这些进程。

代码语言:javascript代码运行次数:0运行复制
echo  “ alias killgazebogym ='killall -9 rosout roslaunch rosmaster gzserver nodelet robot_state_publisher gzclient' ”  >>  〜/ .bashrc

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

769

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

639

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1305

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 8.1万人学习

Django 教程
Django 教程

共28课时 | 3.3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号