华中数控车宏程序

上传人:仙*** 文档编号:128933128 上传时间:2022-08-02 格式:DOC 页数:31 大小:416KB
收藏 版权申诉 举报 下载
华中数控车宏程序_第1页
第1页 / 共31页
华中数控车宏程序_第2页
第2页 / 共31页
华中数控车宏程序_第3页
第3页 / 共31页
资源描述:

《华中数控车宏程序》由会员分享,可在线阅读,更多相关《华中数控车宏程序(31页珍藏版)》请在装配图网上搜索。

1、华中数控宏程序一什么是宏程序?什么是数控加工宏程序?简朴地说,宏程序是一种具有计算能力和决策能力的数控程序。宏程序具有如下些特点:1使用了变量或体现式(计算能力),例如: (1)G01 X3+5 ;有体现式3+5(2)G00 X4 F#1 ;有变量#1(3)G01 Y50*SIN3 ;有函数运算2使用了程序流程控制(决策能力),例如:(1)IF #3 GE 9 ;有选择执行命令ENDIF(2)WHILE #1 LT #4*5 ;有条件循环命令ENDW二用宏程编程有什么好处?1宏程序引入了变量和体现式,尚有函数功能,具有实时动态计算能力,可以加工非圆曲线,如抛物线、椭圆、双曲线、三角函数曲线等;

2、2宏程序可以完毕图形同样,尺寸不同的系列零件加工;3宏程序可以完毕工艺途径同样,位置不同的系列零件加工;4宏程序具有一定决策能力,能根据条件选择性地执行某些部分;5使用宏程序能极大地简化编程,精简程序。适合于复杂零件加工的编程。一宏变量及宏常量1宏变量先看一段简朴的程序:G00 X25.0上面的程序在X轴作一种迅速定位。其中数据25.0是固定的,引入变量后可以写成:#1=25.0 ;#1是一种变量G00 X#1 ;#1就是一种变量宏程序中,用“#”号背面紧跟14位数字表达一种变量,如#1,#50,#101,。变量有什么用呢?变量可以用来替代程序中的数据,如尺寸、刀补号、G指令编号,变量的使用,

3、给程序的设计带来了极大的灵活性。使用变量前,变量必需带有对的的值。如#1=25G01 X#1 ;表达G01 X25 #1=-10 ;运营过程中可以随时变化#1的值G01 X#1 ;表达G01 X-10用变量不仅可以表达坐标,还可以表达G、M、F、D、H、M、X、Y、等多种代码后的数字。如:#2=3G#2 X30 ;表达G03 X30例1 使用了变量的宏子程序。%1000 #50=20 ;先给变量赋值M98 P1001 ;然后调用子程序#50=350 ;重新赋值M98 P1001 ;再调用子程序M30%1001 G91 G01 X#50 ;同样一段程序,#50的值不同,X移动的距离就不同M992

4、局部变量编号#0 #49的变量是局部变量。局部变量的作用范畴是目前程序(在同一种程序号内)。如果在主程序或不同子程序里,浮现了相似名称(编号)的变量,它们不会互相干扰,值也可以不同。例%100N10 #3=30 ;主程序中#3为30M98 P101 ;进入子程序后#3不受影响#4=#3 ;#3仍为30,因此#4=30M30%101#4=#3 ;这里的#3不是主程序中的#3,因此#3=0(没定义),则:#4=0#3=18 ;这里使#3的值为18,不会影响主程序中的#3M993全局变量编号#50 #199的变量是全局变量(注:其中#100#199也是刀补变量)。全局变量的作用范畴是整个零件程序。不

5、管是主程序还是子程序,只要名称(编号)相似就是同一种变量,带有相似的值,在某个地方修改它的值,所有其他地方都受影响。例%100N10 #50=30 ;先使#50为30M98 P101 ;进入子程序#4=#50 ;#50变为18,因此#4=18M30%101#4=#50 ; #50的值在子程序里也有效,因此#4=30#50=18 ;这里使#50=18,然后返回M99为什么要把变量分为局部变量和全局变量?如果只有全局变量,由变量名不能反复,就也许导致变量名不够用;全局变量在任何地方都可以变化它的值,这是它的长处,也是它的缺陷。说是长处,是由于参数传递很以便;说是缺陷,是由于当一种程序较复杂的时候,

