当前位置:文档之家› DDA圆弧插补

DDA圆弧插补

DDA圆弧插补
DDA圆弧插补

一.实验名称:DDA圆弧插补(四象限、左移规格化、半加载、全加载)二.实验原理:

三.实验内容:

#include

#include

{

int xa,ya,xe,ye; /*起点和终点横纵坐标*/

int jx,jy,rx,ry;

int dx,dy,ex,ey;

int ix,iy; /*ix,iy为在程序运行过程中各点的横纵坐标*/ int a,b,c,d;

int i=1,w;

printf("半加载及左移规格化顺弧请输入1,逆弧输入2\n");

printf("全加载及左移规格化顺弧请输入3,逆弧输入4\n");

scanf("%d",&w);

printf("请输入圆弧的起点和终点坐标\n");

scanf("%d,%d,%d,%d",&xa,&ya,&xe,&ye);

jx=abs(ya),jy=abs(xa);/*给累加变量赋初值*/

rx=ry=dx=dy=0;

ix=xa,iy=ya;/*定义刀具起点*/

ex=abs(xa-xe);

ey=abs(ya-ye);

/*调用顺弧计算程序*/

if (w==1)

{

while(jx<8&&jy<8)

{

jx=jx*2;

jy=jy*2;

i=i*2;

}/*左移规格化*/

rx=ry=16;/*半加载赋值*/

for(;ex>0||ey>0;)

{

if((xa>0&&ya>0)||(xa==0&&ya>0))

a=1,b=-1,c=-1,d=1;

else if((xa<0&&ya>0)||(xa<0&&ya==0))

a=1,b=1,c=1,d=-1;

else if((xa<0&&ya<0)||(xa==0&&ya<0))

a=-1,b=1,c=-1,d=1;

else if((xa>0&&ya<0)||(xa>0&&ya==0))

a=-1,b=-1,c=1,d=-1;

/*给不同象限走刀的变量赋值*/

if(ex!=0)/*x方向走刀的计算*/

{

rx=rx+jx;

if(dx!=0)

{ix=ix+dx;

ex=ex-1;

rx=rx%32;

}

}

if(ey!=0)/*y方向走刀的计算*/

{

ry=ry+jy;

dy=b*ry/32;

if(dy!=0)

{iy=iy+dy;

ey=ey-1;

ry=ry%32;

}

}

printf("ix=%d,iy=%d\n",ix,iy);/*输出刀具所在点坐标*/

if(dy!=0)

jx=jx+c*i;

if(dx!=0)

jy=jy+d*i;

}}

if(w==2)

{

while(jx<8&&jy<8)

{

jx=jx*2;

jy=jy*2;

i=i*2;

}/*左移规格化*/

rx=ry=16;/*半加载赋值*/

for(;ex>0||ey>0;)

{

if((xa>0&&ya>0)||(xa>0&&ya==0))

a=-1,b=1,c=1,d=-1;

else if((xa<0&&ya>0)||(xa==0&&ya>0))

a=-1,b=-1,c=-1,d=1;

else if((xa<0&&ya<0)||(xa<0&&ya==0))

a=1,b=-1,c=1,d=-1;

else if((xa>0&&ya<0)||(xa==0&&ya<0))

a=1,b=1,c=-1,d=1;

/*给不同象限走刀的变量赋值*/

if(ex!=0)

{

rx=rx+jx;

dx=a*rx/32;

if(dx!=0)/*x方向走刀的计算*/

{ix=ix+dx;

ex=ex-1;

rx=rx%32;

}

}

if(ey!=0)/*y方向走刀的计算*/

{

ry=ry+jy;

dy=b*ry/32;

if(dy!=0)

{iy=iy+dy;

ey=ey-1;

ry=ry%32;

}

}

printf("ix=%d,iy=%d\n",ix,iy);/*输出刀具所在点坐标*/

if(dy!=0)

jx=jx+c*i;

if(dx!=0)

jy=jy+d*i;

}}

if (w==3)

{while(jx<8&&jy<8)

{

jx=jx*2;

jy=jy*2;

i=i*2;

}/*左移规格化*/

rx=ry=31;/*全加载赋值*/

for(;ex>0||ey>0;)

{

if((xa>0&&ya>0)||(xa==0&&ya>0))

a=1,b=-1,c=-1,d=1;

else if((xa<0&&ya>0)||(xa<0&&ya==0))

a=1,b=1,c=1,d=-1;

else if((xa<0&&ya<0)||(xa==0&&ya<0))

a=-1,b=1,c=-1,d=1;

else if((xa>0&&ya<0)||(xa>0&&ya==0))

a=-1,b=-1,c=1,d=-1;

/*给不同象限走刀的变量赋值*/

if(ex!=0)/*x方向走刀的计算*/

{

rx=rx+jx;

dx=a*rx/32;

if(dx!=0)

{ix=ix+dx;

ex=ex-1;

rx=rx%32;

}

}

if(ey!=0)/*y方向走刀的计算*/

{

ry=ry+jy;

dy=b*ry/32;

if(dy!=0)

{iy=iy+dy;

ey=ey-1;

ry=ry%32;

}

}

printf("ix=%d,iy=%d\n",ix,iy);/*输出刀具所在点坐标*/

if(dy!=0)

jx=jx+c*i;

if(dx!=0)

jy=jy+d*i;

}}

/*调用逆弧计算程序*/

if(w==4)

{

while(jx<8&&jy<8)

{

jx=jx*2;

jy=jy*2;

i=i*2;

}/*左移规格化*/

rx=ry=31;/*全加载赋值*/

for(;ex>0||ey>0;)

{

if((xa>0&&ya>0)||(xa>0&&ya==0))

a=-1,b=1,c=1,d=-1;

else if((xa<0&&ya>0)||(xa==0&&ya>0))

a=-1,b=-1,c=-1,d=1;

else if((xa<0&&ya<0)||(xa<0&&ya==0))

a=1,b=-1,c=1,d=-1;

else if((xa>0&&ya<0)||(xa==0&&ya<0))

a=1,b=1,c=-1,d=1;

/*给不同象限走刀的变量赋值*/

if(ex!=0)

{

rx=rx+jx;

dx=a*rx/32;

if(dx!=0)/*x方向走刀的计算*/

{ix=ix+dx;

ex=ex-1;

rx=rx%32;

}

}

if(ey!=0)/*y方向走刀的计算*/

{

ry=ry+jy;

dy=b*ry/32;

if(dy!=0)

{iy=iy+dy;

ey=ey-1;

ry=ry%32;

}

}

printf("ix=%d,iy=%d\n",ix,iy);/*输出刀具所在点坐标*/

if(dy!=0)

jx=jx+c*i;

if(dx!=0)

jy=jy+d*i;

}}

}

