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

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

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

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

  • KUKA_IIWA:使用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的情况下手动编辑后处理器:
  1. 打开文件夹<代码类="docutils literal notranslate">C: / RoboDK /文章/打开相应的<代码类="docutils literal notranslate">py文件的文本编辑器,如记事本或Python IDLE(右击<代码类="docutils literal notranslate">py文件,然后选择<代码类="docutils literal notranslate">编辑闲置

  2. 进行必要的修改。

  3. 要获得结果的预览:通过双击<代码类="docutils literal notranslate">py文件(或右击,然后选择<代码类="docutils literal notranslate">开放,如下图所示)

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

_images / PostProcessorPreview.png"src=

3.1.后处理方法
samplepost。 RobotPost robotpost没有一个,robotname没有一个,robot_axes6,**kwargs
ProgStart progname
参数

prognamestr) -程序名称

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

提示: ProgFinish在程序的所有指令结束后触发。

参数

prognamestr) -程序名称

ProgSave 文件夹,progname,ask_user,show_result
参数
  • 文件夹str) -文件夹提示保存程序

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

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

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

ProgSendRobot robot_ip,remote_path,ftp_user,ftp_pass
参数
  • robot_ipstr) -机器人的IP地址

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

  • ftp_userstr) - FTP用户凭证

  • ftp_passstr) - FTP用户密码

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

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

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

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

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

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

MoveC pose1,joints1,pose2,joints2,conf_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.w5838.com/doc/en/PythonAPI/_images/math/6b8f91198c7c80fbb17ae885fe40f725fab78a49.svg" alt="毫米/秒">

setAcceleration accel_mmss
参数

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

setSpeedJoints speed_degs
参数

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

setAccelerationJoints accel_degss
参数

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

setZoneData zone_mm
参数

zone_mm浮动) -舍入半径(单位:mm)

setDO io_var,io_value
参数
  • io_varint,str) -要设置的变量,以STR或int形式提供

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

waitDI io_var,io_value,timeout_ms-1
参数
  • io_varint,str) -等待的变量,以STR或int形式提供

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

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

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

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

RunMessage 消息,iscomment
参数
  • 消息str) -消息显示在teach挂坠或作为代码的注释

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

addline 换行符
参数

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

addlog 换行符
参数

换行符str) -新行