6、一不小心就也许在某个地用了相似的变量名或者变化了它的值,导致程序混乱。局部变量的使用,解决了同名变量冲突的问题,编写子程序时,不需要考虑其他地方与否用过某个变量名。什么时候用全局变量?什么时候用局部变量?在一般状况下,你应优先考虑选用局部变量。局部变量在不同的子程序里,可以反复使用,不会互相干扰。如果一种数据在主程序和子程序里都要用到,就要考虑用全局变量。用全局变量来保存数据,可以在不同子程序间传递、共享、以及反复运用。刀补变量(#100#199)。这些变量里寄存的数据可以作为刀具半径或长度补偿值来使用。如#100=8G41 D100 ;D100就是指加载#100的值8作为刀补半径。注意:上面

7、的程序中,如果把D100写成了D#100,则相称于D8,即调用8号刀补,而不是补偿量为8。4系统变量#300以上的变量是系统变量。系统变量是具有特殊意义的变量,它们是数控系统内部定义好了的,你不可以变化它们的用途。系统变量是全局变量,使用时可以直接调用。#0#599是可读写的,#600以上的变量是只读的,不能直接修改。其中,#300 #599是子程序局部变量缓存区。这些变量在一般状况下,不用关怀它的存在,也不推荐你去使用它们。要注意同一种子程序,被调用的层级不同步,相应的系统变量也是不同的。#600#899是与刀具有关系统变量。#1000#1039坐标有关系统变量。#1040#1143参照点有

8、关系统变量。#1144#1194系统状态有关系统变量。(详见:Error! Reference source not found.)有时候需要判断系统的某个状态,以便程序作相应的解决,就要用到系统变量。5常量PI 表达圆周率, TRUE 条件成立(真), FALSE 条件不成立(假) 。二运算符与体现式1算术运算符加 + , 减 - , 乘 * , 除 / 2条件运算符宏程序运算符EQNEGTGELTLE数学意义条件运算符用在程序流程控制IF和WHILE的条件体现式中,作为判断两个体现式大小关系的连接符。注意:宏程序条件运算符与计算机编程语言的条件运算符体现习惯不同。3逻辑运算符在IF或WHI

9、LE语句中,如果有多种条件,用逻辑运算符来连接多种条件。AND (且) 多种条件同步成立才成立 OR (或) 多种条件只要有一种成立即可NOT (非) 取反(如果不是)例#1 LT 50 AND #1GT 20 表达:#120#3 EQ 8 OR #4 LE 10 表达:#3=8或者#410有多种逻辑运算符时,可以用方括号来表达结合顺序,如:NOT#1 LT 50 AND #1GT 20表达:如果不是“#120”更复杂的例子,如:#1 LT 50 AND #2GT 20 OR #3 EQ 8 AND #4 LE 104函数正 弦:SINa 余弦:COSa 正切:TANa 注:a为角度,单位是弧

10、度值。反正切:ATANa (返回:度,范畴:-9090) 反正切:ATAN2a/b (返回:度,范畴:-180180) (注:华中数控暂不支持)绝对值:ABSa,表达|a|取 整:INTa,采用去尾取整,非“四舍五入”取符号:SIGNa,a为正数返回1,0返回0,负数返回-1开平方:SQRTa ,表达 指 数:EXPa,表达5体现式与括号涉及运算符或函数的算式就是体现式。体现式里用方括号来表达运算顺序。宏程序中不用圆括号,因圆括号是注释符。例如 175/SQRT2 * COS55 * PI/180 #3*6 GT 146运算符的优先级方括号 函数 乘除 加减 条件 逻辑技巧:常用方括号来控制运

11、算顺序,更容易阅读和理解。7赋值号 =把常数或体现式的值送给一种宏变量称为赋值,格式如下:宏变量 = 常数或体现式例如 #2 = 175/SQRT2 * COS55 * PI/180 #3 = 124.0#50 = #3+12特别注意,赋值号背面的体现式里可以涉及变量自身,如: #1 = #1+4 ;此式表达把#1的值与4相加,成果赋给#1。这不是数学中的方程或等式,如果#1的值是2,执行#1 = #1+4后,#1的值变为6。三程序流程控制程序流程控制形式有许多种,都是通过判断某个“条件”与否成立来决定程序走向的。所谓“条件”,一般是对变量或变量体现式的值进行大小判断的式子,称为“条件体现式”

12、。华中数控系统有两种流程控制命令:IFENDIF,WHILEENDW。1条件分支 IF需要选择性地执行程序,就要用IF命令。格式1:(条件成立则执行)IF 条件体现式 条件成立执行的语句组ENDIF功能:条件成立执行IF与ENDIF之间的程序,不成立就跳过。其中IF、ENDIF称为核心词,不辨别大小写。IF为开始标记,ENDIF为结束标记。IF语句的执行流程如图1所示。例:IF #1 EQ 10 ;如果#1=10 M99 ;成立则,执行此句(子程返回)ENDIF ;条件不成立,跳到此句背面例:IF #1 LT 10 AND #1 GT 0;如果#10G01 x20 ;成立则执行Y15ENDIF

13、 ;条件不成立,跳到此句背面格式2:(二选一, 选择执行)形式:IF 条件体现式条件成立执行的语句组ELSE条件不成立执行的语句组ENDIF例:IF #51 LT 20 G91G01 X10F250ELSE G91G01X35F200ENDIF功能:条件成立执行IF与ELSE之间的程序,不成立就执行ELSE与ENDIF之间的程序。IF语句的执行流程如图1所示。本资料由百万课件网收2条件循环 WHILE格式:WHILE 条件体现式条件成立循环执行的语句ENDW功能:条件成立执行WHILE与ENDW之间的程序,然后返回到WHILE再次判断条件,直到条件不成立才跳到ENDW背面。WHILE语句的执行

14、流程如图 1 所示。例: #2=30WHILE #2 GT 0 ;如果#20 G91G01X10 ;成立就执行 #2=#2-3 ;修变化量,ENDW ;返回G90 G00 z50 ;不成立跳到这里执行WHILE中必须有“修改条件变量”的语句,使得其循环若干次后,条件变为“不成立”而退出循环,否则就成为死循环。假真IF条件成立?程序AENDIFELSE程序BIFELSEENDIF流程图假真IF条件成立?程序1程序NENDIFIFENDIF流程图WHILEENDW流程图假真WHILE条件程序1程序NENDW 图1 流程控制四子程序及参数递传1一般子程序一般子程序指没有宏的子程序,程序中多种加工的数

15、据是固定的,子程序编好后,子程序的工作流程就固定了,程序内部的数据不能在调用时“动态”地变化,只能通过“镜像”、“旋转”、“缩放”、“平移”来有限的变化子程序的用途。例 %4001G01 X80 F100 M99子程序中数据固定,一般子程序的效能有限。2宏子程序宏子程序可以涉及变量,不仅可以反复调用简化代码,并且通过变化变量的值就能实现加工数据的灵活变化或变化程序的流程,实现复杂的加工过程解决。例 %4002G01 Z#1 F#50 ;Z坐标是变量;进给速度也是变量,可适应粗、精加工。M99例 对圆弧往复切削时,指令G02、G03交替使用。参数#51变化程序流程,自动选择。%4003IF #5

16、1 GE 1G02 X#50 R#50 ;条件满足执行G02ELSEG03 X-#50 R#50 ;条件不满足执行G03ENDIF#51=#51*-1 ;变化条件,为下次做准备M99子程序中的变量,如果不是在子程序内部赋值的,则在调用时,就必需要给变量一种值。这就是参数传递问题,变量类型不同,传值的措施也不同。3全局变量传参数如果子程序中用的变量是全局变量,调用子程序前,先给变量赋值,再调用子程序。例: %400#51=40 ;#51为全局变量,给它赋值M98 P401 ;进入子程序后#51的值是40#51=25 ;第二次给它赋值M98 P401 ;再次调用子程序,进入子程序后#51的值是25

17、M30%401 ;子程序G91G01X#51F150 ;#51的值由主程序决定M994局部变量传参数问题:%400N1 #1=40 ;为局部变量#1赋值N2 M98 P401 ;进入子程序后#1的值是40吗?M30%401N4 G91G01X#1 ;子程序中用的是局部变量#1M99结论:主程序中N1行的#1与子程序中N4行的#1不是同一种变量,子程序不会接受到40这个值。怎么办呢?局部变量的参数传递,是在宏调用指令背面添加参数的措施来传递的。上面的程序中,把N1行去掉,把N2行改成如下形式即可:N2 M98 P401 B40 比较一下,可知多了个B40,其中B代表#1,紧跟的数字40代表#1的

18、值是40。这样就把参数40传给了子程序%401中的#1。更一般地,我们用G65来调用宏子程序(称宏调用)。G65指令:G65是专门用来进行宏子程序调用的,但在华中数控系统里面,G65和M98功能相似,可以互换。宏子程序调用指令G65的格式:G65 P_ L_ A_ B_ Z_P 子程序号L 调用次数AZ 参数,每个字母与一种局部变量号相应。A相应#0,B相应#1,C相应#2,D相应#3,如A20,即#0=20;B6.5,即#1=6.5;其他类推。换句话说,如果要把数50传给变量#17,则写R50。G65代码在调用宏子程序时,系统会将目前程序段各字母(AZ共26个,如果没有定义则为零)后跟的数值

19、相应传到宏子程序中的局部变量#0-#25 。下面列出了宏调用时,参数字母与变量号的相应关系:子程序中的变量#0#1#2#3#4#5#6#7#8#9#10#11#12传参数用的字母ABCDEFGHIJKLM子程序中的变量#13#14#15#16#17#18#19#20#21#22#23#24#25传参数用的字母NOPQRSTUVWXYZ要注意,由于字母G、P、L等已被宏调用命令、子程序号和调用次数占用,因此不能再用来传递其他任意数据。传进去的是,G65即#6=65,P401即#15=401(子程序号),L2即#11=2。为了便于参数传递,编写子程序时要避免用#6、#15、#11等变量号来接受数据

20、,但这些变量号可以用在子程序中作为内部计算的中间变量暂存数据。此外,G65代码在调用宏子程序时,还会把目前九个轴的绝对位置(工件绝对坐标)传入局部变量#30#38。#30#38与轴名的相应关系由机床制造厂家规定,一般#30为X轴,#31为Y轴,#32为Z轴。固定循环指令初始平面Z 模态值也会传给变量#26。通过#30#38可以容易得到进入子程序时的轴坐标位置,这在程序流程控制中是很有用的。5系列零件加工所谓系列零件加工,是指不同规格的零件,形状基本相似,加工过程也相似,只是尺寸数据不同样,运用宏程序就可以编写出一种通用的加工程序来。例1 切槽宏子程序。%8002G92X90 Z30M98 P8

21、001 U10 V50 A20 B40 C3 ;UVABC相应尺寸变量见下图G00 X90Z30M30%8001 ;子程序G00 Z-#20 ;切刀Z向定位X#1+5 ;接近工件,留5毫米距离#10=#2 ;#10已切宽度+#2WHILE #10 LT #21 ;够切一刀? G00 Z-#20-#10 ;Z向定位 G01 X#0 ;切到规定深度 G00X#1+5 ;X退刀到工件外 #10=#10+#2-1 ;修改#10ENDWG00 Z-#21-#20 ;切最后一刀G01X#0G00X#1+5M99例2 根据下面系列零件的图形,编辑精加工轮廓及切断的程序。轮廓加工用外圆车刀、切断用切断刀(刀位

22、点在右刀尖)。工件零点设在右端面。;工件1主程序:%1000M03 S600 T0101M98 P1001 A8B10C24D20E5F40T0202M98 P1002 C24F40M30;工件2主程序:%M03 S600 T0101M98 P1001 A10B15C28D24E7F50T0202M98 P1002 C28F50M30;轮廓加工子程序%1001G00X0Z3G01Z0F100G03X2*#0Z#0R#0G01X#2W-#4#10= #1- #2-#3/2#11=SQRT#1*#1-#10*#10G02X#2W-2*#11R#1G01Z-#5U2G00X#2+50Z100M99;

