刀具半径补偿计算程序的设计(共28页).doc

上传人:飞****2 文档编号:13856405 上传时间:2022-05-01 格式:DOC 页数:28 大小:865.50KB
返回 下载 相关 举报
刀具半径补偿计算程序的设计(共28页).doc_第1页
第1页 / 共28页
刀具半径补偿计算程序的设计(共28页).doc_第2页
第2页 / 共28页
点击查看更多>>
资源描述

《刀具半径补偿计算程序的设计(共28页).doc》由会员分享,可在线阅读,更多相关《刀具半径补偿计算程序的设计(共28页).doc(28页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上1.刀具半径补偿的原理1.1刀具半径补偿的坐标计算 在机床数控技术中已经讲述了刀具半径补偿的编程指令,刀具半径补偿建立和取消时刀具中心点的运动轨迹。本节将要介绍刀具半径十限的坐标计算,在轮廓加工过程中,刀具半径补偿分三个过程:刀具半径补偿的建立;刀具半径补偿的进行;刀具半径补偿的取消。在这三个过程中,刀具中心的轨迹都是根据被加工工件的轮廓计算的。通常,工件轮廓是由直线和圆弧组成的,加工直线时,刀具中心线是工件轮廓的平行线且距离等于刀具半径值,加工圆弧时,半径之差是刀具半径值,本节将要介绍的半径补偿计算是计算刀具半径补偿建立和取消时刀具中心点与工件轮廓起点和终点的位置关

2、系;工件轮廓拐角时刀具中心拐点与工件轮廓拐点的位置关系。由于轮廓线的拐点可是直线与直线、直线与圆弧、圆弧与圆弧的交点;拐角的角度大小又不同;又由于刀具半径补偿可是左侧(c41)或右侧(跳)偏置,因此,计算公式很多,下面仅介绍部分计算公式:1.2直线两端处刀具中心的位置若用半径为r的立铣刀加工图320中的直线45,刀具中心的轨迹在刀具左例偏置时(G41方式),是ab直线;右侧偏置(G42方式)时是cd线,只要计算出端点a,b或c,d的坐标值,就可使刀具准确移动。由于直线AaAcr,过A点垂直于AB线,BbBcr,过B点垂直于AB线,A点和B点的坐标值已由零件程序中给出,因此:图1.2.1 直线两

3、端刀具位置若把式(318)中的r值的符号改为负号,则和式(317)完全一样,因此在实际应用中,只用式(317)计算直线端点处的刀具中心位置,在G41方式下r取正值 在G42方式下r取负值。 式(315)、(316)、(317),适合于各种不同方向的直线,当为负值时,为负值,当AB线平行于X轴时,当AB线平行Y轴时。1.3转接矢量计算 工件轮廓有拐角时,拐点可是直线与直线交点,如图322、323、324所示。直线拐角时拐角的大小等于两直线矢量的夹角;直线与圆弧连接时拐角的大小是直线矢量与拐点处圆弧切线矢量的夹角;圆弧与圆弧连接时是两圆弧在交点处切线矢量的夹角,由于两矢量夹角不同以及G41,G42

4、偏置方向不同,使刀具中心轨迹的转接方式有所不同,共有三种转接方式: 1.3.1缩短型 在G41方式下两矢量夹角。在之间;在G42方式下两向量夹角在之间,是缩短型,如图322、324a,b及图323c,d所示,刀具中心在c点转折,没有到达由式(317)算出的B点,比只加工OA直线时少走CB的距离,也比单程加工AF直线少走DC的距离。 1.3.2伸长型 在G41方式下,两矢量的夹角之间;在G42方式下,两向量的夹角之间,是伸长型,如图322d、323a及324d所示,刀具中心越过由式(317)算出的B点,在C点转折,也比单独加工AF直线多走CD的距离。 1.3.3插入型 在G4l方式下,两矢量的夹

5、角之间,在G42方式下,两向量夹角之间,如图322c、323b及324c所示,刀具中心在C点和C点两次转折,CC是插入直线必须保证BC=CDr(刀具半径)。 图3-22 G41直线与直线转接情况图323 G42直线与直线转接情况图324 G41圆弧接圆弧时的转接情况 对于伸长型和插入型转接交点c和c的计算适合于直线与直线、直线与圆弧、圆弧与圆弧的连接方式,但对于缩短型,由于连接线的不同算法是不同的。伸长型转接交点c的坐标计算图3-23(a)上两式中是以X坐标轴正向为起始边,逆时针方向对轮廓线矢量的夹角,在图322d和图324d中,270。在G41方式时上式中r的符号为负。即在G41时方式时的公

6、式:是c点对A点的坐标值,由于A点在工件坐标系中的坐标值已由程序中给出,因此可求出c点对工件坐标系的坐标值。插入型转接交点C,C的坐标计算 根据刀具偏置方向(G41,G42)不同,计算方式也不相同,图322c是G41方式。由于: 则有 图3-22(c)图323b是G42方式 同理:图323(b)缩短型转接交点的坐标计算 直线与直线连接如图322a、b,图324c、d所示,(AC)x和(AC)y所用公式与伸长型相同,缩短型与伸长型r的符号也相同,即:G41方式r为负,G42方式r为正。图322a 在G42方式下 1.4缩短型转接交点的坐标计算 1.4.1直线与直线连接 直线与直线连接如图322,

7、23所示,和所用公式与仲长型相同v缩短型与伸长型r的符号也相同,即:以G41方式r为负,G42方式为正。 图1-1 直线与圆弧转接交点 1.4.2直线与圆弧连接 图1-1是以1方式直线与圆弧联接形式,工件轮廓线是ABC,B点是直线与圆弧的支点,点是圆弧中心,为已知点,点可用式(317)求得。也是已知点,由图可知在中,已知,; =(r刀具半径)。根据余弦定理可求出的模由上式可求得直线与圆弧的两个交点,离8点近的为点,在x轴和y轴上的投影为 点的坐标 根据上述方法,还可求出N2方式直线与圆弧的转按交点,及以1,N2方式圆弧与直线的转接交点。 1.4.3圆弧与圆弧连接 图326是以G41方式顺圆弧与

8、顺圆弧联接时刀具中心转接点计算图。圆弧的半径为,圆弧半径为,刀具半径为r,则为已知点,则三角形的三个边为己知边,根据余弦定理可求出专心-专注-专业2.刀具半径补偿程序流程图2.1 流程图刀具半径补偿程序设计流程图如图5所示。首先打开数控加工源程序,读取被加工零件的轮廓信息以及刀具的走刀信息、刀具半径,采用矢量算法结合刀具偏置方向计算经刀具半径补偿后各段线段的刀具中心轨迹方程。然后确定相交两线段尖角过渡处的内、外偏形式,根据内偏求交点和外偏采用辅助圆弧过渡的处理方法计算出整个刀具中心运动轨迹。在利用C语言开发的WTUAPT系统软件中,采用这种计算方法成功地解决了刀具半径补偿问题,并经实际应用证明

9、这种处理方法是简单有效的。3.刀具半径补偿程序设计示列3.1.伸长型 在G41方式下,两矢量的夹角之间;在G41方式下,两向量的夹角之间,是伸长型。如下图所示:3.1.1 G41和G02刀具半径补偿准备工作 设刀具半径r=20mm的情况下带入公式: 在中,已知,; (R+r刀具半径)。根据余弦定理可求出的模由上式可求得直线与圆弧的两个交点,离8点近的为点,在x轴和y轴上的投影为 点的坐标 刀具半径补偿清单: /* Lurunmin exp1.c LINE*/* Lurunmin exp1.c ARC */ #include /* 文件包含命令 */Main() /* 主函数 */ float

10、x1,x2,x3,x4,y1,y2,y3,y4 ,; float , ,R,a0 ,ab;int r=20;a0=sqrt(); Scanf(“%d%d%d%d”,&x1,&x2,&x3,&x4); Scanf(“%d%d%d%d”, &y1,&y2,&y3,&y4); /*输入A,B,C点和圆心坐标*/ Scanf(“%d”,&R) =arcsin(); =arccos(); =-; ab=a0cos+; /*AB的模长*/x1=x1-rsin,y2=y1+rcos;x2=x1-rsin+abcos,y2=y1+rcos+ab*sina; /*B的坐标*/ Printf(“ddd%d%d%d

11、n”,x1,y1,x1,y1,x2,y2);int gdriver=DETECT,gmode; /* 定义驱动程序,设置图形模式 */ Initgraph(&gdriver,&gmode,”c:tc”); /* 初始化图形系统,驱动程序所在路径 */ Cleardevice(); /* 清空屏幕 */ Setbkcolor(15); /* 设置背景颜色(白色)*/ Line(x1,y1,x2,y2); /* 画编程轨迹直线AB*/ arc(x4,y4, ,R);/* 画编程轨迹圆弧BC */ Line(x1,y1,x2,y2); /* 画刀具中心轨迹直线AB */ arc (x4,y4,,R+

12、20); /* 画刀具中心轨迹直线BC */ Getch(); /* 关闭程序 */ Closegraph();/ *关闭图形 */ 仿真结果基于Visual C 6.0和Microsoft Excel软件,对前面所提出算法进行实现和仿真。刀具半径补偿进行中(如图3-1)坐标A(0,0),B(300,200), C点(694.517,77.4)和R=231.33.图3-1 刀具半径补偿进行中G41和G02方式下 伸长型转接仿真结果A(-11.09,16.64),B(287.15,215.47),C(714.24,80.7)。3.1.2 G42和G02刀具半径补偿准备工作设刀具半径r=20mm的

13、情况下带入公式: 在中,已知,; =(R+r刀具半径)。根据余弦定理可求出的模由上式可求得直线与圆弧的两个交点,离8点近的为点,在x轴和y轴上的投影为 点的坐标 刀具半径补偿清单: /* Lurunmin exp1.c LINE*/* Lurunmin exp1.c ARC*/ #include /* 文件包含命令 */Main() /* 主函数 */ float x1,x2,x3,x4,y1,y2,y3,y4 ,; float , ,R,a0 ,ab;int r=20;a0=sqrt(); Scanf(“%d%d%d%d”,&x1,&x2,&x3,&x4); Scanf(“%d%d%d%d”

14、, &y1,&y2,&y3,&y4); /*输入A,B,C点和圆心坐标*/ Scanf(“%d”,&R) =arcsin(); =arccos(); =-; ab=a0cos-; /*AB的模长*/x1=x1+rsin,y2=y1-rcos;x2=x1+rsin+abcos,y2=y1-rcos+ab*sina; /*B的坐标*/ Printf(“ddd%d%d%dn”,x1,y1,x1,y1,x2,y2);int gdriver=DETECT,gmode; /* 定义驱动程序,设置图形模式 */ Initgraph(&gdriver,&gmode,”c:tc”); /* 初始化图形系统,驱动

15、程序所在路径 */ Cleardevice(); /* 清空屏幕 */ Setbkcolor(15); /* 设置背景颜色(白色)*/ Line(x1,y1,x2,y2); /* 画编程轨迹直线AB*/ arc(x4,y4, ,R);/* 画编程轨迹圆弧BC */ Line(x1,y1,x2,y2); /* 画刀具中心轨迹直线AB */ arc (x4,y4,,R+20); /* 画刀具中心轨迹直线BC Getch(); /* 关闭程序 */ Closegraph();/ *关闭图形 */ 仿真结果基于Visual C 6.0和Microsoft Excel软件,对前面所提出算法进行实现和仿真

