首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >尝试使用Verilog检测交换机变化

尝试使用Verilog检测交换机变化
EN

Stack Overflow用户
提问于 2022-06-05 13:33:32
回答 1查看 105关注 0票数 -1

意图

我想用Verilog制作一个重击模块,为了完成这个任务,我想用10个开关作为输入信号,让用户点击gopher,如果出现信号(开关状态0->1或1->0)并且相应的LED灯亮起(每个周期只有一个LED会亮起来,每个周期是1秒),得分计数器加1。

是我的变量的一部分

下面是我的一些变量。

代码语言:javascript
复制
input [9:0]SW;                // 10 switch input as an array
output reg[9:0] LED;          // 10 LED output as an array
reg [5:0] score;              // the score counter, in the beginning initialize to 0
reg [4:0] clk;                // this clk is a 1 Hz clock

为什么我不能这么做?

这样做后,分数计数器只是随机跳转到不同的值。我该怎么做才能修好?

代码语言:javascript
复制
always@(SW[0])begin           // if switch 0 goes from 0 to 1 or 1 to 0
    if(LED[0])                // if LED lights up
    begin
    score=score+1;            // score counter +1
    end
end 
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-06-05 19:29:12

我会看一看数字故障过滤器,我总是将它们用于这样的用例。或者,您可以查看模拟故障过滤器。通常,我实现这样的数字:

  • I有一个数值参数,例如。0 ..。255个
  • 我创建了一个具有所需位数的计数器(如这里)。8)
  • 当输入较高时,我将计数器增量1至输入时的参数值
  • ,当计数器命中参数值时,将计数器减少1到0
  • ,我假设输入非常高,计数器点击零时不仅是小故障
  • ,而且假设输入非常低,而不仅仅是小故障

F 213/code>。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72507754

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档