ABB 接口程序指令说明

您正在查看旧版本的文档。点击页面右上角可切换到最新版本的文档。

ABB 机器人程序调用说明:

  1. 程序的 形参列表 中各个 参数 之间以逗号分隔。

  2. 每个 形参变量 都定义为 局部变量 ,只在程序中有效。

  3. 程序的 形参列表 支持定义 输入参数输出参数

  4. 调用程序时的实参:输入实参可以是常量、全局变量或局部变量,输出实参可以是全局变量,或局部变量。

  • 对于Mech-Vision和Mech-Viz 1.8.0 之前的版本,每个接口程序指令都包含通信连接和通信断开语句。

  • 对于Mech-Vision和Mech-Viz 1.8.0 及以上的版本,通信连接和通信断开语句成为两个独立指令(建立TCP/IP通信连接指令和断开TCP/IP通信连接指令),从而避免频繁连接和断开机器人与视觉系统之间的通信。

本节将介绍以下指令。

初始化通信参数

该指令用于设置 TCP/IP 通信的主机IP地址、端口号,以及通信超时等待时间。在调用该指令后,调用建立TCP/IP通信连接指令可以建立机器人与视觉系统之间的TCP/IP通信连接。

程序

MM_Init_Socket "IP_Address",Server_Port,Time_Out;

输入参数

IP_Address

主机的 IP 地址

Server_Port

TCP/IP 通信端口号,端口号默认为 50000

Time_Out

超时等待时间;单位为 s

示例

MM_Init_Socket "192.168.1.20",50000,60;

执行该示例程序将需要连接的主机 IP 地址设为 192.168.1.20,端口号为 50000,超时时间为 60s。

建立TCP/IP通信连接

该指令用于建立机器人与视觉系统之间的TCP/IP通信连接。该指令需要在初始化通信参数指令之后被调用。

程序

MM_Open_Socket

断开TCP/IP通信连接

该指令用于断开机器人与视觉系统之间的TCP/IP通信连接。

程序

MM_Close_Socket

启动 Mech-Vision 工程

该指令用于只有 Mech-Vision 工程,没有 Mech-Viz 的场景。使用该指令触发 Mech-Vision 工程运行,执行相机拍照和视觉识别。

程序

MM_Start_Vis Job,Pos_Num_Need,SendPos_Type,MM_J;

输入参数

Job

Mech-Vision 工程编号可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

Pos_Num_Need

预期视觉点数量,即期望从 Mech-Vision 得到的视觉点数量。视觉点信息包括视觉位姿及对应点云、标签、缩放等。

  • 0:从 Mech-Vision 工程取得识别结果中所有的视觉点。

  • 大于0的整数:从 Mech-Vision 工程取得识别结果中指定数量的视觉点。

    • 如果视觉点总数小于该参数值,则取得识别结果中所有视觉点。

    • 如果视觉点总数大于等于该参数值,则取得该参数指定数量的视觉点。

  • 获取视觉点的指令是 102 指令。默认每次执行 102 指令最多可以获取 20 个视觉点。

  • 在第一次执行 102 指令后,其中一个返回的参数将体现是否已返回所有请求的视觉点;如果没有,请重复执行 102 指令。

SendPos_Type

机器人位姿类型,该参数指定真实机器人的位姿将以何种形式传入 Mech-Vision。参数范围:0~3。

  • 0:该指令不需向视觉系统传入机器人位姿。若工程为 Eye To Hand 模式,则拍照与机器人位姿无关,Mech-Vision 不需要机器人的位姿。

  • 1:该指令以“机器人当前关节角+当前法兰”形式向视觉系统传入机器人位姿。若工程为 Eye In Hand 模式,则推荐使用该参数。在使用时,Mech-Vision 工程中存在的“路径规划”步骤将使用机器人发送关节角。如果法兰位姿为全零,则忽略法兰数据。

  • 2:该指令以当前法兰位姿形式向视觉系统传入机器人位姿,适用于工程为 Eye In Hand 模式,且机器人无关节角数据,仅有法兰位姿数据(如桁架机器人)的场景中。

  • 3:该指令以预定义关节角(读取用户设置的关节角变量)形式向视觉系统传入机器人位姿。若工程为 Eye To Hand 模式,则推荐使用该参数。在使用时,Mech-Vision 工程中存在的“路径规划”步骤将使用机器人发送的关节角作为初始位姿。

MM_J

用户自己定义的关节角。在 SendPos_Type 参数值为 3 时,该关节角数据将发送给 Mech-Vision 工程的“路径规划”步骤作为第一个路径点进行规划。若 SendPos_Type 参数值为 3 以外的其他参数值,此处的关节角无实际用处,但必须设定该关节角。

示例

MM_Start_Vis 1, 1, 1,MM_J

该示例触发 Mech-Vision 工程 1 的运行,希望 Mech-Vision 工程 1 返回 1 个视觉点,机器人将当前关节角和法兰数据传入 Mech-Vision。

获取视觉目标点

用在“启动 Mech-Vision 工程”指令之后,使用该指令获取 Mech-Vision 的识别结果(视觉点)对应的机器人位姿及标签,机器人位姿形式为工具位姿(TCP)。

