毕业设计-基于89c51单片机的电子时钟设计_第1页
毕业设计-基于89c51单片机的电子时钟设计_第2页
毕业设计-基于89c51单片机的电子时钟设计_第3页
毕业设计-基于89c51单片机的电子时钟设计_第4页
毕业设计-基于89c51单片机的电子时钟设计_第5页
已阅读5页,还剩45页未读 继续免费阅读

下载本文档

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

文档简介

湖南信息科学职业学院毕业论文(设计)题目基于单片机的电子时钟设计作者姓名周向阳学号1001010206专业10应用电子技术指导教师李仲春2013年3月目录湖南信息科学职业学院3毕业设计(论文)任务书3湖南信息科学职业学院4毕业设计(论文)开题报告4湖南信息科学职业学院5毕业设计(论文)开题报告5摘要81绪论911课题研究的背景912课题的研究目的与意义9二十一世纪是数字化技术高速发展的时代,而单片机在数字化高速发展的时代扮演着极为重要的角色。913课题解决的主要内容92系统的总体设计1021系统方案的构想与确定1022器件的选用10221单片机的选择1031系统硬件电路设计12311系统硬件框图12312AT89S51单片机123138位移位寄存器74LS164(串行输入,并行输出)16314DS13022041主程序2342从1302读取日期和时间程序2451编程环境PROTEUS2552用PROTEUSISIS对电子万年历的硬件电路设计2553用PROTEUSISIS进行电子万年历的仿真测试29结论32致谢33参考文献34附录35附录135摘要本文介绍了基于AT89C51单片机的多功能电子万年历的硬件结构和软硬件设计方法。系统以AT89C51单片机为控制器,以串行时钟日历芯片DS1302记录日历和时间,它可以对年、月、日、时、分、秒进行计时,还具有闰年补偿等多种功能。万年历采用直观的数字显示,可以在LED上同时显示年、月、日、周日、时、分、秒,还具有时间校准等功能。此万年历具有读取方便、显示直观、功能多样、电路简洁、成本低廉等诸多优点,具有广阔的市场前景。关键字AT89C51;电子万年历;DS13021绪论11课题研究的背景随着科技的快速发展,时间的流逝,从观太阳、摆钟到现在电子钟,人类不断研究,不断创新纪录。它可以对年、月、日、时、分、秒进行计时,还具有闰年补偿等多种功能,而且DS1302的使用寿命长,误差小。对于数字电子万年历采用直观的数字显示,可以同时显示年、月、日、时、分、秒和温度等信息,还具有时间校准等功能。该电路采用AT89C51单片机作为核心,功耗小,能在3V的低压工作,电压可选用35V电压供电。此万年历具有读取方便、显示直观、功能多样、电路简洁、成本低廉等诸多优点,符合电子仪器仪表的发展趋势,具有广阔的市场前景。12课题的研究目的与意义二十一世纪是数字化技术高速发展的时代,而单片机在数字化高速发展的时代扮演着极为重要的角色。电子万年历的开发与研究在信息化时代的今天亦是当务之急,因为它应用在学校、机关、企业、部队等单位礼堂、训练场地、教学室、公共场地等场合,可以说遍及人们生活的每一个角落。所以说电子万年历的开发是国家之所需,社会之所需,人民之所需。由于社会对信息交换不断提高的要求及高新技术的逐步发展,促使电子万年历发展并且投入市场得到广泛应用。13课题解决的主要内容本课题所研究的电子万年历是单片机控制技术的一个具体应用,主要研究内容包括以下几个方面(1)选用电子万年历芯片时,应重点考虑功能实在、使用方便、单片存储、低功耗、抗断电的器件。(2)根据选用的电子万年历芯片设计外围电路和单片机的接口电路。(3)在硬件设计时,结构要尽量简单实用、易于实现,使系统电路尽量简单。(4)根据硬件电路图,在开发板上完成器件的焊接。(5)根据设计的硬件电路,编写控制AT89C51芯片的单片机程序。(6)通过编程、编译、调试,把程序下载到单片机上运行,并实现本设计。(7)在硬件电路和软件程序设计时,主要考虑提高人机界面的友好性,方便用户操作等因素。(8)软件设计时必须要有完善的思路,要做到程序简单,调试方便。2系统的总体设计单片机电子万年历的制作有多种方法,可供选择的器件和运用的技术也有很多种。所以,系统的总体设计方案应在满足系统功能的前提下,充分考虑系统使用的环境,所选的结构要简单使用、易于实现,器件的选用着眼于合适的参数、稳定的性能、较低的功耗以及低廉的成本。21系统方案的构想与确定系统的功能往往决定了系统采用的结构,经过成本,性能,功耗等多方面的考虑决定用三个8位74LS164串行接口外接LED显示器,RESPACK8对单片机AT89C51进行供电,时间芯片DS1302连接单片机AT89C51。从而实现电子万年历的功能。22器件的选用单片机AT89C51电容RESPACK8三个74LS164串行接口传感器DS1302221单片机的选择单片机自70年代问世以来以微处理器(MPU)技术及超大规模集成电路技术的发展为先导,用广泛的应用领域拉动得到蓬勃发展,单片机功能正日渐完善。单片机的应用,使许多领域的技术水平和自动化程度大大提高,可以说当今世界正在经受一场以单片机技术为标志的新技术革命浪潮的冲击。主要单片机类型如下1MCS51系列单片机MCS51系列单片机主要是指INTEL公司生产的以51位内核的单片机芯片,具有8位CPU、4K字节ROM、128字节RAM、可扩展外部64K字节RAM和ROM、2个16位的定时器/计数器、4个8位并行I/O口、1个全双工串行I/O口、21字节的专用寄存器、5个中断源、片内自带振荡器、片内单总线等功能部件。(2)AT89C51单片机AT89C51单片机的主要特性如下与MCS51产品指令系统完全兼容4K字节的在线编程FLASH存储器,1000次擦写周期4055V的工作电压范围全静态工作模式033MHZ三级程序存储器锁1288字节内部RAM32个可编程I/O口线2个16位定时/计数器6个中断源全双工串行UART通道低功耗空闲和掉电模式中断可从空闲模式唤醒系统看门狗(WDT)及双数据指针掉电标识和快速编程特性具有掉电状态下的中断恢复功能灵活的在系统编程(ISP字节或页写模式)由于AT89C51单片机片内有4K字节的在线编程FLASH存储器,可以擦写1000次,具有掉电模式,而且具有掉电状态下的中断恢复功能,对设计开发非常实用。所以选用AT89C51单片机作为电子万年历芯片的控制单片机。3系统硬件的设计根据上述所确定的系统方案构想,下面进行系统硬件电路的具体设计,系统的总体结构框图如图所示。31系统硬件电路设计311系统硬件框图系统硬件框图如图31时钟芯片DS1302串口AT89C51P2口LED显示器驱动电路图31系统硬件框图312AT89S51单片机本系统采用的是美国ATMEL公司生产的AT89C51单片机,首先我们来熟悉一下AT89C51单片机的外部引脚和内部结构。1单片机的引脚功能AT89C51单片机有40个引脚。VCC电源电压5VGND接地P0口P0口是一组8位漏极开路型双向I/O口,也即地址/数据总线复用口。作为输出口用时,每位能驱动8个TTL逻辑门电路,对端口写“1”可作为高阻抗输入端用。在访问外部数据存储器或程序存储器时,这组口线分时转换地址(低8位)和数据总线服用,在访问期间激活内部上拉电阻。在FLASH编程时,P0口接收指令字节,而在程序校验时,输出指令字节,校验时要求外接上拉电阻。P1口P1口是一个带内部上拉电阻的8位双向I/O,P1的输出缓冲级可驱动(吸收或输出电流)4个TTL逻辑门电路。对端口写“1”,通过内部的上拉电阻把端口拉到高电平,此时可作输入口。作输入口使用时,因为内部存在上拉电阻,某个引脚被外部信号拉低时会输出一个电流。FLASH编程和程序校验期间,P1接收低8位地址。P2口P2口是一个带内部上拉电阻的8位双向I/O,P2的输出缓冲级可驱动(吸收或输出电流)4个TTL逻辑门电路。对端口写“1”,通过内部的上拉电阻把端口拉到高电平,此时可作输入口。作输入口使用时,因为内部存在上拉电阻,某个引脚被外部信号拉低时会输出一个电流。在访问外部程序存储器或16位地址的外部数据存储器(例如执行MOVXDPTR指令)时,P2口送出高8位地址数据。在访问8位地址的外部数据存储器(MOVXRI指令)时,P2口线上的内容(也即特殊功能寄存器(SFR)区中P2寄存器的内容),在整个访问期间不改变。FLASH编程和程序校验期间,P2亦接收低高位地址和其他控制信号。P3口P3口是一组带内部上拉电阻的8位双向I/O,P3的输出缓冲级可驱动(吸收或输出电流)4个TTL逻辑门电路。对P3口写入“1”时,它们被内部的上拉电阻拉高并可作为输入端口。作输入端时,被外部拉低的P3口将用上拉电阻输出电流。P3口除了作为一般的I/O口线外,更重要的用途是它的第二功能,见表31所示P3口还接收一些用于FLASH闪速存储器编程和程序校验的控制信号。表31P3口的第二功能图端口引脚第二功能P30RXD(串行输入口)P31TXD(串行输出口)P32INT0(外中断0)P33INT1(外中断1)P34T0(定时/计时器0外部输入)P35T1(定时/计时器1外部输入)P36WR(外部数据存储器写选通)P37RD(外部数据存储器读选通)RST复位输入。当振荡器工作时,RST引脚出现两个机器周期以上高电平将使单片机复位。WDT溢出将使引脚输出高电平,设置SFRAUXR的DISRT0(地址8EH)可打开或关闭该功能。DISRT0位缺省为RESET输出高电平打开状态。ALE/PROG当访问外部程序存储器或数据存储器时,ALE(地址锁存器允许)输出脉冲用于锁存地址的低8位字节。即使不访问外部存储器,ALE仍以时钟振荡频率的1/6输出固定的正脉冲信号,因此它可对外输出时钟或用于定时目的。要注意的是每当访问外部数据存储器时将跳过一个ALE脉冲。对FLASH存储器编程期间,该引脚还用于输入编程脉冲(PROG)。如有必要,可通过多特殊功能寄存器(SFR)区中的8EH单元的D0位置,可禁止ALE操作。该位置后,只有一条MOVX和MOVC指令ALE才会被激活。另外,该引脚会被微弱拉高,单片机执行外部程序时,应设置ALE无效。PSEN程序存储允许(PSEN)输出是外部程序存储器的读选通信号,当AT89C51由外部程序存储器取指令(或数据)时,每个机器周期两次PSEN有效,即输出两个脉冲。当访问外部数据存储器,没有两次有效的PSEN信号。EA/VPP外部访问允许。欲使CPU仅访问外部程序存储器(地址为0000HFFFFH),EA端必须保持低电平(接地)。需要注意的是如果加密位LB1被编程,复位时内部会锁存EA端状态。如EA端为高电平(接VCC端),CPU则执行内部程序存储器中的指令。FLASH存储器编程时,该引脚加上12V的变成电压VPPXTAL1振荡器反相放大器及内部时钟发生器的输入端。XTAL2振荡器反相放大器的输出端。AT89C51单片机内部结构2AT89C51单片机与MCS51完全兼容看门狗(WDT)WDT是一种需要软件控制的复位方式。WDT由13位计数器和特殊功能寄存器中的看门狗定时器复位存储器(WDTRST)构成。WDT在默认情况下无法工作;为了激活WDT,用户必须往WDTRST寄存器(地址0A6H)中依次写入01EH和0E1H。当WDT激活后,晶振工作,WDT在每个机器周期都会增加。WDT计时周期依赖于外部时钟频率。除了复位(硬件复位或WDT溢出复位),没有办法停止WDT工作。当WDT溢出,它将驱动RSR引脚输出一个高电平。可编程串口(UART)在AT89C51中,UART的操作与AT89C51和AT89C52一样。AT89C51系列单片机的串行通信口可以工作于同步和异步通信方式。当工作于异步方式时,它具有全双工的操作功能,也就是说,它可以同时进行数据的发送和接收。串行口内的接收器采用的是双缓冲结构,能够在接收到的第一个字节从接收寄存器读走之前就开始接收第二个字节(当然,如果第二个字节接收完毕,而第一个字节仍然没有被读走,那将会丢掉一个字节)。串行口的发送和接收操作都是通过特殊功能寄存器中的数据缓冲寄存器SBUF进行的,但在SBUF的内部,接收寄存器和发送寄存器在物理结构上是完全独立的。如果将数据写入SBUF,数据会被送入发送寄存器准备发送。如果执行SBUF指令,则读出的数据一定来自接收缓存器。因此,CPU对SBUF的读写,实际上是分别访问2个不同的寄存器。这2个寄存器的功能决不能混淆。振荡电路AT89C51系列单片机的内部振荡器,由一个单极反相器组成。XTAL1反相器的输入,XTAL2为反相器的输出。可以利用它内部的振荡器产生时钟,只要XTAL1和XTAL2引脚上一个晶体及电容组成的并联谐振电路,便构成一个完整的振荡信号发生器,此方式称为内部方式。另一种方式由外部时钟源提供一个时钟信号到XTAL1端输入,而XTAL2端浮空。在组成一个单片机应用系统时,多数采用这种方式,这种方式结构紧凑,成本低廉,可靠性高。在电路中,对电容C1和C2的值要求不是很严格,如果使用高质的晶振,则不管频率为多少,C1、C2通常都选择30PF。定时/计数器AT89C51单片机内含有2个16位的定时器/计数器。当用于定时器方式时,定时器的输入来自内部时钟发生电路,每过一个机器周期,定时器加1,而一个机器周期包含有12个振荡周期,所以,定时器的技术频率为晶振频率的1/12,而计数频率最高为晶振频率的1/24。为了实现定时和计数功能,定时器中含有3种基本的寄存器控制寄存器、方式寄存器和定时器/计数器。控制寄存器是一个8位的寄存器,用于控制定时器的工作状态,方式寄存器是一个8位的寄存器,用于确定定时器的工作方式,定时器/计数器是16位的计数器,分为高字节和低字节两部分。RAM高于7FH内部数据存储器的地址是8位的,也就是说其地址空间只有256字节,但内部RAM的寻址方式实际上可提供384字节。的直接地址访问同一个存储空间,高于7FH的间接地址访问另一个存储空间。这样,虽然高128字节区分与专用寄器,即特殊功能寄存器区的地址是重合的,但实际上它们是分开的。究竟访问哪一区,存是通过不同的寻址方式加以区分的。SFRSFR是具有特殊功能的所有寄存器的集合,共含有22个不同寄存器,它们的地址分配在80HFFH中。虽然如此,不是所有的单元都被特殊功能寄存器占用,未被占用的单元,其内容是不确定的。如对这些单元进行读操作,得到的是一些随机数,而写入则无效,所以在编程时不应该将数据写入这些未确定的地址单元中,特殊功能寄存器主要有累加器ACC、B寄存器、程序状态字寄存器PSW、堆栈指针SP、数据指针DPTR、I/O端口、串行口数据缓冲器SBUF、定时器寄存器、捕捉寄存器、控制寄存器。中断系统AT89C51单片机有6个中断源,中断系统主要由中断允许寄存器IE、中断优先级寄存器IP、优先级结构和一些逻辑门组成。IE寄存器用于允许或禁止中断;IP寄存器用于确定中断源的优先级别;优先级结构用于执行中断源的优先排序;有关逻辑门用于输入中断请求信号。在整个中断响应过程中CPU所执行的操作步骤如下(1)完成当前指令的操作(2)将PC内容压入堆栈(3)保存当前的中断状态(4)阻止同级的中断请求(5)将中断程序入口地址送PC寄存器(6)执行中断服务程序(7)返回3138位移位寄存器74LS164(串行输入,并行输出)74LS164为8位移位寄存器,其主要电特性的典型值如表32表3274LS164主要电特性典型值型号FMPN54/7416436MHZ185MW54/74LS16436MHZ80MW当清除端(CLEAR)为低电平时,输出端(QAQH)均为低电平。串行数据输入端(A,B)可控制数据。当A、B任意一个为低电平时停止新数据输入,在时钟端(CLOCK)脉冲上升沿作用下Q0为低电平。当有一个为高电平,则另一个就允许输入数据,并在CLOCK上升沿作用Q0的状态。引出端符号CLOCK时钟输入端CLEAR同步清除输入端(低电平有效)A,B串行数据输入端QAQH输出端逻辑及封装图,如32,33图32逻辑图图33封装图极限值电源电压7V输入电压55V工作环境温度541645512574164070储存温度65150表33真值表H高电平L低电平X任意电平低到高电平跳变QA0,QB0,QH0规定的稳态条件建立前的电平QAN,QGN时钟最近的前的电平时序图如下34图34时序图推荐工作条件如表34表34推荐工作条件静态特性(TA为工作环境温度范围)如表351测试条件中的“最小”和“最大”用推荐工作条件中的相应值。动态特性TA25如表36表36动态特性2FMAX最大时钟频率。TPLH输出由低电平到高电平传输延迟时间TPHL输出由高电平到低电平传输延迟时间314DS1302现在流行的串行时钟电路很多,如DS1302、DS1307、PCF8485等。这些电路的接口简单、价格低廉、使用方便,被广泛地采用。本文介绍的实时时钟电路DS1302是DALLAS公司的一种具有涓细电流充电能力的电路,主要特点是采用串行数据传输,可为掉电保护电源提供可编程的充电功能,并且可以关闭充电功能。采用普通32768KHZ晶振。DS1302是美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟电路,它可以对年、月、日、周日、时、分、秒进行计时,具有闰年补偿功能,工作电压为25V55V。采用三线接口与CPU进行同步通信,并可采用突发方式一次传送多个字节的时钟信号或RAM数据。DS1302内部有一个318的用于临时性存放数据的RAM寄存器。DS1302是DS1202的升级产品,与DS1202兼容,但增加了主电源/后背电源双电源引脚,同时提供了对后背电源进行涓细电流充电的能力。DS1302的引脚排列,其中VCC1为后备电源,VCC2为主电源。在主电源关闭的情况下,也能保持时钟的连续运行。DS1302由VCC1或VCC2两者中的较大者供电。当VCC2大于VCC102V时,VCC2给DS1302供电。当VCC2小于VCC1时,DS1302由VCC1供电。X1和X2是振荡源,外接32768KHZ晶振。RST是复位/片选线,通过把RST输入驱动置高电平来启动所有的数据传送。RST输入有两种功能首先,RST接通控制逻辑,允许地址/命令序列送入移位寄存器;其次,RST提供终止单字节或多字节数据的传送手段。当RST为高电平时,所有的数据传送被初始化,允许对DS1302进行操作。如果在传送过程中RST置为低电平,则会终止此次数据传送,I/O引脚变为高阻态。上电运行时,在VCC25V之前,RST必须保持低电平。只有在SCLK为低电平时,才能将RST置为高电平。I/O为串行数据输入输出端双向,后面有详细说明。SCLK始终是输入端。DS1302的控制字节的最高有效位位7必须是逻辑1,如果它为0,则不能把数据写入DS1302中,位6如果为0,则表示存取日历时钟数据,为1表示存取RAM数据位5至位1指示操作单元的地址最低有效位位0如为0表示要进行写操作,为1表示进行读操作,控制字节总是从最低位开始输出。在控制指令字输入后的下一个SCLK时钟的上升沿时,数据被写入DS1902,数据输入从低位即位0开始。同样,在紧跟8位的控制指令字后的下一个SCLK脉冲的下降沿读出DS1302的数据,读出数据时从低位0位到高位7。DS1302有12个寄存器,其中有7个寄存器与日历、时钟相关,存放的数据位为BCD码形式,其日历、时间寄存器及其控制字见表1。此外,DS1302还有年份寄存器、控制寄存器、充电寄存器、时钟突发寄存器及与RAM相关的寄存器等。时钟突发寄存器可一次性顺序读写除充电寄存器外的所有寄存器内容。DS1302与RAM相关的寄存器分为两类一类是单个RAM单元,共31个,每个单元组态为一个8位的字节,其命令控制字为C0HFDH,其中奇数为读操作,偶数为写操作;另一类为突发方式下的RAM寄存器,此方式下可一次性读写所有的RAM的31个字节,命令控制字为FEH写、FFH读。DS1302与CPU的连接需要三条线,即SCLK7、I/O6、RST5。DS1902与89C2051的连接图,其中,时钟的显示用LED。DS1302与CPU的连接,实际上,在调试程序时可以不加电容器,只加一个32768KHZ的晶振即可。只是选择晶振时,不同的晶振,误差也较大。另外,还可以在上面的电路中加入DS18B20,同时显示实时温度。只要占用CPU一个口线即可。LED还可以换成LCD,还可以使用北京卫信杰科技发展有限公司生产的10位多功能8段液晶显示模块LCM101,内含看门狗WDT/时钟发生器及两种频率的蜂鸣器驱动电路,并有内置显示RAM,可显示任意字段笔划,具有34线串行接口,可与任何单片机、IC接口。功耗低,显示状态时电流为2A典型值,省电模式时小于1A,工作电压为24V33V,显示清晰。DS1302的实时时间流程。根据流程框图,不难采集实时时间。下面对DS1302的基本操作进行编程根据本人在调试中遇到的问题,特作如下说明DS1302与微处理器进行数据交换时,首先由微处理器向电路发送命令字节,命令字节最高位MSBD7必须为逻辑1,如果D70,则禁止写DS1302,即写保护;D60,指定时钟数据,D61,指定RAM数据;D5D1指定输入或输出的特定寄存器;最低位LSBD0为逻辑0,指定写操作输入,D01,指定读操作输出。在DS1302的时钟日历或RAM进行数据传送时,DS1302必须首先发送命令字节。若进行单字节传送,8位命令字节传送结束之后,在下2个SCLK周期的上升沿输入数据字节,或在下8个SCLK周期的下降沿输出数据字节。DS1302与RAM相关的寄存器分为两类一类是单个RAM单元,共31个,每个单元组态为一个8位的字节,其命令控制字为C0HFDH,其中奇数为读操作,偶数为写操作;再一类为突发方式下的RAM寄存器,在此方式下可一次性读、写所有的RAM的31个字节。要特别说明的是备用电源B1,可以用电池或者超级电容器01F以上。虽然DS1302在主电源掉电后的耗电很小,但是,如果要长时间保证时钟正常,最好选用小型充电电池。可以用老式电脑主板上的36V充电电池。如果断电时间较短几小时或几天时,就可以用漏电较小的普通电解电容器代替。100F就可以保证1小时的正常走时。DS1302在第一次加电后,必须进行初始化操作。初始化后就可以按正常方法调整时间。DS1302存在时钟精度不高,易受环境影响,出现时钟混乱等缺点。DS1302可以用于数据记录,特别是对某些具有特殊意义的数据点的记录,能实现数据与出现该数据的时间同时记录。这种记录对长时间的连续测控系统结果的分析及对异常数据出现的原因的查找具有重要意义。传统的数据记录方式是隔时采样或定时采样,没有具体的时间记录,因此,只能记录数据而无法准确记录其出现的时间;若采用单片机计时,一方面需要采用计数器,占用硬件资源,另一方面需要设置中断、查询等,同样耗费单片机的资源,而且,某些测控系统可能不允许。但是,如果在系统中采用时钟芯片DS1302,则能很好地解决这个问题。4系统的软件设计电子万年历的功能是在程序控制下实现的。该系统的软件设计方法与硬件设计相对应,按整体功能分成多个不同的程序模块,分别进行设计、编程和调试,最后通过主程序将各程序模块连接起来。这样有利于程序修改和调试,增强了程序的可移植性。41主程序主程序如图41所示开始读年、月、日送第一块LED显示读星期、闰、年、日送第二块LED显示读时、分、秒送第三块LED显示返回图41主程序图42从1302读取日期和时间程序图42从1302读取程序5PROTEUS使用51编程环境PROTEUSPROTEUS软件是由英国LABCENTERELECTRONICS公司开发的EDA工具软件,由ISIS和ARES两个软件构成,其中ISIS是一款便捷的电子系统仿真平台软件,ARES是一款高级的布线编辑软件,它集成了高级原理布线图、混合模式SPICE电路仿真、PCB设计以及自动布线来实现一个完整的电子设计。52用PROTEUSISIS对电子万年历的硬件电路设计通过PROTEUSISIS软件的VSM(虚拟仿真技术),用户可以对模拟电路、数字电路、模数混合电路,以及基于微控制器的系统连同所有外围接口电子元器件一起仿真。用PROTEUSISIS设计硬件电路的过程选择设计图纸的到小根据设计所使用到元器件的多少,选择合适大小的设计图纸,操作是单击菜单栏上的SYSTEMSETSHEETSIZE,然后弹出如图51所示的对话框,从中选择合适大小的图纸,也可以选择USER进行图纸的自定义设置。在设计过程中也可以通过此方法调整图纸的大小。图51选取仿真所需的元器件选取元器件的方式是,单击如图52所示的按钮“P”。会弹出如图53所示的窗口。图52图53从此窗口的左上角的“KEYWORDS”中输入电子万年历设计用到的器件,如输入“AT89C51”,在中间会列出带有输入关键字的元器件,选择合适的元器件并双击它,则已经选择好了该元器件。然后再在“KEYWORDS”中输入其他所需的元器件,用同样的方法进行操作。最后选择好所有的元器件如图54所示。图54所用器件其中74LS174表示三个串行接口,AT89C51代表单片机会,DS1302代表时钟芯片,RESPACK8代表八排电阻。把元器件放到图纸的合适位置,进行布线单击如图54所示的元器件AT89C51,再在右边图纸上单击,就把元器件放入到了图纸上。再用同样的方法把DS1302放入到图纸的合适位置。如果元器件放置错误,这可通过两次右击删除所放置的元器件,如果位置放得不理想,可以先右击该器件,然后按住左键进行移动。在布线之前,如果觉得元器件的引脚的方向不好布线,则可以通过单击这四个按钮进行调整,这四按钮的意思分别是顺时针旋转90,逆时针旋转90,沿Y轴对称,沿X轴对称。通过这样的调整,可以使整个布局合理一些。接着进行布线,由于PROTEUSISIS有自动布线的功能,比如要把AT89C51的P2口连到74LS164的OUT8口,只要先在P2引脚上单击一下,再在OUT8引脚上单击,则ISIS自动将两个引脚连上线。图55AT89C51与DS1302的连接ISIS还提供了网络布线,即不使用线连接也可以把两个引脚虚拟的连接了起来。具体操作是单击要连线的一个引脚,连出适当的距离后双击,另一个引脚也同样操作,在单击如图65所示的“LBL”按钮,再在图中P01引脚的A处单击,在弹出的窗口中的“STRING”中填入名称,如“A”,对OUT7引脚进行同样的操作,在“STRING”中也填入名称“A”,这样就完成了P34引脚与RES引脚的网络连接,这个好处避免两个距离比较远的器件进行真实线的连接,使布线美观。编辑窗口连接端子要让最后的设计成功仿真时,必须放置并连接端子。选择,从中可以选择电路原理中的两个通用的端子,一个是接地,一个是电源。如图56所示。图56连接端子在PROTEUSISIS中的最终设计图如图57所示图57仿真图最后分别对各元器件的属性值进行设置,单击按钮,进行电气检测,查看接线是否合理,说明硬件电路已经顺利的完成。53用PROTEUSISIS进行电子万年历的仿真测试添加KEIL中编写的代码文件单击工具栏中的SOURCEADD/REMOVESOURCEFILES,弹出一个对话框,分别单击“NEW”,然后选择在KEIL中编写的数字电压表ASM汇编语言程序,单击“OK”,完成添加代码文件。编译源程序,生成HEX目标代码文件单击SOURCEBUILDALL。如果编译结果没有错误,会出现如图58所示的结果。图58加载HEX目标代码文件通过如图59所示的对话框,选择刚才编译生成的HEX文件。设置使单片机的运行频率为6MHZ。图59单击按钮,进行对电子万年历的仿真测试,运行结果如图510所示图510仿真测试PROTEUS的调试功能由于使用的是汇编语言编写的程序,如果在测量的时候测量值显示错误,说明程序中存在问题,这个问题只用在仿真测量的时候才能被发现,这时可以使用PROTEUS对程序进行调试。单击按钮,再单击菜单栏中的DEBUG,可以在最下面选择打开内存观察窗口,寄存器值观察窗口,汇编语言源代码窗口等等。在汇编语言源代码窗口中,也可以在所需要设置断点的语句前双击设置断点,当设置断点的时候,程序运行到所设断点处停止,从而可以在内存、寄存器等的值的变化,从而找出程序出错的地方。结论本课题从理论到实际应用,用AT89C51单片机与8位模数转换芯片74LS164等一些电路的组合,成功的设计出了一个电子万年历。而且所设计的电子万年历设计也按当初要求的能够在PROTEUS中进行仿真,并且能够很精确的显示年历。可以说该电子万年历具有很高的实用价值。在软件设计的过程中,利用了KEIL这个软件在程序录入和调试的时候的优越性,让我能够在编写软件的时候很方便的发现软件中的错误,现在已经能够使用KEIL对所设计的程序进行调试。对于PROTEUS这款软件,也能熟练掌握电路设计仿真。由于平时没有接触过这两个软件,加上毕业设计的时间有限,对于他们的连接调试程序,未能熟练掌握,但以后有机会的话会再好好学习的。本次设计的电子万年历也存在的不足的地方,有待于以后的改进。致谢经过三个多月的时间,毕业设计按照预期完成了,由于本人的知识水平有限,论文和设计中有遗漏和缺陷的地方恳请指正。感谢我的导师龚玉蓉老师给了我莫大的帮助,在她悉心的指导和严格的要求下,作品和论文顺利完成了。在此毕业设计完成之际,谨向导师和所有帮助过我的老师致以崇高的敬意和衷心的感谢。还有感谢家人、朋友还有宿舍里所有的室友,是他们给我创造了良好的学习氛围,在学习和生活中给了我支持和帮助。在以后的学习生活中我会时时敦促自己更加努力,不辜负师长、亲人、朋友对我的期望。参考文献1赵长德微型计算机原理与接口技术M北京机械工业出版社,1999983502苏平单片机的原理与接口技术M北京电子工业出版社,200611133王忠民微型计算机原理M西安西安科技大学出版社,200315554胡戴明计算机组成原理M北京经济科学出版社,200543565纪宗南单片机外围器件使用手册M北京北京航空航天大学出版社,6226556周雪模拟电子技术M西安西安电子科技大学出版社,200581957左金生电子与模拟电子技术M北京电子工业出版社,20041051318尹勇单片机开发环境VISION2的开发指南M北京北京航空航天大学出版社,20041731999张斌武单片机系统PROTEUS设计与仿真M北京电子工业出版社,20055289附录附录1源代码DELAYCDEFINEDELAY_CINCLUDE”INCLUDESH”DEFINEXTAL12VOIDDELAY_LUSVOIDASM”NOP”VOIDDELAY_NUSUNSIGNEDINTNUNSIGNEDINTI0;FORI0;I1R_BYTEITMPBYTE;PRT_SET_CLK;DELAY_NUS2;PRT_CLEAR_CLK;DELAY_NUS2;BFLAG0;IFPINPWRITEW_2_BYTE;PRT_CLEAR_RST;PRT_CLEAR_CLK;VOIDRESETVOIDDDR_SET_RST;PRT_CLEAR_CLK;PRT_CLEAR_RST;PRT_SET_RST;VOIDWRITEUNSIGNEDCHARW_BYTEUNSIGNEDCHARI;DDRC0XFFFORI0;I1;UNSLGNEDCHARREADVOIDUNSIGNEDCHARI;UNSIGNEDCHARR_BYTE;UNSIGNEDCHARR_BYTE2;UNSIGNEDCHARTMPBYTE;DDR_SET_IO;R_BYTE0X00R_BYTE20X00;PRT_CLEAR_IO;DDR_CLEAR_IO;FORI0I1/R_BYTE1R_BYTE|TMPBYTE;PRT_SET_CLK;DELAY_NUS1;/DELAY_NUS2PRT_CHEAR_CLKDELAY_NUS1;DELAY_NUS2;FORI0;I1;R_BYTE2L;R_BYTE2|TMPBYTEPRT_SET_CLK;DELAY_NUS1DELAY_NUS2;PRT_CLEAR_CLK;DELAY_NUS1;DELAY_NUS2;R_BYTE4;R_BYTE24;R_BYTER_BYTE210R_BYTE;RETURNR_BYTE;HD44780CINCLUDE”INCLUDESH”DEFINEHD44780_CVOIDLCD_PULSEVOIDICDSETEDELAY_NMS1ICD_CLEAR_EDELAY_NMS1;VOIDICD_WAITVOIDASM”NOP”;VOIDICD_SENDUNSIGNEDCHARDATALCD_WAIT;DATAPORTDATALCD_PULSE;VOIDCLRSCRVOIDLCD_CLEAR_RS;LCD_CLEAR_RW;ICD_SEND0X01;LCD_WAIT;VOIDGOTOZUNSIGNEDCHARZLCD_CLEAR_RS;LCD_CLEAR_RW;LCD_SENDZ|0X80;VOIDGOTOXYUNSIGNEDCHARX,UNSIGNEDCHARYGOTOZX|Y6;VOIDPUT_CHARCHARCLCD_CLEAR_RW;LCD_SET_RS;LCD_SENDC;VOIDOUTTEXTUNSIGNEDCHARTEXTUNSIGNEDCHARI;FORI0TEXTIASM”NOP”LCD_CLEAR_E;VOIDLCD_WRITEDATAUNSIQNEDCHARDATACHARTEMPLCD_BUSY;LCD_DIR_PORT0XFFTEMPLCD_OP_PORTTEMPTEMPLCD_CLEAR_RW;SETLCDTOWRITELCD_SET_RS;LCD_SET_E;ASM”NOP”;ASM”NOP”LCD_CLEAR_E;LCD_OP_PORTDATA4|TEMPLCD_CLEAR_RW;LCD_SET_RS;LCD_SET_E;ASM”NOP”;ASM”NOP”;LCD_CLEAR_E;初始化液晶VOIDINIT_LCDVOIDLCD_INITLCD_WRITECONTROLLCD_FUNCTION_SET;LCD_WRITECONTROLLCD_OFF;LCD_WRITECONTROLLCD_CLEAR;LCD_WRITECONTROLLCD_MODE_SET;LCD_WRITECONTROLLCD_ON;LCD_WRLTECONTROLLCD_HOME;LCD_WRITECONTROL0X90;/清屏VOIDLCD_CLEARVOIDLCD_WRITECONTROL0X01;移动光标到0行0列VOIDLCD_HOMEVOIDLCD_WRITECONTROL0X02;“显示字符,在当前光标处VOIDLCD_DISPLAYCHARACTERCHARCHARLCD_WRITEDATACHAR;在FLASH中、在指定的行和列显示一个字符串VOIDLCD_DISPLAYSTRING_FCHARROW,CHARCOLUMN,UNSIGNEDCHAR_FLASHSTRINGLCD_CURSORROW,COLUMN;WHILESTRINGLCD_DISPLAYCHARACTERSTRING;在RAM中、在指定的行和列显示一个字符串VOIDLCD_DISPLAYSTRINGCHARROW,CHARCOLUMN,UNSIGNEDCHARSTRINGLCD_CURSORROW,COLUMN;WHILESTRINGLCD_DISPLAYCHARACTERSTRING;定位行和列的光标VOIDLCD_CURSORCHARROW,CHARCOLUMNSWITCHROWCASE1LCD_WRITECONTROL0X80COLUMN一1;BREAK;CASE2LCD_WRITECONTROL0XC0COLUMN一1;BREAKCASE3LCD_WRITECONTROL0X94COLUMN1;BREAKCASE4LCD_WRITECONTROL0XD4COLUMN1;BREAKDEFAULTBREAK;打开光标VOIDLCD_CURSOR_ONVOIDLCD_WRITECONTROLLCD_CURS_ON;关闭光标VOIDLCD_CURSOR_OFFVOIDLCD_WRITECONTROLLCD_ON;关闭LCD杀VOIDLCD_DISPLAY_OFFVOIDLCD_WRITECONTROLLCD_OFF;打开LCDVOIDLCD_DISPLAY_ONVOIDLCD_WRITECONTROLLCD_ON;MAINCINCLUDE”INCLUDESH”DEFINEWDRASM”WDR”UNSIGNEDCHARALARM_1_SET,ALARM_2_SET,ALARM_3_SET;_FLASHUNSIGNEDCHARTEST”DSL302TIMEIS”;VOIDMAINVOIDUNSIGNEDCHARHOUR,MIN,SEC;UNSIGNEDCHARDATE,MONTHUNSIGNEDCHARFLAG;FLAG1;PORTB0X00;DDRB0X00;DDRD0X7F;PORTD0XFFINIT_LCD;LCD_DISPLAYSTRING0,1,”INITIALIZEOK”;DELAY_NMS500LCD_WRITECONTROLLCD_CLEAR;WDR;WRITEBYTEW_PROTECT,0X00;设置时间WRITEBYTESEC_W,0X09;WRITEBYTEMIN_W,0X09;WRITEBYTEHOUR_W,0X09WHILE1SECREADBYTESEC_R;读秒MINREADBYTEMIN_R;读分HOURREADBYTEHOUR_R;读小时MONTHREADBYTEMONTH_R;DATEREADBYTEDATE_R;WDR;LCD_DISPLAYSTRING_F1,1,TEST;IFFLAGLCD_CURSOR2,1;LCD_DISPLAYCHARACTERHOUR10;LCD_DISPLAYCHARACTERHOURLO;LCD_DISPLAYCHARACTER,;WDR;LCD_DISPLAYCHARACTERM10LCD_DISPLAYCHARACTERMIN10;LCD_DISPLAYCHARACTER;WDR;LCD_DISPLAYCHARACTERDS10;LCD_DISPLAYCHARACTERSEC10LCD_CURSOR2,II;WDR;LCD_DISPLAYCHARACTERYMONTH10;LCDDISPLAYCHARACTERDYMONTH10;LCD_DISPLAYCHARACTER0;WDR;LCD_DISPLAYCHARACTERDATE10;LCD_DISPLAYCHARACTERDATE10WDR;USARTCDEFINEUSART_CINCLUDE”INCLUDESH”VOIDUSART_PUTCHARCHARCIFC飞RRUSART_PUTCHARF;WHILEUCSRAMAYBEBACKINTHEPAST,TOONESELFTHEPARANOIDWEIRDBELIEFDISILLUSIONMENT,THESEDAYS,MYMINDHASBEENVERYMESSY,INMYMINDCONSTANTLYALWAYSFEELONESELFSHOULDGOTODOSOMETHING,ORWRITESOMETHINGTWENTYYEARSOFLIFETRAJECTORYDEEPLYSHALLOW,SUDDENLYFEELSOMETHING,DOIT一字开头的年龄已经到了尾声。或许是愧疚于自己似乎把转瞬即逝的很多个不同的日子过成了同一天的样子;或许是追溯过去,对自己那些近乎偏执的怪异信念的醒悟,这些天以来,思绪一直很凌乱,在脑海中不断纠缠。总觉得自己自己似乎应该去做点什么,或者写点什么。二十年的人生轨迹深深浅浅,突然就感觉到有些事情,非做不可了。THEENDOFOURLIFE,ANDCANMEETMANYTHINGSREALLYDO而穷尽我们的一生,又能遇到多少事情是真正地非做不可DURINGMYCHILDHOOD,THINKLUCKYMONEYANDNEWCLOTHESARENECESSARYFORNEWYEAR,BUTASTHEADVANCEOFTHEAGE,WILLBEMOREANDMOREFOUNDTHATTHOSETHINGSAREOPTIONALJUNIORHIGHSCHOOL,THOUGHTTOHAVEACRUSHONJUSTMEANSTHATTHEREALGROWTH,BUTOVERTHEPASTTHREEYEARSLATER,HISWRITINGOFALUMNIINPEACE,SUDDENLYFOUNDTHATISNTREALLYGROWUP,ITSEEMSISNOTSOIMPORTANTTHENINHIGHSCHOOL,THINKDONTWANTTOGIVEVENTTOOUTYOURINNERVOICECANBEINTHEHIGHSCHOOLCHILDRENOFTHEFEELINGSINAPERIOD,BUTWASEVENTUALLYINFARCTIONWHENGRADUATIONPARTYINTHETHROAT,LATERAGAINSTOODONTHEPITCHHEHASSWEATPROFUSELY,LOOKEDATHISTHROWNABASKETBALLHOOPS,SUDDENLYFOUNDHIMSELFHASALREADYCANTREMEMBERHISAPPEARANCE童年时,觉得压岁钱和新衣服是过年必备,但是随着年龄的推进,会越来越发现,那些东西根本就可有可无;初中时,以为要有一场暗恋才意味着真正的成长,但三年过去后,自己心平气和的写同学录的时候,突然就发现是不是真正的成长了,好像并没有那么重要了;然后到了高中,觉得非要吐露出自己的心声才能为高中生涯里的懵懂情愫划上一个句点,但毕业晚会的时候最终还是被梗塞在了咽喉,后来再次站在他曾经挥汗如雨的球场,看着他投过篮球的球框时,突然间发现自己已经想不起他的容颜。ORIGINALLY,THISWORLD,CANPRODUCEACHEMICALREACTIONTOANEVENT,INADDITIONTORESOLUTELY,HAVETODO,ANDTIME原来,这个世界上,对某个事件能产生化学反应的,除了非做不可的坚决,还有,时间。APERSONSTIME,YOURIDEASAREALWAYSSPECIALTOCLEARWANT,WANT,LINEISCLEAR,ASIFNOTHINGCOULDSHAKEHISALSOONCESEEMEDTOBEDETERMINE

温馨提示

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

评论

0/150

提交评论