3.后处理器
有关后置处理器的更多资料,请浏览以下两个连结:

RoboDK配备了许多后置处理器,为许多机器人品牌(如ABB, Fanuc, KUKA, Motoman, UR,…)提供支持。后置处理器位于文件夹中:<代码类=”docutils literal notranslate">C: / RoboDK /文章/.每个Post Processor都是一个.py文件。你必须把<代码类=”docutils literal notranslate">py后置处理器文件<代码类=”docutils literal notranslate">C: / RoboDK /文章/使用已提供给您的后处理程序。要删除现有的后处理程序,只需删除相应的后处理程序即可<代码类=”docutils literal notranslate">py文件位于<代码类=”docutils literal notranslate">C: / RoboDK /文章/

例如,对于库卡机器人,可以使用以下后置处理器:
  • KUKA_KRC2:生成与KUKA KRC2控制器兼容的SRC程序文件。

  • 生成与KUKA KRC4控制器兼容的SRC程序文件。

  • 使用KUKA生成JAVA程序。日出平台,库卡IIWA机器人所需。

必须安装Python并与RoboDK一起工作才能正确使用后置处理器(如何安装).

遵循RoboDK中的以下步骤将机器人链接到特定的后处理器:
  1. 双击机器人打开机器人面板。

  2. 选择<代码类=”docutils literal notranslate">参数在右上角。

  3. 选择<代码类=”docutils literal notranslate">选择帖子处理器

或者,您可以右键单击某个程序,然后选择<代码类=”docutils literal notranslate">选择帖子处理器

_images / PostProcessorSelect.png”src=
修改或创建后处理程序:
  1. 选择<代码类=”docutils literal notranslate">增设/编辑帖子处理器

  2. 选择现有的后处理程序或创建一个新的后处理程序。如果您决定创建一个新的Post Processor,将提供一个类似本节中提供的示例的模板。

  3. 您可以使用文本编辑器或Python编辑器编辑Post Processor。

Python编辑器允许您在模块末尾给出一个示例程序来快速测试Post Processor。您还可以执行Post Processor文件,以查看它将生成的输出示例(双击<代码类=”docutils literal notranslate">py文件,或右键单击<代码类=”docutils literal notranslate">py文件,然后选择<代码类=”docutils literal notranslate">开放).

不使用RoboDK也可以手动编辑Post Processor:
  1. 进入文件夹<代码类=”docutils literal notranslate">C: / RoboDK /文章/然后打开相应的<代码类=”docutils literal notranslate">py使用文本编辑器(如Notepad或Python IDLE)创建文件(右键单击<代码类=”docutils literal notranslate">py然后,选择文件<代码类=”docutils literal notranslate">编辑闲置

  2. 进行必要的修改。

  3. 要预览结果:双击postprocessor来运行Post Processor<代码类=”docutils literal notranslate">py文件(或右键单击,然后选择<代码类=”docutils literal notranslate">开放,如下图所示)。

或者,您可以使用Python编辑器(如Python IDLE)运行并预览结果。

_images / PostProcessorPreview.png”src=

3.1.后处理器方法
samplepost。 RobotPost robotpost=没有一个robotname=没有一个robot_axes=6**kwargs
ProgStart progname
参数

prognamestr) -程序的名称

ProgFinish progname samplepost.RobotPost.ProgStart ()是执行。

提示: ProgFinish在程序完成所有指令后触发。

参数

prognamestr) -程序的名称

ProgSave 文件夹prognameask_user=show_result=
参数
  • 文件夹str) -保存程序的文件夹提示

  • prognamestr) -程序名称作为保存程序的提示

  • ask_user保龄球str)—如果RoboDK中的默认设置设置为提示用户选择文件夹,则为True

  • show_result保龄球str) - False如果RoboDK的默认设置设置为不显示程序一旦保存。否则,将提供一个字符串,其中包含首选文本编辑器的路径