Mech-Center 会自动将视觉点信息转换为对应的机器人 TCP,其过程为:

  • 将视觉点包含的位姿绕 X 轴旋转 180°。

  • 识别对应机器人型号的参考坐标系定义是否涉及机器人基座高度,并相应增加垂直方向的偏置。

102 指令单次接收 TCP 数量上限默认为 20。如需要获取的 TCP 数量大于 20,需多次执行该指令来获取所有所需 TCP。

程序

MM_Get_VisData Job,Pos_Num,MM_Status;

输入参数

Job

Mech-Vision 工程编号可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

输出参数

Pos_Num

执行该指令获得的 TCP 数量。

  • 如果请求 TCP 数量大于等于 Mech-Vision 识别的视觉点数量,按照 Mech-Vision 识别的视觉点数量发送。

  • 如果请求 TCP 数量小于 Mech-Vision 识别视觉点数量,按照请求数量发送。

默认范围:0~20。

变量类型:num

MM_Status

若指令执行正常,则返回 1100 状态码;否则返回对应的错误码。

调用该指令时,若 Mech-Vision 结果还未返回,则视觉系统会等待 Mech-Vision 结果返回后再给机器人返回。默认等待 10 秒超时,若发生超时,返回超时错误状态码。

变量类型:num

示例

MM_Get_VisData 1,PoseNum,MMStatus;

该示例用于获取 Mech-Vision 工程 1 的视觉结果。PoseNum 表示当次返回的 TCP 数量,MMStatus 为状态码。

启动 Mech-Viz 工程

用于既使用 Mech-Vision 又使用 Mech-Viz 的场景。该指令用于运行 Mech-Viz 工程,启动对应的 Mech-Vision 工程,Mech-Viz 基于 Mech-Vision 的视觉结果规划机器人的运动路径。

请在需要启动 Mech-Viz 工程中勾选 自动加载

Mech-Vision和Mech-Viz软件安装目录下 Mech-Center/tool/viz_project 文件夹内有一些典型应用工程模板,用户可以在模板的基础上进行修改。

程序

MM_Start_Viz SendPos_Type,MM_J;

输入参数

SendPos_Type

机器人的位姿类型。参数范围:0~2。

0:无需向 Mech-Viz 传入机器人位姿,Mech-Viz 软件中仿真机器人将会从关节角 [0,0,0,0,0,0] 位置开始,运动到第一个路径点。

1:将机器人的当前关节角和法兰位姿传入 Mech-Viz,Mech-Viz 软件中仿真机器人将会从当前机器人关节角位置开始,运动到第一个路径点。

2:将机器人的一个预定义关节角传入 Mech-Viz,Mech-Viz 软件中仿真机器人将会从当前机器人关节变量设定的位置开始,运动到第一个路径点。

若场景中的碰撞模型干扰机器人从关节角 [0, 0, 0, 0, 0, 0] 移动到第一个路径点时,则位姿类型必须设置为 1。

MM_J

用户自定义的关节角数据。仅当 SendPos_Type 为 2 时,该关节角数据将发送给 Mech-Viz 作为第一个路径点进行规划;当 SendPos_Type 为其他值时,该关节角数据无实际意义,但必须设定其值。

示例

MM_Start_Viz 1,MM_J;

该示例触发 Mech-Viz 工程运行,将当前机器人的关节角和法兰位姿传入 Mech-Viz。

获取 Mech-Viz 数据

该指令用于获取 Mech-Viz 规划的路径,需在执行“启动 Mech-Viz 工程”指令之后调用。使用该指令后,调用 转存获取的机器人工具位姿(TCP)数据转存获取的关节角数据 才可访问位姿数据。

限制:默认设置下,该指令每次最多只能获取 20 个规划路径的路径点,所以该指令可能需要调用多次。

如果工程中某个移动类步骤的路径点不应发给机器人,请取消勾选该步骤参数中的“发送移动目标”选项。

程序

MM_Get_VizData Jps_Pos,Pos_Num,VisPos_Num,MM_Status;

输入参数

Jps_Pos

路径点的位姿类型,该参数用于指定 Mech-Viz 将返回何种形式的位姿。

输出参数

Pos_Num

路径点数量。该参数用于显示此次执行该指令返回了多少路径路径点([位姿、标签、速度])。

如果路径中含有 20 个以上路径点,请多次执行该指令。

默认范围:0~20。

VisPos_Num

“视觉移动”步骤位置,即“视觉移动”步骤路径点在整个路径中的位置。“视觉移动”步骤即移动至视觉点(抓取物体的点)的移动步骤。

比如,如果规划路径由以下步骤组成:“定点移动_1”,“定点移动_2”,“视觉移动”,“定点移动_3”,则“视觉移动”步骤位置为3。

如果路径中无“视觉移动”步骤,则该参数值为 0。

MM_Status

状态码。

若指令执行正常,则返回 2100 状态码;否则返回对应的错误码。

调用该指令时,若 Mech-Viz 结果还未返回(正在运行中),视觉系统会等待 Mech-Viz 结果返回后再给机器人返回,默认等待 10s 超时,若发生超时,则给机器人返回超时错误。

示例

