




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、基于单片机的数字电子秒表的设计与实基于单片机的数字电子秒表的设计与实现现摘要摘要 近年来随着科技的飞速发展,单片机的应用正在不断的走向深入。本文阐述了基于单片机的数字电子秒表设计。本设计主要特点是计时精度达到 0.01s,解决了传统的由于计时精度不够造成的误差和不公平性,是各种体育竞赛的必备设备之一。本设计的数字电子秒表系统采用 8051 单片机为中心器件,利用其定时器/计数器定时和记数的原理,结合显示电路、LED 数码管以及外部中断电路来设计计时器。将软、硬件有机地结合起来,使得系统能够实现五位 LED 显示,显示时间为 099.99 秒,计时精度为 0.01 秒,能正确地进行计时,同时能记
2、录一次时间,并在下一次计时后对上一次计时时间进行查询。其中软件系统采用汇编语言编写程序,包括显示程序,定时中断服务,外部中断服务程序,延时程序等,并在 WAVE 中调试运行,硬件系统利用PROTEUS 强大的功能来实现,简单切易于观察,在仿真中就可以观察到实际的工作状态。 关键字关键字:单片机;数字电子秒表;仿真 目 录摘 要.IAbstract .II绪 论.11 硬件设计.31.1 总体方案的设计.31.2 单片机的选择.41.3 显示电路的选择与设计.71.4 按键电路的选择与设计.101.5 时钟电路的选择与设计.111.6 复位电路的选择与设计.131.7 系统总电路的设计.152
3、软件设计.172.1 程序设计思想.172.2 系统资源的分配.172.3 主程序设计.182.4 中断程序设计.193 数字电子秒表的安装与调试.253.1 软件的仿真与调试.253.2 硬件的安装与调试.253.3 系统程序的烧录.263.4 数字电子秒表的精度调试.27结 论.28参考文献.28附录 A 程序.30附录 B 电路原理图.35绪 论秒表计时器是电器制造,工业自动化控制、国防、实验室及科研单位理想的计时仪器,它广泛应用于各种继电器、电磁开关,控制器、延时器、定时器等的时间测试。2004 年 8 月 28 日 15 点 15 分,中国选手孟关良/杨文军在雅典奥运会男子 500
4、米划艇决赛中,以 1 分 40 秒 278 的成绩获得中国在雅典奥运会的第 28 金。这是中国皮划艇项目的第一枚奥运金牌,也是中国水上项目在历届奥运会上所获得的第一枚金牌。孟关良/杨文军的成绩比获得银牌的古巴选手只快了 0.072 秒,以至于两人在夺冠之后还不敢相信。在现在的体育竞技比赛中,随着运动员的水平不断提高,差距也在不断缩小。有些运动对时间精度的要求也越来越高,有时比赛冠亚军之间的差距只有几毫秒,因此就需要高精度的秒表来记录成绩。本设计利用 8051 单片机的定时器/计数器定时和记数的原理,使其能精确计时。利用中断系统使其能实现开始暂停的功能。P0 口输出段码数据,P2.0-P2.4
5、口作列扫描输出,P1.1、P3.2、P3.3、P2.5 分别接四个按钮开关,分别实现开始、暂停、清零和查看上次时间的功能。显示电路由五位共阴极数码管组成。初始状态下计时器显示 00.00,当按下开始键时,外部中断 INT1 向 CPU 发出中断请求,CPU 转去执行外部中断 1 服务程序,即开启定时器 T0。计时采用定时器 T0 中断完成,定时溢出中断周期为 1ms,当一处中断后向 CPU 发出溢出中断请求,每发出一次中断请求就对毫秒计数单元进行加一,达到 10 次就对十毫秒位进行加一,依次类推,直到 99.99 秒重新复位。在计时过程中,只要按下暂停键,外部中断 INT0 向 CPU发出中断
6、请求,CPU 转去执行外部中断 0 服务程序,即关闭定时器 T0,调用显示程序,实现暂停功能,同时将此次计时时间存入寄存区。然后对 P1.1 进行扫描。当 P1.1 按下时就跳转回主程序。等待下一次计时开始。在按下暂停键时,将此时的计时时间存入中间缓存区,当再次按下开始键时,则讲中间缓存区的数据转入最终缓存区。秒表停止后对查看键 P2.5 进行扫描,P2.5 按下为低电平时,调用最终缓存区的数据进行显示,即显示上一次计时成绩。当 P2.5 位高电平时,调用显示缓存区的数据进行显示,即显示当此计时的成绩。根据以上设计思路从而实现数字电子秒表的计时和查看上一次计时时间的功能。本文主要内容包括三部分
7、:第一部分介绍硬件部分设计思路及方案;第二部分介绍了软件部分的设计思路和设计;最后一部分则是整个系统的安装与调试过程。1 硬件设计1.1 总体方案的设计数字电子秒表具有显示直观、读取方便、精度高等优点,在计时中广泛使用。本设计用单片机组成数字电子秒表,力求结构简单、精度高为目标。设计中包括硬件电路的设计和系统程序的设计。其硬件电路主要有主控制器,计时与显示电路和回零、启动和停表电路等。主控制器采用单片机 8051,显示电路采用共阴极 LED 数码管显示计时时间。本设计利用 8051 单片机的定时器/计数器定时和记数的原理,使其能精确计时。利用中断系统使其能实现开始暂停的功能。P0 口输出段码数
8、据,P2.0-P2.4 口作列扫描输出,P1.1、P3.2、P3.3、P2.5 口接四个按钮开关,分别实现开始、暂停、清零和查看上次计时时间功能。电路原理图设计最基本的要求是正确性,其次是布局合理,最后在正确性和布局合理的前提下力求美观。硬件电路图按照图 1.1 进行设计。控制开关 位驱动六位数码管8051单片机控制器图 1.1 数字秒表硬件电路基本原理图根据要求知道秒表设计主要实现的功能是计时和显示。本设计中,数码管显示的数据存放在内存单元 79H7DH 中。其中 79H 存放毫秒位数据,7AH 存放十毫秒位数据,7BH 存放百毫秒位数据,7CH 存放秒位数据,7DH 存放十秒位数据,每一地
9、址单元内均为十进制 BCD 码。由于采用软件动态扫描实现数据显示功能,显示用十进制BCD 码数据的对应段码存放在 ROM 表中。显示时,先取出 79H-7dH 某一地址中的数据,然后查得对应的显示用段码,并从 P0 口输出,P2 口将对应的数码管选中供电,就能显示该地址单元的数据值。最终缓存区则设置为 59H-5DH,数据存放规则和 79H-7DH 一样。分别对应存放毫秒位至十秒位数据。与 79H-7DH 存储区不一样的是:59H-5DH 存储的内容为数字秒表上一次计时显示的时间。而 79H-7DH 为当前计时时间存储区。计时采用定时器 T0 中断完成,定时溢出中断周期为 1ms,当一处中断后
10、向 CPU发出溢出中断请求,每发出一次中断请求就对毫秒计数单元进行加一,达到 10 次就对十毫秒位进行加一,依次类推,直到 99.99 秒重新复位。 再看按键的处理。这四个键可以采用中断的方法,也可以采用扫描的方法来识别。复位键和查看主要功能在于数值复位和查询上次计时时间,对于时间的要求不是很严格。而开始和停止键则是用于对时间的锁定,需要比较准确的控制。因此可以对复位和查看按键采取扫描的方式。而对开始和停止键采用外部中断的方式。设计中包括硬件电路的设计和系统程序的设计。其硬件电路主要有主控制器,显示电路和回零、启动、查看、停表电路等。主控制器采用单片机 8051,显示电路采用共阴极 LED 数
11、码管显示计时时间,四个按键均采用触点式按键。1.2 单片机的选择本课题在选取单片机时,充分借鉴了许多成形产品使用单片机的经验,并根据自己的实际情况,选择了 Intel 公司的 8051。单片机的外部结构8051 单片机采用 40 引脚的双列直插封装方式。图 1.2 为引脚排列图, 40 条引脚说明如下:主电源引脚 Vss 和 Vcc Vss 接地 Vcc 正常操作时为+5 伏电源外接晶振引脚 XTAL1 和 XTAL2 XTAL1 内部振荡电路反相放大器的输入端,是外接晶体的一个引脚。当采用外部振荡器时,此引脚接地。 XTAL2 内部振荡电路反相放大器的输出端。是外接晶体的另一端。当采用外部振
12、荡器时,此引脚接外部振荡源。图 1.2 8051 单片机引脚图控制或与其它电源复用引脚 RST/VPD,ALE/,和/VppPROGPSENEA RST/VPD 当振荡器运行时,在此引脚上出现两个机器周期的高电平(由低到高跳变) ,将使单片机复位在 Vcc 掉电期间,此引脚可接上备用电源,由 VPD 向内部提供备用电源,以保持内部 RAM 中的数据。 ALE/正常操作时为 ALE 功能(允许地址锁存)提供把地址的低字节锁PROG存到外部锁存器,ALE 引脚以不变的频率(振荡器频率的 1/6)周期性地发出正脉冲信号。因此,它可用作对外输出的时钟,或用于定时目的。对于 EPROM 型单片机,在 E
13、PROM 编程期间,此引脚接收编程脉冲(功能)PROG 外部程序存储器读选通信号输出端,在从外部程序存储取指令(或数PSEN据)期间,在每个机器周期内两次有效。同样可以驱动八 LSTTL 输入。PSENPSEN /Vpp、/Vpp 为内部程序存储器和外部程序存储器选择端。当/VppEAEAEA为高电平时,访问内部程序存储器,当/Vpp 为低电平时,则访问外部程序存储器。EA对于 EPROM 型单片机,在 EPROM 编程期间,此引脚上加 21 伏 EPROM 编程电源(Vpp) 。输入/输出引脚 P0.0 - P0.7,P1.0 - P1.7,P2.0 - P2.7,P3.0 - P3.7。
14、P0 口(P0.0 - P0.7)是一个 8 位漏极开路型双向 I/O 口,在访问外部存储器时,它是分时传送的低字节地址和数据总线,P0 口能以吸收电流的方式驱动八个 LSTTL负载。 P1 口(P1.0 - P1.7)是一个带有内部提升电阻的 8 位准双向 I/O 口。能驱动(吸收或输出电流)四个 LSTTL 负载。 P2 口(P2.0 - P2.7)是一个带有内部提升电阻的 8 位准双向 I/O 口,在访问外部存储器时,它输出高 8 位地址。P2 口可以驱动(吸收或输出电流)四个 LSTTL 负载。 P3 口(P3.0 - P3.7)是一个带有内部提升电阻的 8 位准双向 I/O 口。能驱
15、动(吸收或输出电流)四个 LSTTL 负载。8051 具有以下标准功能:8k 字节 Flash,256 字节 RAM,32 位 I/O 口线, 2 个数据指针,两个 16 位定时器/计数器,一个全双工串行口,片内晶振及时钟电路。另外,8051 可降至 0Hz 静态逻辑操作,支持 2 种软件可选择节电模式。空闲模式下,CPU停止工作,允许 RAM、定时器/计数器、串口、中断继续工作。掉电保护方式下,RAM 内容被保存,振荡器被冻结,单片机一切工作停止,直到下一个中断或硬件复位为止。CPU 是单片机的核心部件。它由运算器和控制器等部件组成。(1) 运算器运算器的功能是进行算术运算和逻辑运算。可以对
16、半字节(4 位) 、单字节等数据进行操作。例如能完成加、减、乘、除、加 1、减 1、BCD 码十进制调整、比较等算术运算和与、或、异或、求补、循环等逻辑操作,操作结果的状态信息送至状态寄存器。8051 运算器还包含有一个布尔处理器,用来处理位操作。(2) 程序计数器 PC程序计数器 PC 用来存放即将要执行的指令地址,共 16 位,可对 64K 程序存储器直接寻址。执行指令时,PC 内容的低 8 位经 P0 口输出,高 8 位经 P2 口输出。(3) 令寄存器指令寄存器中存放指令代码。CPU 执行指令时,由程序存储器中读取的指令代码送入指令寄存器,经译码后由定时与控制电路发出相应的控制信号,完
17、成指令功能。1.3 显示电路的选择与设计对于数字显示电路,通常采用液晶显示或数码管显示。本设计的显示电路采用 7 段数码管作为显示介质。数码管显示可以分为静态显示和动态显示两种。由于本设计需要采用五位数码管显示时间,如果静态显示则占用的口线多,硬件电路复杂。所以采用动态显示。8051位 驱 动段 驱 动六位数码管图 1.3 显示电路基本原理图动态显示是一位一位地轮流点亮各位数码管,这种逐位点亮显示器的方式称为位扫描。通常各位数码管的段选线相应并联在一起,由一个 8 位的 I/O 口控制;各位的公共阴极位选线由另外的 I/O 口线控制。动态方式显示时,各数码管分时轮流选通,要使其稳定显示必须采用
18、扫描方式,即在某一时刻只选通一位数码管,并送出相应的段码,在另一时刻选通另一位数码管,并送出相应的段码,依此规律循环,即可使各位数码管显示将要显示的字符,虽然这些字符是在不同的时刻分别显示,但由于人眼存在视觉暂留效应,只要每位显示间隔足够短就可以给人同时显示的感觉。数码显示管分为共阳数码管和共阴数码管两种共阳极数码管的 8 个发光二极管的阳极(二极管正端)连接在一起,如图1.4(b),通常,公共阳极接高电平(一般接电源),其它管脚接段驱动电路输出端。当某段驱动电路的输出端为低电平时,则该端所连接的字段导通并点亮,根据发光字段的不同组合可显示出各种数字或字符。此时,要求段驱动电路能吸收额定的段导
19、通电流,还需根据外接电源及额定段导通电流来确定相应的限流电阻。共阴极数码管的 8 个发光二极管的阴极(二极管负端)连接在一起,如图(c),通常,公共阴极接低电平(一般接地),其它管脚接段驱动电路输出端,当某段驱动电路的输出端为高电平时,则该端所连接的字段导通并点亮,根据发光字段的不同组合可显示出各种数字或字符。此时,要求段驱动电路能提供额定的段导通电流,还需根据外接电源及额定段导通电流来确定相应的限流电阻。 图 1.4 (a)数码管引脚图 (b)共阳极内部结构图 (c)共阴极内部结构图本设计采用共阴极数码显示管做显示电路,由于采用的是共阴的数码显示管,所以只要数码管的 a、b、c、d、e、f、
20、g、h 引脚为高电平,那么其对应的二极管就会发光,使数码显示管显示 09 的编码见表 1.1。表 1.1 共阴极数码显示管字型代码字型共阴极代码字型共阴极代码03FH56DH106H67DH25BH707H34FH87FH466H96FH动态显示电路由显示块、字形码驱动模块、字位驱动模块三部分组成。如图 1.3 所示为本系统的 5 位 LED 动态显示器接口电路。图中,5 个数码管的 8 段段选线分别与外接上拉电阻的单片机 P0 口对应相连,而 5 个数码管的位控制端则和 NPN 型三极管的集电极相连接。单片机的 P2.0P2.4 口则分别对应数码显示管的最低位到最高位,P2.0P2.4 口分
21、别和五个 NPN 型三极管的基极相连,做三极管导通的控制端,而 NPN型三极管选用 9013 型三极管。根据 9013 的资料显示:其耐压值为 40V,最大功率为0.65W,最大电流为 0.5A,电气性能完全满足本设计的要求。另外数码管显示是采用动态显示,所以对三极管的开关频率有一定的要求。根据电子秒表的设计计算可知动态显示的频率最高为 3KHz,而 9013 的导通频率为 150MHz,完全能满足本设计的要求,所以最终选取 9013 三极管最为位控制开关。由于数码管是有 P0 口来驱动,它内部没有上拉电阻,作为输出口时驱动能力比较弱,不能点亮数码显示管,因此 P0 口必须接上拉电阻来提高驱动
22、能力。另外一位共阴数码管的驱动电流一般为 20mA 左右,如果电流太大容易造成数码管损坏,所以也需要根据电源的电压值来确定上拉电阻的大小。如果电阻过小,势必会形成灌电流过大,造成单片机 IO 的损坏,如果电阻过大,那么对拉电流没有太大的影响。电源供电电压为 5V,当上拉电阻选用 220 电阻时灌电流为 22mA。不会损坏单片机的 I/O 口,同时也可以为数码显示管起到限制电流的保护作用。 1.4 按键电路的选择与设计本设计中有四个按键,分别实现开始、暂停、复位和查看功能。这四个键可以采用中断的方法,也可以采用查询的方法来识别。对于复位键和查看键,主要功能在于数值复位和对上次计时时间的查看,对于
23、时间的要求不是很严格,而开始和暂停键主要用于时间的锁定,需要比较准确的控制。因此可以考虑,对复位键和查看键采用查询的方式,而对于开始和暂停键采用外部中断。四个按键均采用低电平有效,具体电路连接图如图 1.5 所示。当按键没有按下时,单片机的 I/O 口直接连接电源,因此需要接上拉电阻来进行限流,本设计中选取阻值为 2k 的电阻作为上拉电阻,根据计算可知此时的灌电流为2.5mA,查看 8051 的资料得知次电流在安全范围内,符合安全设计要求。开始暂停复位查看 P3.3(INT1) P3.2(INT0) P1.1 P2.5VCC图 1.5 按键电路按键电路中由于采用了外部中断,所以需要用到 P3
24、口的第二功能。P3 口引脚的第二功能如表 1.2表 1.2 P3 口引脚第二功能表 P3 口引脚特殊功能P3.0RXD(串行输入口)P3.1TXD(串行输出口)P3.2INT0(外部中断 0 请求输入端)P3.3INT1(外部中断 1 请求输入端)P3.4 T0(定时器/计数器 0 计数脉冲输入端)P3.5 T1(定时器/计数器 1 计数脉冲输入端)P3.6WR(片外数据存储器写选通信号输出端)P3.7 RD(片内数据存储器读选通信号输出端)1.5 时钟电路的选择与设计单片机的时钟信号用来提供单片机内各种微操作的时间基准,8051 片内设有一个由反向放大器所构成的振荡电路,XTAL1 和 XT
25、AL2 分别为振荡电路的输入和输出端,8051 单片机的时钟信号通常用两种电路形式得到:内部振荡方式与外部振荡方式。外部方式的时钟很少用,若要用时,只要将 XTAL1 接地,XTAL2 接外部振荡器就行。对外部振荡信号无特殊要求,只要保证脉冲宽度,一般采用频率低于 12MHz 的方波信号。时钟发生器把振荡频率两分频,产生一个两相时钟信号 P1和 P2供单片机使用。P1在每一个状态 S 的前半部分有效,P2在每个状态的后半部分有效。本设计采用的内部振荡方式,内部振荡方式所得的时钟信号比较稳定,实用电路中使用较多。本设计系统的时钟电路如图 1.4 所示。只要按照图 1.6 所示电路进行设计连接就能
26、使系统可靠起振并能稳定运行。图中,电容器 C1 、C2起稳定振荡频率、快速起振的作用,电容值一般为 533pF。但在时钟电路的实际应用中一定要注意正确选择其大小,并保证电路的对称性,尽可能匹配,选用正牌的瓷片或云母电容,如果可能的话,温度系数尽可能低。本设计中采用大小为 30pF 的电容和 12MHz 的晶振。图 1.6 内部振荡电路(4) 时序8051 典型的指令周期(执行一条指令的时间称为指令周期)为一个机器周期,一个机器周期由六个状态(十二振荡周期)组成。每个状态又被分成两个时相 P1和 P2。所以,一个机器周期可以依次表示为 S1P1,S1P2,S6P1,S6P2。通常算术逻辑操作在
27、P1时相进行,而内部寄存器传送在 P2时相进行。图 1.7 8051 时序图 1.7 给出了 8051 单片机的取指和执行指令的定时关系。这些内部时钟信号不能从外部观察到,所用 XTAL2 振荡信号作参考。在图中可看到,低 8 位地址的锁存信号ALE 在每个机器周期中两次有效:一次在 S1P2与 S2P1期间,另一次在 S4P2与 S5P1期间。对于单周期指令,当操作码被送入指令寄存器时,便从 S1P2开始执行指令。如果是双字节单机器周期指令,则在同一机器周期的 S4期间读入第二个字节,若是单字节单机器周期指令,则在 S4期间仍进行读,但所读的这个字节操作码被忽略,程序计数器也不加 1,在 S
28、6P2结束时完成指令操作。图 1.7 的(a)和(b)给出了单字节单机器周期和双字节单机器周期指令的时序。1.6 复位电路的选择与设计当 8051 单片机的复位引脚 RST(全称 RESET)出现 2 个机器周期以上的高电平时,单片机就完成了复位操作。如果 RST 持续为高电平,单片机就处于循环复位状态,而无法执行程序。因此要求单片机复位后能脱离复位状态。而本系统选用的是 12MHz的晶振,因此一个机器周期为 1s,那么复位脉冲宽度最小应为 2s。在实际应用系统中,考虑到电源的稳定时间,参数漂移,晶振稳定时间以及复位的可靠性等因素,必ALE时钟S1S4S6S5S3S2读操作码读操作码(无效)(
29、a) 1字节1周期指令读下一指令S1S4S6S5S3S2读操作码读第二字节(b) 2字节1周期指令读下一指令S1S4S6S5S3S2读操作码读操作码(无效)(c) 1字节2周期指令读下一指令S1S4S6S5S3S2须有足够的余量。根据应用的要求,复位操作通常有两种基本形式:上电复位、手动复位。上电复位要求接通电源后,自动实现复位操作。80C51 单片机的上电复位POR(Power On Reset)实质上就是上电延时复位,也就是在上电延时期间把单片机锁定在复位状态上。在单片机每次初始加电时,首先投入工作的功能部件是复位电路。复位电路把单片机锁定在复位状态上并且维持一个延时(记作 TRST) ,
30、以便给予电源电压从上升到稳定的一个等待时间;在电源电压稳定之后,再插入一个延时,给予时钟振荡器从起振到稳定的一个等待时间;在单片机开始进入运行状态之前,还要至少推迟 2 个机器周期的延时。上述一系列的延时,都是利用在单片机 RST 引脚上外接一个 RC 支路的充电时间而形成的。典型复位电路如图 1.8(a)所示,其中的阻容值是原始手册中提供的。图 1.8 上电复位延时电路标准 80C51 不仅复位源比较单一,而且还没有设计内部上电复位的延时功能,因此必须借助于外接阻容支路来增加延时环节,如图 1.8(a)所示。其实,外接电阻 R 还是可以省略的,理由是一些 CMOS 单片机芯片内部存在一个现成
31、的下拉电阻 Rrst。例如,80C51 系列的 Rrst 阻值约为 50200 k;P89V51Rx2 系列的 Rrst 阻值约为 40225 k,如图 1.9 所示。因此,在图 1.8(a)基础上,上电复位延时电路还可以精简为图1.8(b)所示的简化电路(其中电容 C 的容量也相应减小了) 。图 1.9 复位引脚 RST 内部电路在每次单片机断电之后,须使延时电容 C 上的电荷立刻放掉,以便为随后可能在很短的时间内再次加电作好准备。否则,在断电后 C 还没有充分放电的情况下,如果很快又加电,那么 RC 支路就失去了它应有的延迟功能。因此,在图 1.8(a)的基础上添加一个放电二极管 D,上电
32、复位延时电路就变成了如图 1.8(c)所示的改进电路。也就是说,只有 RC 支路的充电过程对电路是有用的,放电过程不仅无用,而且会带来潜在的危害。于是附加一个放电二极管 D 来大力缩短放电持续时间,以便消除隐患。二极管 D 只有在单片机断电的瞬间(即 VCC 趋近于 0 V,可以看作 VCC 对地短路)正向导通,平时一直处于反偏截止状态。手动复位要求在电源接通的条件下,在单片机运行期间,如果发生死机,用按钮开关操作使单片机复位。单片机要完成复位,必须向复位端输出并持续两个机器周期以上的高电平,从而实现复位操作。本设计采用上电且开关复位电路,如图 1.10 所示上电后,由于电容充电,使 RST持
33、续一段高电平时间。当单片机已在运行之中时,按下复位键也能使 RST 持续一段时间的高电平,从而实现上电且开关复位的操作。通常选择 C=1030F,R=1K,本设计采用的电容值为 22F 的电容和电阻为 1K 的电阻。VCCC3R4S4R52001K22uF接RSET图 1.10 单片机复位电路1.7 系统总电路的设计系统总电路由以上设计的显示电路,时钟电路,按键电路和复位电路组成,只要将单片机与以上各部分电路合理的连接就组成了系统总电路。系统总电路图附录 B 所示。8051 单片机为主电路的核心部分,各个电路均和单片机相连接,由单片机统筹和协调各个电路的运行工作。8051 单片机提供了 XTA
34、L1 和 XTAL2 两个专用引脚接晶振电路,因此只要将晶振电路接到两个专用引脚即可为单片机提供时钟脉冲,但在焊接晶振电路时要尽量使晶振电路靠近单片机,这样可以为单片机提供稳定的始终脉冲。 复位电路同晶振电路,单片机设有一个专用的硬件复位接口,并设置为高电平有效。按键电路与单片机的端口连接可以由用户自己设定,本设计中软件复位键和查看键分别接单片机的 P1.1 和 P2.5,均设为低电平有效。而另外的开始键和暂停键两键使用了外部中断,所以需要连接到单片机的特殊接口 P3.3 和 P3.2,这两个 I/O 口的第二功能分别为单片机的外部中断 1 端口和外部中断 0 端口。同样设置为位低电平有效。显
35、示电路由五位数码管组成,采用动态显示方式,因此有 8 位段控制端和 5 位位控制端,八位段控制接 P0 口,P0.0P0.7 分别控制数码显示管的a、b、c、d、e、f、g、dp 显示,8051 的 P0 口没有集成上拉电阻,高电平的驱动能力很弱,所以需要接上拉电阻来提高 P0 的高电平驱动能力。五位位控制则由低位到高位分别接到 P2.0P2.4 口,NPN 三极管 9013 做为位控制端的开关,当 P2.0P2.4 端口任意一个端口为高电平时,与其相对应的三极管就导通,对应的数码管导通显示。通过以上设计已经将各部分电路与单片机有机的结合到一起,硬件部分的设计以大功告成,剩下的部分就是对单片机
36、的编程,使单片机按程序运行,实现数字电子秒表的全部功能。2 软件设计2.1 程序设计思想本设计采用了汇编语言编写,汇编语言由于采用了助记符号来编写程序,比用机器语言的二进制代码编程要方便些,在一定程度上简化了编程过程。汇编语言的特点是用符号代替了机器指令代码,而且助记符与指令代码一一对应,基本保留了机器语言的灵活性。使用汇编语言能面向机器并较好地发挥机器的特性,得到质量较高的程序。汇编语言的特点:(1).面向机器的低级语言,通常是为特定的计算机或系列计算机专门设计的。(2).保持了机器语言的优点,具有直接和简捷的特点。(3).可有效地访问、控制计算机的各种硬件设备,如磁盘、存储器、CPU、I/
37、O 端口等。(4).目标代码简短,占用内存少,执行速度快,是高效的程序设计语言。(5).经常与高级语言配合使用,应用十分广泛。在程序设计过程中,为了有效地完成任务,把所要完成的任务精心的分割成若干个相互独立但相互又仍可有联系的任务模块,这些任务模块使得任务变得相对单纯,对外的数据交换相对简单,容易编写,容易检测,容易阅读和维护。这种程序设计思想称为模块化程序设计思想。模块化结构程序的设计,可以使系统软件便于调试与优化,也使其他人更好地理解和阅读系统的程序设计。程序的主要模块有:主程序、显示程序、定时溢出中断服务程序、外部中断服务程序。2.2 系统资源的分配本设计系统所用到的单片机端口数比较多,
38、所以在这里将对数字电子秒表的硬件资源的大概分配加以说明。片内 RAM 的分配、各功能键的定义以及各端口的分配安排如表 2.1 所示。表 2.1 端口的分配安排表名称功能描述初始化值79H-7DH1ms-10s 位显示寄存区00H69H-6DH1ms-10s 位中间寄存区00H59H-5DH1ms-10s 位最终寄存区00HR1- R51ms-10s 位溢出计数区定时器 T0控制秒表的最小精度E018H外部中断 INT0停止中断信号入口外部中断 INT1开始中断信号入口2.3 主程序设计本系统程序主要模块由主程序、定时中断服务程序、外部中断 0 服务程序和外部中断 1 服务程序组成。其中主程序是
39、整个程序的主体。可以对各个中断程序进行调用。协调各个子程序之间的联系。系统(上电)复位后,进入主程序,主程序流程图如图 2.1。首先对系统进行初始化,包括设置各入口地址、中断的开启、对各个数据缓存区清“0” 、赋定时器初值,初始化完毕后,就进入数码管显示程序。数码管显示程序对显示缓存区内的数值进行调用并在数码管上进行动态显示。显示一次就对 P1.1 和 P2.5 进行一次扫描,查询复位键 P1.1 是否按下,当复位键按下后,程序返回开始,重新对系统进行初始化。当没有按下复位键时,程序则扫描 P2.5 是否按下,当 P2.5 没有按下则返回显示程,不断地调用显示缓存区的数据进行显示。使用户能清楚
40、的看到当前电子秒表所记录的时间。当查询到 P2.5 按下后则跳转到另外一段显示程序并调用最红缓存区的数据进行显示,此时显示的时间即为上一次计时的时间。与此同时,在 P2.5 按下后单片机执行显示程序的同时也在对 P2.5 进行扫描,当 P2.5 断开后立即跳转回之前的显示程序显示当前的计时时间。在主程序中还进行了赋寄存区的初始值、设置定时器初值以及开启外部中断等操作,当定时时间到后就转去执行定时中断程序。当外部中断有请求则去执行外部中断服务程序。并在执行完后返回主程序。开始赋初始值数码管显示复位键P1.1是否按下是查看键P2.5是否按下否否查看键P2.5是否抬起是调用最终缓存区数据进行显示否是
41、图 2.1 主程序流程图2.4 中断程序设计现在方案中采用了三个中断,外部中断 INT0,INT1 和定时中断 T0。CPU 在响应中断时,先处理高级中断,在处理低级中断,若有多个同级中断时,则按自然优先顺序处理。例如当 CPU 正在处理一个中断申请时,有出现了另一个优先级比它高的中断请求,这是,CPU 就暂停终止对当前优先级较低的中断源的服务,转去响应优先级比它高的中断请求,并为其服务。待服务结束,再继续执行原来较低级的中断服务程序。而当 CPU 为级别高的终端服务程序服务时,如果级别低的中断发出中断请求,此时 CPU是不会响应的,所以为了避免开始和暂停两个按键中的一个出现没有响应的情况,在
42、进行程序编辑时要注意对中断的使用,避免出现中断的嵌套。 ,合理分配中断对本设计的实现是至关重要的。另外由于数字式电子秒表的最小精度位 1ms,属于高精度电子秒表。定时器 T0 的定时周期也为 1ms,为了使电子秒表暂停键按下后 CPU 能马上去响应中断程序,必须将暂停的外部中断级别高于定时计数器的中断级别。避免出现 CPU 执行完定时溢出中断程序后再响应外部中断程序,影响计时精度。8051 的自然优先级顺序排列如下:中断源 最高外部中断 0定时/计数器 0 溢出中断外部中断 1定时/计数器 1 溢出中断串行口中断 最低数字式秒表中的两个按键采用了中断实现功能。开始采用外部中断 INT0,暂停采
43、用外部中断 INT1。另外程序中还用到了定时/计数器 0 溢出中断进行计时。依据设计要求,暂停的外部中断 INT1 中断级别最高,计时的定时/计数器 0 溢出中断次之,开始的外部中断 INT0 级别最低。(1)外部中断 0 服务程序:外部中断 0 服务程序结合外部 P3.2 停止键实现数字电子秒表的停止功能,具体流程图如图 2.2。当按下 P3.2 停止键按下向 CPU 发出外部中断请求,CPU 转向外部中断 0 服务程序执行,停止定时器。另外将当前显示的时间进行一次存储,存进中间寄存区。最后中断返回。外部中断0入口停止定时器T0一次存储中断返回图 2.2 外部中断 0 服务程序流程图(2)外
44、部中断 1 服务程序外部中断 1 服务程序结合外部 P3.3 停止键实现数字电子秒表的启动功能,具体流程图如图 2.2。当按下 P3.3 启动键按下向 CPU 发出外部中断请求,CPU 转向外部中断 1 服务程序执行,启动定时器。另外进行二次存储,将之前进行一次存储的数码管显示数据存入最终缓存区,避免下次计时暂停时一次存储将数据掩盖,从而起到保护数据的作用。二次存储后就中断返回。外部中断1入口启动定时器T0二次存储中断返回图 2.3 外部中断 1 服务程序流程图(3)定时中断服务程序当定时/计数器 T0 器溢出后,向 CPU 发出中断请求信号。CPU 跳转到定时中断程序执行,具体流程如图 2.
45、4。定时中断程序是一个进位程序,主要负责对 1ms 的加一。1ms 位没有满十就跳出中断程序,返回显示程序。当 1ms 位满十后就对 1ms 位清零,向 10ms 位加一,同时检测 10ms 位是否满十,没有满十就跳出中断程序,返回显示程序。如果满十就向 100ms 位加一,依次类推,最终达到 99.99 秒后归零,从零开始再次计时。定时/计数器 T0 工作在方式 0 下,TH0 和 TL0 组成一个 13 位的二进制数计数器。单片机开机或复位时,它的值为 00H,当 T0 启动后,从第一个输入脉冲开始计时,每来一个脉冲计数加一,即从 0 开始计数到 1,再计数一个脉冲时 TH0 和 TL0
46、组成的 13位计数器将会从 13 个 1 变成 13 个 0,并产生溢出,溢出位将被送到 TF0 标志位,通过溢出标志产生溢出中断请求。显然,T0 定时器在方式 0 下引起一次中断所允许计数的最多脉冲个数为 213 个。但如果定时计数器如果每次都固定从 0 开始计数,到计满后,再向 CPU 发出溢出中断请求信号那是毫无意义的。为了使定时计数器在规定的计数脉冲个数字之后(此时应小于 213 个脉冲),向 CPU 发出溢出中断请求,可采取预先向 TH0 和 TL0 中放入一个初值 X 的方法,使计数器以 X 值为起始值开始计数,即 X+1,X+2,直至计数器计满,从 1 全变为 0。设需要计数的脉
47、冲个数为 Y,则有:X+Y=213 在定时方式下:定时时间间隔位 t=(213X)*振荡周期*12现在本设计要求 1ms 实现一次中断,选择定时器 T0 工作在方式 0。所以需要根据以上条件计算出 T0 的初值。设 T0 的初值为 X,则 (213X)*12/12*106 =1*10-3 转换位十六进制数 X=7192=0B即 TH0=0E0H(取 X 的高 8 位)TL0=18H(取 X 的低 5 位)由于定时 1ms 只是一个理想化的时间,其中并没有考虑到中断后单片机执行语句所花的时间。虽然执行语句所花的时间很短只有即微秒,但积少成多,数字秒表一秒中要溢出中断 1000 次,积累起来误差就
48、能达到毫秒级,这对于精度到达毫秒级的数字电子秒表来说是很大的误差。所以要在后期编程时还要将单片机读程序的时间考虑进去,在对定时器赋初值时将单片机需要执行的语句所花的时间加上,这样就能使数字电子秒表的误差达到最小。定时中断服务程序入口1ms位加一判断1ms位是否满101ms位清零,10ms位加一判断10ms位是否满1010ms位清零,100ms位加一判断100ms位是否满10100ms位清零,1s位加一判断1s位是否满101s位清零,10s位加一判断10s位是否满1010s位清零中断返回是是是是是否否否否图 2.4 定时中断服务程序3 数字电子秒表的安装与调试3.1 软件的仿真与调试Proteu
49、s ISIS 是英国 Labcenter 公司开发的电路分析与实物仿真软件,它可以仿真、分析(SPICE)各种模拟器件和集成电路。该软件的主要特点总结后有以下四点:实现了单片机仿真和 SPICE 电路仿真相结合的功能。支持目前主流单片机系统的仿真。提供了软件调试功能,并可以与 WAVE 联合仿真调试。具有强大的原理图绘制功能。总之,该软件是一款集单片机和 SPICE 分析于一身的仿真软件,功能极其强大。在电子领域中也起到了很大的作用,它的出现仿真不需要先焊接电路,可以先仿真调试通过后在焊电路,节省了不少在硬件调试上所花的时间。Proteus ISIS 的工作界面是一种标准的 Windows 界
50、面。它包括标题栏、主菜单、状态栏、标准工具栏、绘图工具栏、对象选择按钮、预览对象方位控制按钮、仿真进程控制按钮、预览窗口、对象选择器窗口、图形编辑窗口等十几个工具,方便了使用者的使用。首先打开已经画好的 proteus DSN 文件,双击图中的 AT89S52 芯片,就弹出一个窗口,在 Program File 项中通过路径选择在 WAVE 中生成的 HEX 文件,双击选中后确定,这样仿真图中的 AT89S52 芯片就已经读取了本设计中的 HEX 文件。单击“三角形按钮”进行仿真。通过对仿真结果的观察来对程序进行修改,最终使程序到达设计要求。3.2 硬件的安装与调试按照之前设计好的数字电子秒表
51、原理图,详细计算系统中各个元件的参数,选择相应器件,制作实际电路板。由于考虑到万能板大小的问题及元件之间连线的方便,在焊接元器件前必须考虑元件的布局然后进行实际操作。制作好的电路板可以用万用表(200 欧姆档)的红、黑表笔测试电路板的每条走线,当其电阻非常小时,证明走线没有断开,当其电阻很大时,证明该条走线断了,应该重新走线,使电路板在电气上得到正确地连接。选用万用表的 20K 欧姆档,检测电路中是否存在短路。因为系统采用的是共阴极数码管作为显示电路,必须确保数码管的公共端接的是低电平。(1)晶振电路的测试在单片机正常运行的必要条件是单片机系统的时钟稳定正常。实际中,因为各种原因导致系统时钟不
52、正常而出现系统无法正常运行的情况时有,因此系统时钟是否振是通电检查的首要环节。在系统通电的状况下,用万用表的直流电压档(20V) ,分别测量 XTAL1 和 XTAL2 引脚的电压,看是否正常,在调试过程中,测得电压 XTAL1 引脚应为 2.05V,XTAT2 应为 2.15V。(2)复位电路的测试复位不正常也会导致系统不能工作。如果复位引脚始终为高电平,系统将始终处于复位状态;如果始终为低电平,不能产生复位所需的高电平信号脉冲,则系统也可能无法正常工作。单片机正常工作时,RST 复位引脚应为 0V,按下复位按键时,复位引脚为高电平 5V 左右。(3)显示电路的测试显示电路是数字电子秒表正常
53、运行最直观的观察窗口,我们可以通过观察显示电路的显示结果观察系统能否正常运行。当显示电路按照电路图焊接好后,用万用表的测二极管档位,将黑表笔接共阴数码管的公共段,然后将红表笔接数码管的各段,当数码管的段能正常显示,说明各点焊接正常。 3.3 系统程序的烧录在软件调试中,使用当今流行的功能强大且普遍的 WAVE 6000 软件进行软件编译与调试,使用 Microcontroller ISP Software 及其配套的单片机对程序进行烧录。 图 3.1 Debice selection 图 3.2 Atmel microcontroller软件的烧录:第一步:安装并运行 Microcontrol
54、ler ISP Software 软件;第二步:点击 Options 栏的 select device 选项;这时出现一个对话窗口,如图 3.1 所示,按图选择后,点击 OK 按键,如出现图 3.2 所示窗口,则说明电脑与开发板没连接好或单片机没插好等,需重装检查硬件连接,如果没有出现则说明初始化成功。第三步:点击 File 栏的 Load Buffer 选项打开已经编译好的 HEX 文件。点击载入,出现如图 3.4.a 对话框点确定后,再点击图 3.3 中的“A”字图标,出现如图 3.4.b 对话框,完成后,按软件默认选项,点击“OK”“OK”“OK”烧录完成;否则重新检查硬件连接后再重新烧
55、录。 图 3.4.a Atmel 图 3.4.b auto programming3.4 数字电子秒表的精度调试将数字电子秒表的程序编译后烧录进单片机,并将单片机插入系统并保证其能正常运行。在进行精度测试之前的编程过程中,我们知道了单片机在进行定时中断时需要执行语句,而执行这些语句是需要占用 CPU 时间的,从而影响单片机定时的精确性,最终会导致数字电子秒表的计时误差,为了减小这种计时误差,我们之前在编程时已经将单片机一秒钟内执行程序的时间计算在内,并将定时器的初值做出了适当调整。争取最大限度的减小数字电子秒表的计时误差。在进行秒表精度调试时,我们让本设计的单片机秒表和电子表同时计时,为了能尽
56、可能的观察出是否有误差,我们将计时时间定为 10 分钟,当计时时间到后观察两个计时秒表是否同时到达。如果不是同时到达就说明有一定的误差,需要在程序中对定时器进行微调。如果两表是同时到达则说明秒表的设计满足要求。结 论本设计的数字电子秒表是由 8051 单片机、共阴数码显示管、控制按键、三极管等器件构成的,设有六位计时显示,开始、暂停、复位按键以及一个系统整机复位按钮。计时精度能到达 10ms,设计精简,使用简单易懂。系统设计合理,线路简单、功能先进,性能稳定,程序精简。并给出了详细的电路设计方法。本系统是以单片机为核心,仅单片机方面知识是不够的,还应根据具体硬件结构,以及针对具体应用对象特点的
57、软件结合,以作完善。所以采用汇编语言来进行软件设计,利用汇编语言面向机器并能较好的发挥机器的特性,得到较高的程序,同时汇编语言目标代码简短,占用内存少,执行速度快,能提高秒表的精度。通过本次设计,复习巩固我们以前所学习的数字、模拟电子技术、单片机原理及应用等课程知识,加深对各门课程及相互关系的理解,并成功使用了 Wave、Protel 99se 和 Proteus 三款电子软件,使理论知识系统化、实用化,系统地掌握微机应用系统的一般设计方法,培养较强的编程能力、开发能力。同时,在设计的过程中,我也发现了本系统的许多不足和可以改进的地方。但因时间紧迫等原因没能改进。本设计的数字电子秒表缺少对多次
58、计时时间进行记录的功能。应给在单片机的内部存储区多设置一些存储空间,用来存储多次计时时间。并在程序中编入对多次计时时间的调用显示。虽然存在不足,但本设计的数字电子秒表仍具有它的实用性。心得体会心得体会 做了两周的课程设计,让人感受颇深,有关于单片机知识的,但更多是团队和合作。我们小组一共 4 个人,人多,分工就显得很重要,在我们的集体的讨论之下,我得到了设计硬件电路和总体调试的任务,当时让我感到很有压力。因为我们平时接触的都是纯粹理论的东西,做实验也是雾里看花,对硬件的认识是很缺乏的。通过 10 多天的努力,我们小组终于完成了单片机的课程设计。我觉得作为一名自动化专业的学生,单片机的课程设计是
59、很有意义的。更重要的是如何把自己平时所学的东西应用到实际中。虽然自己对于这门课懂的并不多,很多基础的东西都还没有很好的掌握,觉得很难,也没有很有效的办法通过自身去理解,但是靠着这一个多礼拜的“学习”,在小组同学的帮助和讲解下,渐渐对这门课逐渐产生了些许的兴趣,自己开始主动学习并逐步从基础慢慢开始弄懂它。我认为这个收获应该说是相当大的。一开始我们从参考书上找来了课题,但是毕竟是参考书,做到后来发现很多程序都是不完整的,这让我们伤透了脑筋。看着别的小组都弄得有模有样了,可是我们连一个课题都还没有定好。好不容易又找到了课题,可是结果还是很不尽人意。程序接线什么的都弄好了,调试也没有问题,可是就是无法
60、达到预期想要的结果。眼看 2 个礼拜就快结束了,别的小组都准备要答辩了。无奈下我们不得不第三次改了课题。参考书毕竟只是一个参考,设计这种东西最后还是要靠自己动脑筋。然后我们大家一起齐心协力,从平时做的实验老师上课的举例书本上的知识以及老师的辅导和其他同学的帮助下终于完成了。应该说这是通过我们小组成员的共同努力和动脑完成的,虽然内容并不是很复杂,但是我们觉得设计的过程相当重要,学到了很多,收获了很多。我觉得课程设计反映的是一个从理论到实际应用的过程,但是更远一点可以联系到以后毕业之后从学校转到踏上社会的一个过程。小组人员的配合相处,以及自身的动脑和努力,都是以后工作中需要的。所以我认为这次的课程
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 健康管理师考试学习策略试题及答案
- 2024春八年级语文下册 第3单元 10小石潭记教学设计 新人教版
- 中小学教育与社会发展的关系探讨及试题及答案
- 健康管理师考试中常见疾病的预防与管理试题及答案
- 信息系统项目管理师考试策略优化试题及答案
- 江西省万载县高中生物 第五章 基因突变及其他变异 5.3 人类遗传病教学设计 新人教版必修2
- 2025年中小学教师资格笔试考试前的准备流程分析试题及答案
- 健康管理师考试提高自我要求试题及答案
- 乡村全科执业医师考试思路全面试题及答案
- 2025年税务师考试有效学习方法的探讨试题及答案
- 新教材 人教B版高中数学必修第四册 第十一章 立体几何初步 精品教学案(知识点考点汇总)
- 10t单梁起重机安装方案
- 钢轨探伤技术及规则PPT课件
- 市政工程给排水全套资料表格模版(113页)
- 船舶管子制作培训教材ppt课件
- 波峰焊工程师面试试题集
- 普通车床主轴变速箱设计及主轴箱设计说明书
- 招标代理工作服务流程图
- 经典老歌简谱100首
- 水管管径流速流量对照表
- 三一重装EBZ260A掘进机各配件价格表
评论
0/150
提交评论