毕业论文——基于51单片机的电子万年历的设计.doc

上传人:滴答 文档编号:1254753 上传时间:2019-01-19 格式:DOC 页数:20 大小:246KB
下载 相关 举报
毕业论文——基于51单片机的电子万年历的设计.doc_第1页
第1页 / 共20页
毕业论文——基于51单片机的电子万年历的设计.doc_第2页
第2页 / 共20页
毕业论文——基于51单片机的电子万年历的设计.doc_第3页
第3页 / 共20页
毕业论文——基于51单片机的电子万年历的设计.doc_第4页
第4页 / 共20页
毕业论文——基于51单片机的电子万年历的设计.doc_第5页
第5页 / 共20页
点击查看更多>>
资源描述

1、目 录摘 要 .IABSTRACT.II1 引言 .12 功能要求 .13 方案论证与设计 .13.1 控制部分的方案选择 .13.2 测温部分的方案选择 .13.3 显示部分的方案选择 .24 系统硬件电路设计 .24.1 主控器 AT89C52 .24.2 时钟电路 DS1302 .34.2.1. DS1302 的性能特性 .34.2.2 DS1302 数据操作原理 .34.3 测温电路的设计 .54.3.1 温度传感器工作原理 .54.3.2 DS18B20 与单片机的接口电路 .84.4 显示电路的设计 .94.5 键盘接口的设计 .105 系统程序的设计 .105.1 阳历程序设计

2、.105.2 时间调整程序设计 .115.3 温度程序设计 .125.3.1 主程序 .125.3.2 读出温度子程序 .125.3.3 温度转换命令子程序 .125.3.4 计算温度子程序 .135.3.5 显示数据刷新子程序 .13 调试及性能分析 .136.1 调试步骤 .146.2 性能分析 .14 总结 .14参考文献 .14致 谢 .14I基于 51 单片机的电子万年历的设计摘 要电子万年历是单片机系统的一个应用,由硬件和软件相配合使用。硬件由主控器、时钟电路、温度检测电路、显示电路、键盘接口 5 个模块组成。主控模块用 AT89C52、时钟电路用时钟芯片DS1302、显示模块用

3、LED 数码管、温度检测采用 DS18B20 温度传感器、键盘接口电路用普通按键接上拉电阻完成;软件利用 C 语言编程实现单片机程序控制。单片机通过时钟芯片 DS1302 获取时间数据,DS18B20 采集温度信号送该给单片机处理,单片机再把时间数据和温度数据送给74LS154 译码,然后通过三极管 C9015 放大驱动 LED 数码管显示阳历年、月、日、时、秒、闹钟、星期、温度。关键词 电子万年历;单片机;温度传感器;时钟;数码显示AbstractElectronic perpetual calendar which is an application of the single-chip

4、processor system, is utilized by combining hardware and software. And Hardware is composed of five modules: Main control unit, clock circuit, temperature test circuit, display circuit, keyboard interface. Main control board adopts AT89S52, clock circuit adopts the DS1302 clock chip, display module a

5、dopts the LED digital tube, and temperature test adopts the DS18B20 temperature sensor, keyboard interface circuit is completed by connecting ordinary button with pull-up resistor. Software takes advantage of C to program, so as to realize the programmed control of single-chip processor. Single-chip

6、 processor gets the time data through using the DS1302 clock chip. The DS18B20 gathers temperature signals and transmits them to single-chip processor. Then, single-chip processor transmits the time data and the temperature data to the 74LS154 decoder. Lastly, the LED displays solar calendar year, y

7、ear, month, day, hour, minute, second, alarm clock, week and temperature with being enlarged and driven by the C9015 triode.Keywords: Electronic perpetual calendar; single-chip processor; temperature sensor; clock; digital display共 15 页,第 1 页1 引言随着微电子技术和超大规模集成电路技术的不断发展,家用电子产品不但种类日益丰富,而且变得更加经济实用,单片微型

8、计算机体积小、性价比高、功能强、可靠性高等独有的特点,在各个领域得到了广泛的应用。电子万年历是一种应用非常广泛的日常计时工具,数字显示的日历钟已经越来越流行,特别是适合在家庭居室、办公室、大厅、会议室、车站和广场等使用。LED数字显示的日历钟显示清晰直观、走时准确、可以进行夜视,并且还可以扩展出多种功能。功能也越来越齐全,除了公历年月日、时分秒、星期显示及闹铃。但通过我们对各种电子钟表、历的不断观察总结发现目前市场的钟、历都存在一些不足之处,比如:时钟不精确、产品成本太高、无环境温度显示等,这都给人们的使用带来了某些不便。为此设计了一种功能全面、计时准确、成本低廉的基于 51 单片机的万年历。