16、。刀具半径补偿进行中在A(0,0),B(300,200),C(694.517)和R=231.33代入图3-2刀具半径补偿进行中G42和G02方式下 伸长型转接结果为A(11.09,-16.64),b(312.93,84.58),c(674.79,74.1).3.1.3 G41和G03刀具半径补偿准备工作刀具半径补偿清单:/* Lurunmin exp1.c LINE*/* Lurunmin exp1.c ARC */ #include /* 文件包含命令 */Main() /* 主函数 */ float x1,x2,x3,x4,y1,y2,y3,y4 ,; float , ,R,a0 ,ab;

17、int r=20;a0=sqrt(); Scanf(“%d%d%d%d”,&x1,&x2,&x3,&x4); Scanf(“%d%d%d%d”, &y1,&y2,&y3,&y4); /*输入A,B,C点和圆心坐标*/ Scanf(“%d”,&R) =arcsin(); =arccos(); =-; ab=a0cos+; /*AB的模长*/x1=x1-rsin,y2=y1+rcos;x2=x1-rsin+abcos,y2=y1+rcos+ab*sina; /*B的坐标*/ Printf(“ddd%d%d%dn”,x1,y1,x1,y1,x2,y2);int gdriver=DETECT,gmod

18、e; /* 定义驱动程序,设置图形模式 */ Initgraph(&gdriver,&gmode,”c:tc”); /* 初始化图形系统,驱动程序所在路径 */ Cleardevice(); /* 清空屏幕 */ Setbkcolor(15); /* 设置背景颜色(白色)*/ Line(x1,y1,x2,y2); /* 画编程轨迹直线AB*/ arc(x4,y4, ,R);/* 画编程轨迹圆弧BC */ Line(x1,y1,x2,y2); /* 画刀具中心轨迹直线AB */ arc (x4,y4,,R-20); /* 画刀具中心轨迹直线BC*/Getch(); /* 关闭程序 */ Clos

