数控车床宏程序编程_第1页
数控车床宏程序编程_第2页
数控车床宏程序编程_第3页
数控车床宏程序编程_第4页
数控车床宏程序编程_第5页
已阅读5页,还剩28页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数控宏程序什么是宏程序什么是数控加工宏程序简单地说,宏程序是一种具有计算能力和决策能力的数控程序。宏程序具有如下些特点:使用了变量或表达式(计算能力),例如:G01X[3+5];有表达式3+5G00X4F[#1];有变量#1G01Y[50*SIN[3]];有函数运算使用了程序流程控制(决策能力),例如:(1)IF#3GE9;有选择执行命令ENDIF(2)WHILE#1LT#4*5;有条件循环命令ENDW用宏程编程有什么好处宏程序引入了变量和表达式,还有函数功能,具有实时动态计算能力,可以加工非圆曲线,如抛物线、椭圆、双曲线、三角函数曲线等;宏程序可以完成图形一样,尺寸不同的系列零件加工;宏程序可以完成工艺路径一样,位置不同的系列零件加工;宏程序具有一定决策能力,能根据条件选择性地执行某些部分;使用宏程序能极大地简化编程,精简程序。适合于复杂零件加工的编程。一.宏变量及宏常量宏变量先看一段简单的程序:G00上面的程序在X轴作一个快速定位。其中数据是固定的,引入变量后可以写成:#1=;#1是一个变量G00X[#1];#1就是一个变量宏程序中,用“#”号后面紧跟1〜4位数字表示一个变量,如#1,#50,#101,……c变量有什么用呢变量可以用来代替程序中的数据,如尺寸、刀补号、G指令编号……,变量的使用,给程序的设计带来了极大的灵活性。使用变量前,变量必需带有正确的值。如#1=25G01X[#1];表示G01X25#1=-10;运行过程中可以随时改变#1的值G01X[#1];表示G01X-10用变量不仅可以表示坐标,还可以表示G、M、F、D、H、M、X、Y、……等各种代码后的数字。如:#2=3G[#2]X30;表示G03X30例1使用了变量的宏子程序。%1000#50=20;先给变量赋值M98P1001M98P1001;然后调用子程序#50=350;重新赋值M98P1001;再调用子程序M30%1001G91G01X[#50];同样一段程序,#50的值不同,X移动的距离就不同M99局部变量#50=350;重新赋值编号#0-#49的变量是局部变量。局部变量的作用范围是当前程序(在同一个程序号内)。如果在主程序或不同子程序里,出现了相同名称(编号)的变量,它们不会相互干扰,值也可以不同。例%100N10#3=30;主程序中#3为30M98P101;进入子程序后#3不受影响#4=#3;#3仍为30,所以#4=30M30%101#4=#3;这里的#3不是主程序中的#3,所以#3=0(没定义),则:#4=0#3=18;这里使#3的值为18,不会影响主程序中的#3M99全局变量编号#50〜#199的变量是全局变量(注:其中#100~#199也是刀补变量)。全局变量的作用范围是整个零件程序。不管是主程序还是子程序,只要名称(编号)相同就是同一个变量,带有相同的值,在某个地方修改它的值,所有其它地方都受影响。例%100N10#50=30;先使#50为30M98P101;进入子程序#4=#50;#50变为18,所以#4=18M30%101#4=#50;#50的值在子程序里也有效,所以#4=30#50=18;这里使#50=18,然后返回M99为什么要把变量分为局部变量和全局变量如果只有全局变量,由变量名不能重复,就可能造成变量名不够用;全局变量在任何地方都可以改变它的值,这是它的优点,也是它的缺点。说是优点,是因为参数传递很方便;说是缺点,是因为当一个程序较复杂的时候,一不小心就可能在某个地用了相同的变量名或者改变了它的值,造成程序混乱。局部变量的使用,解决了同名变量冲突的问题,编写子程序时,不需要考虑其它地方是否用过某个变量名。什么时候用全局变量什么时候用局部变量在一般情况下,你应优先考虑选用局部变量。局部变量在不同的子程序里,可以重复使用,不会互相干扰。如果一个数据在主程序和子程序里都要用到,就要考虑用全局变量。用全局变量来保存数据,可以在不同子程序间传递、共享、以及反复利用。刀补变量(#100~#199)。这些变量里存放的数据可以作为刀具半径或长度补偿值来使用。如#100=8;D100就是指加载#100的值8作为刀补半径。G41D100注意:;D100就是指加载#100的值8作为刀补半径。上面的程序中,如果把D100写成了D[#100],则相当于D8,即调用8号刀补,而不是补偿量为8。系统变量#300以上的变量是系统变量。系统变量是具有特殊意义的变量,它们是数控系统内部定义好了的,你不可以改变它们的用途。系统变量是全局变量,使用时可以直接调用。#0~#599是可读写的,#600以上的变量是只读的,不能直接修改。其中,#300〜#599是子程序局部变量缓存区。这些变量在一般情况下,不用关心它的存在,也不推荐你去使用它们。要注意同一个子程序,被调用的层级不同时,对应的系统变量也是不同的。#600~#899是与刀具相关系统变量。#1000~#1039坐标相关系统变量。#1040〜#1143参考点相关系统变量。#1144〜#1194系统状态相关系统变量。(详见:)有时候需要判断系统的某个状态,以便程序作相应的处理,就要用到系统变量。常量PI表示圆周率,TRUE条件成立(真),FALSE条件不成立(假)。二.运算符与表达式1.算术运算符加+,减-,乘*,除/条件运算符宏程序运算符EQNEGTGELTLE数学意义=丰〉NVW条件运算符用在程序流程控制IF和WHILE的条件表达式中,作为判断两个表达式大小关系的连接符。注意:宏程序条件运算符与计算机编程语言的条件运算符表达习惯不同。逻辑运算符在IF或WHILE语句中,如果有多个条件,用逻辑运算符来连接多个条件。AND(且)多个条件同时成立才成立OR(或)多个条件只要有一个成立即可NOT(非)取反(如果不是)例#1LT50AND#1GT20——表示:[#1<50〕且[#1>20]#3EQ8OR#4LE10——表示:[#3=8]或者[#4W10]有多个逻辑运算符时,可以用方括号来表示结合顺序,如:NOT[#1LT50AND#1GT20]——表示:如果不是“#1<50且#1>20”更复杂的例子,如:[#1LT50]AND[#2GT20OR#3EQ8]AND[#4LE10]函数正弦:SIN[a]余弦:COS[a]正切:TAN[a]注:a为角度,单位是弧度值。反正切:ATAN[a](返回:度,范围:-90〜+90)反正切:ATAN2[a]/[b](返回:度,范围:-180〜+180)(注:华中数控暂不支持)绝对值:ABS[a],表示|a|取整:INT[a],采用去尾取整,非“四舍五入”取符号:SIGN[a],a为正数返回1,0返回0,负数返回-1开平方:SQRT[a],表示V5指数:EXP[a],表示ea表达式与括号包含运算符或函数的算式就是表达式。表达式里用方括号来表示运算顺序。宏程序中不用圆括号,因圆括号是注释符。例如175/SQRT[2]*COS[55*PI/180]#3*6GT14运算符的优先级方括号一函数一乘除一加减一条件一逻辑技巧:常用方括号来控制运算顺序,更容易阅读和理解。赋值号=把常数或表达式的值送给一个宏变量称为赋值,格式如下:宏变量=常数或表达式例如#2=175/SQRT[2]*COS[55*PI/180]#3=#50=#3+12特别注意,赋值号后面的表达式里可以包含变量自身,如:#1=#1+4;此式表示把#1的值与4相加,结果赋给#1。这不是数学中的方程或等式,如果#1的值是2,执行#1=#1+4后,#1的值变为6。程序流程控制程序流程控制形式有许多种,都是通过判断某个“条件”是否成立来决定程序走向的。所谓“条件”,通常是对变量或变量表达式的值进行大小判断的式子,称为“条件表达式”。华中数控系统有两种流程控制命令:IF——ENDIF,WHILE——ENDW。1.条件分支IF需要选择性地执行程序,就要用IF命令。格式1:(条件成立则执行)IF条件表达式

条件成立执行的语句组ENDIF功能:条件成立执行IF与ENDIF之间的程序,不成立就跳过。其中IF、ENDIF称为关键词,不区分大小写。IF为开始标识,ENDIF为结束标识。IF语句的执行流程如图1所示。例:IF#1EQ10;如果#1=10M99;成立则,执行此句(子程返回)ENDIF;条件不成立,跳到此句后面例:IF#1LT10AND#1GT0;如果#1<10且#1>0G01x20;成立则执行Y15ENDIF;条件不成立,跳到此句后面G91G01X35F200ENDIF格式2:(二选一,选择执行)形式:G91G01X35F200ENDIFIF条件表达式条件成立执行的语句组ELSE条件不成立执行的语句组ENDIF例:IF#51LT20G91G01X10F250ELSE功能:条件成立执行IF与ELSE之间的程序,不成立就执行ELSE与ENDIF之间的程序。IF语句的执行流程如图1所示。2.条件循环WHILE格式:WHILE条件表达式条件成立循环执行的语句ENDW功能:条件成立执行WHILE与ENDW之间的程序,然后返回到WHILE再次判断条件,直到条件不成立才跳到ENDW后面oWHILE语句的执行流程如图1所示。例:#2=30WHILE#2GT0;如果#2>0G91G01X10;成立就执行#2=#2-3;修改变量,ENDW;返回G90G00z50;不成立跳到这里执行WHILE中必须有“修改条件变量”的语句,使得其循环若干次后,条件变为“不成立”而退出循环,不然就成为死循环。

IF・・・ENDIF流程图IF・・・ELSE・・・ENDIFIF・・・ENDIF流程图IF・・・ELSE・・・ENDIF流程图图1流程控制子程序及参数递传WHILE・・・ENDW流程图普通子程序指没有宏的子程序,程序中各种加工的数据是固定的,子程序编好后,子程序的工作流程就固定了,程序内部的数据不能在调用时“动态”地改变,只能通过“镜像”、“旋转”、“缩放”、“平移”来有限的改变子程序的用途。例%4001G01X80F100M99子程序中数据固定,普通子程序的效能有限。宏子程序宏子程序可以包含变量,不但可以反复调用简化代码,而且通过改变变量的值就能实现加工数据的灵活变化或改变程序的流程,实现复杂的加工过程处理。例%4002G01Z[#1]F[#50];Z坐标是变量;进给速度也是变量,可适应粗、精加工。M99例对圆弧往复切削时,指令G02、G03交替使用。参数#51改变程序流程,自动选择。%4003IF#51GE1G02X[#50]R[#50];条件满足执行G02ELSEG03X[-#50]R[#50];条件不满足执行G03ENDIF#51二#51*[-1];改变条件,为下次做准备M99子程序中的变量,如果不是在子程序内部赋值的,则在调用时,就必需要给变量一个值。这就是参数传递问题,变量类型不同,传值的方法也不同。全局变量传参数如果子程序中用的变量是全局变量,调用子程序前,先给变量赋值,再调用子程序。例:%400#51=40;#51为全局变量,给它赋值M98P401;进入子程序后#51的值是40#51=25;第二次给它赋值

M98P401M98P401;再次调用子程序,进入子程序后#51的值是25M30%401;子程序G91G01X[#51]F150;#51的值由主程序决定M99局部变量传参数问题:%400N1#1=40;为局部变量#1赋值N2M98P401;进入子程序后#1的值是40吗M30%401N4G91G01X[#1];子程序中用的是局部变量#1M99结论:主程序中N1行的#1与子程序中N4行的#1不是同一个变量,子程序不会接收到40这个值。怎么办呢局部变量的参数传递,是在宏调用指令后面添加参数的方法来传递的。上面的程序中,把N1行去掉,把N2行改成如下形式即可:N2M98P401B40比较一下,可知多了个B40,其中B代表#1,紧跟的数字40代表#1的值是40。这样就把参数40传给了子程序%401中的#1。更一般地,我们用G65来调用宏子程序(称宏调用)。G65指令:G65是专门用来进行宏子程序调用的,但在华中数控系统里面,G65和M98功能相同,可以互换。宏子程序调用指令G65的格式:G65P_L_A_B_…Z__P子程序号L调用次数A~Z参数,每个字母与一个局部变量号对应。A对应#0,B对应#1,C对应#2,D对应#3,……如A20,即#0=20;,即#1二;其余类推。换句话说,如果要把数50传给变量#17,则写R50。G65代码在调用宏子程序时,系统会将当前程序段各字母(A〜Z共26个,如果没有定义则为零)后跟的数值对应传到宏子程序中的局部变量#0-#25。下面列出了宏调用时,参数字母与变量号的对应关系:子程序中的变量#0#1#2#3#4#5#6#7#8#9#10#11#12传参数用的字母ABCDEFGHIJKLM子程序中的#1#1#1#1#1#1#1#2#2#2#2#2#2变量3456789012345传参数用的字母NOPQRSTUVWXYZ要注意,由于字母G、P、L等已被宏调用命令、子程序号和调用次数占用,所以不能再用来传递其它任意数据。传进去的是,G65即#6=65,P401即#15=401(子程序号),L2即#11=2。为了便于参数传递,编写子程序时要避免用#6、#15、#11等变量号来接收数据,但这些变量号可以用在子程

序中作为内部计算的中间变量暂存数据。另外,G65代码在调用宏子程序时,还会把当前九个轴的绝对位置(工件绝对坐标)传入局部变量#30〜#38。#30~#38与轴名的对应关系由机床制造厂家规定,通常#30为X轴,#31为Y轴,#32为Z轴。固定循环指令初始平面Z模态值也会传给变量#26。通过#30~#38可以轻易得到进入子程序时的轴坐标位置,这在程序流程控制中是很有用的。系列零件加工所谓系列零件加工,是指不同规格的零件,形状基本相同,加工过程也相同,只是尺寸数据不一样,利用宏程序就可以编写出一个通用的加工程序来。例1切槽宏子程序。%8002G92X90Z30M98P8001U10V50A20B40C3;UVABC对应尺寸变量见下图M98P8001U10V50A20B40C3;UVABC对应尺寸变量见下图G00X90Z30M30%8001;子程序G00Z[-#20];切刀Z向定位X[#1+5];接近工件,留5毫米距#10=#2;#10己切宽度+#2WHILE#10LT#21;够切一刀离G00Z[-#20-#10];Z向定位%8001;子程序G00Z[-#20];切刀Z向定位X[#1+5];接近工件,留5毫米距#10=#2;#10己切宽度+#2WHILE#10LT#21;够切一刀离G00Z[-#20-#10];Z向定位G01X[#0];切到要求深度G00X[#1+5];X退刀到工件外G00X[#1+5];X退刀到工件外ENDWG00Z[-#21-#20];切最后一刀G01X[#0]G00X[#1+5]M99例2根据下面系列零件的图形,编辑精加工轮廓及切断的程序。轮廓加工用外圆车刀、切断用切断刀(刀位点在右刀尖)。工件零点设在右端面。;工件;工件1主程序:%1000M03S600T0101M98P1001A8B10C24D20E5F40T0202M98P1002C24F40M30;工件2主程序:%2000M03S600T0101M98P1001A10B15C28D24E7F50T0202M98P1002C28F50M30;轮廓加工子程序%1001G00X0Z3G01Z0F100G03X[2*#0]Z[#0]R[#0]G01X[#2]W[-#4]#10=#1-[#2-#3]/2#11=SQRT[#1*#1-#10*#10]G02X[#2]W[-2*#11]R[#1]G01Z[-#5]U2G00X[#2+50]Z100M99;切断子程序%1002G00X[#2+2]Z[-#5]G00X[#2+50]Z100M99高级参考在子程序中,可能会改变系统模态值。例如,主程序中的是绝对编程(G90),而子程序中用的是相对编程(G91),如果调用了这个子程序,主程序的模态就会受到影响。当然,对于简单的程序,你可以在子程序返回后再加一条G90指令变回绝对编程。但是,如果编写的子程序不是你自己用,别人乂不知道你改变了系统模态值,直接调用就有可能出问题。有没有办法,使子程序不影响主程序的模态值呢简单的办法就是,进入子程序后首先把子程序会影响到的所有模态用局部变量保存起来,然后再往后执行,子程序会影响到的所有模态用局部变量保存起来,然后再往后执行,并且在子程序返回时恢复保存的模态值。看下面的例子例%102;不管原来是什么状态,先记录下来#45=#1162,•记录第12组模态码#1162是G61或G64#46=#1163,•记录第13组模态码#1163是G90或G91,•现在可以改变已记录过的模态G91G64,•用相对编程G91及连续插补方式G64,•这里是其它程序,•子程序结束前恢复记录值G[#45]G[#46],•恢复第12组13组模态M99由此可见,系统变量虽然是不能直接改写的,但并不是不能改变的。系统模态值是可以被指令改变固定循环也是用宏程序实现的,而且固定循环中它改变了系统模态值,只是在固定循环子程序中采用了保护措施,在固定循环宏子程序返回时,恢复了它影响过的系统模态,所以外表看它对系统模态没有影响。这可以通过分析系统提供的固定循环宏程序看出来。的。对于每个局部变量,还可用系统宏AR口来判别该变量是否被定义,是被定义为增量或绝对方式。该系统宏的调用格式如下AR[#变量号]返回值:0表示该变量没有被定义90表示该变量被定义为绝对方式G9091表示该变量被定义为相对方式G91例下面的主程序%1000在调用子程序%9990时设置了]JK之值,子程序%9990可分别通过当前局部变量#8#9#10来访问主程序的IJK之值%1000G92X0Y0Z0M98P9990I20J30K40M30%9990IF[AR[#8]EQ0]OR[AR[#9]EQ0]OR[AR[#10]EQ0]M99;如果没有定义IJK值,则返回ENDIFN10G91;用增量方式编写宏程序IFAR[#8]EQ90;如果I值是绝对方式G90#8=#8-#30;将]值转换为增量方式,#30为X的绝对坐标ENDIFHNC-21M子程序嵌套调用的深度最多可以有七层,每一层子程序都有自己独立的局部变量,变量个数为50。当前局部变量为#0-#49,第一层局部变量为#200-#249,第二层局部变量为#250-#299,第三层局部变量#300-#349,依此类推。在子程序中如何确定上层的局部变量要依上层的层数而定。由于通过系统变量来直接访问局部变量容易引起混乱,因此不提倡用这种方法。例%0099G92X0Y0Z0N100#10=98M98P100M30%100N200#10=222;此时N100所在段的局部变量#10为第0层#210M98P110M99%110N300#10=333;此时N200所在段的局部变量#10为第1层#260,即#260=222;此时N100所在段的局部变量#10为第0层#210,即#210=98宏编程实例数车编程函数曲线加工通用宏程序数车编程函数曲线加工通用宏程序;任意曲线y=f(x)的加工;单调区间x由x1变到x2方法一-----%1001#1=x1;初值#2=f(x1);或者写成#2=f(#1)WHILE#1LEx2;或者WHILE#1GEx2G01X[#1]Y[#2];到下一位置#1=#1+;X增量;或者#1=#;X增量#2=f(#1);计算下个点坐标ENDW;......退刀M30(实际应用,请用具体表达式代替f(x))方法二#1=x1;初值#3=f(x1);或者写成#3=f(#1)WHILE#1LEx2;或者WHILE#1GEx2#2=#3;保存前一个点坐标#1=#1+;X增量;或者#1=#;X增量#3=f(#1);计算下个点坐标G91G01X[]Y[#3-#2];到下一位置ENDW;退刀M30地物域给T/2%1002抛物线车削1用宏程序编制如图所示抛物线在X区间[0,8]内的程序。地物域给T/2%3401T0101G37M03S600;G37半径编程#0=0;X坐标,初值为0#1=0;Z坐标,初值为0WHILE#0LE8G90G01X[#0]Z[-#1]F200#0=#0+#1=#0*#0/2ENDWG00X40Z80M05M30(3)抛物线车削2%0342T0101M03S600G00Z2#11=12#10=SQRT[2*#11];A初值WHILE#10LE8G90G01X[2*#10]Z[12-#11]F200#10=#10+#11二#10*#10/2ENDWG01X16Z[-32+12]Z-28U4G00Z2M05辙物线Br-A2/2#11=12;B初值#10=SQRT[2*#11];A初值WHILE#11LE32G90G01X[2*[#10+3]]Z[4-#11]F500#11二#11+#10=SQRT[2*#11]ENDWG01X22Z-28Z-30X30Z-35G00X35Z3M30(5)抛物线车削4%0001辙物线Br-A2/2#11=12;B初值#10=SQRT[2*#11];A初值WHILE#11LE32G90G01X[2*[#10+3]]Z[4-#11]F500#11二#11+#10=SQRT[2*#11]ENDWG01X22Z-28Z-30X30Z-35G00X35Z3M30(5)抛物线车削4%0001T0101M03S800[XIG92X100Z50司二,一G01X[20+2*#10]Z[#11-38]#11=##10=SQRT[2*#11]ENDWG01X20Z-38G00X18Z4X100Z50M30(6)抛物线车削5(G71与宏程序)这个例子中应用了G71复合循环与宏程序配合完成粗精加工。G71参数简介:G71U_R_P_Q_X_Z_F_S_TU背吃刀量;R每次退刀量;P起始段号;Q结束段号;X、Z精加工余量;F、S、T粗车时有效,精车时以精车程序为准。♦■t%3402T0101M03S600G00X21Z2G71R1P11Q22F100S600

N11G01X0S1200;精加工,起始#10=0;A坐标,初值为0#11=0;B坐标,初值为0WHILE#10LE8G01X[2*#10]Z[-#11]F50#10=#10+/坐标增量#11=#10*#10/2;更新B坐标ENDWG01X16Z-32Z-40N22;精加工,结束X21Z2M30(7)抛物线车削6%3404T0101M03S600G92X80Z30G00X20Z3N6G01X38#11=0;B初值#10=0;A初值WHILE#11LE18G01X[38-2*#10]Z[-#11]F100#11二#11+0-0#10=SQRT[#11*2]ENDWG01X26Z-1845-d.]N14G01Z-24X22N仙线放大正弦竖X22G00Z5X80Z30M05M30正弦线车削%3404M03S600T0101G92X80Z30G00X25Z3N6G0X17#11=0WHILE#11GE-25#9二#11*PI/10#10=*SIN[#9]G01X[17-2*#10]Z[#11]F100#11=#N13ENDWZ-30X30G00X80Z30M30(9)抛物线与椭圆车削%8002G92X50Z100M98P8001A8B5C4U32V40W55G36G90X50Z0M30%8001G64G37(连续切削,半径编程)#10=0#11=0(抛物线起点)WHILE#11LE#20G01X[#10]Z[-#11]F150#10=#10+(抛物线X增量)#11=#10*#10/#2(计算抛物线z)ENDW#50=SQRT[#20*#2](抛物线与椭圆交接处半径)G01X[#50]Z[-#20](抛物线终点)G01Z[-#21](直线终点)#12=0#13=0(椭圆起点)WHILE#13LE#1

#12二#0/#1*SQRT[#1*#1-#13*#13](椭圆X增量)G01X[#50+#0-#12]Z[-#21-#13]#13二#13+(椭圆z增量)ENDWG01X[#50+#0]Z[-#21-#1](椭圆终点)Z[-#22]U2G0X50Z100M99(10)椭圆粗、精车削%100M03T0101S600G00X32Z2;粗车#1=15#2=0WHILE#1GE1;还可以车一刀(2mm)#1=#1-1#2=25/15*SQRT[15*15-#1*#1]%100M03T0101S600G00X32Z2;粗车#1=15#2=0WHILE#1GE1;还可以车一刀(2mm)#1=#1-1#2=25/15*SQRT[15*15-#1*#1]G00X[#1*2+];转为直径编程并留精车余量G01Z[#2-25]F150(11)用子程序完成粗、精加工G91X1G90Z2ENDWG00X0S1200;精车#1=0#2=25WHILE#1LE15G01X[#1*2]Z[#2-25]F80#1=#1+#2=25/15*SQRT[15*15-#1*#1]ENDWG01X32G00X50Z100M30子程序按精车路径用相对编程(X方向)。方法%1010M03S600T0101#50=35;初始化X尺寸(毛坯值)M98P1011;精车G00X50Z100M05M30%1011G01Z0;编程起点X0,Z1G03U20W-10R10G01U12W-5W-10U1;退刀G00Z1M99#50=#50-#51G00X[#50]Z1M98P1011ENDWG00Z1M98P1011;半精车G00X0Z1方法2...%1020M03S600T0101#50=35;初始化X尺寸(毛坯值)#51=3;切削量WHILE#50GT[#51+];还够车一刀#50=#50-#51G90G00X[#50]Z1M98P1021ENDWG00Z1M98P1021;半精车G00X0Z1M98P1021;精车G00X50Z100M05M30%1021(少走空刀的子程序)G01Z0;编程起点X0,Z1G03U20W-10R10IF[#50+20]GT35;过了毛坯就退刀G01U12W-5IF[#50+20+12]GT35;过了毛坯就退刀W-10ENDIFENDIFU1;退刀G00Z1M99华中数控系统系统变量一览⑴子程序嵌套局部变量主程序的局部变量为0层,没有对应的系统变量#200~#2490层局部变量(对应0层子程序#0~#49#250~#2991层局部变量(对应1层子程序#0~#49)#300~#3492层局部变量(对应2层子程序#0~#49)#350~#3993层局部变量(对应3层子程序#0~#49)#400~#4494层局部变量(对应4层子程序#0~#49)#450~#4995层局部变量(对应5层子程序#0~#49)#500~#5496层局部变量(对应6层子程序#0~#49)#550~#5997层局部变量(对应7层子程序#0~#49)(2)刀具相关系统变量#600~#699刀具长度寄存器H0H99#700~#799刀具半径寄存器D0D99#800~#899刀具寿命寄存器(3)坐标相关系统变量:#1000机床当前位置X#1001机床当前位置Y#1002机床当前位置Z#1003机床当前位置A#1004机床当前位置B#1005机床当前位置C#1006机床当前位置U#1007机床当前位置V#1008机床当前位置W#1009保留#1012程编机床位置Z#1015程编机床位置C#1018程编机床位置W#1021程编工件位置Y#1024程编工件位置B#1027程编工件位置V#1030当前工件零点X#1033当前工件零点A#1036当前工件零点UW#1039保留⑷参考点相关系统变量#1040G54零点X#1043G54零点A#1046G54零点U#1049保留#1050G55零点X#1053G55零点A#1056G55零点U#1059保留#1060G56零点X#1063G56零点A#1010程编机床位置X#1013程编机床位置A#1016程编机床位置U#1019保留#1022程编工件位置Z#1025程编工件位置C#1028程编工件位置W#1031当前工件零点Y#1034当前工件零点B#1037当前工件零点V#1041G54零点Y#1044G54零点B#1047G54零点V#1051G55零点Y#1054G55零点B#1057G55零点V#1061G56零点Y#1064G56零点B#1011程编机床位置Y#1014程编机床位置B#1017程编机床位置V#1020程编工件位置X#1023程编工件位置A#1026程编工件位置U#1029保留#1032当前工件零点Z#1035当前工件零点C#1038当前工件零点#1042G54零点Z#1045G54零点C#1048G54零点W#1052G55零点Z#1055G55零点C#1058G55零点W#1062G56零点Z#1065G56零点C#1067G56零点V#1071G57零点Y#1074G57零点B#1077G57零点V#1081G58零点Y#1084G58零点B#1087G58零点V#1091G59零点Y#1094G59零点B#1097G59零点V#1101中断点位置Y#1104中断点位置B#1107中断点位置V#1111G28中间点位置Y#1114G28中间点位置B#1115G28中间#1066G56零点U#1069保留#1070G57零点X#1073G57#1067G56零点V#1071G57零点Y#1074G57零点B#1077G57零点V#1081G58零点Y#1084G58零点B#1087G58零点V#1091G59零点Y#1094G59零点B#1097G59零点V#1101中断点位置Y#1104中断点位置B#1107中断点位置V#1111G28中间点位置Y#1114G28中间点位置B#1115G28中间#1068G56零点W#1072G57零点Z#1075G57零点C#1078G57零点W#1082G58零点Z#1085G58零点C#1088G58零点W#1092G59零点Z#1095G59零点C#1098G59零点W#1102中断点位置Z#1105中断点位置C#1108中断点位置W#1112G28中点位置C#1116G28中间点位置U#1117G28中间点位置V#1118G28中间点位置W#1119G28屏蔽字#1120镜像点位置X#1121镜像点位置Y#1122镜像点位置Z#1123镜像点位置A#1124镜像点位置B#1125镜像点位置C#1126镜像点位置U#1127镜像点位置V#1128镜像点位置W#1129镜像屏蔽字#1130旋转中心(轴

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论