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

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