单片机流水灯课程设计报告书.docx
- 文档编号:12818822
- 上传时间:2023-06-08
- 格式:DOCX
- 页数:28
- 大小:816.66KB
单片机流水灯课程设计报告书.docx
《单片机流水灯课程设计报告书.docx》由会员分享,可在线阅读,更多相关《单片机流水灯课程设计报告书.docx(28页珍藏版)》请在冰点文库上搜索。
单片机流水灯课程设计报告书
1设计任务与要求
1.1设计任务
设计一个通过单片机P2口控制流水灯的系统
1.2设计要求
(1)至少8个灯;
(2)可实现不同的亮灯(如左循环,右循环,间隔闪等)。
2设计方案
2.1设计思路
整个系统工作由软件程序控制运行,根据需要,可以上电后系统经过初始化,进入用户设定模式状态。
于STC89C52单片机的彩灯控制方案,实现对LED红灯的控制。
本方案以STC89C52单片机作为主控核心,与驱动等模块组成核心主控制模块。
在主控模块上设有晶振电路和8个LED灯,根据需要编写若干种亮灯模式,根据各种亮灯时间的不同需要,在不同时刻输出灯亮或灯灭的控制信号。
2.2器件介绍与作用
2.2.1STC89C52RC简介
STC89C52是STC公司生产的一种低功耗、高性能CMOS8位微控制器,具有8K在系统可编程Flash存储器。
STC89C52使用经典的MCS-51核,但做了很多的改进使得芯片具有传统51单片机不具备的功能。
在单芯片上,拥有灵巧的8位CPU和在系统可编程Flash,使得STC89C52为众多嵌入式控制应用系统提供高灵活、超有效的解决方案。
具有以下标准功能:
8k字节Flash,512字节RAM,32位I/O口线,看门狗定时器,置4KBEEPROM,MAX810复位电路,3个16位定时器/计数器,4个外部中断,一个7向量4级中断结构(兼容传统51的5向量2级中断结构),全双工串行口。
另外STC89C52可降至0Hz静态逻辑操作,支持2种软件可选择节电模式。
空闲模式下,CPU停止工作,允许RAM、定时器/计数器、串口、中断继续工作。
掉电保护方式下,RAM容被保存,振荡器被冻结,单片机一切工作停止,直到下一个中断或件复位为止。
最高运作频率35MHz,6T/12T可选
图2.1STC89C52RC实物图
图2.2STC89C52RC管脚图
2.2.2STC89C52RC参数
1.增强型8051单片机,6时钟/机器周期和12时钟/机器周期可以任意选择,指令代码完全兼容传统8051.[2]
2.工作电压:
5.5V~3.3V(5V单片机)/3.8V~2.0V(3V单片机)
3.工作频率围:
0~40MHz,相当于普通8051的0~80MHz,实际工作频率可达48MHz
4.用户应用程序空间为8K字节
5.片上集成512字节RAM
6.通用I/O口(32个),复位后为:
P0/P1/P2/P3是准双向口/弱上拉,P0口是漏极开路输出,作为总线扩展用时,不用加上拉电阻,作为I/O口用时,需加上拉电阻。
7.ISP(在系统可编程)/IAP(在应用可编程),无需专用编程器,无需专用仿真器,可通过串口(RxD/P3.0,TxD/P3.1)直接下载用户程序,数秒即可完成一片
8.具有EEPROM功能
9.共3个16位定时器/计数器。
即定时器T0、T1、T2
10.外部中断4路,下降沿中断或低电平触发电路,PowerDown模式可由外部中断低电平触发中断方式唤醒
11.通用异步串行口(UART),还可用定时器软件实现多个UART
12.工作温度围:
-40~+85℃(工业级)/0~75℃(商业级)
13.PDIP封装
2.2.3STC89C52RC特性
STC89C52RC单片机:
8K字节程序存储空间;512字节数据存储空间;带2K字节EEPROM存储空间;可直接使用串口下载;AT89S52单片机:
8K字节程序存储空间;256字节数据存储空间;没有带EEPROM存储空间;
2.2.4STC89C52RC单片机的P2口介绍
P2口由一个输出锁存器、一个转换开关MUX、两个三态输入缓冲器、输出驱动电路和一个反相器组成。
P2的结构如图2.3所示。
图2.3P2口的位结构
图2.3中控制信号C的状态决定转换开关的位置。
当C=0时,开关处于图示的位置;当C=1时,开关拨向地址线位置。
由图可见,输出驱动电路与P0口不同,部设有上拉电阻(由两个场效应晶体管并联构成,图中用等效电阻R表示)。
(1).P2用作通用I/O口(C=0)
当没有在单片机芯片外扩展总线;或者虽然扩展了片外总线,但采用“MOVXRi”类指令访问,且P2口用高八位地址线没有全部用到时(P2.6,P2.7,.....),P2口的口线就可以作为通用I/O口线使用。
执行输出指令时,部数据总线的数据在“写锁存器”信号的作用下由D端进去锁存器,经反相器反相后送至场效应晶体管T,再经T反相,在P2.x引脚出现数据正好是部数据总线的数据。
用作输入时,数据可以自口锁存器,也可以读自口的引脚,这是根据输入操作采用的是“读锁存器”指令还是“读引脚”指令决定。
CPU在执行“读--修改--写”类输入指令时(ANLP2,A)部产生的“读锁存器”操作信号使锁存器Q端数据进入部总线,在与累加器A进行逻辑运算之后,结果又送回P2的口锁存器并出现在引脚。
CPU在执行“MOV”类指令时(如:
MOVA,P2)部产生的操作信号使“读引脚”应在执行输入指令前把锁存器写入1,目的是场效应晶体管T2截止,从而使引脚处于高阻抗输入状态。
所以,P2口在通用I/O口时,属于准双向口。
(2)P2在作为地址总线(C=1)
当需要在单片机芯片外部扩展程序存储器或扩展了RAM(或接口芯片)且采用“MOVXDPTR”类指令访问,单片机部硬件会使C=1,MUX开关接向地址线,这时P2.x引脚的状态与地址线信息相同
2.2.5LED灯介绍
LED是英文lightemittingdiode(发光二极管)的缩写,LED灯俗称发光二极管,它的基本结构是一块电致发光的半导体材料,置于一个有引线的架子上,然后四周用环氧树脂密封,起到保护部芯线的作用,所以LED的抗震性能好。
LED(LightEmittingDiode),发光二极管,是一种能够将电能转化为可见光的固态的半导体器件,它可以直接把电转化为光。
LED的心脏是一个半导体的晶片,晶片的一端附在一个支架上,一端是负极,另一端连接电源的正极,使整个晶片被环氧树脂封装起来。
半导体晶片由两部分组成,一部分是P型半导体,在它里面空穴占主导地位,另一端是N型半导体,在这边主要是电子。
但这两种半导体连接起来的时候,它们之间就形成一个P-N结。
当电流通过导线作用于这个晶片的时候,电子就会被推向P区,在P区里电子跟空穴复合,然后就会以光子的形式发出能量,这就是LED灯发光的原理。
而光的波长也就是光的颜色,是由形成P-N结的材料决定的。
3硬件电路设计
3.1原理图
通过图3.1我们可以看出,在LED灯后要加一个电阻,通常电阻应用在单片机电路中有三种作用:
限流电阻、上拉电阻、下拉电阻。
在流水灯接线图中的电阻起的是限流作用。
图3.1流水灯接线原理图
3.2LED被点亮的原理
图3.2中A端为发光二极管的阳极,B端为发光二极管的阴极,要想点亮发光二极管,阴极必须加一个低电平(0V),发光二极管允许的电流在3mA至10mA之间,发光二极管被点亮的最小电流为3mA。
已知发光二极管被点亮后的压降值为1.7V,VCC=+5V,电阻上的电压为3.3V,根据欧姆定律R=3.3V/3mA=1.1K,因此要选用1K的电阻
图3.2流水灯接线分支电路
4软件设计
4.1设计流程
1)打开KeilμVision3软件
2)建立工程
工程以LED为名保存
选择芯片
3)建立新文件
以了LED.asm为名保存
4)把文件添加到工程
添加成功
5)在文件中输入程序
6)设置生成.hex文件和编译
设置生成.hex文件
编译成功,无错误
7)打开STC_ISP_V483.exe软件
8)下载程序
4.2源程序
1 程序一
ORG0000H
LJMPSTART
ORG0100H
START:
MOVSP,#60H;设置堆栈的初始地址
LOOP:
MOVP2,00H;点亮八个LED灯
LCALLDELAY;调用延时子程序
MOVP2,0FFH;熄灭八个LED灯
LCALLDELAY;调用延时子程序
SJMPLOOP
DELAY:
;延时子程序
MOVR0,#0FFH
NEXT:
MOVR1,#0FFH
DJNZR1,$
DJNZR0,NEXT
RET
END
2 程序二
ORG0000H
LJMPSTART
ORG0100H
START:
MOVSP,#60H;设置堆栈的初始地址
MOVR7,#0FFH;把R7置1
MOVP2,R7;把P2口置1
LOOP:
MOVA,R7
RLCA;循环移位
MOVP2,A;点亮第一个灯
MOVR7,A
LCALLDELAY;调用延时子程序
SJMPLOOP
DELAY:
;延时子程序
MOVR0,#0FFH
NEXT:
MOVR1,#0FFH
DJNZR1,$
DJNZR0,NEXT
RET
END
5调试过程
5.1实物连接图
在普中科技HC6800V2.8开发板中,将开发板中的USB插口与电脑上的USB插口相连,再将单片机的P2口与LED灯用线连接起来。
图5.1连接实物图
5.2调试
程序编译成功以后,生成.hex文件,用STC_ISP下载到单片机中,在下载过程中先进行下载然后再上电,打开单片机开发板的开关后,就会看到八个发光二极管的亮灭情况。
程序一的现象是八个发光二极管同时亮、灭,一直循环,并且亮和灭的速度很快。
程序二的现象是八个发光二极管从头依次亮,每次只有一个灯亮,从第一个一直亮到第八个,从后再从头循环,
在调试过程中,我们可以在程序中的“LCALLDELAY”语句后再增加“LCALLDELAY”语句,增加的越多,延时越长,亮或者是灭的时间就越长。
5.3出现的问题
在用STC_ISP往单片机中下载程序时出现图5.2中的打开串口失败,原因是串口已被其他程序打开或该串口不存在。
出现该问题的原因时使用的串口不正确,在设备管理器中查找正确的串口,并改正。
改正后程序能正常下载
+
图5.2问题截图
6总结
通过这次课程设计我学到了很多东西,我更加体会到理论知识与动手能力相结合的重要性,而且设计过程中使我懂得在设计程序之前,务必要对所用单片机的部结构有一个系统的了解,知道该单片机有哪些资源:
懂得设计的关键是要有一个清晰的思路和一个完整的软件流程图。
在设计程序时,不能妄想一次就将整个程序设计好,“反复修改,不断改进”是程序设计的必经之路。
要养成注释程序的好习惯,一个程序的完美与否不仅仅是实现功能,而应该让人一看就能明白你思路,这样也为资料的保存和交流提供了方便。
整个设计的过程中,还是碰到了一些问题。
比如,对于键盘的延时防抖问题不能较好的解决;对于编程的顺序及各模块程序调用掌握得还不够好;对于一些相关的应用软件没能熟练掌握。
设计中我最大的收获就是自己的动手能力和独立解决问题的能力得到了很大的提高,在动手的过程中,不仅能增强实践能力,而且在理论上可以有更深的认识
当今社会,由单片机芯片控制各种硬件工作的技术日益成熟,并普及在交通、化工、机械等各个领域。
而流水灯这项技术在生活中应用更为广泛,较为贴近生活。
以前在路上夜景中经常见到各种流水灯,感觉很漂亮,通过此次编程以后才知道了原理,让我有一种学以致用的成就感!
很开心!
流水灯控制的设计所需要的知识不仅吻合了我们本学期对于单片机这门课程的学习,而且对于我们以前所学习的如数码管显示、LEG灯等知识也是一次很好地运用,所以设计流水灯控制的这个课题让我们对知识的学习和巩固都有了进一步的加深。
总的来说,这次设计获益良多。
不仅培养了实践能力,还培养了设计思维,在摸索该如何设计电之实现所需功能的过程中,锻炼了运用所学知识的灵活性,加深了对知识的理解及提高了解决问题的能力。
在体会到设计电路编写程序的艰辛的同时,更能体会到成功的喜悦和快乐。
7附录MSC-51系列单片机指令表
表7-1数据类传送令表
助记符
操作
功能
字节数
周期数
MOVA,Rd
(A)←(Rd)
寄存器字节送到累加器
1
1
MOVA,m
(A)←(m)
直接字节送到累加器
2
1
MOVA,Ri
(A)←((Ri))
间接RAM送到累加器
1
1
MOVA,#n
(A)←n
立即数送累加器
2
1
MOVRd,A
(Rd)←(A)
累加器字节送寄存器
1
1
MOVRd,m
(Rd)←(m)
直接字节送寄存器
2
2
MOVRd,#n
(Rd)←n
立即数送寄存器
2
1
MOVm,A
(m)←(A)
累加器字节送直接字节
2
1
MOVm,Rd
(m)←(Rd)
寄存器字节送直接字节
2
2
MOVm1,m2
(m1)←(m2)
直接字节送直接字节
3
2
MOVm,Ri
(m)←((Ri))
间接RAM送入直接字节
2
2
MOVm,#n
(m)←n
立即数送入直接字节
3
2
MOVRi,A
((Ri))←(A)
累加器字节送入间接RAM
1
1
MOVRi,m
((Ri))←(m)
直接字节送入间接RAM
2
2
MOVRi,#n
((Ri))←n
立即数送入间接RAM
2
1
MOVDPTR,#n(16)
(DPTR)←n(16)
十六位立即数送数据指示器
3
2
MOVCA,A+DPTR
(A)←((A)+(DPTR))
间接ROM送累加器
1
2
MOVCA,A+PC
(A)←((A)+(PC))
间接ROM送累加器
1
2
MOVXA,Ri
(A)←((P2)+(Ri))
从外部间接RAM(8位地址)送入累加器
1
2
MOVXA,DPTR
(A)←((DPTR))
从外部间接RAM(16位地址)送入累加器
1
2
MOVXRi,A
((P2)+(Ri))←(A)
累加器容送外部间接RAM(8位地址)
1
2
MOVXDPTR,A
((DPTR))←(A)
累加器容送外部间接RAM(16位地址)
1
2
PUSHm
((SP)+1)←(m)
直接字节进堆栈
2
2
POPm
(m)←((SP))
直接字节出堆栈
2
2
XCHA,Rd
(A)←→(Rd)
寄存器与累加器交换
1
1
XCHA,m
(A)←→(m)
直接字节与累加器交换
2
1
XCHA,Ri
(A)←→(Ri)
间接RAM与累加器交换
1
1
XCHDA,Ri
(A3~0)←→((Ri)7~4)
间接RAM低半字节与累加器交换
1
1
表7-2算术运算指令
助记符
操作
功能
字节数
周期数
ADDA,Rd
(A)←(A)+(Rd)
寄存器加到累加器
1
1
ADDA,m
(A)←(A)+(m)
直接字节加到累加器
2
1
ADDA,Ri
(A)←(A)+((Ri))
间接RAM加到累加器
1
1
ADDA,#n
(A)←(A)+n
立即数加到累加器
2
1
ADDCA,Rd
(A)←(A)+(Rd)+(C)
寄存器和进位加到累加器
1
1
ADDCA,m
(A)←(A)+(m)+(C)
直接字节和进位加到累加器
2
1
ADDCA,Ri
(A)←(A)+((Ri))+(C)
间接RAM和进位加到累加器
1
1
ADDCA,#n
(A)←(A)+n+(C)
立即数和进位加到累加器
2
1
SUBBA,Rd
(A)←(A)-(Rd)-(C)
累加器减去寄存器和借位
1
1
SUBBA,m
(A)←(A)-(m)-(C)
累加器减去直接字节和借位
2
1
SUBBA,Ri
(A)←(A)-((Ri))-(C)
累加器减去间接RAM和借位
1
1
SUBBA,#n
(A)←(A)-n-(C)
累加器减去立即数和借位
2
1
INCA
(A)←(A)+1
累加器加1
1
1
INCRd
(Rd)←(Rd)+1
寄存器加1
1
1
INCm
(m)←(m)+1
直接字节加1
2
1
INCRi
((Ri))←((Ri))+1
间接RAM加1
1
1
INCDPTR
(DPTR)←(DPTR)+1
数据指示器加1
1
2
DECA
(A)←(A)-1
累加器减1
1
1
DECRd
(Rd)←(Rd)-1
寄存器减1
1
1
DECm
(m)←(m)-1
直接字节减1
2
1
DECRi
((Ri))←((Ri))-1
间接RAM减1
1
1
MULAB
(B)(A)←(A)·(B)
A乘B
1
4
DIVAB
(A)…(B)←(A)/(B)
A除B
1
4
DAA
累加器十进制调整
1
1
表7-3逻辑运算指令
助记符
操作
功能
字节数
周期数
ANLA,Rd
(A)←(A)∧(Rd)
寄存器“与”到累加器
1
1
ANLA,m
(A)←(A)∧(m)
直接字节“与”到累加器
2
1
ANLA,Ri
(A)←(A)∧((Ri))
间接RAM“与”到累加器
1
1
ANLA,#n
(A)←(A)∧n
立即数“与”到累加器
2
1
ANLm,A
(m)←(m)∧(A)
累加器“与”到直接字节
2
1
ANLm,#n
(m)←(m)∧n
立即数“与”到累加器
3
2
ORLA,Rd
(A)←(A)∨(Rd)
寄存器“或”到累加器
1
1
ORLA,m
(A)←(A)∨(m)
直接字节“或”到累加器
2
1
ORLA,Ri
(A)←(A)∨((Ri))
间接RAM“或”到累加器
1
1
ORLA,#n
(A)←(A)∨n
立即数“或”到累加器
2
1
ORLm,A
(m)←(m)∨(A)
累加器“或”到直接字节
2
1
ORLm,#n
(m)←(m)∨n
立即数“或”到累加器
3
2
XRLA,Rd
(A)←(A)⊕(Rd)
寄存器“异或”到累加器
1
1
XRLA,m
(A)←(A)⊕(m)
直接字节“异或”到累加器
2
1
XRLA,Ri
(A)←(A)⊕((Ri))
间接RAM“异或”到累加器
1
1
XRLA,#n
(A)←(A)⊕n
立即数“异或”到累加器
2
1
XRLm,A
(m)←(m)⊕(A)
累加器“异或”到直接字节
2
1
XRLm,#n
(m)←(m)⊕n
立即数“异或”到累加器
3
2
CLRA
(A)←0
累加器清零
1
1
CPLA
(A)←(
)
累加器取反
1
1
RLA
累加器循环左移
1
1
RLCA
累加器带进位循环左移
1
1
RRA
累加器循环右移
1
1
RRCA
累加器带进位循环右移
1
1
SWAPA
(A7~4)←→(A3~1)
累加器半字节交换
1
1
表7-4位操作指令
助记符
操作
功能
字节数
周期数
CLRc
(c)←0
进位清0
1
1
CLRb
(b)←0
直接位清0
2
1
SETBc
(c)←1
进位置位
1
1
SETBb
(b)←1
直接位置位
2
1
CPLc
(c)←(c非)
进位取反
1
1
CPLb
(b)←(b非)
直接位取反
2
1
ANLc,b
(c)←(c)∧(b)
直接位“与”到进位
2
2
ANLc,/b
(c)←(c)∧(b非)
直接位的反“与”到进位
2
2
ORLc,b
(c)←(c)∨(b)
直接位“或”到进位
2
2
ORLc,/b
(c)←(c)∨(b非)
直接位的反“或”到进位
2
2
MOVc,b
(c)←(b)
直接位送进位
2
1
MOVb,c
(b)←(c)
进位送直接位
2
2
表7-5控制转移指令
助记符
功能
字节数
周期数
JCr
若进位为1,则相对转移
2
2
JNCr
若进位为0,则相对转移
2
2
JBb,r
若直接位为1,则相对转移
3
2
JNBb,r
若直接位为0,则相对转移
3
2
JBCb,r
若直接位为1,则相对转移,并对直接位清0
3
2
JZr
若累加器为0,则相对转移
2
2
JNZr
若累加器不为0,则相对转移
2
2
CJNEA,m,r
若累加器不等于直接字节,则相对转移
3
2
CJNEA,#n,r
若累加器不等于立即数,则相对转移
3
2
CJNERd,#n,r
若寄存器不等于立即数,则相对转移
3
2
CJNERi,n,r
若间接RAM不等于立即数,则相对转移
3
2
DJNZRd,r
寄存器减1,若不等于0,则相对转移
2
2
DJNZm,r
直接字节减1,若不等于0,则相对转移
3
2
AJMPa(11)
绝对转移
2
2
LJMPa(16)
长转移
3
2
SJMPr
短转移(相对转移)
1
1
JMPA+DPTR
按A+DPTR间接转移
1
2
ACALLa(11)
绝对调用子程序
2
2
LCALLa(16)
长调用子程序
3
2
RET
从子程序返回
1
2
RETI
从中断返回
1
2
参考文献
[1]广弟,朱月秀,冷祖祁.单片机基础第3版.北京:
北京航空航天大学,2007
[2]蔡美琴,为民MCS-51系列单片机系统及其应用.第2版.北京:
高等教育,2004
[3]周润景,丽娜.基于PROTEUS的电路及单片机系统设计与仿真[M].北京:
航空航天大学,2006
[4]全利.单片机原理及应用技术第3版.北京:
高等教育,2009
[5]万光毅,严义,邢春香.单片机实验与实践教程[M].北京:
北京航空航天大学,2006.4
指导教师评语:
成绩:
指导教师签字:
年月日
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 单片机 流水 课程设计 报告书