ProgSendRobot robot_ipremote_pathftp_userftp_pass
参数
  • robot_ipstr) -机器人的IP地址

  • remote_pathstr) -机器人的远程路径

  • ftp_userstr) - FTP用户凭证

  • ftp_passstr) - FTP用户密码

MoveJ 构成关节conf_RLF=没有一个
参数
  • 构成robodk.robomath.Mat ()) -工具相对于参考系的姿态目标。如果目标被定义为联合目标,姿态可以为None

  • 关节浮动列表)——机器人关节作为列表

  • conf_RLFint列表) -机器人配置为3个整数列表:[REAR, LOWER-ARM, FLIP]。[0,0,0]表示[前,上臂和非翻转]配置

MoveL 构成关节conf_RLF=没有一个
参数
  • 构成robodk.robomath.Mat ()) -工具相对于参考系的姿态目标。如果目标被定义为联合目标,姿态可以为None

  • 关节浮动列表)——机器人关节作为列表

  • conf_RLFint列表) -机器人配置为3个整数列表:[REAR, LOWER-ARM, FLIP]。[0,0,0]表示[前,上臂和非翻转]配置

MoveC pose1joints1pose2joints2conf_RLF_1=没有一个conf_RLF_2=没有一个
参数
  • pose1robodk.robomath.Mat ()) -定义弧线(路径点)的点的姿态目标

  • pose2robodk.robomath.Mat ()) -弧线末端的姿态目标(最后一点)

  • joints1浮动列表) -航路点的机器人关节

  • joints2浮动列表)——机器人关节的最后一点

  • conf_RLF_1int列表) -航路点的机器人配置

  • conf_RLF_2int列表)——机器人构型的最后一点

setFrame 构成frame_id=没有一个frame_name=没有一个
参数
  • 构成robodk.robomath.Mat ()) -参考系相对于机器人基架的位姿

  • frame_idint没有一个) -参考帧的编号(如果可用)

  • frame_namestr) - RoboDK中定义的参考系名称

setTool 构成tool_id=没有一个tool_name=没有一个
参数
  • 构成robodk.robomath.Mat ()) - TCP帧相对于机器人基础框架的位姿

  • tool_idint没有一个) -参考帧的编号(如果可用)

  • tool_namestr) - RoboDK中定义的参考系名称

暂停 time_ms
参数

time_ms浮动) -暂停时间,以毫秒为单位

setSpeed speed_mms
参数

speed_mms浮动) -速度<我mg class="math" src="//www.sinclairbody.com/www/doc/en/PythonAPI/_images/math/6b8f91198c7c80fbb17ae885fe40f725fab78a49.svg" alt="毫米/秒”>

setAcceleration accel_mmss
参数

accel_mmss浮动) -速度<我mg class="math" src="//www.sinclairbody.com/www/doc/en/PythonAPI/_images/math/f4358b5dabd003f14451dcc35d051f60cd4f0c1d.svg" alt="毫米/秒^ 2”>

setSpeedJoints speed_degs
参数

speed_degs浮动) -速度<我mg class="math" src="//www.sinclairbody.com/www/doc/en/PythonAPI/_images/math/96d2273fb077de249ed1cad011d40ecb94078fd8.svg" alt="度/秒”>

setAccelerationJoints accel_degss
参数

accel_degss浮动) -速度<我mg class="math" src="//www.sinclairbody.com/www/doc/en/PythonAPI/_images/math/19e1a7c31e2cd2376253c0465e8e9c5fb61c2ef9.svg" alt="度/秒^ 2”>

setZoneData zone_mm
参数

zone_mm浮动) -舍入半径,单位为mm

setDO io_vario_value
参数
  • io_varintstr) -要设置的变量,以STR或int形式提供

  • io_valueint浮动str) -变量的值,以str、float或int形式提供

waitDI io_vario_valuetimeout_ms=-1
参数
  • io_varintstr) -等待的变量,以STR或int形式提供

  • io_valueint浮动str) -变量的值,以str、float或int形式提供

  • timeout_ms浮动int) -最大等待时间

RunCode 代码is_function_call=
参数
  • 代码str)——要调用的代码或过程

  • is_function_call保龄球) -如果提供的代码是要调用的特定函数,则为True

