基于VHDL語(yǔ)言的幾種消抖電路的設計
主要程序結構如下:

圖4為D觸發(fā)器型消抖電路波形仿真圖,由圖可見(jiàn),當按鍵操作時(shí)間大于或等于clk時(shí)鐘周期的3倍時(shí),輸出一個(gè)正脈沖,正脈沖的寬度比key_in少2個(gè)clk時(shí)鐘周期。本文引用地址:http://dyxdggzs.com/article/191239.htm
D觸發(fā)器型消抖電路與計數器型消抖電路(一)相似,計數器型消抖電路(一)輸出脈沖寬度是固定的,D觸發(fā)器型消抖電路輸出脈沖寬度隨著(zhù)按鍵操作時(shí)間長(cháng)短變化。
3 狀態(tài)機型消抖電路
狀態(tài)機型消抖電路采用有限狀態(tài)機的設計方法來(lái)描述與實(shí)現,狀態(tài)機有S0,S1,S2三種狀態(tài),在S0狀態(tài)下key_out輸出為低電平,并以clk時(shí)鐘信號的頻率采樣按鍵輸入信號,如果key_in=‘0’,則保持在S0狀態(tài),并繼續采樣按鍵輸入信號的狀態(tài),如果key_in=‘1’,則轉入S1狀態(tài);在S1狀態(tài)下key_out輸出仍為低電平,繼續采樣按鍵輸入信號的狀態(tài),如果key_in=‘1’,則轉入S2狀態(tài),如果key_in=‘0’則轉入
S0狀態(tài);在S2狀態(tài)下繼續采樣按鍵輸入信號的狀態(tài),如果key_in=‘1’,則保持在S2狀態(tài),key_out輸出正脈沖,如果key_in=‘0’,則轉入S0狀態(tài),key_out輸出低電平。
主要程序結構如下:
圖5為狀態(tài)機型消抖電路波形仿真圖,由圖可見(jiàn),該狀態(tài)機型消抖電路與D觸發(fā)器型消抖電路仿真結果一致。
4 結束語(yǔ)
采用VHDL語(yǔ)言實(shí)現按鍵的消抖電路的方法有很多,本文介紹的幾種消抖電路都通過(guò)仿真分析及實(shí)驗驗證,消抖效果良好,性能穩定,而且各有自己的優(yōu)勢與缺點(diǎn),設計者可以根據設計需求選擇使用。
評論