FPGA小白养成记--按键消抖实验

本文介绍了FPGA中按键消抖的原理和实现方法,通过计数器判断低电平持续时间来确定按键是否真正按下。使用VIVADO的在线逻辑分析仪进行仿真,并详细解析了两种关键情况:按键按下和抖动的区分。实验通过设置延时和计数器确保20ms以上的低电平才视为有效按键操作。
摘要由CSDN通过智能技术生成

今天做一个按键消抖的实验,要求如下:判断出按键是真正的按了下去从而触发蜂鸣器,而要消除抖动(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; //像一面旗帜,判断是否计数计满
(<

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值