MM_Get_VizData 2,Pos_Num,Vis_Index,StatusCode;

该示例用于接收 Mech-Viz 返回的机器人移动路径,移动点数据类型为 TCP,位姿的数量保存在变量 Pos_Num 中,视觉移动点在路径中的编号保存在变量 Vis_Index 中,指令执行的状态码保存在变量 StatusCode 中。

转存获取的机器人工具位姿(TCP)数据

该指令用于将某个视觉点(Mech-Vision 返回)或路径点(Mech-Vision或Mech-Viz 返回)的 TCP 位姿数据转存到指定变量中。

程序

MM_Get_Pose Index,P90,Label,Pose_Speed;

输入参数

Index:该参数用于指定要转存的是第几个 TCP 位姿数据。

输出参数

P90

位姿变量,用于保存指定的 TCP 位姿数据。

Label

num 类型变量,用于保存和指定位姿对应的标签数据。

Pose_Speed

num类型变量,用于保存和指定位姿对应的移动速度数据。

示例

MM_Get_Pose 1,P90,Label,PoseSpeed1;

该示例用于将收到的第一个位姿保存到位置变量 P90 中,将标签保存到变量 Label 中,将移动速度保存到变量 PoseSpeed1 中。

转存获取的关节角数据

该指令用于将 Mech-Vision 或 Mech-Viz 返回的某个路径点的关节角数据转存到指定变量中。

程序

MM_Get_Jps Index,Jointtarget,Label,Pose_Speed;

输入参数

Index:该参数用于指定要转存的是第几个路径点的关节角。

输出参数

Jointtarget

关节角变量,用于保存指定的关节角数据。

Label

num 类型变量,用于保存和指定路径点对应的标签数据。

Pose_Speed

num类型变量,用于保存和指定路径点对应的移动速度数据。

示例

MM_Get_Jps 1,jpose1,Label1,PoseSpeed1;

该示例用于将收到的第一个路径点的关节角数据保存到位置变量 jpose1 中,将标签保存到变量 Label1 中,将移动速度保存到变量 PoseSpeed1 中。

切换 Mech-Vision 配方

切换 Mech-Vision 工程内的参数配方。

Mech-Vision 中步骤的参数设定可通过切换参数配方调整。

参数配方调整涉及的参数通常包括点云匹配模板、图像匹配模板、感兴趣区域、置信度阈值等。

需要在执行“启动 Mech-Vision 工程”指令之前使用该指令。

程序

MM_Switch_Model Job,Model_Number;

输入参数

Job

Mech-Vision 工程编号可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

Model_Number

配方编号。

Mech-Vision 工程中配方模板的编号,为正整数。单击工程助手  参数配方,进入参数配方编辑器。编号范围:1~99。

示例

MM_Switch_Model 1,1;

该示例会将 Mech-Vision 工程 1 的配方切换成配方 1 。

选择 Mech-Viz 分支

当 Mech-Viz 工程中有分支步骤时,该指令可控制 Mech-Viz 工程中的分支步骤走指定的出口。

在执行该指令前请先执行“启动 Mech-Viz 工程”指令。

Mech-Viz 工程运行至分支步骤时,将等待该指令指定出口。

程序

MM_Set_Branch Branch_Num,Exit_Num;

输入参数

Branch_Num

分支步骤编号,为正整数,可在步骤参数中读取。

Exit_Num

分支步骤的出口号,为正整数。

出口号为从 1 开始的端口索引号。例如指定的出口为从左往右数第二个端口,那么出口号为 2。

示例

MM_Set_Branch 1,3;

该示例会指定 Mech-Viz 工程执行遇到分支名称为 1 的步骤时,走 3 出口。

设置移动索引

该指令用于设定Mech-Viz步骤的当前索引参数值。带有该参数的步骤包括“按序列移动”、“按阵列移动”、“自定义垛型”、“预设垛型”等。

在执行该指令前,请先执行“启动 Mech-Viz 工程”指令。

程序

MM_Set_Index Skill_Num,Index_Num;

输入参数

Skill_Num

步骤编号。

该参数指定哪个步骤需要索引参数设定。

该参数值应为正整数,即待索引步骤的步骤编号。步骤编号可在步骤参数中读取。

Index_Num

下次执行此步骤时应设置的当前索引值。

发送该指令时,Mech-Viz 中的当前索引值将变为该参数值减 1。

当 Mech-Viz 工程运行到该指令指定的步骤时,Mech-Viz 中的当前索引值将增加 1,成为该参数的值。

示例

MM_Set_Index 2,10;

该示例设置 Mech-Viz 工程中编号为 2 的步骤的当前索引值为 9,工程运行至该步骤时,该步骤索引值加一变为 10。

获取软件状态

该指令用于检查软件运行状态(Mech-Vision、Mech-Viz、Mech-Center)。

目前该指令只支持检查 Mech-Vision 是否可以开始运行工程。

程序

MM_Get_Status MM_Status;

输出参数

MM_Status

变量,用于保存指令状态码。1101 状态码为“Mech-Vision 工程已就绪”;其他状态码为 “Mech-Vision 工程未就绪”。目前该指令只能用于检查 Mech-Vision 工程是否已就绪。