19、egraph();/ *关闭图形 */ 仿真结果基于Visual C 6.0和Microsoft Excel软件,对前面所提出算法进行实现和仿真。刀具半径补偿进行中。图3-3刀具半径补偿进行中G41和G03方式下 伸长型转接。代入A(0,0),B(300,200),C(338.57,611.32), R=231.33。图3-3刀具半径补偿进行中G41和G03方式下 伸长型转接得A(-11.09,16.64),B(290.74,217.86),C(327.93,594.38)3.1.4 G42和G03刀具半径补偿准备工作刀具半径补偿清单:/* Lurunmin exp1.c LINE*/* Lu

20、runmin exp1.c ARC */ #include /* 文件包含命令 */Main() /* 主函数 */ float x1,x2,x3,x4,y1,y2,y3,y4 ,; float , ,R,a0 ,ab;int r=20;a0=sqrt(); Scanf(“%d%d%d%d”,&x1,&x2,&x3,&x4); Scanf(“%d%d%d%d”, &y1,&y2,&y3,&y4); /*输入A,B,C点和圆心坐标*/ Scanf(“%d”,&R) =arcsin(); =arccos(); =-; ab=a0cos+; /*AB的模长*/x1=x1+rsin,y2=y1-rco

21、s;x2=x1+rsin+abcos,y2=y1-rcos+ab*sina; /*B的坐标*/ Printf(“ddd%d%d%dn”,x1,y1,x1,y1,x2,y2);int gdriver=DETECT,gmode; /* 定义驱动程序,设置图形模式 */ Initgraph(&gdriver,&gmode,”c:tc”); /* 初始化图形系统,驱动程序所在路径 */ Cleardevice(); /* 清空屏幕 */ Setbkcolor(15); /* 设置背景颜色(白色)*/ Line(x1,y1,x2,y2); /* 画编程轨迹直线AB*/ arc(x4,y4, ,R);/*

22、 画编程轨迹圆弧BC */ Line(x1,y1,x2,y2); /* 画刀具中心轨迹直线AB */ arc (x4,y4,,R+20); /* 画刀具中心轨迹直线BC Getch(); /* 关闭程序 */ Closegraph();/ *关闭图形 */ 仿真结果基于Visual C 6.0和Microsoft Excel软件,对前面所提出算法进行实现和仿真。刀具半径补偿进行中代入A(0,0),B(300,200),C(338.57,611.32)三点和R=231.33。图3-4 刀具半径补偿进行中G42和G03方式下 伸长型转接得出A(11.09,-16.64)B(309.34,182.1

23、9),C(349.2,628.26)。3.2 缩短型3.2.1 G41和G02是加工不出来的3.2.2 G41和G03刀具半径补偿准备工作这个里面要用到圆弧接圆弧的情况,直线的就参考前面编程就可以了。刀具半径补偿清单:/* Lurunmin exp1.c LINE*/* Lurunmin exp1.c ARC*/ #include /* 文件包含命令 */Main() /* 主函数 */ float x1,x2,x3,x4,y1,y2,y3 ,y4,; float , ,=20,oo;int r=20;oo=sqrt(); Scanf(“%d%d%d%d%d%d%d%dn”, &x1,&y1,