RunMessage 消息iscomment=
参数
  • 消息str) -在教学挂件上显示的消息或作为代码的注释

  • iscomment保龄球) -如果消息不需要显示在教学挂件上,而是作为代码的注释,则为True

addline 换行符
参数

换行符str) -要添加的新行。

addlog 换行符
参数

换行符str) -新线

3.2.后置处理器示例
样本后置处理器
RoboDK Inc. - //www.sinclairbody.com/版权所有#根据Apache许可证2.0版(“许可证”)进行许可;除非遵守许可,否则您不得使用此文件。您可以从以下网址获得许可证的副本# http://www.apache.org/licenses/license - 2.0除非适用法律要求或书面同意,软件在许可证下分发的是按“现状”分发的,无任何明示或暗示的保证或条件。#请参阅许可证,以了解具体的语言管理权限和许可证下的限制。# ----------------------------------------------------这个文件是一个示例POST PROCESSOR脚本来生成程序#与RoboDK的通用机器人#编辑/测试POST PROCESSOR脚本文件:选择“程序”->“添加/编辑后处理器”,然后选择你的文章或创建一个新的。您可以使用任何文本编辑器或Python编辑器编辑此文件。使用Python编辑器可以快速评估该文件末尾的示例程序。# Python应该与RoboDK一起自动安装#你也可以手动编辑POST处理器:# 1-使用Python IDLE打开*.py文件(右键单击-> Edit with IDLE)2 .做必要的改变# 3-运行文件打开Python Shell: Run -> Run模块(默认为F5)# 4-自动调用“test_post()”函数#或者,你可以使用文本编辑器编辑这个文件,然后用Python运行它#要使用POST PROCESSOR文件,你必须把*.py文件放在"C:/RoboDK/Posts/"目录下。要在RoboDK中为你的机器人选择一个特定的POST PROCESSOR,你必须遵循以下步骤:打开机器人面板(双击一个机器人)# 2-选择“参数”# 3-选择“解锁高级选项”# 4-在“Robot brand”框中选择你的帖子作为文件名##要删除现有的POST PROCESSOR脚本,只需删除这个文件(.py文件)## ----------------------------------------------------更多关于RoboDK后处理器和离线编程的信息:2022世界杯8强赛时间# //www.sinclairbody.com/help后处理程序# //www.sinclairbody.com/doc/PythonAPI/postprocessor.html# ----------------------------------------------------# ----------------------------------------------------#导入RoboDK工具robodk.robomath进口*robodk.robodialogs进口*robodk.robofileio进口*# ----------------------------------------------------defpose_2_str构成):"""根据控制器的语法/格式将机器人姿态目标转换为字符串。参数姿态:4x4姿态矩阵:type pose::meth: ' robodk.robomath.Mat ':返回:XYZWPR字符串的位置: rtype: str”“”xyzrpw=pose_2_xyzrpw构成返回“X% .3fY% .3fZ% .3fR% .3fP% .3fW% .3fxyzrpw))defjoints_2_str关节):"""根据控制器的语法/格式将机器人关节目标转换为字符串。参数关节:机器人关节列表:型接头:浮动列表:返回:J1-Jn字符串的联合格式: rtype: str”“”str=数据=“一个”“B”“C”' D '“E”“F”‘G’“H”“我”“J”“K”“L”范围len关节)):str=str+% s % .6f数据],关节)))str=str[:-1返回str# ----------------------------------------------------处理机器人指令/语法的对象类RobotPost对象):""" "机器人后处理器对象""" "#设置程序扩展PROG_EXT=“三”# --------------------------------------------------------#其他变量ROBOT_POST=ROBOT_NAME=PROG_FILES=[]掠夺=[]日志=nAxes=6def__init__自我robotpost=没有一个robotname=没有一个robot_axes=6**kwargs):"""创建一个新的后置处理器。:param robotpost:后置处理器的名称类型robotpost: STR:param robotname:机器人名称:类型robotname: STR:param robot_axes:机器人的轴数:type robot_axes: int”“”自我ROBOT_POST=robotpost自我ROBOT_NAME=robotname自我掠夺=[]自我日志=自我nAxes=robot_axesdefProgStart自我progname):"""启动一个给定名称的新程序。可以同时生成多个程序。* * * *:每次必须生成新程序时,都会触发ProgStart。:param programname:程序名程序名:STR”“”自我addline“PROC% s()的prognamedefProgFinish自我progname):执行此方法是为了定义程序或过程的结束。一个模块可以有多个程序。在另一个:meth: ' samplepost.RobotPost之前不会执行其他指令。执行“ProgStart”。* * * *:在程序的所有指令之后触发ProgFinish。:param programname:程序名程序名:STR”“”自我addline“ENDPROC”defProgSave自我文件夹prognameask_user=show_result=):"""保存程序。该方法在处理完所有程序后执行。* * * *:在执行完所有程序和指令后触发ProgSave。:param folder:保存程序的文件夹提示:类型文件夹:STR:param programname:程序名作为保存程序的提示程序名:STR:param ask_user:如果在RoboDK中设置了默认设置来提示用户选择文件夹,则为True类型ask_user: bool, STR:param show_result: False表示RoboDK默认设置为保存后不显示程序。否则,将提供一个字符串,其中包含首选文本编辑器的路径:类型show_result: bool, STR”“”progname=progname+“。”+自我PROG_EXT如果ask_userDirExists文件夹):filesave=getSaveFile文件夹progname“将程序另存为…”如果filesave没有一个filesave=filesave名字其他的返回其他的filesave=文件夹+' / '+progname#日本控制器需要shift_jis编解码器和替换错误,以避免在不支持的字符上抛出错误#with open(filesave, "w", encoding="shift_jis", errors="replace")作为fid:开放filesave“w”编码=“utf - 8”作为支撑材自我掠夺支撑材支撑材\ n打印保存:% s\ nfilesave#---------------------- show result如果show_result如果类型show_resultstr#打开文件与提供的应用程序进口子流程p=子流程Popen([show_resultfilesave])其他的#使用默认应用程序打开文件进口操作系统操作系统startfilefilesave如果len自我日志>0mbox程序生成日志:\ n \ n+自我日志defProgSendRobot自我robot_ipremote_pathftp_userftp_pass):"""使用提供的参数向机器人发送程序。这个方法在ProgSave之后执行,如果我们选择了“Send Program to Robot”选项。连接参数必须在RoboDK的机器人连接菜单中提供。:param robot_ip:机器人的IP地址:类型robot_ip: STR:param remote_path:机器人的远端路径:类型remote_path: STR参数ftp_user: FTP用户凭据:类型ftp_user: STR:参数ftp_pass: FTP用户密码:类型ftp_pass: STR”“”UploadFTP自我PROG_FILESrobot_ipremote_pathftp_userftp_passdefMoveJ自我构成关节conf_RLF=没有一个):"""定义一个关节运动。* * * *:MoveJ是由RoboDK指令Program->Move Joint instruction触发的。:参数姿态:工具相对于参考系的姿态目标。如果目标被定义为联合目标,姿态可以为None:type pose::meth: ' robodk.robomath.Mat '参数关节:机器人关节列表:型接头:浮动列表:param conf_RLF:机器人配置为3个int的列表:[REAR, LOWER-ARM, FLIP]。[0,0,0]表示[前,上臂和非翻转]配置:类型conf_RLF: int列表”“”自我addline“MOVJ”+joints_2_str关节))defMoveL自我构成关节conf_RLF=没有一个):"""定义线性运动。* * * *:移动是由RoboDK指令程序->移动线性指令触发的。:参数姿态:工具相对于参考系的姿态目标。如果目标被定义为联合目标,姿态可以为None:type pose::meth: ' robodk.robomath.Mat '参数关节:机器人关节列表:型接头:浮动列表:param conf_RLF:机器人配置为3个int的列表:[REAR, LOWER-ARM, FLIP]。[0,0,0]表示[前,上臂和非翻转]配置:类型conf_RLF: int列表”“”自我addline“MOVL”+pose_2_str构成))defMoveC自我pose1joints1pose2joints2conf_RLF_1=没有一个conf_RLF_2=没有一个):"""定义圆周运动。* * * *:MoveC是由RoboDK指令Program->Move Circular instruction触发的。:param pose1:定义圆弧(航路点)的点的姿态目标:type pos1::meth: ' robodk.robomath.Mat '参数pos2:圆弧末端的姿态目标(最后一点):type pose2::meth: ' robodk.robomath.Mat ':param joints1:航点的机器人关节类型joints1:浮点列表:参数joints2:机器人最后一点的关节类型joints2:浮点列表:param conf_RLF_1:路点的机器人配置:类型conf_RLF_1: int列表:param conf_RLF_2:最终点的机器人配置:类型conf_RLF_2: int列表”“”自我addline“MOVC”+pose_2_strpose1+' '+pose_2_strpose2))defsetFrame自我构成frame_id=没有一个frame_name=没有一个):""" "定义一个相对于机器人基架的新的参考系。这个参考系用于跟踪运动指令使用的姿态目标。* * * *:setFrame是由RoboDK指令Program->Set Reference Frame指令触发的。参数位姿:参考系相对于机器人基架的位姿:type pose::meth: ' robodk.robomath.Mat ':param frame_id:参考帧的编号(如果可用):类型frame_id: int,无:param frame_name: RoboDK中定义的参考帧名称:类型frame_name: STR”“”自我addline“BASE_FRAME”+pose_2_str构成))defsetTool自我构成tool_id=没有一个tool_name=没有一个):""" "改变机器人TCP(工具中心点)相对于机器人法兰。在笛卡尔坐标系中定义的任何运动都假定它使用所提供的最后一个参考系和工具架。* * * *:setTool是由RoboDK指令程序->设置工具框架指令触发的。:参数姿态:TCP帧相对于机器人基架的姿态:type pose::meth: ' robodk.robomath.Mat '参数tool_id:参考帧的编号(如果可用):类型tool_id: int,无:param tool_name: RoboDK中定义的参考帧名称:类型tool_name: STR”“”自我addline“TOOL_FRAME”+pose_2_str构成))def暂停自我time_ms):"""定义程序中的暂停(包括移动)。如果暂停必须引起机器人停止,直到用户希望继续程序,则Time_ms为负值。* * * *:暂停是由RoboDK指令程序->暂停指令触发的。:param time_ms:暂停时间,单位为毫秒:类型time_ms: float”“”如果time_ms<0自我addline“暂停”其他的自我addline”等% .3ftime_ms*0.001))defsetSpeed自我speed_mms):"""改变机器人速度(单位:mm/s)* * * *:setSpeed是由RoboDK指令Program->Set Speed指令触发的。参数:speed_mm: speed in:math: ' mm/s ':类型speed_mm:浮动”“”自我addlog'setSpeed not defined ' (% .2fmms) 'speed_mmsdefsetAcceleration自我accel_mmss):"""改变机器人的加速度(单位:mm/s2)* * * *:setAcceleration是由RoboDK指令Program->Set Speed instruction触发的。必须提供加速度值。:param acceler_mmss: speed in:math: ' mm/s^2 ':类型:accel_mmss: float”“”自我addlog'setAcceleration未定义'defsetSpeedJoints自我speed_degs):“”“改变机器人关节速度(以度/秒为单位)* * * *:setspeedjoint是由RoboDK指令Program->Set Speed instruction触发的。必须提供连接速度值。参数:speed_degs: speed in:math: ' deg/s ':类型speed_degs:浮动”“”自我addlog" setspeedjoint未定义"defsetAccelerationJoints自我accel_degss):“”“改变机器人关节加速度(单位为度/s2)* * * *:setaccelerationjoint是由RoboDK指令Program->Set Speed instruction触发的。必须提供关节加速度值。:param acceler_degss: speed in:math: ' deg/s^2 '类型:accel_degss: float”“”自我addlog' setaccelerationjointnot defined'defsetZoneData自我zone_mm):“”“改变平滑半径(也称为舍入,混合半径,CNT, APO或区域数据)。如果此参数较高,则有助于使移动更平滑* * * *:setZoneData是由RoboDK指令Program->Set舍入指令触发的。:参数zone_mm:舍入半径,单位为mm:type zone_mm: float”“”自我addlogsetZoneData not defined (% .1f毫米)”zone_mmdefsetDO自我io_vario_value):"""将变量(通常是数字输出)设置为给定值。此方法也可用于设置其他变量。* * * *:setDO是由RoboDK指令Program->Set or Wait I/O指令触发的。param io_var:要设置的变量,以STR或int类型提供:类型io_var: int, STR:param io_value:变量的值,以str、float或int形式提供:类型io_value: int, float, STR”“”如果类型io_var! =str#设置io_var为数字时的默认变量名io_var=出[% s]“strio_var如果类型io_value! =str#设置io_value为数字时的默认变量值如果io_value>0io_value=“真正的”其他的io_value=“假”#此时,io_var和io_value必须是字符串值自我addline% s=% sio_vario_value))defwaitDI自我io_vario_valuetimeout_ms= -1):等待变量(通常是数字输入)获得给定值io_value。此方法也可用于设置其他变量。可选地,可以提供超时。* * * *:waitDI是由RoboDK指令Program->Set或Wait I/O指令触发的。:param io_var:等待的变量,作为STR或int类型提供:类型io_var: int, STR:param io_value:变量的值,以str、float或int形式提供:类型io_value: int, float, STR:参数timeout_ms:最大等待时间:类型timeout_ms: float, int”“”如果类型io_var! =str#设置io_var为数字时的默认变量名io_var=”(% s]“strio_var如果类型io_value! =str#设置io_value为数字时的默认变量值如果io_value>0io_value=“真正的”其他的io_value=“假”#此时,io_var和io_value必须是字符串值如果timeout_ms<0自我addline的等待% s= =% sio_vario_value))其他的自我addline的等待% s= =% sTIMEOUT =% .1fio_vario_valuetimeout_ms))defRunCode自我代码is_function_call=):"""添加代码或函数调用。* * * *:RunCode是由RoboDK指令程序->函数调用指令触发的。参数代码:要调用的代码或过程:param is_function_call:如果提供的代码是要调用的特定函数,则为True:类型代码:STR:类型is_function_call: bool”“”如果is_function_call代码取代' '“_”如果代码endswith“)”):代码=代码+“()”自我addline代码其他的自我addline代码defRunMessage自我消息iscomment=):"""在机器人控制器屏幕显示消息(教学挂件)* * * *:RunMessage是由RoboDK指令Program->Show Message instruction触发的。参数message:要显示在教学挂件上或作为代码注释的消息:类型消息:STR:param iscomment:如果消息不需要显示在教学挂件上,而是作为代码的注释显示,则为True:类型iscomment: bool”“”如果iscomment自我addline“%”+消息其他的#自我。addlog('显示未实现的教学挂件上的消息(%s)' % message)自我addline'%显示消息:'+消息# ------------------ 私人  ----------------------defaddline自我换行符):“”“添加一个新的程序行。这是一个仅由其他方法使用的私有方法。:param newline:添加新行。:type newline: STR”“”自我掠夺附加换行符defaddlog自我换行符):"""向日志中添加一条消息。这是一个仅由其他方法使用的私有方法。程序生成时显示日志,以显示机器人程序生成时出现的任何问题。:param newline:换行:type newline: STR”“”自我日志=自我日志+换行符+\ n# -------------------------------------------------# ------------ 出于测试目的  ---------------deftest_post():用一个简单的程序测试后置处理器robodk.robomath进口PosePP作为pr=RobotPost()rProgStart“程序”rRunMessageRoboDK使用自定义后置处理器生成的程序真正的rsetFramep807.766544-963.69989841.478944000))rsetToolp62.5-108.253175One hundred.-60900))rMoveJp2002005001800180),-46.18419-6.77518-20.5492571.3867449.58727-302.54752])rMoveLp200250348.7345751800-150),-41.62707-8.89064-30.0180960.6232949.66749-258.98418])rMoveLp200200262.1320341800-150),-43.73892-3.91728-35.7793558.5756654.11615-253.81122])rRunMessage“打开空气阀1”rRunCode“TCP_On”真正的r暂停1000rMoveLp200250348.7345751800-150),-41.62707-8.89064-30.0180960.6232949.66749-258.98418])rMoveLp250300278.0238971800-150),-37.52588-6.32628-34.5969353.5252549.24426-251.44677])rMoveLp250250191.4213561800-150),-39.75778-1.04537-40.3788352.0911854.15317-246.94403])rRunMessage“关闭空气阀”rRunCode“TCP_Off”真正的r暂停1000rMoveLp250300278.0238971800-150),-37.52588-6.32628-34.5969353.5252549.24426-251.44677])rMoveLp250200278.0238971800-150),-41.85389-1.95619-34.8915457.4391252.34162-253.73403])rMoveLp250150191.4213561800-150),-43.821113.29703-40.2949356.0240256.61169-249.23532])rMoveJ没有一个-46.18419-6.77518-20.5492571.3867449.58727-302.54752])rProgFinish“程序”# robot.ProgSave(“。”,“计划”,真的)r掠夺打印如果lenr日志>0mbox程序生成日志:\ n \ n+r日志输入“按Enter键关闭…”如果__name__= =“__main__”"""模块自己执行时调用的过程:test_post()"”“test_post()