9、2 功能要求1. 万年历能用数码管显示阳历年、月、日、星期、小 时、分、秒并设置指定时间的闹铃。2. 数字式温度计要求测温范围-50100C , LED 数码管直读显示。3 方案论证与设计3.1 控制部分的方案选择1. 用可编程逻辑器件设计。可采用 ALTERA 公司的 FLEX10K 系列 PLD 器件。设计起来结构清晰,各个模块,从硬件上设计起来相对简单,控制与显示的模块间的连接也会比较方便。但是考虑到本设计的特点,EDA 在功能扩展上比较受局限,而且 EDA 占用的资源也相对多一些。从成本上来讲,用可编程逻辑器件来设计也没有什么优势。2. 用凌阳 16 位单片机设计。凌阳 16 位单片机

10、有丰富的中断源和时基,方便本实验的设计。它的准确度相当高,并且 C 语言和汇编兼容的编程环境也很方便来实现一些递归调用。I/O 口功能也比较强大,方便使用。用凌阳 16 位单片机做控制器最有特色的就是它的可编程音频处理,可完成语音的录制播放和识别。这些都方便对设计进行扩展,使设计更加完善。成本也相对低一些。但是,在控制与显示的结合上有些复杂,显示模组资源相对有限,而且单片机的稳定性不是很高。3. 主控芯片使用 51 系列 AT89C52 单片机,时钟芯片用美国 DALLAS 公司推出的一种高性能、低功耗、带 RAM 的时钟 DS1302。采用 DS1302 作为主要计时芯片,可以做到计时准确。

11、更重要的是,DS1302 可以在很小电流的后备电源(2.55V 电源,在 2.5V 时耗电小于 300nA)下继续计时,停电后时钟无需重新调整,并可编程选择多种充电电流来对后备电源进行慢速充电,可以保证后备电源基本不耗电,还可自设闹铃,阳历、星期与年月日自动对应。本系统采用了此方案。3.2 测温部分的方案选择1.在日常生活及工农业生产中经常要乃至温度的检测及控制,传统的测温元件有热电偶和热电阻。而热电偶和热电阻测一般都是电压,再转换成对应的温度,需要比较多的外部硬件支持,硬件电路复杂,软件调试复杂,制作成本高。2.与前面相比,采用美国 DALLAS 半导体公司继 DS1820 之后推出的一种改

12、进型智能温度传感器DS18B20 作为检测元件,测温范围为-55125,最大分辨率可达 0.0625。DS18B20 可以直接读出被测温度值,而且采用 3 线制与单片机相连,减少了外部的硬件电路,具有低成本和易使用的特点。马培:基于 51 单片机的电子万年历设计共 15 页,第 2 页3.3 显示部分的方案选择1. 液晶显示方式。液晶显示效果出众,可以运用菜单项来方便操作,但是在显示时,特别是使用秒表功能时扫描速度跟不上,屏幕会有明显的闪烁。而且由于 61 板的存储空间有限,液晶显示就不能与语音播抱程序同时实现。这些大大影响了电子万年历的性能。2. 相比液晶显示,8 段数码管虽然操作比液晶显示

13、略显繁琐,但可视范围十分宽,而且经济实惠,也不需要复杂的驱动程序。所以最后选择 LED 数码管显示方案。综上所述,按照系统设计功能的要求,确定硬件系统由主控制器、时钟模块、测温电路、显示模块、键盘接口共 5 个模块组成,总体系统构成框图如图 3.1 所示。图 3.1 电子万年历系统构成框图4 系统硬件电路设计电子万年历电路原理图见附件一,系统由主控制器 AT89C52、时钟芯片 DS1302、温度传感器DS18B20 传感器、显示电路及键盘扫描电路组成。4.1 主控器 AT89C52ATMEL 公司生产的 AT89C52 单片机采用高性能的静态 80C51 设计,由先进工艺制造,并带有非易失性

14、 Flsah 程序存储器。它是一种高性能、低功耗的 8 位 CMOS 微处理芯片,市场应用最多。主要性能特点有:8KB Flash ROM,可以檫写 1000 次以上,数据保存 10 年。256 字节内部 RAM。电源控制模式时钟可停止和恢复;空闲模式;掉电模式。 6 个中断源。4 个中断优先级。4 个 8 位 I/O 口。全双工增强型 UART。3 个 16 位定时/计数器,T0、T1(标准 80C51)和增加的 T2(捕获和比较) 。全静态工作方式:024MHz。DS1302 时钟模块AT89C52主控制器DS18B2 温度探测键盘扫描电路数码显示电路共 15 页,第 3 页4.2 时钟电