23、切断子程序%1002G00X#2+2Z-#5G01X0.3F30G00X#2+50Z100M996高档参照在子程序中,也许会变化系统模态值。例如,主程序中的是绝对编程(G90),而子程序中用的是相对编程(G91),如果调用了这个子程序,主程序的模态就会受到影响。固然,对于简朴的程序,你可以在子程序返回后再加一条G90指令变回绝对编程。但是,如果编写的子程序不是你自己用,别人又不懂得你变化了系统模态值,直接调用就有也许出问题。有无措施,使子程序不影响主程序的模态值呢?简朴的措施就是,进入子程序后一方面把子程序会影响到的所有模态用局部变量保存起来,然后再往后执行,并且在子程序返回时恢复保存的模态值

24、。看下面的例子例%102;不管本来是什么状态,先记录下来#45=#1162 ; 记录第12 组模态码#1162 是G61 或 G64?#46=#1163 ; 记录第13 组模态码#1163 是G90 或 G91?;目前可以变化已记录过的模态G91 G64 ;用相对编程G91 及持续插补方式G64 ;这里是其他程序;子程序结束前恢复记录值G#45 G#46 ;恢复第12 组13 组模态M99由此可见,系统变量虽然是不能直接改写的,但并不是不能变化的。系统模态值是可以被指令变化的。固定循环也是用宏程序实现的,并且固定循环中它变化了系统模态值,只是在固定循环子程序中采用了保护措施,在固定循环宏子程序