示例

MM_Get_Status StatusCode;

该示例将检查系统状态的状态码保存到变量 StatusCode 中。

向 Mech-Vision 中传入物体尺寸

该参数用于往 Mech-Vision 工程中动态传入物体尺寸。启动 Mech-Vision 工程前请先确认物体尺寸。

Mech-Vision 工程中应有“读取物体尺寸”步骤,且应勾选该步骤的从参数读取物体尺寸参数。

程序

MM_Set_BoxSize Job,Lenght,Width,Height;

输入参数

Job

Mech-Vision 工程编号可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

Length, Width, Height

传入 Mech-Vision 工程的物体尺寸(依次为长、宽、高)。尺寸值将被“读取物体尺寸”步骤读取。

单位:毫米(mm)

示例

MM_Set_BoxSize 1,500,300,200

该示例将设置 Mech-Vision 工程中的“读取物体尺寸”步骤读取的尺寸为 500 × 300 × 200 mm。

获取吸盘DO信号

该指令用于获取 Mech-Vision 或 Mech-Viz 规划的 DO 信号列表。机器人通过 MM_Set_DoList 将获取到的 DO 信号列表作用于末端工具。

程序

MM_Get_DoList Resource;

输入参数

Resource

num类型变量。该参数指定DO信号列表的来源。

  • 0:从Mech-Viz获取DO信号列表。

  • 正整数:从Mech-Vision获取DO信号列表。此处设置的正整数就是Mech-Vision工程编号。

示例

MM_Get_DoList 0;

该示例表示将从Mech-Viz获取的DO信号列表存入机器人内存中。

设置吸盘DO信号

该指令用于将 Mech-Vision 或 Mech-Viz 软件返回的 DO 列表设置到 GO 信号中,最多支持4组 GO 信号,一组 GO 信号为 16 位。 如需设置多组 GO 信号,请多次使用此指令。

该指令需在 MM_Get_DoList 之后使用。

程序

MM_Set_DoList Serial,GO16;

输入参数

Serial

信号组索引号,范围为1~4。

输出参数

GO16

组信号名称,用于存储需要设置的 DO 信号值。

示例

MM_Set_DoList 1,GO16;

MM_Set_DoList 2,GO32;

执行此程序会将 DO 列表 0-15 写入到 GO16 ,16-32 写入到 GO32 信号里。

标定

该指令用于手眼标定(相机外参标定)。

该指令会与 Mech-Vision 同步标定状态,并从 Mech-Vision 处获得机器人需要到达的标定点。

该指令需要运行多次以完成标定。

程序

MM_Calib Move_Type,Pos_Jps,Wait_time,\num Ext;

输入参数

参数 描述

Move_Type

移动方式;1为 MoveL ,2为 MoveJ 。

Pos_Jps

使用坐标点位或关节角数据;1 使用工具坐标中心点 ,2 使用关节角。

Wait_time

机器人移动到标定点后的等待时间(防止机器人发生抖动);默认为 2 秒;单位为 s(秒)。

Ext

可选变量,外部轴数据(当有7轴导轨时使用);单位为 mm 。

示例

  • 示例1:

    MM_Calib 2,1,2;

    该示例设置机器人使用工具中心点坐标,按 MoveJ 方式移动,机器人移动到标定点后的等待时间为 2 秒。

  • 示例2:

    MM_Calib 2,1,2\EXT:=Axis7;

    该示例设置机器人使用工具中心点坐标,按 MoveJ 方式移动,机器人移动到标定点后的等待时间为 2 秒,7轴值为 Axis7 。

获取 Mech-Vision 自定义数据

该指令用于从 Mech-Vision 中的“输出”步骤接收自定义数据,即除 poses 和 labels 之外其他端口的数据(“输出”步骤参数“端口类型”设置为“自定义”)。

该指令调用一次获取全部数据到机器人内存。

程序

MM_Get_DyData job,Pos_Num,MM_Status;

输入参数

job

num 类型变量。Mech-Vision 工程编号可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

输出参数

Pos_Num

num 类型变量。保存返回的视觉点个数。

MM_Status

num 类型变量。保存该指令返回的状态码。

示例

MM_Get_DyData 2,Pos_Num,StatusCode;

该示例在 Mech-Vision 工程 2 运行后,将所有视觉点的物体位姿数据和对应标签数据存放到机器人全局数组 MMvis2_Pose 中,对应的自定义数据存放到全局数组 UserData 中,并将视觉点个数存放到 Pos_Num,StatusCode 变量存放本指令执行后的状态码。

将 MM_GET_DY_DATA 获取的自定义数据分配至各变量中

该指令用于将一组自定义数据按指定索引从内存存放到不同变量中,在触发 获取 Mech-Vision 自定义数据 指令之后使用。

程序

MM_Get_DyPose Serial,MM_P,MM_Label;

输入参数

Serial

num 类型变量。指定索引值,即获取第几个视觉点中的自定义数据(数据顺序按照 Mech-Vision 发送顺序排列)。

输出参数

MM_P

robtarget 类型变量。保存指定视觉点的位姿数据。

MM_Label

num 类型变量。保存指定视觉点的标签数据(若 Mech-Vision 未设置标签端口,则会用 0 填充)。