15、路 DS13024.2.1. DS1302 的性能特性实时时钟,可对秒、分、时、日、周、月以及带闰年补偿的年进行计数;用于高速数据暂存的 318 位 RAM;最少引脚的串行 I/O;2.55.5V 电压工作范围;2.5V 时耗电小于 300nA;用于时钟或 RAM 数据读/写的单字节或多字节(脉冲方式)数据传送方式;简单的 3 线接口;可选的慢速充电(至 Vcc1)的能力。DS1302 时钟芯片包括实时时钟/日历和 31 字节的静态 RAM。它经过一个简单的串行接口与微处理器通信。实时时钟/日历提供秒、分、时、日、周、月和年等信息。对于小于 31 天的月和月末的日期自动调整,还包括闰年校正的功

16、能。时钟的运行可以采用 24h 或带 AM(上午)/PM(下午)的12h 格式。采用三线接口与 CPU 进行同步通信,并可采用突发方式一次传送多个字节的时钟信号或RAM 数据。DS1302 有主电源/后备电源双电源引脚:Vcc1 在单电源与电池供电的系统中提供低电源,并提供低功率的电池备份;Vcc2 在双电源系统中提供主电源,在这种运用方式中,Vcc1 连接到备份电,以便在没有主电源的情况下能保存时间信息以及数据。DS1302 由 Vcc1或 Vcc2中较大者供电。当 Vcc2大于 Vcc1+0.2V 时,Vcc2 给 DS1302 供电;当 Vcc2小于 Vcc 时, DS13026 由 V

17、cc1供电。4.2.2 DS1302 数据操作原理DS1302 在任何数据传送时必须先初始化,把 RST 脚置为高电平,然后把 8 位地址和命令字装入移位寄存器,数据在 SCLK 的上升沿被输入。无论是读周期还是写周期,开始 8 位指定 40 个寄存器中哪个将被访问到。在开始 8 个时钟周期,把命令字节装入移位寄存器之后,另外的时钟周期在读操作时输出数据,在写操作是写入时写入数据。时钟脉冲的个数在单字节方式下为 8 加 8,在多字节方式下为 8 加字节数,最大可达 248 字节数。如果在传送过程中置 RST 脚为低电平,则会终止本次数据传送,并且 I/O 引脚变为高阻态。上电运行时,在 Vcc

18、 大于等于 2.5V 之前,RST 脚必须保持低电平。只有在 SCLK 为低电平时,才能将RST 置为高电平。DS1302 的引脚及内部结构图如图 4.1 所示,表 4.1 为各引脚的功能。DS1302 的控制字如图 4.2 所示。控制字节的最高位(位 7)必须是逻辑 1;如果它为 0,则不能把数据写入到 DS1302 中。位 6 如果为 0,则表示存取日历时钟数据;为 1 表示存取 RAM 数据。位 51(A4A0)指示操作单元的地址。最低有效位(位 0)如为 0,表示要进行写操作;为 1 表示进行读操作。控制字节总是从最低位开始输入/输出。为了提高对 32 个地址的寻址能力(地址/命令位

19、15=逻辑 1) ,可以把时钟/日历或 RAM 寄存器规定为多字节(burst)方式。位 6 规定时钟或 RAM,而位 0 规定读或写。在时钟/日历寄存器中的地址 931 或 RAM 寄存器中的地址 31 不能寄存数据。在多字节方式中,读或写从地址 0 的位 0开始。必须按数据传送的次序写最先的 8 个寄存器。但是,当以多字节方式写 RAM 时,为了传送数据不必写所有 31 字节。不管是否写了全部 31 字节,所写的每一字节都将传送至 RAM。马培:基于 51 单片机的电子万年历设计共 15 页,第 4 页1234 5678 Vcc1SCLKI/ORSTVcc2X1X2GND电源控制Vcc1V

20、cc2GND输入移位寄存器I/OSCLK实时时钟命令与控制逻辑振荡器与分频器318RAMRSTX2X132.768kHzDATA BUS图 4.1 DS1302 引脚及内部结构表 4.1 DS1302 引脚功能引脚号 引脚名称 功 能1 Vcc2 主电源2,3 X1,X 2 振荡源,外界 32.768kHz 晶振4 GND 地线5 RST 复位/片选线6 I/O 串行数据输入/输出端(双向)7 SCLK 串行数据输入端8 Vcc1 后备电池7 6 5 4 3 2 1 01RAMCKA4 A3 A2 A1 A0RAMK图 4.2 DS1302 的控制字DS1302 共有 12 个寄存器,其中有

21、7 个寄存器与日历、时钟相关,存放的数据位为 BCD 码形式。其日历、时间寄存器及其控制字见表 3.2,其中奇数为读操作,偶数为写操作。时钟暂停:秒寄存器的位 7 定义位时钟暂停位。当它为 1 时,DS1302 停止震荡,进入低功耗的备份方式。通常在对 DS1302 进行写操作时(如进入时钟调整程序) ,停止震荡。当它为 0 时,时钟将开始启动。AMPM/1224小时方式:小时寄存器的位 7 定义为 12 或 24小时方式选择位。它为高电平时,选择 12小时方式。在此方式下,位 5 是 AM/PM 位,此位是高电平时表示 PM 低电平表示共 15 页,第 5 页AM。在 24小时方式下,位 5