四.实验结果:

仿真:

半加载及左移规格化顺弧第一象限:

半加载及左移规格化顺弧第三象限:

半加载及左移规格化逆弧第二象限:

半加载及左移规格化逆弧第四象限:

全加载及左移规格化顺弧第三象限:

全加载及左移规格化逆弧第四象限:

分析:

本程序默认寄存器是5位,圆弧圆心在原点,圆弧在但一象限内的情况,不考虑其他情况。

直线插补与圆弧插补程序设计

直线插补与圆弧插补程序设计

一.直线插补 1. 直线插补程序流程图

#i nclude #in elude vgraphics.h> #i nclude void cb_li ne(i nt { x1, int y1, int x2, int y2) 直线插补程序流程图 2.直线插补程序设计 int dx, dy, n, k, i, f;

int x, y; dx = abs(x2-x1); dy = abs(y2-y1); n = dx + dy; if (x2 >= x1) { k y2 >= y1 ? 1: 4; x x1; y y1; } else { k y2 >= y1 ? 2: 3; x x2; y y2; } putpixel(x, y, 1); for (i = 0, f = 0; i < n; i++) if (f >= 0) switch (k) { case 1: else switch (k) { case 1: putpixel(x++, y, f -= dy; break; case 2: putpixel(x, y++, f -= dx; break; case 3: putpixel(x--, y, f -= dy; break; case 4: 1); 1); 1); putpixel(x, y--, 1); } f -= dx; break;

putpixel(x, f += dx; break; y++, 1); case 2 : putpixel(x--, f += dy; break; y, 1); case 3 : putpixel(x, f += dx; break; y--, 1); case 4 : putpixel(x++, f += dy; break; y, 1); } } 二. 圆弧插补 2.1. 四象限圆弧插补程序流程图int main() { cb_line(0,0,15,20); /* <--- you forgot return 0; } here */

逐点比较法直线插补圆弧插补实例

逐点比较法直线插补 (1)偏差函数构造 对于第一象限直线OA上任一点(X,Y):X/Y = Xe/Ye 若刀具加工点为Pi(Xi,Yi),则该点的偏差函数Fi可表示为: 若Fi= 0,表示加工点位于直线上; 若Fi> 0,表示加工点位于直线上方; 若Fi< 0,表示加工点位于直线下方。 (2)偏差函数字的递推计算 采用偏差函数的递推式(迭代式):既由前一点计算后一点 Fi =Yi Xe -XiYe 若Fi>=0,规定向+X 方向走一步 Xi+1 = Xi +1 Fi+1 = XeYi –Ye(Xi +1)=Fi –Ye 若Fi<0,规定+Y 方向走一步,则有 Yi+1 = Yi +1 Fi+1 = Xe(Yi +1)-YeXi =Fi +Xe (3)终点判别 直线插补的终点判别可采用三种方法。 1)判断插补或进给的总步数:2)分别判断各坐标轴的进给步数;3)仅判断进给步数较多的坐标轴的进给步数。 (4)例 对于第一象限直线OA,终点坐标Xe=6 ,Ye=4,插补从直线起点O开始,故F0=0 。终点判别是判断进给总步数N=6+4=10,将其存入终点判别计数器中,每进给一步减1,若N=0,则停止插补。

逐点比较法圆弧插补(1)偏差函数构造 任意加工点Pi(Xi,Yi),偏差函数Fi可表示为 若Fi=0,表示加工点位于圆上;

