大规模数字逻辑课程设计流水灯设计

上传人:无*** 文档编号:80066746 上传时间:2022-04-24 格式:DOC 页数:11 大小:146.51KB
收藏 版权申诉 举报 下载
大规模数字逻辑课程设计流水灯设计_第1页
第1页 / 共11页
大规模数字逻辑课程设计流水灯设计_第2页
第2页 / 共11页
大规模数字逻辑课程设计流水灯设计_第3页
第3页 / 共11页
资源描述:

《大规模数字逻辑课程设计流水灯设计》由会员分享,可在线阅读,更多相关《大规模数字逻辑课程设计流水灯设计(11页珍藏版)》请在装配图网上搜索。

1、大规模数字逻辑课程设计题目:流水灯设计学 号: XXX 姓 名: XXX 班 级: XXX 目录1.流水灯控制的实验要求与思路31.1实验要求31.2实验思路32.系统逻辑设计:43.源程序代码4(1)分频器部分4(2)控制模块54.实验步骤:75. 实验原理图:76.分配管脚87.运行界面:88.总结与体会109.参考文献101. 流水灯控制的实验要求与思路1.1实验要求在流水灯控制系统中,要求开发板上的8个LED灯依次以0.5S的时间间隔从上到下再下到上的顺序点亮,然后分别以1S、1.5S、2S的时间间隔和相同顺序点亮8个LED灯,以此为一个循环,重复以上四个步骤就可以实现流水灯系统的自动

2、循环运作。1.2实验思路根据时钟信号的脉冲输入,我们以改变每个LED点亮状态的保持的时间来改变LED的变换间隔时间,根据LED的循环点亮和时间间隔的改变设计成为一个直观的LED流水灯自动循环系统,由此思路我们就可以很容易的着手流水灯控制程序的设计。2. 系统逻辑设计: 根据以上的设计要求,运用模块化的设计思路,我们在Quartus II8.0 软件系统中设计了LED流水灯控制模块、分频器模块,并通过各个模块程序之间的端口合理连接和协调,成功设计出LED流水灯灯控制电路,得到逻辑结构原理图,即为整个流水灯控制电路的逻辑结构。使用VerilogHDL语言设计相应的模块。3.源程序代码(1)/ 分频

3、器部分 ,获得便于试验观察的时钟信号module clk_div(clk_out,clk_in); input clk_in; output clk_out; reg clk_out; integer counter; parameter cnt=25_000_000; always (posedge clk_in) begincounter=counter+1; if(counter=cnt/2-1)begin clk_out=!clk_out; counter=0;end endendmodule(2)/控制模块:module lsd(clk,led);input clk;output 7

4、:0led;/ 输出端口定义为寄存器型reg 7:0 count;reg 7:0 count1;reg 7:0 count2;reg 7:0 led;reg 3:0 state; always (posedge clk)/ always语句,表示每当CLK的上升沿到来时,完成begin-end之间语句的操作 begin count=count+1; if(count17) begin state = state + 4b0001; / one clk,one state case(state) 4b0000: led = 8b00000001; /the 1st state 4b0001: l

5、ed = 8b00000010; 4b0010: led = 8b00000100; 4b0011: led = 8b00001000; 4b0100: led = 8b00010000; 4b0101: led = 8b00100000; 4b0110: led = 8b01000000; 4b0111: led = 8b10000000; 4b1000: led = 8b10000000; 4b1001: led = 8b01000000; 4b1010: led = 8b00100000; 4b1011: led = 8b00010000; 4b1100: led = 8b0000100

6、0; 4b1101: led = 8b00000100; 4b1110: led = 8b00000010; 4b1111: led = 8b00000001; default: state = 4b0000; / default,8b00000001 endcase end else if(count49) begin if(count%2=0) begin state = state + 4b0001; / one clk,one state case(state) 4b0000: led = 8b00000001; /the 2st state 4b0001: led = 8b00000

