色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

通過狀態機的使用直接移植MCU代碼的兩種方法

lhl545545 ? 來源:電子工程技術 ? 作者:電子工程技術 ? 2020-06-11 16:10 ? 次閱讀

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

一、為什么要消抖動

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

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

(1)延時

(2)N次低電平計數

(3)低通濾波

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

二、各種消抖動

1. 模擬電路按鍵消抖動

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

通過狀態機的使用直接移植MCU代碼的兩種方法

2. 單片機中按鍵消抖動

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

unsigned char key_sCAN(void)

{

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

{

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

if(key != 0)

retrurn 0; //是抖動,返回退出

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

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

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

return 1; //返回按下信號

}

return 0; //沒信號

}

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

(1)檢測到信號

(2)延時5ms,消抖動

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

a) 是,則開始等待釋放

b) 否,則返回0,退出

(4)延時5ms,消抖動

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

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

3. FPGA中的按鍵消抖動

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

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

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

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

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

* Module Name : key_scan_jitter.v

* Engineer : Crazy Bingo

* Target DevICe : EP2C8Q208C8

* Tool versions : QUARTus II 11.0

* Create Date : 2011-6-26

* Revision : v1.0

* DescripTIon :

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

module key_scan_jitter

#(

parameter KEY_WIDTH = 2

input clk,

input rst_n,

input [KEY_WIDTH-1:0] key_data,

output key_flag,

output reg [KEY_WIDTH-1:0] key_value

);

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

reg [2:0] state;

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

always @(posedge clk or negedge rst_n)
責任編輯:pj

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 單片機
    +關注

    關注

    6039

    文章

    44583

    瀏覽量

    636526
  • mcu
    mcu
    +關注

    關注

    146

    文章

    17185

    瀏覽量

    351735
  • 代碼
    +關注

    關注

    30

    文章

    4803

    瀏覽量

    68754