25、返回时,恢复了它影响过的系统模态,因此外表看它对系统模态没有影响。这可以通过度析系统提供的固定循环宏程序看出来。对于每个局部变量,还可用系统宏AR来鉴别该变量与否被定义,是被定义为增量或绝对方式。该系统宏的调用格式如下AR#变量号返回值:0 表达该变量没有被定义90 表达该变量被定义为绝对方式G9091 表达该变量被定义为相对方式G91例 下面的主程序%1000 在调用子程序%9990 时设立了I JK 之值,子程序%9990 可分别通过目前局部变量#8 #9 #10 来访问主程序的I J K 之值%1000G92 X0Y0Z0M98 P9990 I20 J30 K40M30%9990IF A

26、R#8 EQ 0 OR AR#9 EQ 0 OR AR#10 EQ 0M99 ; 如果没有定义I J K 值,则返回ENDIFN10 G91 ; 用增量方式编写宏程序IF AR#8 EQ 90 ; 如果I 值是绝对方式G90#8=#8-#30 ;将I 值转换为增量方式, #30 为X 的绝对坐标ENDIFM99HNC-21M 子程序嵌套调用的深度最多可以有七层,每一层子程序均有自己独立的局部变量,变量个数为50 。目前局部变量为#0-#49, 第一层局部变量为#200-#249 ,第二层局部变量为#250-#299,第三层局部变量#300-#349 ,依此类推。在子程序中如何拟定上层的局部变量