7、010; 4b0010: led = 8b00000100; 4b0011: led = 8b00001000; 4b0100: led = 8b00010000; 4b0101: led = 8b00100000; 4b0110: led = 8b01000000; 4b0111: led = 8b10000000; 4b1000: led = 8b10000000; 4b1001: led = 8b01000000; 4b1010: led = 8b00100000; 4b1011: led = 8b00010000; 4b1100: led = 8b00001000; 4b1101: l

8、ed = 8b00000100; 4b1110: led = 8b00000010; 4b1111: led = 8b00000001; default: state = 4b0000; / default,8b00000001 endcase end end else if(count97) begin count1=count1+1; if(count1%3=0) begin state = state + 4b0001; / one clk,one state case(state) 4b0000: led = 8b00000001; /the 3st state 4b0001: led

9、 = 8b00000010; 4b0010: led = 8b00000100; 4b0011: led = 8b00001000; 4b0100: led = 8b00010000; 4b0101: led = 8b00100000; 4b0110: led = 8b01000000; 4b0111: led = 8b10000000; 4b1000: led = 8b10000000; 4b1001: led = 8b01000000; 4b1010: led = 8b00100000; 4b1011: led = 8b00010000; 4b1100: led = 8b00001000;

10、 4b1101: led = 8b00000100; 4b1110: led = 8b00000010; 4b1111: led = 8b00000001; default: state = 4b0000; / default,8b00000001 endcase end end else if(count161) begin count2=count2+1; if(count2%4=0) begin state = state + 4b0001; / one clk,one state case(state) 4b0000: led = 8b00000001; /the 4st state

11、4b0001: led = 8b00000010; 4b0010: led = 8b00000100; 4b0011: led = 8b00001000; 4b0100: led = 8b00010000; 4b0101: led = 8b00100000; 4b0110: led = 8b01000000; 4b0111: led = 8b10000000; 4b1000: led = 8b10000000; 4b1001: led = 8b01000000; 4b1010: led = 8b00100000; 4b1011: led = 8b00010000; 4b1100: led =

12、8b00001000; 4b1101: led = 8b00000100; 4b1110: led = 8b00000010; 4b1111: led = 8b00000001; default: state = 4b0000; / default,8b00000001 endcase end end else count=0; endendmodule4.实验步骤:将MODUL_SEL拨码开关组合为1,2,8拨上3,4,5,6,7拨下,是数码管显示为C1. 建立工程,对建立的工程命名、文件命名,选择相应的芯片及配置,然后在打开的工程下建立VerilogHDL语言编写的文件:文件名分别是lsd

13、.v、clk_div.v,将这两个文件同时加入此工程内。 将相应的文件转换为符号文件,并创建一个block,生成电路原理图,然后将此文件保存到当前工程下,并将文件名命名为lsdblock,然后将其设置为顶层实体。 将步骤2中生成的Block文件先进行综合,待综合无误之后进行管脚分配,之后进行全编译生成我们需要下载到开发板上的lsd.sof文件,然后加入下载界面,选择相应的设置,且在JTAG模式下,然后下载该sof文件来观察开发板上LED的变化现象。5. 实验原理图:6.分配管脚7. 运行界面:(1)根据lsd.v文件代码创建符号文件:(2)根据clk_div.v文件代码创建符号文件:(3)综合

14、时显示框(4)全编译时显示框(5)下载文件的界面:8.总结与体会 此次课程设计,学到了很多课内学不到的东西,比如独立思考解决问题,出现差错的随机应变,和与人合作共同提高,都受益非浅,通过这次的课程设计,使我对基础知识加深了理解,熟练了软件Qutars II8.0的基本操作,并且对一个设计中的流程有所了解,知道了每个操作步骤的具体作用,这样可以使自己更加明白的去操作每一步。在课程设计中不仅知道了自己的不足之处,而且更加的了解了编程对学习的重要性,自己编程的水平直接制约了设计的进展,所以在以后的学生生活之中一定要对编程加以巩固保证不会拖自己的后腿;平时看课本时,有时问题老是弄不懂,做完课程设计,那些问题就迎刃而解了,而且还可以记住很多东西。所以这个课程设计对我的作用是非常大的。9.参考文献VerilogHDL综合实用教程 J.Bhasker 著 孙海平 译 清华大学出版社 2004. 111

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!