今天做一个按键消抖的实验,要求如下:判断出按键是真正的按了下去从而触发蜂鸣器,而要消除抖动(20ms以上算是按键按下,否则算做抖动)
原理:当我们按按键的时候,从而触发某些功能,然而有时我们明明没有按下按键,为什么也会触发功能呢?其原因就是抖动,导致抖动的因素有很多种,比如板子受到外力抖了抖之类的,都可能导致误触发功能。那么消抖就成了不可缺少的一环,接下来的问题是:我们如何消抖呢?
我们假设未按键时,正常电平为高,而当有按键按下或者有抖动时,电平为低,那么我们就只需要判断低电平的时间是否达到了20ms,从而得出按键是否按下的结论,从而触发蜂鸣器。这就是大致的思路。
然而我们如何知道时间是否达到了20ms呢?我们采用计数器计数的方式来判断时间是否达到了20ms。
本次使用VIVADO软件的在线逻辑分析仪进行仿真:
接下来直接开搞:
module key(
input clk,
input clk_rst,
input key_in,
//output flag,
output reg beep
);
(* dont_touch = “true” )reg [19:0] cnt0; //20位的cnt,利用20ms除以20ns的周期而得出的位数
( dont_touch = “true” )reg adden;
( dont_touch = “true” )wire flag; //像一面旗帜,判断是否计数计满
(<