3.3.后置处理器示例输出
Weld_Hexagon。型号为ABB IRC5机器人
模块MOD_Weld_Hexagon珀耳斯wobjdata rdkWObj: =(假的,真的,”,[(0,0,0),[1 0 0,0]],[[0,0,0),[1 0 0,0]];珀耳斯tooldata rdkTool: =(真的,[[0,0,0),[1 0 0,0]],[3 [0,0200][1,0,0,0),0,0,0.005]];VAR speeddata:= [500,500,500,500];VAR extjoint rdkExtax:= [9E9,9E9,9E9,9E9,9E9];PROC Weld_Hexagon() !由RoboDK生成的ABB IRB 1600ID-4/1.5程序(29/11/2014 17:42:31)ConfL \;rdkWObj.oframe: = (0, 0, 0), (1, 0, 0, 0);rdkWObj.uframe: = (0, 0, 0), (1, 0, 0, 0);rdkTool.tframe: = (0371 3), [0.92387953, 0, 0.38268343, 0];MoveAbsJ [[-0,-19.143793,-7.978668,0,49.189506,-0]],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; MoveJ [[1010.634,-114.491,662.29],[0,0,1,0],[-1,0,-1,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; WeldStart; MoveL [[810.634,-114.491,662.29],[0,0,1,0],[-1,0,-1,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; MoveL [[910.634,58.715,662.29],[0,0,1,0],[0,-1,0,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; MoveL [[1110.634,58.715,662.29],[0,0,1,0],[0,-1,0,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; MoveL [[1210.634,-114.491,662.29],[0,0,1,0],[-1,0,-1,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; MoveL [[1110.634,-287.696,662.29],[0,0,1,0],[-1,0,-1,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; MoveL [[910.634,-287.696,662.29],[0,0,1,0],[-1,0,-1,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; MoveL [[810.634,-114.491,662.29],[0,0,1,0],[-1,0,-1,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; WeldStop; MoveL [[1010.634,-114.491,662.29],[0,0,1,0],[-1,0,-1,0],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; MoveAbsJ [[-0,-19.143793,-7.978668,0,49.189506,-0]],rdkExtax], rdkSpeed, rdkZone, rdkTool, \WObj:=rdkWObj; ConfJ \On; ConfL \On; ENDPROC ENDMODULE