MM_UserData

num 类型变量。全局数组变量(用户不需要传递该参数,直接读取该数组即可),用于保存指定视觉点的用户自定义数据。

示例

MM_Get_DyPose 2,MM_P_VISION,MM_Label;

该示例在 MM_Get_DyPose 运行后,将第二个视觉点的位姿数据存放在 MM_P_VISION 变量中,对应的标签数据存放在 MM_Label 变量中,对应的用户自定义数据存放在 MM_UserData 数组中。

获取视觉移动规划数据或自定义数据

该指令用于获取Mech-Vision工程的视觉移动规划数据,或者获取Mech-Viz工程的视觉移动规划数据或自定义数据。 MM_Get_PlanPose或MM_Get_PlanJps可将获取的数据分配至各变量中。

程序

MM_GET_PLANDATA Resource,Jps_Pos,Pos_Num,VisPos_Num,MM_Status;

输入参数

Resource

num类型变量。该参数指定视觉移动规划数据的来源。

  • 0:从Mech-Viz获取视觉移动规划数据。

  • 正整数:从Mech-Vision获取视觉移动规划数据。此处设置的正整数就是Mech-Vision工程编号。

Jps_Pos

num 类型变量。预期的返回数据格式。

  • 当Resource为0时,Jps_Pos 参数取值范围为 1~4,具体说明如下。

    Jps_Pos 参数值 预期的返回数据 说明(每个字段的具体解释参见下文)

    1

    位姿(JPs 形式), 移动类型, 末端工具编号, 速度, 自定义数据项 1, …, 自定义数据项 N

    2

    位姿(TCP 形式), 移动类型, 末端工具编号, 速度, 自定义数据项 1, …, 自定义数据项 N

    3

    位姿(JPs 形式), 移动类型, 末端工具编号, 速度, Mech-Viz视觉移动规划数据, 自定义数据项 1, …, 自定义数据项 N

    4

    位姿(TCP 形式), 移动类型, 末端工具编号, 速度, Mech-Viz视觉移动规划数据, 自定义数据项 1, …, 自定义数据项 N

  • 当Resource为正整数时,Jps_Pos 参数取值范围为 1~2,具体说明如下。

    Jps_Pos 参数值 预期的返回数据 说明(每个字段的具体解释参见下文)

    1

    位姿(JPs 形式), 移动类型, 末端工具编号, 速度, Mech-Vision视觉移动规划数据

    2

    位姿(TCP 形式), 移动类型, 末端工具编号, 速度, Mech-Vision视觉移动规划数据

位姿

路径点的位姿可以是机器人关节角(JPs,单位为度)或工具位姿(TCP,其中三维坐标单位为毫米,欧拉角单位为度),其形式取决于发送的指令参数。

移动类型

  • 1:关节移动。

  • 2:直线移动。

末端工具编号

路径点的末端工具编号。若值为-1,表示不使用末端工具。

速度

路径点的速度值。

视觉移动规划数据

Mech-Vision或Mech-Viz中“视觉移动”步骤规划的数据,包括被抓取工件的标签、已抓取的工件总数、本次抓取的工件数量、吸盘边角号、TCP偏移量、工件组朝向、单个工件朝向、工件组尺寸。

自定义数据项

当 Mech-Vision 工程中“输出”步骤的端口类型为“自定义”时,除 poses 和 labels 等之外其他自定义端口的数据。

各自定义数据按照端口名称的字母顺序(A—Z)排列。

输出参数

Pos_Num

num 类型变量。保存返回的路径点个数。

VisPos_Num

num 类型变量。保存第一个视觉移动在规划路径中的位置编号。例如,如果规划路径由以下组成:“定点移动_1”,“定点移动_2”,“视觉移动”,“定点移动_3”,则“视觉移动”位置为 3。如果路径中无“视觉移动”,则该参数值为 0。

MM_Status

num 类型变量。保存该指令返回的状态码。

示例

MM_GET_PLANDATA 0,4,PosNum,Vis_Index,StatusCode;

该示例在 Mech-Viz 工程运行后,将所有输出数据存放到机器人全局数组中,PosNum 变量为数据组数,Vis_Index 变量为视觉移动位置编号,StatusCode 变量为本指令执行的状态码。

将从MM_GET_PLANDATA获取的数据保存至各变量

该指令用在获取视觉移动规划数据或自定义数据指令后,用于将获取的数据存放到不同变量中。根据获取视觉移动规划数据或自定义数据指令中指定的Jps_Pos参数值,选择不同的程序。

程序

MM_Get_PlanPose Serial,Jps_Pos,MM_P,MM_MoveType,MM_ToolNum,MM_Speed; (当 Jps_Pos=2 或者 4 时)
MM_Get_PlanJps Serial,Jps_Pos,MM_J,MM_MoveType,MM_ToolNum,MM_Speed; (当 Jps_Pos=1 或者 3 时)

输入参数

Serial

num 类型变量。指定获取全局数组中的第几组路径点数据(数据顺序按照 Mech-Viz 输出的路径点顺序排列)。

Jps_Pos

num 类型变量。需要与 MM_GET_PLANDATA 中的 Jps_Pos 所选值一致。

