单片机电子时钟设计_第1页
单片机电子时钟设计_第2页
单片机电子时钟设计_第3页
单片机电子时钟设计_第4页
单片机电子时钟设计_第5页
已阅读5页,还剩18页未读 继续免费阅读

下载本文档

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

文档简介

PAGEPAGE12绪论 单片机在多功能数字电子钟中的应用已是非常普遍,人们对电子时钟的功能及工作顺序都已非常熟悉了,但是却很少知道它的内部结构以及工作原理。由单片机作为电子时钟的核心控制器,可以通过它的时钟信号来实现计时功能,将时间数据由单片机输出,利用显示器将时间显示出来。通过键盘可以进行时间的设定。输出设备显示器可以用液晶显示技术或数码管来显示技术。本系统利用单片机实现具有计时、校时等功能的数字电子时钟,是以单片机AT89C51为核心元件同时采用LED数码管显示器动态显示“时”,“分”,“秒”的现代计时装置。与传统机械表相比,它具有走时精确,显示直观等特点。另外具有校时功能,利用单片机实现的数字时钟具有编程灵活,便于功能的扩充等优点第一章概述1.1课题研究的目的和意义数字钟已成为人们日常生活中必不可少的必需品,广泛用于个人家庭以及办公室等公共场所,给人们的生活、学习、工作、娱乐带来极大的方便。由于电子集成电路技术的发展和采用了先进的石英技术,使电子钟具有走时准确、性能稳定、携带方便等优点,它还用于计时、自动报时及自动控制等各个领域,因此进行电子钟的设计是必要的。尽管目前市场上已有现成的电子钟集成电路芯片出售,价格便宜、使用也方便,但鉴于单片机定时器的功能也可以完成电子钟电路的设计,因此进行电子钟的设计是可行的。在这里我们将已学过的比较零散的数字电路和单片机的知识有机的、系统的联系、组织起来应用于实际,来培养我们的综合分析和设计电路,写程序,调试电路、程序的能力。单片机具有体积小、功能强、可靠性高、价格低廉等一系列优点,不仅已成为工业测控领域普遍采用的智能化控制工具,而且已渗入到人们工作和和生活的各个角落,有力地推动了各行业的技术改造和产品的更新换代,应用前景广阔。1.2国内外研究的现状及发展趋势从单片机电子时钟近年的发展趋势来看,正朝着多层次用户、多品种、多规格、高精度、小体积、低能耗等方面发展。在这种趋势下,时钟的数字化,智能化已经成为现代时钟生产研究的主导设计方向。带有时钟功能的电子产品和电子设备进年来广泛地出现在国内外市场中,例如奥运会倒计时显示屏、铁路安全显示屏、生产线看板、体育比赛记时屏、大型室外高亮度时钟等,这类产品覆盖银行、医院、地铁车站、体育运动、电视台、监控系统、高大建筑物等行业。作为一种人机接口方式,语音比显示屏,鼠标键盘等设备更易于使用。而在设计里加上语音提示、音乐或者其他语音功能,还使得设计显得既人性化又有趣,不但能提高开发者的兴趣和积极性,同时也能让设计作品与众不同,从而得到了各界领域的广泛应用所以对语音的研究有很大的实际意义。2.2实现时钟计时的基本方法利用MCS-51系列单片机的可编程定时/计数器、中断系统来实现时钟计数。(1)计数初值计算:把定时器设为工作方式1,定时时间为50ms,则计数溢出20次即得时钟计时最小单位1s。定时器方式1为16位定时/计数器工作方式,用于定时工作方式时,计数时间为:T=(216-T0初值)×振荡周期×12假设使用T/C0,方式1,50ms定时,晶振频率fosc=12MHz。则初值X满足:(216-X)×1/12MHz×12×1μs=50000μsX=15536D→0011110010110000B→3CB0H(2)采用中断方式进行溢出次数累计,计满20次则为秒计时(1秒);(3)从秒到分和从分到时的计时是通过累加和数值比较实现。2.3电子钟的时间显示电子钟的时钟时间要在六位数码管上进行显示,则要在内部RAM中设置缓存地址单元。显示寄存器单元位:32H31H30H时显示寄存器单元位分显示寄存器单元位秒显示寄存器单元位2.4电子钟的时间调整时间调整:用6个按键S1、S2、S3、S4、S5、S6,通过P1.0~P1.5口将调整信号输入单片机,再通过程序控制来完成时间调整的功能。2.5总体方案介绍2.5.1计时方案利用AT89C51单片机内部的定时/计数器进行中断时,配合软件延时实现时、分、秒的计时。该方案节省硬件成本,且能使读者在定时/计数器的使用、中断及程序设计方面得到锻炼与提高,对单片机的指令系统能有更深入的了解,从而对学好单片机技术这门课程起到一定的提升2.5.2控制方案AT89C51的P0口外接6位LED显示数码管的段选信号,P2口外接6位LED显示数码管的位选信号,P1口外接6个调整时、分、秒加减的按键2.5(1)AT89C51是一种低功耗,高性能的CMOS8位微型计算机。片内有4KBFLASH(EPROM)可系统编程的只读存储器,该器件采用ATMEL公司的高密度非易失性存储器技术制造,与工业上标准的8031、8051和8751的指令系统及引脚兼容,它集Flash程序存储器既可在线编程(ISP)也可用传统方法进行编程及通用8

