AT89C51单片机应用系统的设计与调试.ppt
《AT89C51单片机应用系统的设计与调试.ppt》由会员分享,可在线阅读,更多相关《AT89C51单片机应用系统的设计与调试.ppt(89页珍藏版)》请在三一办公上搜索。
1、第13章 AT89C51单片机应用系统的设计与调试,13.1 AT89C51 单片机应用系统的设计步骤 设计一个单片机测控系统,一般可分为四个步骤:(1)需求分析,方案论证和总体设计需求分析:被测控参数的形式(电量、非电量、模拟量、数字量等)、被测控参数的范围、性能指标、系统功能、工作环境、显示、报警、打印要求等。方案论证:根据要求,设计出符合现场条件的软硬件方案,又要使系统简单、经济、可靠,这是进行方案论证与总体设计一贯坚持的原则。,(2)器件选择,电路设计制作,数据处理算法,软件的编制阶段。(3)系统调试与性能测定。(4)文件编制。文件包括:任务描述、设计的指导思想及设计方案论证、性能测定
2、及现场试用报告与说明、使用指南、软件资料(流程图、子程序使用说明、地址分配、程序清单)、硬件资料(电原理图、元件布置图及接线图、接插件引脚图、线路板图、注意事项)。文件不仅是设计工作的结果,而且是以后使用、维修以及进一步再设计的依据。因此,一定要精心编写,描述清楚,使数据及资料齐全。,13.2 应用系统的硬件设计为使硬件设计尽可能合理,应重点考虑以下几点。1尽可能采用功能强的芯片(1)单片机的选型。随着集成电路技术的飞速发展,许多外围部件都已集成在芯片内,本身就是一个系统,这样可以省去许多外围部件的扩展工作,设计工作大大简化。例如,美国Cygnal公司的C8051F020 8位单片机,片内集成
3、有8通道A/D、两路D/A、两路电压比较器,内置温度传感器、定时器、可编程数字交叉开关和64个通用I/O口、电源监测、看门狗、多种类型的串行总线(两个UART、SPI)等。,(2)优先选用片内带有闪烁存储器的产品。例如,使用ATMEL公司的89C51/89C52/89C55,PHILIPS公司的89C58(内有32KB的闪烁存储器),可省去扩展单片机程序存储器的工作,减少芯片数量,缩小体积。(3)考虑EPROM空间和RAM空间。目前EPROM容量越来越大,一般尽量选用容量大的EPROM。89C51内部的RAM单元有限,当需增强软件数据处理功能时,往往觉得不足,这就要求系统配置外部RAM,如62
4、64,62256芯片等。如果处理的数据量大,需要更大的数据存储器空间,可采用数据存储器芯片DS12887,其容量为256KB,内有锂电池保护,保存数据可达10年以上。,(4)对I/O端口的考虑。在样机研制出来进行现场试用时,往往会发现一些被忽视的问题,而这些问题是不能单靠软件措施来解决的。如有些新的信号需要采集,就必须增加输入检测端;有些物理量需要控制,就必须增加输出端。如果在硬件设计之初就多设计出一些I/O端口,这些问题就会迎刃而解了。(5)预留A/D和D/A通道。和I/O端口同样的原因,留出一些A/D和D/A通道将来可能会解决大问题。,2以软代硬原则上,只要软件能做到且能满足性能要求,就不
5、用硬件。硬件多了不但增加成本,而且系统故障率也会提高。以软带硬的实质,是以时间换空间,软件执行过程需要消耗时间,因此这种代替带来的问题就是实时性下降。在实时性要求不高的场合,以软代硬是很合算的。3工艺设计包括机箱、面板、配线、接插件等。必须考虑到安装、调试、维修的方便。另外,硬件抗干扰措施也必须在硬件设计时一并考虑进去。,13.3 AT89C51单片机系统设计举例首先介绍单片机应用系统设计时的地址空间分配和总线驱动问题,最后举一个应用系统设计的例子供读者参考。13.3.1 应用系统设计中的地址空间分配与总线驱动系统往往是多芯片系统,这时要遇到两个问题:一是如何把64KB程序存储器和64KB数据
6、存储器的空间分配给各个芯片;二是如何实现89C51单片机对多片芯片的驱动。1地址空间分配图13-1是一个全地址译码的系统实例。各器件芯片所对应的地址如表13-1所示。,地址空间分配的两种方法:线选法和译码法。下面通过一个例子来说明如何解决这个问题。,图13-1,因6264、2764都是8KB,故需要13条低位地址线(A12A0)进行片内寻址,低8位地址线A7A0经8D锁存器74LS373输出,图中没有画出。其他三条高位地址线A15A13经3-8译码器74LS138译码后作为外围芯片的片选线。图中尚剩余三条地址选择线Y7*Y5*,可扩展三片存储器芯片或外围I/O接口电路芯片。2总线驱动设计时,有
7、时要扩展多片芯片,注意AT89C51的I/O口驱动能力。AT89C51有4个并行双向口,P0、P1、P2、P3 4个口的驱动能力不同,P0口的驱动能力较大,每位可驱动8个LSTTL输入,当其输出高电平时,可提供400A的电流;,当其输出低电平(0.45V)时,可提供3.2mA的灌电流,如低电平允许提高,灌电流可相应加大。P1、P2、P3口的每一位只能驱动4个LSTTL。所以,任何一个口要想获得较大的驱动能力,只能用低电平输出。AT89C51通常将P0、P2口用作访问外部存储器,所以P1、P3口只能用作输入/输出口。P1、P3口的驱动能力有限,在低电平输出时,一般也只能提供不到2mA的灌电流。当
8、应用系统规模过大时,可能造成负载过重,使驱动能力不够,系统不能可靠地工作,所以通常要附加总线驱动器或其他驱动电路。,多芯片应用系统中首先要估计总线的负载情况,以确定是否需要对总线的驱动能力进行扩展。图13-2为AT89C51单片机总线驱动扩展原理图。地址总线和控制总线的驱动器为单向驱动器,并具有三态输出功能。驱动器有一个控制端,以控制驱动器开通或处于高阻状态。通常,在单片机应用系统中不采用DMA功能时,地址总线及控制总线可一直处于开通状态,这时控制端接地即可。常用的单向总线驱动器为74LS244。图13-3为74LS244引脚图和逻辑图。8个三态驱动器分成两组,分别由1G*和2G*控制。,2总
9、线的驱动,图13-2,图13-3,图13-4,常用的双向驱动器为74LS245,图13-4为其引脚图和逻辑图。,图13-5是AT89C51单片机应用系统总线驱动扩展电路。P0口的双向驱动采用74LS245,如图13-5(b)所示;P2口的单向驱动器采用74LS244,如图13-5(a)所示。,图13-5,13.4.2 AT89C51的最小系统AT89C51内部有4KB闪烁存储器,芯片本身就是一个最小系统。在能满足系统的性能要求的情况下,可优先考虑采用此种方案。这种最小系统简单、可靠。在用89C51单片机构成最小应用系统时,只要将单片机接上时钟电路和复位电路即可,如图13-6所示。本最小应用系统
10、只能用作一些小型的数字量的测控单元。,图13-6,13.4.3 应用设计举例-水温控制系统的设计,水温控制是经常遇到的过程控制。下面介绍以89C51为核心的水温控制系统的设计。本系统采用3位LED显示器显示水温度,温度控制采用改进的PID数字控制算法。具有如下基本功能:(1)温度控制的设定范围为 25-50,最小分辨率为0.1。(2)偏差0.6,静态误差0.4。(3)实时显示当前的温度值。(4)命令按键5个:复位键,功能转换键,加1键,减1键。,1.硬件电路设计硬件电路从功能模块上来划分有:主机电路数据采集电路键盘、显示电路控制执行电路(1)硬件功能结构框图硬件功能结构框图如图13-7所示。,
11、图13-7,(2)数据采集电路的设计主机采用AT89C51,系统时钟采用12MHz,内部含有4K字节的闪烁存储器。无须外扩程序存储器。数据采集电路主要由温度传感器、A/D转换器、放大电路等组成,见图13-8。,图13-8,(3)控制执行电路的设计由单片机的输出来控制风扇或电炉。设计中要采用光电耦合器进行强电和弱电的隔离,但还要考虑到输出信号要对可控硅进行触发,以便接通风扇或电炉电路。可控硅选用了既有光电隔离又有触发功能的MC3041。其中使用P1.0控制电炉电路,P1.1控制风扇电路,如图13-9所示。,图13-9,(4)键盘与显示器电路的设计 键盘共有4个键,采用软件查询和外部中断相结合的方
12、法来设计,当某个键按下时,低电平有效。4个键K1K4的功能定义如表13-2所示。,表13-2 4个键K1-K4的定义,按键K2与 INT0*(P3.2)相连,采用外部中断方式,且优先级定为高优先级。K3和K4分别与P1.7和P1.6相连,采用软件查询方式,K1为复位键,与RC构成复位电路。显示电路部分利用串行口来实现3位LED的共阳静态显示,显示内容为温度的十位、个位以及小数点后的一位。利用串行口实现LED的共阳静态显示的工作原理及软件编程请见小节的有关内容。,2.软件设计模块化设计,三大模块:主程序模块、功能实现模块和运算控制模块。(1)主程序模块主程序流程如图13-10所示。在主程序中首先
13、给定PID算法的参数值,然后通过循环显示当前温度,以等待中断,并且使键盘外部中断为高优先级,以便使主程序程序能实时响应键盘处理。设定定时器T0为5s定时,无键按下时,应每隔5s响应一次,以用来采集温度传感器并经A/D转换的温度信号。设置定时器T1为嵌套在T0之中的定时中断,初值由PID算法子程序提供,以用来执行对电炉或风扇的控制。,图13-10,(2)功能实现模块 T1中断子程序 键盘中断子程序 T0中断子程序(3)运算控制模块 标度变换子程序 PID算法子程序,13.4 应用系统的软件设计13.4.1 软件设计考虑的问题 在进行应用系统的总体设计时,软件设计和硬件设计应统一考虑,相互结合进行
14、。当系统的电路设计定型后,软件的任务也就明确了。一般来说,软件的功能分为两大类。一类是执行软件,它能完成各种实质性的功能,如测量、计算、显示、打印、输出控制等;另一类是监控软件,它是专门用来协调各执行模块和操作者的关系,在系统软件中充当组织调度的角色。设计人员在进行程序设计时应从以下几个方面加以考虑:,(1)根据软件功能要求,将系统软件分成若干相对独立的部分,设计出合理的软件总体结构,使其清晰、简洁、流程合理。(2)各功能程序实行模块化、子程序化。既便于调试、链接,又便于移植、修改。(3)在编写应用软件之前,应绘制出程序流程图。多花一些时间来设计程序流程图,就可以节约几倍于源程序的编辑和调试时
15、间。(4)要合理分配系统资源,包括ROM、RAM、定时器/计数器、中断源等。其中最关键的是片内RAM分配。对AT89C51来讲,片内RAM指00H7FH单元,这128个字节的功能不完全相,同,分配时应充分发挥其特长,做到物尽其用。例如,在工作寄存器的8个单元中,R0和R1具有指针功能,是编程的重要角色,避免作为它用;20H2FH这16个字节具有位寻址功能,用来存放各种标志位、逻辑变量、状态变量等;设置堆栈区时应事先估算出子程序和中断嵌套技术及程序中栈操作指令使用情况,其大小应留有余量。若系统中扩展了RAM存储器,应把使用频率最高的数据缓冲器安排在片内RAM中,以提高处理速度。当RAM资源规划好
16、后,应列出一张详细的RAM资源分配表,以备编程时查用方便。,13.4.2 系统软件的总体框架设计应用设计者在软件设计时,感觉比较困难的是如何进行系统软件的总体框架设计。下面给出一个典型的例子,供读者在软件设计时参考。例13-1 有一个AT89C51的应用系统,假设5个中断源都已用到,应用系统的程序框架如下:ORG 0000H;系统程序入口LJMP MAIN;跳向主程序入口ORG 0003H;外中断0中断向量入口LJMP IINT0P;跳向外中断0中断处理程;序入口IINT0PORG 000BH;T0中断向量入口LJMP IT0P;跳向T0中断入口IT0P,ORG 0013H;外中断0中断向量入
17、口LJMP IINT1P;跳向外中断1中断处理程序入口IINT1PORG 001BH;T1中断向量入口LJMP IT1P;跳向T1中断处理程序入口IT1PORG 0023H;串行口中断向量入口LJMP ISIOP;跳向串行口中断处理程序入口ISIOPORG 0040H;主程序入口MAIN:对片内各功能部件,如定时器、串行口、中断系统进行初始化;对扩展的各个I/O接口芯片进行初始化MOV SP,#60H;对堆栈区进行初始化主程序(根据实际处理任务编写),ORG XXXXH;外中断0中断处理子程序IINT0P入口IINT0P:外中断0中断处理子程序RETIORG YYYYH IT0P:T0中断处理
18、子程序RETIORG ZZZZH IINT1P:外中断1中断处理子程序RETIORG UUUUH IT1P:T1中断处理子程序RETIORG VVVVH ISIOP:串行口中断处理子程序RETI,上述程序框架仅供参考,5个中断源的中断入口XXXXHVVVVH要根据主程序、各中断源的中断处理程序的长度而定,不要重叠。,13.5 软件抗干扰设计单片机系统在噪声环境下运行,除了前面介绍的各种抗干扰的措施外,还可采用软件来增强系统的抗干扰能力。本节介绍几种常用软件抗干扰的方法。13.5.1 软件滤波对于实时数据采集系统,为了消除传感器通道中的干扰信号,硬件上,常采用模拟滤波器对信号实现频率滤波。同样,
19、采用软件也可以完成硬件模拟滤波器类似的功能,这就是软件滤波。,1.算术平均滤波法对一点数据连续取n个值进行采样,然后算术平均。这种方法适用于对一般具有随机干扰的信号进行滤波。这样信号的特点是有一个平均值,信号在某一数值范围附近上下波动。这种滤波法当n值较大时,信号的平滑度高,但是灵敏度低;当n值较小时,平滑度低,但灵敏度高。应视具体情况选取n,以使既节约时间,又滤波效果好。对于一般流量测量,通常取n=12;若为压力,则取n=4。一般情况下n=35次平均即可。,2.滑动平均滤波法上面介绍的算术平均滤波法,每计算一次数据需要测量N次。对于测量速度较慢或要求数据计算速度较快的实时控制系统,上述方法无
20、法使用。下面介绍一种只需测量一次,就能得到当前算术平均值的方法-滑动平均滤波法。本法是把n个采样值看成一个队列,队列的长度为n,每进行一次采样,就把采样值放入队尾,而扔掉原来队首的一个采样值,这样在队列中始终有n个“最新”采样值。对队列中的n个采样值进行平均,就可以得到新的滤波值。,滑动平均滤波法对周期性干扰有良好的抑制作用,平滑度高,灵敏度低;但对偶然出现的脉冲性干扰的抑制作用差,不易消除由于脉冲干扰引起的采样值的偏差。因此它不适用于脉冲干扰比较严重的场合,而适用于高频振荡系统。通常观察不同N值下滑动平均的输出响应来选取N值,以便既少占有时间,又能达到最好滤波效果,其工程经验值为:,下例为滑
21、动平均滤波法的参考程序。【例13-2】假定n个双字节型采样值,30H单元为采样队列内存单元首地址,n个采样值之和不大于16位。新的采样值存于2EH、2FH单元,滤波值存于50H、51H单元,AVGFIL为本程序调用的算术平均滤波子程序。参考程序如下:SAVGFIL:MOVR2,#n-1;采样个数MOV R0,#32H;队列单元首地址MOV R1,#33H LOOP:MOV A,R0;移动低字节DEC R0DEC R0,MOV R0,AMOV A,R0;修改低字节地址ADD A,#04HMOV R0,AMOV A,R1;移动高字节DEC R1DEC R1MOV R1,AMOV A,R1;修改高字
22、节地址ADD A,#04HMOV R1,ADJNZ R2,LOOPMOV R0,2EH;存新的采样值MOV R1,2FHACALL AVGFIL;AVGFIL算术平均值子程序,设已编写RET,3.中位值滤波法本方法就是对某一被测参数接连采样n次(一般n取奇数),然后把n次采样值按大小排列,取中间值为本次采样值。中位值滤波能有效地克服因偶然因素引起的波动干扰。对温度、液位等变化缓慢的被测参数采用此法能收到良好的滤波效果。但对流量、速度等快速变化的参数一般不宜采用中位值滤波法。中位值滤波程序设计的实质是,首先把n个采样值从小到大或从大到小进行排序,然后再取中间值。n个数据按大小“冒泡法”(排序程序
23、设计见第4章)进行比较,直到最大数沉底为止。然后再重新进行比较,把次大值放到n-1位,依此类推,则可将n个数从小到大顺序排列。,【例13-3】设采样值从8位A/D转换器输入5次,存放在SAMP为首地址的内存单元中,采用中位值滤波。程序如下:SAMP EQU 30H ORG 1000HINTER:MOV R2,#04H;置最大循环次数SORT:MOV A,R2;小循环次数(R3)MOV R3,AMOV R0,#SAMP;采样数据首地址(R0)LOOP:MOV A,R0INC R0,MOV R1,ACLR CSUBB A,R0MOV A,R1JC DONEMOV A,R0;(R0)(R0)+1)D
24、EC R0XCH A,R0INC R0MOV R0,ADONE:DJNZ R3,LOOP;R30,小循环继续进行DJNZ R2,SORT;R20,大循环继续进行INC R0MOV A,R0RET,4.去极值平均值滤波法前面介绍的算术平均与滑动平均滤波法,在脉冲干扰比较严重的场合,则干扰将会“平均”到结果中去,故上述两种平均值法不易消除由于脉冲干扰而引起的误差。这时可采用去极值平均值滤波法。思想:连续采样n次后累加求和,同时找出其中的最大值与最小值,再从累加和中减去最大值和最小值,按n-2个采样值求平均,即可得到有效采样值。类似于体育比赛中的去掉最高、最低分,再求平均分的评分办法。,(2)打印机
25、接口,为使平均滤波算法简单,n-2应为2,4,6,8或16,故n常取4,6,8,10或18。具体做法有两种:对于快变参数,先连续采样n次,然后再处理,但要在RAM中开辟出n个数据的暂存区;对于慢变参数,可一边采样,一边处理,而不必在RAM中开辟数据暂存区。实践中,为了加快测量速度,一般n取4。【例13-4】以n=4为例,即连续进行4次数据采样,去掉其中最大值和最小值,然后求剩下两个数据的平均值。R2R3存最大值,R4R5存最小值,R6R7存放累加和及最后结果。当然,连续采样不只限4次,可以进行任意次,这时,只需改变R0中的数值。参考程序(见教材),(3)A/D与D/A转换器与单片机的接口,指令
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- AT89C51 单片机 应用 系统 设计 调试
链接地址:https://www.31ppt.com/p-6501838.html