输出参数

MM_P

robtarget 类型变量。保存指定路径点对应的 TCP 数据(程序 1 使用)。

MM_J

Jointtarget 类型变量。保存指定路径点对应的关节角数据(程序 2 使用)。

MM_MoveType

num 类型变量。保存指定路径点对应的移动类型。

MM_ToolNum

num 类型变量。保存指定路径点对应的末端工具编号。

MM_Speed

num 类型变量。保存指定路径点对应的速度。

MM_UserData

已定义的全局数组变量(用户不需要传递该参数,直接读取该数组即可)。保存指定路径点对应的用户自定义数据。

MM_Plan_Results

已定义的全局数组变量(用户不需要传递该参数,直接读取该数组即可)。保存指定路径点对应的视觉移动规划数据。数组大小为21。

MM_Plan_Results数组变量的具体内容如下表所示。

数据 说明 变量

被抓取工件的标签

由10个整数组成,默认为10个0

MM_Plan_Results[1] ~ MM_Plan_Results[10]

已抓取的工件总数

累计已抓取的工件数量

MM_Plan_Results[11]

本次抓取的工件数量

本次抓取的工件数量

MM_Plan_Results[12]

吸盘边角号

本次吸盘所使用的边角号

MM_Plan_Results[13]

TCP偏移量

工件组中心相对于末端工具中心的XYZ偏移量

MM_Plan_Results[14] ~ MM_Plan_Results[16]

工件组朝向

工件组与吸盘长边的朝向关系,0表示平行,1表示垂直

MM_Plan_Results[17]

单个工件朝向

单个工件长边与吸盘长边的朝向关系,0表示平行,1表示垂直

MM_Plan_Results[18]

工件组尺寸

本次抓取的工件组的长宽高

MM_Plan_Results[19] ~ MM_Plan_Results[21]

示例

  • 示例1:

    MM_Get_PlanPose 2,4,P10,MoveType,ToolNum,Speed;

    该示例在 MM_GET_PLANDATA 运行后,将 Mech-Viz 规划的第二个路径点的 TCP 数据存放在 P10 变量中,移动类型、末端工具编号、速度分别存放在 MoveType、ToolNum、Speed 变量中。如果该路径点不是视觉移动路径点,则无后续信息;如果是视觉移动路径点,则将视觉移动规划数据保存到 MM_Plan_Results 全局数组中,将自定义数据保存到 MM_UserData 全局数组中。

  • 示例2:

    MM_Get_PlanJps 1,3,jpose1,MoveType,ToolNum,Speed;

    该示例在 MM_GET_PLANDATA 运行后,将 Mech-Viz 规划的第一个路径点的关节角数据存放在 jpose1 变量中,移动类型、末端工具编号、速度分别存放在 MoveType、ToolNum、Speed 变量中。如果该路径点不是视觉移动路径点,则无后续信息;如果是视觉移动路径点,则将视觉移动规划数据保存到 MM_Plan_Results 全局数组中, 将自定义数据保存到 MM_UserData 全局数组中。

获取 Mech-Vision “路径规划”步骤的结果

在启动 Mech-Vision 工程后,该指令用于获取 Mech-Vision 中“路径规划”步骤输出的免碰撞抓取路径。

在使用该指令时,Mech-Vision “输出”步骤的 端口类型 参数需要设置为“预定义(机器人路径)”。

程序

MM_Get_VisPath Job,Jps_Pos,Pos_Num,VisPos_Num,MM_Status;

输入参数

Job

num 类型变量。Mech-Vision 工程编号可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

Jps_Pos

num 类型变量。指定“路径规划”步骤返回的路径点的位姿类型。

  • 1:路径点的位姿将以机器人关节角(JPs)的形式返回。

  • 2:路径点的位姿将以机器人工具位姿(TCP)的形式返回。

输出参数

Pos_Num

num 类型变量。保存该指令返回的路径点个数。

VisPos_Num

num 类型变量。保存路径规划工具中设置的“视觉移动”路径点在整个路径中的位置。例如,如果规划路径由以下组成:“定点移动_1”,“定点移动_2”,“视觉移动”,“定点移动_3”,则“视觉移动”位置为 3。如果路径中无“视觉移动”,则该参数值为 0。

MM_Status

num 类型变量。保存该指令返回的状态码。

示例

MM_Get_VisPath 2,2,PosNum,Vis_Index,StatusCode;

该示例用于接收 Mech-Vision 工程 2 返回的机器人移动路径,路径点位姿类型为 TCP,路径点的数量保存在 PosNum 变量中,视觉移动路径点在路径中的位置编号保存在变量 Vis_Index 中,执行指令后的状态码保存在变量 StatusCode 中。

运行Mech-Vision工程并获取结果

该指令先设置Mech-Vision工程所使用的参数配方(工程中无参数配方,可跳过),然后触发Mech-Vision工程运行,最终返回视觉系统输出的结果(视觉点、路径点或自定义数据)。该指令相等于将 切换 Mech-Vision 配方启动 Mech-Vision 工程获取视觉目标点获取 Mech-Vision “路径规划”步骤的结果获取 Mech-Vision 自定义数据 指令合并。

