单片机作息时间的控制系统.docx

上传人:b****8 文档编号:29325422 上传时间:2023-07-22 格式:DOCX 页数:76 大小:528.80KB
下载 相关 举报
单片机作息时间的控制系统.docx_第1页
第1页 / 共76页
单片机作息时间的控制系统.docx_第2页
第2页 / 共76页
单片机作息时间的控制系统.docx_第3页
第3页 / 共76页
单片机作息时间的控制系统.docx_第4页
第4页 / 共76页
单片机作息时间的控制系统.docx_第5页
第5页 / 共76页
点击查看更多>>
下载资源
资源描述

单片机作息时间的控制系统.docx

《单片机作息时间的控制系统.docx》由会员分享,可在线阅读,更多相关《单片机作息时间的控制系统.docx(76页珍藏版)》请在冰豆网上搜索。

单片机作息时间的控制系统.docx

单片机作息时间的控制系统

 

济源职业技术学院

 

毕业设计

 

单片机作息时间的控制系统

电气工程系

应用电子技术

电技0801班

李芳

08020107

导教师

李春光

2010年12月

济源职业技术学院毕业设计

 

设计任务书

 

设计题目

 

作息时间的控制

 

设计要求:

 

(1)作息时间能控制电铃。

(2)作息时间能启动和关闭放音机,使用6位七段显示器来显示现在的时间。

(3)显示格式为“时分秒”从左到右依次显示。

 

(4)具有按键来作功能设置,可以设置现在的时间及显示定时设置时间一旦时间到则发出一阵声响,同时继电器启动,可以控制放音机开。

 

设计进度要求:

 

第一周:

领取题目,分析设计题目原理及设计思路。

第二周:

去图书馆查阅资料,制定大纲。

第三周:

编写程序,拟定论文。

第四周:

上机调试程序,验证实验效果。

第五周:

根据设计要求,进行编排电子稿。

第六周:

由指导教师审核,进行更改指正。

第七周:

交正规电子稿,由指导教师评阅。

第八周:

进行毕业论文答辩。

 

指导教师(签名):

 

I

济源职业技术学院毕业设计

 

摘要

 

本设计详细介绍了利用AT89C51单片机设计时间控制器的方法。

该时间控制器是

以AT89C51单片机为核心,扩展一片XICOR公司的X5045组成的小系统,控制一路继电器:

可以设定一天中的时间,设定继电器的开启时间和关闭时间,可以清除不需要的定时,能够紧急启动:

所有的设定均通过键盘实现,按键具有连击功能,每个状态

都有指示灯提示。

我们设计的作息时间控制是用单片机实现的,是为了更好的对时间控制智能化。

时间控制器包括硬件和软件。

硬件部分包括继电器,存储器和显示器接口芯片。

软件部分,主要是主程序设计。

软硬件结合在一起,先调试子程序,然后逐

级叠加调试,最后系统调试通过。

时间控制系统可以准确的显示时间,在定时时间到时发出悦耳的铃声提醒同学们按时上下课。

 

关键词:

单片机,控制,时间

 

II

济源职业技术学院毕业设计

 

要..............................................................................................................................

II

1

总体设计方案...................................................................................................................

1

2

硬件电路设计...................................................................................................................

2

2.1

AT89C51单片机简介................................................................................................

2

2.2

LED动态显示接口....................................................................................................

5

2.3

按键部分...................................................................................................................

7

2.4

中断的控制...............................................................................................................

8

3

软件设计...........................................................................................................................

9

3.1

主程序的设计...........................................................................................................

9

3.2

中断服务程序设计.................................................................................................

10

3.3

查时子程序流程图.................................................................................................

12

3.4

按键子程序流程图.................................................................................................

12

4

调试过程.........................................................................................................................

14

.................................................................................................................................

17

参考文献.............................................................................................................................

18

附录A

.................................................................................................................................

19

 

III

济源职业技术学院毕业设计

 

1总体设计方案

 

本设计题目是单片机作息时间的控制,根据设计要求,单片机作息时间的控制要实现时、分、秒的正常显示。

只有硬件和软件的有效结合才能实现单片机作息时间时、分、秒的正常显示。

硬件主要由AT89C51单片机、复位电路,按键电路、显示电路、继电器和电源组成,其核心部分是CPU。