3.2.后处理器示例
样本后置处理器
版权所有2015-2021 - RoboDK Inc. - //www.w5838.com/#根据Apache许可证2.0版(“许可证”)授权;#您不能使用此文件,除非符合许可证。#您可以在此处获得许可证副本# http://www.apache.org/licenses/license - 2.0除非适用法律要求或书面同意,软件#在许可下发布的是“AS is”基础上发布的,没有任何明示或暗示的保证或条件。#请参阅许可证以了解具体的语言管理权限和#许可下的限制。# ----------------------------------------------------这个文件是一个生成程序的POST PROCESSOR脚本示例#使用RoboDK的通用机器人编辑/测试这个POST PROCESSOR脚本文件:#选择“程序”->“添加/编辑文章处理器”,然后选择你的文章或创建一个新的。您可以使用任何文本编辑器或Python编辑器编辑此文件。使用Python编辑器可以快速计算文件末尾的示例程序。# Python应该与RoboDK一起自动安装#你也可以手动编辑POST PROCESSOR:# 1-用Python IDLE打开*.py文件(右击-> Edit with IDLE)# 2-做出必要的改变运行文件打开Python Shell: Run ->运行模块(默认为F5)# 4-自动调用"test_post()"函数#或者,您可以使用文本编辑器编辑此文件并使用Python运行它要使用POST PROCESSOR文件,必须将*.py文件放在“C:/RoboDK/Posts/”在RoboDK中为你的机器人选择一个特定的后置处理器,你必须遵循以下步骤:打开机器人面板(双击一个机器人)# 2-选择“参数”3-选择“解锁高级选项”# 4-在“Robot brand”框中选择你的帖子作为文件名要删除现有的POST PROCESSOR脚本,只需删除这个文件(.py文件)# ----------------------------------------------------更多关于RoboDK后处理器和离线编程的信息:# http://www.www.w5838.com/help后处理程序# http://www.www.w5838.com/doc/PythonAPI/postprocessor.html# ----------------------------------------------------# ----------------------------------------------------#导入RoboDK工具robodk.robomath进口robodk.robodialogs进口robodk.robofileio进口# ----------------------------------------------------defpose_2_str构成):"""根据控制器的语法/格式将机器人姿态目标转换为字符串。:param pose: 4x4姿态矩阵:type pose::meth: ' robodk.robomath.Mat ':return:位置为XYZWPR字符串: rtype: str”“”x,y,z,r,p,wpose_2_xyzrpw构成返回“X% .3fY% .3fZ% .3fR% .3fP% .3fW% .3fx,y,z,r,p,w))defjoints_2_str关节):"""根据控制器的语法/格式将机器人关节目标转换为字符串。:param关节:作为列表的机器人关节:类型关节:浮动列表:return:关节格式为J1-Jn字符串: rtype: str”“”str数据“一个”,“B”,“C”,' D ',“E”,“F”,‘G’,“H”,“我”,“J”,“K”,“L”范围len关节)):strstr+% s % .6f数据],关节)))strstr[:-1返回str# ----------------------------------------------------#处理机器人指令/语法的对象类RobotPost对象):"""机器人后处理器对象""" "#设置程序扩展名PROG_EXT“三”# --------------------------------------------------------#其他变量ROBOT_POSTROBOT_NAMEPROG_FILES[]掠夺[]日志nAxes6def__init__自我,robotpost没有一个,robotname没有一个,robot_axes6,**kwargs):"""创建一个新的后处理器。:param robotpost:后置处理器名称:类型robotpost: STR:param robotname:机器人名:type roboname: STR:param robot_axes:机器人的轴数:类型robot_axes: int”“”自我ROBOT_POSTrobotpost自我ROBOT_NAMErobotname自我掠夺[]自我日志自我nAxesrobot_axesdefProgStart自我,progname):"""启动一个指定名称的新程序。可以同时生成多个程序。* * * *:每次必须生成一个新程序时都会触发ProgStart。:param progname:程序名:类型progname: STR”“”自我addline“PROC% s()的prognamedefProgFinish自我,progname):此方法用于定义程序或过程的结束。一个模块可以有多个程序。在另一个指令:meth:`samplepost.RobotPost。执行ProgStart。* * * *:ProgFinish在程序的所有指令之后被触发。:param progname:程序名:类型progname: STR”“”自我addline“ENDPROC”defProgSave自我,文件夹,progname,ask_user,show_result):"""保存程序。此方法在处理完所有程序后执行。* * * *:ProgSave在所有程序和指令执行完毕后触发。:param folder:保存程序的文件夹提示:type文件夹:STR:param progname:程序名,提示保存程序:类型progname: STR:param ask_user:如果RoboDK的默认设置设置为提示用户选择文件夹,则为True:类型ask_user: bool, STR:param show_result:如果RoboDK的默认设置设置为保存后不显示程序,则为False。否则,将提供具有首选文本编辑器路径的字符串:类型show_result: bool, STR”“”prognameprogname+“。”+自我PROG_EXT如果ask_userDirExists文件夹):filesavegetSaveFile文件夹,progname,“另存程序为……”如果filesave没有一个filesavefilesave的名字其他的返回其他的filesave文件夹+' / '+progname#日本控制器需要shift_jis编解码器和replace错误,以避免在不支持的字符上抛出错误#with open(filesave, "w", encoding="shift_jis", errors="replace") as fid:开放filesave,“w”,编码“utf - 8”作为支撑材自我掠夺支撑材支撑材\ n打印保存:% s\ nfilesave#----------------------显示结果如果show_result如果类型show_resultstr使用提供的应用程序打开文件进口子流程p子流程Popen([show_result,filesave])其他的使用默认应用程序打开文件进口操作系统操作系统startfilefilesave如果len自我日志>0mbox'程序生成日志:\ n \ n+自我日志defProgSendRobot自我,robot_ip,remote_path,ftp_user,ftp_pass):"""用提供的参数给机器人发送一个程序。如果我们选择了“Send Program to Robot”选项,这个方法会在ProgSave之后执行。连接参数必须在RoboDK的机器人连接菜单中提供。:param robot_ip:机器人IP地址:type robot_ip: STR:param remote_path:机器人远端路径:type remote_path: STR:param ftp_user: FTP用户证书:类型ftp_user: STR:param ftp_pass: FTP用户密码:类型ftp_pass: STR”“”UploadFTP自我PROG_FILES,robot_ip,remote_path,ftp_user,ftp_passdefMoveJ自我,构成,关节,conf_RLF没有一个):"""定义关节运动。* * * *:MoveJ由RoboDK指令Program->Move Joint instruction触发。:param pose:工具相对于参考系的姿态目标。如果目标被定义为联合目标,则Pose可以为None:type pose::meth: ' robodk.robomath.Mat ':param关节:作为列表的机器人关节:类型关节:浮动列表:param conf_RLF:机器人配置为3个整数的列表:[REAR, LOWER-ARM, FLIP]。[0,0,0]表示[前、上臂和非翻转]配置:类型conf_RLF: int列表”“”自我addline“MOVJ”+joints_2_str关节))defMoveL自我,构成,关节,conf_RLF没有一个):"""定义线性运动。* * * *:MoveL由RoboDK指令Program->Move线性指令触发。:param pose:工具相对于参考系的姿态目标。如果目标被定义为联合目标,则Pose可以为None:type pose::meth: ' robodk.robomath.Mat ':param关节:作为列表的机器人关节:类型关节:浮动列表:param conf_RLF:机器人配置为3个整数的列表:[REAR, LOWER-ARM, FLIP]。[0,0,0]表示[前、上臂和非翻转]配置:类型conf_RLF: int列表”“”自我addline“MOVL”+pose_2_str构成))defMoveC自我,pose1,joints1,pose2,joints2,conf_RLF_1没有一个,conf_RLF_2没有一个):"""定义圆周运动。* * * *:MoveC由RoboDK指令Program->Move Circular instruction触发。:param pose1:定义一个弧的点的姿态目标(路点):type pose1::meth: ' robodk.robomath.Mat ':param pose2:弧形末端的姿态目标(最终点):type pose2::meth: ' robodk.robomath.Mat ':param joints1:路径点的机器人关节:类型joints1:浮动列表:param 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 instruction触发。:param pose:参考坐标系相对于机器人基本坐标系的姿态: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指令Program->Set Tool Frame instruction触发。:param pose: TCP帧相对于机器人基帧的姿态:type pose::meth: ' robodk.robomath.Mat ':param tool_id:参考系编号(如果可用):type tool_id: int,无:param tool_name: RoboDK中定义的参考系名称:类型tool_name: STR”“”自我addline“TOOL_FRAME”+pose_2_str构成))def暂停自我,time_ms):"""定义程序中的暂停(包括移动)。如果暂停必须触发机器人停止,直到用户希望继续执行程序,则Time_ms为负值。* * * *:暂停是由RoboDK指令Program->Pause instruction触发的。:param time_ms:暂停时间,单位为毫秒:type time_ms: float”“”如果time_ms<0自我addline“暂停”其他的自我addline”等% .3ftime_ms0.001))defsetSpeed自我,speed_mms):改变机器人速度(单位:mm/s)* * * *:setSpeed由RoboDK指令Program->Set Speed instruction触发。:param speed_mms: speed in:math: ' mm/s ':类型speed_mms: float”“”自我addlog没有定义setSpeed (% .2fmms) 'speed_mmsdefsetAcceleration自我,accel_mmss):改变机器人加速度(单位:mm/s2)* * * *:setAcceleration由RoboDK指令Program->Set Speed instruction触发。必须提供加速度值。:参数acceler_mmss: speed in:math: ' mm/s^2 ':类型accel_mmss: float”“”自我addlogsetAcceleration未定义defsetSpeedJoints自我,speed_degs):改变机器人关节速度(单位:deg/s)* * * *:setspeed关节由RoboDK指令Program->Set Speed instruction触发。必须提供关节速度值。:param speed_degs: speed in:math: ' deg/s ':类型speed_degs:浮动”“”自我addlog' setspeed关节未定义'defsetAccelerationJoints自我,accel_degss):改变机器人关节加速度(单位:deg/s2)* * * *:setacceleration关节由RoboDK指令Program->Set Speed instruction触发。必须提供关节加速度值。:参数acceler_degss: speed in:math: ' deg/s^2 ':类型accel_degss:浮动”“”自我addlogsetacceleration关节未定义defsetZoneData自我,zone_mm):"""更改平滑半径(也称为舍入、混合半径、CNT、APO或区域数据)。如果这个参数更高,它有助于使移动更流畅* * * *:setZoneData由RoboDK指令Program->Set舍入指令触发。:param zone_mm:舍入半径,单位为mm:类型zone_mm: float”“”自我addlog'setZoneData未定义(% .1f毫米)”zone_mmdefsetDO自我,io_var,io_value):"""将一个变量(通常是数字输出)设置为给定值。此方法也可用于设置其他变量。* * * *:setDO由RoboDK指令Program->Set or Wait I/O instruction触发。: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_var,io_value))defwaitDI自我,io_var,io_value,timeout_ms= -1):"""等待变量(通常是数字输入)获得给定值io_value。此方法也可用于设置其他变量。可以选择提供一个超时。* * * *:waitDI由RoboDK指令Program->Set or Wait I/O instruction触发。:param io_var:等待的变量,以STR或int形式提供:类型io_var: int, STR:param io_value:变量的值,以str, float或int形式提供:类型io_value: int, float, STR:param 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_var,io_value))其他的自我addline的等待% s= =% sTIMEOUT =% .1fio_var,io_value,timeout_ms))defRunCode自我,代码,is_function_call):"""添加代码或函数调用。* * * *:RunCode由RoboDK指令Program->函数调用指令触发。:param code:要调用的代码或过程:param is_function_call:如果所提供的代码是要调用的特定函数,则为True:类型代码:STR:类型is_function_call: bool”“”如果is_function_call代码取代' ',“_”如果代码endswith“)”):代码代码+“()”自我addline代码其他的自我addline代码defRunMessage自我,消息,iscomment):机器人控制器屏幕显示一条信息(教挂件)* * * *:RunMessage由RoboDK指令Program->Show Message instruction触发。:param message:显示在teach挂坠上或作为代码注释的消息:type消息:STR:param iscomment:如果消息不需要显示在teach挂坠上,而是作为代码的注释显示,则为True:类型iscomment: bool”“”如果iscomment自我addline“%”+消息其他的#自我。addlog('显示在教挂坠上的消息未实现(%s)' %消息)自我addline显示消息:+消息# ------------------ 私人  ----------------------defaddline自我,换行符):"""添加新的程序行。这是一个私有方法,仅供其他方法使用。:param newline:要添加的新行。:换行符:STR”“”自我掠夺附加换行符defaddlog自我,换行符):"""向日志中添加一条消息。这是一个私有方法,仅供其他方法使用。生成程序时将显示日志,以显示生成机器人程序时的任何问题。:param newline:换行:换行符:STR”“”自我日志自我日志+换行符+\ n# -------------------------------------------------# ------------ 出于测试目的  ---------------deftest_post():"""用一个简单程序测试后处理器""" "robodk.robomath进口PosePP作为prRobotPost()rProgStart“程序”rRunMessage由RoboDK使用自定义后处理器生成的程序,真正的rsetFramep807.766544,-963.699898,41.478944,0,0,0))rsetToolp62.5,-108.253175,One hundred.,-60,90,0))rMoveJp200,200,500,180,0,180),-46.18419,-6.77518,-20.54925,71.38674,49.58727,-302.54752])rMoveLp200,250,348.734575,180,0,-150),-41.62707,-8.89064,-30.01809,60.62329,49.66749,-258.98418])rMoveLp200,200,262.132034,180,0,-150),-43.73892,-3.91728,-35.77935,58.57566,54.11615,-253.81122])rRunMessage“开启风阀1”rRunCode“TCP_On”,真正的r暂停1000rMoveLp200,250,348.734575,180,0,-150),-41.62707,-8.89064,-30.01809,60.62329,49.66749,-258.98418])rMoveLp250,300,278.023897,180,0,-150),-37.52588,-6.32628,-34.59693,53.52525,49.24426,-251.44677])rMoveLp250,250,191.421356,180,0,-150),-39.75778,-1.04537,-40.37883,52.09118,54.15317,-246.94403])rRunMessage“关闭空气阀”rRunCode“TCP_Off”,真正的r暂停1000rMoveLp250,300,278.023897,180,0,-150),-37.52588,-6.32628,-34.59693,53.52525,49.24426,-251.44677])rMoveLp250,200,278.023897,180,0,-150),-41.85389,-1.95619,-34.89154,57.43912,52.34162,-253.73403])rMoveLp250,150,191.421356,180,0,-150),-43.82111,3.29703,-40.29493,56.02402,56.61169,-249.23532])rMoveJ没有一个,-46.18419,-6.77518,-20.54925,71.38674,49.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
模块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 rdkSpeed:= [500,500,500,500];VAR extjoint rdkExtax:= [9E9,9E9,9E9,9E9,9E9,9E9];PROC Weld_Hexagon() !程序生成的RoboDK为ABB IRB 1600ID-4/1.5在29/11/2014 17:42:31 ConfJ \ on;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