MATLAB - Gazebo 联合仿真 —— 使用 UR10 机械臂检测和采摘水果

news2025/1/11 5:14:07

系列文章目录


文章目录

  • 系列文章目录
  • 前言
  • 一、设置 Gazebo 仿真环境
  • 二、在 Gazebo 中模拟和控制机器人
    • 2.1 概述
    • 2.2 任务调度器
    • 2.3 感知和目标生成系统
    • 2.4 运动规划
    • 2.5 机械臂和关节控制系统
  • 三、分配用于控制机器人的参数
    • 3.1 定义机器人模型和运动规划参数,
    • 3.2 定义机械手姿势和摄像机参数
    • 3.3 配置 Gazebo 协同仿真设置
    • 3.4 定义夹具控制设置
  • 4. Simulink 模型


前言

本示例演示如何在 Gazebo 物理模拟器中设置 Universal Robotics UR10 机械臂和仿真环境。您需要配置一个机器人从树上摘苹果的仿真环境。

本示例演示如何利用这些工具箱,使用 Universal Robotics UR10 机械手模拟机器人检测并从树上摘取苹果。

  • Robotics System Toolbox™ - 在 Simulink® 和 Gazebo 中对机械手进行建模、规划和模拟。

  • Navigation Toolbox™ - 生成三维环境的占用图。

  • Stateflow® - 调度示例中的高级任务并按顺序执行。

  • Computer Vision Toolbox™ - 处理三维点云数据。

  • Deep Learning Toolbox™ - 使用 Gazebo 中的模拟摄像头检测物体。

  • Computer Vision Toolbox™ Model for YOLO v4 Object Detection - 提供预训练的 YOLO v4 csp-darknet53-coco 物体检测网络。

要使用预训练的 YOLO v4 csp-darknet53-coco 物体检测网络,您必须从附加组件资源管理器下载并安装用于 YOLO v4 物体检测的 Computer Vision Toolbox™ Model。有关安装附加组件的更多信息,请参阅获取和管理附加组件。

本示例中的板条箱模型版权归 Arturo Matheus 所有,采用 1.3 版自由艺术许可协议进行许可。原始板条箱模型可在 sweethome3d 上获取。


一、设置 Gazebo 仿真环境

请按照以下步骤设置仿真环境。

  1. 要下载带有 Gazebo 的虚拟机 (VM),请按照在 Simulink 和 Gazebo 之间执行协同仿真中的说明操作。

  2. 在虚拟机设置中,在虚拟机 > 设置 > 硬件 > 显示下,禁用加速 3D 图形。有关更多信息,请参阅准备虚拟机以使用加速 3D 图形。

  3. 启动 Ubuntu® 虚拟机桌面。

  4. 在 Ubuntu 桌面上,单击 Gazebo Co-Sim Fruit Picking 启动本例的 Gazebo 世界。

二、在 Gazebo 中模拟和控制机器人

本示例使用 Gazebo 协同仿真 Simulink 模块来连接、读取摄像头图像以及读取和设置关节位置。Gazebo 世界包含一个带有 RGB-D 深度(RGB-D)摄像头传感器的 Universal Robotics UR10 机械臂机器人模型。Gazebo 世界还包含一棵苹果树和一个收集苹果的箱子。

2.1 概述

模拟开始时,机械手处于原点配置。然后,机械手移动到图像抓取位置,从 Gazebo 收集 RGB-D 图像。当机器人接收到图像时,它会使用 YOLO v4 物体检测网络检测并识别苹果。然后,机器人计算出目标位置,并将其发送给运动规划子系统。然后,模型使用操纵器RRT 对象在图像抓取位置和计算出的目标位置之间进行运动规划。当机器人接近目标苹果时,抓手手指张开,当机器人摘到苹果后,抓手手指关闭。然后,模型规划目标位置和苹果下落位置之间的运动。然后,机械手向苹果下落位置移动,并打开抓手,将苹果放入箱子中。接着,机械手移回图像抓取位置。这个过程一直持续到机器人从树上取下所有苹果为止。

在这里插入图片描述

Simulink 模型

在这里插入图片描述

Simulink 模型由这些子系统组成。

  • 任务调度器

  • 感知和目标生成系统

  • 运动规划

  • 抓手和关节控制系统