该指令最多返回20个位姿数据。如果获取的位姿个数大于20,请勿使用该指令,而是使用 切换 Mech-Vision 配方启动 Mech-Vision 工程获取视觉目标点获取 Mech-Vision “路径规划”步骤的结果获取 Mech-Vision 自定义数据 指令。

程序

MM_Lite_Vis Job,Model_Number,Recv_Data_Type,MM_Status,\MM_J,\Pos_Num,\VisPos_Num;

输入参数

Job

num类型变量。Mech-Vision工程编号可在Mech-Vision工程列表窗口中查看,工程名称前的数字表示工程编号。

Model_Number

num类型变量。Mech-Vision工程中参数配方的编号,取值范围为0~99。0表示Mech-Vision工程不使用配方参数。

Recv_Data_Type

num类型变量。该参数用于指定视觉系统返回的数据类型,取值范围为1~4。

  • 1:视觉系统返回视觉点(无自定义数据)。用户后续需调用MM_Get_Pose将视觉点的位姿保存至指定变量中。

  • 2:视觉系统返回视觉点(携带自定义数据)。用户后续需调用MM_Get_DyPose将视觉点的自定义数据保存至指定变量中。

  • 3:视觉系统返回路径点(位姿形式为关节角)。用户后续需调用MM_Get_Jps将路径点的位姿数据保存至指定变量中。

  • 4:视觉系统返回路径点(位姿形式为TCP)。用户后续需调用MM_Get_Pose将路径点的位姿数据保存至指定变量中。

输出参数

MM_Status

num类型变量。保存该指令返回的状态码。

Pos_Num(可选)

num类型变量。保存该指令返回的视觉点或路径点个数。

VisPos_Num(可选)

num类型变量。在 Recv_Data_Type 为3或4时,该参数值才有意义,将保存“路径规划”步骤中设置的第一个“视觉移动”路径点在整个路径中的位置。例如,如果规划路径由以下组成:“定点移动_1”,“定点移动_2”,“视觉移动”,“定点移动_3”,则“视觉移动”位置为3。如果路径中无“视觉移动”,则该参数值为0。

示例

MM_Lite_Vis 1,2,1,MMStatus,\Pos_Num:=PoseNum;

该示例表示获取Mech-Vision工程1输出的视觉点。在运行Mech-Vision工程前,先设置Mech-Vision使用编号为2的参数配方。获取的视觉点数量保存在变量PoseNum中,指令执行的状态码保存在变量MMStatus中。

运行Mech-Viz工程并获取规划路径

该指令先触发Mech-Viz工程运行,然后设置消息分支出口(工程中无分支,可跳过),最后返回Mech-Viz工程规划的移动路径。该指令相等于将 启动 Mech-Viz 工程选择 Mech-Viz 分支获取 Mech-Viz 数据 指令合并。

该指令最多返回20个位姿数据。如果获取的位姿个数大于20,请勿使用该指令,而是使用 启动 Mech-Viz 工程选择 Mech-Viz 分支获取 Mech-Viz 数据 指令。

程序

MM_Lite_Viz Branch_Num,Export_Num,Recv_Data_Type,MM_Status,\Pos_Num,\VisPos_Num;

输入参数

Branch_Num

num类型变量。该参数用于指定消息分支的步骤编号,取值范围为0~99。0表示Mech-Viz工程不使用“消息分支”步骤。

Export_Num

num类型变量。该参数用于指定“消息分支”步骤的出口号,其值为正整数。若将该参数值设置为N,则Mech-Viz工程将沿“消息分支”步骤的N-1出口继续执行。

Recv_Data_Type

num类型变量。该参数用于指定视觉系统返回的数据类型,取值范围为1~2。

  • 1:视觉系统返回路径点(位姿形式为关节角)。用户后续需调用MM_Get_Jps将路径点的位姿数据保存至指定变量中。

  • 2:视觉系统返回路径点(位姿形式为TCP)。用户后续需调用MM_Get_Pose将路径点的位姿数据保存至指定变量中。

输出参数

MM_Status

num类型变量。保存该指令返回的状态码。

Pos_Num(可选)

num类型变量。保存该指令返回的路径点个数。

VisPos_Num(可选)

num类型变量。该参数用于保存“路径规划”步骤中设置的第一个“视觉移动”路径点在整个路径中的位置。例如,如果规划路径由以下组成:“定点移动_1”,“定点移动_2”,“视觉移动”,“定点移动_3”,则“视觉移动”位置为3。如果路径中无“视觉移动”,则该参数值为0。

示例

MM_Lite_Viz 1,2,1,MMStatus,\Pos_Num:=PoseNum;

该示例表示获取Mech-Viz工程输出的路径点。在运行Mech-Viz工程时,设置步骤编号为1的消息分支走出口1。获取的路径点数量保存在变量PoseNum中,指令执行的状态码保存在变量MMStatus中。

获取通知的消息

在触发Mech-Vision或Mech-Viz工程运行后,该指令用于获取“通知”步骤中预先设置的消息。

程序

MM_Get_Notify Msg;

输出参数

Msg

num类型变量。保存通知的消息(暂时只支持整数)。

