- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于 HDL十进制计数显示系统的设计
1
2020 年 4 月 19 日
大学
实验报告
课程名称: 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, 先经过消抖模块消抖后, 再输出至后续使用 .
3
2020 年 4 月 19 日
文档仅供参考
1) 十进制计数器模块设计输入 :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 的对应位)
4
2020 年 4 月 19 日
文档仅供参考
这是一个组合逻辑电路, 能够考虑用 always, 或者 assign 语句设计。
3) 消抖模块
(1)按键抖动的产生原因:一般的按键所用开关为机械弹性开关, 当机械
触点断开、 闭合时, 由于机械触点的弹性作用, 一个按键开关在闭合
时不会马上稳定地接通, 在断开时也不会一下子断开。 因而在闭合及
断开的瞬间均伴随有一连串的抖动, 为了不产生这种现象而作的措施就
是按键消抖。
5
2020 年 4 月 19 日
原创力文档


文档评论(0)