若Fi >0,表示加工点位于圆外; 若Fi <0,表示加工点位于圆内 (2)偏差函数的递推计算 1) 逆圆插补 若F ≥0,规定向-X 方向走一步 若Fi<0,规定向+Y 方向走一步 2) 顺圆插补 若Fi ≥0,规定向-Y 方向走一步 若Fi<0,规定向+y 方向走一步 (3)终点判别 1)判断插补或进给的总步数: 2)分别判断各坐标轴的进给步数: (4)例 对于第一象限圆弧AB ,起点A (4,0),终点B (0,4) ???+-=-+-=-=++12)1(122211i i i i i i i X F R Y X F X X ???++=-++=+=++12)1(122211i i i i i i i Y F R Y X F Y Y ???+-=--+=-=++12)1(122211i i i i i i i Y F R Y X F Y Y ???++=-++=+=++12)1(122211i i i i i i i X F R Y X F X X b a b a Y Y X X N -+-=b a x X X N -= b a y Y Y N -=

圆弧插补C语言程序

圆弧插补c语言源代码 专业2008-11-24 20:50:26 阅读253 评论0 字号:大中小订阅 #include #include int ArcXY(double dfx0,double dfy0,double dfrx, double dfry,int angle); int symbol(double number); main() { ArcXY(0,0,-3,5,360); getch(); } int ArcXY(double dfx0,double dfy0,double dfrx, double dfry,int angle) { FILE *f1; double i,j,dx,dy,dfr,x,y,ang,step,f = 0.01; int flag,tempx,tempy,statex,statey,direction = 1; dfr = sqrt((dfrx - dfx0) * (dfrx - dfx0) + (dfry - dfy0) * (dfry - dfy0)); if(dfx0 == 0) { dfx0 = 1; dfrx = dfrx + 1; statex =1; } if(dfy0 == 0) { dfy0 = 1; dfry = dfry + 1; statey =1; } dfrx = 2 * dfx0 - dfrx; i = dfx0 - dfrx; j = dfy0 - dfry; x = dfx0 ; y = dfy0 ; step = ang = 180 * 2 * asin(f/(2*dfr))/3.1415926;

基于FPGA的逐点比较圆弧插补算法设计

二○一三届毕业设计 基于FPGA逐点比较圆弧插补算法设计 学院:电子与控制工程学院 专业:电子科学与技术 姓名:…….. 学号:……… 指导教师:…….. 完成时间:2013年5月 二〇一三年五月

摘 要 ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ 装 ┊ ┊ ┊ ┊ ┊ 订 ┊ ┊ ┊ ┊ ┊ 线 ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ 摘 要 本课题主要是研究基于VHDL 实现数控系统中的逐点比较圆弧插补,要求圆弧运动过程平滑,在各象限能顺利过渡,并有较小的设计误差,能与运动控制部分很好的集成,实现较高的切割频率。 本课题采用QuartusII 软件来调试程序,并进行波形仿真。主要的工作如下: 1) 理解数控系统中逐点比较圆弧插补算法的原理及其实现方法; 2) 通过硬件描述语言VHDL 在FPGA 上实现上述算法; 3) 完成圆弧插补的仿真与测试。 关键词:VHDL ,FPGA ,逐点比较法,QuartusII

ABSTRACT ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ 装 ┊ ┊ ┊ ┊ ┊ 订 ┊ ┊ ┊ ┊ ┊ 线 ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ┊ ABSTRACT This topic mainly studies based on VHDL realization of point by point comparison circular arc interpolation in nc system, the movement for arc process smooth, in each quadrant can smooth transition, and a relatively small design error, can very good integration with motion control part, realize the high frequency of cutting. This subject adopts software QuartusII to debug program and waveform simulation. The main work is as follows: 1. Understand CNC system the principle of point by point comparison in circular arc interpolation algorithm and its realization method 2. Through the hardware description language VHDL FPGA to realize the above algorithms. 3. Finish arc interpolation of simulation and test KEY WORDS : VHDL, FPGA, point-by-point comparison, QUARTUS II

基于Matlab的四象限圆弧插补程序

X0=input('请输入起点横轴坐标x: '); Y0=input('请输入起点纵轴坐标y: '); NXY=input('请输入差补步数: '); pace=input('请输入差补步长: '); RNSS=input('请选择差补走向(1代表顺时针/2代表逆时针): '); XM=X0; YM=Y0; %画基准圆 R=sqrt(X0*X0+Y0*Y0); alpha=0:pi/20:2*pi; xx=R*cos(alpha); yy=R*sin(alpha); plot(xx,yy,'g:'); hold on; axis equal; %针对跨象限运行时对ZF初始化(由于在跨象限运行时不改变ZF值所以必须对其初始化) ZF=(RNSS==1)*(((Y0==0)*((X0>0)*4+(X0<0)*3))+((X0==0)*((Y0>0)*1+(Y0<0) *2)))+... (RNSS~=1)*(((Y0==0)*((X0>0)*3+(X0<0)*4))+((X0==0)*((Y0>0)*2+(Y0<0)*1) )); %建立NXY次循环来实现差补计算与绘图 for num=1:NXY %FM值判断 FM=XM*XM+YM*YM-X0*X0-Y0*Y0; %象限判断(RNS为1,2,3,4分别代表1,2,3,4象限) RNS=(XM>0)*((YM>0)*1+(YM<0)*4)+(XM<0)*((YM>0)*2+(YM<0)*3); %走步计算(RNS百位为1表示逆时针画圆,十位为1表示FM<0,个位数字表示所在

象限,ZF代表走步方向) switch RNS+((FM<0)*10)+(RNSS~=1)*100 case 001 ZF=4; case 002 ZF=1; case 003 ZF=3; case 004 ZF=2; case 011 ZF=1; case 012 ZF=3; case 013 ZF=2; case 014 ZF=4; case 101 ZF=2; case 102 ZF=4; case 103 ZF=1; case 104 ZF=3; case 111 ZF=3; case 112

逐点比较法直线插补圆弧插补实例

逐点比较法直线插补(1)偏差函数构造 对于第一象限直线OA上任一点(X,Y):X/Y=Xe/Ye 若刀具加工点为Pi(Xi,Yi),则该点的偏差函数F i 可表示 为 : 若Fi=0,表示加工点位于直线上; 若Fi>0,表示加工点位于直线上方; 若Fi<0,表示加工点位于直线下方。 (2)偏差函数字的递推计算 采用偏差函数的递推式(迭代式):既由前一点计算后一点 Fi=YiXe-XiYe 若Fi>=0,规定向+X 方向走一步 Xi+1=Xi+1 Fi+1=XeYi–Ye(Xi+1)=Fi–Ye 若Fi<0,规定+Y方向走一步,则有 Yi+1=Yi+1 Fi+1=Xe(Yi+1)-YeXi=Fi+Xe (3)终点判别 直线插补的终点判别可采用三种方法。 1)判断插补或进给的总步数:2)分别判断各坐标轴的进给步数;3)仅判断进给步数较多的坐标轴的进给步数。(4)例 对于第一象限直线OA,终点坐标Xe=6,Ye=4,插补从直线起点O开始,故F0=0。终点判别是判断进给总步数 N=6+4=10,将其存入终点判别计数器中,每进给一步减1,若N=0,则停止插补。

