3254|4

6892

帖子

0

TA的资源

五彩晶圆(高级)

楼主
 

帮忙看看这个消抖动程序有什么问题 [复制链接]

library ieee;--消抖动 延迟10ms
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity dou is
port(s,clk1k:in std_logic;
     so:Put std_logic);
end;
architecture one of dou is
signal cout4 :std_logic_vector(3 downto 0);
signal f,en:std_logic;
begin
process(s)
begin
if s'event and s='1'then
f<='1';end if;
end process;
process(clk1k,f)
begin
if f='1' then
if clk1k'event and clk1k='1' then
if cout4=9 then cout4<=(others=>'0');en<='0';f<='0';
else cout4<=cout4+1;en<='1';end if;end if;
else cout4<=(others=>'0'); en<='0';
end if;
end process;
process(en)
constant a:std_logic:='0';
begin
if en='1' then
so<=a;else so<=s;
end if;
end process;
end

 

请大虾看看有什么问题?

此帖出自FPGA/CPLD论坛

最新回复

看你的程序,大概是想消S的,但是f这个信号你是让s边沿触发锁存起来了,f的清零是在计数满9之后,整个看来你没有有效的消抖,最好的办法是,不要把s信号锁存,每CLK一次直接进行if判断即可。  详情 回复 发表于 2010-12-13 21:07
点赞 关注
个人签名一个为理想不懈前进的人,一个永不言败人!
http://shop57496282.taobao.com/
欢迎光临网上店铺!
 

回复
举报

135

帖子

1

TA的资源

一粒金砂(高级)

沙发
 
能上流程图吗?直接看代码太晕了,也不容易弄懂你的思路
我一般做键盘扫描是用状态机的
此帖出自FPGA/CPLD论坛
 
 

回复

381

帖子

0

TA的资源

纯净的硅(高级)

板凳
 
else cout4<=cout4+1;en<='1';end if;end if;
else cout4<=(others=>'0'); en<='0';

这两个 end if 是不是放早了??
此帖出自FPGA/CPLD论坛
 
 
 

回复

107

帖子

0

TA的资源

纯净的硅(高级)

4
 

回复 楼主 eeleader 的帖子

我觉得这个程序不能起到消抖动的作用,看下面这个进程:
process(s)
begin
if s'event and s='1'then
f<='1';end if;
end process;
只要“s“有按下就当有效信号输入,万一是抖动产生的呢?
在VHDL写抖动程序中,我个人觉得比较好的思路就是:
建立几个信号量,比如说a,b,c,设输入就是s,输出为so;
在时钟激励下,a<=s;b<=a;c<=b;
而so<=a and b and c and s;

这样就起到了消除抖动的作用。以上仅供参考,呵呵
此帖出自FPGA/CPLD论坛
个人签名快乐是一天,不快乐也是一天,为什么不天天快乐呢
 
 
 

回复

9

帖子

0

TA的资源

一粒金砂(初级)

5
 
看你的程序,大概是想消S的,但是f这个信号你是让s边沿触发锁存起来了,f的清零是在计数满9之后,整个看来你没有有效的消抖,最好的办法是,不要把s信号锁存,每CLK一次直接进行if判断即可。
此帖出自FPGA/CPLD论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表