27、要依上层的层数而定。由于通过系统变量来直接访问局部变量容易引起混乱,因此不倡导用这种措施。例%0099G92 X0 Y0 Z0N100 #10=98M98 P100M30%100N200 #10=222 ;此时N100 所在段的局部变量#10 为第0层#210M98 P110M99%110N300 #10=333 ;此时N200 所在段的局部变量#10为第1层#260,即#260=222;此时N100 所在段的局部变量#10为第0层#210,即#210=98M99五宏编程实例1数车编程(1)函数曲线加工通用宏程序;任意曲线y=f(x)的加工;单调区间x由x1变到x2措施一-%1001#1=x1

28、 ;初值#2=f(x1) ;或者写成#2=f(#1)WHILE #1 LE x2;或者WHILE #1 GE x2 G01 X#1 Y#2 ;到下一位置 #1=#1+0.01 ;X增量0.01 ;或者#1=#1-0.01 ;X增量-0.01 #2=f(#1) ;计算下个点坐标ENDW;.退刀M30(实际应用,请用品体体现式替代f(x))措施二%1002#1=x1 ;初值#3=f(x1) ;或者写成#3=f(#1)WHILE #1 LE x2;或者WHILE #1 GE x2 #2=#3 ;保存前一种点坐标 #1=#1+0.01 ;X增量0.01 ;或者#1=#1-0.01 ;X增量-0.01

29、#3=f(#1) ;计算下个点坐标 G91 G01 X0.01 Y#3-#2 ;到下一位置ENDW;.退刀M30(2)抛物线车削1用宏程序编制如图所示抛物线在X区间0,8内的程序。%3401T0101 G37 M03 S600 ;G37半径编程#0=0 ;X坐标,初值为0#1=0 ; Z坐标,初值为0WHILE #0 LE 8 G90G01X#0Z-#1F200 #0=#0+0.08 #1=#0*#0/2ENDWG00 X40Z80 M05M30(3)抛物线车削2%0342T0101 M03 S600G00 X20.5 Z2#11=12 ;B初值#10=SQRT2*#11 ;A初值WHILE

30、#10 LE 8 G90G01 X2*#10 Z12- #11 F200 #10=#10+0.1 #11=#10*#10/2ENDWG01 X16 Z-32+12Z-28U4G00 X20.5 Z2 M05M30(4)抛物线车削3%0342T0101 M03 S600G00 X35 Z3G01 X18 F100Z-8#11=12 ;B初值#10=SQRT2*#11 ;A初值WHILE #11 LE 32 G90G01X2*#10+3Z4-#11F500 #11=#11+0.06#10=SQRT2*#11ENDWG01 X22 Z-28Z-30X30Z-35G00X35Z3M30(5)抛物线车削