逐点比较法圆弧插补 (1)偏差函数构造 任意加工点Pi(Xi,Yi),偏差函数Fi可表示为若Fi=0,表示加工点位于圆上; 若Fi>0,表示加工点位于圆外; 若Fi<0,表示加工点位于圆内 (2)偏差函数的递推计算 1)逆圆插补 若F≥0,规定向-X方向走一步 X i1X i1 F i1(X i1)2Y i 2R2F i2X i1 若Fi<0,规定向+Y方向走一步 Y i1Y i1 F i1X i2(Y i1)2R2F i2Y i1

欧姆龙NJ直线插补及圆弧插补

NJ网络实验4 实验目的:a.实现空间一组4个工位的合成直线运动。 工位1(0,0),工位2(2000,2000),工位3(2000, 0),工位4(0,0) b.使用圆弧插补功能,实现下图运动轨迹。(图中数值仅供参考,可自行修改) C.学习齿轮比(变速)MC_gearin,MC_gearout指令。速度比要求3比1 实验器材:NJ、G5伺服及伺服电机两套;E3ZM-V81两个、网线若干(AT部门NJ样机箱)。 参考资料:NJ教材、NJ操作手册、运动控制指令手册 指导人员: 实验内容: 1.样机搭建、网络组建、轴设置在前报告中已经说明,此处省略。其中轴设置中原点返回设置选择如下图 两轴原点返回均为此设置

2.建立轴组: 轴设置完毕后,在“配置和设置”中右键点击轴组设置,在下拉菜单中左键点击添加轴组设置,如下图 添加后,左键双击MC_Group000;在轴组基本设置中“轴组使用”选择“使用轴组”如下图: 构成选择“2轴” 分别将“轴A0”分配MC_Axis000(0);“轴A1”分配MC_Axis001(1)如下图

点击左侧“轴组操作设置”在下图中设置最大插补速度及加速度等, 轴设置完毕 3.编写程序 A、准备程序程序 本次程序依然需要MC_POWER及MC_HOME指令由于与上次程序相同这里不多介绍,程序如下图:

原点返回指令 “MC_GroupEnable”轴组使能指令,以下为手册截图 由于直线插补指令属于轴组指令,如想进行直线插补首先要进行轴组使能指令,否则无法使用对应指令。

将上一步设置好的MC_Group000使能,程序如下 指令“MC_GroupDisable”使能解除指令 与MC_GroupEnable对应指令,被轴组使能后被使能轴只能使用轴组指令,而不能使用轴指令,例如MC_Move等指令,所以程序中需要编写MC_GroupEnable程序

直线及圆弧插补程序--逐点比较法

此程序是根据《微型计算机控制技术》(第二版)清华大学出版社 第三章数字控制技术——3.2插补原理中的3.2.1逐点比较法的直线插补,3.2.2逐点比较法圆弧插补编写的。其中的变量定义,原理依据均来源于此,如有疑问,请参考书中的讲解。尤其是例子,以下两个程序的第一个运行图均与例题中的一致。 一、四象限直线插补程序 分别加工第一、二、三、四象限直线,起点均为(0,0),终点坐标为(NX,NY),进行插补计算。 程序中(NX,NY)为终点坐标;NXY为总步数;XOY=1,2,3,4,分别为第一、二、三、四象限; ZF=1,2,3,4,分别代表+x,-x,+y,-y走步方向;FM为加工点偏差,初值为0。 源程序: # include "stdio.h" # include "string.h" # include "math.h" void main() { int NX,NY,NXY,BS,XOY,ZF; int FM=0; char a[10]="+X",b[10]="-X",c[10]="+Y",d[10]="-Y",e[10]; printf("\n\n请输入NX,NY\n"); scanf("%d %d",&NX,&NY); {if(NX>0) if(NY>0)

