時間:2018-04-19 16:42:48來源:網(wǎng)絡(luò)轉(zhuǎn)載
簡單的說,進(jìn)入了電子,不管是學(xué)純模擬,還是學(xué)單片機(jī),DSP、ARM等處理器,或者是我們的FPGA,一般沒有不用到按鍵的地方。按鍵:人機(jī)交互控制,主要用于對系統(tǒng)的控制,信號的釋放等。因此在這里,FPGA上應(yīng)用的按鍵消抖動,也不得不講!
一、為什么要消抖動
如上圖所示,在按鍵被按下的短暫一瞬間,由于硬件上的抖動,往往會產(chǎn)生幾毫秒的抖動,在這時候若采集信號,勢必導(dǎo)致誤操作,甚至系統(tǒng)崩潰;同樣,在釋放按鍵的那一刻,硬件上會相應(yīng)的產(chǎn)生抖動,會產(chǎn)生同樣的后果。因此,在模擬或者數(shù)字電路中,我們要避免在最不穩(wěn)定的時候采集信號,進(jìn)行操作。
對此一般產(chǎn)用消抖動的原理。一般可分為以下幾種:
(1)延時
(2)N次低電平計數(shù)
(3)低通濾波
在數(shù)字電路中,一般產(chǎn)用(1)(2)種方法。后文中將詳細(xì)介紹。
二、各種消抖動
1.模擬電路按鍵消抖動
對于模擬電路中,一般消抖動用的是電容消抖動或者施密特觸發(fā)等電路,再次不做具體介紹。
2.單片機(jī)中按鍵消抖動
對于單片機(jī)中的按鍵消抖動,本節(jié)Bingo根據(jù)自己當(dāng)年寫過的單片機(jī)其中的一個代碼來講解,代碼如下所示:
unsignedcharkey_sCAN(void)
{
if(key==0)//檢測到被按下
{
delay(5);//延時5ms,消抖
if(key!=0)
retrurn0;//是抖動,返回退出
while(!key1);//確認(rèn)被按下,等下釋放
delay(5);//延時5ms,消抖
while(!key1);//確認(rèn)被釋放
return1;//返回按下信號
}
return0;//沒信號
}
針對以上代碼,消抖動的順序如下所示:
(1)檢測到信號
(2)延時5ms,消抖動
(3)繼續(xù)檢測信號,確認(rèn)是否被按下
a)是,則開始等待釋放
b)否,則返回0,退出
(4)延時5ms,消抖動
(5)確認(rèn),返回按下信號,退出
當(dāng)然在單片機(jī)中也可以循環(huán)計數(shù)來確認(rèn)是否被按下。Bingo認(rèn)為如此,太耗MCU資源,因此再次不做講述。
3.FPGA中的按鍵消抖動
對于FPGA中的消抖動,很多教科書上都沒有講述。但Bingo覺得這個很有必要。對于信號穩(wěn)定性以及準(zhǔn)確性分析,按鍵信號必須有一個穩(wěn)定的脈沖,不然對系統(tǒng)穩(wěn)定性有很大的干擾。
此處Bingo用兩種方法對FPGA中按鍵消抖動分析。其中第一種是通過狀態(tài)機(jī)的使用直接移植以上MCU的代碼,這個思想在FPGA狀態(tài)機(jī)中很重要。第二種,通過循環(huán)n次計數(shù)的方法來確認(rèn)是否真的被按下,這種方法很實(shí)用在FPGA這種高速并行器件中。
(1)利用狀態(tài)機(jī)移植MCU按鍵消抖動
此模塊由Bingo無數(shù)次修改測試最后成型的代碼,在功能上可適配n個按鍵,在思想上利用單片機(jī)采用了單片機(jī)消抖動的思想。具體代碼實(shí)現(xià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)
標(biāo)簽:
中國傳動網(wǎng)版權(quán)與免責(zé)聲明:凡本網(wǎng)注明[來源:中國傳動網(wǎng)]的所有文字、圖片、音視和視頻文件,版權(quán)均為中國傳動網(wǎng)(www.hysjfh.com)獨(dú)家所有。如需轉(zhuǎn)載請與0755-82949061聯(lián)系。任何媒體、網(wǎng)站或個人轉(zhuǎn)載使用時須注明來源“中國傳動網(wǎng)”,違反者本網(wǎng)將追究其法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明其他來源的稿件,均來自互聯(lián)網(wǎng)或業(yè)內(nèi)投稿人士,版權(quán)屬于原版權(quán)人。轉(zhuǎn)載請保留稿件來源及作者,禁止擅自篡改,違者自負(fù)版權(quán)法律責(zé)任。
產(chǎn)品新聞
更多>2025-04-30
性能躍升20%!維宏NK300CX Plus數(shù)控系統(tǒng)...
2025-04-11
rpi-image-gen:樹莓派軟件鏡像構(gòu)建的終...
2025-04-08
【產(chǎn)品解讀】全面提升精密制造檢測節(jié)拍...
2025-03-31
激光閃耀 智慧引領(lǐng) | WISE MASER 黑武士...
2025-03-20