31、4%0001T0101 M03 S800G92 X100 Z50G64 G00X36Z4#11=32 ;B初值#10=SQRT2*#11 ;A初值WHILE #11 GT 0G01X20+2*#10Z#11-38#11=#11-0.2#10=SQRT2*#11ENDWG01X20Z-38G00X18Z4X100Z50M30(6)抛物线车削5(G71与宏程序)这个例子中应用了G71复合循环与宏程序配合完毕粗精加工。G71参数简介:G71 U_R_P_Q_X_Z_F_S_T_U背吃刀量;R每次退刀量;P起始段号;Q结束段号;X、Z精加工余量;F、S、T粗车时有效,精车时以精车程序为准。%3402T

32、0101 M03 S600G00 X21 Z2G71 U0.5 R1 P11 Q22 X0.6 Z0.1 F100 S600N11 G01 X0 S1200 ;精加工,起始#10=0 ;A坐标,初值为0#11=0 ;B坐标,初值为0WHILE #10 LE 8 G01 X2*#10 Z-#11 F50#10=#10+0.1 ;A坐标增量0.1#11=#10*#10/2 ;更新B坐标ENDWG01 X16 Z-32Z-40N22 G00X20.5 ;精加工,结束X21 Z2M30(7)抛物线车削6%3404T0101 M03 S600G92X80Z30G00X20Z3G71U0.6R0.6P6Q

33、14X-0.6Z0.1F100N6G01X38#11=0 ;B初值#10=0 ;A初值WHILE #11 LE 18G01X38-2*#10Z-#11F100#11=#11+0.5#10=SQRT#11*2ENDWG01X26 Z-18N14 G01Z-24X22G00Z5X80Z30M05M30(8)正弦线车削%3404M03 S600 T0101G92 X80 Z30G00 X25 Z3G71 U0.6R0.6P6Q13X0.8F100N6G0X17#11=0WHILE #11 GE -25#9=#11*PI/10 ;#10=3.5*SIN#9G01X17-2*#10Z#11F100#11

34、=#11-0.5N13ENDWG01X24Z-25Z-30X30G00X80Z30M30(9)抛物线与椭圆车削%8002G92X50Z100M98 P8001 A8B5C4U32V40W55G36G90X50Z0M30%8001G64 G37 (持续切削,半径编程)#10=0 #11=0 (抛物线起点)WHILE #11 LE #20G01 X#10 Z-#11 F150 #10=#10+0.08 (抛物线X增量)#11=#10*#10/#2(计算抛物线z)ENDW #50= SQRT#20*#2 (抛物线与椭圆交接处半径)G01 X#50 Z-#20(抛物线终点)G01Z-#21 (直线终点

35、)#12=0 #13=0 (椭圆起点)WHILE #13 LE #1#12=#0/#1*SQRT#1*#1-#13*#13 (椭圆X增量)G01 X#50+#0-#12 Z-#21-#13#13=#13+0.08 (椭圆z增量) ENDWG01 X#50+#0 Z-#21-#1 (椭圆终点)Z-#22U2G0X50Z100M99(10)椭圆粗、精车削-%100M03 T0101 S600G00 X32 Z2 ;粗车#1=15#2=0WHILE #1 GE 1 ;还可以车一刀(2mm) #1=#1-1 #2=25/15*SQRT15*15-#1*#1 G00 X#1*2+0.5 ;转为直径编程并

36、留精车余量0.5 G01 Z#2-25 F150 G91 X1 G90 Z2ENDWG00 X0 S1200 ;精车#1=0#2=25WHILE #1 LE 15 G01 X#1*2 Z#2-25 F80 #1=#1+0.1 #2=25/15*SQRT15*15-#1*#1ENDWG01 X32G00 X50 Z100M30(11)用子程序完毕粗、精加工子程序按精车途径用相对编程(X方向)。措施1-%1010M03 S600 T0101#50=35 ;初始化X尺寸(毛坯值)#51=3 ;切削量WHILE #50 GT #51+0.5 ;还够车一刀? #50=#50-#51 G00 X#50 Z