XOY=1; else XOY=4; else if(NY>0) XOY=2; else XOY=3;} printf("终点在第%d象限\n",XOY); printf("\n 步数坐标进给偏差计算终点判断\n\n"); BS=fabs(NX) + fabs(NY); for(NXY= fabs(NX) + fabs(NY)-1;NXY>=0;NXY--) { if(FM>=0) {if(XOY==1||XOY==4) { ZF=1; strcpy(e,a);} else { ZF=2; strcpy(e,b); } FM=FM-fabs(NY); printf(" %d %s FM=%d NXY=%d\n\n",BS-NXY,e,

C语言模拟直线插补与圆弧插补程序设计

数控技术课程设计 说明书 设计题目直线插补与圆弧插补程序设计 机械设计以及自动化专业机械工程学院 机械102班 设计者青岛理工大学 2013年6月20

日 目录 1.设计题目 (1) 2.目录 (2) 3.直线插补流程图 (3) 4.直线插补程序 (4) 5.程序结果 (8) 6.圆弧插补流程图 (9) 7.圆弧插补程序 (10)

8.程序结果 (21) 一.直线插补 1.直线插补程序流程图 2.直线插补程序设计

#include "stdio.h" int i,X,Y,X0,Y0,Xe,Ye,F,N; int a[30][2]; void main() { int m; int menu(); void yi(); void er(); void san(); void si(); void te(); void shuchu(); m=menu(); a[0][0]=X0; a[0][1]=Y0; switch(m) { case 1:yi();shuchu();break; case 2:er();shuchu();break; case 3:san();shuchu();break; case 4:si();shuchu();break; case 5:te();shuchu();break; default:printf("无法插补\n"); } } int menu() { int t; printf("输入起点坐标\n"); scanf("%d,%d",&X0,&Y0); printf("输入终点坐标\n"); scanf("%d,%d",&Xe,&Ye); if (Xe>=X0&&Ye>=Y0) t=1; else if (Xe<=X0&&Ye>=Y0) t=2; else if (Xe<=X0&&Ye<=Y0) t=3; else if (Xe>=X0&&Ye<=Y0) t=4;

逐点比较法直线插补圆弧插补实例

N=6+4=10,将其存入终点判别计数器中,每进给一步减 1,若N=0,则停止插补。 (1)偏差函数构造 对于第一象限直线 0A 上任一点(X,Y): X/Y = Xe/Ye Pi (Xi , Yi ),则该点的偏差函数 Fi 可表示为: (2 )偏差函数字的递推计算 采用偏差函数的递推式(迭代式):既由前一点计算后一点 Fi =Yi Xe -XiYe 若Fi>=0,规定向 +X 方向走 Xi+1 = Xi +1 Fi+1 = XeYi 讦e(Xi +1)=Fi 讦e 若Fi<0,规定+Y 方向走一步,则有 Yi+1 = Yi +1 Fi+1 = Xe(Yi +1)-YeXi =Fi +Xe (3 )终点判别 直线插补的终点判别可采用三种方法。 逐点比较法直线插补 若刀具加工点为 若 Fi= 0, 表示加工点位于直线上; 若 Fi> 0, 表示加工点位于直线上方; 若 Fi< 0, 表示加工点位于直线下方。

1)判断插补或进给的总步数:2)分别判断各坐标轴的进给步数;3)仅判断进给步数较多的坐标轴的进给步数。 (4)例 对于第一象限直线0A终点坐标Xe=6 ,Ye=4,插补从直线起点0开始,故F0=0。终点判别是判断进给总步数

10 4 逐点比较法圆弧插补(1)偏差函数构造 任意加工点Pi (Xi , Yi),偏差函数Fi可表示为 若Fi=0,表示加工点位于圆上; 若Fi >0,表示加工点位于圆外; 2