2.2 任务调度器

状态流程图定义了机器人手臂在取放工作流程中的不同状态。该图包含以下步骤。

  1. 最初,闲置状态(IdleState)触发并过渡到原点状态(HomeState)。

  2. 在 HomeState 状态下,当前配置通过运动规划过渡到图像抓取配置。

  3. 当 HomeState 结束时,它会触发 PerceptionState,捕捉 RGB-D 图像并过渡到 GrabState。

  4. 为了让机械手向目标移动,GrabState 会计算目标苹果的位置并执行运动规划。

  5. 机械手在向目标移动时打开抓手,到达目标后开始关闭抓手。

  6. 当 GrabState 结束时,抓手关闭以抓取苹果。

  7. 然后,ReleaseState 计划目标位置和苹果下落位置之间的运动。

  8. 机械手在到达苹果下落位置后,打开抓手并释放苹果。

  9. 机械手回到原点状态,从树上摘下一个苹果。

  10. 这个过程一直持续到机械手从树上摘下所有苹果为止。

在这里插入图片描述

2.3 感知和目标生成系统

感知系统模块和目标生成系统模块通过 Gazebo 读取模块从 Gazebo 中查询 RGB-D 图像,并通过接收到的 RGB-D 图像检测目标苹果生成目标姿态。

在这里插入图片描述

感知系统使用深度学习对象检测器(计算机视觉工具箱)模块,从输入的 RGB 图像中估计边界框和标签。子系统对标签进行细化,只选择苹果标签。感知系统从所有检测到的苹果标签列表中选择第一个苹果标签作为目标苹果,并通过输入的深度图像计算三维目标姿态。此外,子系统还会根据输入的深度图像计算运动规划中所需的点云。

在这里插入图片描述

2.4 运动规划

感知和目标生成器系统会生成目标姿态,并将其发送至目标配置生成器模块,以生成目标关节配置。获取目标姿势模块利用机械手的基准位置、末端执行器偏移和当前状态输入计算目标姿势。然后,逆运动学程序块根据计算出的目标姿势、权重和初始猜测计算出目标关节配置。

在这里插入图片描述

运动规划模块从 Gazebo 中获取当前关节配置,并使用操纵器RRT 对象进行运动规划。此外,子系统还会使用 occupancyMap3D(导航工具箱)对象为计算出的点云生成三维占位图。为了避免 Gazebo 世界中复杂的树形结构,子系统将该占用图作为运动规划的输入之一。最后,子系统根据运动规划中计算出的航点来估算关节位置。

在这里插入图片描述

2.5 机械臂和关节控制系统

Gazebo 应用命令块将估算的关节位置应用到 Gazebo 模型中。Gazebo 读取模块从 Gazebo 中获取当前的关节位置。抓手控制器模块使用 Gazebo 应用命令块对每个抓手手指关节施加扭矩。此外,任务调度程序中的状态转换会计算关节差,并利用关节差执行状态转换。

在这里插入图片描述

三、分配用于控制机器人的参数

打开 Simulink 模型。

open_system("FruitPickingGazeboManipulator.slx");

3.1 定义机器人模型和运动规划参数,

使用 loadrobot 对 universalUR10 机械手进行加载和可视化。

robot = loadrobot("universalUR10",DataFormat="row",Gravity=[0 0 -9.81]);
show(robot)

在这里插入图片描述

ans = 
  Axes (Primary) with properties:

             XLim: [-2 2]
             YLim: [-2 2]
           XScale: 'linear'
           YScale: 'linear'
    GridLineStyle: '-'
         Position: [0.1300 0.1100 0.7750 0.8150]
            Units: 'normalized'

  Show all properties

在 Gazebo 世界中,RGB-D 摄像机和抓手连接到 Universal Robotics UR10 机器人模型的手腕_3_link 上。因此,请指定 wrist_3_link 为末端执行器。

endEffectorName = "wrist_3_link";

为 universalUR10 机器人模型指定所附抓手偏移量。

endEffectorOffset = [0.0 -0.27 0.0];

初始化运动规划参数

initializeMotionPlanningParameters

3.2 定义机械手姿势和摄像机参数

加载要在 Gazebo 模拟器中应用的相机设置。

initializeCameraParameters