总设计图如图1.1所示

 

图1.1总方案图

单片机即AT89C51芯片的主要功能是:

存储程序、对存储程序进行相应的处理从I/O口输出。

复位电路:

在单片机上有一输入复位引脚RST,在单片机外部用电容和电阻控制RST。

显示电路:

主要用以实现作息时间控制的结果。

电源部分:

采用+5V的电源供电。

 

1

济源职业技术学院毕业设计

 

2硬件电路设计

 

2.1AT89C51单片机简介

 

AT89C51是一种低功耗、高性能的片内含有4KB快闪可编程/擦除只读存储器的8

位COMS微控制器,使用高密度,非易失存储技术制造,并且与AT89C51引脚和指令

系统完全兼容。

芯片上的FPEROM允许在线编程或采用通用的非易失存储编程器对存

储器重复编程。

AT89C51具有多种功能的8位CPU与结合在一个芯片上,为很多嵌入式控制应

用提供了非常灵活而又便宜的方案,其性能价格比远高于AT87C51。

由于片内带EPROM

的AT87C51价格偏高,而片内带FPEROM的AT89C51价格低且与INTEL80C51兼容,这就显示出了AT89C51的优越性。

AT89C2051是一种带2K字节闪烁可编程可擦除只读存储器的单片机。

单片机的可擦除只读存储器可以反复擦除100次。

该器件采用ATMEL

高密度非易失存储器制造技术制造,与工业标准的MCS-51指令集和输出管脚相兼容。

由于将多功能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器,AT89C2051是它的一种精简版本。

AT89C51单片机为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。

2.1.1AT89C51性能及特点

(1)与MCS-51微控制器产品系列兼容。

(2)片内有4KB可在线重复编程的快闪擦写存储器(FlashMemory)。

(3)存储器可循环写入/擦除1000次。

(4)存储数据保存时间为10年。

(5)宽工作电压范围:

Vcc可为2.7V~6V。

(6)全静态工作:

可从0HZ到16MHZ。

(7)程序存储器具有3级加密保护。

(8)128*8位内部RAM。

(9)32条可编程I/O线。

(10)两个16位定时器/计数器。

(11)中断结构具有5个中断源和2个优先级。

(12)可编程全双工串行通道。

 

2

济源职业技术学院毕业设计

 

(13)空闲状态维持低功耗和掉电状态保存存储内容。

2.1.2片内快闪存储器

由于EPROM具有在线改写,并且在掉电状态保存存储数据的特点,可为用户的特

殊应用提供便利。

但是擦除和写入对于要求数据高速吞吐的应用还显得时间过长,这

是EPROM芯片的主要缺陷。

2.1.3AT89C51的引脚及管脚说明

AT89C51的内部硬件结构中除了程序存储器由FPEROM取代了87C51的EPROM外,

其余部分完全相同。

AT89C51的引脚与AT87C51的引脚完全兼容。

如图2.1所示为

AT89C51的引脚图:

 

图2.1引脚图

 

管脚说明:

VCC:

供电电压

GND:

接地

P0口:

P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。

当P1

口的管脚第一次写1时,被定义为高阻输入。

P0能够用于外部程序数据存储器,它

可以被定义为数据/地址的第八位。

在FIASH编程时,P0口作为原码输入口,当FIASH

进行校验时,P0输出原码,此时P0外部必须被拉高。

 

3

济源职业技术学院毕业设计

 

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的一些特殊功能口,如下所示:

P3.0RXD(串行输入口)

P3.1TXD(串行输出口)

 

P3.2INT0(外部中断0)

 

P3.3INT1(外部中断1)

 

P3.4T0(记时器0外部输入)

P3.5T1(记时器1外部输入)

 

P3.6WR(外部数据存储器写选通)

 

P3.7RD(外部数据存储器读选通)

 

P3口同时为闪烁编程和编程校验接收一些控制信号。

RST:

复位输入;当振荡器复位器复位时,要保持RST脚两个机器周期的高电平

时间。

ALE/PROG:

当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的低

位字节。

在FLASH编程期间,此引脚用于输入编程脉冲。

在平时,ALE端以不变的频

 

4

济源职业技术学院毕业设计

 

率周期输出正脉冲信号,此频率为振荡器频率的1/6。