若Fi<0,表示加工点位于圆内 (2)偏差函数的递推计 算 1)逆圆插补 若F> 0,规定向-X方向走一步X i 1 X i 若Fi<0,规定向+Y方向走一步 2)顺圆插补 若Fi > 0,规定向-Y方向走一步若Fi<0,规定向+y方向走一步 (3 )终点判 别 1 )判断插补或进给的总步数: 2)分别判断各坐标轴的进给步数: (4)例F i Y i F i Y i F i X i 1 F i 1 N x 对于第一象限圆弧AB,起点A(4,0), (X i Y i X i2 Y i X i2 X i (X i X a X a 终点 1 1)2 (Y i (Y i 1 1)2 X b X b B (0, Y i2 1)2 1)2 Y i2 Y a R2 R2 R2 R2 Y b N y F i F i F i F i Y a 2X i 2Y i 2Y i 2X i Y b

直线与圆弧插补实验

实验一工作台直线插补运动 1 实验目的 1.了解工作台直线插补原理和算法; 2.在掌握直线插补原理的基础上实现平面绘图。 2 实验设备 1.直线/旋转工作台; 2.工作台控制箱一台; 3.笔架夹持器、画笔及画板。 3 实验原理 本实验利用逐点比较法插补直线,逐点比较法在第一象限的直线插补原理如下图: 现加工OE直线。如果刀具动点在OE直线上方或在该直线上,则令刀具沿X正方向进给一步;若刀具动点在OE直线下方,则令刀具沿Y轴正方向进给一步,如此循环直到加工到E点。判别刀具动点的位置根据偏差判别公式,第一象限直线插补的偏差判别公式如下: Fi = Xe Y i -Y e X i

Fi≥0时,偏差判别公式为 F i+1=F i -Ye 向X正方向进给 Fi<0时,偏差判别公式为 F i+1= F i+Xe,向Y正方向进给 逐点比较法插补节拍:逐点比较法插补需要四个节拍,即偏差判别、进给、偏差计算和终点判别。 4.4 实验步骤 1.按使用说明书上将工作台组合成二自由度直线工作台,安装好笔架夹持器,放置好画板,并正确连接电缆。 2.安装上笔架夹持器及画笔,在桌面相应位置放好画板,使笔尖接触到画板; 3.接通控制箱电源; 4.启动计算机,运行工作台控制软件; 5.在“工作台组合方式”界面中选择X直线工作台和Y直线工作台; 6.单击主界面“工作台复位”按钮,工作台进行回零运动,运动完成后工作台处于零点位置; 7.把画笔安装到笔架夹持器上,使笔尖接触到画板; 8.单击“直线插补”按钮; 9.加速方式选择“梯形”,插补目标X轴填写0,Y轴填写-30,点击“运动”按钮,画出一条直线, 10.插补目标X轴填写30,Y轴填写30,点击“运动”, 11.插补目标X轴填写30,Y轴填写0,点击“运动”,

(完整版)vb圆弧插补程序

Private Sub Command1_Click() Const pi = 3.14159265 Picture1.ForeColor = vbBlack Picture1.DrawWidth = 2 Picture1.Line (50, 500)-(50, 5500) Picture1.Line (50, 5500)-(6500, 5500) Picture1.Line (80, 600)-(50, 500) Picture1.Line (20, 600)-(50, 500) Picture1.Line (6400, 5450)-(6500, 5500) Picture1.Line (6400, 5550)-(6500, 5500) Picture1.ForeColor = vbRed Picture1.DrawWidth = 3 If Int(Text1) = 0 Then Picture1.Circle (50, 5500), Sqr(Int(Text1) * Int(Text1) + Int(Text2) * Int(Text2)) * 400, , Atn(Int(Text4) / Int(Text3)), pi / 2 Else Picture1.Circle (50, 5500), Sqr(Int(Text1) * Int(Text1) + Int(Text2) * Int(Text2)) * 400, , Atn(Int(Text4) / Int(Text3)), Atn(Int(Text2) / Int(Text1)) End If End Sub Private Sub Command2_Click() Dim k, m, j, l, n, F(20) As Integer m = 0 l = Text1.Text k = Text2.Text F(m) = 0 Picture1.ForeColor = vbGreen Picture1.DrawWidth = 3 j = Abs(Int(Text1) - Int(Text3)) + Abs(Int(Text2) - Int(Text4)) Form1.CurrentX = 200 Form1.CurrentY = 200 Print "初始:进给方向 " & "F(m)=0" & " X0=" & Int(Text1) & " Y0=" & Int(Text2) & " ∑ = " & j For n = 1 To j If F(m) >= 0 And j > 0 Then m = m + 1 k = k - 1 F(m) = F(m - 1) - 2 * Abs(k + 1) + 1 Picture1.Line (50 + 400 * l, 5500 - k * 400)-(50 + 400 * l, 5500 - (k + 1) * 400) Form1.CurrentX = 200 Form1.CurrentY = 200 + m * 300 Print "第" & m & "步" & " -△y F(" & m & ")= " & F(m) & " " & "x=" & l & " " & "y="; k & " ∑=" & j - n Else l = l + 1 m = m + 1 Picture1.Line (50 + 400 * l, 5500 - k * 400)-(50 + 400 * (l - 1), 5500 - k * 400) F(m) = F(m - 1) + 2 * Abs(l - 1) + 1 Form1.CurrentX = 200 Form1.CurrentY = 200 + m * 300 Print "第" & m & "步" & " +△x F(" & m & ")= " & F(m) & " " & "x="; l & " " & "y="; k & " ∑=" & j - n End If Next n End Sub Private Sub Command3_Click() Text1.Text = "" Text3.Text = "" End Sub Private Sub Command4_Click() End End Sub

步进驱动系统与数控圆弧插补程序的设计说明

JIANGSU UNIVERSITY OF TECHNOLOGY 课程设计题目: 步进驱动系统与数控圆弧插补程序设计 综合训练题目: 连接电路和机床进给电机驱动器实现第二象限逆圆弧插补加工 学院名称: 机械学院 专 业: 班 级: 姓 名: 学 号: 指导教师: 课程设计与综合训练 说明书

2016年1月 课程设计与综合训练任务书

课程设计题目:步进驱动系统与数控圆弧 插补程序设计 综合训练题目:连接电路和机床进给电机驱动器 实现第二象限逆圆弧插补加工 摘要:通过对微控制器-PLC的学习进行了为期三周的课程设计,本次课程设计是以第二象限逆圆弧插补为例。PLC在工业控制应用非常广泛,主要是因为

其稳定可靠。本设计即根据自制的车数控平台(双轴平台),通过插补运算,利用FX3uPLC发出脉冲,从而控制步进电机的运行,按照插补程序画出轨迹。从而初步掌握步进电机控制系统的设计方法,仿真数控车加工平台加工零件的加工轨迹。 关键词:FX3U-64M ; 步进电机; NR2插补; 目录 第一章概述 (5) 1.1 本次课程设计综合训练对象及容 (5) 1.2 课程设计综合训练任务书及要求 (5) 第二章机电伺服传动系统设计及图形绘制 (7)

2.1 步进电机的选择和齿轮传动比的计算 (7) 2.1.1 系统方案设计 (7) 2.1.2 传动比计算和步进电机的选择 (9) 2.2 圆柱齿轮减速器的设计计算 (15) 2.2.1 X向齿轮减速器的设计计算 (15) 2.2.2 Z向齿轮减速器的设计计算 (17) 2.2.3 丝杠的选择 (19) 2.3 联轴器选择 (24) 2.4 轴承选择 (24) 2.5 键 (25) 2.6 齿轮结构设计的选择 (25) 2.7 传动系统结构设计和图形绘制 (25) 第三章机电伺服系统微控制器电器线路及程序设计 (27) 3.1开环控制系统 (27) 3.2 三菱PLC驱动电路设计 (28) 3.3 PLC插补程序设计概述 (30) 3.4 程序设计调试 (35) 参考文献 (43) 第一章概述

逐点比较法第一象限直线圆弧插补

逐点比较法第一象限直线,圆弧插补编程 逐点比较法是以折线来逼近给定的轨迹,就是每走一步控制系统都要将加工点与给定的图形轨迹相比较,以决定下一步进给的方向,使之逼近加工轨迹。逐点比较法以折线来逼近直线或圆弧,其最大的偏差不超过一个最小设定单位。只要将脉冲当量取得足够小,就可以达到精度要求。逐点比较插补法在脉冲当量为0.01mm,系统进给速度小于3000mm/min时,能很好的满足要求。 一、逐点比较法直线插补 如下图所示设直线 oA 为第一象限的直线,起点为坐标原点o (0 , 0) ,终点坐标为, A( ) , P() 为加工点。 若 P 点正好处在直线 oA 上,由相似三角形关系则有

即 点在直线 oA 上方 ( 严格为直线 oA 与 y 轴正向所包围的区域 ) ,则有 即 若 P 点在直线 oA 下方 ( 严格为直线 oA 与 x 轴正向所包围的区域 ) ,则有图 3 — 1 逐点比较法第一象限直线插补 即 令 则有: ①如 ,则点 P 在直线 oA 上,既可向 +x 方向进给一步,也可向 +y 方 向进给一步;

②如,则点 P 在直线 oA 上方,应向 +x 方向进给一步,以逼近oA直线; ③如,则点 P 在直线 oA 下方,应向 +y 方向进给一步,以逼近 oA直 线一般将及视为一类情况, 即时,都向 +x 方向进给一步。 当两方向所走的步数与终点坐标相等时,停止插补。这即逐点比较法直线插补的原理。 对第一象限直线 oA 从起点 ( 即坐标原点 ) 出发,当 F 时, +x 向走一步;当 F<0 时,y 向走一步。 特点:每一步都需计算偏差,这样的计算比较麻烦。 递推的方法计算偏差: 每走一步后新的加工点的偏差用前一点的加工偏差递推出来。 采用递推方法,必须知道开始加工点的偏差,而开始加工点正是直线的起点,故。下面推导其递推公式。 设在加工点 P( ) 处,,则应沿 +x 方向进给一步,此时新加工点的坐标值为

VB软件-模拟逐点比较法逆圆弧插补的程序设计

xxxx 学院 课程设计说明书 设计题目: 逐点比较法逆圆弧插补的程序设计 系(部):机电工程系 专业:自动化(数控技术) 班级:08数控本(1)班 姓名: 学号: 指导老师(签名): 起止时间:20 11年12月5 日至20 11年12月9 日共 1 周 20 11 年12 月11 日

目录 一.课程设计的目的 (1) 二.课程设计的任务 (1) 三.逐点比较法基本原理 (1) 四.算法描述 (6) 五.具体算法程序 (10) 六.各象限选例展示 (17) 七.心得体会 (19) 八.参考文献 (19)

正文: 数控原理与系统课程设计说明书 一、课程设计的目的 1)了解连续轨迹控制数控系统的组成原理。 2) 掌握逐点比较法插补的基本原理。 3)握逐点比较法插补的软件实现方法。 二.课程设计的任务 逐点比较法插补是最简单的脉冲增量式插补算法之一,其过程清晰,速度平稳,但一般只用于一个平面内两个坐标轴的插补运算。其基本原理是在刀具按要求轨迹运动加工零件轮廓的过程中,不断比较刀具与被加工零件轮廓之间的相对位置,并根据比较结果决定下一步的进 给方向,使刀具向减小偏差的方向进给, 且只有一个方向的进给。也就是说,逐 点比较法每一步均要比较加工点瞬时坐 标与规定零件轮廓之间的距离,依此决 定下一步的走向。如果加工点走到轮廓 外面去了,则下一步要朝着轮廓内部走; 如果加工点处在轮廓的内部,则下一步 要向轮廓外面走,以缩小偏差,这样周 而复始,直至全部结束,从而获得一个 非常接近于数控加工程序规定轮廓的轨 迹。逐点比较法插补过程中的每进给一 步都要经过偏差判别、坐标进给、偏差计算和终点判别四个节拍的处理,其工作流程图如图所示。 三.逐点比较法基本原理 逐点比较法I象限逆圆插补 在加工圆弧过程中,人们很容易联想到使用动点到圆心的距离与该圆弧的名

