基于单片机的八路数字抢答器的设计.docx_第1页
基于单片机的八路数字抢答器的设计.docx_第2页
基于单片机的八路数字抢答器的设计.docx_第3页
基于单片机的八路数字抢答器的设计.docx_第4页
基于单片机的八路数字抢答器的设计.docx_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

基于单片机的八位数字抢答器一、设计目的(1) 掌握单片机芯片at89c52的基本功能和使用。(2) 熟悉proteus仿真软件的使用,了解各元件的功能及作用。(3) 掌握keil软件的使用方法,以及如何创建文件和编写程序。(4) 掌握基本的模拟电路和数字电路的知识。(5) 进一步将单片机和c语言相结合,能够熟练掌握单片机的程序编写。(6) 提高焊接能力以及实际问题分析能力。二、设计功能 利用现在市面上性价比极高且易于购买的stc89c52单片机设计一款数字抢答器,需实现以下功能:(1) 八名选手同时使用;(2) 能显示答题人的编号;(3) 需显示出剩余时间;(4) 开始与抢答成功声音提示;(5) 抢答成功的选手,前面会亮对应的灯;(6) 主持人可控制开始和结束抢答;(7) 时间可调。三、设计思路 接通电源后,系统自动复位,无需手动按复位键。抢答器处于禁止状态,选手按抢答键无效,也不作提示。数码管显示030,主持人这时可以按动add键与dec键设置抢答剩余时间;主持人启动start键后,抢答器开始工作。蜂鸣器给出声响提示。抢答时间开始减少,直到有选手抢答为止。如果在规定的时间内,没有选手抢答,抢答器自动复位。选手在设定的时间内抢答时,抢答器完成:优先判断、编号显示、蜂鸣器提示、对应的灯亮。当一轮抢答成之后,禁止二次抢答、数码管显示当前剩余时间。选手答题结束后,主持人按下reset键,抢答器复位,方可进行下一轮的抢答。该数字抢答器的预期目标如下:(1) 抢答器同时供8名选手或8个代表队比赛,分别用8个按钮sw1 sw8和8个灯d0d7表示。(2) 设置一个系统复位键reset,一个系统开始键start,由主持人控制。(3) 抢答器可自动识别抢答成功的选手,并在led数码管上显示该选手编号,同时蜂鸣器发出提示声。选手抢答成功后其他选手不可抢答,及按下抢答键后无效。(4) 抢答器具有定时抢答功能,且一次抢答的时间由主持人设定(默认30秒)。当主持人启动 start键后,中断程序开始计时。抢答时间开始减少。同时蜂鸣器发出短暂的声响,声响持续的时间0.5秒。(5) 参赛选手在设定的时间内进行抢答,抢答有效,报警0.5秒,对应选手前会有一盏灯亮,数码管上显示选手的编号和抢答的时间,并保持到主持人启动reset复位键为止。(6) 如果定时时间已到,无人抢答,本次抢答无效,系统报警并自动复位。准备下一次的抢答。四、stc89c52单片机系统说明 4、1 sct89c52介绍说明 stc89c52 是intel公司mcs-51系列单片机中基本的产品,它采用atmel公司可靠的cmos工艺技术制造的高性能8位单片机,属于标准的mcs-51的hcmos产品。它结合了cmos的高速和高密度技术及cmos的低功耗特征,它基于标准的mcs-51单片机体系结构和指令系统,属于89c51增强型单片机版本,集成了时钟输出和向上或向下计数器等更多的功能,适合于类似马达控制等应用场合。stc89c52有pdip(40pin)和plcc(44pin)两种封装形式。内部结构图:运算器控制器寄存器数据存储器程序存储器i/o口cpu存储器内部总线接口电路输入输出外部设备1接口电路输入输出外部设备2复位电路时钟电路电源电路vccgnd图 4error! main document only. stc89c52内部结构图如图4-2,图中:(1) 内部总线是stc89c52单片机内部的数据通路。(2) 时钟电路为单片机提供一个基准工作时钟。(3) 复位电路是为单片机通电后设置初始状态。图4-2各引脚介绍:如图2-3,本设计所选用的stc89c52单片机是pdip封装。及双排针式,40引脚的封装。p0 口:p0口是一个8位漏极开路的双向i/o口。作为输出口,每位能驱动8个ttl逻辑电对p0端口写“1”时,引脚用作高阻抗输入。当访问外部程序和数据存储器时,p0口也被作为低8位地址/数据复用。在这种模式下,p0具有内部上拉电阻。在flash编程时,p0口也用来接收指令字节;在程序校验时,输出指令字节。程序校验时,需要外部上拉电阻。p1 口:p1 口是一个具有内部上拉电阻的8 位双向i/o 口,p1 输出缓冲器能驱动4 个 ttl 逻辑电平。对p1 端口写“1”时,内部上拉电阻把端口拉高,此时可以作为输入口使用。作为输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流(iil)。此外,p1.0和p1.2分别作定时器/计数器2的外部计数输入(p1.0/t2)和时器/计数器2 的触输入(p1.1/t2ex)。 在flash编程和校验时,p1口接收低8位地址字节。引脚号第二功能p1.0 t2(定时器/计数器t2的外部计数输入),时钟输出。p1.1 t2ex(定时器/计数器t2的捕捉/重载触发信号和方向控制)。p1.5 mosi(在线系统编程用)。p1.6 miso(在线系统编程用)。p1.7 sck(在线系统编程用)。p2 口:p2 口是一个具有内部上拉电阻的8 位双向i/o 口,p2 输出缓冲器能驱动4 个 ttl 逻辑电平。对p2 端口写“1”时,内部上拉电阻把端口拉高,此时可以作为输入口使用。作为输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流(iil)。在访问外部程序存储器或用16位地址读取外部数据存储器(例如执行movx dptr) 时,p2 口送出高八位地址。在这种应用中,p2 口使用很强的内部上拉发送1。在使用 8位地址(如movx ri)访问外部数据存储器时,p2口输出p2锁存器的内容。在flash编程和校验时,p2口也接收高8位地址字节和一些控制信号。p3 口:p3 口是一个具有内部上拉电阻的8 位双向i/o 口,p2 输出缓冲器能驱动4 个 ttl 逻辑电平。对p3 端口写“1”时,内部上拉电阻把端口拉高,此时可以作为输入口使用。作为输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流(iil)。 p3口亦作为stc89c52特殊功能(第二功能)使用。在flash编程和校验时,p3口也接收一些控制信号。端口引脚 第二功能p3.0 rxd(串行输入口)。p3.1 txd(串行输出口)。p3.2 into(外中断0)。p3.3 int1(外中断1)。p3.4 to(定时/计数器0)。p3.5 t1(定时/计数器1)。p3.6 wr(外部数据存储器写选通)。p3.7 rd(外部数据存储器读选通)。此外,p3口还接收一些用于flash闪存编程和程序校验的控制信号。rst复位输入。当振荡器工作时,rst引脚出现两个机器周期以上高电平将是单片机复位。ale/prog当访问外部程序存储器或数据存储器时,ale(地址锁存允许)输出脉冲用于锁存地址的低8位字节。一般情况下,ale仍以时钟振荡频率的1/6输出固定的脉冲信号,因此它可对外输出时钟或用于定时目的。要注意的是:每当访问外部数据存储器时将跳过一个ale脉冲。对flash存储器编程期间,该引脚还用于输入编程脉冲(prog)。如有必要,可通过对特殊功能寄存器(sfr)区中的8eh单元的d0位置位,可禁止ale操作。该位置位后,只有一条movx和movc指令才能将ale激活。此外,该引脚会被微弱拉高,单片机执行外部程序时,应设置ale禁止位无效。psen程序储存允许(psen)输出是外部程序存储器的读选通信号,当stc89c52由外部程序存储器取指令(或数据)时,每个机器周期两次psen有效,即输出两个脉冲,在此期间,当访问外部数据存储器,将跳过两次psen信号。ea/vpp外部访问允许,欲使cpu仅访问外部程序存储器(地址为0000h-ffffh),ea端必须保持低电平(接地)。需注意的是:如果加密位lb1被编程,复位时内部会锁存ea端状态。如ea端为高电平(接vcc端),cpu则执行内部程序存储器的指令。flash存储器编程时,该引脚加上+12v的编程允许电源vpp,当然这必须是该器件是使用12v编程电压vpp。4、2 stc89c52单片机的性能stc89c52 与mcs-51单片机产品兼容。8k字节在系统可编程flash存储器,1000次擦写周期,全静态操作。晶振频率范围0hz33hz,三级加密程序存储器,32个可编程i/o口线、三个16位定时器/计数器,八个中断源,全双工uart串行通道,低功耗空闲和掉电模式,掉电后中断可唤醒,看门狗定时器,双数据指针,掉电标识符 。stc89c52 是一种低功耗、高性能cmos8位微控制器,具有 8k 在系统可编程flash 存储器。使用高密度非易失性存储器技术制造,与工业80c51 产品指令和引脚完全兼容。片上flash允许程序存储器在系统可编程,亦适于常规编程器。在单芯片上,拥有灵巧的8 位cpu 和在线系统可编程flash,使得stc89c52为众多嵌入式控制应用系统提供高灵活、超有效的解决方案。 stc89c52具有以下标准功能: 8k字节flash,256字节ram, 32 位i/o 口线,看门狗定时器,2 个数据指针,三个16 位 定时器/计数器,一个6向量2级中断结构,全双工串行口,片内晶振及时钟电路。另外,stc89c52可降至0hz静态逻辑操作,支持2种软件可选择节电模式。空闲模式下,cpu 停止工作,允许ram、定时器/计数器、串口、中断继续工作。掉电保护方式下,ram内容被保存,振荡器被冻结,单片机一切工作停止,直到下一个中断或硬件复位为止。8 位微控制器 8k字节在系统可编程 flash。54、3 各类单片机的比较与分析如表4-4所示,以下各种类型的单片机内除cpu外,还包括rom、ram、4*8i/o口和2个16位定时/计数器,它们都是功能很强的单片微型计算机。但由于80c51片内为掩膜rom,故内部程序不能改写,不用于实验开发。87c51具有片内eprom,是真正的单片微机,但由于价格较贵,且程序改写时要用紫外线擦除,时间较长,所以用得较少。80c31在市场上的价格很低,但片内没有rom,必须在片外扩展一片eprom,非常不便。at89c51片内具有可电擦除的fperom,可以快速、多次地编程,且价格不高,所以用得非常广泛,目前开发用的mcs51产品绝大多数用89c51。由于现在市面上 89c51 和 89c52 价格相差极小(仅5角钱的差异),故本设计采用了性能更好的89c52系列。使系统有了更大的扩展空间。6表 4-4型号rom形式片内rom片内ram寻址范围定时计数i/o口串行i/o口外部中断80c31接rom4k1282*64 k2*164uart280c51rom4k1282*64 k2*164uart287c51eprom4k1282*64 k2*164uart289c51fpeprom4k1282*64 k2*164uart289c52eeprom8k2562*64 k3*164uart3五、数字抢答器总体方案的设计本设计分为硬件设计和软件设计,这两者相互结合,不可分离;从时间上看,硬件设计的绝大部分工作量是在最初阶段,到后期往往还要做一些修改。只要技术准备充分,硬件设计的大返工是比较少的,软件设计的任务贯彻始终,到中后期基本上都是软件设计任务,随着集成电路技术的飞速发展,各种功能很强的芯片不断出现,使硬件电路的集成度越来越高,硬件设计的工作量在整个项目中的所占的比重逐渐下降。5、1 系统硬件的设计 5、1.1 系统设计原理图1、本设计各原理图所使用的画图软件简介 本设计各原理图所使用的画图软件是proteus,proteus简介:proteus软件是英国lab center electronics公司出版的eda工具软件(该软件中国总代理为广州风标电子技术有限公司)。它不仅具有其它eda工具软件的仿真功能,还能仿真单片机及外围器件。它是目前比较好的仿真单片机及外围器件的工具。虽然目前国内推广刚起步,但已受到单片机爱好者、从事单片机教学的教师、致力于单片机开发应用的科技工作者的青睐。 图5-1proteus是世界上著名的eda工具(仿真软件),从原理图布图、代码调试到单片机与外围电路协同仿真,一键切换到pcb设计,真正实现了从概念到产品的完整设计。是目前世界上唯一将电路仿真软件、pcb设计软件和虚拟模型仿真软件三合一的设计平台,其处理器模型支持8051、hc11、pic10/12/16/18/24/30/dspic33、avr、arm、8086和msp430等,2010年又增加了cortex和dsp系列处理器,并持续增加其他系列处理器模型。在编译方面,它也支持iar、keil和mplab等多种编译器。2、设计原理图 图5-2如图5-2,p2.3口为开始start键,p2.4为复位reset键,p1.0-p1.7为八路抢答输入sw1-sw8键,数码管段选p0口,位选p2.0、p2.1、p2.2,蜂鸣器输出为p2.7口。p2.5为时间加1 add键,p2.6为时间减1 dec键。5、1.2 时钟频率电路的设计 如图5-3,单片机必须在时钟的驱动下才能工作.在单片机内部有一个时钟振荡电路,只需要外接一个振荡源就能产生一定的时钟信号送到单片机内部的各个单元,决定单片机的工作速度。本设计采用11.0592m晶振,而不是12m,使计时更加精准。单片机一般选用石英晶体振荡器。此电路在加电大约延迟10ms后振荡器起振,在xtal2引脚产生幅度为3v左右的正弦波时钟信号,其振荡频率主要由石英晶振的频率确定。电路中两个电容 c1,c2的作用有两个:一是帮助振荡器起振;二是对振荡器的频率进行微调。c1,c2的典型值为30pf。单片机在工作时,由内部振荡器产生或由外直接输入的送至内部控制逻辑单元的时钟信号的周期称为时钟周期。其大小是时钟信号频率的倒数,常用fosc表示。如时钟频率为110592mhz,即fosc=11.0592mhz,则时钟周期为1/11.0592s。5、1.3 复位电路的设计 图5-4如图5-4,单片机的第9脚reset为硬件复位端,只要将该端持续4个机器周期的高电平即可实现复位,复位后单片机的各状态都恢复到初始化状态。值得注意的是,在设计当中使用到了硬件复位和软件复位两种功能,由上面的硬件复位后的各状态可知寄存器及存储器的值都恢复到了初始值,系统实现了复位 。本设计还设计了软复位功能。软复位实际上就是当复位程序执行完毕之后,将程序中的变量恢复到初始状态,也实现了系统复位。5、1.4 显示电路的设计 图5-5如图5-5,数码管采用4位八段共阳极led,位选采用反相器74hc14间接控制。增强数码管的电流输入。避免了因单片机驱动电流较小而引起的显示问题。使选手和主持人都能清楚的看到显示内容。且大大减小了单片机的负担。5、1.5键盘扫描电路的设计键盘是人与微机系统打交道的主要设备。键盘分为独立式和矩阵式。它们各有自己的特点,其中独立键盘硬件电路简单,而且在程序设计上也不复杂,一般用在对硬件电路要求不高的简单电路中;矩阵键盘与独立键盘有很大区别,首先在硬件电路上它要比独立键盘复杂得多,而且在程序算法上比它要烦琐,但它在节省端口资源上有优势得多,因此它更适合于多按键电路。其次就是消除在按键过程中产生的“毛刺” 现象。这里采用最常用的方法,即延时法,延时法的原理为:因为“毛刺”脉冲一般持续时间短,约为几ms,而我们按键的时间一般远远大于这个时间,所以当单片机检测到有按键动静后再延时一段时间(这里我们取200ms)后再进行运算。9本设计共12个键。为增强本设计的稳定性,减少单片机的工作量,在单片机剩余引脚允许的情况下,本设计采用了独立式键盘。1.抢答部分 图5-6p1 口八个引脚刚好代表八个抢答键,一个按键对应一盏灯,按下一个按键,则对应的灯就会亮,方便编程与布线。2. 主持人控制部分 图5-75、1.6报警电路的设计 我们知道,声音的频谱范围约在几十到几千赫兹,若能利用程序来控制单片机某个口线的“高”电平或低电平,则在该口线上就能产生一定频率的矩形波,接上喇叭就能发出一定频率的声音,若再利用延时程序控制“高”“低”电平的持续时间,就能改变输出频率,从而改变音调,使喇叭发出不同的声音。 图5-8如图5-8,本设计对声音要求不高,不需要复杂的编程。我们只需要简单的控制p2.7的高低电平即可。5、2 系统软件的设计 5、2.1 keil 软件介绍keil c51是美国keil software公司出品的51系列兼容单片机c语言软件开发系统,与汇编相比,c语言在功能上、结构性、可读性、可维护性上有明显的优势,因而易学易用。keil提供了包括c编译器、宏汇编、链接器、库管理和一个功能强大的仿真调试器等在内的完整开发方案,通过一个集成开发环境(vision)将这些部分组合在一起。运行keil软件需要win98、nt、win2000、winxp等操作系统。如果你使用c语言编程,那么keil几乎就是你的不二之选,即使不使用c语言而仅用汇编语言编程,其方便易用的集成环境、强大的软件仿真调试工具也会令你事半功倍。 图5-9如图5-9所示,2009年2月发布keil vision4,keil vision4引入灵活的窗口管理系统,使开发人员能够使用多台监视器,并提供了视觉上的表面对窗口位置的完全控制的任何地方。新的用户界面可以更好地利用屏幕空间和更有效地组织多个窗口,提供一个整洁,高效的环境来开发应用程序。新版本支持更多最新的arm芯片,还添加了一些其他新功能。2011年3月arm公司发布最新集成开发环境realview mdk开发工具中集成了最新版本的keil vision4,其编译器、调试工具实现与arm器件的最完美匹配。5、2.2 主程序系统结构图初始化显示0xx开始键按下?复位键按下?减一键按下?加一键按下?抢答时间减一抢答时间加一无人抢答抢答成功主持人复位yyyy系统复位图 3-10 主程序系统结构图六、设计体会 本次电子课程设计实习将理论与实践有机地结合,既考查了我对理论知识的掌握程度,反映了实际动手能力,更主要的是考查了我对知识的综合运用以及创新设计思维能力,为今后的发展提供了一次良好的学习环境。针对课程设计八路抢答器,一开始还没有头绪,不会运用所学知识进行有效设计,但通过上网查阅各种类似的设计,去图书馆翻阅相关设计书籍,查阅所提供的芯片功能,确定基本设计方案,又通过仿真验证试验方案的可实行性,虽说比较烦杂但却对设计一个电路有了基本的经验。同时也使自己认识到:1.设计思路是整个设计的灵魂拿下每个课题能有一个非常清晰的设计思路是至关重要的。只有对课题的充分理解,对各种器件的熟练掌握,勾画出基本的设计图是成功的关键,必须多花时间在设计上才能为后续工作提供更扎实的基础。翻阅各种资料,上网查询填补所需知识的空白是必要的。2.调试调试工作是个精细工作。通过对芯片功能的检验,最后检查出问题所在。当最后解决问题时,电路的正确是非常振奋,也很有成就感和满足感。总之,在设计过程中学到了许多。作为现代的大学生,如果仅停留在以往的层次上,是远远跟不上时代的步伐,也无法使自己立足在竞争如此激烈的社会里,通过此次实习,看到了自己的水平和差距,学要在今后的学习中又进一步的提高。参考文献1 臧殿红,臧殿红.基于at89s51的八路抢答器的设计j. 科技信息,2011,25期:3.2 谭浩强. c程序设计 4版.北京:清华大学出版社,2010年6月 3 王建. 单片机入门与典型应用实例m.1版.北京:中国电力出版社 4 凌志浩. at89c52单片机原理与接口技术m.1版.北京:高等教育出版社5 李学海. 经典80c51单片机轻松入门与上手m.1版.哈尔滨:清华大学出版社6 郭天祥. 新概念51单片机c语言教程m.1版.哈尔滨:电子工业出版社

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论