- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
FPGA实验报告实验.doc
课程名称:基于FPGA的现代数字系统设计
指导教师:刘桂华
西南科技大学信息工程学院制基于HDL十进制计
显示系统设计
实验H的
1、 掌握基于语言的ISE设计全流程;
2、 熟悉、应用VerilogHDL描述数字电路;
3、 掌握基于Verilog的组合和吋序逻辑电路的设计方法;
4、 掌握chipscope片内逻辑分析仪的使用与调试方法。 实验原理
实验内容:设计具有异步复位、同步使能的十进制计数器,其计数结
果可以通过七段数码管、发光二极管等进行显示。
2、 模块端口信号说明:
输入信号:
Clk_50m ---系统采样时钟 elk——待计数的时钟
clr 异步清零信号,当clr=0,输出复位为0,当clr=l,
正常计数
使能控制信号,当ena-1,电路正常累加计数,否则电
路不工作 输出信号:
q[6: 0] 驱动数码管,显示计数值的个位
cout lbit数掘,显示计数值向十位的进位
COM 共阳级数码管,公共端(接地,参考开发板原理图
3、 以自顶向下的设计思路进行模块划分:
整个系统主要设计的模块是:十进制计数模块和数码管驱动模块,由 于实验板的按键为实现硬件防抖,则需要将按键输入的时钟clk,先通 过消抖模块消抖后,再输出至后续使用。
十进制计数器模块设计
输入:CLK 待计数的吋钟
CLR 异步清零信号,当CLR=0,输出复位为0,当CLR=1,正
常计数。
EN 使能控制信号,当EN=1,电路正常累加计数,否则电路不工作
输出:SUM[3:0] 计数值的个位。即,在CLK上升沿检测到
SUM=9时,SUM将被置0,开始新一轮的计数。
计数值的十位进位,即:只有在时钟CLK上升沿检测到
SUM=9时,TC将被置1,其余情况下TC=O;
在设计屮可以使用always, if-else-if语句实现,设计屮注意不要在两个以 上的always模块中对同一个变量进行赋值,否则会产生多重赋值源
(multi-source)的问题。
数码管显示驱动模块(led.v)输入:input4[3:0] 待显示的数位输
出:out7[6:0] 驱动数码管的七位数值(注意下表中out的对应位)
输入sum 输出out 数
码 3 2 1 0 A
out[0] B
out[l] c
out[2] D
out[3] 0 0 0 0 0 0 0 0 0 1 0 0 0 1 1 0 0 1 2 0 0 1 0 0 0 1 0 3 0 0 1 1 0 0 0 0 4 0 1 0 0 1 0 0 1 5 0 1 0 1 0 1 0 0 6 0 1 1 0 0 1 0 0 7 0 1 1 1 0 0 0 1 8 1 0 0 0 0 0 0 0 9 1 0 0 1 0 0 0 0 A 1 0 1 0 0 0 0 1
b 1 0 1 1 1 1 0 0 C 1 1 0 0 0 1 1 0 d 1 1 0 1 1 0 0 0 E 1 1 1 0 0 1 1 0 F 1 1 1 1 0 1 1 1 3)消抖模块 (1)按键抖动的产生原因:通常的按键所用开关为机 械弹性开关,当机械触点断开、闭合时,巾于机械触点的弹性作用,一 个按键开关在闭合时不会马上稳定地接通,在断开时也不会一下子断开。 因而在闭合及断开的瞬间均伴随有一连申的抖动,为了不产生这种现象 而作的措施就是按键消抖。
(2)本次实验提供的消抖模块简介
电平检查模块:检测输入的按键是否被按下或者释放,并分别将 H2L_Sig,L2H_Sig拉高,并随P拉低,给出按键的操作信息。延时模块: 对输入的信号变化吋刻进行计吋并观察信号的变换情况,对输出端口进行 恰当地赋值实验资料中将给出消抖模块设计源代码。对模块的具体设计 细节不需理解,消抖模块不要求仿真
三、实验步骤
创建工程。
为工程,为工程命名、指定存储路径个文件夹。
计数器及数码管驱动模块设计
创建VHD模块文件,对各个模块进行设计 (1)计数器模块代码编写
module cntlO(clk,clr,en,sum,tc
input clk,clr,en;
output reg [3:0] sum;output tc;
assign tc=(sum==4bl 111);
always @(posedge elk,negedge clr)
begin
if(?clr) sum=4b0000;
else if(en) begin sum=sum+l’bl;
if(sum==4b’ 1010) sum=4b’0000; end
else sum=sum;
end
endmodule
(2)数码管驱动模块代码编写
module led(
input [3:0] i
您可能关注的文档
- EngineeringCostManagementandControl工程造价管理控制大学外文文献翻译.doc
- Engineeringfailureanalysis工程故障分析外文文献翻译及原文.doc
- EQ5D量表在失代偿肝硬化患者心理干预中的应用.doc
- ERP环境下企业内部控制问题探讨以金力地产公司为例.doc
- eva、传统会计指标与上市公司股价表现基于贵州茅台公司的典型案例研究.doc
- EXV膨胀阀控制器的设计0.doc
- F1断层施工专项方案.doc
- FA2013009振动沉管素砼桩施工方案.doc
- FANUC15MB数控龙门式镗铣床伺服系统的故障诊断与维修.doc
- FedExCorporationSWOTAnalysis联邦快递公司的SWOT分析外文文献翻译及原文.doc
文档评论(0)