直线插补,圆弧插补

数控技术第三次作业 题目【1】:第一象限的逆圆插补。 1.取该圆弧的圆心坐标为(0,0),起点坐标为(4,0),终点坐标为(0,4),圆弧半径为4. 2.采用逐点比较法的C程序如 #include void main() { int n=8,x,y,f,g; scanf("%d,%d",&x,&y); f=x^2+y^2-16; if (f>=0) g=f-2x+1,x--,n--; printf("%d,%d,%d\n",x,y,n); else g=f+2y+1,y++,n--; printf("%d,%d,%d\n",x,y,n); if (g>=0) g=g-2x+1,x--,n--; printf("%d,%d,%d\n",x,y,n); else g=g+2y+1,y++,n--;

printf("%d,%d,%d\n",x,y,n); while (n==0) printf("it is over"); } 3.程序流程图如下: 4.程序运行后得到一系列插补点,连接插补点得到插补轨迹如

下图所示: 5.综上,第一象限的逆圆采用逐点插补法的插补过程及其解决算法如上所述。 题目【2】:第一象限的直线插补取第一象限的直线方程为Y=X,起点坐标为原点(0,0),终点坐标为(4,4)。 1.基于MATLAB的插补程序如下: Xe = input('输入终点横坐标X\nXe = '); Ye = input('输入终点纵坐标Y\nYe = '); h = input('输入步长\nh = '); Tstep= (abs(Xe)+abs(Ye))/h; Step=0; F=0; Xi=0; Yi=0; x = 0; y = 0; Xi=Xi+h; x = [x Xi]; y = [y Yi]; end Step=1; while (Step

逐点比较法圆弧插补

逐点比较法圆弧插补 逐点比较法圆弧插补过程与直线插补过程类似,每进给一步也都要完成四个工作节拍:偏差判别、坐标进给、偏差计算、终点判别。但是,逐点比较法圆弧插补以加工点距圆心的距离大于还是小于圆弧半径来作为偏差判别的依据。如图5-7所示的圆弧AB,其圆心位于原点O(0,0),半径为R,令加工点的坐标为P(xi,yj),则逐点比较法圆弧插补的偏差判别函数为 当F=0时,加工点在圆弧上;当F>0时,加工点在圆弧外;当F<0时,加工点在圆弧内。同插补直线时一样,将Fi,j=0同Fi,j>0归于一类。 下面以第一象限圆弧为例,分别介绍顺时针圆弧和逆时针圆弧插补时的偏差计算和坐标进给情况。 1.插补第一象限逆圆弧 1)当Fi,j≥0时,加工点P(xi,yj)在圆弧上或圆弧外,-X方向进给一个脉冲当量,即向趋近圆弧的圆内方向进给,到达新的加工点Pi-1,j,此时xi -1=xi-1,则新加工点Pi-1,j的偏差判别函数Fi-1,j为 (2)当Fi,j<0时,加工点P(xi,yj)在圆弧内,+Y方向进给一个脉冲当量,即向趋近圆弧的圆外方向进给,到达新的加工点Pi,j+1,此时yj+1=yj+1,则新加工点Pi,j+1的偏差判别函数Fi,j+12.插补第一象限顺圆弧 1)当Fi,j≥0时,加工点P(xi,yj)在圆弧上或圆弧外,-Y方向进给一个脉冲当量,即向趋近圆弧的圆内方向进给,到达新的加工点Pi,,j-1,此时yj-1=yj-1,则新加工点Pi,j-1的偏差判别函数Fi,j-1为 2)当Fi,j<0时,加工点P(xi,yj)在圆弧内,+X方向进给一个脉冲当量,即向趋近圆弧的圆外方向进给,到达新的加工点Pi+1,j,此时xi+1=xi +1,则新加工点Pi+1,j的偏差判别函数为Fi+1,j 由以上分析可知,新加工点的偏差是由前一个加工点的偏差Fi,j及前一点的坐标值xi、yj递推出来的,如果按式(5-6)、(5-7)、(5-8)、(5-9)计算偏差,则计算大为简化。需要注意的是xi、yj的值在插补过程中是变化的,这一点与直线插补不同。 与直线插补一样,除偏差计算外,还要进行终点判别。圆弧插补的终点判别可采用与直线插补相同的方法,通常,通过判别插补或进给的总步数及分别判别各坐标轴的进给步数来实现。 插补第一象限逆圆弧的插补流程,设加工第一象限逆圆弧AB,起点A(6,0),终点B(0,6)。试用逐点比较法对其进行插补并画出插补轨迹图。 插补从圆弧的起点开始,故F0,0=0;终点判别寄存器E存入X和Y两个坐标方向的总步数,即E=6+6=12,每进给一步减1,E=0时停止插补。应用第一象限逆圆弧插补计算公式,其插补运算过程如表5-2所示,插补轨迹如图5-9所示。

