Verilog按键消抖的原理及实现

实验原理

按键作为基本的人机输入接口,由于其机械特性,在按键按下或松开的时候,都是会有抖动的。按键小豆的方式有很多。我的方法是通过计时来消抖,通过一个计数器,当按键输入有变化时,计数器清零,否则就累加,直到加到一个预定值,就认为按键稳定,输出按键值,这样就得到了没有抖动的按键值。

module key(
	input clk,
	input key_in, //按键输入
	output reg key_out //按键输出
);

parameter COUNT_VALUE = 20;

reg [5:0]cnt_press; //按键按下计数器
reg [5:0]cnt_release;//按键未按计数器

always @(posedge clk)
begin
	if(key_in == 1'b1)//按键未按下
	begin
		cnt_press <= 6'd0;
		cnt_release <= cnt_release + 1;
	end
	if(key_in == 1'b0)//按键按下
	begin
		cnt_press <= cnt_press + 1;
		cnt_release <= 6'd0;
	end
end

//------输出按键状态,0-按键按下,1-按键未按----------
always @(posedge clk)
begin
	if(cnt_press == COUNT_VALUE)
		key_out <= 1'b0;
	else if(cnt_release == COUNT_VALUE)
		key_out <= 1'b1;
end
  • 1
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值