參考Verilog代碼
技巧分享:如何在FPGA內(nèi)實(shí)現(xiàn)按鍵消抖?
發(fā)布時(shí)間:2015-01-08 責(zé)任編輯:sherryyu
【導(dǎo)讀】在FPGA內(nèi)實(shí)現(xiàn)按鍵消抖的方法多種多樣,但是最簡(jiǎn)單的是采用移位寄存器的方法進(jìn)行消抖。因?yàn)橐莆患拇嫫鞯姆椒ú恍枰獙?duì)時(shí)鐘進(jìn)行分頻,也不需要進(jìn)行延時(shí)等復(fù)雜操作。本文就為大家講解這種在FPGA內(nèi)實(shí)現(xiàn)按鍵消抖的方法。
抖動(dòng)的產(chǎn)生
通常的按鍵所用開(kāi)關(guān)為機(jī)械彈性開(kāi)關(guān),當(dāng)機(jī)械觸點(diǎn)斷開(kāi)、閉合時(shí),由于機(jī)械觸點(diǎn)的彈性作用,一個(gè)按鍵開(kāi)關(guān)在閉合時(shí)不會(huì)馬上穩(wěn)定地接通,在斷開(kāi)時(shí)也不會(huì)一下子斷開(kāi)。因而在閉合及斷開(kāi)的瞬間均伴隨有一連串的抖動(dòng),為了不產(chǎn)生這種現(xiàn)象而作的措施就是按鍵消抖。
抖動(dòng)時(shí)間
抖動(dòng)時(shí)間的長(zhǎng)短由按鍵的機(jī)械特性決定,一般為5ms~10ms。這是一個(gè)很重要的時(shí)間參數(shù),在很多場(chǎng)合都要用到按鍵穩(wěn)定閉合時(shí)間的長(zhǎng)短則是由操作人員的按鍵動(dòng)作決定的,一般為零點(diǎn)幾秒至數(shù)秒。鍵抖動(dòng)會(huì)引起一次按鍵被誤讀多次。為確保FPGA對(duì)鍵的一次閉合僅作一次處理,必須去除鍵抖動(dòng)。在鍵閉合穩(wěn)定時(shí)讀取鍵的狀態(tài),并且必須判別到鍵釋放穩(wěn)定后再作處理。
圖1 按鍵抖動(dòng)
FPGA內(nèi)實(shí)現(xiàn)消抖的方法
在FPGA內(nèi)實(shí)現(xiàn)按鍵消抖的方法多種多樣,但是最簡(jiǎn)單的是采用移位寄存器的方法進(jìn)行消抖。因?yàn)橐莆患拇嫫鞯姆椒ú恍枰獙?duì)時(shí)鐘進(jìn)行分頻,也不需要進(jìn)行延時(shí)等復(fù)雜操作,即可實(shí)現(xiàn)對(duì)按鍵邊沿的檢測(cè)。假設(shè)未按下時(shí)鍵值=1.
1、在無(wú)鍵按下時(shí),移位寄存器samp[7:0]始終采集到高電平,即samp[7:0]=8''b1111_1111;
2、當(dāng)鍵按下時(shí),samp[7:0]將采集到低電平,數(shù)據(jù)的變化方式為samp[7:0]=8''b1111_1110-->8''b1111_1100-->8''b1111_1000--> ........——>8''b0000_0000;samp[7:0]=8''b1111_1110即為按鍵下降沿。
3、當(dāng)松開(kāi)按鍵時(shí),samp[7:0]將重新采集到高電平,數(shù)據(jù)變化方式為samp[7:0]=8''b0000_0001-->8''b0000_0011--> ........-->8''b1111_1111;當(dāng)samp[7:0]=8''b0111_1111時(shí),即為按鍵上升沿。
圖2 移位寄存器消抖原理圖
[page]
參考Verilog代碼
//模塊名:EdgeDetect,邊沿檢測(cè)
//button:按鍵,無(wú)鍵按下時(shí)為高電平//clk:10M時(shí)鐘
//rst:復(fù)位按鈕,低電平有效
//rise:檢測(cè)到上升沿,高電平有效,寬度為1個(gè)clk
//fall:檢測(cè)到下降沿,高電平有效,寬度為1個(gè)clk
module EdgeDetect(
input clk,
input rst,
input button,
output reg rise,
output reg fall
);
reg[7:0] samp;//移位寄存器采集button鍵值
//移位寄存器采集button信息
always@(posedge clk or negedge rst)
begin
if(!rst)
samp<=8''b1111_1111;
else
samp<={samp[7:1],button};
end
//產(chǎn)生上升沿信息
always@(posedge clk or negedge rst)
begin
if(!rst)
rise<=1''b0;
else if(samp==8''b1111_1110)
rise<=1''b1;
else
rise<=1''b0;
end
//產(chǎn)生下降沿信息
always@(posedge clk or negedge rst)
begin
if(!rst)
fall<=1''b0;
else if(samp==8''b0111_1111)
fall<=1''b1;
else
fall<=1''b0;
end
endmodule
特別推薦
- 貿(mào)澤推出全新一期EIT系列 探索可持續(xù)智能電網(wǎng)的技術(shù)創(chuàng)新
- 使用微型模制電感器可節(jié)省空間、降低損耗并提高電源完整性和效率
- 貿(mào)澤電子以鉆石贊助商身份閃耀亮相Silicon Labs Works With 2024開(kāi)發(fā)者大會(huì)
- 意法半導(dǎo)體推出FIPS 140-3認(rèn)證TPM加密模塊,面向計(jì)算機(jī)、服務(wù)器和嵌入式系統(tǒng)
- Teledyne e2v一站式成像模塊實(shí)現(xiàn) 200萬(wàn)像素視覺(jué)和3D深度數(shù)據(jù)
- Littelfuse推出高頻應(yīng)用的IX4341和IX4342雙5安培低壓側(cè)MOSFET柵極驅(qū)動(dòng)器
- Diodes 公司推出兩款符合汽車(chē)規(guī)格的霍爾效應(yīng)芯片系列
技術(shù)文章更多>>
- 超低功耗與高精度兼?zhèn)?,助力物?lián)網(wǎng)與可穿戴設(shè)備的性能提升
- 從智能手機(jī)到助聽(tīng)器:MEMS音頻技術(shù)開(kāi)啟無(wú)限可能
- 意法半導(dǎo)體第四代碳化硅功率技術(shù)問(wèn)世:為下一代電動(dòng)汽車(chē)電驅(qū)逆變器量身定制
- 預(yù)補(bǔ)償方法以減少Class D功率放大器的爆裂噪聲
- MVG 將安立無(wú)線通信測(cè)試儀 MT8000A 集成到 ComoSAR 系統(tǒng)中,以增強(qiáng) 5G SAR 測(cè)量能力
技術(shù)白皮書(shū)下載更多>>
- 車(chē)規(guī)與基于V2X的車(chē)輛協(xié)同主動(dòng)避撞技術(shù)展望
- 數(shù)字隔離助力新能源汽車(chē)安全隔離的新挑戰(zhàn)
- 汽車(chē)模塊拋負(fù)載的解決方案
- 車(chē)用連接器的安全創(chuàng)新應(yīng)用
- Melexis Actuators Business Unit
- Position / Current Sensors - Triaxis Hall
熱門(mén)搜索
DVI連接器
EEPROM
Element14
EMC
EMI
EMI濾波器
Energy Micro
EPB
ept
ESC
ESD
ESD保護(hù)
ESD保護(hù)器件
ESD器件
Eurotect
Exar
Fairhild
FFC連接器
Flash
FPC連接器
FPGA
Fujitsu
Future
GFIVE
GPS
GPU
Harting
HDMI
HDMI連接器
HD監(jiān)控