基于51单片机的秒表设计.docx
- 文档编号:25364281
- 上传时间:2023-06-07
- 格式:DOCX
- 页数:14
- 大小:115.21KB
基于51单片机的秒表设计.docx
《基于51单片机的秒表设计.docx》由会员分享,可在线阅读,更多相关《基于51单片机的秒表设计.docx(14页珍藏版)》请在冰豆网上搜索。
基于51单片机的秒表设计
江西理工大学应用科学学院信息工程系
单片机原理与应用课程设计报告
设计题目:
基于51单片机的秒表设计
专业:
电子信息工程
班级:
电信121
学号:
08060312109
参与人员:
贺佳、周代元、周昶旭、张浥中
指导老师:
王苏敏
完成日期:
2015年1月20日
指导老师评语:
得分:
指导教师签名:
目录
1设计任务和性能指标1
1.1课题内容1
1.2课题要求1
2设计方案2
2.1需求分析2
2.2方案论证2
3系统软件设计5
4.1系统软件流程图5
4.2实验程序清单5
4系统硬件设计7
5.1调试步骤7
5.2性能分析7
5系统硬件设计8
参考文献9
1设计任务和性能指标
1课题内容要求及目的
1.1课题内容
用AT89C51设计一个秒表,该秒表课可显示0.0~99.9秒的时间,进行相应的单片机硬件电路的设计并进行软件编程利用单片机定时器/计数器中断设计秒表,从而实现秒、十分之一秒的计时。
综合运用所学的《单片机原理与应用》理论知识,通过实践加强对所学知识的理解,具备设计单片机应用系统的能力。
通过本次系统设计加深对单片机掌握定时器、外部中断的设置和编程原理的全面认识复习和掌握。
本系统利用单片机的定时器/计数器定时和记数的原理,通过采用proteus仿真软件来模拟实现。
模拟利用AT89C51单片机、LED数码管以及控件来控制秒表的计数以及计位!
其中有三位数码管用来显示数据,显示秒(两位)和十分之一秒,十分之一秒的数码管计数从0~9,满十进一后显示秒的数码管的数字加一,并且十分之一秒显示清零重新从零计数。
计秒数码管采用三位的数码管,当计数超过范围是所有数码管全部清零重新计数。
1.2课题要求
本课题是基于单片机的秒表系统设计,它的具体要求有以下几点:
(1)用单片机AT89C51实现;
(2)以0.1秒为最小单位进行显示;
(3)秒表量程为0.0-99.9秒,用LED显示;
(4)有清零、开始、停止功能。
1.3课题目的
通过课程设计,进一步熟悉和掌握AT89C51单片机的结构及工作原理,掌握以单片机核心的电路设计的基本方法和技术,了解表关电路参数的计算方法。
通过完成一个包括电路设计和程序开发的完整过程,进一步了解开发一单片机应用系统的全过程,通过此综合训练,为以后毕业设计打下一定的基础。
(1)利用单片机定时器计数器中断设计秒表,从而实现秒、十分之一秒的计时。
(2)综合运用所学的《单片机原理与应用》理论知识,通过实践加强对所学知识的理解,具备设计单片机应用系统的能力,加深对单片机课程的全面认识。
(3)通过本次课程设计能够对程序进行编辑,校验。
(4)通过本次系统设计加深对单片机掌握定时器、外部中断的设置和编程原理的全面认识复习和掌握,对单片机实际的应用作进一步的了解。
(5)通过本次系统设计,增强自己的动手能力。
认识单片机在日常生活中的应用的广泛性,实用性。
(6)该实验通过单片机的软件延时设计,设计简单的计时器系统,能正确的计时。
2.1需求分析
近年来,随着科学技术的进步和时代的发展,人们对秒表的功能和精度提出了越来越高的要求,各种秒表的设计也越来越重要。
秒表计时器是在一种计时器上实现两种功能的一种器件。
它广泛应用于各种场所,同时它的小巧,价格廉价,精确度高,使用方便,功能齐全,便于集成化。
而受广大消费者的喜爱。
2.2方案论证
现今的计时器通常只能通过启/停按键实现断点计时的功能,即通过启/停按键来记录一段时间。
这种计时器查看的时间只能为计时结束时刻。
实际的应用中往往需要在不影响正常计时的基础上,能查看记录过程中的某些点的时间。
本课设即针对此问题,设计了一种能通过按键方式查看记录过程中任一时刻值的计时器。
这种计时器在查看中间值时不会影响整个记录过程,并且能把相应数据送入存储模块及显示模块,以便查看。
本系统采用AT89C51单片机作控制器,LED数码管,实现显示时、分、秒,以24小时计时方式。
为了实现LED显示器的数字显示,可以采用静态显示法和动态显示法。
由于静态显示法需要数据锁存器等硬件,结构较为复杂,考虑时钟显示只有六位,且系统没有其他复杂的处理任务,所以采用动态扫描法实现LED的显示。
单片机采用AT89C51系列,有足够的空余硬件资源实现其它的扩充功能。
3系统软件设计
3.1软件程序流程图
根据课题内容,可作出主流程序树状图如图3.1所示:
图3.1
3.2实验程序清单:
HAOMIAOEQU34H
MIAOEQU35H
SHIMIAOEQU36H
ORG0000H
AJMPSTART
ORG0030H
START:
CLRC
SETBP1.6
SETBP1.5
SETBP1.4
MOVHAOMIAO,#0
MOVMIAO,#0
MOVSHIMIAO,#0
MOVDPTR,#TABLE
MOVA,#00H
MOVCA,@A+DPTR
CLRP1.6
MOVP2,A
MOVA,#00H
MOVCA,@A+DPTR
CLRP1.4
MOVP2,A
MOVDPTR,#TABLE1
MOVA,#00H
MOVCA,@A+DPTR
CLRP1.5
MOVP2,A
LCALLKAISHI
LCALLMAIN
SHIWEI:
SETBP1.5
MOVDPTR,#TABLE;十秒位显示
MOVMIAO,#0;使秒位从零位重新循环
INCSHIMIAO
MOVA,SHIMIAO
CLRC
SUBBA,#6
JZSTART
AJMPMAIN
RET
TINGZHI:
MOVA,#00H;判断是否有清零指
MOVA,P3
ANLA,#04H
JZSTART
MOVA,#00H;判断是否有停止指令
MOVA,P3
CLRC
ANLA,#02H
LCALLYANSHI
JZMAIN
LJMPTINGZHI
START1:
LJMPSTART
SHIWEI1:
LJMPSHIWEI
MAIN:
SETBP1.5
SETBP1.4
SETBP1.6
MOVA,#00H;判断是否有清零指令
MOVA,P3
ANLA,#04H
JZSTART1
MOVA,#00H;判断是否有停止指令
MOVA,P3
CLRC
ANLA,#02H
JZTINGZHI
MOVDPTR,#TABLE;0.1位秒显示
INCHAOMIAO;加一,可查下一位数据
MOVA,HAOMIAO;判断是否进位
CLRC
SUBBA,#10
JZMIAOZHEN
LCALLYANSHI;延时0.1秒
AJMPMAIN
RET;继续计时
MIAOZHEN:
SETBP1.4
MOVDPTR,#TABLE1;秒位显示
MOVHAOMIAO,#0;使0.1秒从零重新循环
INCMIAO;加一,可查下一位数据
MOVA,MIAO;判断是否进位
CLRC
SUBBA,#10
JZSHIWEI1
LCALLSND
AJMPMAIN;返回0.1秒计
YANSHI:
MOVR6,#30
DL2:
MOVA,#00H;判断是否有清零指令
MOVA,P3
ANLA,#04H
JZSTART1
MOVDPTR,#TABLE
MOVA,SHIMIAO
MOVCA,@A+DPTR
CLRP1.6
MOVP2,A
ACALLYIHAOMIAO
SETBP1.6
MOVA,HAOMIAO
MOVCA,@A+DPTR
CLRP1.4
MOVP2,A
ACALLYIHAOMIAO
SETBP1.4
MOVDPTR,#TABLE1
MOVA,MIAO
MOVCA,@A+DPTR
CLRP1.5
MOVP2,A
ACALLYIHAOMIAO
SETBP1.5
DJNZR6,DL2
RET
YIHAOMIAO:
MOVR7,#250
CV:
NOP
NOP
DJNZR7,CV
RET
KAISHI:
MOVA,#0
MOVA,P3
ANLA,#01H
JNZKAISHI
RET
SND:
SETBP1.0
MOVR1,#1EH
DL:
MOVR0,#0F9H
DL1:
DJNZR0,DL1
DJNZR1,DL
CLRP1.0
RET
TABLE:
DB3FH,06H,5BH,4FH,66H,6DH,7DH,07H,7FH,6FH;0,1,2,3,4,5,6,7,8,9
TABLE1:
DB0BFH,086H,0DBH,0CFH,0E6H,0EDH,0FDH,087H,0FFH,0EFH
END
}
4系统硬件设计
AT89C51单片机简介
AT89C51是一种低功耗、高性能的片内含有4KB快闪可编程/擦除只读存储器(FPEROM-FlashProgrammableandEraseableReadOnlyMemory)的8位CMOS微控制器,使用高密度、非易失存储技术制造,并且与89C51引脚和指令系统完全兼容。
引脚分别如图2.1所示。
图2.1
图2.1所示的单片机是引脚双列直插封装方式,电源引脚40脚与接地脚20。
P0口作输入口使用时,应先向口锁存器写入1。
P1口是一个带有内部上拉电阻的8位双向I/O端口。
P1的输出缓存可驱动4个TTL输入。
P2口是一个带有内部上拉电阻的8位双向I/O端口。
P3口也是一个带有内部上拉电阻的8位双向I/O端口,P3端口还用于一些复用功能。
5系统硬件设计
5.1调试步骤
(1) 分析各单元电路图,并分析其各部分的功能;
(2) 用仿真软件仿真电路的功能,并检查是否有错,无误后进行下步工作;
(3) 查找有关文献了解各元件的功能及引脚和有关的资料;
5.2设计实验电路图
设计的实验原理图如下所示:
实验设计总结
为期两周的课程设计,主要是以上机操作为主,在实验室查资料,编程序,画图。
设计语言主要是采用c语言和汇编语言的自上而下的设计方法。
Proteus中,自上向下的设计,就是在整个设计流程中各设计环节逐步精益求精的过程,应用Proteus运行自上而下的设计,就是使用Proteus模型在所有综合级别上对硬件进行说明和仿真测试。
顶层文件采用了原理图的方法设计,使各模块之间的层次关系清晰。
在秒表计时器实际设计过程中,所有的模块都是通过不同进制的计数器来实现其主要功能的,各模块之间是通过进位信号连接在一起的。
一开始由于没有一定的合理的思路,走了不少弯路。
在查阅了相关资料之后,解决了相关的问题,使我的程序更加优化。
通过这次课程设计,我进一步熟悉了Proteus软件的使用和操作方法。
对c语言和汇编语言的自上向下的设计方法有了进一步的认识,在底层文件具备的条件下,使原理图可以使设置更加简单,使程序清晰,增加可读性。
当然这次课程设计也存在着不足之处,计时不够足够的精确等。
单片机课程设计,是对单片机知识的验证,可以帮助我们理解巩固所学知识,激发我们对单片机课程的兴趣,更锻炼了我们独立思考、开拓创新的能力。
通过这次课程设计我也发现了自身存在的不足之处,虽然感觉理论上已经掌握,但在运用到实践的过程中仍有意想不到的困惑,经过一番努力才得以解决。
这也激发了我今后努力学习的兴趣,我想这将对我以后的学习产生积极的影响。
其次,这次课程设计让我充分认识到合作的重要性,只有合作才能保证整个项目的有条不絮。
在设计过程中,非常感谢同学们的指导,才使设计进展的比较顺利。
另外在课程设计的过程中,当我们碰到不明白的问题时,指导老师总是耐心的讲解,给我的设计以极大的帮助,使我获益匪浅。
因此非常感谢王苏敏老师的教导。
通过这次设计,我懂得了学习的重要性,了解到理论知识与实践相结合的重要意义,学会了坚持、耐心和努力,这将为自己今后的学习和工作做出了最好的榜样。
参考文献:
1、单片机原理及应用;
2、数字电子技术基础;
3、模拟电子技术基础;
4、高频电子线路;
........忽略此处.......
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 51 单片机 秒表 设计