收藏 人收藏

    評論

    相關推薦

    Simulink中的狀態機建模方法 Simulink數據可視化與分析功能

    1. Simulink中的狀態機建模方法 1.1 理解狀態機的基本概念 在開始建模之前,了解狀態機的基本概念是必要的。狀態機由以下幾個部分組
    的頭像 發表于 12-12 09:27 ?569次閱讀

    linux驅動程序的編譯方法有哪兩種

    Linux驅動程序的編譯方法主要可以歸納為兩種: 手動編譯 和 使用內核構建系統(Makefile)自動編譯 。 1. 手動編譯 手動編譯驅動程序通常涉及直接使用GCC(GNU Compiler
    的頭像 發表于 08-30 14:39 ?805次閱讀

    晶閘管的阻斷狀態兩種是什么

    晶閘管(Thyristor)是一種半導體器件,具有單向導電性,廣泛應用于電力電子領域。晶閘管的阻斷狀態兩種:正向阻斷狀態和反向阻斷狀態。以下是對這
    的頭像 發表于 08-14 16:49 ?788次閱讀

    觸發器和狀態機的關系是什么

    觸發器和狀態機在數字電路設計中有著緊密的關系,它們共同構成了時序邏輯電路的基礎,用于實現數據的存儲、處理和傳輸。
    的頭像 發表于 08-12 11:24 ?493次閱讀

    如何在FPGA中實現狀態機

    在FPGA(現場可編程門陣列)中實現狀態機是一種常見的做法,用于控制復雜的數字系統行為。狀態機能夠根據當前的輸入和系統狀態,決定下一步的動作和新的狀態。這里,我們將詳細探討如何在FPG
    的頭像 發表于 07-18 15:57 ?658次閱讀

    玩轉Spring狀態機

    說起Spring狀態機,大家很容易聯想到這個狀態機和設計模式中狀態模式的區別是啥呢?沒錯,Spring狀態機就是狀態模式的一種實現,在介紹S
    的頭像 發表于 06-25 14:21 ?977次閱讀
    玩轉Spring<b class='flag-5'>狀態機</b>

    數字設備中采集數字圖像的兩種方法是什么

    在數字設備中,采集數字圖像的方法有很多種,但最常見的兩種方法是:1) 使用數字相機拍攝,2) 通過掃描儀掃描。 一、使用數字相機拍攝 數字相機是一種可以捕捉圖像并將其轉換為數字格式的設備。數字相機
    的頭像 發表于 05-31 15:48 ?881次閱讀

    關于SMU狀態機的問題求解

    enableFaultToRunState(TRUE)的情況下才有效 ? 鑒于 SMU 狀態機不受軟件復位的影響,是否只有通過PORST 才能返回 RUN 狀態
    發表于 05-29 08:18

    芯海通用 MCU 應用筆記:在 MDK 開發環境下代碼重定向到 RAM 執行的幾種方法

    為 V5.37.0.0。本文檔介紹方法適用于芯??萍?MCU。*附件:應用筆記:在MDK開發環境下代碼重定向到RAM執行的幾種方法.pdf
    發表于 05-16 11:58

    請問STM32F051用了操作系統RTX后還需要寫狀態機不?

    現在學會了rtx操作系統后,原來用狀態機的學的程序,可不可以不切割,直接單線程來執行列?各位前前輩指點一下。多謝!
    發表于 05-08 06:11

    在Verilog中實現Moore型和Mealy型狀態機方法簡析

    編寫能夠被綜合工具識別的狀態機,首先需要理解狀態機的基本概念和分類。狀態機(FSM)是表示有限個狀態以及在這些狀態之間轉換的邏輯結構。
    的頭像 發表于 05-01 11:38 ?1717次閱讀

    如何采用“狀態機”解析UART數據幀

    如果一個系統接收上述“不定長度”的協議幀,將會有一個挑戰--如何高效接收與解析。 為簡化系統設計,我們強烈建議您采用“狀態機”來解析UART數據幀。
    的頭像 發表于 03-25 14:29 ?744次閱讀
    如何采用“<b class='flag-5'>狀態機</b>”解析UART數據幀

    什么是有限狀態機?如何解決傳統有限狀態機狀態爆炸」問題?

    有限狀態機(Finite State Machine,簡稱FSM)是一種用來進行對象行為建模的工具,其作用主要是描述對象在它的生命周期內所經歷的狀態序列以及如何響應來自外界的各種事件。
    的頭像 發表于 02-17 16:09 ?6284次閱讀
    什么是有限<b class='flag-5'>狀態機</b>?如何解決傳統有限<b class='flag-5'>狀態機</b>「<b class='flag-5'>狀態</b>爆炸」問題?

    Verilog狀態機+設計實例

    在verilog中狀態機的一種很常用的邏輯結構,學習和理解狀態機的運行規律能夠幫助我們更好地書寫代碼,同時作為一種思想方法,在別的代碼設計中
    的頭像 發表于 02-12 19:07 ?4237次閱讀
    Verilog<b class='flag-5'>狀態機</b>+設計實例

    狀態機該怎么監控

    狀態機卡住的場景——通過狀態跳轉條件的DFX信號去判斷卡住的原因
    的頭像 發表于 01-15 10:03 ?431次閱讀
    <b class='flag-5'>狀態機</b>該怎么監控
    主站蜘蛛池模板: 亚洲欧洲免费三级网站| 99精品视频在线观看| 国产精品伦理一二三区伦理| 泰国淫乐园实录| 国产人成精品综合欧美成人| 亚洲日产2020乱码草莓毕| 久久亚洲精品永久网站 | 浪荡受自我调教纯肉BL| AAA级精品无码久久久国片| 少妇高潮久久久久7777| 精品久久久久久久99热| 91久久偷偷做嫩草影院免| 9277高清在线观看视频| 青青草偷拍国产亚洲欧洲| 国产老头与老太hd| 中文字幕专区高清在线观看| 青娱国产区在线| 黄片长版看嘛| zooskoo1videos人与狗| 亚洲精品国产在线网站| 女人被躁到高潮嗷嗷叫小| 国产免费阿v精品视频网址| 4455永久在线毛片观看| 午夜伦伦电影理论片大片| 麻花传媒XK在线观看| 国产免费怕怕免费视频观看| 97无码人妻精品1国产精东影业 | 亚洲AV精品无码国产一区| 久热久热精品在线观看| 国产电影一区二区三区| 91亚洲精品| 亚洲成 人a影院青久在线观看| 年轻老师毛茸茸自由性| 好妞操| 福利视频久久| 91麻豆国产精品91久久久| 亚洲裸舞 hd| 手机国产视频福利| 女性性纵欲派对| 久久深夜视频| 国产亚洲一区在线|