




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、河南理工学院课程设计说明书题目: 把戏流水灯设计 姓 名: 院 系: 专业班级: 学 号: 指导教师: 成 绩: 时间: 2021 年 4 月 23 日至 2021 年 5月 29日河南理工学院课程设计任务书题 目: 把戏流水灯设计 专业、班级 学号 主要内容、根本要求、主要参考资料等:主要内容:利用单片机控制16个发光二极管模拟的彩灯按照一定的规律点亮、熄灭、闪烁。根本要求:1.实现发光二极管的多样化显示;2.利用proteus软件完成设计电路和仿真;3.掌握相关芯片和电子元件的使用方法;4.通过此次设计将单片机软硬件结合起来对程序进行编辑、校验,锻炼实践能力和理论联系实际的能力。主要参考资
2、料:1李全利,单片机原理及接口技术M,高等教育出版社2王文杰,单片机应用技术M,冶金工业出版社3朱清慧,PROTEUS教程电子线路设计、制版与仿真M,清华大学出版社4单片机实验指导书,天煌教仪5彭伟,单片机C语言程序设计实训100例M,电子工业出版社完 成 期 限: 2021.4.23-2021.5.29指导教师签名: 课程负责人签名: 年 月 日目录绪论11 课程设计的目的和要求21.1 设计目的21.2 设计要求22 总体设计22.1 硬件总体设计22.1.1 设计思想22.1.2 原件清单22.1.3 模块分析22.2软件总体设计33 硬件设计43.1 AT89C51单片机的硬件结构43
3、.1.1主要特性43.1.2主要引脚功能43.1.3外部总线结构63.1.4振荡器特性73.1.5芯片擦除73.2硬件电路设计73.2.1震荡电路73.2.2LED电路显示83.2.3复位电路94软件设计104.1主程序设计104.2子程序设计114.3流水灯控制码程序设计114.4程序流程图125使用proteus软件调试仿真说明125.1 Proteus的介绍125.2 Proteus的特点135.3 Proteus的使用方法135.4电路原理图的设计方法135.5仿真过程146测试数据147附录147.1把戏流水灯程序147.2把戏流水灯总线路图16结束语16参考文献16绪论随着人们生活
4、环境的不断改善和美化,在许多场合可以看到彩色霓虹灯不断变化闪烁。LED灯由于其丰富的灯光色彩,低廉的造价以及控制简单等特点而得到了广泛的应用,用彩灯来装饰街道和城市建筑物已经成为一种时尚。但目前市场上各式样的LED灯控制器大多数用全硬件电路实现,电路结构复杂、功能单一,这样一旦制作成品只能按照固定的模式闪亮,不能根据不同场合、不同时间段的需要来调节亮灯时间、模式、闪烁频率等动态参数。这种彩灯控制器结构往往有芯片过多、电路复杂、功率损耗大等缺点。此外从功能效果上看,亮灯模式少而且样式单调,缺乏用户可操作性,影响亮灯效果。因此有必要对现有的彩灯控制器进行改良。流水灯是一串按一定的规律像流水一样连续
5、闪亮。流水灯控制是可编程控制器的一个应用,其控制思想在工业控制技术领域也同样适用。流水灯控制可用多种方法实现,但对现代可编程控制器而言,利用移位存放器实现最为便利。通常用左移存放器实现灯的单方向移动;用双向移位存放器实现灯的双向移动。本案例利用价格低廉的AT89C51系列单片机控制基色LED灯泡从而实现丰富的变化。关键词:AT89C51,LED灯,单片机,把戏流水灯01 课程设计的目的和要求1.1 设计目的近年来随着科技的开展,单片机的应用正在不断走向深入,同时带动传统控制检测日新月异更新,在实时检测和自动控制的单片机应用系统中,单片机往往是作为一个核心部件来使用,单片机方面知识是不够的,还应
6、根据具体硬件结构,以及针对具体应用对象点的软件结合,加以完善。流水灯,可以更简单、方便的使用。通过本课程设计使学生进一步稳固单片机原理及应用的根本概念、根本理论,分析问题的根本方法,增强系统地运用已学的理论知识解决实际问题的能力和查阅资料的能力。培养一定的自学能力和独立分析问题、解决问题的能力,能通过独立思考、查阅工具书、参考文献,寻找解决方案。1.2 设计要求流水灯设计的根本要求:设计一个流水灯,应用AT89C51试验系统,电路开启后红、绿两种颜色的灯在时钟信号作用下按一定规律转换状态。2 总体设计2.1 硬件总体设计2.1.1 设计思想整个系统工作由软件程序控制运行,根据需要,可以上电后系
7、统经过初始化,入用户设定模式状态。基于AT89C51单片机的彩灯控制方案,实现对LED彩灯的控制。本方案以AT89C51单片机作为主控核心,与驱动等模块组成核心主控制模块。在主控模块上设有晶振电路和16个LED显示二极管,根据需要编写假设干种亮灯模式,根据各种亮灯时间的不同需要,在不同时刻输出灯亮或灯灭的控制信号。2.1.2 原件清单2.1.3 模块分析1核心部件AT89C51单片机是整个彩灯循环系统的核心是控制彩灯循环闪烁等等一切功能的部件;其中内部有ROM、有RAM、有并行I/O口等,在51单片机内部有一个CPU用来运算、控制,有四个并行I/O口,分别是P0、P1、P2、P3,有ROM,用
8、来存放程序,有RAM,用来存放中间结果,此外还有定时/计数器,串行I/O口,中断系统,以及一个内部的时钟电路。2复位系统 电路中C1、R2组成复位电路,它的作用是将单片机内部特殊功能存放器和端口存放器恢复到初始状态,从内部FLASH存储器的初始状态开始执行3震荡系统 单片机本身如同一个复杂的同步时序电路,为了保证同步工作,电路应在唯一的时钟信号控制下,严格地按规定时序工作。而时钟电路就用于产生单片机工作所需要的时钟信号。4闪烁系统利用单片机的P口控制LED的发光闪烁,再利用编程实现流水灯的电路,用软件来实现对LED的控制,每个LED接一个限流电阻,来控制流入LED发光管的电流。复位电路AT89
9、C51核心部件闪烁系统震荡系统图2-1 硬件系统方框图3 硬件设计3.1 AT89C51单片机的硬件结构由图3-1可以看出,单片机内部主要包含以下几个部件:一个8位CPU; 一个时钟电路; 4Kbyte程序存储器; 128byte数据存储器; 两个16位定时/计数器; 64Kbyte扩展总线控制电路; 四个8-bit并行I/O端口; 一个可编程串行接口; 五个中断源,其中包括两个优先级嵌套中断。 图3-1 AT89C51硬件结构框图3.1.1主要特性AT89C51是一种低功耗/低电压、高性能的八位CMOS单片机,片内有一个4KB的FLASH可编程可擦除只读存储器FPEROMFlash Prog
10、rammable and Erasable Read Only Memory,它采用了CMOS工艺和ATMEL公司的高密度非易失性存储器技术,而且其输出引脚和指令系统都与MSC51兼容。片内置通用8位中央处理器CPU和FLASH存储单元,片内的存储器允许在系统内改编程序或用常规的非易失性存储器编程。因此,AT89C51是一种功能强、灵活性高且价格合理的单片机,可方便的应用于各种控制领域。3.1.2主要引脚功能1.电源引脚Vcc和Vss Vcc:电源端,接5V。 Vss:接地端。 通常在Vcc和Vss引脚之间接0.1高频滤波电容。 2.时钟电路引脚XTAL1和XTAL2 XTAL1:接外部晶振和
11、微调电容的一端,在片内它是振荡器倒相放大器的输入,假设使用外部TTL时钟时,该引脚必须接地。 XTAL2:接外部晶振和微调电容的另一端,在片内它是振荡器倒相放大器的输出,假设使用外部TTL时钟时,该引脚为外部时钟的输入端。 3.地址锁存允许ALE 在系统扩展时,ALE用于控制地址锁存器锁存P0口输出的低8位地址,从而实现数据与低位地址的复用。当单片机上电正常工作后,ALE端就周期性地以时钟频率的1/6的固定频率向外输出正脉冲信号,ALE的负载能力为8个LSTTL器件。 4.外部程序存储器读选通信号 是读外部程序存储器的选通信号,低电平有效。CPU从外部存储器取指令时,它在每个机器周期中两次有效
12、。 5.程序存储器地址允许输入端 /VPP 当 为高电平时,CPU执行片内程序存储器指令,但当PC中的值超过0FFFH时,将自动转向执行片外程序存储器指令。当 为低电平时,CPU只执行片外程序存储器指令。对于8031,由于其无片内ROM,故 必须接低电平。 6.复位信号RST 该信号高电平有效,在输入端保持两个机器周期的高电平后,就可以完成复位操作。此外,该引脚还有掉电保护功能,假设在该端接5V备用电源,在使用中假设Vcc掉电,可保护片内RAM中信息不丧失。 7.输入/输出口引脚P0、P1、P2和P3 P0口P0.0P0.7:该端口为漏极开路的8位准双向口,负载能力位8高LSTTL负载,它为8
13、位地址线和8位数据线的复用端口。 P1口P1.0P1.7:它是一个内部带上拉电阻的8位准双向I/O口,P1口的驱动能力为4个LSTTL负载。 P2口P2.0P2.7:它为一个内部带上拉电阻的8位准双向I/O口,P2口的驱动能力也为4个LSTTL负载。在访问外部程序存储器时,它作存储器的高8位地址线。 P3口P3.0P3.7:P3口同样是内部带上拉电阻的8位准双向I/O口,P3口除了作为一般的I/O口使用之外,其还具有特殊功能。3.1.3外部总线结构所谓总线,就是连接单片机与各外部器件的一组公共的信号线。当系统要求扩展时,单片机要与一定数量的外部器件和外围设备连接。如果各部件及每一种外围设备都分
14、别用各自的一组线路与CPU直接连接,那么连线将会错综复杂,甚至难以实现。为了简化硬件电路的设计和系统结构,常用一组线路,并配以适当的接口电路来与各个外部器件和外围设备连接,这组共用的连接线路就是总线。采用总线结构便于扩展外部器件和外围设备,而统一的总线标准那么使不同设备间的互连更容易实现。利用片外引脚可以构造MCS-51系列单片机的三总线结构。单片机的引脚除了电源端VCC、接地端VSS、复位端RST、晶振接入端XTAL1和XTAL2、通用I/O口的P1.0P1.7以外,其余的引脚都是为实现系统扩展而设置的。用这些引脚构造的单片机系统的三总线结构如图3-2所示。图3-2 MCS-51系列单片机片
15、外三总线结构1地址总线Address Bus,AB:MCS-51系列单片机总共有16根地址线A15 A0,片外存储器可寻址范围达64KB216=65536字节,由P2口直接提供高8位地址A15 A8,P0口经地址锁存器提供低8位地址A7 A0。2数据总线Data Bus,DB:MCS-51系列单片机总共有8根数据线D7D0,全由P0口提供。由于P0口是分时复用总线,分时输送低8位地址通过地址锁存器锁存和高8位数据信息。 3控制总线Control Bus,CB:控制总线由P3口的第二功能(P3.6)、(P3.7)和3根独立的控制线、ALE、组成。3.1.4振荡器特性 XTAL1和XTAL2分别为
16、反向放大器的输入和输出。该反向放大器可以配置为片内振荡器。石晶振荡和陶瓷振荡均可采用。如采用外部时钟源驱动器件,XTAL2应不接。有余输入至内部时钟信号要通过一个二分频触发器,因此对外部时钟信号的脉宽无任何要求,但必须保证脉冲的上下电平要求的宽度3.1.5芯片擦除AT89C51设有稳态逻辑,可以在低到零频率的条件下静态逻辑,支持两种软件可选的掉电模式。在闲置模式下,CPU停止工作。但RAM,定时器,计数器,串口和中断系统仍在工作。在掉电模式下,保存RAM的内容并且冻结振荡器,禁止所用其他芯片功能,直到下一个硬件复位为止。3.2硬件电路设计 3.2.1震荡电路为彩灯循环系统提供稳定频率波在由多片
17、单片机组成的系统中,为了各单片机之间时钟信号的同步,引入唯一的外部脉冲信号作为各单片机的振荡脉冲。这时外部的脉冲信号是经单片机89C51的XTAL2引脚注入的;在MCS51单片机片内有一个高增益的反相放大器,反相放大器的输入端为XTAL1,输出端为XTAL2,在芯片的外部通过这两个引脚跨接晶体振荡器和微调电容C1、C2形成反应电路,可构成稳定的自激振荡器,振荡频率范围通常是1.212MHz。晶体振荡频率高,那么系统的时钟频率也高,单片机的运行速度也就快。图3-4 震荡电路晶体振荡器的振荡信号从XTAL2端送入内部时钟电路,它将该振荡信号二分频,产生一个两相时钟信号P1和P2供单片机使用。时钟信
18、号的周期称为状态时间S,它是振荡周期的2倍,P1信号在每个状态的前半周期有效,在每个状态的后半周期P2信号有效。CPU就是以两相时钟P1和P2为根本节拍协调单片机各局部有效工作的。 MCS-51单片机时钟电路示意图如图4所示。图3-5 MCS-51单片机时钟振荡电路示意图振荡电路产生的振荡脉冲并不直接使用,而是经分频后再为系统所用。振荡脉冲在片内通过一个时钟发生电路二分频后才作为系统的时钟信号。片内时钟发生电路实质上是一个二分频的触发器,其输入来自振荡器,输出为二相时钟信号,即状态时钟信号,其频率为fosc/2;状态时钟三分频后为ALE信号,其频率为fosc/6;状态时钟六分频后为机器周期,其
19、频率为fosc/12。在图3-4中,使用晶体振荡器时,C1、C2取值3010pF;使用陶瓷振荡器时,C1、C2取值4010pF。C1、C2的取值虽然没有严格的要求,但电容的大小影响振荡电路的稳定性和快速性,通常取值2030pF。在设计印制电路板时,晶振和电容等应尽可能靠近芯片,以减少分布电容,保证振荡器振荡的稳定性。也可以由外部时钟电路向片内输入脉冲信号作为单片机的振荡脉冲。这时外部脉冲信号是经XTAL1引脚引入的,而XTAL2引脚悬空或接地。对外部信号的占空比没有要求,但上下电平持续的时间不应小于20ns。这种方式常用于多块芯片同时工作,便于同步。其外部脉冲接入方式如图3-6所示。图3-6
20、MCS-51单片机外部时钟输入接线图所谓时序,是指在指令执行过程中,CPU的控制器所发出的一系列特定的控制信号在时间上的先后关系。CPU发出的控制信号有两类:一类是用于单片机内部的,用户不能直接接触此类信号,不必对它作过多了解;另一类是通过控制总线送到片外的,人们通常以时序图的形式来表示相关信号的波形及出现的先后次序。为了说明信号的时间关系,需要定义时序单位。89C51的时序单位共有四个,从小到大依次是拍节、状态、机器周期和指令周期。如图3-4所示。3.2.2LED电路显示 如下图,P0口控制LED灯D1D8的显示,P2口控制LED灯D9D16的显示。限流电阻为470欧姆,经过的电流大概为10
21、mA。3.2.3复位电路当要对晶片重置时,只要按开关就能完成LED和开关的重置。复位是单片机的初始化操作,其主要功能是把PC初始化为0000H,使单片机从0000H单元开始执行程序。单片机的RST管脚为主机提供了一个外部复位信号输入口。复位信号是高电平有效,高电平有效的持续时间为2个机器周期以上。单片机的复位方式可由手动复位完成。RST引脚是复位信号输入端,复位信号为高电平有效,其有效时间应持续24个周期以上才能完成复位操作,假设使用6MHZ晶振,那么持续4微秒以上才能完成复位操作。CPU在第二个机器周期内执行复位操作,以后每个机器周期重复一次,直至RST端电平变低。在单片机复位期间,ALE和
22、PSEN信号都不产生。复位操作将对局部专用存放器产生影响,复位后,这些内部存放器状态如表3-1.表3-1局部专用存放器复位状态存放器值存放器值PC0000HACC00HB00HPSW00HSP07HDPTR0000HP0P3OFEHIPXXX0000IE0XX0000TMOD00HTCON00HTL0,TL100HTH0,TH100HSCON00HSBUF不定PCON0XX0000上电瞬间由于电容C上无储能,其端电压近似为零,RST获得高电平,随着电容器C的充电,RST引脚上的高电平将逐渐下降,当RST引脚上的电压小于某一数值后,单片机就脱离复位状态,进入正常工作模式,只要高电平能保持复位所需
23、要的时间约两个机器周期,单片机就能实现复位。4软件设计4.1主程序设计 #include #includeunsigned char k,a,b; void delay(); void main() while(1) a=0xfe;/1111 1110 b=0xfe;/111 for(k=0;k8;k+) P0=a; delay(); b=_crol_(b,1); a=a&b; a=0xfe;/1111 1110 b=0xfe;/111 for(k=0;k0;i-) for(j=200;j0;j-); 4.3流水灯控制码程序设计利用总线控制实现流水灯8位二极管循环点亮编程思路:a) 先点亮第一
24、盏灯,延时点亮第二盏, 依次延时8盏灯全部点亮。b) 当8盏灯全部点亮时,熄灭8盏灯。c) 进入循环。4.4程序流程图图4-1程序流程图5使用proteus软件调试仿真说明5.1 Proteus的介绍Proteus软件由ISIS和ARES两局部构成,其中ISIS是一款便捷的电子系统原理设计和仿真平台软件,ARES是一款高级的PCB布线编辑软件。Proteus是目前最好的模拟单片机外围器件的工具,与其他单片机仿真软件不同的是,它不仅能仿真单片机CPU的工作情况,也能仿真单片机外围电路或没有单片机参与的其他电路的工作情况。因此在仿真和调试程序时,关心的不再是某些语句执行时单片机存放器和存储器内容的
25、改变,而是从工程的角度直接看程序运行和电路工作的过程和结果。对于这样的仿真实验,从某种意义上讲,解决了实验和工程应用间脱节的矛盾。5.2 Proteus的特点实现了单片机仿真和SPICE电路仿真的结合。具有模拟电路仿真、数字电路仿真、单片机及其外围电路组成的系统仿真、RS232动态仿真、I2C调试器、SPI调试器、键盘和LCD系统仿真等功能;有各种虚拟仪器,如示波器、逻辑分析仪、信号发生器等。具有强大的原理图绘制功能。提供软件调试功能。在硬件仿真系统中具有全速、单步、设置断点等调试功能,同时可以观察各个变量、存放器等的当前状态,因此在该软件仿真系统中,也必须具有这些功能;同时支持第三方的软件编
26、译和调试环境,如Keil C51 uVision2等软件。5.3 Proteus的使用方法点状的栅格区域为编辑窗口,左上方为预览窗口,左下方为元器件列表区,即对象选择器编辑窗口用于放置元器件,进行连线,绘制原理图。预览窗口可以显示全部原理图。在预览窗口中,有两个框,蓝框表示当前页的边界,绿框表示当前编辑窗口显示的区域。当从对象选择器中选中一个新的对象时,预览窗口可以预览选中的对象。在预览窗口上单击,Proteus ISIS将会以单击位置为中心刷新编辑窗口。 5.4电路原理图的设计方法原理图的具体设计步骤如下: (1) 新建设计文档。在进入原理图设计之前,首先要构思好原理图,即必须知道所设计的工
27、程需要哪些电路来完成,用何种模板;然后在Proteus ISIS编辑环境中画出电路原理图 。 (2) 设置工作环境。根据实际电路的复杂程度来设置图纸的大小等。在电路图设计的整个过程中,图纸的大小可以不断地调整。设置适宜的图纸大小是完成原理图设计的第一步。 (3) 放置元器件。首先从添加元器件对话框中选取需要添加的元器件,将其布置到图纸的适宜位置,并对元器件的名称、标注进行设定;再根据元器件之间的走线等联系对元器件在工作平面上的位置进行调整和修改,使得原理图美观、易懂。 4对原理图进行布线。根据实际电路的需要,利用Proteus ISIS编辑环境所提供的各种工具、命令进行布线,将工作平面上的元器
28、件用导线连接起来,构成一幅完整的电路原理图。(5) 建立网络表。在完成上述步骤之后,即可看到一张完整的电路图,但要完成印制版电路的设计,还需要生成一个网络表文件。网络表是印制版电路与电路原理图之间的纽带。 (6) 原理图的电气规那么检查。当完成原理图布线后,利用Proteus ISIS编辑环境所提供的电气规那么检查命令对设计进行检查,并根据系统提示的错误检查报告修改原理图。 (7) 调整。如果原理图已通过电气规那么检查,那么原理图的设计就完成了,但是对于一般电路设计而言,尤其是较大的工程,通常需要对电路进行屡次修改才能通过电气规那么检查。 (8) 存盘和输出报表。Proteus ISIS提供了多种报表输出格式,同时可以对设计好的原理图和报表进行存盘和输出打印。 5.5仿真过程 Proteus Isis仿真时,单片机需要加载程序,加载程序为.HEX文件。本设计利用proteus,在proteus中的source下拉框中选择add/removesource files新建汇编语言程序文件,然后用鼠标点击OK.在source下拉框中新
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 《教育教学道德》课件
- 《石油化工产品分离与提纯》课件
- 无效祛斑协议书
- 企业知识产权保护合作框架合同
- 车辆年检委托书合同协议
- 旧件回收协议书
- 通知解除劳务合同协议
- 劳动合同工伤赔偿
- 母亲卖房协议书
- 超纯水工程合同协议
- 应急疏散的标识与规范
- 2025年月度工作日历含农历节假日电子表格版
- 《儿科护理》 课件 22.3.1婴儿沐浴法
- 推土机安全技术操作规程模版(3篇)
- 【MOOC】广告创意学-湖南大学 中国大学慕课MOOC答案
- 国开2024年秋《投资学》形考作业册1-4答案
- 建筑企业安全生产事故报告及处理制度(4篇)
- 130T吊车-吊装方案
- 施工现场临水施工方案
- 3D数字游戏艺术-6-评价分评分表-3D建模-14分
- 护理医疗垃圾分类
评论
0/150
提交评论