示例

MM_Get_Notify Msg_1;

该示例表示将从“通知”步骤获取的消息保存至变量Msg_1中。

读取Mech-Viz步骤参数值

该指令用于读取Mech-Viz工程中指定的步骤参数值。

程序

MM_Get_Property Get_Id,MM_Status,Viz_Prop;

输入参数

Get_Id

该参数为property_config文件中指定的 配置编号 字段。

在Mech-Vision工具栏的 机器人通信配置  下一步  高级设置 下,单击 属性配置,即可打开property_config文件。

get property config

在使用该指令前,用户需提前在property_config文件中指定步骤编号和参数名称对应的key名称,具体格式如下所示。

read, 配置编号, 步骤编号, key名称

read

指定该行用于读取步骤参数值。

配置编号

指定一个唯一的编号,为正整数。一个配置编号只能用于读取一个步骤参数值。如果读取多个步骤参数值,请使用不同的配置编号。

步骤编号

指定将要读取的参数所属步骤的编号。

key名称

指定将要读取的参数名称对应的key名称。

  • key名称 可通过 Keys查询工具 获取。单击Mech-Viz菜单栏的 工具  Keys查询工具,即可打开该工具。单击具体步骤图标,中间区域就是选中步骤的所有参数名称对应的key名称。设置的key名称必须是下图区域中出现的名称。

    parameter key name
  • property_config文件中以“#”为开头的内容为注释行,指令在执行代码时会忽略注释,不做任何处理。

  • 对property_config文件编辑完后,注意保存文件,并重启Mech-Vision工具栏中的接口服务。

property_config文件中可以设置多条read指令,但每条read指令的配置编号必须唯一。

输出参数

MM_Status

整型变量,用于保存该指令返回的状态码。

Viz_Prop

整型变量,用于保存返回的指定步骤的参数值,目前只支持返回INT整型值。

示例

例如,在property_config文件中添加如下内容,5表示配置编号,3表示步骤编号,xCount表示key名称。

read, 5, 3, xCount

机器人发送如下指令后,将会获取到xCount对应的参数值。

MM_Get_Property 5,MM_Status,Viz_Prop;

该示例表示将Mech-Viz工程中步骤编号3的xCount对应参数值保存到Viz_Prop变量中,并将返回的状态码保存在MM_Status变量中。

设置Mech-Viz步骤参数值

该指令用于设置Mech-Viz工程中指定的步骤参数值。

程序

MM_Set_Property Set_Id,MM_Status;

输入参数

Set_Id

该参数为property_config文件中指定的 配置编号 字段。

在Mech-Vision工具栏的 机器人通信配置  下一步  高级设置 下,单击 属性配置,即可打开property_config文件。

get property config

在使用该指令前,用户需提前在property_config文件中指定步骤编号、参数名称对应的key名称和参数值,具体格式如下所示。

write, 配置编号, 步骤编号, key名称, 参数值

write

指定该行用于设置步骤参数值。

配置编号

指定一个编号(非唯一),为正整数。

步骤编号

指定将要设置的参数所属步骤的编号。

key名称

指定将要设置的参数名称对应的key名称。

参数值

指定将要设置的参数值。

  • property_config文件中可以设置多条write指令,且配置编号允许重复,即使用一个配置编号设置多个参数值。

  • key名称 可通过 Keys查询工具 获取。单击Mech-Viz菜单栏的 工具  Keys查询工具,即可打开该工具。单击具体步骤图标,中间区域就是选中步骤的所有参数名称对应的key名称。设置的key名称必须是下图区域中出现的名称。

    parameter key name
  • property_config文件中以“#”为开头的内容为注释行,指令在执行代码时会忽略注释,不做任何处理。

  • 对property_config文件编辑完后,注意保存文件,并重启Mech-Vision工具栏中的接口服务。

输出参数

MM_Status

该参数用于保存该指令返回的状态码。

示例

例如,property_config文件内容如下,1表示配置编号,3表示步骤编号,xOffset、yOffset和zOffset表示key名称,10表示xOffset对应的参数值,20表示yOffset对应的参数值,30表示zOffset对应的参数值。

write, 1, 3, xOffset, 10
write, 1, 3, yOffset, 20
write, 1, 3, zOffset, 30

机器人发送如下指令后,Mech-Viz会将xOffset、yOffset和zOffset对应的参数值分别设置为10、20和30。

MM_Set_Property 1,MM_Status;

该示例表示将xOffset、yOffset和zOffset对应的参数值分别设置为10、20和30,并将返回的状态码保存在MM_Status变量中。

停止Mech-Viz工程

该指令用于停止正在运行的Mech-Viz工程。

程序

MM_Stop_Viz MM_Status;

输出参数

MM_Status

该参数用于保存该指令返回的状态码。

示例

MM_Stop_Viz MM_Status;

该示例表示停止正在运行的Mech-Viz工程,并将返回的状态码保存在MM_Status变量中。

我们重视您的隐私

我们使用 cookie 为您在我们的网站上提供最佳体验。继续使用该网站即表示您同意使用 cookie。如果您拒绝,将使用一个单独的 cookie 来确保您在访问本网站时不会被跟踪或记住。