色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

按鍵彈跳消除模塊的程序設計與應用

電子設計 ? 來源:郭婷 ? 作者:電子設計 ? 2019-01-07 08:45 ? 次閱讀

按鍵在數字電路設計中經常用到。按鍵的彈跳現象是數字系統設計中存在的客觀問題。按鍵是機械觸點,當接觸點斷開或閉合時會產生抖動。為使每一次按鍵只做一次響應,就必須去除抖動。本文對按鍵的抖動信號進行了分析,并通過計數器的方式完成了消除抖動電路模塊的設計。把該模塊應用到按鍵控制LCD顯示的系統中,并在Memec代理的Virtex-4 MB系統實驗板上實現了該系統。消抖電路的效果良好,按鍵控制LCD顯示結果正常。

按鍵開關是電子設備人機交互的主要器件之一。按鍵大多是機械式開關結構,由于機械式開關的核心部件為彈性金屬簧片,因而在開關切換的瞬間會在接觸點出現來回彈跳的現象。對于靈敏度比較高的電路,這種彈跳現象引起的信號抖動會造成誤動作而影響到系統的正確性。因此,我們需要設計按鍵彈跳消除電路來去除抖動。。

1.彈跳消除電路的原理和功能

按鍵開關的典型連線分為低電平有效和高電平有效,本文的是低電平有效。

機械開關的抖動存在三種情況:按下時有抖動,松開時也有抖動;按下時有抖動,松開時無抖動;按下時無抖動,松開時有抖動。機械開關的抖動波形、抖動次數、抖動時間都是隨機的,并不是每次都會產生抖動。

不同開關的最長抖動時間也不同。抖動時間的長短和機械開關特性有關,一般為5ms到10ms。但是,某些開關的抖動時間長達20ms,甚至更長。所以,在具體設計中要具體分析,根據實際情況來調整設計。

彈跳現象以及彈跳消除如圖1 所示,雖然只是按下按鍵一次后放掉,結果在按鍵信號穩定先后竟出現了多個段脈沖,如果將這樣的信號直接送到計數器之類的時序電路,結果將可能發生計數超過一次以上的誤動作,從而誤以為鍵盤按了多次。因此,必須加上彈跳消除電路,除去短脈沖,避免誤操作的發生。

按鍵彈跳消除模塊的程序設計與應用

2.按鍵彈跳消除模塊的實現

為了使按鍵彈跳消除模塊的更加簡潔,并且移植性好,在此用計數器的方式實現消除按鍵抖動的功能。

2.1 計數器模值的計算

計數器模值的確定是按鍵彈跳消除效果的關鍵問題,如果值過大,即采樣時間過長,就會漏掉正確的信號;如果值過小,采樣時間過短,則會將毛刺誤認為是輸入信號。

計數器的模值n根據抖動信號的脈沖寬度和采樣信號clk的周期大小決定。根據一般人按鍵的速度小于10Hz(每秒小于10次),所以按鍵時間大于100ms,按占空比50%計算,按下的時間大于50ms。按這種約定,我們認為按下的時間小于50ms的為抖動信號,按下的時間大于50ms的是按鍵信號。即n=50ms/采樣脈沖信號周期,這樣就可以把按下的時間小于50ms的抖動信號濾掉。

在此,根據實驗板提供的系統時鐘來確定實際需要的模值。實驗板提供的系統時鐘為100mHz,通過分頻后得到25mHz的時鐘,50ms*25mHz得到count的模值為21’h1312D0。采用這個模值得到的消抖時間大約為50ms,符合要求。

2.2 程序設計

設計一個高脈沖計數器count1和一個低脈沖計數器conut0。引入一個采樣脈沖信號clk,對輸入信號button_in進行采樣,并對clk進行計數。若button_in為高電平,count1做加法計數,直到count1各位全為1,停止計數,歸零,使消抖后的輸出信號button_out輸出1。若button_in為低電平,count0做加法計數,直到count0各位全為1,停止計數歸零,并使消抖后的輸出信號button_out輸出0。

部分程序如下:

module filter(clk,

reset,

button_in,

button_out);

input clk;

input reset;

input button_in;

output button_out;

wire buttong_out1;

reg [20:0] count0;

reg [20:0] count1;

reg button_out1_reg;

……

assign button_out=button_out1_reg;

//對輸入進行采樣,計數

always@(posedge clk or negedge reset)

begin

if(!reset) count1《=21‘h000000;