24、&x2,&y2,&x3,&y3,&x4,&y4); /*输入头2个点和2个点的圆心坐标*/ Scanf(“%d”,&); /*输入后一个圆的半径*/ =arccos(); oo=sqrt(+); /*求2个圆心的距离*/ ; =+; =arccos(+); ; /*B的坐标*/ Printf(“dd n”,); x1=x1-rsin,y2=y1+rcos;x2=x1-rsin+abcos,y2=y1+rcos+ab*sina;int gdriver=DETECT,gmode; /* 定义驱动程序,设置图形模式 */ Initgraph(&gdriver,&gmode,”c:tc”); /* 初

25、始化图形系统,驱动程序所在路径 */ Cleardevice(); /* 清空屏幕 */ Setbkcolor(15); /* 设置背景颜色(白色)*/ Line(x1,y1,x2,y2); /*画直线AB*/Arc (x4,y4, ,r); /*画编程圆弧轨迹BC*/Line(,); /* 画头刀具段轨迹直线AB*/Arc(x2,y2, ,r); /*换前段刀具中心圆弧轨迹BB*/ Arc(x4,y4, , ,-20); /* 画后段刀具中心圆弧轨迹BC*/ Getch(); /* 关闭程序 */ Closegraph();/ *关闭图形 */ 仿真结果基于Visual C 6.0和Micr

