YASKAWA (安川)接口程序指令说明
YASKAWA 机器人程序调用说明:
-
程序的参数列表中,各个参数之间以分号分割。
-
调用程序时的参数:输入参数默认是字符串常量;输出参数默认是字符串常量,在后台对应相应的全局变量。
|
以下为接口程序指令介绍。
初始化通信指令
启动 Mech-Vision 工程
该指令用于触发 Mech-Vision 工程的运行,执行相机拍照和视觉处理。用于只使用 Mech-Vision 而不使用 Mech-Viz 的场景。
参数说明
参数 | 描述 |
---|---|
输入参数 |
|
job |
Mech-Vision 工程编号,可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。 |
pos_num_need |
预期视觉点数量,即期望从 Mech-Vision 得到的视觉点数量。可设置范围 [0~20],0 表示获取所有。 |
sendpos_type |
机器人位姿类型,该参数指定真实机器人的位姿将以何种形式传入 Mech-Vision。参数范围:[0~3]。
|
prNum |
P 变量编号,用于保存机器人预定义的关节角数据,仅当 sendpos_type=3 时才会使用此关节角数据。P 变量需要选择脉冲形式(最终会通过后台转换成关节角形式数据发出,选择未设定脉冲形式的 P 变量会报错误 “MM:PVAR_SET_ERROR”)。 |
获取视觉目标点
启动 Mech-Viz 工程
该指令用于既用到 Mech-Vision 工程又用到 Mech-Viz 工程的场景,用于启动 Mech-Viz 工程,调用相应的 Mech-Vision 工程,并设置 Mech-Viz 中仿真机器人的初始位姿。
参数说明
参数 | 描述 |
---|---|
输入参数 |
|
sendpos_type |
机器人的位姿类型。参数范围:[0~2]。
|
prNum |
P 变量编号,用于保存机器人预定义的关节角数据,仅当 SendPos_Type=2 时才会使用此关节角数据。P 变量需要选择脉冲形式(最终会通过后台转换成关节角形式数据发出,选择未设定脉冲形式的 P 变量会报错误 “MM:PVAR_SET_ERROR”)。 |
获取 Mech-Viz 数据
该指令用于获取 Mech-Viz 工程规划的抓取路径。
参数说明
参数 | 描述 |
---|---|
输入参数 |
|
GetPos_Type |
要获取的路径上点的位姿类型。 1:Mech-Viz 返回的位姿类型为机器人关节角。 2:Mech-Viz 返回的位姿类型为机器人工具中心点位姿。 |
输出参数 |
|
Pose_Num |
I 变量,用于保存返回的位姿数量。 |
VisPos_Num |
I 变量,用于保存第一个视觉移动在路径中的位置编号。例如路径是:移动-1,移动-2,视觉移动-1,移动-3,则视觉移动的位置是3。若路径中无视觉移动,则返回值为零。 |
MM_Status |
I 变量,用于保存指令状态码,具体可参考《标准接口状态码及错误排查》。 |
获取视觉点坐标值
获取视觉点关节角(使用 Mech-Viz 软件规划时有效)
选择 Mech-Viz 分支
该指令用于 Mech-Viz 工程中有“消息分支”步骤时,控制 Mech-Viz 工程中的“消息分支”步骤走指定的出口。 在调用该指令之前,需要先调用 MM_START_VIZ。Mech-Viz 软件运行到“消息分支”步骤时会等待 203 指令发送“消息分支”步骤的分支出口。
设置移动索引
获取软件状态
该指令用于获取 Mech-Vision,Mech-Viz,Mech-Center 的软件运行状态,目前只支持检测 Mech-Vision 软件是否就绪。
参数说明
参数 | 描述 |
---|---|
输出参数 |
|
Status |
I 变量,用于保存指令状态码,具体可参考《标准接口状态码及错误排查》。 |
向 Mech-Vision 传入物体尺寸
获取吸盘DO信号
该指令用于获取Mech-Vision或Mech-Viz规划的吸盘DO信号。机器人通过MM_SET_DOLIST将获取的吸盘DO信号作用于末端工具。
设置吸盘DO信号
该指令用于将Mech-Vision或Mech-Viz软件返回的DO列表设置到通用输出信号中。
该指令需在 MM_GET_DOLIST 之后被调用。 |
标定
该指令用于相机外参的自动标定。该指令如需使用请在 MM_Calibration() 程序中修改运行即可,该程序需配合 Mech-Vision 软件的相机标定工具,可以实现全自动标定,具体可以参见 YASKAWA自动标定 。
获取 Mech-Vision 自定义数据
将获取的 Mech-Vision 自定义输出数据保存至各变量
该指令用于将 Mech-Vision 返回的自定义输出数据结果转存到机器人指定的变量中,在触发 获取 Mech-Vision 自定义数据 指令之后使用。
获取视觉移动规划数据或自定义数据
该指令用于获取Mech-Vision工程的视觉移动规划数据,或者获取Mech-Viz工程的视觉移动规划数据或自定义数据。MM_GET_PLANPOSE可将获取的数据分配至各变量中。
参数说明
参数 | 描述 |
---|---|
输入参数 |
|
Resource |
该参数指定视觉移动规划数据的来源。
|
jpsPos |
预期的返回数据格式,详情参见以下说明。 |
输出参数 |
|
regPosNum |
I 变量号,用于保存接收到的路径点个数。 |
visPosNum |
I 变量号,用于保存第一个视觉移动在规划路径中的位置编号。 |
regStatus |
I 变量号,用于保存该指令返回的状态码。 |
-
当Resource为0时,jpsPos 参数取值范围为 1~4,具体说明如下。
jpsPos 参数值 预期的返回数据 说明(每个字段的具体解释参见下文) 1
位姿(JPs 形式), 移动类型, 末端工具编号, 速度, 自定义数据项 1, …, 自定义数据项 N
2
位姿(TCP 形式), 移动类型, 末端工具编号, 速度, 自定义数据项 1, …, 自定义数据项 N
3
位姿(JPs 形式), 移动类型, 末端工具编号, 速度, Mech-Viz视觉移动规划数据, 自定义数据项 1, …, 自定义数据项 N
4
位姿(TCP 形式), 移动类型, 末端工具编号, 速度, Mech-Viz视觉移动规划数据, 自定义数据项 1, …, 自定义数据项 N
-
当Resource为正整数时,jpsPos 参数取值范围为 1~2,具体说明如下。
jpsPos 参数值 预期的返回数据 说明(每个字段的具体解释参见下文) 1
位姿(JPs 形式), 移动类型, 末端工具编号, 速度, Mech-Vision视觉移动规划数据
2
位姿(TCP 形式), 移动类型, 末端工具编号, 速度, Mech-Vision视觉移动规划数据
位姿
路径点的位姿可以是机器人关节角(JPs,单位为度)或工具位姿(TCP,其中三维坐标单位为毫米,欧拉角单位为度),其形式取决于发送的指令参数。
移动类型
-
1:关节移动。
-
2:直线移动。
末端工具编号
路径点的末端工具编号。若值为-1,表示不使用末端工具。
速度
路径点的速度值。
视觉移动规划数据
Mech-Vision或Mech-Viz中“视觉移动”步骤规划的数据,包括被抓取工件的标签、已抓取的工件总数、本次抓取的工件数量、吸盘边角号、TCP偏移量、工件组朝向、单个工件朝向、工件组尺寸。
自定义数据项
当 Mech-Vision 工程中“输出”步骤的端口类型为“自定义”时,除 poses 和 labels 等之外其他自定义端口的数据。 各自定义数据按照端口名称的字母顺序(A—Z)排列。
将从MM_GET_PLANDATA获取的数据保存至各变量
该指令用在获取视觉移动规划数据或自定义数据指令后,用于将获取的数据存放到不同变量中。
参数说明
参数 | 描述 |
---|---|
输入参数 |
|
serial |
指定要转存第几个路径点。 |
输出参数 |
|
prNum |
P 变量号,用于保存指定的位姿数据。
|
brNum |
B 变量起始号,用于保存“移动类型”、“末端工具编号”、“速度”,设定时保证起始编号开始的连续三个变量不受其他因素影响。 |
rrNum |
R 变量起始号,用于保存视觉移动规划数据、自定义数据。当不是视觉移动路径点时,无需设定该参数。 在设定该参数时,注意变量总数量(视觉移动规划数据固定占用 21 个变量,自定义输出数据需根据具体情况计算),保证 R 变量有足够空间。 |
视觉移动规划数据的具体内容如下表所示。
数据 | 说明 | 占用的变量数 |
---|---|---|
被抓取工件的标签 |
由10个整数组成,默认为10个0 |
10 |
已抓取的工件总数 |
累计已抓取的工件数量 |
1 |
本次抓取的工件数量 |
本次抓取的工件数量 |
1 |
吸盘边角号 |
本次吸盘所使用的边角号 |
1 |
TCP偏移量 |
工件组中心相对于末端工具中心的XYZ偏移量 |
3 |
工件组朝向 |
工件组与吸盘长边的朝向关系,0表示平行,1表示垂直 |
1 |
单个工件朝向 |
单个工件长边与吸盘长边的朝向关系,0表示平行,1表示垂直 |
1 |
工件组尺寸 |
本次抓取的工件组的长宽高 |
3 |
获取 Mech-Vision “路径规划”步骤的结果
在启动 Mech-Vision 工程后,该指令用于获取 Mech-Vision 中“路径规划”步骤输出的免碰撞抓取路径。
在使用该指令时,Mech-Vision “输出”步骤的 端口类型 参数需要设置为“预定义(机器人路径)”。
参数说明
参数 | 描述 |
---|---|
输入参数 |
|
job |
Mech-Vision 工程编号,可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。 |
GetPos_Type |
指定“路径规划”步骤返回的路径点的位姿类型。
|
输出参数 |
|
Pos_Num |
I 变量,用于保存该指令返回的路径点个数。 |
VisPos_Num |
I 变量,用于保存路径规划工具中设置的“视觉移动”路径点在整个路径中的位置。 例如,如果规划路径由以下组成:“定点移动_1”,“定点移动_2”,“视觉移动”,“定点移动_3”,则“视觉移动”位置为 3。 如果路径中无“视觉移动”,则该参数值为 0。 |
MM_Status |
I 变量,用于保存该指令返回的状态码。 |
读取Mech-Viz步骤参数值
该指令用于读取Mech-Viz工程中指定的步骤参数值。
参数说明
参数 | 描述 |
---|---|
输入参数 |
|
Read_id |
该参数为property_config文件中指定的 配置编号 字段。 |
输出参数 |
|
Status |
I变量,用于保存该指令返回的状态码。 |
Viz_Prop |
I变量,用于保存返回的指定步骤的参数值,目前只支持返回INT整型值。 |
在Mech-Vision工具栏的 下,单击 属性配置,即可打开property_config文件。 |
在使用该指令前,用户需提前在property_config文件中指定步骤编号和参数名称对应的key名称,具体格式如下所示。
read, 配置编号, 步骤编号, key名称
read |
指定该行用于读取步骤参数值。 |
配置编号 |
指定一个唯一的编号,为正整数。一个配置编号只能用于读取一个步骤参数值。如果读取多个步骤参数值,请使用不同的配置编号。 |
步骤编号 |
指定将要读取的参数所属步骤的编号。 |
key名称 |
指定将要读取的参数名称对应的key名称。 |
|
property_config文件中可以设置多条read指令,但每条read指令的配置编号必须唯一。 |
设置Mech-Viz步骤参数值
该指令用于设置Mech-Viz工程中指定的步骤参数值。
参数说明
参数 | 描述 |
---|---|
输入参数 |
|
Write_id |
该参数为property_config文件中指定的 配置编号 字段。 |
输出参数 |
|
Status |
I变量,用于保存该指令返回的状态码。 |
在Mech-Vision工具栏的 下,单击 属性配置,即可打开property_config文件。 |
在使用该指令前,用户需提前在property_config文件中指定步骤编号、参数名称对应的key名称和参数值,具体格式如下所示。
write, 配置编号, 步骤编号, key名称, 参数值
write |
指定该行用于设置步骤参数值。 |
配置编号 |
指定一个编号(非唯一),为正整数。 |
步骤编号 |
指定将要设置的参数所属步骤的编号。 |
key名称 |
指定将要设置的参数名称对应的key名称。 |
参数值 |
指定将要设置的参数值。 |
|
示例
例如,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。
CALL JOB:MM_SET_PROPERTY("1;10")
该示例表示将xOffset、yOffset和zOffset对应的参数值分别设置为10、20和30,并将返回的状态码保存在I10变量中。