else if(button_out1==1’b1) count1《=count1+1;//對高電平計數

else count1《=21‘h000000;

end

always@(posedge clk or negedge reset)

begin

if(!reset) count0《=21’h000000;

else if(button_out1==1‘b0) count0《=count0+1;//對低電平計數

else count0《=21’h000000;

end

//輸出

always@(posedge clk or negedge reset

begin

if(!reset) button_out1_reg《=1’b1;

else if(count0==21‘h1312D0) //判斷低電平信號是否符合輸出條件

button_out1_reg《=1’b0; //如果符合條件,則輸出低電平

else if(count1==21‘h1312D0) //判斷低電平信號是否符合輸出條件

button_out1_reg《=1’b1; //如果符合條件,則輸出高電平

else button_out1_reg《=button_out1_reg;

end

endmodule

按鍵彈跳消除模塊的程序設計與應用

3 按鍵彈跳消除模塊的實際應用

利用Memec virtex-4 開發板,通過開發板上的按鈕輸入8位的01控制代碼,用開發板上的開關輸入狀態控制位,從而控制板上的1602 C型字符型液晶模塊的顯示模式和內容。

LCD控制信號生成模塊:根據按鈕輸入,產生控制顯示模塊的8位控制信號。對按鈕送入該模塊的1位(0/1)信號進行保存并進行轉換,使每8次輸入形成一個8位的信號。如果輸入不滿8位或需重新輸入,則取消上次結果;如果確定輸入結果正確,則將8位信號保存并輸出。

LCD顯示控制模塊:完成1602 C型字符型液晶模塊的初始化,并根據控制信號完成狀態轉換。

按鍵彈跳消除模塊的程序設計與應用

總系統設計如圖4:

按鍵彈跳消除模塊的程序設計與應用

結束語

本文進行性模塊化設計,實現了彈跳消除電路模塊、LCD控制信號生成模塊和LCD顯示控制模塊組成的系統的具體功能,在Memec實驗板上運行效果良好。并且在用FPGA進行電路調試的時候,可以將該系統嵌入其它電路中,增加需要的測試點和觀察點,通過按鈕控制顯示,可以動態的對電路進行測試,找出問題,使調試更加直觀,從而提高的FPGA的內部信號的可觀察性,提高驗證效率。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1630

    文章

    21760

    瀏覽量

    604382
  • lcd
    lcd
    +關注

    關注

    34

    文章

    4432

    瀏覽量

    167837
  • 數字系統
    +關注

    關注

    0

    文章

    144

    瀏覽量

    20874
收藏 人收藏

    評論

    相關推薦

    verilog寫cpld的程序如何消除按鍵的抖動?

    verilog寫cpld的程序如何消除按鍵的抖動?
    發表于 04-02 09:22

    按鍵彈跳消除模塊的原理及應用

    按鍵在數字電路設計中經常用到。按鍵彈跳現象是數字系統設計中存在的客觀問題。按鍵是機械觸點,當接觸點斷開或閉合時會產生抖動。為使每一次按鍵
    發表于 07-31 09:18 ?3056次閱讀
    <b class='flag-5'>按鍵</b><b class='flag-5'>彈跳</b><b class='flag-5'>消除</b><b class='flag-5'>模塊</b>的原理及應用

    彈跳消除模塊程序下載

    I.彈跳消除模塊程序如下: --content definition of component debounce library ieee; use ieee.std_logic_1
    發表于 02-23 15:53 ?34次下載

    基于PDA和無線模塊的SMS程序設計

    本內容提供了基于PDA和無線模塊的SMS程序設計,歡迎大家下載學習
    發表于 06-27 15:54 ?21次下載
    基于PDA和無線<b class='flag-5'>模塊</b>的SMS<b class='flag-5'>程序設計</b>

    基于51單片機的超聲波模塊測距程序設計系統

    基于51單片機的超聲波模塊測距程序設計系統
    發表于 02-18 17:08 ?40次下載

    模塊程序設計

    模塊程序設計思想,單片機c語言的模塊化設計,方便移植,將程序封裝備用。
    發表于 03-22 15:29 ?9次下載

    模塊程序設計

    模塊程序設計,利用c語言的移植性好特點,更好的利用c語言。
    發表于 03-23 09:25 ?0次下載

    介紹關于按鍵與數碼管的程序的設計

    按鍵與數碼管的程序設計
    的頭像 發表于 07-10 03:46 ?3550次閱讀
    介紹關于<b class='flag-5'>按鍵</b>與數碼管的<b class='flag-5'>程序</b>的設計

    C程序設計的詳細中文資料免費下載

    本文檔的主要內容詳細介紹的是C程序設計的詳細中文資料免費下載內容包括了: 程序設計和C語言,算法---程序的靈魂,最簡單的C程序設計,選擇結構程序設
    發表于 08-01 08:00 ?0次下載

    簡單的C程序設計教程之順序程序設計的資料概述

    本文檔的主要內容詳細介紹的是簡單的C程序設計教程之順序程序設計的資料概述。
    發表于 11-16 16:17 ?4次下載
    簡單的C<b class='flag-5'>程序設計</b>教程之順序<b class='flag-5'>程序設計</b>的資料概述

    C語言程序設計教程之模塊設計課件資料免費下載

    本文檔的主要內容詳細介紹的是C語言程序設計教程之模塊設計課件資料免費下載主要內容包括了:1 模塊的實現——函數,2 模塊間的參數傳遞,3 模塊
    發表于 01-08 14:19 ?71次下載
    C語言<b class='flag-5'>程序設計</b>教程之<b class='flag-5'>模塊</b>設計課件資料免費下載

    JAVA程序設計教程之JSP程序設計實驗

    本文檔的主要內容詳細介紹的是JAVA程序設計教程之JSP程序設計實驗。
    發表于 11-05 15:34 ?6次下載
    JAVA<b class='flag-5'>程序設計</b>教程之JSP<b class='flag-5'>程序設計</b>實驗

    單片機C程序設計的六個實例詳細講解

    本文檔的主要內容詳細介紹的是單片機C程序設計的5個實例詳細講解包括了:按鍵程序編寫的基礎,模塊化編程初識,按鍵
    發表于 11-18 08:00 ?1次下載
    單片機C<b class='flag-5'>程序設計</b>的六個實例詳細講解

    多功能按鍵嵌入式程序設計資料下載

    電子發燒友網為你提供多功能按鍵嵌入式程序設計資料下載的電子資料下載,更有其他相關的電路圖、源代碼、課件教程、中文資料、英文資料、參考設計、用戶指南、解決方案等資料,希望可以幫助到廣大的電子工程師們。
    發表于 04-23 08:40 ?8次下載
    多功能<b class='flag-5'>按鍵</b>嵌入式<b class='flag-5'>程序設計</b>資料下載

    嵌入式軟件開發之模塊程序設計(三)

    模塊程序設計是指在進行程序設計時將一個大程序按照功能劃分為若干小程序模塊,每個小程序模塊完成一
    發表于 11-03 21:06 ?10次下載
    嵌入式軟件開發之<b class='flag-5'>模塊</b>化<b class='flag-5'>程序設計</b>(三)
    主站蜘蛛池模板: 久久精品亚洲AV无码三区观看| 色色色久久久免费视频| 亚洲国产韩国欧美在线不卡| 国产免费播放一区二区三区| 亚洲精品有码在线观看| 久久性色AV亚洲电影无码| 99re久久超碰视频精品| 日本九九热在线观看官网| 国产精品99久久久久久AV下载 | 男女XX00上下抽搐动态图| videossex性暴力| 亚州中文字幕| 妹妹的第一次有点紧| 抽插内射高潮呻吟V杜V| 亚洲精品欧美精品中文字幕| 名女躁b久久天天躁| 国产成人精选免费视频| 一级毛片西西人体44rt高清| 欧洲人交xxx69| 国产又湿又黄又硬又刺激视频 | 高h浪荡文辣文神奇宝贝| 亚洲精品午夜久久久伊人| 欧美精品熟妇乱| 国产亚洲精品久久久久久鸭绿欲 | 青青草原国产| 精品第一国产综合精品蜜芽| WWW国产精品内射熟女| 亚洲欧洲日本无在线码播放 | 性女传奇 快播| 男人和女人一级黄色大片| 国产精品一国产AV麻豆| 97色伦在色在线播放| 亚洲国产成人精品无码区5566| 年轻老师毛茸茸自由性| 国模玲玲自拍337p| 被老头下药玩好爽| 曰本熟妇乱妇色A片在线| 翁熄性放纵交换01| 啪啪激情婷婷久久婷婷色五月| 精品免费久久久久久影院| 国产爱豆剧果冻传媒在线|