要抓取图像,请定义 universalUR10 机器人移动到的位置。

imageGrabPositionTform = eye(4);
imageGrabPositionTform(1:3,4) = [0.1639 -0.6120 0.5839];
imageGrabPositionTform(1:3,1:3) = eul2rotm([0 0 0]);

定义机械手图像抓取位置的初始猜测配置。

imageGrabPositionInitialGuess = [-pi/2 0 -pi/2 pi/2 -pi/2 pi];

定义采摘苹果的下落位置。

releasePositionInitialTform = eye(4);
releasePositionInitialTform(1:3,4) = [-0.1348 -0.5613 0.3530];
releasePositionInitialTform(1:3,1:3) = eul2rotm([5*pi/6 0 -5*pi/6]);

定义机械手目标释放位置的初始猜测配置。

releasePositionInitialGuess = [-2*pi/3 -pi/2 2*pi/3 -pi/3 -pi/2 0];

3.3 配置 Gazebo 协同仿真设置

定义 Gazebo 协同模拟模块的采样时间。

Ts = 0.01;

打开 Gazebo Pacer 块,点击配置 Gazebo 网络和模拟设置链接。在网络地址下拉菜单中,选择自定义。输入 Linux 机器的 IP 地址。Gazebo 的默认端口值是 14581。将响应超时设置为 10。

在这里插入图片描述

单击 "测试 "按钮,测试与运行中的 Gazebo 模拟器的连接。

3.4 定义夹具控制设置

分配机械手开合力度值。

gripperOpenEffort = -0.15;
gripperCloseEffort = 0.15;

4. Simulink 模型

要执行模拟并将其可视化,请单击 “运行”。

在这里插入图片描述

在 MATLAB 中可视化检测到的苹果和深度图像。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1175692.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于野马算法的无人机航迹规划-附代码

基于野马算法的无人机航迹规划 文章目录 基于野马算法的无人机航迹规划1.野马搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要:本文主要介绍利用野马算法来优化无人机航迹规划。 1.野马搜索算法 …

基于向量加权平均算法的无人机航迹规划-附代码

基于向量加权平均算法的无人机航迹规划 文章目录 基于向量加权平均算法的无人机航迹规划1.向量加权平均搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要:本文主要介绍利用向量加权平均算法来优化无…

CSS 滚动捕获 Scroll Snap

CSS 滚动捕获 Scroll Snap CSS 滚动捕获允许开发者通过声明一些位置(或叫作捕获位置)来创建精准控制的滚动体验. 通常来说轮播图就是这种体验的例子, 在轮播图中, 用户只能停在图 A 或者图 B, 而不能停在 A 和 B 的中间. 比如平时用淘宝或小红书, 当你上滑到下一个推荐内容时…

分享90个节日庆典PPT,总有一款适合您

分享90个节日庆典PPT,总有一款适合您 PPT下载链接:百度网盘 请输入提取码 提取码:8888 Python采集代码下载链接:采集代码.zip - 蓝奏云 学习知识费力气,收集整理更不易。知识付费甚欢喜,为咱码农谋福利…

浅析C/C++的内存分段

