永发信息网

Verilog HDL的数字秒表和电子时钟设计

答案:2  悬赏:30  手机版
解决时间 2021-02-14 11:34
  • 提问者网友:原来太熟悉了会陌生
  • 2021-02-14 08:00
将下面两个程序合在一起,加入一个模式开关按键,按一下,变为跑表模式,再按一下切换回电子时钟模式。
module paobiao(clk,rst,srt,Q1,Q2,Q3,Q4,Q5,Q6);
module shizhong(clk,rst,srt,Q1,Q2,Q3,Q4,Q5,Q6,);
(clk,rst,srt,输入,Q1,Q2,Q3,Q4,Q5,Q6输出)
最佳答案
  • 五星知识达人网友:北城痞子
  • 2021-02-14 08:18
在module paobiao中把执行条件srt=1,在module shizhong中把执行条件srt=0;
通过按键消抖,当按键按一下是对外部srt=~srt执行一次。其他的计时很容易设计。
全部回答
  • 1楼网友:空山清雨
  • 2021-02-14 09:37
1. “分分:秒秒”计数器设计 我们要实现“分分:秒秒”显示的电子秒表,需要设计计数频率为1hz 的 计数器。因为“分分:秒秒”的结构对应有4个十进制数字(个位的秒,十位的 秒,个位的分,十位的分),如果采用统一计数再分别求出“分分:秒秒” 对应 的4个十进制数字进行译码显示,则求解对应的4个十进制数字的过程难于用硬 件实现。在此,我们将每个显示的值分别进行计数,即分别针对个位的秒、十位 的秒、个位的分、十位的分设计对应的计数器,其中个位的秒计数频率为1hz, 其从0到9计数,当从9回到0时,向前进一位,使得十位的秒进行计数加1。 35 十位的秒从0到5计数,当从5回到0时,向前进一位,使得个位的分进行计数 加1。个位的分从0到9计数,当从9回到0 时,向前进一位,使得十位的分进 行计数加1。十位的分则从0 到5计数,计数到5时,又回到0。 2. 扫描显示技术 因为4位数码管的段控制输入是复用的,要分别显示不同的计数数值,需要 使用动态扫描显示技术,其电路结构如图61 所示。首先,以扫描显示的频率进 行2比特宽的模4计数,然后由其值从4个数码管的待显示值输入中选择对应的 一个经译码后连接到公共的段控制输入端,同时将计数值经2到4译码后输出到 对应数码管位的公共端,点亮对应的数码管。虽然各数码管位是轮流显示,每个 数码管位上的数字是断续的显示,只要扫描的频率够快,由于人眼的视觉残余效 应,就可以看到各数码管位上稳定的数字显示值。这和我们使用的电视、显示器 的显示原理是一样的。参考液晶显示器的刷新频率,经验证,在每秒钟扫描60 帧的时候,各数码管位上即能得到稳定的数字显示,此时,对应计数时钟的等效 频率为240hz。我们可以参考实验四的图47,再做一个等效分频计数器,通过 产生的后级时钟使能信号将20mhz的时钟等效分频到240hz。 图 61 扫描显示电路结构 3. 冒号点的处理 数码管中间的时间分隔冒号点(对应为左边第2个数码管位的dp点)每秒 钟闪烁一次,其频率为1hz,只需要输出1hz,占空比为50%的周期信号即可。 其他数码管位的点号不需要显示,对应的dp 点输出低电平无效信号即可。这4 个信号 所示的显示切换计数值进行4 选1 选择后接到数码管上公共的 dp控制端。 在实验四中,我们为了得到1hz的主功能计数频率,前面利用precnt 进行了等效分频计数,其一个完整的计数周期即为1s,对应产生的使能信号en 频率即为1hz,但我们在此不能直接使用en 的信号,因为其占空比只有 1/20000000,肉眼无法看到其闪烁的效果。为得到占空比为50%的1hz信号,我 们可以通过对precnt 的计数值进行比较得出,只需要在precnt 计数周期内一半的 时间输出1,一半的时间输出0 即可,例如,当precnt>25'd9999999 时输出0, 否则输出1,此时即可得到占空比为50%的1hz信号。 4. 总体设计 总体设计只需要将时钟电路、复位电路、按键电路、数码管电路等组合起来, 综合使用时钟使能的同步设计技术、按键处理技术、扫描显示技术、“分分:秒 秒”计数器设计技术及冒号点的处理技术即可。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