37、1 M98 P1011ENDWG00 X0.5 Z1M98 P1011 ;半精车G00 X0 Z1M98 P1011 ;精车G00 X50 Z100 M05M30%1011G01 Z0 ;编程起点X0,Z1G03 U20 W-10 R10G01 U12 W-5W-10U1 ;退刀G00 Z1M99措施2-%1020M03 S600 T0101#50=35 ;初始化X尺寸(毛坯值)#51=3 ;切削量WHILE #50 GT #51+0.5 ;还够车一刀? #50=#50-#51 G90 G00 X#50 Z1 M98 P1021ENDWG00 X0.5 Z1M98 P1021 ;半精车G00

38、X0 Z1M98 P1021 ;精车G00 X50 Z100 M05M30%1021(少走空刀的子程序)G01 Z0 ;编程起点X0,Z1G03 U20 W-10 R10IF #50+20 GT 35 ;过了毛坯就退刀 G01 U12 W-5 IF #50+20+12 GT 35 ;过了毛坯就退刀 W-10 ENDIFENDIFU1 ;退刀G00 Z1M992华中数控系统系统变量一览(1)子程序嵌套局部变量主程序的局部变量为0层,没有相应的系统变量#200 #249 0 层局部变量(相应0层子程序#0#49#250 #299 1 层局部变量(相应1层子程序#0#49)#300 #349 2 层