因此它可用作对外部输出的脉

冲或用于定时目的。

然而要注意的是:

每当用作外部数据存储器时,将跳过一个ALE脉冲。

如想禁止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应不接。

有余输入至内部时钟信号要通过一个二分频触发器,因此对外部时钟信号的脉宽无任

何要求,但必须保证脉冲的高低电平要求的宽度。

 

2.2LED动态显示接口

 

采用动态显示方式比较节省I/O接口,硬件电路也较静态显示方式简单,但其亮

度不如静态显示方式,而且在显示位数较多时,CPU要依次扫描,占用CPU较多的时

间。

1、动态显示原理

LED动态显示就是利用单片机依次输出每一位数码管的段选码和对应于位码管

的位选择控制信号。

一位一位轮流点亮七段数码管,对每位数码管来说,每隔一段时

间点亮一次,如此循环,采用动态显示方式比较节省I/O接口,硬件电路也比静态显

 

5

济源职业技术学院毕业设计

 

示方式简单。

并利用89C51的I/O接口控制数码管的段选码,同时采用动态扫描方式,

依次循环点亮各位数码管,即可构成多位动态显示电路。

6位数码管均采用共阴极

LED,P0口作为段选码输出口,P1口作为位选码输出口。

2、七段LED数码管结构

七段LED数码管构成“日”字形,还有一只发光二极管作为小数点。

因此,这种

七段数码管又可称为八段数码管。

如图2.2a所示,这八段发光管分别称为a、b、c、d、e、f、g和dp。

通过8个发光段的不同组合,可以显示0-9和A-F等16个数字字

母,从而可以实现十六进制整数和小数的显示。

LED数码管显示器可以分为共阴极和

共阳极两种结构。

我本次设计所使用的是共阴极结构。

如图2.2b所示。

 

1a

2a

b

3

f

b

c

4g

d

5

ee

c

6d

f

7

g

dp

8dp

 

a、管脚配置b、共阴极

图2.2七段数码管

3、显示的控制

 

图2.3显示电路

 

6

济源职业技术学院毕业设计

 

如图2.3所示。

六位数码管均采用LED,P0接口作为段选码输出口,8路驱动采

用74LS244总线驱动器作为字形驱动芯片,经过8路驱动电路后接至数码管的各段,字形驱动输出0时发光。

C接口作为位选码输出口,6路驱动采用74LS07(OC门驱动器),当C接口线输出1时,选通相应位的数码管工作。

 

2.3按键部分

 

我们此次的设计使用查询式按键,使用3个按键,是由单片机的P3接口接到查询式按键的接口的。

图2.4是按键的电路原理图:

 

图2.4按键电路

按下操作键K1-K3动作如下:

(1)操作键K1:

调整时;(K1由单片机P3.0控制)

(2)操作键K2:

调整分;(K2由单片机P3.1控制)

(3)操作键K3:

调整秒;(K3由单片机P3.2控制)

如果有按键按下,则相应输出为低,否则输出为高。

单片机通过识别,判断按下什么键,有键按下后,要有一定的延时,防止由于键盘抖动而引起误操作。

按键开关的去除抖动功能:

通常消除抖动影响的方法有硬件、软件两种。

在按键较少时,可采用硬件方法消

除抖动。

在按键较多时,可采用软件方法消除抖动。

根据按键的抖动时间为5-10毫

秒,稳定闭合时间一般为十分之几至几秒时间的特点,采用软件消除抖动的方法是:

 

7

济源职业技术学院毕业设计

 

在检测到有按键按下时,执行一个10毫秒左右的延时程序,而后,再确认该键电平是

否仍保持闭合状态电平,则确认为该键处于闭合状态,这实际上是避开了按键按下时

的抖动时间.同理在检测到该键释放后,也应采用相同的步骤进行确认,从而可消除抖

动的影响.本次设计我们采用软件去抖的方式。

 

2.4中断的控制

 

1、中断是指CPU对系统发生的某个事件作出的一种反应:

CPU暂停正在执行的程序,保留现场后自动地转去执行相应的处理程序,处理完该事件后再返回断点继续执行被“打断”的程序。

对中断请求的整个处理过程是由硬件和软件结合起来而形

成的一套中断机构实施的。

