1、 目 录一、设计正文 (1)二、附录1. 设计任务书(32)2. 设计中期检查报告(34)3. 指导教师指导记录表(35)4. 设计结题报告(36)5. 成绩评定及答辩评议表(37)6. 设计答辩过程记录(40)基于Proteus软件的单片机数字时钟系统设计与仿真摘 要:近年来随着计算机在社会领域的渗透和大规模集成电路的发展,单片机的应用正在不断地走向深入,由于它具有功能强,体积小,功耗低,价格便宜,工作可靠,使用方便等特点,因此越来越广泛地应用各个领域. 本文的电子钟系统是以单片机(AT89C51)为核心,时钟芯片DS1302、数码管显示驱动芯片MAX7219等元器件组成。具体介绍应用Pro
2、teus的ISIS软件进行单片机系统的电子钟设计与仿真的实现方法。该方法既能准确验证所设计的系统是否满足技术要求,又能提高系统设计的效率和质量,降低开发成本,具有推广价值。关键词:单片机、时钟芯片、数码管显示驱动芯片、Proteus、电子钟Design and Simulation Of electronic clock Based onProteus Software SystemAbstract :In recent years, with computers in the infiltration and the development of large-scale integrated
3、 circuits. SCM application is steadily deepening, as it has strong function, small size, low power dissipation, low prices, reliable, easy to use features, it is particularly suited to and control of the system, increasingly widely used in various fields.This article describes an electronic bell sys
4、tem is single-chip microcomputer (AT89C51) as the core, the clock chip DS1302, LED display driver chip components, such as MAX7219 component.Describes the application of Proteuss ISIS software of the electronic single-chip system clock to achieve the design and simulation methods in details.The meth
5、od can not only test the property of the system precisely,but also improve development efficiency and reduce development cost,which values in popularity.Key words: AT89C51、DS1302、MAX7219、Proteus、 electronics clock目 录1 绪论- 1 -1.1引 言- 1 -1.2 Proteus软件简介- 1 -2系统设计- 3 -2.1电子钟系统硬件组成- 3 -2.2 AT89C51单片机简介-
6、 4 -2.2.1.主要特性- 5 -2.2.2.管脚说明- 5 -2.3实时时钟电路DS1302工作原理- 8 -2.3.1 DS1302的结构及工作原理- 8 -2.3.3 DS1302的寄存器- 9 -2.4 MAX7219工作原理简介- 10 -2.4.1.引脚分配及功能- 11 -2.4.2.寄存器介绍- 12 -2.5 数码管介绍- 14 -2.5.1数码管的分类- 14 -2.5.2 数码管的应用- 15 -2.5.6 数码管使用的电流与电压- 15 -2.6 电子时钟系统设计流程- 16 -3硬件电路设计- 17 -3.1 电路原理图设计- 17 -3.2 Proteus 电路
7、图设计- 18 -4软件设计- 19 -4.1 程序流程图设计- 19 -4.2 源程序设计- 19 -4.3 KeilC51进行程序调试- 25 -5.系统调试与仿真- 27 -5.1 Proteus中Hex 文件选择- 27 -5.2 Proteus进行电子钟系统仿真- 28 -结束语- 29 -参考文献- 30 -谢 辞- 31 -V1 绪论1.1引 言随着半导体技术的飞速发展,以及移动通信、网络技术、多媒体技术在嵌入式系统设计中的应用,单片机从4位、8位、16位到32位,其发展历程一直受到广大电子爱好者的极大关注。单片机功能越来越强大,价格却不断下降的优势无疑成为嵌入式系统方案设计的首
8、选,同时单片机应用领域的扩大也使得更多人加入到基于单片机系统的开发行列中,推动着单片机技术的创新进步。然而传统的单片机系统开发除了需要购置诸如仿真器、编程器、示波器等价格不菲的电子设备外,开发过程也较繁琐。来自英国Labcenter Electronics公司的Proteus软件很好地诠释了利用现代EDA工具方便快捷开发单片机系统的优势。它包括PROTEUS VSM(Virtual System Modelling)、PROTEUS PCB DESIGN两大组成部分,在PC机上就能实现原理图电路设计、电路分析与仿真、单片机代码级调试与仿真、系统测试与功能验证以及形成PCB文件的完整嵌入式系统设
9、计与研发过程。单片机系统作为一种典型的嵌入式系统,其系统设计包括硬件电路设计和软件编程设计两个方面, 其调试过程一般分为软件调试、硬件测试、系统调试3个过程。如果采用单片机系统的虚拟仿真软件Proteus,则不用制作具体的电路板也能够完成以上工作。1.2 Proteus软件简介PROTEUS软件由Labcenter公司开发,是目前世界上最先进、最完整的嵌入式系统设计与仿真平台,可以实现数字电路、模拟电路及微控制器系统与外设的混合电路系统的电路仿真、软件仿真、系统协同仿真和PCB设计等功能,是目前唯一能够对各种处理器进行实时仿真、调试与测试的EDA工具。微控制器系统相关的仿真需建立编译和调试环境
10、,可选择Keil C51uVision2 软件。该软件支持众多不同公司的芯片,集编辑、编译和程序仿真等于一体,同时还支持PLM、汇编和C语言的程序设计。它的界面友好易学,在调试程序、软件仿真方面有很强大的功能。 其革命性的功能是:将电路仿真和微处理器仿真进行协同,直接在基于原理图的虚拟原型上进行处理器编程调试,并进行功能验证,通过动态器件如电机、LED、LCD、开关等,实时看到运行后的输入、输出的效果,配合系统配置的虚拟仪器如示波器、逻辑分析仪等, Proteus为我们建立了完备的电子设计开发环境。2系统设计2.1电子钟系统硬件组成电子钟系统硬件主要由AT89C51单片机、时钟芯片DS1302
11、、数码管显示驱动芯片MAX7219等元器件组成。AT89C51是一种带4K字节闪烁可编程可擦除只读存储器的低电压,高性能CMOS8位微处理器,俗称单片机DS1302 是美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟电路,它可以对年、月、日、周日、时、分、秒进行计时。MAX7219是MAXIM公司生产的串行输入/输出共阴极数码管显示驱动芯片。图1 电子钟系统硬件电路组成框图2.2 AT89C51单片机简介AT89C51是一种带4K字节闪烁可编程可擦除只读存储器(FPEROMFalsh Programmable and Erasable Read Only Memory)的低电压
12、,高性能CMOS8位微处理器,俗称单片机。AT89C2051是一种带2K字节闪烁可编程可擦除只读存储器的单片机。单片机的可擦除只读存储器可以反复擦除100次。该器件采用ATMEL高密度非易失存储器制造技术制造,与工业标准的MCS-51指令集和输出管脚相兼容。由于将多功能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器,AT89C2051是它的一种精简版本。AT89C单片机为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。图2 AT89C51单片机2.2.1.主要特性与MCS-51 兼容 4K字节可编程闪烁存储器 寿命:1000写/擦循环 数据保留时间:10
13、年 全静态工作:0Hz-24Hz 三级程序存储器锁定 128*8位内部RAM 32可编程I/O线 两个16位定时器/计数器 5个中断源 可编程串行通道 低功耗的闲置和掉电模式 片内振荡器和时钟电路 2.2.2.管脚说明VCC:供电电压。GND:接地。P0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,P1
14、口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。 P2口:P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P
15、2口输出其特殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。P3口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。P3口也可作为AT89C51的一些特殊功能口,如下表所示:P3.0 RXD串行输入口P3.1 TXD串行输出口P3.2 /INT0外部中断0P3.3 /INT1外部中断1P3.4 T0记时器0外部输入P3.6 /WR外部数据存储器写选通P3.7 /RD外部数据存储器读选通表1.1 P3口作
16、为AT89C51的一些特殊功能口RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。ALE/PROG:当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ALE脉冲。如想禁止ALE的输出可在SFR8EH地址上置0。此时, ALE只有在执行MOVX,MOVC指令是ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置
17、位无效。/PSEN:外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。/EA/VPP:当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式1时,/EA将内部锁定为RESET;当/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源(VPP)。XTAL1:反向振荡放大器的输入及内部时钟工作电路的输入。XTAL2:来自反向振荡器的输出。振荡器特性:XTAL1和XTAL2分别为反向放大器的输入和输出。该反
18、向放大器可以配置为片内振荡器。石晶振荡和陶瓷振荡均可采用。如采用外部时钟源驱动器件,XTAL2应不接。有余输入至内部时钟信号要通过一个二分频触发器,因此对外部时钟信号的脉宽无任何要求,但必须保证脉冲的高低电平要求的宽度。2.3实时时钟电路DS1302工作原理 2.3.1 DS1302的结构及工作原理DS1302 是美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟电路,它可以对年、月、日、周日、时、分、秒进行计时,具有闰年补偿功能,工作电压为2.5V5.5V。采用三线接口与CPU进行同步通信,并可采用突发方式一次传送多个字节的时钟信号或RAM数据。DS1302内部有一个318的用
19、于临时性存放数据的RAM寄存器。DS1302是DS1202的升级产品,与DS1202兼容,但增加了主电源/后背电源双电源引脚,同时提供了对后背电源进行涓细电流充电的能力。2.3.2 引脚功能及结构图3 DS1302芯片图示表出DS1302的引脚排列,其中Vcc1为后备电源,VCC2为主电源。在主电源关闭的情况下,也能保持时钟的连续运行。DS1302由Vcc1或Vcc2两者中的较大者供电。当Vcc2大于Vcc10.2V时,Vcc2给DS1302供电。当Vcc2小于Vcc1时,DS1302由Vcc1供电。X1和X2是振荡源,外接32.768kHz晶振。RST是复位/片选线,通过把RST输入驱动置高
20、电平来启动所有的数据传送。RST输入有两种功能:首先,RST接通控制逻辑,允许地址/命令序列送入移位寄存器;其次,RST提供终止单字节或多字节数据的传送手段。当RST为高电平时,所有的数据传送被初始化,允许对DS1302进行操作。如果在传送过程中RST置为低电平,则会终止此次数据传送,I/O引脚变为高阻态。上电运行时,在Vcc2.5V之前,RST必须保持低电平。只有在SCLK为低电平时,才能将RST置为高电平。I/O为串行数据输入输出端(双向),SCLK始终是输入端。2.3.3 DS1302的寄存器 DS1302有12个寄存器,其中有7个寄存器与日历、时钟相关,存放的数据位为BCD码形式, 此
21、外,DS1302 还有年份寄存器、控制寄存器、充电寄存器、时钟突发寄存器及与RAM相关的寄存器等。时钟突发寄存器可一次性顺序读写除充电寄存器外的所有寄存器内容。 DS1302与RAM相关的寄存器分为两类:一类是单个RAM单元,共31个,每个单元组态为一个8位的字节,其命令控制字为C0HFDH,其中奇数为读操作,偶数为写操作;另一类为突发方式下的RAM寄存器,此方式下可一次性读写所有的RAM的31个字节,命令控制字为FEH(写)、FFH(读)。2.4 MAX7219工作原理简介MAX7219是MAXIM公司生产的串行输入/输出共阴极数码管显示驱动芯片,一片MAX7219可驱动8个7段(包括小数点
22、共8段)数字LED、LED条线图形显示器、或64个分立的LED发光二级管。该芯片具有10MHz传输率的三线串行接口可与任何微处理器相连,只需一个外接电阻即可设置所有LED的段电流。它的操作很简单,MCU只需通过模拟SPI三线接口就可以将相关的指令写入MAX7219的内部指令和数据寄存器,同时它还允许用户选择多种译码方式和译码位。此外它还支持多片7219串联方式,这样MCU就可以通过3根线(即串行数据线、串行时钟线和芯片选通线)控制更多的数码管显示。 图4 DS1302芯片MAX7219的外部引脚分配2.4.1.引脚分配及功能图5 MAX7219的内部引脚分配各引脚的功能为:DIN:串行数据输入
23、端DOUT:串行数据输出端,用于级连扩展LOAD:装载数据输入CLK:串行时钟输入DIG0DIG7:8位LED位选线,从共阴极LED中吸入电流SEG ASEG G DP7段驱动和小数点驱动ISET:通过一个10k电阻和Vcc相连,设置段电流2.4.2.寄存器介绍MAX7219内部的寄存器如图所示,主要有:译码控制寄存器、亮度控制寄存器、扫描界限寄存器、关断模式寄存器、测试控制寄存器。编程时只有正确操作这些寄存器,MAX7219才可工作。图6 MAX7219内部的相关寄存器分别介绍如下:() 译码控制寄存器(X9H)如图所示,MAX7219有两种译码方式:B译码方式和不译码方式。当选择不译码时,
24、8个数据为分别一一对应7个段和小数点位;B译码方式是BCD译码,直接送数据就可以显示。实际应用中可以按位设置选择B译码或是不译码方式。图7 MAX7219的译码控制寄存器() 扫描界限寄存器(XBH)如图所示,此寄存器用于设置显示的LED的个数(18),比如当设置为0xX4时,LED 05显示。图8 MAX7219的扫描界限控制寄存器() 亮度控制寄存器(XAH)共有16级可选择,用于设置LED的显示亮度,从0xX00xXF() 关断模式寄存器(XCH)共有两种模式选择,一是关断状态,(最低位 D0=0)一是正常工作状态(D0=1)。2.5 数码管介绍2.5.1数码管的分类数码管按段数分为七段
25、数码管和八段数码管,八段数码管比七段数码管多一个发光二极管单元(多一个小数点显示);按能显示多少个“8”可分为1位、2位、4位等等数码管;按发光二极管单元连接方式分为共阳极数码管和共阴极数码管。共阳极数码管是指将所有发光二极管的阳极接到一起形成公共阳极(COM)的数码管。共阳极数码管在应用时应将公共极COM接到+5V,当某一字段发光二极管的阴极为低电平时,相应字段就点亮。当某一字段的阴极为高电平时,相应字段就不亮。共阴极数码管是指将所有发光二极管的阴极接到一起形成公共阴极(COM)的数码管。共阴极数码管在应用时应将公共极COM接到地线GND上,当某一字段发光二极管的阳极为高电平时,相应字段就点
26、亮。当某一字段的阳极为低电平时,相应字段就不亮。(1)数码管驱动方式的分类数码管要正常显示,就要用驱动电路来驱动数码管的各个段码,从而显示出我们要的数字,因此根据数码管的驱动方式的不同,可以分为静态式和动态式两类。(2)静态显示驱动静态驱动也称直流驱动。静态驱动是指每个数码管的每一个段码都由一个单片机的I/O端口进行驱动,或者使用如BCD码二-十进制译码器译码进行驱动。静态驱动的优点是编程简单,显示亮度高,缺点是占用I/O端口多,如驱动5个数码管静态显示则需要5840根I/O端口来驱动,要知道一个89S51单片机可用的I/O端口才32个呢:),实际应用时必须增加译码驱动器进行驱动,增加了硬件电
27、路的复杂性。(3)动态显示驱动数码管动态显示接口是单片机中应用最为广泛的一种显示方式之一,动态驱动是将所有数码管的8个显示笔划a,b,c,d,e,f,g,dp的同名端连在一起,另外为每个数码管的公共极COM增加位选通控制电各自独立的I/O线控制,当单片机输出字形码时,所有数码管都接收到相同的字形码,但究竟是那个数码管会显示出字形,取决于单片机对位选通COM端电路的控制,所以我们只要将需要显示的数码管的选通控制打开,该位就显示出字形,没有选通的数码管就不会亮。通过分时轮流控制各个数码管的COM端,就使各个数码管轮流受控显示,这就是动态驱动。在轮流显示过程中,每位数码管的点亮时间为12ms,由于人
28、的视觉暂留现象及发光二极管的余辉效应,尽管实际上各位数码管并非同时点亮,但只要扫描的速度足够快,给人的印象就是一组稳定的显示数据,不会有闪烁感,动态显示的效果和静态显示是一样的,能够节省大量的I/O端口,而且功耗更低。2.5.2 数码管的应用数码管是一类显示屏 通过对其不同的管脚输入相对的电流会使其发亮从而显示出数字。可以显示、时间、日期、温度等所有可以用数字代替的参数。由于它的价格便宜使用简单,所以在电器特别是家电领域应用极为广泛,如:空调、热水器、冰箱等等。绝大多数热水器用的都是数码管其他家电也用液晶屏与荧光屏。2.5.6 数码管使用的电流与电压电流:静态时,推荐使用10-15mA;动态时
29、,16/1动态扫描时,平均电流为4-5mA,峰值电流50-60mA。电压:当选择红色时,使用1.9V;当选择绿色时,使用2.1V。2.6 电子时钟系统设计流程图9 基于Proteus的单片机系统设计流程3硬件电路设计3.1 电路原理图设计图10 Protel DXP设计的电子钟电路原理图主要元器件功能介绍:AT89C51是一种带4K字节闪烁可编程可擦除只读存储器的低电压,高性能CMOS8位微处理器,俗称单片机。DS1302 是美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟电路,它可以对年、月、日、周日、时、分、秒进行计时。具有调时功能。时钟操作可通过AMPM指示决定采用24或
30、12小时格式。MAX7219是MAXIM公司生产的串行输入/输出共阴极数码管显示驱动芯片。采用三线制串行接口技术进行数据传送,可直接与单片机连接,用户能方便地修改内部参数实现多位LED数码管显示。内含有硬件动态扫描显示控制,每块芯片可驱动8个LED数码管。3.2 Proteus 电路图设计运行Proteus的ISIS 后出现程序主窗口界面,鼠标左键单击窗口左侧的元器件工具栏的component.按钮, 接着再点击窗口左侧的元器件选择区的Pick Divices.按钮,弹出的Pick Devices窗口,再在Categ栏里点击MicroprocessorICs项后,在Results栏里会出现各种
31、类型的CPU器件,找到 AT89C51后双击,AT89C51就被添加到当前窗口左侧的元器件列表区了。用同样的方法依次把 DS130、MAX7219、数码管、晶振以及多个电阻、电容也添加到器件列表区里。然后再依次点击列表区里的器件,单击左键把他们放到绘图区,右键选中元件,并编辑其属性,合理布局后,进行连线。连线时当鼠标的指针靠近一个对象的引脚时,跟着鼠标的指针r ICs就会出现一个“”提示符号,点击鼠标左键即可画线了,需要拐弯时点击一下即可,在终点再点击确认一下就画出了一段导线,所有导线画完后,点击工具栏的 Inter-sheeTerminal.按钮,添加上电源和接地符号,原理图的绘制就完成了。
32、图11 Proteus中设计的电子时钟系统原理图4软件设计4.1 程序流程图设计图12 系统程序流程图4.2 源程序设计以下为源程序:#include AT89X51.H#include delay.h#include max7219.c#include music.c#define uchar unsigned char#define uint unsigned int idatasbit ADD=P11;sbit SUB=P10;sbit ACC0 = ACC0;sbit ACC7 = ACC7;void showDay(void);/显示时间void showData(void);/显示
33、日期void showDishi(void);/显示定时void int_0(void);/中断0void int_1(void);/中断1void flash_max7219(unsigned char n);/闪一个位max7219/*/* 实时时钟模块 时钟芯片型号:DS1302 */*/*/sbit T_CLK = P23; /*实时时钟时钟线引脚 */sbit T_IO = P24; /*实时时钟数据线引脚 */sbit T_RST = P25; /*实时时钟复位线引脚 */*/void v_RTInputByte(uchar ucDa); /往DS1302写入1Byte数据ucha
34、r uc_RTOutputByte(void);/ 从DS1302读取1Byte数据void v_W1302(uchar ucAddr, uchar ucDa);/往DS1302写入数据uchar uc_R1302(uchar ucAddr);/读取DS1302某地址的数据/void v_BurstW1302T(uchar *pSecDa);/往DS1302写入时钟数据(多字节方式)/void v_BurstR1302T(uchar *pSecDa);/读取DS1302时钟数据/void v_BurstW1302R(uchar *pReDa);/往DS1302寄存器数写入数据(多字节方式)/v
35、oid v_BurstR1302R(uchar *pReDa);/读取DS1302寄存器数据void v_Set1302(uchar *pSecDa) ;/设置初始时间,输入: pSecDa: 初始时间地址。初始时间格式为: 秒 分 时 日 月 星期 年 void v_Get1302(uchar ucCurtime) ;/读取DS1302当前时间uchar showTime8=0,0,10,0,0,10,0,0;/显示的时间*全局变量uchar setTime2=0,0;/定时的设定uchar time7=0,0x59,0x19,0x24,0x7,0x01,0x08;/秒 分 时 日 月 星期
36、 年uchar Tmod=7;/此时的调节模式void main()delay_ms(200);/sound();initMAX7219();/初始化max7219cls();/清屏max7219/v_Get1302(& time);/v_Set1302(& time);EX0=1;EX1=1;IT1=1;/下降沿触发IT0=1;EA=1;/开中断v_Get1302(& time);showDay();/int_1();/int_0();while(1)v_Get1302(& time);showDay();if (setTime0=time2)&(setTime1=time1)sound()
37、;/*显示时间void showDay(void)/将数据转化为显示格式showTime7=time0 & 0x0f;/个位showTime6=time04;/十位showTime4=time1 & 0x0f;showTime3=time14;showTime1=time2 & 0x0f;showTime0=time24;showTime2=showTime5=10;disp_88(& showTime);/*显示日期void showData(void)showTime7=time3 & 0x0f;showTime6=time34;showTime4=time4 & 0x0f;showTim
38、e3=time44;showTime1=time6 & 0x0f;showTime0=time64;showTime2=showTime5=10;disp_88(& showTime);/*显示定时void showDishi(void)showTime1=setTime0 & 0x0f;showTime0=setTime04;showTime4=setTime1 & 0x0f;showTime3=setTime14;showTime6=12;showTime7=13;showTime2=showTime5=10;disp_88(& showTime); 4.3 KeilC51进行程序调试把编
39、写完的源程序放在KEIL软件中,先自行检查下程序是否有误,更改有误的部分,再创建工程进行程序一个一个地调试,把调试结果显示有误的部分找出,检查错误的原因然后再进行更改,更改后再进行调试,再找出错误进行更改,依次循环进行,至到程序调试成功为止。图13 电子时钟程序编辑编译图14 电子时钟程序链接5.系统调试与仿真5.1 Proteus中Hex 文件选择 系统仿真分析电路原理图在ISIS里设计完成,并将系统软件编译成.Hex文件,再进行电子时钟的系统虚拟仿真 。(1)在ISIS的原理图中,右键单击AT89C51将其选中,然后单击左键打开AT89C51的Edit Component 对话框,如下图所
40、示。图15 Edit Component 对话框(2)选择相应的.Hex文件,再在Proteus ISIS 编辑窗口的File菜单中选择Save Design 选项,保存设计,生成.DSN文件。5.2 Proteus进行电子钟系统仿真在Proteus ISIS的Debug菜单中选择Execute,运行程序,系统仿真结果如下图所示。实现功能:当进入调整功能时,按第一个键K1进行减运算,按第二个键K2进行加运算。按下第三个键K3,实现日期时间调整及定时功能,等数字闪烁后,按一二键进行加减,从而可以进行具体日期时间调整。当定时设定后,到预定时间后,系统通过C51音乐程序演唱歌曲-八月桂花。按下第四个
41、键K4,可以进行时间日期切换,8位LED数码管将显示时间或日期,采用24小时制。时间显示格式为:时-分-秒;日期显示格式为:日-月-年。具有实时显示当前计算机系统时间和日期的功能。图16 Proteus系统仿真结果结束语本文的电子钟系统是以单片机(AT89C51)为核心,时钟芯片DS1302、数码管显示驱动芯片MAX7219等元器件组成。具体介绍应用Protel DXP进行电路原理图设计,Keil C51软件调试程序以及Proteus的ISIS软件进行单片机系统的电子钟设计与仿真,实现了硬件软化的目的。参考文献1 代启化.基于Proteus的电路设计与仿真J.现代电子技术.2006,第19期.
42、2 曹洪奎;马莹莹 基于Proteus单片机系统设计与仿真J. 辽宁工学院学报07年04期3 侯玉宝 基于Proteus的51系列单片机设计与仿真M电子工业出版社,2008.2702884 蔡希彪,曹洪奎; 单片机电子时钟系统的设计与仿真 J;中国科技信息; 2007年04期5 方怡冰.单片机课程的教学与实验改革J.电气电子教学学报.2006,第3期.6 刘文秀.单片机应用系统仿真的研究J.现代电子技术.2005, 第286 期7 张友德.单片微型机原理、应用与实验M.上海:复旦大学出版社,2003.225256.8 李光飞.单片机设计实例指导M.北京:北京航空航天大学出版社,2004.5,9
43、6100.9 胡汉才 单片机原理及其接口技术M. 北京: 清华大学出版社 , 1996.89110.10 杨立民.单片机技术及应用M.西安:西安电子科技大学出版社.谢 辞时光如梭,转眼四年的求学之路已临近尾声,心中感慨万千,在此之际我要向这四年来在生活和学习等诸多方面给予我无私帮助、关心的老师、同学和亲人们表示我崇高的敬意和诚挚的感激之情。在本文结束之际,我要感谢*老师。她在论文选题、结构、内容等方面提供了很多宝贵的意见,并在百忙之中对论文进行了多次审阅、修改,没有她的帮助与监督,论文不可能如期顺利完成,在四年的学习期间,*老师对我的学习和工作做了悉心指导和耐心帮助,她开朗的作风和平易近人的态度为我今后的工作、生活树立了学习的榜样。最后特别感谢我的父母,衷心感谢他们对我无微不至的关心和为我学习和生活做出的无私奉献。祝福所有给我帮助的人:万事如意!宝鸡文理学院本科毕业