39、局部变量(相应2层子程序#0#49)#350 #399 3 层局部变量(相应3层子程序#0#49)#400 #449 4 层局部变量(相应4层子程序#0#49)#450 #499 5 层局部变量(相应5层子程序#0#49)#500 #549 6 层局部变量(相应6层子程序#0#49)#550 #599 7 层局部变量(相应7层子程序#0#49)(2)刀具有关系统变量#600 #699 刀具长度寄存器H0 H99#700 #799 刀具半径寄存器D0 D99#800 #899 刀具寿命寄存器(3)坐标有关系统变量:#1000 机床目前位置X #1001 机床目前位置Y #1002 机床目前位置Z

40、#1003 机床目前位置A #1004 机床目前位置B #1005 机床目前位置C#1006 机床目前位置U #1007 机床目前位置V #1008 机床目前位置W#1009 保存 #1010 程编机床位置X #1011 程编机床位置Y#1012 程编机床位置Z #1013 程编机床位置A #1014 程编机床位置B#1015 程编机床位置C #1016 程编机床位置U #1017 程编机床位置V#1018 程编机床位置W #1019 保存 #1020 程编工件位置X#1021 程编工件位置Y #1022 程编工件位置Z #1023 程编工件位置A#1024 程编工件位置B #1025 程编工

41、件位置C #1026 程编工件位置U#1027 程编工件位置V #1028 程编工件位置W #1029 保存#1030 目前工件零点X #1031 目前工件零点Y #1032 目前工件零点Z#1033 目前工件零点A #1034 目前工件零点B #1035 目前工件零点C#1036 目前工件零点U #1037 目前工件零点V #1038 目前工件零点W #1039 保存(4)参照点有关系统变量#1040 G54零点X #1041 G54零点Y #1042 G54零点Z#1043 G54零点A #1044 G54零点B #1045 G54零点C#1046 G54零点U #1047 G54零点V

42、#1048 G54零点W #1049 保存#1050 G55零点X #1051 G55零点Y #1052 G55零点Z#1053 G55零点A #1054 G55零点B #1055 G55零点C#1056 G55零点U #1057 G55零点V #1058 G55零点W #1059 保存#1060 G56零点X #1061 G56零点Y #1062 G56零点Z#1063 G56零点A #1064 G56零点B #1065 G56零点C#1066 G56零点U #1067 G56零点V #1068 G56零点W #1069 保存#1070 G57零点X #1071 G57零点Y #1072 G

43、57零点Z#1073 G57零点A #1074 G57零点B #1075 G57零点C#1076 G57零点U #1077 G57零点V #1078 G57零点W #1079 保存 #1080 G58零点X #1081 G58零点Y #1082 G58零点Z#1083 G58零点A #1084 G58零点B #1085 G58零点C#1086 G58零点U #1087 G58零点V #1088 G58零点W #1089 保存#1090 G59零点X #1091 G59零点Y #1092 G59零点Z#1093 G59零点A #1094 G59零点B #1095 G59零点C#1096 G59零

44、点U #1097 G59零点V #1098 G59零点W #1099 保存#1100 中断点位置X #1101 中断点位置Y #1102 中断点位置Z#1103 中断点位置A #1104 中断点位置B #1105 中断点位置C#1106 中断点位置U #1107 中断点位置V #1108 中断点位置W #1109 坐标系建立轴#1110 G28中间点位置X #1111 G28中间点位置Y #1112 G28中间点位置Z#1113 G28中间点位置A #1114 G28中间点位置B #1115 G28中间点位置C#1116 G28中间点位置U #1117 G28中间点位置V #1118 G28中

45、间点位置W #1119 G28屏蔽字#1120 镜像点位置X #1121 镜像点位置Y #1122 镜像点位置Z#1123 镜像点位置A #1124 镜像点位置B #1125 镜像点位置C#1126 镜像点位置U #1127 镜像点位置V #1128 镜像点位置W#1129 镜像屏蔽字 #1130 旋转中心(轴1) #1131 旋转中心(轴2)#1132 旋转角度 #1133 旋转轴屏蔽字 #1134 保存#1135 缩放中心(轴1) #1136 缩放中心(轴2) #1137 缩放中心(轴3)#1138 缩放比例 #1139 缩放轴屏蔽字 #1140 坐标变换代码1#1141 坐标变换代码2

46、#1142 坐标变换代码3 #1143 保存(5)系统状态变量#1144 刀具长度补偿号 #1145 刀具半径补偿号 #1146 目前平面轴1#1147 目前平面轴2 #1148 虚拟轴屏蔽字 #1149 进给速度指定#1150 G代码模态值0 #1151 G代码模态值1 #1152 G代码模态值2#1153 G代码模态值3 #1154 G代码模态值4 #1155 G代码模态值5#1156 G代码模态值6 #1157 G代码模态值7 #1158 G代码模态值8#1159 G代码模态值9 #1160 “G代码模态值10” #1161 “G代码模态值11”#1162 “G代码模态值12” #116

47、3 “G代码模态值13” #1164 “G代码模态值14”#1165 “G代码模态值15” #1166 “G代码模态值16” #1167 “G代码模态值17”#1168 “G代码模态值18” #1169 “G代码模态值19” #1170 剩余CACHE#1171 备用CACHE #1172 剩余缓冲区 #1173 备用缓冲区#1174 #1189 保存 #1190 顾客自定义输入 #1191 顾客自定义输出#1192 自定义输出屏蔽 #1193 保存 #1194 保存3数学知识(1)和角公式Sin(AB)=SinA*CosBSinB*CosA Cos(AB)=CosA*CosBSinA*Sin

48、B Tan(AB)=(TanATanB)/(1TanA*TanB) (2)圆标方程原则方程:(3)椭圆方程原则方程:可推出: 或参数方程:x=a*cosy=b*sin(4)旋转点点P(a,b)以原点为中心旋转一定角度到P(A,B)点,则有关系:A=a*Cos-b*SinB=a*Sin+b*Cos 椭圆N10 G54 G90 G0 S1500 M03N12 X0 Y0 Z20.N14 G0 Z1N16 G1 Z-5. F150.N18 G41 D1N20 #1=0 (椭圆起始角)N22 #2=34(椭圆长轴)N24 #3=24(椭圆短轴)N26 #4=#2*COS#1(计算坐标)N28 #5=#

49、3*SIN#1N30 #10=#4*COS45 - #5*SIN45(椭圆外形与水平的角度)N32 #11=#4*SIN45 - #5*COS45N34 G1 X#10 Y#11 N36 #1=#1+1(角度增长,精度高可以减小一点的值)N38 IF #1 LT 370 GOTO26N40 G40 G1 X0 Y0 N42 G0 Z100N44 M30 圆变方上圆周直径D24方体40高度30G54 G90 G00 X0 Y0 Z30. S1500 M31-0.5Z方向每次的进刀量211.8R的每次变化量,第一刀的初值312.0357第一次X,Y方向的初始值432中间变量。G00 X-25.Y-2 Z1N10 G01 Z#1 F150N12 G41 D1 X-#3G1 Y#4G2 X#3 Y#4 R#2G1 X#4G2 X#3 Y#4 R#2G1 Y-#4G2 X#4 Y-#3 R#2G1 X-#4G2 X-#3 Y-#4 R#2G1 Y#3G40 X-25.#1=#1-0.5#2=#2-0.2#3=#3+0.0357#4=#3-#2IF #1 GE -30 GOTO10G0 Z100 M5M30

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!