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

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

前言

本示例演示如何在 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 模型

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

image.png

FruitPickPlaceSimulinkGazebo

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


目录
相关文章
|
6天前
|
算法 5G 数据安全/隐私保护
大规模MIMO通信系统信道估计matlab性能仿真,对比LS,OMP,MOMP以及CoSaMP
本文介绍了大规模MIMO系统中的信道估计方法,包括最小二乘法(LS)、正交匹配追踪(OMP)、多正交匹配追踪(MOMP)和压缩感知算法CoSaMP。展示了MATLAB 2022a仿真的结果,验证了不同算法在信道估计中的表现。最小二乘法适用于非稀疏信道,而OMP、MOMP和CoSaMP更适合稀疏信道。MATLAB核心程序实现了这些算法并进行了性能对比。以下是部分
149 84
|
5天前
|
算法
基于GA遗传优化的TSP问题最优路线规划matlab仿真
本项目使用遗传算法(GA)解决旅行商问题(TSP),目标是在访问一系列城市后返回起点的最短路径。TSP属于NP-难问题,启发式方法尤其GA在此类问题上表现出色。项目在MATLAB 2022a中实现,通过编码、初始化种群、适应度评估、选择、交叉与变异等步骤,最终展示适应度收敛曲线及最优路径。
|
6天前
|
算法 BI Serverless
基于鱼群算法的散热片形状优化matlab仿真
本研究利用浴盆曲线模拟空隙外形,并通过鱼群算法(FSA)优化浴盆曲线参数,以获得最佳孔隙度值及对应的R值。FSA通过模拟鱼群的聚群、避障和觅食行为,实现高效全局搜索。具体步骤包括初始化鱼群、计算适应度值、更新位置及判断终止条件。最终确定散热片的最佳形状参数。仿真结果显示该方法能显著提高优化效率。相关代码使用MATLAB 2022a实现。
|
6天前
|
算法 数据可视化
基于SSA奇异谱分析算法的时间序列趋势线提取matlab仿真
奇异谱分析(SSA)是一种基于奇异值分解(SVD)和轨迹矩阵的非线性、非参数时间序列分析方法,适用于提取趋势、周期性和噪声成分。本项目使用MATLAB 2022a版本实现从强干扰序列中提取趋势线,并通过可视化展示了原时间序列与提取的趋势分量。代码实现了滑动窗口下的奇异值分解和分组重构,适用于非线性和非平稳时间序列分析。此方法在气候变化、金融市场和生物医学信号处理等领域有广泛应用。
|
5天前
|
监控 算法 数据安全/隐私保护
基于视觉工具箱和背景差法的行人检测,行走轨迹跟踪,人员行走习惯统计matlab仿真
该算法基于Matlab 2022a,利用视觉工具箱和背景差法实现行人检测与轨迹跟踪,通过构建背景模型(如GMM),对比当前帧与模型差异,识别运动物体并统计行走习惯,包括轨迹、速度及停留时间等特征。演示三维图中幅度越大代表更常走的路线。完整代码含中文注释及操作视频。
|
7天前
|
算法
基于GA遗传优化的离散交通网络双层规划模型设计matlab仿真
该程序基于GA遗传优化设计了离散交通网络的双层规划模型,以路段收费情况的优化为核心,并通过一氧化碳排放量评估环境影响。在MATLAB2022a版本中进行了验证,显示了系统总出行时间和区域排放最小化的过程。上层模型采用多目标优化策略,下层则确保总阻抗最小,实现整体最优解。
|
7天前
|
资源调度 算法
基于迭代扩展卡尔曼滤波算法的倒立摆控制系统matlab仿真
本课题研究基于迭代扩展卡尔曼滤波算法的倒立摆控制系统,并对比UKF、EKF、迭代UKF和迭代EKF的控制效果。倒立摆作为典型的非线性系统,适用于评估不同滤波方法的性能。UKF采用无迹变换逼近非线性函数,避免了EKF中的截断误差;EKF则通过泰勒级数展开近似非线性函数;迭代EKF和迭代UKF通过多次迭代提高状态估计精度。系统使用MATLAB 2022a进行仿真和分析,结果显示UKF和迭代UKF在非线性强的系统中表现更佳,但计算复杂度较高;EKF和迭代EKF则更适合维数较高或计算受限的场景。
|
8天前
|
算法
基于SIR模型的疫情发展趋势预测算法matlab仿真
该程序基于SIR模型预测疫情发展趋势,通过MATLAB 2022a版实现病例增长拟合分析,比较疫情防控力度。使用SIR微分方程模型拟合疫情发展过程,优化参数并求解微分方程组以预测易感者(S)、感染者(I)和移除者(R)的数量变化。![]该模型将总人群分为S、I、R三部分,通过解析或数值求解微分方程组预测疫情趋势。
|
8天前
|
算法 安全
基于MATLAB的SEIR传染病模型建模与仿真
本项目基于SEIR模型,利用MATLAB 2022a对传染病传播过程进行建模与仿真。SEIR模型将人群分为易感者(S)、暴露者(E)、感染者(I)和康复者(R),通过四类人群间的转换描述传染病动态。通过设定初始条件与参数,并采用ODE求解器进行模拟,生成了不同状态人群随时间变化的曲线图,展示了感染趋势及防控效果。系统仿真结果显示了模型的有效性和预测能力。
|
8天前
|
算法 数据可视化 数据安全/隐私保护
基于LK光流提取算法的图像序列晃动程度计算matlab仿真
该算法基于Lucas-Kanade光流方法,用于计算图像序列的晃动程度。通过计算相邻帧间的光流场并定义晃动程度指标(如RMS),可量化图像晃动。此版本适用于Matlab 2022a,提供详细中文注释与操作视频。完整代码无水印。

热门文章

最新文章

下一篇
DDNS