基于HDL十进制计数显示系统的设计.docx

上传人:b****7 文档编号:10064846 上传时间:2023-02-08 格式:DOCX 页数:10 大小:655.94KB
下载 相关 举报
基于HDL十进制计数显示系统的设计.docx_第1页
第1页 / 共10页
基于HDL十进制计数显示系统的设计.docx_第2页
第2页 / 共10页
基于HDL十进制计数显示系统的设计.docx_第3页
第3页 / 共10页
基于HDL十进制计数显示系统的设计.docx_第4页
第4页 / 共10页
基于HDL十进制计数显示系统的设计.docx_第5页
第5页 / 共10页
点击查看更多>>
下载资源
资源描述

基于HDL十进制计数显示系统的设计.docx

《基于HDL十进制计数显示系统的设计.docx》由会员分享,可在线阅读,更多相关《基于HDL十进制计数显示系统的设计.docx(10页珍藏版)》请在冰豆网上搜索。

基于HDL十进制计数显示系统的设计.docx

基于HDL十进制计数显示系统的设计

基于HDL十进制计数、显示系统的设计

 

****大学

实验报告

 

课程名称:

FPGA技术

实验名称:

基于原理图的十进制计数器设计

姓名:

*****

学号:

*****

班级:

电子1202

指导教师:

******

 

*****大学****学院制

实验二基于HDL十进制计数、显示系统设计

一、实验原理

1、实验内容:

设计具有异步复位、同步使能的十进制计数器,其计数结果可以通过七段数码管、发光二极管等进行显示。

2、模块端口信号说明输入信号:

Clk_50m---系统采样时钟clk-------待计数的时钟clr---------异步清零信号,当clr=1,输出复位为0,当clr=0,正常计数ena---------使能控制信号,当ena=1,电路正常累加计数,否则电路不工作输出信号:

q[6:

0]---------驱动数码管,显示计数值的个位cout-----------1bit数据,显示计数值向十位的进位COM-----------共阳级数码管,公共端(接地,参考开发板原理图)3、以自顶向下的设计思路进行模块划分:

整个系统主要设计的模块是:

十进制计数模块和数码管驱动模块,由于实验板的按键为实现硬件防抖,则需要将按键输入的时钟clk,先通过消抖模块消抖后,再输出至后续使用.

仿真截图如下:

1、在同一工程下简历灵一资源“led.v”的VerilogHDL模型,建好之后,按照所给真值表进行代码编辑,完成之后同样进行编译,看是否出现错误,经过调试后得到正确代码截图如下:

Testbench后截图如下:

并进行仿真:

2、再建立一个消抖模块资源,并将老师所给的代码复制到窗口里,然后将两个子模块程序添加到这个资源下;完成第三部分;

3、最后是顶层模块的设计,建立一个名为“zongde”的资源,将前面三个模块都添加到此资源下,并编写相关代码,截图如下:

4、写好约束文件,建立一个net.ucf文件,并将第一行改成实验指导书上所要求的,完成这步之后,由于实验时间有限,后面的就没有完成了。

一、实验结果及分析

仿真结果如下截图所示:

二、实验思考题解答(实验指导书要求的思考题)

1、如何用两个或一个always实现十进制计数模块?

写出相应代码。

modulecounter(clk,clr,E,C,data_out);

inputclk,E;

inputclr;

output[3:

0]data_out;

outputC;

regC;

reg[3:

0]data_out;

initial

begin

C=0;

data_out=0;

end

always@(posedgeclkorposedgeclr)

begin

if(clr)

begin

data_out=0;

C=0;

end

else

begin

if(E)

begin

if(data_out<4'b1001)

begin

data_out=data_out+1;

C=0;

end

else

begin

data_out=0;

C=1;

end

end

end

end

endmodule

2、如何用always,或assign实现数码管的驱动设计?

写出相应代码。

moduleseg7(data_in,data_out);

input[3:

0]data_in;

output[6:

0]data_out;

reg[6:

0]data_out;

always@(data_in)

begin

data_out=7'b1111111;

case(data_in)

4'b0000:

data_out=7'b0111111;

4'b0001:

data_out=7'b0000110;

4'b0010:

data_out=7'b1011011;

4'b0011:

data_out=7'b1001111;

4'b0100:

data_out=7'b1100110;

4'b0101:

data_out=7'b1101101;

4'b0110:

data_out=7'b1111101;

4'b0111:

data_out=7'b0000111;

4'b1000:

data_out=7'b1111111;

4'b1001:

data_out=7'b1101111;

4'b1010:

data_out=7'b1110111;

4'b1011:

data_out=7'b1111100;

4'b1100:

data_out=7'b0111001;

4'b1101:

data_out=7'b1011110;

4'b1110:

data_out=7'b1111001;

4'b1111:

data_out=7'b1110001;

default;

endcase

end

3、比较实验一与实验二的实验过程,说明原理图输入法与HDL输入法的不同的应用环境。

通过两次实验对FPGA及ISE工具的学习,认识到:

原理图输入法繁琐、效率低,一般只应用于小系设计或复杂系统的顶层模块连接。

引荐描述语言HDL,适用于复杂系统设计要求的输入方式,可以有效的表达、传达设计者的设计意图,快速实现作者的设计思想。

4、CHIPSCOPE调试和仿真有何区别?

前者是对代码当中出现的错误进行检查,重点在过程;而后者则是一种虚拟的结果的分析。

三、体会

这次实验虽然和第一次实验的题目都一样,但区别在于前者是通过电路原理图来实现,而这次实验室靠编写代码来实现同样的功能。

我觉得写代码要更难一些,但是很能锻炼我们,在自己编写的过程中,我们队理论课上老师讲的一些语法规则,语句等的使用,都有了更深入的了解和认识,而且在对仿真结果的分析,更能结合这个模块要实现的功能来进行分析,但不足的是,每次都不能把握时间将代码下载到硬件里,希望下次能有所改变。

 

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

当前位置:首页 > 外语学习 > 法语学习

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

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