1 / 26
文档名称:

单片机秒表设计毕业论文.pdf

格式:pdf   大小:2,547KB   页数:26页
下载后只包含 1 个 PDF 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

单片机秒表设计毕业论文.pdf

上传人:1781111**** 2024/5/11 文件大小:2.49 MB

下载得到文件列表

单片机秒表设计毕业论文.pdf

相关文档

文档介绍

文档介绍:该【单片机秒表设计毕业论文 】是由【1781111****】上传分享,文档一共【26】页,该文档可以免费在线阅读,需要了解更多关于【单片机秒表设计毕业论文 】的内容,可以使用淘豆网的站内搜索功能,选择自己适合的文档,以下文字是截取该文章内的部分文字,如需要获得完整电子版,请下载此文档到您的设备,方便您编辑和打印。:....论文说明书单片机秒表系统的设计课题名称:学生专业机电一体化班级机电0902时间指导教师电子与电气工程系...:....要近年来随着科技的飞速开展,微电子的开展可谓是日新月异,特别是单片机更是百花争艳。在电子时代的大潮流中,系列的单片机以其特有的简单、易用、易学、应用技术成熟、应用技术人员多、性价比高的优势占有8位微控制器市场大约50%以上的份额,由此可见单片机在实际生活的广泛运用。单片机控制秒表是集于单片机技术、模拟电子技术、数字技术为一体的机电一体化高科技产品,具有功耗低,平安性高,使用方便等优点。本次设计容为以AT89C51单片机为核心的秒表。设计的主要特点是计时器从00~99秒的计时,每秒自动加1,同时设置有暂停键和复位键,在任何情况下都可以暂停和复位。利用单片机定时器/计数器定时和记数的原理,结合显示电路、LED数码管以及外部中断电路来设计计时器。将软、硬件有机地结合起来,使得系统能够实现3位LED显示,显示时间为0~99秒,计时精度为1秒,能正确地进展计时。其中软件系统采用汇编语言编写程序,包括显示程序,中断效劳,外部中断效劳程序,复位程序等。本系统相对简单,指令中有较丰富的逻辑控制功能指令,能叫方便的直接操作外部的I/O设备。关键字:单片机;定时器;计数器-.--:....一、硬件简介与电路设计错误!未定义书签。、、数字电子秒表的安装与调试..................................................................、程序设计20五、完毕语21致24?参考文献25-.--:....〔FPEROM—FalshProgrammableandErasableReadOnlyMemory〕的低电压,高性能CMOS8位微处理器,俗称单片机。该器件采用ATMEL高密度非易失存储器制造技术制造,与工业标准的MCS-51?指令集和输出管脚相兼容。由于将多功图1AT89C51能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器,为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。:VCC:供电电压。-.--:....GNDP0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0口作为原码输入口,当FIASH进展校验时,P0输出原码,此时P0外部必须被拉高。P1口:P1口是一个部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。P2口:P2口为一个部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1〞时,其管脚被部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进展存取时,P2口输出地址的高八位。在给出地址“1〞时,它利用部上拉优势,当对外部八位地址数据存储器进展读写时,P2口输出其特殊功能存放器的容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。P3口:P3口管脚是8个带部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1〞后,它们被部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流〔ILL〕这是由于上拉的缘故。P3口也可作为AT89C51的一些特殊功能口,如下表所示:〔串行输入口〕〔串行输出口〕〔外部中断0〕〔外部中断1〕〔记时器0外部输入〕〔记时器1外部输入〕〔外部数据存储器写选通〕〔外部数据存储器读选通〕P3口同时为闪烁编程和编程校验接收一些控制信号。RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。ALE/PROG:当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作-.--:....然而要注意的是:每当用作外部数据存储器时,将跳过一个脉冲。如想制止ALE的输出可在SFR8EH地址上置0。此时,ALE只有在执行MOVX,MOVC指令是ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE制止,置位无效。/PSEN:外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。/EA/VPP:当/EA保持低电平时,那么在此期间外部程序存储器〔0000H-FFFFH〕,不管是否有部程序存储器。注意加密方式1时,/EA将部锁定为RESET;当/EA端保持高电平时,此间部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源〔VPP〕。XTAL1:反向振荡放大器的输入及部时钟工作电路的输入。XTAL2:来自反向振荡器的输出。:XTAL1和XTAL2分别为反向放大器的输入和输出。该反向放大器可以配置为片振荡器。石晶振荡和瓷振荡均可采用。如采用外部时钟源驱动器件,XTAL2应不接。有余输入至部时钟信号要通过一个二分频触发器,因此对外部时钟信号的脉宽无任何要求,但必须保证脉冲的上下电平要求的宽度。:整个PEROM阵列和三个锁定位的电擦除可通过正确的控制信号组合,并保持ALE管脚处于低电平10ms来完成。在芯片擦操作中,代码阵列全被写“1〞且在任何非空存储字节被重复编程以前,该操作必须被执行。此外,AT89C51设有稳态逻辑,可以在低到零频率的条件下静态逻辑,支持两种软件可选的掉电模式。在闲置模式下,CPU停顿工作。但RAM,定时器,计数器,串口和中断系统仍在工作。在掉电模式下,保存RAM的容并且冻结振荡器,制止所用其他芯片功能,直到下一个硬件复位为止。-.--:....、读取方便、精度高等优点,在计时中广泛使用。本设计用单片机组成数字电子秒表,力求构造简单、精度高为目标。本方案采用AT89C51单片机为中心器件,利用其定时器/计数器定时和计数的原理,结合硬件电路如电源电路,晶振电路,复位电路,显示电路,以及一些案件电路来设计计时器,将软、硬件结合起来。设计中包括硬件电路的设计和系统程序的设计。其硬件电路主控制采用单片机AT89C51,显示电路采用二位共阳极LED数码管显示计时时间。利用中断系统使其能实现开场、继续/暂停、复位和分/秒显示转换的功能。图2电路设计图初始状态下计时器显示00,当按下开场键时,外部中断INT0向CPU发出中断请求,CPU转去执行外部中断0效劳程序,即开启定时器T0。计时采用定时器T0中断完成,定时溢出中断周期为1s,当一处中断后向CPU发出溢出中断请求,每发出一次中断请求就对计数单元进展加一,到达1次就对秒位进展加一,-.--:....秒重新复位。在计时过程中,只要按下继续/暂停键,外部中断INT1向CPU发出中断请求,CPU转去执行外部中断1效劳程序,即关闭定时器T0,调用显示程序,实现暂停功能,同时将此次计时时间存入中间缓存区。再次按下继续/暂停键,定时器T0在次开启,调用中间缓存区的数据,秒表继续加一。当秒表计时超过99时,那么程序跳转从0开场。在秒表暂停时,按下复位开关,中间缓存区中的数据清零,程序回到开场。而在秒表暂停时,按下分/秒显示转换开关,那么将中间缓存区中的数据转换为以分秒显示的状态送入显示区。根据要求秒表设计主要实现的功能是计时和显示。因此设置了四个按键和二位数码管显示时间,四个按键分别是开场、继续/暂停、复位、分/秒显示转换。利用这四个键来实现秒表的全部功能,而二位数码管那么能显示最多99秒的计时。-.--:....3开场、继续/暂停电路图4复位电路本设计中,数码管显示的数据存放在存单元7CH-7DH中。7CH存放秒位数据,7DH存放十秒位数据,每一地址单元均为十进制BCD码。由于采用软件动态扫描实现数据显示功能,显示用十进制BCD码数据的对应段码存放在ROM表中。显示时,先取出7CH-7DH某一地址中的数据,然后查得对应的显示用段码,并从P0口输出,P2口将对应的数码管选中供电,就能显示该地址单元的数据值。按键处理方面,四个键可以采用中断的方法,也可以采用扫描的方法来识别。复位键和分/秒显示转换键主要功能在于数值复位和转换,对于时间的要求不是很严格。而开场、继续/暂停键那么是用于对时间的锁定,需要比拟准确的控制。因此可以对开场、继续/暂停键采用外部中断的方式。,通常采用液晶显示或数码管显示。一般的段式液晶屏,需要专门的驱动电路,而且液晶显示作为一种被动显示,可视性差,不适合远距离观看;对于具有驱动电路和单片机接口的液晶显示模块(字符或点阵),一般多采用并行接口,对单片机的接口要求较高,占用资源多;另外,AT89C51单片机本身无专门的液晶驱动接口。而数码管作为一种主动显示器件,具有亮度高、响应速度快、防潮防湿性能好、温度特性极性、价格廉价、易于购置等优点,而且有远距离视觉效果,很适合夜间或是远距离操作。因此,本设计的显示电路采用8段数码管作为显示介质。数码管显示可以分为静态显示和动态显示两种。本设计采用二位数码管显示时间,动/静态显示皆可。那么本设计应任务要求选用动态显示。-.--:....5显示电路根本原理图动态显示是一位一位地轮流点亮各位数码管,这种逐位点亮显示器的方式称为位扫描。通常各位数码管的段选线相应并联在一起,由一个8位的I/O口控制。动态方式显示时,各数码管分时轮流选通,要使其稳定显示必须采用扫描方式,即在某一时刻只能选通一位数码管,并送出相应的段码,在另一时刻选通另一位数码管,并送出相应的段码,依此规律循环,即可使各位数码管显示将要显示的字符,虽然这些字符是在不同的时刻分别显示,但由于人眼存在视觉暂留效应,只要每位显示间隔足够短就可以给人同时显示的感觉。数码显示管分为共阳数码管和共阴数码管两种。共阳极数码管的8个发光二极管的阳极〔二极管正端〕连接在一起,如图6〔c〕,通常,公共阳极接高电平〔一般接电源〕,其它管脚接段驱动电路输出端。当某段驱动电路的输出端为低电平时,那么该端所连接的字段导通并点亮,根据发光字段的不同组合可显示出各种数字或字符。此时,要求段驱动电路能吸收额定的段导通电流,还需根据外接电源及额定段导通电流来确定相应的限流电阻。共阴极数码管的8个发光二极管的阴极〔二极管负端〕连接在一起,如图〔b〕,通常,公共阴极接低电平〔一般接地〕,其它管脚接段驱动电路输出端,当某段-.--:....那么该端所连接的字段导通并点亮,根据发光字段的不同组合可显示出各种数字或字符。此时,要求段驱动电路能提供额定的段导通电流,还需根据外接电源及额定段导通电流来确定相应的限流电阻。图6〔a〕数码管引脚图〔b〕共阳极部构造图〔c〕共阴极部构造图显示电路由二位数码管组成,采用动态显示方式,有8位段控制端和2位位控制端,八位段控制接P0口,~、b、c、d、e、f、g、dp显示,AT89C51的P0口没有集成上拉电阻,高电平的驱动能力很弱,所以需要接上拉电阻来提高P0的高电平驱动能力。~,NPN三极管9013做为位控制端的开关,~,与其相对应的三极管就导通,对应的数码管导通显示。本设计采用共阳极数码显示管做显示电路,由于采用的是共阳的数码显示管,所以只要数码管的a、b、c、d、e、f、g、h引脚为低电平,那么其对应的-.--:....~。,R3MOVDPTR,#TABMOVCA,A+DPTRMOVP0,AMOVA,R4MOVDPTR,#TABMOVCA,A+DPTRMOVP2,ARETTAB:DB0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H由于数码管是有P0口来驱动,它部没有上拉电阻,作为输出口时驱动能力比拟弱,不能点亮数码显示管,因此P0口必须接上拉电阻来提高驱动能力。电源供电电压为+5V,当上拉电阻选用220Ω电阻时灌电流为22mA。不会损坏单片机的I/O口,同时也可以为数码显示管起到限制电流的保护作用。晶振电路和电源电路的设计系统总电路除以上设计的显示电路,按键电路和复位电路组成外,其次还剩-.--:....再将单片机与以上各局部电路合理的连接就组成了系统总电路。单片机为主电路的核心局部,各个电路均和单片机相连接,由单片机统筹和协调各个电路的运行工作。AT89C51单片机提供了XTAL1和XTAL2两个专用引脚接晶振电路,因此只要将晶振电路接到两个专用引脚即可为单片机提供时钟脉冲,但在焊接晶振电路时要尽量使晶振电路靠近单片机,这样可以为单片机提供稳定的始终脉冲。图7晶振电路在这个系统中电源采用由7805构成的稳压电路,它可以提供非常恒定的+5V电压,不会因为电压不稳儿引入新的干扰,保证系统更加稳定运行。通过以上设计已经将各局部电路与单片机有机的结合到一起,硬件局部的设计以大功告成,剩下的局部就是对单片机的编程,使单片机按程序运行,实现数字电子秒表的全部功能。二、软件设计程序设计思想本设计采用了汇编语言编写,汇编语言由于采用了助记符号来编写程序,比用机器语言的二进制代码编程要方便些,在一定程度上简化了编程过程。汇编语-.--:....而且助记符与指令代码一一对应,根本保存了机器语言的灵活性。使用汇编语言能面向机器并较好地发挥机器的特性,得到质量较高的程序。汇编语言的特点:(1).面向机器的低级语言,通常是为特定的计算机或系列计算机专门设计的。(2).保持了机器语言的优点,具有直接和简捷的特点。(3).可有效地访问、控制计算机的各种硬件设备,如磁盘、存储器、CPU、I/O端口等。(4).目标代码简短,占用存少,执行速度快,是高效的程序设计语言。(5).经常与高级语言配合使用,应用十分广泛。在程序设计过程中,为了有效地完成任务,把所要完成的任务精心的分割成假设干个相互独立但相互又仍可有联系的任务模块,这些任务模块使得任务变得相对单纯,对外的数据交换相对简单,容易编写,容易检测,容易阅读和维护。这种程序设计思想称为模块化程序设计思想。模块化构造程序的设计,可以使系统软件便于调试与优化,也使其他人更好地理解和阅读系统的程序设计。因此,本医院病床呼叫系统在软件的设计上,运用了模块化程序的构造对软件进展设计,使得程序变得更加直观易懂。程序的主要模块有:主程序、显示程序、定时溢出中断效劳程序、外部中断效劳程序。系统资源的分配本设计系统所用到的单片机端口数比拟多,所以在这里将对数字电子秒表的硬件资源的大概分配加以说明。片RAM的分配、各功能键的定义以及各端口的分配。-7DH1s-99s位显示存放区6CH-6DH1s-99s位中间存放区-.--:..../、定时中断效劳程序、外部中断0效劳程序和外部中断1效劳程序组成。其中主程序是整个程序的主体。可以对各个中断程序进展调用。协调各个子程序之间的联系。系统〔上电〕复位后,进入主程序。,包括设置各入口地址、中断的开启、对各个数据缓存区清“0〞、赋定时器初值,初-.--:....就进入数码管显示程序。数码管显示程序对显示缓存区的数值进展调用并在数码管上进展动态显示。查询复位键是否按下,当复位键按下后,程序返回开场,重新对系统进展初始化。图8主程序流程图在主程序中还进展了赋存放区的初始值、设置定时器初值以及开启外部中断等操作,当定时时间到后就转去执行定时中断程序。当外部中断有请求那么去执行外部中断效劳程序。并在执行完后返回主程序。-.--:....现在方案中采用了三个中断,外部中断,INT1和定时中断T0。CPU在响应中断时,先处理高级中断,在处理低级中断,假设有多个同级中断时,那么按自然优先顺序处理。例如当CPU正在处理一个中断申请时,有出现了另一个优先级比它高的中断请求,这是,CPU就暂停终止对当前优先级较低的中断源的效劳,转去响应优先级比它高的中断请求,并为其效劳。待效劳完毕,再继续执行原来较低级的中断效劳程序。而当CPU为级别高的终端效劳程序效劳时,如果级别低的中断发出中断请求,此时CPU是不会响应的,所以为了防止开场和暂停两个按键中的一个出现没有响应的情况,在进展程序编辑时要注意对中断的使用,防止出现中断的嵌套。,合理分配中断对本设计的实现是至关重要的。另外由于数字式电子秒表的最小精度位1ms,属于高精度电子秒表。定时器T0的定时周期也为1ms,为了使电子秒表暂停键按下后CPU能马上去响应中断程序,必须将暂停的外部中断级别高于定时计数器的中断级别。防止出现CPU执行完定时溢出中断程序后再响应外部中断程序,影响计时精度。AT89C51的自然优先级顺序排列如下:中断源最高外部中断0定时/计数器0溢出中断外部中断1定时/计数器1溢出中断串行口中断最低数字式秒表中的两个按键采用了中断实现功能。开场采用外部中断INT0,-.--:....。另外程序中还用到了定时/计数器0溢出中断进展计时。依据设计要求,暂停的外部中断INT1中断级别最高,计时的定时/计数器0溢出中断次之,开场的外部中断INT0级别最低。:。,CPU转向外部中断0效劳程序执行,停顿定时器。另外将当前显示的时间进展一次存储,存进中间存放区。最后中断返回。。,CPU转向外部中断1效劳程序执行,启动定时器。另外进展二次存储,将之前进展一次存储的数码管显示数据存入最终缓存区,防止下次计时暂停时一次存储将数据掩盖,从而起到保护数据的作用。二次存储后就中断返回。在对定时器赋初值时将单片机需要执行的语句所花的时间加上,这样就能使数字电子秒表的误差到达最小。定时器T0子程序设计-.--:....9定时器T0子程序图框三、,它可以仿真、分析(SPICE)各种模拟器件和集成电路。该软件的主要特点总结后有以下四点:①实现了单片机仿真和SPICE电路仿真相结合的功能。②支持目前主流单片机系统的仿真。③提供了软件调试功能,并可以与WAVE联合仿真调试。④具有强大的原理图绘制功能。总之,该软件是一款集单片机和SPICE分析于一身的仿真软件,功能极其强大。在电子领域中也起到了很大的作用,它的出现仿真不需要先焊接电路,可以先仿真调试通过后在焊电路,节省了不少在硬件调试上所花的时间。ProteusISIS的工作界面是一种标准的Windows界面。它包括标题栏、主菜单、状态栏、标准工具栏、绘图工具栏、对象选择按钮、预览对象方位控制按钮、仿真进程控制按钮、预览窗口、对象选择器窗口、图形编辑窗口等十几个工具,方便了使用者的使用。-.--:....Protel99se绘制原理图的操作根本一样,在这里就不再作赘述。下面拿本设计中的一个仿真例子作简述说明。运行ProteusSISI后,绘制病床呼叫系统的原理图。首先翻开已经画好的proteusDSN文件,双击图中的AT89S52芯片,就弹出一个窗口,在ProgramFile项过路径选择在WAVE中生成的HEX文件,双击选中后确定,这样仿真图中的AT89S52芯片就已经读取了本设计中的HEX文件。单击“三角形按钮〞进展仿真。通过对仿真结果的观察来对程序进展修改,最终使程序到达设计要求。硬件的安装与调试按照之前设计好的数字电子秒表原理图,详细计算系统中各个元件的参数,选择相应器件,制作实际电路板。由于考虑到万能板大小的问题及元件之间连线的方便,在焊接元器件前必须考虑元件的布局然后进展实际操作。制作好的电路板可以用万用表〔200欧姆档〕的红、黑表笔测试电路板的每条走线,当其电阻非常小时,证明走线没有断开,当其电阻很大时,证明该条走线断了,应该重新走线,使电路板在电气上得到正确地连接。选用万用表的20K欧姆档,检测电路中是否存在短路。因为系统采用的是共阴极数码管作为显示电路,必须确保数码管的公共端接的是低电平。。实际中,因为各种原因导致系统时钟不正常而出现系统无常运行的情况时有,因此系统时钟是否振是通电检查的首要环节。在系统通电的状况下,用万用表的直流电压档-.--:....〕,分别测量XTAL1和XTAL2引脚的电压,看是否正常,在调试过程中,,。。如果复位引脚始终为高电平,系统将始终处于复位状态;如果始终为低电平,不能产生复位所需的高电平信号脉冲,那么系统也可能无常工作。单片机正常工作时,RST复位引脚应为0V,按下复位按键时,复位引脚为高电平+5V左右。,我们可以通过观察显示电路的显示结果观察系统能否正常运行。当显示电路按照电路图焊接好后,用万用表的测二极管档位,将黑表笔接共阴数码管的公共段,然后将红表笔接数码管的各段,当数码管的段能正常显示,说明各点焊接正常。四、程序设计原程序:ORG0000HAJMPMAINORG0003HAJMPX0_INTORG000BHAJMPT0_INTORG0013HAJMPX1_INTMAIN:MOVTMOD,#01H;T0定时方式1MOVTH0,#(65536-50000)/256;50ms12MHz-.--:....MOVTL0,#(65536-50000)MOD256;SETBTR0SETBET0;SETBEX0SETBEX1SETBEA;开中断MOVR1,#0;0~99秒计数MOVR2,#0;,#1;50ms计数MOVP0,#0C0H;,#0C0HMOVp1,#0C0HLOOP:SJMPLOOP;-----------------------------------------------------------DELAY:;,#0DJNZR4,$DJNZR4,$RET;-----------------------------------------------------------X0_INT:;启动/停顿CPLF0RETI;-----------------------------------------------------------X1_INT:;清零MOVR1,#0MOVP0,#0C0HMOVP2,#0C0HMOVp1,#0C0HRETI-.--:....T0_INT:;,#(65536-50000)MOD256;MOVTH0,#(65536-50000)/256;50ms12MHzDJNZR7,T0_END;,#2;#20JNBF0,T0_ENDMOVa,r2adda,#1daaANLa,#0fhMOVr2,aJNZDISPMOVA,R1ADDA,#1DAAMOVR1,ADISP:MOVa,r2ANLa,#0fhMOVCa,a+DPTR;查出段码MOVp1,a;,R1ANLA,#0FHMOVDPTR,#TABMOVCA,A+DPTR;查出段码MOVP2,A;显示个位MOVA,R1SWAPAANLA,#0FHMOVCA,A+DPTR;查出段码-.--:....MOVP0,A;T0_END:RETI;-----------------------------------------------------------TAB:DB0c0H,0f9H,0a4H,0b0H,99H,92H,82H,0f8H,80H,〔SinglechipMicroputer〕和接口外围电路组成的时钟和秒表双重功能的电子秒表电路。整个电路由硬件电路和软件程序两局部组成。硬件电路使用元件少,电路构造简单,功能强,在文中有很多地方表达的并不是很清楚,因此用图示出以便更好的了解;软件程序设计构造合理,思路清晰,利用中断效劳程序对各种事件进展处理,提高微处理器的工作效率。硬件电路由单片机AT89C51(微处理器CPU)、接口芯片8279、8位LED数码管显示电路、按键电路等构成。系统总电路由以上设计的显示电路,时钟电路,按键电路和复位电路组成,只要将单片机与以上各局部电路合理的连接就组成了系统总电路。AT89C52单片-.--:....各个