<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 如何在FPGA中實(shí)現狀態(tài)機

如何在FPGA中實(shí)現狀態(tài)機

作者: 時(shí)間:2013-05-08 來(lái)源:網(wǎng)絡(luò ) 收藏

常常用于執行基于序列和控制的行動(dòng),比如一個(gè)簡(jiǎn)單的通信協(xié)議。對于設計人員來(lái)說(shuō),滿(mǎn)足這些行動(dòng)和序列要求的最佳方法則是使用機。機是在數量有限的之間進(jìn)行轉換的邏輯結構。一個(gè)狀態(tài)機在某個(gè)特定的時(shí)間點(diǎn)只處于一種狀態(tài)。但在一系列觸發(fā)器的觸發(fā)下,將在不同狀態(tài)間進(jìn)行轉換。

本文引用地址:http://dyxdggzs.com/article/148029.htm

理論上講,狀態(tài)機可以分為Moore狀態(tài)機和Mealy狀態(tài)機兩大類(lèi)。它們之間的差異僅在于生成狀態(tài)機的輸出。Moore狀態(tài)機的輸出僅為當前狀態(tài)的函數。典型的例子就是計數器。而Mealy狀態(tài)機的輸出是當前狀態(tài)和輸入的函數。典型的例子就是Richards控制器。

定義狀態(tài)機

當需要定義一個(gè)狀態(tài)機時(shí),首先要繪制一張狀態(tài)圖。狀態(tài)圖可用來(lái)顯示狀態(tài)、狀態(tài)間的轉換和狀態(tài)機的輸出。圖1顯示了Moore狀態(tài)機的狀態(tài)圖(左)和Mealy狀態(tài)機的狀態(tài)圖(右)。

用于開(kāi)/關(guān)LED的Moore狀態(tài)機(左)和Mealy狀態(tài)機(右)的狀態(tài)圖

圖1,用于開(kāi)/關(guān)LED的Moore狀態(tài)機(左)和Mealy狀態(tài)機(右)的狀態(tài)圖。

如果您要在物理組件中這些狀態(tài)圖(工程師在問(wèn)世之前就是這么做的),首先就得生成當前狀態(tài)和后續狀態(tài)表,然后生成狀態(tài)機所需的邏輯。不過(guò)由于我們將使用來(lái)實(shí)現設計,因此我們可以直接從狀態(tài)轉換圖開(kāi)始工作。

算法狀態(tài)圖

雖然有許多狀態(tài)機是使用圖1所示的狀態(tài)圖方法進(jìn)行設計的,但另外還有一種描述狀態(tài)機行為的方法,這就是算法狀態(tài)圖法。ASM圖(圖2)在外觀(guān)上更加接近軟件工程流程圖。它由三個(gè)基本部分構成:

1.狀態(tài)框。它與狀態(tài)名稱(chēng)有關(guān),并包含Moore狀態(tài)輸出列表。

2.決策框。如果檢驗某條件為真,則進(jìn)行下一狀態(tài)的判斷。

3.條件輸出框。讓狀態(tài)機根據當前狀態(tài)和輸入描述Mealy輸出。

一些工程師認為,如果使用VHDL等硬件描述語(yǔ)言,則采用ASM格式進(jìn)行描述的狀態(tài)機更易于映射到實(shí)現方案中。

用于圖1所示的狀態(tài)機(Moore狀態(tài)機(左),Mealy狀態(tài)機(右))的算法狀態(tài)圖

圖2,用于圖1所示的狀態(tài)機(Moore狀態(tài)機(左),Mealy狀態(tài)機(右))的算法狀態(tài)圖。

Moore和Mealy:應該選擇哪個(gè)?

實(shí)現Moore狀態(tài)機還是Mealy狀態(tài)機,取決于狀態(tài)機需要實(shí)現的功能,以及特定的反應次數要求。兩種狀態(tài)機之間的最大差別在于狀態(tài)機對輸入做出反應。在輸入和設置的適當輸出之間,Moore狀態(tài)機一般有一個(gè)時(shí)鐘周期的延遲。這就意味著(zhù)Moore狀態(tài)機無(wú)法對輸入變化立即做出反應,這點(diǎn)在圖3中可以清楚地看到。而Mealy狀態(tài)機則能夠立即對輸入做出反應,這通常意味著(zhù):實(shí)現相同的函數,Mealy狀態(tài)機比Moore狀態(tài)機需要更少的狀態(tài)。Mealy狀態(tài)機的不足之處就是在與另一個(gè)狀態(tài)機進(jìn)行通信時(shí),如果輸出出乎意料地嚴重依賴(lài)于其它事件的序列或時(shí)序,就可能會(huì )發(fā)生紊亂情況。

