机电一体化课程设计基于单片机控制的数控十字工作台设计.doc
专业课程设计计算说明书YX设计题目 基于单片机控制的数控十字工作台设计学校 XXXXX学习中心班级 XXXX学号 XXXXXXXXXX设计者 XXX指导老师 XXX2007年12月10日_目 录前言2机械传动部分电动机选择4电动机的选择4滚珠丝杠的选择7轴承的选择14导轨的选择23步进电机控制和直线插补部分步进电机驱动电路和单片机接口电路24软件脉冲分配24减速器附件的选择25润滑与密封25设计小结26参考资料目录27前 言 专业课程设计的目的 本次专业课程设计是机电类专业学生的一次较全面的机电一体化设计训练,是数控技术和机电一体化设计基础课程重要的综合性与实践性教学环节。其基本目的是:(1) 通过本课程的设计,综合运用机械设计课程和数控技术及其他有关先修课程的理论,结合生产实际知识,培养分析和解决一般工程实际问题的能力,并使所学知识得到进一步巩固、深化和扩展。(2) 学习机电一体化设计的一般方法,掌握通用机械零件、机械传动装置和简单工作台运动控制的设计原理和控制过程。(3) 进行机电一体化设计基本技能的训练,如计算、绘图、控制编程、熟悉和运用设计资料(手册、图册、标准和规范等)以及使用经验数据,进行经验估算和数据处理等。机械设计课程的内容及要求 设计一个基于单片机控制系统的数控工作台课程设计的内容包括:确定传动装置的总体设计方案,选择电动机(步进电机/伺服电机);连轴器的选择,滚珠丝杠的结构设计,导轨、螺母副及工作台的设计绘制装配工作图,电机驱动电路设计,单片机控制电路及直线插补程序,编写设计计算说明书。在设计中完成了以下工作: 数控工作台结构装配图1张(手工或三维工作图); 单片机直线插补程序 设计计算说明书1份; 课程设计的步骤机电一体化课程设计一般可按照以下所述的几个阶段进行:1设计准备 分析设计计划任务书,明确工作条件、设计要求、内容和步骤。 了解设计对象,阅读有关资料、图纸、观察事物或模型以进行工作台装拆试验等。 熟悉课程有关内容,熟悉机电一体化产品的设计方法和步骤。 准备好设计需要的图书、资料和用具,并拟定设计计划等。 一、 电动机选择步进电动机的特点:1、工作状态不易受各种干扰因素(如电源电压的波动、电源的大小与波形的变化、温度等)的影响,只要在它们的大小未引起步进电机产生“丢步”现象之前,就不影响其正常工作;2、步距角有误差,转子转过一定步数以后也不会出现累计误差,但转子转过一转以后,其累计误差变为零,因此不会长期积累;3、控制性能好,在启动,停止,反转时不易丢步,因此步进电机被广泛引用于开环控制的机电一体化系统,使系统简化并可靠地获得较高的位置精度;4、转角与控制脉冲数成比例,可构成直接数字控制5、有定位转矩6、可构成廉价的开环控制系统综上所述,根据本课程设计中数控工作台的控制要求及成本预算,宜选用混合型反应式步进电机。由于丝杠基本导程L选择范围在3-8mm,取根据脉冲当量与工作台系统精度的关系有:,因此 取,根据参数选择电机型号为75BY003相数步距角/(°)电压/V相电流/A最大静转矩/N·m空载起动频率/(步/s)电感/(mH)电阻/分配方式外形尺寸(轴径)/mm重量/kg转子转动惯量/30.93040.882125035.50.823相6拍1.581.563二、滚珠丝杠的选择滚珠丝杆的特点:1、传动效率高,摩擦损失小,一般滚珠丝杆副的传动效率达到85%-95%;2、运动平稳,系统刚度好,滚动摩擦系数接近常数,启动时无冲击,低速时无爬行,能够预紧,预紧后可消除间隙,产生过盈,提高接触刚度和传动精度;3、使用寿命长,滚珠丝杠的摩擦表面硬度高,精度高,具有较长的工作寿命和精度保持性;4、定位精度和重复定位精度高,由于滚珠丝杠副摩擦小,温升少,无爬行,无间隙,因此可达到较高的定位精度和重复定位精度;5、运动具有可逆性,可以将回转运动变为直线运动,也可以将直线运动转换为回转运动,即丝杠和螺母都可以作为主动件;6、不能自锁,特别是垂直安装的丝杠必须在系统中附加自锁或制动装置;7、制造复杂,经济性差,成本高,由于结构复杂,滚珠丝杠和螺母等零件加工精度表面粗糙度要求高,制造成本高。传动形式螺杆转动,螺母移动。如下图所示:滚道法向型面的形状和结构滚珠的循环方式和滚珠丝杠副轴向间隙的调整与预紧方法选择螺旋槽式外循环结构,采用双螺母螺纹预紧调整方式。如下图支承方式三、轴承的选择双向止推球轴承(一个)深沟球轴承(2个)主要尺寸参数公称直径;20mm基本导程:5mm两轴行程:40*30根据参数,确定型号为 或 联轴器的选择弹性套柱销联轴器型号周孔直径轴孔长度,TL19四、导轨的选择滚动导轨副的特点:1、摩擦系数小(0.003-0.005),运动灵活;2、动静摩擦系数基本相同,因而起动阻力小,不易产生爬行;3、可以预紧,刚度高;4、寿命长;5、精度高;6、润滑方便,可以采用脂润滑,一次装填,长期使用;7、由专业厂生产,可以外购选用,因此滚动导轨副广泛的被应用于精密机床,数控机床,测量机和测量仪器等。滚动导轨副的缺点是:导轨面与滚动体是点接触或线接触,所以抗振性差,接触应力大,对导轨的表面硬度、表面形状精度和滚动体的尺寸精度要求高,若滚动体的直径不一致,导轨表面有高低,会使运动部件倾斜,产生振动,影响运动精度;结构复杂,制造困难,成本较高;对赃物比较敏感,必需有比较良好的防护装置。滚动体循环的滚动导轨副材料与技术要求滚动体一般采用滚动轴承钢(如),淬火后硬度可达HRC60-66滚动导轨常用的材料有:1、低碳合金钢(如20、18)渗碳、淬火。渗碳层厚度1-1.5mm,硬度达HRC60-632、合金工具钢(如、)淬火后低温回火(180-200),硬度达HRC60-64。3、氮化钢(如38、38)调质厚氮化,硬度达HRC62-66。数控机床的结构1、主机2、CNC装置3、驱动装置4、辅助装置5、编程机及辅助设备数控程序设计部分一、步进电机控制和直线插补部分1、步进电机驱动电路和单片机接口电路2、软件脉冲分配查表法。查表法的基本思路是:结合电动机的驱动电路,按步进电动机励磁状态转换表求出脉冲分配器输出状态字组成的状态表,并将其存入程序存储器(EEPROM)中,然后根据步进电动机运转方向按表地址正向或反向地取初单元中的状态字进行输出,即可控制步进电动机正向或反向地旋转起来。由于单片机I/O口P1.0、P1.1、P1.2分别与步进电动机(X轴)的A、B、C三相对应,设该表格首地址未2000H,则可以写出脉冲分配入下表所示。序号CBA存储单元方向P1.0P1.1P1.2地址内容10012000H01H反转正转20112001H03H30102002H02H41102003H06H51002004H04H61012005H05H入口保护现场取出上次励磁状态对应地址指针正转?末址?首址?指针+1指针-1指针置成首址指针置成末首址取出该指针对应的环分状态延时输出环分状态保存目前指针恢复现场返回Y(正转)N(反转)NYYN3、速度控制在基于步进电机的开环进给系统中,对进给速度的控制就是对步进电机速度的控制。由步进电机原理分析可知,通过控制步进电机相邻两相励磁状态之间的时间间隔,即可实现步进电动机速度的控制。对于软件环分来说,只要控制相邻两次环形分配器输出状态之间的时间间隔,也就是控制如下循环流程中延时时间的长短:A延时AB延时B延时BC延时C延时CA延时 (01H) (03H) (02H) (06H) (04H) (05H) 正转 反转 为充分利用单片机的时间资源,实现延时的方法采用定时器中断延时。二、逐点比较法的直线插补原理插补计算就是对数控系统输入基本数据,运用一定的算法计算,并根据计算结果向相应的坐标发出进给指令。步进电机工作台应用逐点比较法直线插补是每走一步控制系统都要将加工点与给定的图形轨迹相比较,以决定下一步进给的方向,使之逼近加工轨迹。逐点比较法既可实现直线插补,也可以实现圆弧插补。其特点是运算简单直观,插补过程的最大误差不超过一个脉冲当量,输出脉冲均匀,而且输出脉冲速度变化小,调节方便。因此在两坐标数控工作台中应用较为普遍。1、逐点比较直线插补的数学原理如图1-1所示,设计直线OA为第一象限直线,起点为坐标原点O(0,0),终点坐标为E(,),N(,)为加工点。 Y E(,) F>0 N(,) F=0 F<0 0 图1-1 X若N点正好处在直线OE上,由相似三角关系则有:/= / 即 -=0若N点在直线OE上方,则有: />/即 ->0 若N点在直线OE下方,则有: /</即 -<0 令=- 则有(1)如=0,则有N点在直线OE上;>0, 则有N点在直线OE上方;<0,则有N点在直线OE下方。从图1-1看出对于起点在原点的第一象限直线OE,当N在直线上方时(>0),应向+X方向进给一步,以逼近该直线;当N点在直线下方时(<0),应向+Y方向进给一步;当N点在直线OE上时(=0),既要向+X方向进给一步,也向+Y方向进给一步。逐点比较直线插补每一步都要完成四个步骤,(1)位置判别;(2)坐标进给;(3)偏差计算;(4)终点判别。2、逐点比较法直线插补的递推算式由偏差函数式子=-可以看出,在计算F时,总是要做乘法和减法运算。这在用硬件或汇编语言软件实现时不太方便,还会增加运算时间。因此,为了简化运算,通常采用递推算式来求取F值,即每进给一步后,新加工点的偏差值总是通过前一点的偏差值递推算出来的。现假设第i次插补后动点坐标未 N(,),偏差函数为=-,若,刀具应向+X方向进给一步,新的动点坐标值为,则新的偏差函数为,所以同理,当时,刀具应向+X方向进给一步,新的动点坐标值为,对应新的偏差函数为,所以有以上推导可以看出,采用递推公式计算偏差函数F,将不涉及动点坐标与乘法运算,仅与直线的终点坐标以及前一点的偏差函数值有关,并且算法简单,易于实现。要说明的是,通过坐标平移的方式可以使每个直线轮廓段起点总处于坐标系的原点上。因此以下只讨论在坐标系第一象限的直线插补情况。且偏差函数的初始值为综上所述,第1象限的偏差函数与进给方向有以下关系:当时,刀具向+X方向进给,新的偏差函数值为;当时,刀具向+Y方向进给,新的偏差函数值为;3、直线插补中的终点判别机制在插补计算过程中,还有一项工作需要同步进行,即终点判别,以确定刀具是否抵达直线终点。如果到了终点就停止插补运算,否则继续作循环插补处理。以下的处理将采用总步长法进行判别。总步长法:在插补计算之前,先设置一个总步长计数器,求出被插补直线轮廓在各个坐标轴方向上应走的总步数,加在一起存入计数器中,即,然后每插补计算一次,无论向哪个坐标轴进给一步,计数器都作减1修正。这样,当总步数减到零时,则表示刀具已经抵达直线轮廓的终点。4、四象限直线插补仿照前面介绍的第I象限直线插补方法,不难发现,当被插补直线处于不同象限时,其计算公式及处理过程完全一样,仅仅时进给方向不同而已。进一步总结出、的进给方向如图所示F<0F<0F<0F<0F0F0F0F0+X-X四个象限直线插补进给方向由此,可设计出四个象限内直线插补计算的通用软件,其流程如图所示开始初始化,结束逐点比较法四象限直线插补软件流程图YNYYNNNY5、逐点比较法合成进给速度逐点比较法插补的特点是脉冲源每发送一个脉冲过来,就进行一次插补计算,产生一步进给,并且不是发向X轴,就是发向Y轴,因此有下式成立;式中脉冲源频率(Hz);X轴进给脉冲频率(Hz)Y轴进给脉冲频率(Hz)因此,其合成进给速度为,当或时,即刀具沿着平行于坐标轴的方向切削,这时对应的切削速度最大,相应的速度称为脉冲源速度,即因此,合成进给速度与脉冲源速度之比为合成进给速度为,可见,当编程进给速度确定了脉冲源频率后,实际获得的合成进给速度v随变化而变化。为了得到较平稳的进给速度,在软件编程时可根据不同的直线采用相应的脉冲源频率以确保在插补不同直线时候其合成进给速度相同。三、单片机直线插补的编程方法 由于步进电机的步距角,丝杠导程。算出数控系统的脉冲当量,即坐标上的量化单位1为0.0125mm。由于导轨的最大行程为400mm,对应的脉冲数为,两轴相加最大的脉冲数为,需要使用16位以上二进制数才能表示出来,由于AT89s51单片机的字长为8位,可利用两个8位字长的内存单元(RAM)来联合存放以上数据。其中偏差函数F、坐标、坐标、总步数在内存中均占用三个字节,并且F、采用补码形式,其余数据采用绝对值或正数,地址分配情况如下表所示 参数类型存储地址偏差函数F坐标值坐标值总步数低字节地址10H13H16H19H中字节地址11H14H17H1AH高字节地址12H15H18H1BH四象限直线插补程序如下:单片机I/O口P1.0、P1.1、P1.2分别与步进电动机(X轴)的A、B、C三相对应;而 P2.0、P2.1、P2.2口分别与步进电动机(Y轴)的A、B、C三相对应.R1、R2表地址指针 EQU X1 BIT 50H ; 终点横坐标为零标志位Y1 BIT 51H ; 终点纵坐标为零标志位FEYES BIT 52H ; 插补结束标志位ER BIT 53H ;插补直线长度为零出错标志位ORG 0000HAJMP MAINORG 0003HAJMP XIANWEI ;外中断,限位报警处理ORG 000BHAJMP CHABU ;定时插补(给定相应频率)MAIN: MOV SP #60H ;设栈口ACALL TO_INT ;初始化 ;ACALL XTEXT ;判断终点横坐标是否为零;JB X1, XLINE ;为零则转坐标轴直线插补处理 ;ACALL YTEXT ;判断终点纵坐标是否为零;JB Y1, YLINE ;为零则转坐标轴直线插补处理 SETB TR0 ;开定时中断,开始进行插补SJMP $ ;等待定时中断CHABU : PUSH ACC PUSH PSW ;保护现场 ACALL XTEXT ;判断终点横坐标是否为零JB X1, XLINE ;为零则转坐标轴直线插补处理 ACALL YTEXT ;判断终点纵坐标是否为零JB Y1, YLINE ;为零则转坐标轴直线插补处理AJMP STARTXLINE: ACALL YTEXT ;判断终点纵坐标是否为零JB Y1, ERR ;为零则转出错处理 MOV A, 18H ; 插补直线与Y轴重合 JB ACC.7 ,FEED_1Y ; 终点纵坐标为负则向方向进给 ACALL FEED_Y1 ;否则向方向进给一步LJMP Y_TONEXT ; 转修正F YLINE: MOV A, 15H ;插补直线与X轴重合 JB ACC.7 ,FEED_1X ; 终点横坐标为负则向方向进给 ACALL FEED_X1 ;否则向方向进给一步LJMP X_TONEXT ; 转修正FERR: SET ER LJMP ERNX1 ; 插补结束,置位转其他处理START: MOV A , 12HJB ACC.7 ,LOOP ; ,则转LOOP平行Y轴方向进给MOV A , 15H JB ACC.7 ,FEED_1X ;属于第二、三象限直线则向方向进给ACALL FEED_X1 ; 一、四象限直线则向方向进给LJMP X_TONEXT ; 转修正FFEED_1X : MOV A, R1CJNE A, #00H ,XZGO1 ;是首址?指针置为末址MOV R1,#05HSJMP XNX1 XZGO1: DEC R1 ; 非首址,指针-1 XNX1: MOV A, R1 MOV DPTR,#TABLEMOV A,A+DPTR ; 取出该指针对应的环分状态 MOV P1, AX_TONEXT: ACALL SUBFYE ;修正F,LJMP ADD_M ; 转修正总步数LOOP : MOV A , 18H JB ACC.7 ,FEED_1Y ;属于第三、四象限直线则向方向进给ACALL FEED_Y1 ; 一、二象限直线则向方向进给LJMP Y_TONEXT ; 转修正FFEED_1Y : MOV A, R2CJNE A, #00H ,YZGO1 ;是首址?指针置为末址MOV R1,#05HSJMP YNX1 YZGO1: DEC R2 ; 非首址,指针-1 YNX1: MOV A, R2 MOV DPTR,#TABLEMOV A,A+DPTR ; 取出该指针对应的环分状态 MOV P3, AY_TONEXT: ACALL ADDFXE ;修正F,LJMP ADD_M ; 转修正总步数ADD_M : ACALL STEP_1 ;修正总步数MOV A, 19H ;取总步数低字节CJNE A,#00H ,NEXT1 ;判别,该字节不为零继续插补MOV A , 1AH ; 取总步数中字节CJNE A,#00H ,NEXT1 ;判别,该字节不为零继续插补MOV A , 1BH ; 取总步数高字节CJNE A,#00H ,NEXT1 ;判别,该字节不为零继续插补ERNX1: CLR TR0 SETB FEYES ;,插补结束,置位转其他处理NEXT1: POP PSWPOP ACC ;恢复现场NOP RETIFEED_X1: MOV A, R1 ; 向方向进给一步子程序CJNE A, #05H ,XZGO2 ;是末址?指针置为首址MOV R1,#00HSJMP XNX2 XZGO2: DEC R1 ; 非末址,指针+1 XNX2: MOV A, R1 MOV DPTR,#TABLEMOV A,A+DPTR ; 取出该指针对应的环分状态 MOV P1, ARETFEED_Y1 : MOV A, R2 ; 向方向进给一步子程序CJNE A, #00H ,YZGO2 ;是末址?指针置为首址MOV R1,#05HSJMP YNX1 YZGO2: DEC R2 ; 非末址,指针+1 YNX2: MOV A, R2 MOV DPTR,#TABLEMOV A,A+DPTR ; 取出该指针对应的环分状态 MOV P3, ARETTABLE: DB 01H, 03H, 02H, 06H, 04H,05HXTEXT : MOV A, 13H ;判断终点横坐标是否为零,取终点横坐标低字节 CJNE A,#00H ,HIRR01 ;判别,该字节不为零转 MOV A , 14H ; 取总步数中字节CJNE A,#00H , HIRR01 ;判别,该字节不为零转MOV A , 15H ; 取总步数高字节CJNE A,#00H , HIRR01 ;判别,该字节不为零转 SETB X1 SJMP WANT01HIRR01 : CLR X1WENT01 : NOPRETYTEXT : MOV A, 16H ;判断终点综坐标是否为零,取终点横坐标低字节 CJNE A,#00H ,HIRR02 ;判别,该字节不为零转 MOV A , 17H ; 取总步数中字节CJNE A,#00H , HIRR02 ;判别,该字节不为零转MOV A , 18H ; 取总步数高字节CJNE A,#00H , HIRR02 ;判别,该字节不为零转 SETB Y1 SJMP WENT02HIRR02 : CLR X1WENT02 : NOPRETINI: CLR FEYES ;清状态标志位 CLR 30H CLR 31H CLR 50H CLR 51H MOV 10H,#00H MOV 11H,#00H MOV 12H,#00H ;初始化偏差函数F值 MOV A, 13H ; 计算总步数 (三字节有符号数相加) ADD A , 16H MOV 30H , CMOV 19H, A MOV A, 14H ADD A, 17H MOV 31H , CMOV 1AH, A MOV A, 15H ADD A, 18H MOV 1BH, AJNB 30H ,TN01 ;低字节相加无进位,转MOV A, 19H INC A MOV 19H, A JNC TN01 MOV A, 1AH INC A MOV 1AH, A INC 1BHTN01 JB 31H,TN02 ; 中字节相加无进位,转MOV A, 1AH INC A MOV 1AH, A JNC TN02 INC 1BHTN02: LCALL TIME ;调速度控制机制 RET END.参考资料1机电一体化系统设计(第二版),高等教育出版社,张建民 等编著,2001年8月第2版;2机械设计(第七版),高等教育出版社,濮良贵,纪名刚主编,2001年7月第七版;3计算机工程制图(第二版),华南理工大学出版社,陈锦昌 刘就女 刘林 编著,2003年6月第2版;4数控原理与系统,机械工业出版社,汪木兰 主编,2006年7月第1版;5机械系统计算机控制,清华大学出版社,钟约先 林亨 主编,2001年4月第1版6数字控制机床,华中理工大学出版社,廖效果 朱启逑 主编,1992年9月第1版;7机电一体化机系统设计,机械工业出版社,赵松年 张奇鹏 主编,1996年6月第1版。8互换性与技术测量(第四版),中国计量出版社,廖念钊,古莹庵,莫雨松,李硕根,杨兴骏编,2001年1月第四版。9 机械设计手册(软件版)R2.0机械工业出版社出版