位微处理器于单片芯片中,

片内Flash集成在一个芯片上,可用与解决复杂的问题,且成本较低。简易电子钟的功能不复杂,AT89C51

提供以下标准功能:4k

字节Flash

闪速存储器,128字节内部RAM,32

个I/O

口线,看门狗(WDT),两个数据指针,两个16

位定时/计数器,一个5

向量两级中断结构,一个全双工串行通信口,片内振荡器及时钟电路。同时,AT89(2)六位LED显示数码管由于考虑到充分利用DJ-598K试验仪的硬件资源,所以使用DJ-598K试验仪的六位数码管作为显示器,其是带有驱动器的六位数码显示管,如图2-2。图2-2显示数码管实形图图2-3显示数码管模块电路图数据插座:JS__LED位选扫描线;JLED__LED段选码。第三章系统硬件电路设计根据以上的电子时钟的设计要求可以分为以下的几个硬件电路模块:单片机模块、数码显示模块与按键模块,模块之间的关系图如下面得方框电路图3-1所示。图3-1硬件电路方框图3.1单片机模块设计3.1.1芯片分析MCS-51系列单片机中的8031、8051及8751均采用40Pin封装的双列直接DIP结构,AT89C51单片机引脚图3-2所示:图3-2AT89C51MCS-51单片机是标准的40引脚双列直插式集成电路芯片,其各引脚功能如下:VCC:+5V电源。VSS:接地。RST:复位信号。当输入的复位信号延续两个机器周期以上的高电平时即为有效,用完成单片机的复位初始化操作。XTAL1和XTAL2:外接晶体引线端。当使用芯片内部时钟时,此二引线端用于外接石英晶体和微调电容;当使用外部时钟时,用于接外部时钟脉冲信号。P0口:P0口为一个8位漏极开路双向I/O口,当作输出口使用时,必须接上拉电阻才能有高电平输出;当作输入口使用时,必须先向电路中的锁存器写入“1”,使FET截止,以避免锁存器为“0P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,它不再需要多路转接电路MUX;因此它作为输出口使用时,无需再外接上拉电阻,当作为输入口使用时,同样也需先向其锁存器写“1”,使输出驱动电路的FETP2口:P2口电路比P1口电路多了一个多路转接电路MUX,这又正好与P0口一样。P2口可以作为通用的I/O口使用,这时多路转接电路开关倒向锁丰存器Q端。P3口:P3口特点在于,为适应引脚信号第二功能的需要,增加了第二功能控制逻辑。当作为I/O口使用时,第二功能信号引线应保持高电平,与非门开通,以维持从锁存器到输出端数据输出通路的畅通。当输出第二功能信号时,该位应应置“1”,使与非门对第二功能表所示。3.1.2晶振电路图3-2所示为时钟电路原理图,在AT89C51芯片内部有一个高增益反相放大器,其输入端为芯片引脚XTAL1,输出端为引脚XTAL2。而在芯片内部,XTAL1和XTAL2之间跨接晶体振荡器和微调电容,从而构成一个稳定的自激振荡器。时钟电路产生的振荡脉冲经过触发器进行二分频之后,才成为单片机的时钟脉图3-2晶振电路3.1.3单片机复位的条件是:必须使RST/VPD或RST引(9)加上持续两个机器周期(即24个振荡周期)的高电平。例如,若时钟频率为12MHz,每机器周期为1μs,则只需2μs以上时间的高电平,在RST引脚出现高电平后的第二个机器周期执行复位。单片机常见的复位如图所示。电路为上电复位电路,它是利用电容充电来实现的。在接电瞬间,RESET端的电位与VCC相同,随着充电电流的减少,RESET的电位逐渐下降。只要保证RESET为高电平的时间大于两个机器周期,便能正常复位。图3-3复位电路3.2数码显示模块设计系统采用动态显示方式,动态显示通常都是采用动态扫描的方法进行显示,即循环点亮每一个数码管,这样虽然在任何时刻都只有一位数码管被点亮,但由于人眼存在视觉残留效应,只要每位数码管间隔时间足够短,就可以给人以同时显示的感觉。图3-4数码显示电路3.3按键模块设计图3-5为按键模块电路原理图,时钟调整按键,分钟调整按键,秒钟调整按键。图3-5按键模块电路图四、系统软件设计4.1系统总体流程图基本的程序流程应该是:程序执行,先通过初始化各个寄存器,在主程序中经过扫描按键来检测各个时间按键是否有动作,从而决定是否设定参数来执行相应功能的程序,进而在数码管上显示,若有就储存并修改相关的的时间寄存器的值,若没有就继续检测。在计时子程序中将各时间寄存器的值逐个加1,每加一次就要检查是否已超过显示的上限值,这样在后面就便于处理,在扫描显示子程序中,将扫描位数指针与数字字码表首地址相加,从而得到相应的显示数据;然后按照显示的位数将数据从P0和P2口输出到数码管上去显示,当然还有定时中断子程序,在这里,它实现计时1S的时间延时。图4-1系统总体流程图4.2源程序代码 S_SET BIT P1.0 ;秒+1端口 SO_SET BIT P1.1 ;秒-1端口 M_SET BIT P1.2 ;分+1端口 MO_SET BIT P1.3 ;分-1端口 H_SET BIT P1.4 ;时+1端口 HO_SET BIT P1.5 ;时-1端口 S EQU 30H ;秒显示寄存器单元位 M EQU 31H ;分显示寄存器单元位 H EQU 32H ;时显示寄存器单元位 ORG 0000H LJMP START ORG 000FH LJMP INT_T0 ORG 0100HSTART: MOV DPTR,#TAB MOV H,#12 MOV M,#0 MOV S,#0 MOV R0,#0 MOV TMOD,#01H MOV TH0,#3CH MOV TL0,#0B0H SETB TR0 SETB ET0 SETB EAS1: ACALL DEL JB S_SET,A1 INC S MOV A,S CJNE A,#60,J1 MOV S,#0 LJMP K1S2: ACALL DEL JB SO_SET,A1 DEC S MOV A,S CJNE A,#00,J2 MOV S,#0 LJMP A1S3: ACALL DEL JB M_SET,A1K1: INC M MOV A,M CJNE A,#60,J3 MOV M,#0 LJMP K2S4: ACALL DEL JB MO_SET,A1 DEC M MOV A,M CJNE A,#00,J4 MOV M,#0 LJMP A1S5: ACALL DEL JB H_SET,A1K2: INC H MOV A,H CJNE A,#24,J5 MOV S,#0 MOV M,#0 MOV H,#0 LJMP A1S6: ACALL DEL JB HO_SET,A1 DEC H MOV A,H CJNE A,#00,J6 MOV H,#0 LJMP A1A1: ACALL DISPLAY JNB S_SET,S1 JNB SO_SET,S2 JNB M_SET,S3 JNB MO_SET,S4 JNB H_SET,S5 JNB HO_SET,S6 LJMP A1J1: JB S_SET,A1 ACALL DISPLAY SJMP J1J2: JB SO_SET,A1 ACALL DISPLAY SJMP J2J3: JB M_SET,A1 ACALL DISPLAY SJMP J3J4: JB MO_SET,A1 ACALL DISPLAY SJMP J4J5: JB H_SET,A1 ACALL DISPLAY SJMP J5J6: JB HO_SET,A1 ACALL DISPLAY SJMP J6INT_T0: MOV TH0,#3CH ;设置定时初值50ms MOV TL0,#0B0H INC R0 MOV A,R0 CJNE A,#20,RETUNE ;设置中断20次 INC S MOV R0,#0 MOV A,S CJNE A,#60,RETUNE INC M MOV S,#0 MOV A,M CJNE A,#60,RETUNE INC H MOV M,#0 MOV A,H CJNE A,#24,RETUNE MOV H,#0 MOV M,#0 MOV S,#0 MOV R0,#0RETUNE:RETIDISPLAY:MOV A,S MOV B,#10 DIV AB CLR P2.6 ;秒片选H位 MOVC A,@A+DPTR CPL A MOV P0,A ;段选信号输出口 ACALL DEL SETB P2.6 MOV A,B CLR P2.7 ;秒片选L位 MOVC A,@A+DPTR CPL A MOV P0,A ACALL DEL SETB P2.7 MOV A,M MOV B,#10 DIV AB CLR P2.3 ;分片选H位 MOVC A,@A+DPTR CPL A MOV P0,A ACALL DEL SETB P2.3 MOV A,B CLR P2.4 ;分片选L位 MOVC A,@A+DPTR CPL A MOV P0,A ACALL DEL SETB P2.4 MOV A,H MOV B,#10 DIV AB CLR P2.0 ;时片选H位 MOVC A,@A+DPTR CPL A MOV P0,A ACALL DEL SETB P2.0 MOV A,B CLR P2.1 ;时片选L位 MOVC A,@A+DPTR CPL A MOV P0,A ACALL DEL SETB P2.1 RETTAB: DB 03H,9FH,25H,0DH,99H,49H,41H,1FH,01H,09H ;数字字码表DEL: MOV R6,#10LOOP1: MOV R7,#100LOOP2: DJNZ R7,LOOP2 DJNZ R6,LOOP1 RET END五、系统仿真与测试5.1系统仿真运用proteus软件进行仿真现在proteus软件中建立一个新的文件,再根据自己的要求选择所需的器件,把器件进行适当的排位后进行连接,连接后运行软件进行仿真。如图5-1。图5-1系统仿真图5.2实验接线此接线以在DJ-598K试验仪上为例,因为课题要求利用DJ-598K试验仪的硬件资源,又由于DJ-598K试验仪内关于电源线、地线、晶振、复位等部分接线均以接好,且最终也要在DJ-598K试验仪上实现系统。接线1接到接到接到秒加P1.0P0.0JLED.7P2.JS.0秒减P1.1P0.1JLED.6P2.JS.1分加P1.2P0.2JLED.5分减P1.3P0.3JLED.4P2.JS.2时加P1.4P0.4JLED.3P2.JS.3时减P1.5P0.5JLED.2P0.6JLED.1P2.JS.4P0.7JLED.0P2.JS.5接线2设置开关设置设置JK外接CPU卡上拨码开关K1、K8ONuVision中的debugUSE:KeilMonitor-51DriverPort:COM1口KB651K2、K3、K4、K5、K6、K7OFFBandrate:57600仿真实验接线,则按系统仿真图进行线路的连接。5.3实验测试电子时钟主要的设计要求是能够实现时钟的一般功能,以及包括时间的调整功能,这个基于单片机的电子时钟基本上实现了上述功能,能够通过时间调整电路对时间进行调整以及时间计时。图5-2为23:45:10的仿真图:图5-223:45:10时刻的仿真效果总结单片机作为我们主要的专业课程之一,我觉得单片机课程设计很有必要,而且很有意义。但当拿到题目时,确实不知道怎么着手,有些迷茫,但想到谢永宁老师在上课时,给我们很详细的开发、分析过一个工业实例,在这个案例的启发、帮助下,历时一个星期,解决了一个又一个难题,终于完成本次课题任务。通过本课程设计培养我的系统设计能力,使我得到了能力上的训练,培养和提高我以下方面的能力:(1)、调查研究、分析问题的能力(2)、使用设计手册、技术规范的能力(3)、查阅中外文献的能力(4)、制定设计方案的能力(5)、计算机应用的能力(6)、设计计算和绘图的能力(7)、技术经济指示的分析能力(8)、语言文字表达的能力在这次课程设计中,运用到了很多以前的专业知识,虽然过去从未独立应用过它们,但在学习的过程中带着问题去学,我发现效率很高,这是我做这次课程设计的一大收获。另外,要做好一个课程设计,就必须做到

温馨提示

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

评论

0/150

提交评论