毕业设计基于单片机的数字抢答器设计Word文档下载推荐.docx
- 文档编号:17216602
- 上传时间:2022-11-29
- 格式:DOCX
- 页数:25
- 大小:335.61KB
毕业设计基于单片机的数字抢答器设计Word文档下载推荐.docx
《毕业设计基于单片机的数字抢答器设计Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《毕业设计基于单片机的数字抢答器设计Word文档下载推荐.docx(25页珍藏版)》请在冰豆网上搜索。
五结束语
六参考文献
基于单片机的数字抢答器设计
引言:
单片机的发展史
单片机诞生于20世纪70年代末,经历了SCM、MCU、SoC三大阶段。
1.SCM即单片微型计算机(SingleChipMicrocomputer)阶段,主要是寻求最佳的单片形态嵌入式系统的最佳体系结构。
“创新模式”获得成功,奠定了SCM与通用计算机完全不同的发展道路。
在开创嵌式系统独立发展道路上,Intel公司功不可没。
2.MCU即微控制器(MicroControllerUnit)阶段,主要的技术发展方向是:
不断扩展满足嵌入式应用时,对象系统要求的各种外围电路与接口电路,突显其对象的智能化控制能力。
它所涉及的领域都与对象系统相关,因此,发展MCU的重任不可避免地落在电气、电子技术厂家。
从这一角度来看,Intel逐渐淡出MCU的发展也有其客观因素。
在发展MCU方面,最著名的厂家当数Philips公司。
Philips公司以其在嵌入式应用方面的巨大优势,将MCS-51从单片微型计算机迅速发展到微控制器。
因此,当我们回顾嵌入式系统发展道路时,不要忘记Intel和Philips的历史功绩。
3.单片机是嵌入式系统的独立发展之路,向MCU阶段发展的重要因素,就是寻求应用系统在芯片上的最大化解决;
因此,专用单片机的发展自然形成了SoC化趋势。
随着微电子技术、IC设计、EDA工具的发展,基于SoC的单片机应用系统设计会有较大的发展。
因此,对单片机的理解可以从单片微型计算机、单片微控制器延伸到单片应用系统。
单片机的发展单片机作为微型计算机的一个重要分支,应用面很广,发展很快。
自单片机诞生至今,已发展为上百种系列的近千个机种。
绪论
1.1单片机抢答器的背景
二十世纪跨越了三个“电”的时代,即电气时代、电子时代和现已进入的电脑时代。
不过,这种电脑,通常是指个人计算机,简称PC机。
它由主机、键盘、显示器等组成。
还有一类计算机,大多数人却不怎么熟悉。
这种计算机就是把智能赋予各种机械的单片机(亦称微控制器)。
顾名思义,这种计算机的最小系统只用了一片集成电路,即可进行简单运算和控制。
因为它体积小,通常都藏在被控机械的“肚子”里。
它在整个装置中,起着有如人类头脑的作用,它出了毛病,整个装置就瘫痪了。
现在,这种单片机的使用领域已十分广泛,如智能仪表、实时工控、通讯设备、导航系统、家用电器等。
各种产品一旦用上了单片机,就能起到使产品升级换代的功效,常在产品名称前冠以形容词——“智能型”,如智能型洗衣机等。
现在有些工厂的技术人员或其它业余电子开发者搞出来的某些产品,不是电路太复杂,就是功能太简单且极易被仿制。
究其原因,可能就卡在产品未使用单片机或其它可编程逻辑器件上。
在知识竞赛中,特别是做抢答题时,在抢答过程中,为了更确切的知道哪一组或哪一位选手先抢答到题,必须要有一个系统来完成这个任务。
若在抢答中,只靠人的视觉(或者是听觉)是很难判断出哪一组(或哪一个选手)先抢答到题的。
利用单片机编程来设计抢答器,可以使以上问题得以解决,即使两组的抢答时间相差几微秒,也能轻松的分辨出哪一组(或哪个选手)先抢答到题的。
本文主要介绍了抢答器的工作原理及设计,以及它的实际用途。
1.2单片机抢答器的意义
本系统采用单片机作为整个控制核心。
控制系统的四个模块为:
显示模块、存储模块、语音模块、抢答开关模块。
该系统通过开关电路四个按键输入抢答信号;
利用一个数码管来完成显示功能;
用按键来让选手进行抢答,在数码管上显示哪一组先答题的,从而实现整个抢答过程。
在知识比赛中,特别是做抢答题目的时候,在抢答过程中,为了知道哪一组或哪一位选手先答题,必须要设计一个系统来完成这个任务。
如果在抢答中,靠视觉是很难判断出哪组先答题。
利用单片机系统来设计抢答器,使以上问题得以解决,即使两组的抢答时间相差几微秒,也可分辨出哪组优先答题。
本文主要介绍了单片机抢答器设计及工作原理,以及它的实际用途。
系统工作原理本系统采用89c52单片机作为核心。
控制系统的四个模块分别为:
存储模块、显示模块、语音模块、抢答开关模块。
该抢答器系统通过开关电路四个按键输入抢答信号;
利用一个数码管来完成显示功能。
工作时,用按键通过开关电路输入各路的抢答信号,经单片机的处理,输出控制信号,单片机控制的智能抢答器设计。
1.3抢答器的应用
随着我国经济和文化事业的发展,在很多公开竞争场合要求有公正的竞争裁决,诸如证券、股票交易及各种智力竞赛等,因此出现了抢答器。
抢答器一般是由很多电路组成的,线路复杂,可靠性不高,功能也比较简单,特别是当抢答路数很多时,实现起来就更为困难。
因此我们设计了以单片机为核心的新型智能的抢答器,在保留了原始抢答器的基本功能的同时又增加一系列的实用功能并简化其电路结构。
抢答器又称为第一信号鉴别器,其主要应用于各种知识竞赛、文艺活动等场合。
传统普通抢答器主要存在以下缺陷:
(1)、在一次抢答过程中,当出现超前违规抢答时,只能处理违规抢答信号,而对没有违规的有效抢答信号不能进行处理,因而使该次抢答过程变为无效。
(2)、当有多个违规抢答时,普通抢答器或采用优先编码电路选择其中一个,或利用抢答电路电子元件的“竞争”选择其中一个。
对于后者由于抢答电路制作完毕后电子元件被固定。
各路抢答信号的“竞争”能力也被固定,因而本质上也有优先权。
普通抢答器存在不公平性。
(4)、当有多个违规抢答时,普通抢答器只能“抓住”其中一个而出现“漏洞”
1.1数字抢答器的概述
对于抢答器我们大家来说都不陌生,它是用于很多竞赛场合,真正实现先抢先答,让最先抢到题的选手来回答问题。
1.2设计任务与要求
(1)给主持人设置一个开关,用来控制系统的清零(显示按键编号的数码管熄灭)和抢答器的开始。
(2)抢答器具有数据锁存和显示的功能。
抢答开始后,若有选手按动抢答器按钮,按键编号立即锁存,并在数码管上显示选手的编号(即按键编号),同时扬声器发出声响提示(即报警)。
此外,要封锁输入电路,禁止其他选手抢答。
(3)抢答器具有定时抢答的功能,且一次抢答的时间可以由主持人设定(如30秒)。
当节目主持人启动“开始”键后,要求定时器立即减计时,并显示在数码管上。
(4)参加选手在设定的时间内抢答,抢答有效,定时器停止工作,显示器上显示选手的编号和抢答时刻的时间,并保持到主持人将系统清零为止。
(5)如果定时抢答的时间已到,却没有选手抢答时,本次抢答无效,系统短暂报警,并封锁输入电路,禁止选手超时后抢答,时间显示器上显示00。
(6)选手如果在主持人按开始键之前违规抢答,系统报警,数码管上显示违规选手号码(即按键编号),直到主持人将系统清零为止。
注:
系统每次报警后,均在3s后停止发出声响。
二单片机芯片的选择及抢答器方案
2.1单片机芯片的选择
单片机选用的是STC公司推出的STC89C52RC40C,它的机器周期的时钟可选:
12时钟/机器周期、6时钟/机器周期;
工作电压范围:
3.4V-5.5V;
工作频率范围:
0—40MHz,相当于普通8051单片机的0—80MHz;
用户程序空间:
根据单片机型号配置不同的用户程序空间,有4KB、8KB、13KB、20KB、32KB、64KB等;
片内集成RAM:
有1280字节和512字节两种;
通用I/O口:
相比传统的8051单片机增加了一个P4口;
ISP(在系统编程)和IAP(在应用编程)功能:
无需专用编程器/仿真器,可通过单片机串口直接下载用户程序,8KB程序3秒即可完成;
有EEPROM功能;
有看门狗定功能;
内部集成MAX810专用复位电路,外部晶体20M以下时,可省外部复位电路;
共有3个16位定时器/计数器,其中定时器0还可以当成2个8位定时器使用,外部中断4路,下降沿中断或低电平触发中断,PowerDown模式可由外部中断低电平触发中断方式唤醒;
通用异步串行口(UART),还可用定时器软件实现多个UART;
工作温度范围:
有0—75℃和-40—85℃两种
(1)单片机管脚说明
①Vcc:
供电电压。
②GND:
接地。
③P0口:
P9口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门流。
当P1口的管脚第一次写1时,被定义为高阻输入。
P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。
在Flash编程时,P0口作为原码输入口,当Flash进行校验时,P0输出原码,此时P0外部必须被拉高。
④P1口:
P1口是一个内部提供的上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。
P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故,。
在Flash编程和校验时,P1作为第八位地址接收。
⑤P2口:
P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。
并因此作为输入时,P2口的管脚被外部拉低,将输出电流。
这是由于内部上拉的缘故。
P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。
在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。
P2口在Flash编程和校验时接收高八位地址信号和控制信号。
⑥P3口:
P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。
当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。
作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。
P3口也可作为AT89S52的一些特殊功能口,如下表所示:
P3口功能引脚简介
P3口引脚第二功能
P3.0
RXD(串行口输入)
P3.1
TXD(串行口输出)
P3.2
INT0(外部中断0输入)
P3.3
INT1(外部中断1输入)
P3.4
T0(定时器0外部脉冲输入)
P3.5
T1(定时器1外部脉冲输入)
P3.6
WR(外部数据存储器写脉冲输出)
P3.7
RD(外部数据存储器读脉冲输出)
P3口同时为闪烁编程和编程校验接收一些控制信号。
⑦RST:
复位输入。
当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。
⑧ALE/RPOG:
当访问外部存储器时,地址锁存允许的输出电平由于锁存地址的地位字节。
在Flash编程期间,此引脚用于输入编程脉冲。
在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6.因此它可用作对外部输出的脉冲或用于定时目的。
然而要注意的是:
每当用作外部数据存储器时,将跳出一个ALE脉冲。
如想禁止ALE的输出可在SFR8EH地址上置0.此时,ALE只有在执行MOVX,MOVC指令时ALE才起作用。
另外该引脚被略微拉高。
如果微处理器在外部执行状态ALE禁止,置位无效。
⑨/PSEN:
外部程序存储器的选通信号。
在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。
但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。
⑩/EA/VPP:
当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。
注意加密方式1时,/EA将内部锁定为RESET;
当/EA端保持高电平时,此间内部程序存储器。
在Flash编程期间,此引脚也用于施加12V编程电源(VPP)。
11XTAL1:
反向振荡放大器的输入及内部时钟工作电路的输入。
12XTAL2:
来自反向振荡器的输出。
2.2模块性能分析
模块部分主要分为STC89C52芯片、矩阵式键盘、LED数码管显示部分,下面对这后两部分进行介绍,其中对LED七段数码管显示器做详细介绍,并根据实际工作情况采用合适的工作方式。
(1)矩阵式键盘
利用矩阵式按钮开关S1~S16组成抢答器的输入电路。
S1~S16为自复式常开按钮开关,分别作为选手抢答按钮,利用行线与列线分别扫描,扫描值相或来确定是几号按键按下,锁存器的输入端为低电平。
矩阵式按键主要的一个特点就是,提高单片机IO端口的利用率,以少量的IO端口控制多个按键。
当程序执行时,按下按键,七段数码管显示器上即显示相应的是哪个组按下抢答。
(2)LED数码管显示
译码器的逻辑功能是将每一个输入的二进制代码译成对应的输出高、低电平信号,是编码器的反操作。
数码管可以用TTL或CMOS集成电路直接驱动,所以使用译码器将BCD编码译成数码管所需要的驱动信号,以便使数码管用十进制数字显示出BCD编码表示的数值。
七段数码管的段排列和内部结构如图所示七段数码管的段排列和内部部结构
应根据实际情况决定究竟采用共阳还是共阴方式,其基本原则是:
若单片机口线直接驱动数码管各段,最好采用共阳极数码管,因为8051系列单片机口线输出高电平时,输出的电流很小,数码管不会太亮。
若数码管通过驱动芯片与单片机相连,就要看驱动芯片对数码管极性的要求了
点亮显示器分为静态和动态显示两种方法。
所谓静态显示,就是当显示器显示某一字符时,相应的发光二极管恒定的导通或是截止。
例如,其段数码管的a、b、c、d、e、f、导通,g截止,则显示0.这对这种显示方式每一位都要有一个8位输出口控制,所占硬件较多,一般用于显示位数较少(很少)的场合。
当位数较多时,用静态显示所需的I/O过多,一般采用动态显示方法。
所谓动态显示,就是逐位地轮流点亮各位显示器(扫描),对于每一位显示器而言,每个一段时间点亮一次。
显示器的点亮既与点亮时的导通电流有关,也与点亮时间和间隔时间比例有关。
调整电流和时间参数,可是实现亮度较高、较为稳定的显示,同时可减少工作电流。
三极管中的COM是选通位,对于共阳极数码管,当a、b、c、d、e、f、g、h端接低电平时,COM位高电平,数码管各段全部点亮。
例如,想让数码管显示“1”,就必须使数码管的b、c段点亮,其它段熄灭;
所以使b、c段为低电平,其它各引脚均为高电平。
在设计电路时,可将这几位分别接到单片机的引脚上,还要加上限流电阻,这样就可由程序控制数码管的工作情况了。
但是如果用一个端口驱动一个数码管,四位数码管就需要四个空闲端口,而在许多系统中并无四个端口可用。
此外,使用四个端口往往使得每一个数字都需要独立驱动(缓冲)电路和排阻,这将大大增加系统的成本。
最常见的解决方案是采用多路复用显示。
这是指对于每一个显示只驱动1/4时间。
只要在20Hz-50Hz之间循环所有显示,由于人眼存在视觉残留,在这样的显示方式下,数码管看起来时同时点亮的。
在这次课程设计中根据实际需要采用了七段数码管共阳极和静态显示方式。
抢答器的实现方式有种多样,通过纯电子器件搭建电路实现,如优先编码器,锁存器,555定时器译码器等,纯电子器件实现没有软件参与,调试简单,但是它不易于扩展和修改,而且电路结构复杂,调试困难电子,电子器件管脚很多,实际搭建起来费时费力,焊接很容易出错。
于是,我想到了用单片机实现。
由于单片机本身不具有软件编译测试的功能,我们需要借助其他软件编译,将编译好的程序“烧”入单片机内。
在实际电路设计中,需要先通过仿真软件测试电路以及编译的程序,检查外围电路设计是否合理,软件编译是否正确,以及软件和硬件电路能否正常配合工作,能否准确的实现所设计的功能。
如果测试通过,电路仿真没有问题能完全实现功能的话就可以实际的做板子的焊接工作了。
在老师的指导下我选择了常用的单片机仿真软件proteus6.9以及keil进行仿真。
三硬件电路设计
3.1总体设计
根据抢答器的基本功能,可以设计出如下的单片机外围电路。
(详细电路图见附件1)硬件电路设计主要由我的搭档汪姗完成,在这里只展示电路图。
3.2单片机最小系统电路:
3.3显示电路的设计:
3.4抢答电路的设计:
3.5报警电路的设计:
四系统软件设计
4.1抢答器流程图
流程图是使用图形表示算法的思路是一种极好的方法,不论采用何种程序设计方法,程序总体结构确定后,一般以程序流程图的形式对其进行描述。
总体框图中的各个子模块或各个子任务也应该结合具体的教学模型和算法画出较详细的程序流程图,供后面编写具体程序和阅读程序使用。
流程图是由一些图框和流程线组成的,其中图框表示各种操作的类型,图框中的文字和符号表示操作的内容,流程线表示操作的先后次序。
流程图的基本结构为顺序结构,分支结构(又称选择结构),循环结构。
为便于识别,绘制流程图的习惯做法是:
方框表示:
要执行的处理(Process)
平行四边型表示:
代表资料输入(Input)
不规则图形代表资料输出(Output)或报表输出(Print)
菱形表示:
决策或判断(例如:
If...Then...Else)
我们组所设计的抢答器的程序采用的是C程序设计,C语言的显著特点是用二进制来编写程序,程序的各个部分除了必要的信息交流外彼此之间相互独立。
这种结构化方式可使程序层次清晰,便于使用、维护以及调试。
C语言是以函数形式提供给用户的,这些函数可方便的调用,并具有多种循环、条件语句控制程序流向,从而使程序完全结构化。
虽然C语言也是强类型语言,但它的语法比较灵活,允许程序编写者有较大的自由度。
抢答器主程序流程图如下:
4.2中断程序
(1)什么是中断
中断是指由于某种随机事件的发生,计算机暂停现行的程序的运行,转去执行另一个程序,以处理发生的事件,处理完毕后又自动返回原来的程序继续运行。
有五种中断源:
外部中断0、外部中断1、定时器中断0、定时器中断1、串行中断。
它们的描述如下图所示:
中断源符号
名称
终端引起的原因
中断矢量地址
INT0
外部中断0
由P3.2低电平或下降沿信号
0003H
T0
定时器中断0
定时/计数器0回零溢出P3.4
0013H
INT1
外部中断1
由P3.3低电平或下降沿信号
000BH
T1
定时器中断1
定时/计数器1回零溢出P3.5
001BH
TI/RI
串行中断
串行口接收或发送完帧数据引起的中断
0023H
(2)中断所用到的寄存器
介绍定时器/计数器中所介绍的寄存器:
①、定时器/计数器控制寄存器TCON
TCON的作用是控制定时器的启动`停止,标志定时器的溢出和中断情况;
②、中断允许控制寄存器IE
对中断源的开放或屏蔽是由中断寄存器IE控制的,地址为0A8H,即可以按字节寻址,也可以按位寻址。
当单片机复位时,IE被清零。
③、串行控制寄存器SCON
定时/计数器的控制方法:
在启动定时/计数器工作之前CPU必须将一些命令(称为控制字)写入定时/计数器中,这个过程称为定时/计数的初始化。
(定时/计数器的初始化通过定时/计数器的方式寄存器TMOD和控制寄存器TCON来完成。
︱
④定时/计数器方式寄存器TMOD
GATE
C/T
M1
M0
定时器1定时器0
工作方式
功能说明
方式0
13位计数器
1
方式1
16位计数器
方式2
自动再装入8位计数器
方式3
定时器0:
分成两个8位计数器;
定时器1:
停止计数
(3)中断程序的编写的步骤:
①、根据要求设置IE(中断允许寄存器)的对应位EA(EA—总中断允许位EA=1开放所有的中断;
EA=0禁止所有的中断),某个中断源还有相应的中断允许位
a、当=1时:
允许相应中断源的中断;
b、当=0时:
禁止相应中断源的中断;
③、INT0、INT1设定触发方式IT0(外部中断触发方式控制位)当为0时:
低电平触发;
当为1时:
下降沿触发;
④、返回值是Void中断函数名()interrupt()
(4)为什么采用中断控制方式
CPU与外部设备的数据传送方式:
①无条件传送方式CPU总认为外设处于准备好的状态,外设比较简单
②程序查询传送方式外设有一个状态(状态存储在寄存器内)
缺点:
CPU工作效率低,CPU处于等待的状态,为解决此缺点便出现了第三种传送方式
③中断传送方式
中断是指由于某种随机事件的发生,计算机暂停现行的程序,转去执行另一程序以处理发生的事件,处理完毕后又自动返回原来的程序继续运行。
优点:
a.实现分时操作CPU分为多个I/O设备服务,提高计算机的利用率(提前安排好的函数而中断不同);
b.实时响应CPU能够及时处理应用系统的随机事件,系统的实时性大大增强;
c.可靠性高CPU具有处理设备故障及掉电等突发性事件的能力,从而使系统的可靠性提高。
下图是中断服务程序流程图:
中断服务程序具体如下:
if(f20ms==1)
{
f20ms=0;
unsignedcharkey;
unsignedcharxiang=3;
unsignedintdaojishu=30;
unsignedcharstart=0;
//1表示抢答开始;
0表示抢答没有开始
unsignedcharkg1=0//0表示蜂鸣器不响,1表示蜂鸣器响——按键按下,才控制
unsignedcharkg2=0;
//0表示蜂鸣器不响,1表示蜂鸣器响——30秒到了,才
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 毕业设计 基于 单片机 数字 抢答 设计