博客
关于我
Verilog 按键消抖的一些分析和想法
阅读量:789 次
发布时间:2019-03-24

本文共 1025 字,大约阅读时间需要 3 分钟。

按键消抖设计方案分析

在开发硬件系统时,确保按键输入的稳定性至关重要,尤其考虑到量化信号传输过程中可能出现的抖动干扰。在本文中,进行了对Verilog代码中按键消抖设计方案的详细分析,从方案一到方案三,逐步探讨了各自的优缺点与实际应用价值。


方案一:20ms计数器采样法

方案一采用计数器的方式,每20ms采一次按键状态,认为是抖动抑制的手段。一旦发现按键状态稳定,利用前后采样比较的方式,判断是否存在真实的按下情况。这种方案简单易行,适合对抖动的影响不严重的场景。

优点

  • 实现简单,代码逻辑容易理解。
  • 计数器稳定,固定的20ms采样周期,避免时钟频率带来的不确定性。

缺点

  • 当真实按键与抖动同时发生时,如果20ms计数器正好到达,或抖动正好发生在采样点,可能导致误判。

方案二:下降沿检测结合计数器

方案二通过在检测到按键下降沿时立即重置计数器,避免了方案一中计数器到达时的误判问题。这一设计能够更准确地捕捉并保护真实按键信号。

优点

  • 具备抖动时期稳定的检测方式。
  • 在下降沿发生时,立即重置计数器,确保真实按键不会被漏判。

缺点

  • 依然可能存在计数器到达时的误判风险,尤其是在高抖动场合。

方案三:状态机结合计数器

方案三采用状态机设计,进一步增强了系统的鲁棒性。通过IDLE(空闲)、SAMPLING(采样)、DOWN(已按下)三个状态,设立一个严格的逻辑控制流程。一旦检测到下降沿,系统进入采样状态,并持续计数,判定稳定时间是否足够;若检测到上升沿,则返回空闲状态。如果计数满足,系统确认真实按键并改变状态。

优点

  • 状态机详细处理系统内逻辑流程。
  • 综合考虑了下降沿和上升沿的检测,能够准确识别真实按键。
  • 增加了系统的健壮性和鲁棒性,除了一定程度的硬件抖动外,能够在大多数情况下有效运行。

缺点

  • 实现复杂,代码量较多。
  • 开发初期需要更加详细的逻辑分析,甚至需要使用测试芯片进行验证。

综合评价

在各个方案中,方案三的状态机设计被认为最为全面和可靠。它不仅能够检测下降沿以确认按键的真实按压,还通过计数器和状态机的结合,有效排除抖动干扰。尽管其实现复杂一些,但其更有容错能力和更高的稳定性,尤其适用于对系统敏感度较高的应用场景,如人机交互或自动驾驶中的按钮控制。


结论:

对于Verilog按键消抖设计,方案三在抖动抑制、误判防治及系统抗干扰方面表现最为优异。我们建议在有高精度按键检测需求的项目中,优先考虑采用状态机结合计数器的方案三。

转载地址:http://xquuk.baihongyu.com/

你可能感兴趣的文章
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>
mysql加强(5)~DML 增删改操作和 DQL 查询操作
查看>>
mysql加强(6)~子查询简单介绍、子查询分类
查看>>
mysql加强(7)~事务、事务并发、解决事务并发的方法
查看>>
mysql千万级大数据SQL查询优化
查看>>
MySQL千万级大表优化策略
查看>>
MySQL单实例或多实例启动脚本
查看>>
MySQL压缩包方式安装,傻瓜式教学
查看>>