1、单片机课程设计-悬挂运动控制系统(E题)设计报告【完整版】(文档可以直接使用,也可根据实际需要修订后使用,可编辑放心下载)悬挂运动控制系统E题设计报告摘要:本悬挂控制系统是一个电机控制系统,控制物体在80cm100cm的范围内作直线、圆、寻迹等运动,并且在运动时能显示运动物体的坐标。设计采用AT89S52单片机作为核心控制器件,采用57BYG007-4型步进电机和高细分步进电机驱动器SM-60作为动力装置,采用红外反射式光电传感器实现画板上黑色线寻迹检测,显示局部用液晶显示模块LCD1602实现。关键词:悬挂控制、单片机、 步进电机、 红外反射式光电传感器一、设计要求1、任务设计一电机控制系统
2、,控制物体在倾斜仰角100度的板上运动。在一白色底板上固定两个滑轮,两只电机固定在板上通过穿过滑轮的吊绳控制一物体在板上运动,运动范围为80cm100cm。物体的形状不限,质量大于100克。物体上固定有浅色画笔,以便运动时能在板上画出运动轨迹。板上标有间距为1cm的浅色坐标线不同于画笔颜色,左下角为直角坐标原点, 示意图如下。 2、根本要求:1控制系统能够通过键盘或其他方式任意设定坐标点参数;2控制物体在80cm100cm的范围内作自行设定的运动,运动轨迹长度不小于100cm,物体在运动时能够在板上画出运动轨迹,限300秒内完成;3控制物体作圆心可任意设定、直径为50cm的圆周运动,限300秒
3、内完成;4物体从左下角坐标原点出发,在150秒内到达设定的一个坐标点(两点间直线距离不小于40cm)。3、发挥局部1能够显示物体中画笔所在位置的坐标;2控制物体沿板上标出的任意曲线运动(见示意图),曲线在测试时现场标出,线宽1.5cm1.8cm,总长度约50cm,颜色为黑色;曲线的前一局部是连续的,长约30cm;后一局部是两段总长约20cm的间断线段,间断距离不大于1cm;沿连续曲线运动限定在200秒内完成,沿间断曲线运动限定在300秒内完成;3其他。4、评分标准工程总分值根本要求设计与总结报告:方案比拟、设计与论证,理论分析与计算,电路图及有关设计文件,测试方法与仪器,测试数据及测试结果分析
4、。50实际制作完成情况50发挥局部完成第(1)项10完成第(2)项中连续线段运动14完成第(2)项中断续线段运动16其他105、说明1、物体的运动轨迹以画笔画出的痕迹为准,应尽量使物体运动轨迹与预期轨迹吻合,同时尽量缩短运动时间;2、假设在某项测试中运动超过限定的时间,该工程不得分;3、运动轨迹与预期轨迹之间的偏差超过4cm时,该工程不得分;4、在根本要求(3)、(4)和发挥局部(2)中,物体开始运动前,允许手动将物体定位;开始运动后,不能再人为干预物体运动;5、竞赛结束时,控制系统封存上交赛区组委会,测试用板(板上含空白坐标纸) 测试时自带。二、方案论证与选择1.核心控制模块的选择方案一:F
5、PGA/CPLD方式。即用FPGA/CPLD完成键盘定义与识别、电机工作状态选择与切换、液晶电路的驱动与控制等功能。这种方案的优点在于系统结构紧凑、操作方便,而且可以使用的I/O口线很多;缺点是调试时需要接很多接线,过程繁琐,而且使用CPLD时,由于其内部没有ROM,对功能的实现有所限制。方案二:单片机方式。即由单片机、电机驱动电路及电机等组成系统。使用单片机也可以完成键盘定义与识别、电机工作状选择与切换等功能,组成的系统规模较小,有一定灵活性,而且可以使用我们比拟熟悉的单片机最小系统电路板,减少了工作量。该控制方式需要单片机具有较大的程序存储量,所以可选择存储量为8K的AT89S52单片机。
6、基于以上分析,拟选用方案二。2.电机及其驱动模块的选择 电机驱动模块是本系统的执行机构,用于控制悬挂物体的运动。 方案1:采用普通小型直流电机。普通直流电机由于其自身结构的限制,控制精度很低,无法到达系统要求的指标,这里不予采用。 方案2:采用专用步进电机驱动器及与其配套的步进电机。用这种方案的控制精度、效率和可靠性都很高。根据精度要求选择方案二。3.黑线探测模块方案一:采用多路阵列式光敏电阻组成的光电探测器。因为光敏电阻探测到黑线时,黑线上方的电阻值发生变化,经过电压比拟器比拟将信号送给单片机处理,从而控制物体做相应的动作。但由于光敏电阻对环境光的识别,容易受到外界环境光的影响。,方案二:采
7、用红外反射式探测,即用已调的红外线垂直射到板面,经反射后转换为电信号送入单片机处理。由于使用的是红外线,不受外界自然光的影响,循迹效果好。基于上面的讨论,选用了抗干扰能力强的方案二。4.显示方案的选择方案一:采用LED数码管显示器。LED 数码管亮度高,醒目,但是其电路复杂,显示信息量较小,且动态扫描需要占用大量单片机时间,无法做到实时显示。方案二:采用汉字LCD液晶显示器。LCD有明显的优点:微功耗、尺寸小,超薄轻巧、显示信息量大、字迹清晰、美观、视觉舒适。本设计中采用1602字符型LCM。1602字符型LCM克服了LED数码管的缺点,具有显示容量大、占用单片机口线少、节省单片机时间、功耗低
8、等优点,完全符合本系统要求。5.位置传感模块位置传感模块用于实现显示画笔位置的功能。对于这个模块可以有硬件和软件两类解决方案。 方案1:在物体上安装水平和垂直方向的两只激光笔,在板边缘每条坐标线旁边安装一光电传感器,物体坐标所在处的传感器接收到激光笔,即可确定物体位置。可见本方案共需要180个光电传感器,造成此方案几乎不可实现。方案2:采用软件的方法确定物体位置。单片机控制物体从某个的坐标位置出发,并且记录步进电机的每一次移动情况,就可以通过一定的算法计算出物体的位置。这种方案没有位置传感器,精度较低,但是系统简单。防止了硬件方案过于复杂的缺点。本设计使用方案2。6.键盘模块本模块采用即插型按
9、键,接在最小系统的P2.0P2.7,采用了44的16点阵键盘。可以键入19的数字,即可以输入点的坐标值(X,Y),以及去除,确定,等功能按键。三、系统具体设计实现1、硬件电路的设计1系统的总体设计方案如图3-1所示采用AT89S52单片机作为运动物体的控制中心,进行数学计算、对光电传感器送来的信号进行处理来控制运动物体的运行方向、计算运行物体的坐标位置、LCD数据显示、键盘控制等。图3-1 系统方框图2黑线检测模块电路黑线检测模块电路图3-2所示。当红外线反射式光电传感器ST178位于黑线之上时,光电开关输出高电平;反之,输出低电平。光电传感器输出电平后接反相器74LS04以稳定电平和增大驱动
10、能力。 本设计采用8个红外传感器实现对黑线的检测,通过并口转串口芯片74LS165将数据串行传送到单片机。图3-2 黑线检测模块电路3键盘电路本设计采用4x4矩阵键盘实现数字的输入和功能的选择,键盘接到AT89S52单片机的P2口,通过单片机对键盘的行列扫描实现按键的识别。键盘电路如图3-3所示:图3-3 4x4键盘电路对应的按键码如下:789/456/123/去除0确认/4单片机电源电路单片机控制电路、红外传感器模块电路和液晶显示模块均采用+5V供电,采用集成稳压芯片7805来实现,电路图如图3-4所示。图3-4单片机电源电路5步进电机驱动电路本设计采用57BYG007-4型步进电机和专用高
11、细分步进电机驱动器SM-60作为动力装置。57BYG007-4型步进电机为四相混合式步进电机,由于实验室现有电机驱动器为两相的,固步进电机作两相使用,步距脚为1.8度,通过步进电机驱动器SM-60细分实现步距脚0.9度。电机驱动器SM-60接口如下: GND端为外接直流电源,直流电压为12vA+,A-端为电机A相,B+,B-端为电机B相。+COM端为光电隔离电源公共端,接单片机供电电源为+5V,CP端为脉冲信号,下降沿有效。DIR端为方向控制信号,电平上下决定电机运行方向。FREE端为驱动器使能,高电平或悬空电机可运行。低电平驱动器无电流输出,电机处于自由状态。2、软件及算法设计1物体位置的计
12、算图 3-5 物体位置示意图坐标点参数的计算将画笔所在的位置设定为整个物体的位置。如图3-5设定物体位置的初值坐标为X,YL1= L2= 设电机A 的步进为a cm, 电机B的步进为b cm,物体高度为h cm。如图8为物体在画板某一位置,那么有:解得X轴点位置和h为那么Y轴点位置Y=115-h控制物体从一点到另一点的实现就是当X、Y条件,求电机的步进过程。由图8 解得:解得 cmcm由此,利用软件实现以上算法来分别控制两个步进电机的步进a,b,这样就可以向控制系统输入起点坐标和终点坐标让物体在画板置任意行走。2直线算法: 目前画直线的算法也算是有很多,比方:逐点比拟直线插补,脉冲增量插补和数
13、据采集插补,本设计根据实际所学知识,选择了逐点比拟直线插补法,具体如下:逐点比拟法的根本原理是,在刀具按要求轨迹运动加工零件轮廓的过程中,不断比拟刀具与被加工零件轮廓之间的相对位置,并根据比拟结果断定下一步的进给方向,使刀具向减小偏差的方向进给。图3-6 第一象限直线如图3-6所示,设直线的起点为坐标原点,终点坐标为A,,点m (,)为加工点动点。定义偏差公式为 。假设=0,说明点m在OA直线段上;假设0,说明点m在OA直线段上方,即点m 处;假设0, 说明点m在OA直线段下方,即点m处。由此可得第一象限直线逐点比拟法插补的原理是:从直线的起点出发,当0时,沿+x轴方向走一步;当0时,沿+y轴
14、方向走一步;当两方向所走的步数与终点坐标,相等时,发出终点到信号,停止插补。可以将上面所定义的偏差公式进一步简化,推导出偏差的递推公式。 当0时,沿+x轴方向进给一步, 1当0时,沿+y轴方向进给一步, 2式1和式2是简化后偏差的计算公式,在公式中只有一次加法或减法运算,新加工点的偏差都可由前一点偏差和终点坐标相加或相减得到。本体设计中采用以上原理,不过对于非原点开始的直线,采用起点坐标归零思想,结果也证明了改思路的可行性。3画圆算法:画圆算法采用圆弧插补法。圆弧插补法也是在绘图系统中常用的一种方法,它和直线插补法原理相同,也是逐点比拟算法。假设 F=0,说明加工点在圆弧上;F0,说明加工点在
15、圆弧外;F0,说明加工点在圆弧内。假设 F0,为逼近圆弧,下一步向-X轴进给一步,并计算出新的偏差值;F0,为逼近圆弧,下一步向+Y 轴进给一步,并计算出新的偏差值。各象限插补公式如下在实际操作中,可以以圆心为假设的坐标原点,再根据上面的原理设计算法。4循迹黑线的探测及循迹算法在以画笔为中心,半径20毫米的圆周上安装了8个反射式红外对管作为轨迹探测传感器,安装方式如图3所示。 07654321-1+1图3-7 轨迹探测传感器安装方式 图3-8 方向调整示意图根据图3-7安装方式及安装半径,只要系统的采样频率足够高,轨迹是无法脱离探测范围的。但由于使用了8个传感器,不同传感器信号间的组合太多,使
16、用一般穷举方法难以实现循迹控制,因此自己设计了一套循迹算法。如图3-8,定义了物体循迹时运动的8个方向,图中黑箭头1号方向上表示物体当前的循迹方向。循迹时,使用变量Direct表示当前物体运动方向,物体每次运动时先按当前方向向前步进一段固定的距离,然后检测采样传感器信号并调整Direct,再沿新的Direct方向步进。由于所给的曲线是连续的,所以每次调整Direct只能是1或1。如图3-8所示,Direct在需向左偏时那么Direct加1,需向右偏那么减1,继续前进那么保持不变。由于只有8个运动方向,所以对Direct的运算需在模8的范围内07进行。现在考虑如何决定左偏或右偏的问题,使用上述调
17、整方法只需要根据Direct的前前方向及左右方向的四个信号对Direct调整即可。如图4中仅需根据1、3、5、7方向的信号对Direct调整。由于每个方向上1和保持不变的传感器信号是一定的,故对8个方向上的调整策略用一个静态数组的形式保存起来,调整时直接查表即可,方便编程。这种循迹算法大大地减少了循迹运动的调试时间,为整个作品成功的完成打下了根底。当每次步进的距离较小时,假设在Direct方向的前、左、右三处的传感器同时发现是白纸,那么说明传感器探测到了曲线的间断局部或尽头,此时应根据前几次23次Direct的平均值作为探索方向,再向前步进23步,保证循迹的正确停止。在取平均值时,需对70和0
18、7的转变作特殊处理,否那么可能出错。实践证明,按照上面的方法循迹迅速稳定,并且不会受交叉线的影响。由于轨迹线有一定宽度,实际的轨迹不可能转折得十分迅速,当步进距离较小时,甚至可以完成锐角的循迹。本系统使用的步进距离是5毫米,效果很好。5系统主程序流程框图上电,初始化液晶显示等待按键,选择所需的功能1直线2正方形 3圆 4循迹输入起 点终点坐 标按照事先设定运 行设定圆心手动到 点手动到循迹起始 点执 行 部 件返回显示程序按键确认,进入对应程序图3-9系统主程序流程框图四、系统测试1测试仪器DT9205A型数字万用表;秒表、卷尺;+12V直流稳压电源。2测量结果(1) 直线测试次数设定起点坐标
19、设定终点坐标实际坐标误差用时1(0,0)(50,50)(50.2,51.3)2cm75s2(0,0)(80,99)(80.1,100.5)1.5cm134s(2) 画圆测试次数圆心坐标半径最大误差用时1(25,25)251cm130s2(3) 循迹测试连续线段线长间断线段长度60cm46cm用时28.1s24.3s3误差分析及改良措施1坐标转换的误差。(X,Y)坐标向(L,R)坐标转换时使用几何分析的方法,但为了处理方便,将悬挂滑轮视为一点,没有考虑其半径。本作品以减小其半径的方法降低误差。同时,进行坐标变换时,单片机在计算精度上也会引进误差,由于使用浮点运算,该误差不大。2笔尖和悬挂点不在同
20、一平面引入误差,应尽量使三点处于与地板平行的平面以减小误差。3步进电机的步进脉冲个数和步进线距离之间的折算误差。作品使用了直接测量一段距离和步进个数再求平均值的方法降低误差。4牵引线引入的误差,包括拉伸误差和由松弛产生的误差。改良措施是使用变形系数小的牵引线和增加悬挂物体的重量。5绕线产生的误差。解决方法是根据力学分析采用机械的方法保证绕线不重叠,并且使用半径小的牵引线使绕线在横向延伸的距离减少,从而减少误差。6读数误差。初始定位时需提供物体坐标,测量结果需人为读数,这会引入误差。五、结论本设计以AT89S52单片机为核心,利用软件编程,实现了定点直线运动,圆形轨迹运动,间断黑线循迹以及坐标的
21、实时显示。测试结果说明,本设计很好地完成了题目根本局部和发挥局部的全部要求,速度快、精度高。整个系统从软件到硬件都表达优良简约的风格。主要有以下几个优点:(1) 采用步进电机及专用细分驱动器,悬绳收放控制较精确;(2) 程序算法优良,易于误差处理和提高精确度;(3) LCD液晶显示,界面友好。 六、参考文献1、王琼.单片机原理及应用.合肥工业大学出版社2、求是科技.单片机典型模块设计实例导航.人民邮电出版社3、 高桔祥.全国大学生电子设计竞赛培训教程 - 数字系统与自动控制系统设计.电子工业出版社附录一 电路原理图1、控制局部电路图:2、循迹模块电路图:附录二 源代码/*/#include #
22、include #include #include #define uchar unsigned char /无符号字符类型定义#define uint unsigned int /无符号整数类型定义/*/步进电机驱动器引脚连接定义sbit Motor_Left_CP =P10; /左步进电机脉冲sbit Motor_Left_DIR=P11; /左步进电机方向控制端sbit Motor_Right_CP =P12; /右步进电机脉冲sbit Motor_Right_DIR=P13; /右步进电机方向控制端sbit Motor_FREE =P14; /电机使能端(高电平有效,低电平是电机处于自
23、由状态)sbit SHLD = P15;sbit S_clk = P16;sbit S_data = P17;sbit jiesu=P36;/*/#define pai 3.141592 /圆周率#define a 15 /80cm x 100cm场地到两电机连线的垂直距离(厘米)#define b 15 /80cm x 100cm场地到边线(顶端滑轮和电机的连线)的垂直距离(厘米)#define r 0.8276 /滑轮半径(厘米)#define stepz 0.0122 /左步进电机每步弧长厘米#define stepy 0.0122 /右进步点击每步弧长厘米#define step 0.
24、0125 /步进电机每步弧长厘米#define radius 25 /圆周半径长度#define Motor_FREE 1/*/LCD1602液晶模块引脚连接定义#define LCD_Data P0 /1602的8位数据线连接到P0口sbit RS=P35; /1602的数据/命令选择端RS连接到P1.0sbit RW=P34; /1602的读/写选择端连接到P1.1sbit EN=P33; /1602的使能信号引脚连接到P1.2/*/uchar code kaiji016= WELCOME! ;uchar code kaiji116=LOADDOWNING.;uchar code tabl
25、e016=1.Line 2 Rectan;uchar code table116=3.Circu 4.Follow; uchar code table316= Draw a Line ;uchar code table416=Draw Circularity;uchar code table516=Follow the Line ;uchar code table616=( , );( , ) ;uchar code table716=( , ); r= cm ; uchar code table816=( cm, cm) ;uchar code table916= ENTER to Begi
26、n ;uchar code table1016=Executing . x;uchar code table1116=Rectan perform. ;uchar code table1216=(25,25)-(50,25) ;uchar code table1316=(50,50)-(25,50) ;uchar code table1416=have completed!;uchar code wrong16=Wrong Coordinate;uchar code agian16=Input Agian ? ;uchar code number10=0123456789; /*/int x0
27、,y0,x1,y1;/*/函数声明void Delay_1ms(int time); /延时1ms*timevoid LCD1602_Busy_Check(void); /LCD1602忙检查函数void Write_LCD1602(uchar udata,bit command); /LCD1602写数据和写指令函数void Write_Byte_Locate(uchar x,uchar y,uchar udata); /把数据显示在LCD1602的指定位置void Init_LCD1602(); /LCD1602初始化函数uchar Keyboard_Scan(void); /键盘扫描函数
28、,返回键盘扫描码uchar Scan_Code_Transform(uchar scancode); /键码识别函数/void Motot_ld(int );void Motor_Left_Step(bit Dir); /左电机转动一步,Dir=0时反转(顺时针),即松开线;Dir=1时正转(逆时针),即收紧线void Motor_Right_Step(bit Dir);/右电机转动一步,Dir=0时反转(顺时针),即收紧线;Dir=1时正转(逆时针),即松开线void Draw_Circular(int x,int y); / 画圆函数void currentdisp(int line,in
29、t x,int y);/当前显示void linedisp(int,int,int,int,int); /当前直线点显示void display(uchar table16,bit line);/提示显示void line(int,int,int,int);/画直线函数void Draw_line();/void buchang(float,float,float,float);/确定左右电机移动的步数void Returndata();/读取对光二极管的值void follow();/循迹函数void zouxiang(int);/循迹电机驱动函数/*/延时函数,延时时间=1ms*time(
30、晶振12MHz)void Delay_1ms(int time) uchar i,j; do for(i=0;i15;i+) for(j=0;j20;j+); while(time-)!=0); /*/*LCD1602液晶操作函数局部*/LCD1602液晶检查忙函数void LCD1602_Busy_Check(void) EN=0; RW=1; RS=0; EN=1; while(LCD_Data&0x80=1); EN=0; Delay_1ms(1);/*/LCD1602写数据和写指令函数/把写数据和指令二个合在一起,用一个变量command来判断void Write_LCD1602(uc
31、har udata,bit command) LCD1602_Busy_Check(); /忙检查 RS=command;/command=0时写入指令,command=1时写入数据 RW=0; /把LCD设置成写状态 EN=1; /E高脉冲,把数据/指令写入 LCD_Data=udata; EN=0;/*/把数据显示在LCD1602的指定位置/x,y是坐标,udata是需要显示的数据/x不能大于15,每行最多显示16字符/y不能大于1,最多显示2行void Write_Byte_Locate(uchar x,uchar y,uchar udata) if(y)x+=0x40;/判断显示哪行,
32、显示第二行LCD存储区加40H x+=0x80; /如果没有加0X40那么显示第一行 Write_LCD1602(x,0); /写指令 Write_LCD1602(udata,1);/写显示数据/*/LCD1602初始化函数void Init_LCD1602() Write_LCD1602(0x38,0); /显示模式设置 Delay_1ms(20); Write_LCD1602(0x01,0);/去除屏幕 Write_LCD1602(0x06,0);/显示光标移动设置 Write_LCD1602(0x0c,0);/开显示/*/*键盘扫描和键码识别函数局部*/键盘扫描函数,返回键盘扫描码/P2
33、.0P2.3输出,P2.4P2.7输入uchar Keyboard_Scan(void) uchar scancode,tmpcode; P2=0xf0; while(P2=0xf0); /等待有键按下 Delay_1ms(20); /延时10ms去抖动 if(P2!=0xf0) scancode=0xfe; /逐行扫描 while(scancode!=0xef) /还没有扫描完4行 P2=scancode; if(P2&0xf0)!=0xf0) /本列有键按下 tmpcode=(P2&0xf0)|(scancode&0x0f); while(P2&0xf0)!=0xf0); /等待键释放 r
34、eturn(tmpcode); else scancode=(scancode1)|0x01; return(0);/*/键码识别函数uchar Scan_Code_Transform(uchar scancode) switch (scancode) /*将按键码转换成键值*/ case 0xde: return 0; case 0xed: return 1; case 0xdd: return 2; case 0xbd: return 3; case 0xeb: return 4; case 0xdb: return 5; case 0xbb: return 6; case 0xe7: r
35、eturn 7; case 0xd7: return 8; case 0xb7: return 9; case 0xee: return 10; default : return 0xff; /*/*步进电机根本操作局部*/左电机转动一步,Dir=0时反转(顺时针),即松开线;Dir=1时正转(逆时针),即收紧线void Motor_Left_Step(bit Dir) Motor_Left_DIR=Dir; Motor_Left_CP=1; Delay_1ms(1); Motor_Left_CP=0; Delay_1ms(1);/*/右电机转动一步,Dir=0时反转(顺时针),即收紧线;Di
36、r=1时正转(逆时针),即松开线void Motor_Right_Step(bit Dir) Motor_Right_DIR=Dir; Motor_Right_CP=1; Delay_1ms(1); Motor_Right_CP=0; Delay_1ms(1);/*/* 圆形当前坐标显示模块*/void currentdisp(int line,int x,int y) Write_Byte_Locate(1,line,numberx/10);Write_Byte_Locate(2,line,numberx%10); Write_Byte_Locate(4,line,numbery/10);
37、Write_Byte_Locate(5,line,numbery%10);/* * 直线当前坐标实现模块* */* “,;, */void linedisp(int line,int x,int y,int xz,int yz) display(table6,line); Write_Byte_Locate(1,line,numberx/10); Write_Byte_Locate(2,line,numberx%10); Write_Byte_Locate(4,line,numbery/10); Write_Byte_Locate(5,line,numbery%10); Write_Byte_
38、Locate(9,line,numberxz/10); Write_Byte_Locate(10,line,numberxz%10); Write_Byte_Locate(12,line,numberyz/10); Write_Byte_Locate(13,line,numberyz%10); /*/*功能实现局部*/* 步数确定函数 */void buchang(float x,float y,float nextx,float nexty)/,int *znum1,int *ynum1) float zb,yb;int znum,ynum,fhz,fhy; zb=(sqrt(114.3-y)*(114.3-y)+(14.4+x)*(14.4+x)-sqrt(114.3-nexty)*(114.3-nexty)+(14.4+nextx)*(14.4+nextx)/stepz; yb=(sqrt(11