发生中断时,CPU暂停执行当前的程序,而转去处理中断。

这个由硬件对中断请求作出反应的过程,称之为中断响应。

一般说来,中断响应顺序执行下述三步动作:

(1)中止当前程序的执行;

(2)保存原程序的断点信息(主要是程序计数器PC和程序状态寄存器PS的内容);

(3)转到相应的处理程序。

2、实现同步工作:

计算机有了中断功能后,就解决了快速CPU与低速外设之间的矛盾,可以使CPU和外设同时工作。

CPU启动外设以后,继续执行主程序,同时外设也在工作。

当外设把数据准备好后,就发出中断请求,请求CPU中断正在执行的程

序,转去执行中断服务程序,中断服务程序执行完之后,CPU恢复执行主程序,外设

也继续工作。

这样CPU可以指挥多个外设同时工作,从而大大提高了CPU的效率。

3、实时处理:

在实时控制系统中,为使控制系统能保持在最佳工作状态,被控

系统的各种控制参量可随时向计算机发出中断请求,要求CPU处理。

对此,CPU必须

作出快速响应和及时处理这种实时处理功能只有靠中断技术才能实现。

我们的设计需要使用许多次中断,因为我们设计的时钟计数是在中断里面,还包

括所设定的定时时间,都是有中断来完成的。

也就是每过1秒钟系统就会向中断申请中断请求,查看所设置的时间到了,如果时间到话中断允许请求,执行相应的中断请求。

也就是给单片机P2口送高电平使外接的电铃开始动作,执行此次的请求后,在进入下一次中断的扫描。

 

8

济源职业技术学院毕业设计

 

3软件设计

 

单片机作息时间控制的动作利用时间计时处理来做秒计数,当早晨所设置的起床时间6:

00到了,电铃就会自动开启,响十秒后电铃关闭,第一节课7:

50预备电铃开启10秒后自动关闭,10分钟之后上课铃响起,正式上课。

45分钟后,电铃又会自动打开提醒同学们下课。

当所设置的课间操时间9:

40到时继电器就会自动启动,

由继电器开启放音机。

所设时间为20分钟到之后,由继电器关闭放音机。

到11:

50

时电铃又会自动打开提醒同学们放学。

当14:

20分的时候电铃又会自动打开,提醒同学们该上课了,做好上课准备,到15:

15分的时候,电铃又开始工作提醒同学们下课,到16:

10分的时候继电器就会自动启动,下课铃响起,提醒同学们下课。

这一切的定时是由单片机定时器负责定时计数的,不会因为按键处理而中断时间秒数的增加,时,分,秒数据是存在变量内并写入七段显示器的缓冲区内,而由显示器扫描程序中定时扫描而显示出时间。

 

3.1主程序的设计

 

在主控程序循环中主要工作为扫描是否有按键,若有按键则应做相应的功能处

理,同时也扫描显示器显示时间数据,并检查所设置的时间是否到了,图3.1为主程

序控制的工作流程图。

时间计时处理程序是等过了1S后,则更新时间数据,将最新

的时,分,秒的数据转换为数字数据并显示在七段显示器上。

程序中是这样判断是否过了1S的:

设一旧秒数变量,当新旧秒数变量不一样时,

则表示已过了1S,要做相关程序时间处理了。

(主程序见附录A)

 

9

济源职业技术学院毕业设计

 

图3.1主程序流程图

 

3.2中断服务程序设计

 

我们的设计需要使用许多次中断,因为我们设计的时钟计数是在中断里面,还包括所设定的定时时间,都是有中断来完成的。

如3.2图所示的中断程序流程图。

也就是每过1秒钟系统就会向中断申请中断请求,查看所设置的时间到了,如果时间到话

中断允许请求,执行相应的中断请求。

也就是给单片机P2口送高电平使外接的电铃开始动作,执行此次的请求后,在进入下一次中断的扫描。

(程序见附录A)

 

10

济源职业技术学院毕业设计

 

中断入口

 

中断入口

 

1S到没?

 

R7重赋初值

 

调查时子程序

 

地址针初始化

 

取数

 

调整时间

 

十进制调整

 

送回计数单元

 

是否计到小时单元

 

计数单元内容

是否等60H?

计数单元内容

是否等2

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > IT计算机 > 电脑基础知识

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1