青岛理工大学
毕业论文
题目:
抢答器设计
学生姓名:**
学生学号:********
院系名称:机电工程系
专业班级:***************
指导教师:*****
2016年6月15日
青岛理工大学毕业论文
摘要
随着科学技术的发展和普及,各种各样的竞赛越来越多,其中抢答器的作用也越来越
重要。本文设计出以AT89S51单片机为核心的八路抢答器,采用了数字显示器直接指示,
自动锁存显示结果,并自动复位的设计思想,它能根据不同的抢答输入信号,经过单片机
的控制处理并产生不同的与输入信号相对应的输出信号,最后通过LED数码管显示相应的
路数,即使两组的抢答时间相差几微秒,也可分辨出是哪组优先按下的按键,充分利用了
单片机系统结构简单、功能强大、可靠性好、实用性强的特点。
本设计是以抢答为出发点。考虑到依需设定限时回答的功能,利用89S51单片机及外
围接口实现的抢答系统,利用单片机的定时器/计数器定时和记数的原理,将软、硬件有
机地结合起来,使得系统能够正确地进行计时,同时使数码管能够正确地显示时间。用开
关做键盘输出,扬声器发生提示。同时系统能够实现:在抢答中,只有开始后抢答才有效,
如果在开始抢答前抢答为无效;满时后系统计时自动复位及主控强制复位;按键锁定,在
有效状态下,按键无效非法。
关键词:抢答器,单片机,LED数码显示管,定时器/计数器,扬声器
I
青岛理工大学毕业论文
ABSTRACT
Withthedevelopmentofscienceandtechnologyandthepopularizationofallkindsof
competitionmoreandmore,esignoutto
AT89S51singletabletsmachineforcoreofeightanswerdevice,udhasdigitaldisplaydirectly
indicates,automaticallylocksavedisplayedresults,andautomaticallyretofdesignthought,it
canaccordingtodifferentofanswerenteredsignal,aftersingletabletsmachineofcontrol
processingandproduceddifferentofandenteredsignalrelativeshouldofoutputsignal,last
throughLEDdigitaltubedisplayedcorrespondingofnumber,eventwogroupofanswertime
differenceveralmicroconds,alsocantelloutiswhichgroupprioritybyXiaofpress,full
usinghassingletabletsmachinesystemstructuresimple,Powerful,reliableandpractical
intoaccountthefunctionsaccording
tothettimelimittoanswer,using89S51microcontrollerandperipheralinterface
implementationsoftheVIESsystem,usingtheprinciplesoftimingandcountingtimer/counter,
combiningsoftwareandhardware,andallowsthesystemtocorrecttiming,whileallowing
esthekeyboardoutput,hesystem
canachieve:answer,onlyafterthestartofcontestisonlyvalid,ifVIEStoanswerbeforeyou
begintobeinvalid;fullsystemsaftertimeautomaticretandmasterforcereduction;keylockintheeffectiveState,keyisinvalidillegal.
KeyWords:responder,singlechipmicrocomputer,LEDdigitaldisplay,timer/counterspeakers
II
青岛理工大学毕业论文
目录
摘要.......................................................................I
第1章绪论.................................................................1
1.1课题研究的背景及意义.................................................1
1.2可编程控制器概论.....................................................1
1.3课题研究内容.........................................................1
第2章抢答器的概述.........................................................3
2.1系统设计的功能......................................................3
2.1.1基本功能.......................................................3
2.1.2扩展功能.......................................................3
2.2抢答器的需求分析....................................................3
第3章硬件电路的设计.......................................................4
3.1总电路原理..........................................................4
3.2时钟频率电路的设计..................................................5
3.3复位电路的设计......................................................6
3.3.1复位电路的可靠性和田白玉 设计...........................................6
3.3.2人工复位.......................................................7
3.4显示电路的设计......................................................8
3.4.1显示模块在系统硬件中的安排.....................................8
3.5扫描电路的实现......................................................9
3.5.1按钮输入的硬件处理............................................10
3.6发声...............................................................10
3.7系统复位...........................................................10
第4章软件设计............................................鱼类简笔画 ................12
4.1主程序设计.........................................................12
4.2倒计时30s子程序设计...............................................13
4.3外部中断T1中断子程序设计..........................................14
4.4定时器T1中断子程序设计............................................15
I
青岛理工大学毕业论文
4.5选手按键程序设计...................................................15
4.6数码管显示程序设计.................................................16
第5章软硬件综合调试......................................................18
5.1软件仿真...........................................................18
5.1.1KeiluVsion2软件仿真.........................................18
5.1.2Protues7professional软件仿真...............................19
5.2软件仿真过程说明...................................................20
5.3心得体会与结果.....................................................20
第6章结论...............................................................22
致谢......................................................................23
参考文献.........................丁义珍原型 ..........................................24
II
青岛理工大学毕业论文
第1章绪论
1.1课题研究的背景及意义
抢答器已经越来越多的出现在我们的学习生活和电视节目中,例如在学校里经常会举
办各种各样的智力竞赛,就会用到抢答器,抢答器是能够在任何比赛及竞争性的游戏中体
现公平、公正的电子装备,在各项中不仅可以准确、公正和直接地判断出第一个抢答者是
谁,还有助于锻炼参赛者的掌握知识的能力、思维反应能力、语言表达能力、心理承受能
力。但如果在比赛中,做不到严格意义的公正,会挫伤选手的积极性,达不到比赛的真正
目的。
随着电子技术的迅速发展,通过人为判断抢答器顺序这种古老的方法早已被现在先进
的电子产品所取代。现在的电子抢答器虽然制作方法不同,但基本设计实现的功能都大同
小异,无外乎需要设计一个竞赛抢答器,要求具有任意路抢答输入,能够识别最先抢答的
信号,显示该分台号;对回答问题所用的时间进行计时、显示、超时报警;可以预置回答
问题的时间;同时具有复位功能,倒计时启动功能等等的主要实现功能。
1.2可编程控制器概论
可编程控制器(PLC)是一种新型的通用自动化控制装置,它将传统的继电器控制技
术、计算机技术和通讯技术融为一体,具有控制功能强,可靠性高,使用灵活方便,易于
扩展等优点而应用越来越广泛。可编程控制器(ProgrammableLogicController)即PLC。
现已广泛应用于工业控制的各个领域。他以微处理为核心,用编写的程序不仅可以进行逻
辑控制,还可以定时,计数和算术运算等,并通过数字量和模拟量的输入/输出来控制机
械设备或生产过程。美国电气制造商协会经过4年调查,于1980年将其正式命名为可编
程控制器(ProgrammableLogicController),简写为PC。后来由于PC这个名称常常被用
来称呼个人电脑(PersonalComputer),为了区别,现在也把可编程控制器称为PLC。
1.3课题研究内容
系统设计主要包括硬件和软件两大部分,依据控制系统的工作原理和技术性能,将硬件和软件分开设计。硬件设计部分包括电路原理图、合理选择元器件、绘制线路图,然后
1
青岛理工大学毕业论文
对硬件进行调试、测试,以达到设计要求。软件设计部分,首先在总体设计中完成系统总
框图和各模块的功能设计,拟定详细的工作计划;然后进行具体设计,包括各模块的流程
图,选择合适的编程语言和工具,进行代码设计等;最后是对软件进行调试,测试,达到
所需功能要求。
在系统设计中设计方法的选用是系统设计能否成功的关键。硬件电路是采用结构化系
统设计方法,该方法保证设计电路的标准化、模块化。硬件电路的设计最重要的选择可编
程的PLC,并确定与之配套的外围芯片,使所设计的系统既经济又高性能。硬件电路设计
还包括输入输出接口设计,画出详细电路图,标出芯片的型号、器件参数值,根据电路图
在仿真机上进行调试,发现设计不当及时修改,最终达到设计目的。
2
青岛理工大学毕业论文
第2章抢答器的概述
2.1系统设计的功能
2.1.1基本功能
(1)同时供8名选手比赛,分别用8个按钮S0~S7表示。
(2)设置一个系统清除和抢答控制开关S,该开关由主持人控制。
(3)抢答器具有锁存与显示功能。即选手按动按钮,锁存相应的编号,扬声器发出
声响提示,并在七段数码管上显示选手号码。选手抢答实行优先锁存,优先抢答选手的编
号一直保持到主持人将系统清除为止。
2.1.2扩展功能
(1)抢答器具有定时抢答功能,且一次抢答的时间由主持人设定(如30秒)。当主
持人启动“开始”键后,定时器进行减计时。
(2)参赛选手在设定的时间内进行抢答,抢答有效,定时器停止工作,显示器上显
示选手的编号和抢答的时间,并保持到主持人将系统清除为止。
(3)如果定时时间已到,无人抢答,本次抢答无效,系统报警并禁止抢答,定时显
示器上显示00。
2.2抢答器的需求分析
1、在抢答中,只有开始后抢答才有效,如果在开始抢答前抢答为无效。
2、抢答限定时间和回答问题的时间可在1~99s设定。
3、可以显示是哪位选手有效抢答和无效抢答,正确按键后有音乐提示。
4、抢答时间和回答问题时间倒记时显示,时间完后系统自动复位。
5、按键锁定,在有效状态下,按键无效非法。
3
青岛理工大学毕业论文
第3章硬件电路的设计
本系统采用AT89S51单片机作为核心,控制系统的四个模块分别为:单片机最小系统、
显示模块、显示驱动模块、抢答开关模块。抢答器原理框图如图3.1所示。
时
钟
电
路
复
位
电路
图
驱动
单
片机
键盘
限
流
显示
图3.什么时候吃元宵 1抢答器原理框图
总体设计之后,然后进行单元电路设计。单元电路设计分为电源电路设计、时钟和复
位电路、键盘电路、显示报警电路等。
3.1总电路原理
为使硬件电路设计尽可能合理,应注意以下几方面:
(1)尽可能采用功能强的芯片,以简化电路,功能强的芯片可以代替若干普通芯片,
随着生产工艺的提高,新型芯片的的价格不断下降,并不一定比若干普通芯片价格的总和
高。
(2)留有设计余地。在设计硬件电路时,要考虑到将来修改扩展的方便。因为很少有
一锤定音的电路设计,如果现在不留余地,将来可能要为一点小小的修改或扩展而被迫进
行全面返工。
(3)程序空间,选用片内程序空间足够大的单片机,本设计采用AT89S51单片机。
(4)RAM空间,AT89S51内部RAM不多,当要增强软件数据处理功能时,往往觉得
不足。如果系统配置了外部RAM,则建议多留一些空间。如选用8155作I/O接口,就可
以增强256字节RAM.如果有大批数据需要处理,则应配置足够的RAM,如6264,62256
等。随着软件设计水平的提高,往往只要改变或增加软件中的数据处理算法,就可以使系统功能提高很多,而系统的硬件不必做任何更换就使系统升级换代。只要在硬件电路设计
4
青岛理工大学毕业论文
初期考虑到这一点,就应该为系统将来升级留足够的RAM空间,哪怕多设计一个RAM
的插座,暂不插芯片也好。
(5)I/O端口:在样机研制出来后进行现场试用时,往往会发现一些被忽视的问题,
而这些问题不是靠单纯的软件措施来解决的。如有些新的信号需要采集,就必须增加输入
检测端;有些物理量需要控制,就必须增加输出端。如果在硬件电路设计就预留出一些I/O
端口,虽然当时空着没用,那么用的时候就派上用场了。
3.2时钟频率电路的设计
时钟电路是计算机的心脏,它控制着计算机的工作节奏。MCS-51单片机允许的时钟
频率是因型号而异的。
晶振的选择:
6MHz的晶振,其机器周期是2us。
12MHz的晶振,其机器周期是1us,也就是说在执行同一条指令时用6MHz的晶振所
用的时间是12MHz晶振的两倍。为了提高整个系统的性能我选择了12MHz的晶振。
振荡方式的选择:
内部振荡方式,MCS-51内部都有一个反相放大器,XTAL1、XTAL2分别为反相放大
器输入和输出端,外接定时反馈元件以后就组成振荡器,产生时钟送至单片机内部的各个
部件。这样就构成了内部振荡方式。
外部振荡方式是把已有的时钟信号引入单片机内。这种方式适合用来使单片机的时钟
与外部信号肉炒 一致。
在我的这个设计中没有也无需与外部时钟信号一致,所以我选择了内部振荡方式,由
于单片机内部有一个高增益反相放大器,当外接晶振后,就构成了自激振荡器并产生振荡
时钟脉冲。晶振我选择了12MHz,相对于6MHz的晶振,整个系统的运行速度更快了。电
容器C1、C2起稳定振荡频率、快速起振的作用,电容值我选择了30pF。内部振荡方式所
得的时钟信号稳定性高。
5
青岛理工大学毕业论文
图3.3时钟电路的设计
单片机必须在时钟的驱动下才能工作。在单片机内部有一个时钟振荡电路,只需要外
接一个振荡源就能产生一定的时钟信号送到单片机内部的各个单元,决定单片机的工作速
度。
一般选用石英晶体振荡器。此电路在加电大约延迟10ms后振荡器起振,在XTAL2引
脚产生幅度为3V左右的正弦波时钟信号,其振荡频率主要由石英晶振的频率确定。电路中
两个电容C1,C2的作用有两个:一是帮助振荡器起振;二是对振荡器的频率进行微调。
C1,C2的典型值为30PF。
单片机在工作时,由内部振荡器产生或由外直接输入的送至内部控制逻辑单元的时钟
信号的周期称为时钟周期。其大小是时钟信号频率的倒数,常用f
osc
表示。如时钟频率为
12MHz,即f
osc
=12MHz,则时钟周期为1/12s。
3.3复位电路的设计
3.3.1复位电路的可靠性设计
计算机在启动运行时都需要复位,使中央处理器CPU和系统中的其它部件都处于一个
确定的初始状态,并从这个状态开始工作。MCS-51的复位输入引脚RST为MCS-51提供
了初始化的手段,可以使程序从指定处开始执行,在MCS-51的时钟电路工作后,只要RST
引脚上出现超过两个机器周期以上的高电平时,即可产生复位的操作。只要RST保持高
电平,则MCS-51循环复位。只有当RST由高电平变低电平以后,MCS-51才从0000H地
址开始执行程序。本系统采用按键复位方式的复位电路。
MCS-51单片机有一个复位引脚RST,它是施密特触发输入,当振荡器起振后,该引
脚上出现2个机器周期(即24个时钟周期)以上的高电平。使器件复位,只要RST保持
6
青岛理工大学毕业论文
高电平,MCS-51保持复位状态。此时ALE、/PSEN、P0、P1、P2、P3口都输出高电平。
RST变为低电平后,退出复位,CPU从初始状态开始工作。复位以后内部寄存器的初始状
态为(SP=07,P0、P1、P2、P3为0FFH外,其它寄存器都为0。在RST复位端接一个电
容至VccHE一个电阻至Vss,就能实现上电自动复位,对于CMOS单片机只要接一个电
容至Vcc即可。如图,在加电瞬间,电容通过电阻充电,就在RST端出现一定时间的高电
平,只要高电平时间足够长,就可以使MCS-51有效地复位。RST端在加电时应保持的高
电平时间包括Vcc的上升时间和振荡器起振时间,Vcc上升时间若为10ms,振荡器起振时
间和频率有关。10MHz时间约为1ms,1MHz时约为10ms,所以一般为了可靠地复位,
RST在上电时应保持20ms以上的高电平。RC时间常数越大,上电时RST端保持高电平
的时间越长。当振荡频率为12MHZ时,典型值为C=10uF,R=8.2k.
图3.4上电复位电路
3.3.2人工复位
除上电自动复位以外,常常需要人工复位,将一个按钮开关并联于上电自动复位电路,
按一下开关就RST端出现一段时间的高电平,即使器件复位。如图所示。
图3.5上电和开关复位
7
青岛理工大学毕业论文
而我们在这次的毕业设计中运用的人工复位电路.其中电平复位是通过RST端经电
阻和电源Vcc接通而实现的,按键手动电平复位电路如图。当时钟频率选用12MHz时,C
选取10uF,R选择1000欧。
3.4显示电路的设计
显示功能与硬件关系极大,当硬件固定后,如何在不引起操作者误解的前提下提供尽
可能丰富的信息,全靠软件来解决。
3.4.1显示模块在系统硬件中的安排
操作者主要设计从显示设备上获取微机系统的信息的,因此,操作者每操作一下,显
示设备商都应该有一定的反应。这说明,显示模块与操作有关,即监控程序是需要调用显
示模块。不同的操作需要显示不同的内容,这又说明各执行模块对显示模块的驱动方式是
不同的。另一方面,在操作者没有进行操作时,显示内容也是变化的,如显示现场各物理
量的变化情况。这时显示模块不是由操作者通过命令键来驱动,而是由各类自动执行的功
能模块来驱动。自动执行的各类模块在安排在各种中断子程序中,这就是说,各种中断子
程序也要调用显示模块。如果监控安排在中断子程序中,两者的要求就统一了,问题比较
好解决,如果监控程序安排在主程序中,在监控程序调用显示模块的过程中发生了中断,
中断子程序也调用显示模块,这时就容易出问题。一种比较妥善的办法是只让一处调用显
示模块,其他各处均不得直接调用显示模块,但有权申请显示。这就要设置一个显示申请
标志,当某模块需要显示时,将申请标志置位,同时设定有关显示内容(或指针)。由于
一处调用显示模块,故不会发生冲突。为了使显示模块能及时反应系统需要,应将显示模
块安排在一个重复执行的循环(如监控循环或时钟中断子程序)中。当监控程序(键盘解
释程序)安排在时钟中断子程序中时,处理比较方便,只要在监控程序的汇合处调用显示
模块就可以了。
这里将显示功能集中到一起,作为一个功能模块,就要求它的功能全面,能根据系统
软件提供的信息自动完成显示内容的查找,变换和输出驱动。这样设计使得各功能模块都
不必考虑显示问题,只要给出一个简单的信息(如显示格式编码)甚至不用再提供额外信
息,直接利用当前状态变量和软件标志就可以完成所需的显示要求。
如果编写这样一个集中显示模块有困难,也可以将显示模块编小一些,只完成显示缓
8
青岛理工大学毕业论文
冲区的内容输出到显示器件上的工作。这时各功能模块在提出显示申请时,还需要将显示
内容按需要的格式送入显示缓冲区中。这样分而治之比较容易编程,但要小心出现显示混
乱。例如后台程序需要调用显示,将有关信息送入到现实缓冲区进行显示;中断返回后,
后台程序继续送完后半部分显示内容,但前半部分内容已经变了,这样就出现了显示错误。
解决的办法是,在申请显示前,先检查是否已经有显示申请,如果有,就不再申请,等待
下次机会;如果没有,则先申请标志位,再将显示内容送入显示缓冲区。这时就不必担心
其他前台模块来打扰了,就可以得到一次完整的显示机会。
在这里我们使用的是七段数码管显示,通常最大的房车 在显示上我们采用的方法一般包括两种:
一种是静态显示,一种是动态显示。其中静态显示的特点是显示稳定不闪烁,程序编写简
单,但占用端口资源多;动态显示的特点是显示稳定性没静态好,程序编写复杂,但是相
对静态显示而言占用端口资源少。在本设计中根据实际情况采用的是动态显示方法。
并通过查表法,将其在数码管上显示出来,其中P0口为字型码输入端,P2口低3位
为字选段输入端。在这里我们通过查表将字型码送给7段数码管显示的数字,数码管显示
原理如下:
MOVA,R5
MOVCA,@A+DPTR;查字型
MOVP2,#01H;送位选码
MOVP0,A;送字型码
ACALLDELAY;调延时,去闪烁
在七段数码管显示中可分为共阳极和共阴极两种类型极。以共阴为例,要想a段亮,
向a段送1就是,返之送0,共阳刚好相反。
3.5扫描电路的实现
键盘是人与微机系统打交道的主要设备。关于键盘硬件电路的设计方法也可以在文献
和书籍中找到,配合各种不同的硬件电路,这些书籍中一般也提供了相应的键盘扫描程序。
站在系统监控软件设计的立场上来看,仅仅完成键盘扫描,读取当前时刻的键盘状态是不
够的,还有不少问题需要妥善解决,否则,人们在操作键盘就容易引起误操作和操作失控
现象。在单片机应用中键盘用得最多的形式是独立键盘及矩阵键盘。
它们各有自己的特点,其中独立键盘硬件电路简单,而且在程序设计上也不复杂,一般用在对硬件电路要求不高的简单电路中;矩阵键盘与独立键盘有很大区别,首先在硬件
9
青岛理工大学毕业论文
电路上它要比独立键盘复杂得多,而且在程序算法上比它要烦琐,但它在节省端口资源上
有优势得多,因此它更适合于多按键电路。其次就是消除在按键过程中产生的“毛刺”现
象。这里采用最常用的方法,即延时重复扫描法,延时法的原理为:因为“毛刺”脉冲一
般持续时间短,约为几ms,而我们按键的时间一般远远大于这个时间,所以当单片机检测
到有按键动静后再延时一段时间(这里我们取10ms)后再判断此电平是否保持原状态,如果
是则为有效按键,否则无效。
3.5.1按钮输入的硬件处理
按钮的触点在闭合和断开时均会产生抖动,这是触点的逻辑电平是不稳定的,如不妥
善处理,将会引起按键命令的错误执行或重复执行。现在一般均用软件延时的方法来避开
抖动阶段,这一延时过程一般大于5ms,例如取10-20ms。如果监控程序中的读键操作安
排在主程序(后台程序)或键盘中断(外部中断)子程序中,则该延时子程序便可直接插
入读键过程中。如果读键过程安排在定时中断子程序中,就可省去专门的延时子程序,利用两次定时中断的时间间隔来完成抖动处理。
3.6发声
我们知道,声音的频谱范围约在几十到几千赫兹,若能利用程序来控制单片机某个口
线的“高”电平或“低”电平,则在该口线上就能产生一定频率的矩形波,接上喇叭就能
发出一定频率的声音,若再利用延时程序控制“高”“低”电平的持续时间,就能改变输
出频率,从而改变音调,使喇叭发出不同的声音。
3.7系统复位
使CPU进入初始状态,从0000H地址开始执行程序的过程叫系统复位。从实现系统
复位的方法来看,系统复位可分为硬件复位和软件复位。硬件复位必须通过CPU外部的硬
件电路给CPU的RESET端加上足够时间的高电位才能实现。上电复位,人工按钮复位和
硬件看门狗复位均为硬件复位。硬件复位后,各专用寄存器的状态均被初始化,且对片内
通用寄存器的内容没有影响。但是,硬件复位还能自动清除中断激活标志,使中断系统能
够正常工作,这样一个事实却容易被不少编码人员所忽视。软件复位就是用一系列指令来
模拟硬件复位功能,最后通过转移指令使程序从0000H地址开始执行。对各专用寄存器的
10
青岛理工大学毕业论文
复位操作是容易的,也没有必要完全模拟,可根据实际需要去主程序初始化过程中完成。
而对中断激活标志的清除工作常被遗忘,因为它没有明确的位地址可供编程。有的编程人
员用020000(LJMP0000H)作为软件陷阱,认为直接转向0000H地址就完成了软件复
位,就是这类错误的典型代表。软件复位是使用软件陷阱和软件看门狗后必须进行的工作,
这时程序出错完全有可能发生在中断子程序中,中断激活标志已置位,它将阻止同级中断
响应。由于软件看门是高级中断,它将阻止说要中断响应,由此可见清除中断激活标志的
重要性。
在所有的指令中,只有RETI指令能够清除中断激活标志。前文各处提案到的出错处
理程序ERR主要完成这一功能,其他的善后工作交由复位后的系统去完成。
有复位时系统的历史状况,可将复位分为“冷启动”和“热启动”。“冷启动”时,系
统的状态全部无效,进行彻底的初始化操作;而“热启动”时,对系统的当前状态进行修
复和有选择的初始化。系统初次上电投入运行时,必须是“冷启动”,以后由抗干扰措施
引起的复位操作一般均为“热启动”。为了使系统能正确决定采用何种启动方式,常用上
电标志来区分,如图3.6所示。
冷启自检全
面初始化
图3.6系统复位策略图
复位
关中断,设定堆栈
上电标志
热启动恢复被破
坏的信息部分初
始化
建立上电标志
开始运转
11
青岛理工大学毕业论文
第4章软件设计
系统软件分为主程序、中断服务程序和子程序三部分。
4.1主程序设计
主程序流程框图如图4.1所示。
时
钟
电路
驱限显
动流示
单
片
复
机
位
键
电
盘路
图4.1主程序流程框图
主程序是系统上电或复位后首先要执行的程序,主程序主要完成系统的初始化、扫描
12
青岛理工大学毕业论文
显示、扫描键盘等工作。程序流程如图4.1所示,对单片机进行初始化,包括设置堆栈、
倒计时30S设置、定时器T0设置,外部中断设置,键盘扫描设置,初始化状态时显示000。
4.2倒计时30s子程序设计
定时器T0中断子程序框图如图4.2所示。
开始
把A、PSW放入堆
栈
N
倒计时设置
1S到否
Y
倒计时存入59H
中
十位存入61H、
个位存入60H中
调用显示子程序
弹出A、PSW
退出中断
结束
图4.2定时器T0中断子程序框图
首先要把累加器ACC和程序状态字PSW放入堆栈保护,然后进行倒计时的设置,设
13
青岛理工大学毕业论文
置为30s倒计时,先看看1s到没,如果到,倒计时自动减1,并在数码管显示,再判断倒
计时的30s到没,没到继续倒计时并显示,倒计时计完为止,然后弹出累加器ACC与程序
状态字PSW,中断退出,返回到中断入口处。
4.3外部中断T1中断子程序设计
外部T1中断子程序框图如图4.3所示。
开始
把A、PSW放堆
栈
20H位置0
调用显示子程
序
使三个标志位
清零
T0开始定时T1
停止
使(21H)置
0、30S倒计时
设置
退出ACC、PSW
中断返回
图4.3外部T1中断子程序框图
14
青岛理工大学毕业论文
外部中断T1中断时要先把累加器ACC和程序状态字PSW放入堆栈保护,然后把20H
标志位置0,再调用显示程序,T0开始定时,T1停止,然后设置30S倒计时,设置之后
弹出累加器ACC与程序状态字PSW,中断退出,返回到中断入口处。
4.4定时器T1中断子程序设计
定时器T1中断程序框图如图4.4所示。
开始
把ACC、PSW
放入堆栈
响铃
中断返回
图4.4定时器T1中断程序框图
定时器T1中断时要先把累加器ACC和程序状态字PSW放入堆栈保护,然后就是响
铃,接上喇叭,利用延时程序控制“高”“低”电平的持续时间,就能改变输出频率,从
而改变音调,使喇叭发出不同的声音。设置之后弹出累加器ACC与程序状态字PSW,中
断退出,返回到中断入口处。
4.5选手按键程序设计
键盘扫描程序框图如图4.5所示。
15
青岛理工大学毕业论文
开始
(20H)、
(21H)是否为
0
N
Y
1扫描P1口
0
是否扫描到最后
选手号保存
N
置位(20H)
开始响铃
Y
返回调用
结束
图4.5
键盘扫描程序框图
键盘扫描时先判断20H单元和21H单元标志位是否为0,是的话说明允许键盘扫描,
否的话即不允许键盘扫描,不允许扫描就返回调用,结束,允许扫描时开始扫描P1口看
有没有选手按下答题键,按下时此口变为低电平0,如果没有选手按键,则判断P1口有没
有扫描完,没有扫描完就继续扫描,扫描完没有选手按下就检查20H和21H。
4.6数码管显示程序设计
显示子程序框图如图4.6所示。
16
青岛理工大学毕业论文
开始
选手号在数码管显示出来
倒计时显示N
个位显示与02数
码管、十位显示
于04数码管
倒计时结束?
Y返回调用
结束
图4.6显示子程序框图
进入歌曲赏析 显示子程序先把选手的号码显示于01数码管,然后是选手的答题时间十秒钟倒计
时显示,把个位显示在02数码管上,把十位显示在04数码管上,同时把倒计时的数值减1
后存在61H和62H中,判断倒计时是否结束到0,结束的话返回调用,倒计时没有结束即继续倒计时。
17
青岛理工大学毕业论文
第5章软硬件综合调试
5.1软件仿真
为了更好地完成课程设计这一重要教学环节,我们采用Proteus软件与Keil软件整合
构建单片机虚拟实验平台。首先在PC上利用Proteus软件自己搭建硬件电路,并利用系统
提供的功能完成电路分析、系统调试和输出显示的硬件设计部分;同时在Keil软件中编制
程序,进行相应的编译和仿真,完成系统的软件设计部分。当系统的设计工作完成后,我
们可以在PC上看到最终的运行效果。最后再通过Proteus设计PCB,再完成真正硬件的调
试。
采用以上方案具有以下优势:有利于促进课程和教学改革,更有利于人才的培养;从
经济性、可移植性、可推广性角度讲,建立这样的课程设计平台是非常有意义的;利用仿
真系统,可以节约开发时间和开发成本;利用仿真系统,具有很大的灵活性和可扩展性。
5.1.1KeiluVsion2软件仿真
KeilC51标准C编译器为8051微控制器的软件开发提供了C语言环境,同时保留了汇
编代码高效,快速的特点。C51编译器的功能不断增强,使你可以更加贴近CPU本身,及其
它的衍生产品。C51已被完全集成到uVision2的集成开发环境中,这个集成开发环境包含:
编译器,汇编器,实时操作系统,项目管理器,调试器。uVision2IDE可为它们提供单一而灵
活的开发环境。C51V7版本是目前最高效、灵活的8051开发平台。它可以支持所有8051
的衍生产品,也可以支持所有兼容的仿真器,同时支持其它第三方开发工具。因此,C51V7
版本无疑是8051开发用户的最佳选择。
18
青岛理工大学毕业论文
图5.1KeiluVsion2仿真图
5.1.2Protues7professional软件仿真
ProteusISIS是英国Labcenter公司开发的电路分析与实物仿真软件。它运行于Windows
操作系统上,可以仿真、分析(SPICE)各种模拟器件和集成电路,Proteus是目前最好的模
拟单片机外围器件的工具,它可以仿真51系列、AVR,PIC等常用的MCU及其外围电路
(如LCD,RAM,ROM,键盘,马达,LED,AD/DA,部分SPI器件,部分IIC器件...)Proteus
与其它单片机仿真软件不同的是,它不仅能仿真单片机CPU的工作情况,也能仿真单片机
外围电路或没有单片机参与的其它电路的工作情况。该软件的特点是:
①实现了单片机仿真和SPICE电路仿真相结合。具有模拟电路仿真、数字电路仿真、
单片机及其外围电路组成的系统的仿真、RS232动态仿真、I2C调试器、SPI调试器、键盘
和LCD系统仿真的功能;有各种虚拟仪器,如示波器、逻辑分析仪、信号发生器等。
②支持主流单片机系统的仿真。目前支持的单片机类型有:68000系列、8051系列、
AVR系列、PIC12系列、PIC16系列、PIC18系列、Z80系列、HC11系列以及各种外围芯
片。
③提供软件调试功能。在硬件仿真系统中具有全速、单步、设置断点等调试功能,同时可以观察各个变量、寄存器等的当前状态,因此在该软件仿真系统中,也必须具有这些
19
青岛理工大学毕业论文
功能;同时支持第三方的软件编译和调试环境,如KeilC51uVision2等软件。
④具有强大的原理图绘制功能。总之,该软件是一款集单片机和SPICE分析于一身
的仿真软件,功能极其强大。仿真图如下
图5.2Protues7professional仿真图
5.2软件仿真过程说明
在软件调试过程中,第一阶段,我根据程序流程图在草稿上写出主体程序,然后逐步
细化,采用模块化程序设计方法,如初始子程序,延时子程序等等,这样简洁明了,很方
便查找问题;第二阶段,我将所写的程序输入到电脑上,利用Keil软件调试:新建项目,
保存,新建文件,编译,仿真。在软件仿真中,我在工程项目的SourceGroup1母文件夹
下添加了两个子文件(一个原文件,一个修改后的文件),然后点击RebuildAllTargetFiles
编译图标,编译器马上给我提示,程序正确!这个软件使得程序很快得到验证,也为我的
设计提高了效率!
5.3心得体会与结果
通过这次对抢答器控制系统的设计制作,让我在电路设计的基本上更进一步,也让我
了解了关于数字钟的原理与设计理念。要设计一个成功电路首先进行软件模拟仿真在进行
实际的电路制作,但是最后的成品不一定会成功,因为,在实际接线中会有各种各样的条
20
青岛理工大学毕业论文
件制约着。而且,在仿真中无法成功的电路接法,在实际中因为芯片本身的特性而能够成
功,所以,在设计时应考虑两者的差异,从中找出最适合的设计方法。通过这次自主学习,
让我对各种电路都有了大概的了解,也学会了几个软件的用法。所以说,坐而言不如立而行,对于这些电路还是应该自己动手实际操作才会有深刻的理解。
21
青岛理工大学毕业论文
第6章结论
本文研究与设计的八路多功能抢答器采用了通用的电子元器件,利用AT89S51单片机
及外围接口实现抢答系统,利用单片机的定时器/计数器定时和记数的原理,将软、硬件
有机地结合起来,使得系统能够正确地进行计时,同时使数码管能够正确地显示时间。计
分接霸道什么意思 收的单片机部分利用汇编语言编写。设计时,首先通过在线编程,然后具体安装,仿
真,完全实现了设计功能。
本设计中,利用常规的单片机扫描识别的方法。通过系统的仿真研究得出。
由于采用汇编语言设计电路,所以本设计在编程成功后,硬件电路基本上不需要调试
就可正常使用。
整个设计通过了软件的仿真。我想这对于自己以后的学习和工作都会有很大的帮助。
在这次设计中遇到了很多实际性的问题,在实际设计中才发现,书本上理论性的东西与在
实际运用中的还是有一定的出入的,所以有些问题不但要深入地理解,而且要不断地更正
以前的错误思维。对于单片机设计,其硬件电路是比较简单的,主要是解决程序设计中的
问题。而程序设计是一个很灵活的错误代码105 东西,它反映了你解决问题的逻辑思维和创新能力。它
才是一个设计的灵魂所在。因此在整个设计过程中大部分时间是用在程序上面的。很多子
程序是可以借鉴书本上的,但怎样衔接各个子程序才是关键的问题所在,这需要对单片机
的结构很熟悉。因此可以说单片机的设计是软件和硬件的结合,二者是密不可分的。
但是,通过这次设计我也发现自己的很多不足之处。在设计过程中我发现自己考虑问
题很不全面,自己的专业知识掌握的很不牢固,所掌握的计算机应用软件还不够多,我希
望自己的这些不足之处能在今后的工作和学习中得到改善。而且,通过这次设计,我懂得了学习的重要性,学会了坚持和努力,我将会在以后的学习中继续学习。
22
青岛理工大学毕业论文
致谢
在大学三年的时间大多在学习理论基础知识,实践的不并是太多。经过这次毕业设计,
我接触到了更多元器件以及相关的使用调试经验,发现了自己很多不足之处,体会到了所
学理论知识的重要性。理论知识结合实践操作加深了对理论知识的理解,而且知识掌握得
越多,设计的会更好,更全面。
在设计过程中,通过针对性地查找资料,了解了些电子方面的资料,既增长了自己见
识,补充最新的专业知识,又提高了自己的应用能力。
通过抢答器的设计,让我体会到单片机使用的广泛性以及其重要性,单片机技术的出
现给现代控制领域带来了一项新的改变。目前,单片机在控制系统诸多领域中得到了极为
广泛的应用,特别是其中S51系列的单片机的出现,具有很好的稳定性,更快和更准确的
运算精度,推动了工业生产,影响着人们的工作和学习。所以我们要不断学习加强这方面
的知识以及相关的山西特色菜 知识,比如PCB电路板设计、汇编语言编程、C语言等。
总之这次毕业设计让我把理论设计和工程实践相结合、巩固基础知识与培养创新意识
相结合、个人作用和集体协作相结合等方面全面的培养学生的全面素质。这些在我今后的
学习和工作当中都会有很大的帮助。
最后,我要感谢我的指导老师梁老师,是她给了我许多的帮助。在设计过程中,自始
至终凝聚着导师的心血。恩师那治学严谨的态度,渊博的学识感染着我。她那诲人不倦、
宽厚朴实的作风给我们留下了不可磨灭的影响,是我学习的榜样,使我终生受益无穷。在
此论文完成之际,特向恩师表达诚挚的谢意。
我还要感谢我的一些同学,他们在我最需要帮助的时候无私的伸出了援助之手,在此,
对于他们无私的帮助我表示深深的感谢。可以说如果没有他们的帮助我就不可能顺利的按
时完成毕业设计。
真诚的感谢所有的帮助过我的老师们,同学们、家人和朋友们,感谢对本设计进行评审的老师们,感谢他们给我提出的宝贵意见和建议。
23
青岛理工大学毕业论文
参考文献
[1]陈大钦.电子技术基础实验(第二版)[M].湖北:机械工业出版社,2009.
[2]李广弟.单片机基础[M].北京:北航出版社,2010.
[3]胡学海.单片机原理及应用系统设计[M].北京:京电子工业出版社,2005.
[4]马轲瀛.八路数字抢答器系统[J].华商,2007(23).
[5]梁超.一款基于单片机技术的电子抢答器[J].机电工程技术,2005(1).
[6]蔡朝阳.单片机控制实习与专题制作[M].北京:北京航空航天大学出版社,2006年.
[7]杨凌霄.微型计算机原理及应用[M].江苏:中国矿业大学出版社,2008年.
[8]丁建伟.抢答器电路设计[J].兰州工业高等专科学校学报,2008(04).
[9]李增生.对抢答器的改进[J].电子制作,2008(12).
[10]高伟.AT89单片机原理及应用[M].北京:国防工业出版社,2008年.
[11]林凌,李刚,丁茹.新型单片机接口器件与技术[M].西安:西安电子科技大学出版
社,2006年.
24
本文发布于:2023-04-15 00:31:23,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/fan/82/497855.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |