91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

通過狀態(tài)機的使用直接移植MCU代碼的兩種方法

lhl545545 ? 來源:電子工程技術(shù) ? 作者:電子工程技術(shù) ? 2020-06-11 16:10 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

一、為什么要消抖動

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

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

(1)延時

(2)N次低電平計數(shù)

(3)低通濾波

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

二、各種消抖動

1. 模擬電路按鍵消抖動

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

通過狀態(tài)機的使用直接移植MCU代碼的兩種方法

2. 單片機中按鍵消抖動

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

unsigned char key_sCAN(void)

{

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

{

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

if(key != 0)

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

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

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

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

return 1; //返回按下信號

}

return 0; //沒信號

}

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

(1)檢測到信號

(2)延時5ms,消抖動

(3)繼續(xù)檢測信號,確認(rèn)是否被按下

a) 是,則開始等待釋放

b) 否,則返回0,退出

(4)延時5ms,消抖動

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

當(dāng)然在單片機中也可以循環(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)機的使用直接移植以上MCU的代碼,這個思想在FPGA狀態(tài)機中很重要。第二種,通過循環(huán)n次計數(shù)的方法來確認(rèn)是否真的被按下,這種方法很實用在FPGA這種高速并行器件中。

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

此模塊由Bingo無數(shù)次修改測試最后成型的代碼,在功能上可適配n個按鍵,在思想上利用單片機采用了單片機消抖動的思想。具體代碼實現(xià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)
責(zé)任編輯:pj

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 單片機
    +關(guān)注

    關(guān)注

    6077

    文章

    45515

    瀏覽量

    671618
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    147

    文章

    18991

    瀏覽量

    399820
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4972

    瀏覽量

    74106
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    條件判斷法來實現(xiàn)狀態(tài)機

    S0 只需要考慮事件 E1 的處理就行了。 既然是個 switch—case 之間的嵌套, 那么就有一個誰嵌套誰的問題, 所以說 switch—case法有兩種寫法:狀態(tài)嵌套事件和事件嵌套
    發(fā)表于 12-09 08:18

    睿遠研究院丨IO-Link規(guī)范解讀(十一):ISDU狀態(tài)機與EVENT事件

    上篇我們介紹了ISDU的典型編碼格式和應(yīng)用案例,本篇我們就來詳細介紹下,ISDU的狀態(tài)機,并把EVENT事件的邏輯,給大家好好解析下。 1主站ISDU狀態(tài)機 如上圖所示,ISDU的狀態(tài)機的核心
    的頭像 發(fā)表于 11-29 18:28 ?4786次閱讀
    睿遠研究院丨IO-Link規(guī)范解讀(十一):ISDU<b class='flag-5'>狀態(tài)機</b>與EVENT事件

    什么是狀態(tài)機

    狀態(tài),這樣用 20 個狀態(tài)同樣能實現(xiàn)這個狀態(tài)機,而且只需要一個 unsigned char 型的變量就足夠了,每次擊鍵都會引發(fā)狀態(tài)遷移,每遷移 5 次就能改變一次 LED 燈的
    發(fā)表于 11-27 08:15

    嵌入式開發(fā)為何經(jīng)常用到狀態(tài)機架構(gòu)

    ,這樣CPU就閑不下來了。 這種處理方法的實質(zhì)就是在程序等待事件的過程中間隔性地插入一些有意義的工作,好讓CPU不是一直無謂地等待。 二、邏輯完備性 邏輯完備性是狀態(tài)機編程最大的優(yōu)點。 不知道大家
    發(fā)表于 11-25 07:08

    用PLC實現(xiàn)卷徑計算的兩種算法

    卷徑計算,是動態(tài)計算如鋼卷,紙卷等存料量的一種方法,它是實現(xiàn)張力控制和自動充放料、以及甩尾控制的重要前提。卷徑計算目前主流的方法兩種,一種是根據(jù)列速度(產(chǎn)線速度)和和被測卷的轉(zhuǎn)動角
    的頭像 發(fā)表于 11-14 16:54 ?2204次閱讀
    用PLC實現(xiàn)卷徑計算的<b class='flag-5'>兩種</b>算法

    睿遠研究院丨IO-Link規(guī)范解讀(八):M-Sequence Type 與消息處理狀態(tài)機

    丟棄,減少后端工作量。 那么今天我們就來深入研究下,消息處理模塊中提到的各類M-Sequence,以及主從站的消息處理狀態(tài)機! ? 1 M-Sequence Type 上回講到主站發(fā)出來的MC和CKT
    的頭像 發(fā)表于 11-07 16:18 ?6422次閱讀
    睿遠研究院丨IO-Link規(guī)范解讀(八):M-Sequence Type 與消息處理<b class='flag-5'>狀態(tài)機</b>

    睿遠研究院丨IO-Link規(guī)范解讀(六):主從站狀態(tài)機解析

    前言 書接上文,今天我們就來好好聊聊主從站的DL-Mode狀態(tài)機,還請各位童鞋前排坐好! 1主站狀態(tài)機解析 主站的DL-Mode狀態(tài)機有5個大狀態(tài),也是我們很熟悉的 建立通信、開始、預(yù)
    的頭像 發(fā)表于 10-28 17:34 ?6244次閱讀
    睿遠研究院丨IO-Link規(guī)范解讀(六):主從站<b class='flag-5'>狀態(tài)機</b>解析

    剃毛器MCU解決方案

    ”; 計數(shù)器 3 s 觸發(fā)長按; ADC 采樣電池電壓,查表得電量百分比; 狀態(tài)機切換 + LED 效果。 核心代碼片段(C 語言,可直接拷貝到 FMD IDE) 初始化 void
    發(fā)表于 08-25 16:12

    請問如何在FX10上使用GPIF III狀態(tài)機 *.h 文件?

    LVCMOS 2 位 SlaveFIFO GPIF III 狀態(tài)機的演示中有一個 cy_gpif_header_lvcmos.h 文件。 我想知道如何使用.h文件,只需放入.h文件放入 FX10 項目? 您有它的用戶指南文檔嗎?
    發(fā)表于 07-16 08:17

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計之八:PCIe初始化狀態(tài)機設(shè)計

    獲取配置空間的Header Type字段,其中當(dāng)該字段第8位值為1時,表示設(shè)備為多功能設(shè)備,而NoP邏輯加速引擎當(dāng)前并不支持多功能設(shè)備,因此狀態(tài)機跳轉(zhuǎn)到ERROR狀態(tài),并設(shè)置錯誤代碼寄存器表示檢測
    發(fā)表于 07-05 22:00

    機智云配網(wǎng)教程第三期:單片代碼移植實戰(zhàn)

    前言本篇文章將分享單片移植的經(jīng)驗??梢韵螺d并按步驟移植,也可以直接使用已移植好的工程文件。文中將介紹我在
    的頭像 發(fā)表于 07-01 17:32 ?1828次閱讀
    機智云配網(wǎng)教程第三期:單片<b class='flag-5'>機</b><b class='flag-5'>代碼</b><b class='flag-5'>移植</b>實戰(zhàn)

    六相永磁同步電機串聯(lián)系統(tǒng)控制的兩種方法分析研究

    /simulink環(huán)境下,分別用這兩種方法臺電機串聯(lián)系統(tǒng)的運行特性進行仿真研究。當(dāng)其中一臺電機轉(zhuǎn)速、負載變化時,分析兩種方法下另外一臺電機獨立運行的情況,臉證分析這兩種方法的可行性
    發(fā)表于 06-10 13:09

    STM32與機智云連接實現(xiàn)步驟與技巧(下篇):機智云代碼移植與優(yōu)化

    機智云SDK,集成API,實現(xiàn)數(shù)據(jù)傳輸和設(shè)備狀態(tài)同步,并分享移植過程中的常見問題及解決方法,幫助開發(fā)者順利實現(xiàn)云端連接。機智云相關(guān)代碼開始移植
    的頭像 發(fā)表于 05-23 18:10 ?1160次閱讀
    STM32與機智云連接實現(xiàn)步驟與技巧(下篇):機智云<b class='flag-5'>代碼</b><b class='flag-5'>移植</b>與優(yōu)化

    有可能在 FX3 GPIF2 中創(chuàng)建個獨立的狀態(tài)機嗎?

    我想,如果我想通過 FX3 GPIF2 創(chuàng)建個獨立的傳輸流接口,我需要在 GPIF2 設(shè)計器中創(chuàng)建個獨立的狀態(tài)機,我是否有可能在 GPIF2 設(shè)計器中創(chuàng)建
    發(fā)表于 05-20 06:14

    求助,關(guān)于srammaster.cydsn中狀態(tài)機的問題求解

    晚上好。 我目前正在學(xué)習(xí) GPIF II。 查看..EZ-USB FX3 SDK1.3firmwaregpif_examplescyfxsrammastersrammaster.cydsn中的狀態(tài)機,有狀態(tài)START和START1。 這意味著什么?
    發(fā)表于 05-12 06:20