基于HDL十进制计数、显示系统的设计说明书.docVIP

基于HDL十进制计数、显示系统的设计说明书.doc

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE PAGE 2 专业资料 word完美格式 ****大学 实验报告 课程名称: FPGA技术 实验名称: 基于原理图的十进制计数器设计 姓 名: ***** 学 号: ***** 班 级: 电子1202 指导教师: ****** *****大学****学院制 实验二 基于 HDL 十进制计数、 显示系统设计 一、实验原理 实验内容: 设计具有异步复位、 同步使能的十进制计数器, 其计数结果可以通过七段数码管、 发光二极管等进行显示。 模块端口信号说明输入信号:Clk_50m 系统采样时钟clk 待计数的时钟clr 异步清零信号, 当 clr=1, 输出复位为 0, 当 clr=0, 正常计数ena使能控制信号, 当 ena=1, 电路正常累加计数, 否则电路不工作输出信号:q[6: 0]驱动数码管, 显示计数值的个位cout 1bit 数据, 显示计数值向十位的进位COM共阳级数码管,公共端( 接地, 参考开发板原理图)3、 以自顶向下的设计思路进行模块划分:整个系统主要设计的模块是: 十进制计数模块和数码管驱动模块, 由于实验板的按键为实现硬件防抖, 则需要将按键输入的时钟 clk, 先通过消抖模块消抖后, 再输出至后续使用. 十进制计数器模块设计输入:CLK 待计数的时钟CLR 异步清零信号, 当 CLR =1, 输出复位为 0, 当 CLR =0, 正常计数ENA使能控制信号, 当 ENA=1, 电路正常累加计数, 否则电路不工作输出:SUM[3:0] 计数值的个位。 即, 在 CLK 上升沿检测到 SUM=9 时, SUM 将被置0, 开始新一轮的计数。COUT 计数值的十位进位, 即: 只有在时钟 CLK 上升沿检测到 SUM=9 时,COUT 将被置 1, 其余情况下 COUT=0;在设计中可以使用 always, if-else-if语句实现, 设计中注意不要在两个以上的 always模块中对同一个变量进行赋值, 否则会产生多重赋值源( multi-source) 的问题。2) 数码管显示驱动模块( led.v)输入: sum[3:0] 待显示的数值输出: out[6:0] 驱动数码管的七位数值( 注意下表中 out 的对应位) 这是一个组合逻辑电路, 可以考虑用 always, 或者 assign 语句设计。 消抖模块 按键抖动的产生原因:通常的按键所用开关为机械弹性开关, 当机械触点断开、 闭合时, 由于机械触点的弹性作用, 一个按键开关在闭合时不会马上稳定地接通, 在断开时也不会一下子断开。 因而在闭合及断开的瞬间均伴随有一连串的抖动, 为了不产生这种现象而作的措施就是按键消抖。 ( 2) 本次实验提供的消抖模块简介 电平检查模块: 检测输入的按键是否被按下或者释放, 并分别将 H2L_Sig,L2H_Sig 拉高, 并随后拉低, 给出按键的操作信息。 延时模块: 对输入的信号变化时刻进行计时并观察信号的变换情况, 对输出端口进行恰 当地赋值; 实验资料中将给出消抖模块设计源代码。 对模块的具体设计细节不需理解, 消抖模 块不要求仿真; 4、 扩展内容: 完成四位一体数码管的动态扫描显示。 完成从 0-9999 循环计数。 实验步骤 先建立一个名为shiyan2的工程,在建立资源“cnt10”的Verilog HDL模型,完了之后,在此窗口下编辑cnt10的相关代码;完成以后,进行编译,看代码是否有错,代码截图如下: Testbench截图如下: 仿真截图如下: 在同一工程下简历灵一资源“led.v”的Verilog HDL模型,建好之后,按照所给真值表进行代码编辑,完成之后同样进行编译,看是否出现错误,经过调试后得到正确代码截图如下: Testbench后截图如下: 并进行仿真: 再建立一个消抖模块资源,并将老师所给的代码复制到窗口里,然后将两个子模块程序添加到这个资源下;完成第三部分; 最后是顶层模块的设计,建立一个名为“zongde”的资源,将前面三个模块都添加到此资源下,并编写相关代码,截图如下: 写好约束文件,建立一个net.ucf文件,并将第一行改成实验指导书上所要求的,完成这步之后,由于实验时间有限,后面的就没有完成了。 实验结果及分析 仿真结果如下截图所示: 实验思考题解

文档评论(0)

smdh + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档