26、osoft Excel软件,对前面所提出算法进行实现和仿真。刀具半径补偿进行中,代入A(0,0),B(243.34,136.8),C(441.69,-68.92)圆心(342.47,33.94),R=142.85。图3-2-1刀具半径补偿进行中G41和G03方式下缩短型转接仿真出A(-22.95,40.83)B(221.57,176.13)B(274.53,104.43)C(410.4,-36.55)。3.2.3 G42和G02刀具半径补偿准备工作刀具半径补偿清单:/* Lurunmin exp1.c LINE*/* Lurunmin exp1.c ARC */ #include /* 文件包

27、含命令 */Main() /* 主函数 */ float x1,x2,x3,x4,y1,y2,y3 ,y4,; float , ,R,,oo;int r=20,= =r;oo=sqrt(); Scanf(“%d%d%d%d%d%d%d%dn”, &x1,&y1,&x2,&y2,&x3,&y3,&x4,&y4); /*输入3个点和圆心坐标*/ Scanf(“%dn”,&); /*输入第二个圆的半径*/ =arccos(); oo=sqrt(+); /*求2个圆心的距离*/ ; =+; =arcos(+); ; /*B的坐标*/ Printf(“dd n”,); x1=x1+rsin,y2=y1-

28、rcos;x2=x1+rsin+abcos,y2=y1-rcos+ab*sina;int gdriver=DETECT,gmode; /* 定义驱动程序,设置图形模式 */ Initgraph(&gdriver,&gmode,”c:tc”); /* 初始化图形系统,驱动程序所在路径 */ Cleardevice(); /* 清空屏幕 */ Setbkcolor(15); /* 设置背景颜色(白色)*/ Line(x1,y1,x2,y2); /*画直线AB*/Arc (x4,y4, ,r); /*画编程圆弧轨迹BC*/Line(,); /* 画头刀具段轨迹直线AB*/Arc(x2,y2, ,r)

29、; /*换前段刀具中心圆弧轨迹BB*/ Arc(x4,y4, , ,-20); /* 画后段刀具中心圆弧轨迹BC*/ Getch(); /* 关闭程序 */ Closegraph();/ *关闭图形 */ 仿真结果基于Visual C 6.0和Microsoft Excel软件,对前面所提出算法进行实现和仿真。刀具半径补偿进行中代入A(0,0)B(243.34,136.8)C(100.02,369.64)圆心(206.98,274.95)R=142.85。图3-2-2刀具半径补偿进行中G42和G02方式下缩短型转接得:A(198.94,-33.7)B(262.28,103.1)C(128.97

30、.344.01)B(233.5,174.19)参 考 文 献1 王永章,数控技术. 北京:高等教育出版社,2001.2 杜国臣,数控机床编程. 北京:机械工业出版社,2004.3 李宏胜,机床数控技术及应用. 北京:机械工业出版社,2003.4 全国数控培训网络天津分中心,数控机床. 北京:机械工业出版社,1997.5 许祥泰,数控加工编程实用技术. 北京:机械工业出版社,2002.6 李郝林,机床数控技术. 北京:机械工业出版社,2004.7 林 宋,现代数控机床. 北京:化学工业出版社,2003.8 刘启中,现代数控技术及应用. 北京:机械工业出版社,2000.9 严爱珍,机床数控原理与系统. 北京:机械工业出版社,199910 陈志雄,数控机床与数控编程技术. 北京:电子工业出版社,2003.11 杨有君,数控技术,北京:机械工业出版社,2005.致 谢感谢杨光老师在本次课程设计期间给予我的帮助和指导。由于时间和水平有限,本设计难免存在缺点和错误,望指导老师和同学们批评指正。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

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

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