22、 为第二个 10小时位(2023h) 。表 4.2 内部寄存器地址和内容命令字节 积存器内容积存器名写 读 取值范围 7 6 5 4 3 2 1 0秒积存器 80H 81H 0059 CH 10S SEC分积存器 82H 83H 0059 0 10 min MIN小时积存器 84H 85H 0023 或 0112 12/24 0 10A/P HR HR日积存器 85H 87H 0128, 29,30,31 0 0 10DATE DATE月积存器 88H 89H 0112 0 0 0 10M MONTH周积存器 8AH 8BH 0107 0 0 0 0 0 DAY年积存器 8CH D3H 009

23、9 10YEAR YEARDS1302 的晶震选用 32.768kHz,电容推荐值为 33pF,因为震荡频率较低,也可以不接电容,对计时精度影响不大。4.3 测温电路的设计测温电路主要使用温度传感器 DS18B20,由于精度要求不高所以采用 2 位共阳 LED 数码管以动态扫描法实现温度显示。其设计原理图如附件一所示。4.3.1 温度传感器工作原理DS18B20 温度传感器是美国 DALLAS 半导体公司最新推出的一种改进型智能温度传感器,与传统的热敏电阻等测温元件相比,它能直接读出被测温度,并且可根据实际要示通过简单的编程实现912 位的数字值读数方式。DS18B20 的性能特点如下:独特的

24、单线接口仅需要一个端口引脚进行通信;多个 DS18B20 可以并联在唯一的三线上,实现多点组网功能;无须外部器件;可通过数据线供电,电压范围为 3.03.5V;零待机功耗;温度以 9 或 12 数字量读出;用户可定义的非易失性温度报警设置;报警搜索命令识别并标志超过程序限定温度(温度报警条件)的器件;负电压特性,电源极性接反时,温度计不会因发热而烧毁,但不能正常工作。DS18B20 采用 3 脚 PR35 封装或脚 SOIC 封装,其内部结构框图如图 4.3 所示。64 位 ROM 的位结构如图 4.4 所示。开始 8 位是产品类型的编号,接着是每个器件的唯一的序号,共有 48 位,最后 8

25、位是前面 56 位的 CRC 检验码,这也是多个 DS18B20 可以采用一线进行通信的原因。非易失性温度报警触发器 TH 和 TL,可通过软件写入户报警上下限。DS18B20 温度传感器的内部存储器还包括一个调整暂存 RAM 和一个易失性的可电擦除的EERAM。高速暂存 RAM 的结构为 8 字节存储器,结构如图 4.5 所示。头 2 个字节包含测得的温度信马培:基于 51 单片机的电子万年历设计共 15 页,第 6 页息,第 3 和第 4 节是 TH 和 TL 的拷贝,是易失的,每次上电复位时被刷新。第 5 个字节为配置寄存器,它的内容用于确定温度值的数字转换分辨率。DS18B20 工作时

26、按此寄存器中的分辨率将温度转换为相应64 位ROM和单线接口图 4.DS18B20 内部结构图存储器与控制逻辑高速缓存温度传感器高温触发器 TH低温触发器 TL配置寄存器8 位 CRC 发生器I/OCVDD8 位检验 CRC 48 位序列号 8 位工厂代码(10H)MSB LSB MSB LSB MSB LSB图 4.4 64 位 ROM 结构图温度 LSB温度 MSBTH 用户字节 1TL 用户字节 2 TH 用户字节 1配置寄存器 TL 用户字节 2保留保留保留CRC1 字节2 字节3 字节4 字节5 字节6 字节7 字节8 字节9 字节图 4.5 高速暂存 RAM 结构图精度的数值。该字

27、节各位的定义如图 4.6 所示。低 5 位一直 1,M 是测试模式位,用于设置DS18B20 在工作模式还是在测试模式。在 DS18B20 出厂时该位被设置为 0,用户不要去改动,R1 和R0 决定温度转换的精度位数,即用来设置分辨率,定义方法见表 4.3。由表 4.3 可见,DS18B20 温度转换的时间比较长,而且设定的分辨率越高,所需要的温度数据转换时间就越长。因此,在实际应用中要将分辨率和转换时间权衡考虑。高速暂存 RAM 的第 6、7、8 字节保留未用,表现为全逻辑 1。第 9 字节读出前面所有 8 字节的CRC 码,可用来检验数据,从而保证通信数据的正确性。当 DS18B20 接收到温度转换命令后,开始启动转换。转换完成后的温度值就以 16 位带符号扩EEROM

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文资料库 > 毕业论文

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。