截屏顯示了Moore狀態(tài)機(上)和Mealy狀態(tài)機(下)輸出的仿真結果

圖3,截屏顯示了Moore狀態(tài)機(上)和Mealy狀態(tài)機(下)輸出的仿真結果。

當然,并非只能使用單純的Moore狀態(tài)機或Mealy狀態(tài)機,也可以將這兩種狀態(tài)機混合使用,從而更有效地實(shí)現所需的函數。比如說(shuō),用于接收RS232串行數據的狀態(tài)機就可以是混合機。

實(shí)現狀態(tài)機

使用VHDL這樣的高級語(yǔ)言,可以輕松地直接從狀態(tài)圖實(shí)現狀態(tài)機。VHDL支持多種枚舉類(lèi)型,方便您定義實(shí)際的狀態(tài)名稱(chēng)。舉例如下:

TYPE state IS (idle, led_on, led_off) ;

上面的類(lèi)型定義對應的是圖1中所示的狀態(tài)圖,即用于在按下按鈕時(shí)切換發(fā)光二極管開(kāi)/關(guān)的狀態(tài)機。

實(shí)現狀態(tài)機有許多種方法,可分為兩類(lèi)基本方法。第一類(lèi)基本方法就是一次性將所有內容集成到單個(gè)進(jìn)程中。第二類(lèi)基本方法是雙進(jìn)程法,將組合邏輯和順序邏輯分開(kāi)。

一般來(lái)說(shuō),大多數工程師都傾向于實(shí)現單進(jìn)程狀態(tài)機。與傳統上講授的雙進(jìn)程法相比,這種方法具有以下優(yōu)勢:

●可以避免組合過(guò)程中信號覆蓋不完全造成的閉鎖風(fēng)險。

●狀態(tài)機的輸出與時(shí)鐘保持同步。

●通常比雙進(jìn)程實(shí)現方案更容易調試。

無(wú)論您決定采用哪一種方法來(lái)實(shí)現狀態(tài)機,都需要使用CASE語(yǔ)句來(lái)評估下一狀態(tài)的判定和任何輸出,如圖4所示。該圖并行比較了使用單進(jìn)程法的Moore狀態(tài)機(左)和Mealy狀態(tài)機(右)。

使用VHDL語(yǔ)言的Moore狀態(tài)機(左)和Mealy狀態(tài)機

圖4,使用VHDL語(yǔ)言的Moore狀態(tài)機(左)和Mealy狀態(tài)機。

狀態(tài)機編碼

狀態(tài)變量存儲在觸發(fā)器中,使用下一時(shí)鐘邊緣上的下一狀態(tài)進(jìn)行更新(即使沒(méi)有狀態(tài)變化也是如此)。使用觸發(fā)器來(lái)表示狀態(tài)值具體取決于狀態(tài)的數量和是否選擇用某種特定的方法來(lái)管理綜合工具。狀態(tài)編碼最常見(jiàn)的三種類(lèi)型是:

●順序碼--狀態(tài)編碼遵循傳統的狀態(tài)二進(jìn)制序列。

●格雷碼--除了狀態(tài)編碼使用格雷碼,且狀態(tài)編碼串之間只有一個(gè)位變化外,其它基本與順序編碼方法類(lèi)似。

●獨熱碼--這種方法在狀態(tài)機中為每一種狀態(tài)分配一個(gè)觸發(fā)器。只有一個(gè)觸發(fā)器當前設置為高位,其余均設置為低位。故稱(chēng)為“獨熱”.

順序編碼和格雷編碼都需要一定數量的觸發(fā)器,可以通過(guò)下列等式來(lái)確定:

相比之下,獨熱編碼法所需的觸發(fā)器數量和狀態(tài)數量一樣多。

狀態(tài)編碼的自動(dòng)分配取決于狀態(tài)機所包含的狀態(tài)數量。同時(shí)還需要考慮您選擇使用的綜合工具。您可以根據下列經(jīng)驗法則來(lái)選取編碼方法:

fpga相關(guān)文章:fpga是什么


塵埃粒子計數器相關(guān)文章:塵埃粒子計數器原理

上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: 狀態(tài) 實(shí)現 FPGA 如何

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>