技術頻道

娓娓工業(yè)
您現在的位置: 中國傳動網 > 技術頻道 > 應用方案 > FPGA應用上的按鍵該如何消抖動?

FPGA應用上的按鍵該如何消抖動?

時間:2018-04-19 16:42:48來源:網絡轉載

導語:?簡單的說,進入了電子,不管是學純模擬,還是學單片機,DSP、ARM等處理器,或者是我們的FPGA,一般沒有不用到按鍵的地方。按鍵:人機交互控制,主要用于對系統(tǒng)的控制,信號的釋放等。因此在這里,FPGA上應用的按鍵消抖動,也不得不講!

簡單的說,進入了電子,不管是學純模擬,還是學單片機,DSP、ARM等處理器,或者是我們的FPGA,一般沒有不用到按鍵的地方。按鍵:人機交互控制,主要用于對系統(tǒng)的控制,信號的釋放等。因此在這里,FPGA上應用的按鍵消抖動,也不得不講!

一、為什么要消抖動

如上圖所示,在按鍵被按下的短暫一瞬間,由于硬件上的抖動,往往會產生幾毫秒的抖動,在這時候若采集信號,勢必導致誤操作,甚至系統(tǒng)崩潰;同樣,在釋放按鍵的那一刻,硬件上會相應的產生抖動,會產生同樣的后果。因此,在模擬或者數字電路中,我們要避免在最不穩(wěn)定的時候采集信號,進行操作。

對此一般產用消抖動的原理。一般可分為以下幾種:

(1)延時

(2)N次低電平計數

(3)低通濾波

在數字電路中,一般產用(1)(2)種方法。后文中將詳細介紹。

二、各種消抖動

1.模擬電路按鍵消抖動

對于模擬電路中,一般消抖動用的是電容消抖動或者施密特觸發(fā)等電路,再次不做具體介紹。

2.單片機中按鍵消抖動

對于單片機中的按鍵消抖動,本節(jié)Bingo根據自己當年寫過的單片機其中的一個代碼來講解,代碼如下所示:

unsignedcharkey_sCAN(void)

{

if(key==0)//檢測到被按下

{

delay(5);//延時5ms,消抖

if(key!=0)

retrurn0;//是抖動,返回退出

while(!key1);//確認被按下,等下釋放

delay(5);//延時5ms,消抖

while(!key1);//確認被釋放

return1;//返回按下信號

}

return0;//沒信號

}

針對以上代碼,消抖動的順序如下所示:

(1)檢測到信號

(2)延時5ms,消抖動

(3)繼續(xù)檢測信號,確認是否被按下

a)是,則開始等待釋放

b)否,則返回0,退出

(4)延時5ms,消抖動

(5)確認,返回按下信號,退出

當然在單片機中也可以循環(huán)計數來確認是否被按下。Bingo認為如此,太耗MCU資源,因此再次不做講述。

3.FPGA中的按鍵消抖動

對于FPGA中的消抖動,很多教科書上都沒有講述。但Bingo覺得這個很有必要。對于信號穩(wěn)定性以及準確性分析,按鍵信號必須有一個穩(wěn)定的脈沖,不然對系統(tǒng)穩(wěn)定性有很大的干擾。

此處Bingo用兩種方法對FPGA中按鍵消抖動分析。其中第一種是通過狀態(tài)機的使用直接移植以上MCU的代碼,這個思想在FPGA狀態(tài)機中很重要。第二種,通過循環(huán)n次計數的方法來確認是否真的被按下,這種方法很實用在FPGA這種高速并行器件中。

(1)利用狀態(tài)機移植MCU按鍵消抖動

此模塊由Bingo無數次修改測試最后成型的代碼,在功能上可適配n個按鍵,在思想上利用單片機采用了單片機消抖動的思想。具體代碼實現過程請有需要的自行分析,本模塊移植方便,Verilog代碼如下所示:

/*************************************************

*ModuleName:key_scan_jitter.v

*Engineer:CrazyBingo

*TargetDevICe:EP2C8Q208C8

*Toolversions:QUARTusII11.0

*CreateDate:2011-6-26

*Revision:v1.0

*DescripTIon:

**************************************************/

modulekey_scan_jitter

#(

parameterKEY_WIDTH=2

)

(

inputclk,

inputrst_n,

input[KEY_WIDTH-1:0]key_data,

outputkey_flag,

outputreg[KEY_WIDTH-1:0]key_value

);

reg[19:0]cnt;//delay_5ms(249999)

reg[2:0]state;

//-----------------------------------

always@(posedgeclkornegedgerst_n)

標簽:

點贊

分享到:

上一篇:手把手教你玩轉嵌入式Keil

下一篇:羅姆推出650V耐壓IGBT和RGW系...

中國傳動網版權與免責聲明:凡本網注明[來源:中國傳動網]的所有文字、圖片、音視和視頻文件,版權均為中國傳動網(www.surachana.com)獨家所有。如需轉載請與0755-82949061聯系。任何媒體、網站或個人轉載使用時須注明來源“中國傳動網”,違反者本網將追究其法律責任。

本網轉載并注明其他來源的稿件,均來自互聯網或業(yè)內投稿人士,版權屬于原版權人。轉載請保留稿件來源及作者,禁止擅自篡改,違者自負版權法律責任。

網站簡介|會員服務|聯系方式|幫助信息|版權信息|網站地圖|友情鏈接|法律支持|意見反饋|sitemap

傳動網-工業(yè)自動化與智能制造的全媒體“互聯網+”創(chuàng)新服務平臺

網站客服服務咨詢采購咨詢媒體合作

Chuandong.com Copyright ?2005 - 2025 ,All Rights Reserved 深圳市奧美大唐廣告有限公司 版權所有
粵ICP備 14004826號 | 營業(yè)執(zhí)照證書 | 不良信息舉報中心 | 粵公網安備 44030402000946號