直线圆弧插补程序

直线插补 Private Sub Command1_Click() Command1.Enabled = False Line (x(0), y(0))-(xa, ya) f(0) = 0 For i = 0 To n - 1 If (xa >= 0) And (ya >= 0) Then If f(i) >= 0 Then For j = x(i) To x(i) + 1 Step 0.0001 PSet (j, y(i)), 255 Next j x(i + 1) = x(i) + 1 y(i + 1) = y(i) f(i + 1) = f(i) - ya Else For j = y(i) To y(i) + 1 Step 0.0001 PSet (x(i), j), 255 Next j y(i + 1) = y(i) + 1 x(i + 1) = x(i) f(i + 1) = f(i) + xa End If End If If (xa > 0) And (ya < 0) Then If f(i) >= 0 Then For j = x(i) To x(i) + 1 Step 0.0001 PSet (j, y(i)), 255 Next j x(i + 1) = x(i) + 1 y(i + 1) = y(i) f(i + 1) = f(i) + ya Else For j = y(i) To y(i) - 1 Step -0.0001 PSet (x(i), j), 255 Next j y(i + 1) = y(i) - 1 x(i + 1) = x(i) f(i + 1) = f(i) + xa End If End If If (xa < 0) And (ya > 0) Then If f(i) >= 0 Then For j = x(i) To x(i) - 1 Step -0.0001 PSet (j, y(i)), 255

逐点比较法圆弧插补代码VB

VB界面: 直线插补和圆弧插补的程序代码: Dim x1%, y1%, x2%, y2%, p! Dim Di As Integer Const PI = 3.14159 Private Sub cmdShow_Click() x1 = V al(Text1(0)): y1 = V al(Text1(1)) x2 = V al(Text1(2)): y2 = V al(Text1(3)) pic.Cls axis pic p = V al(Combo1.Text) cmdShow.Enabled = False If Option1.V alue Then pic.Circle (x1, y1), 0.1, vbBlack pic.Circle (x2, y2), 0.1, vbBlack zhixian pic, x1, y1, x2, y2 ElseIf Option2.V alue Then pic.Circle (x1, y1), 0.1, vbBlack

pic.Circle (x2, y2), 0.1, vbBlack If x1 ^ 2 + y1 ^ 2 = x2 ^ 2 + y2 ^ 2 Then yuanhu pic, x1, y1, x2, y2 Else MsgBox "ERROR!请重新输入!", vbCritical End If End If cmdShow.Enabled = True End Sub Private Sub zhixian(obj As Object, xi%, yi%, xj%, yj%) Dim x!, y! f = 0 x = xi: y = yi obj.Line (xi, yi)-(xj, yj), vbBlack obj.CurrentX = x obj.CurrentY = y n = (Abs(xj - xi) + Abs(yj - yi)) / p While n <> 0 If f >= 0 Then If xj <> xi Then x = x + (xj - xi) / Abs(xj - xi) * p Else y = y + (yj - yi) / Abs(yj - yi) * p End If f = f - Abs(yj - yi) Else If yj <> yi Then y = y + (yj - yi) / Abs(yj - yi) * p End If f = f + Abs(xj - xi) End If obj.Line -(x, y), vbRed n = n - 1 DoEvents For i = 1 To 2000000 * p Next i Wend End Sub Private Sub Form_Load() If App.PrevInstance Then End Combo1.Text = Combo1.List(6) pic.Height = 460 pic.Width = 460

相关主题
文本预览
相关文档 最新文档