《单片机课程设计手动计数器.doc》由会员分享,可在线阅读,更多相关《单片机课程设计手动计数器.doc(11页珍藏版)》请在三一办公上搜索。
1、单片机原理与接口技术课程设计基于AT89S51单片机的手动计数器设计报告 目 录一、手动计数器课程设计功能描述21.1 单片机概述21.2 芯片简介2二、硬件分析设计及硬件连线图52.1 硬件分析设计52.2 硬件连线图6三、程序设计内容及框图63.1 程序设计内容63.2 程序框图7四、程序源代码清单7五、上机调试运行结果及分析9六、课程设计的经验教训总结9 参考文献10一、手动计数器课程设计功能描述1.1 单片机概述 单片机微型计算机是微型计算机的一个重要分支,也是颇具生命力的机种。单片机微型计算机简称单片机,特别适用于控制领域,故又称为微控制器。 通常,单片机由单块集成电路芯片构成,内部
2、包含有计算机的基本功能部件:中央处理器、存储器和I/O接口电路等。因此,单片机只需要和适当的软件及外部设备相结合,便可成为一个单片机控制系统。 单片机经过1、2、3、3代的发展,目前单片机正朝着高性能和多品种方向发展,它们的CPU功能在增强,内部资源在增多,引角的多功能化,以及低电压底功耗。1.2 MSC-51芯片简介1.2.1 MCS-51单片机内部结构8051是MCS-51系列单片机的典型产品,我们以这一代表性的机型作为课程设计的实验板。 8051单片机包含中央处理器、程序存储器(ROM)、数据存储器(RAM)、定时/计数器、并行接口、串行接口和中断系统等几大单元及数据总线、地址总线和控制
3、总线等三大总线,现在我们分别加以说明:中央处理器:中央处理器(CPU)是整个单片机的核心部件,是8位数据宽度的处理器,能处理8位二进制数据或代码,CPU负责控制、指挥和调度整个单元系统协调的工作,完成运算和控制输入输出功能等操作。数据存储器(RAM)8051内部有128个8位用户数据存储单元和128个专用寄存器单元,它们是统一编址的,专用寄存器只能用于存放控制指令数据,用户只能访问,而不能用于存放用户数据,所以,用户能使用的RAM只有128个,可存放读写的数据,运算的中间结果或用户定义的字型表。程序存储器(ROM):8051共有4096个8位掩膜ROM,用于存放用户程序,原始数据或表格。定时/
4、计数器(ROM):8051有两个16位的可编程定时/计数器,以实现定时或计数产生中断用于控制程序转向。并行输入输出(I/O)口:8051共有4组8位I/O口(P0、 P1、P2或P3),用于对外部数据的传输。全双工串行口:8051内置一个全双工串行通信口,用于与其它设备间的串行数据传送,该串行口既可以用作异步通信收发器,也可以当同步移位器使用。中断系统:8051具备较完善的中断功能,有两个外中断、两个定时/计数器中断和一个串行中断,可满足不同的控制要求,并具有2级的优先级别选择。时钟电路:8051内置最高频率达12MHz的时钟电路,用于产生整个单片机运行的脉冲时序,但8051单片机需外置振荡电
5、容。单片机的结构有两种类型,一种是程序存储器和数据存储器分开的形式,即哈佛(Harvard)结构,另一种是采用通用计算机广泛使用的程序存储器与数据存储器合二为一的结构,即普林斯顿(Princeton)结构。INTEL的MCS-51系列单片机采用的是哈佛结构的形式,而后续产品16位的MCS-96系列单片机则采用普林斯顿结构。下图是MCS-51系列单片机的内部结构示意图。 1.2.2 MCS-51的引脚说明:MCS-51系列单片机中的8031、8051及8751均采用40Pin封装的双列直接DIP结构,右图是它们的引脚配置,40个引脚中,正电源和地线两根,外置石英振荡器的时钟线两根,4组8位共32
6、个I/O口,中断口线与P3口线复用。现在我们对这些引脚的功能加以说明:MCS-51的引脚说明:MCS-51系列单片机中的8031、8051及8751均采用40Pin封装的双列直接DIP结构,右图是它们的引脚配置,40个引脚中,正电源和地线两根,外置石英振荡器的时钟线两根,4组8位共32个I/O口,中断口线与P3口线复用。现在我们对这些引脚的功能加以说明:Pin9:RESET/Vpd复位信号复用脚,当8051通电,时钟电路开始工作,在RESET引脚上出现24个时钟周期以上的高电平,系统即初始复位。初始化后,程序计数器PC指向0000H,P0-P3输出口全部为高电平,堆栈指针写入07H,其它专用寄
7、存器被清“0”。RESET由高电平下降为低电平后,系统即从0000H地址开始执行程序。然而,初始复位不改变RAM(包括工作寄存器R0-R7)的状态,8051的初始态。8051的复位方式可以是自动复位,也可以是手动复位,见下图。此外,RESET/Vpd还是一复用脚,Vcc掉电其间,此脚可接上备用电源,以保证单片机内部RAM的数据不丢失。Pin30:ALE/当访问外部程序器时,ALE(地址锁存)的输出用于锁存地址的低位字节。而访问内部程序存储器时,ALE端将有一个1/6时钟频率的正脉冲信号,这个信号可以用于识别单片机是否工作,也可以当作一个时钟向外输出。更有一个特点,当访问外部程序存储器,ALE会
8、跳过一个脉冲。如果单片机是EPROM,在编程其间,将用于输入编程脉冲。Pin29:当访问外部程序存储器时,此脚输出负脉冲选通信号,PC的16位地址数据将出现在P0和P2口上,外部程序存储器则把指令数据放到P0口上,由CPU读入并执行。Pin31:EA/Vpp程序存储器的内外部选通线,8051和8751单片机,内置有4kB的程序存储器,当EA为高电平并且程序地址小于4kB时,读取内部程序存储器指令数据,而超过4kB地址则读取外部指令数据。如EA为低电平,则不管地址大小,一律读取外部程序存储器指令。显然,对内部无程序存储器的8031,EA端必须接地。在编程时,EA/Vpp脚还需加上21V的编程电压
9、。二、课程设计分析设计及硬件接线图2.1 分析设计利用AT89S51单片机来制作一个手动计数器,在AT89S51单片机的P3.7管脚接一个轻触开关,作为手动计数的按钮;用单片机的P0.0P0.7接一个共阳数码管,作为0099计数的个位数显示;用单片机的P1.0P1.7接一个共阳数码管,作为0099计数的十位数显示;P2.7口接一个发光二极管作为计数按钮显示,P2.7口接一个发光二极管作为数据溢出标志。硬件电路图如下图所示。2.2 硬件接线图三、程序设计内容及框图3.1程序设计内容 (1)单片机对按键的识别的过程处理 (2)单片机对正确识别的按键进行计数,同时P2.7口驱动发光二极管进行闪烁显示
10、,计数满时,P2.0口驱动发光二极管显示溢出,又从零开始计数; (3)单片机对计的数值要进行数码显示,计得的数是十进数,含有十位和个位,我们要把十位和个位拆开分别送出这样的十位和个位数值到对应的数码管上显示。如何拆开十位和个位我们可以把所计得的数值对10求余,即可个位数字,对10整除,即可得到十位数字了。 (4)通过查表方式,分别显示出个位和十位数字。 3.2程序框图 四、程序源代码清单#include unsigned char code table=0xc0,0xf9,0xa4,0xb0,0x99, 0x92,0x82,0xf8,0x80,0x90; /共阳极数码管显示代码unsigned
11、 char Count; unsigned int z;void delay(int z) /延时程序 unsigned char i,j; for(i=z;i0;i-) for(j=496;j0;j-); void main(void) Count=0; /初始状态数码管显示00 P1=tableCount/10; P0=tableCount%10; while(1) if(P3_7=0) /读取P3.7口按钮状态 delay(10); /调用延时,防抖动 if(P3_7=0) /确定按钮按下 P2_7=0; /P2.7口发光二极管闪烁 delay(20); P2_7=1; Count+;
12、/计数累加 if(Count=100) /检查溢出 P2_0=0; /P2.0口二极管闪烁delay(2000);P2_0=1; Count=0; /计数归零 P1=tableCount/10; /数码管显示十位数字 P0=tableCount%10; /数码管显示个位数字 while(P3_7=0); 五、上机调试运行结果及分析 最初开始调试时,发现数码管个位数字与十位数字颠倒,经分析发现将P1口和P0口的输出颠倒了;改正后,再次调试,功能演示正常,但个人感觉计数按钮显示二极管和溢出显示二极管闪烁过于短暂,经反复修改延时时间,终于得到较满意的显示效果。六、课程设计的经验教训总结通过这次课程设
13、计,加强了我的分析、思考、解决问题的能力。同时在课程设计的过程中,通过对实验板的观察和软件程序的不断改进,深刻体会到了单片机的工作原理和程序开发的步骤过程。实践是检验真理的唯一标准,完成课程设计的基础上,我还尝试了其他的实验项目,如交通灯设计和报警器设计等。越学习越发现单片机的无穷魅力,这种兴趣比上理论课时强烈得多。但是,由于课设时间比较短暂,没有能够尝试更多的功能,颇为遗憾。同时,本次课设,本想加入溢出声音报警,但实验室没有接线,无法连接蜂鸣器,也是一个遗憾。希望学校重视学生实验室,给予实验室应有的硬件设备,让学生更多的尝试实践体验学科的实用性。最后感谢指导老师的无私帮助!参考文献l 单片机原理与接口技术.牛昱光.电子工业出版社l 51单片机实验指导书.太原理工大学信息工程学院实验中心l 单片机原理及其应用.胡汉才.清华大学出版社l 单片机应用文集.何立民.北京航空航天大学出版社