这部分是计算机系统相关的知识,碍于本人才疏学浅,如本文存在疏漏或者错误,还望大佬能帮忙指出,感激不尽。 内存分段 从狭义上讲内存的分段可以分为堆、栈、数据段以及代码段(内存映射区比较复杂,暂不涉及…

C++ Concurrency in Action 2nd Edition

《C Concurrency in Action - SECOND EDITION》的中文翻译-面圈网 (mianshigee.com) C/C 学习教程源码-C/C源码推荐-面试哥 (mianshigee.com) 作者正是为C11标准引入线程库的C标准委员会成员本人!并且本书作者还编写了众多构成C标准的多线程和并发相关的提案、制定…

基于天鹰算法的无人机航迹规划-附代码

基于天鹰算法的无人机航迹规划 文章目录 基于天鹰算法的无人机航迹规划1.天鹰搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要:本文主要介绍利用天鹰算法来优化无人机航迹规划。 1.天鹰搜索算法 …

如何使用腾讯云+Picgo搭建图床

目录 一、进入腾讯云进行实名认证 二、领取免费存储额度 2.1新用户界面概览就可以领取 三、开始创建远端图床并生成秘钥等信息 3.1创建存储桶 3.2配置基本信息 3.3配置高级选项 3.4确认配置页面点击创建即可 3.5创建访问秘钥 3.6查看秘钥等信息 3.7查看桶名称 四、图…

《向量数据库指南》——开源框架NVIDIA Merlin 向量数据库Milvus

NVIDIA Merlin & Milvus 推荐系统 pipeline 中至关重要的一环便是为用户检索并找到最相关的商品。为了实现这一目标,通常会使用低维向量(embedding)表示商品,使用数据库存储及索引数据,最终对数据库中数据进行近似最近邻(ANN)搜索。这些向量表示是通过深度学习模型获…

Sentinel黑白名单授权规则解读

目录 基本介绍 代码实战 架构说明 RequestOriginParser的实现类 网关添加请求头 配置授权规则 基本介绍 授权规则可以对请求方来源做判断和控制。 很多时候,我们需要根据调用来源来判断该次请求是否允许放行,这时候可以使用 Sentinel 的来源…

zigbee路灯无线通讯机制

zigbee路灯无线通讯机制 wang20160630 前言 目前路灯上通讯主要有电力载波和无线通讯;各有利弊,众说纷纭;本文不对两种技术进行比较,也不讨论哪种好,毕竟同种通讯模块,有的开发出来稳定,有的…

cesium示例教程100+目录

cesium示例教程100旨在为开发者提供简单快捷的代码示例,复制即可用。在每一个示例中,解释相应的API知识点,做到简易实现,轻松学会。 文章目录 目录基础设置及界面配置设置材质material显示图形绘制图形加载文件数据加载各种地图综…

2023.11.6-分析 Gateway 和 VirtualService

2023.11.6-分析 Gateway 和 VirtualService 目录 本节实战 实战名称 正文 前面我们创建了一个 Gateway 和 VirtualService 对象,用来对外暴露应用,然后我们就可以通过 ingressgateway 来访问 Bookinfo 应用了。那么这两个资源对象是如何实现的呢&…

PyTorch深度学习实战——图像着色

PyTorch深度学习实战——图像着色 0. 前言1. 模型与数据集分析1.1 数据集介绍1.2 模型策略 2. 实现图像着色相关链接 0. 前言 图像着色指的是将黑白或灰度图像转换为彩色图像的过程,传统的图像处理技术通常基于直方图匹配和颜色传递的方法或基于用户交互的方法等完…

提升你的C#技能:掌握PrintDocument实现打印操作的秘诀

前言: 我们用C#在开发应用的时候,经常需要打印操作,比如你需要打印某些记录,或者是某些图像都需要用到打印的操作,比如我需要打印报警记录,按照指定的格式打印出来,我需要PrintDocument类&…

项目管理之如何识别并应对项目风险

项目风险管理是项目管理中不可忽视的环节,如何识别并应对项目的风险对于项目的成功实施至关重要。本文将介绍风险管理的流程、风险分解结构、定性及定量风险评估方法,以及消极和积极的风险应对策略,旨在帮助读者更好地理解和应对项目风险。 …

(1)(1.12) LeddarTech LeddarVu8

文章目录 前言 1 连接到自动驾驶仪 2 参数说明 前言 LeddarTech LeddarVu8 是一款长距离(185m)激光雷达,可在 16 度至 99 度视场范围内提供 8 个单独的距离,具体取决于所使用的型号。ArduPilot 始终使用所提供的 8 个距离中最…

VSCode设置中文语言界面(VScode设置其他语言界面)

一、下载中文插件 二、修改配置 1、使用快捷键 CtrlShiftP 显示出搜索框 2、然后输入 configure display language 3、点击 (中文简体) 需要修改的语言配置 三、重启 四、可能出现的问题 1、如果configure display language已经是中文配置,界面仍是英文 解决&a…

优化C++资源利用:探索高效内存管理技巧

W...Y的主页 😊 代码仓库分享💕 🍔前言: 我们之前在C语言中学习过动态内存开辟,使用malloc、calloc与realloc进行开辟,使用free进行堆上内存的释放。进入C后对于动态内存开辟我们又有了新的内容new与dele…

【C++】一篇文章搞懂auto关键字及其相关用法!

💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤 📃个人主页 :阿然成长日记 …