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

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

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

什么是狀態(tài)機 狀態(tài)機的描述三種方法

454398 ? 來源:CSDN博主 ? 作者:herryone123 ? 2020-11-16 17:39 ? 次閱讀

狀態(tài)機

1、狀態(tài)機是許多數(shù)字系統(tǒng)的核心部件,是一類重要的時序邏輯電路。通常包括三個部分:一是下一個狀態(tài)的邏輯電路,二是存儲狀態(tài)機當前狀態(tài)的時序邏輯電路,三是輸出組合邏輯電路。

2、根據(jù)狀態(tài)機的輸出信號是否與電路的輸入有關分為Mealy型狀態(tài)機和Moore型狀態(tài)機。電路的輸出信號不僅與電路當前狀態(tài)有關,還與電路的輸入有關,稱為 Mealy 型狀態(tài)機,而電路的輸出僅僅與各觸發(fā)器的狀態(tài),不受電路輸入信號影響或無輸入,稱為
Moore 型狀態(tài)機。

3、狀態(tài)機的描述通常有三種方法,稱為一段式狀態(tài)機,二段式狀態(tài)機和三段式狀態(tài)機。狀態(tài)機的描述通常包含以下四部分:
1)利用參數(shù)定義語句 parameter 描述狀態(tài)機各個狀態(tài)名稱,即狀態(tài)編碼。狀態(tài)編碼通常有很多方法包含自然二進制編碼,One-hot 編碼,格雷編碼碼等;
2)用時序的 always 塊描述狀態(tài)觸發(fā)器實現(xiàn)狀態(tài)存儲;
3)使用敏感表和 case 語句(也采用 if-else 等價語句)描述狀態(tài)轉(zhuǎn)換邏輯;
4)描述狀態(tài)機的輸出邏輯。

4、(1)一段式狀態(tài)機

module detect_1(
input clk_i,
input rst_n_i,
output out_o
);
reg out_r;
//狀態(tài)聲明和狀態(tài)編碼
reg [1:0] state;
parameter [1:0] S0=2'b00;
parameter [1:0] S1=2'b01;
parameter [1:0] S2=2'b10;
parameter [1:0] S3=2'b11;
always@(posedge clk_i)
begin
if(!rst_n_i)begin
state<=0;
out_r<=1'b0;
end
else
case(state)
S0 :
begin
out_r<=1'b0;
state<= S1;
end
S1 :
begin
out_r<=1'b1;
state<= S2;
end
S2 :
begin
out_r<=1'b0;
state<= S3;
end
S3 :
begin
out_r<=1'b1;
end
endcase
end
assign out_o=out_r;
endmodule

一段式狀態(tài)機是應該避免使用的,該寫法僅僅適用于非常簡單的狀態(tài)機設計,不符合組
合邏輯與時序邏輯分開的原則,整個結構代碼也不清晰,不利用維護和修改。

(2)兩段式狀態(tài)機

//狀態(tài)聲明和狀態(tài)編碼
reg [1:0] Current_state;
reg [1:0] Next_state;
parameter [1:0] S0=2'b00;
parameter [1:0] S1=2'b01;
parameter [1:0] S2=2'b10;
parameter [1:0] S3=2'b11;
//時序邏輯:描述狀態(tài)轉(zhuǎn)換
always@(posedge clk_i)
begin
if(!rst_n_i)
Current_state<=0;
else
Current_state<=Next_state;
end
//組合邏輯:描述下一狀態(tài)和輸出
always@(*)
begin
out_r=1'b0;
case(Current_state)
S0 :
begin
out_r=1'b0;
Next_state= S1;
end
S1 :
begin
out_r=1'b1;
Next_state= S2;
end
S2 :
begin
out_r=1'b0;
Next_state= S3;
end
S3 :
begin
out_r=1'b1;
Next_state=Next_state;
end
endcase
end
assign out_o=out_r;
endmodule

兩段式狀態(tài)機采用兩個 always 模塊實現(xiàn)狀態(tài)機的功能,其中一個 always 采用同步時序邏輯描述狀態(tài)轉(zhuǎn)移,另一個 always 采用組合邏輯來判斷狀態(tài)條件轉(zhuǎn)移。兩段式狀態(tài)機是推薦的狀態(tài)機設計方法。

(3)三段式狀態(tài)機

module detect_3(
input clk_i,
input rst_n_i,
output out_o
);
reg out_r;
//狀態(tài)聲明和狀態(tài)編碼
reg [1:0] Current_state;
reg [1:0] Next_state;
parameter [1:0] S0=2'b00;
parameter [1:0] S1=2'b01;
parameter [1:0] S2=2'b10;
parameter [1:0] S3=2'b11;
//時序邏輯:描述狀態(tài)轉(zhuǎn)換
always@(posedge clk_i)
begin
if(!rst_n_i)
Current_state<=0;
else
Current_state<=Next_state;
end
//組合邏輯:描述下一狀態(tài)
always@(*)
begin
case(Current_state)
S0:
Next_state = S1;
S1:
Next_state = S2;
S2:
Next_state = S3;
S3:
begin
Next_state = Next_state;
end
default :
Next_state = S0;
endcase
end
//輸出邏輯:讓輸出 out,經(jīng)過寄存器 out_r 鎖存后輸出,消除毛刺
always@(posedge clk_i)
begin
if(!rst_n_i)
out_r<=1'b0;
else
begin
case(Current_state)
S0,S2:
out_r<=1'b0;
S1,S3:
out_r<=1'b1;
default :
out_r<=out_r;
endcase
end
end
assign out_o=out_r;

三段式狀態(tài)機在第一個 always 模塊采用同步時序邏輯方式描述狀態(tài)轉(zhuǎn)移,第二個always 模塊采用組合邏輯方式描述狀態(tài)轉(zhuǎn)移規(guī)律,第三個 always 描述電路的輸出。通常讓輸出信號經(jīng)過寄存器緩存之后再輸出,消除電路毛刺。這種狀態(tài)機也是比較推崇的,主要是由于維護方便,組合邏輯與時序邏輯完全獨立。

編輯:hfy


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

    關注

    13

    文章

    502

    瀏覽量

    43161
  • Verilog
    +關注

    關注

    28

    文章

    1365

    瀏覽量

    111776
  • 觸發(fā)器
    +關注

    關注

    14

    文章

    2032

    瀏覽量

    61853
  • 狀態(tài)機
    +關注

    關注

    2

    文章

    493

    瀏覽量

    28062
收藏 人收藏

    評論

    相關推薦
    熱點推薦

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

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

    cypress3014視頻格式改變的話,GPIF狀態(tài)機需不需要重新配置?

    你好,請問視頻格式改變的話,GPIF狀態(tài)機需不需要重新配置
    發(fā)表于 05-14 07:28

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

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

    Simulink中的狀態(tài)機建模方法 Simulink數(shù)據(jù)可視化與分析功能

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

    基于狀態(tài)機和面向?qū)ο蟮乃枷朐O計按鍵檢測模塊

    嵌入式入門學習的教程里面,按鍵原理普遍被認為是“很簡單”的知識點之一,按鍵輸入檢測的原理,無非就是通過CPU不斷掃描按鍵引腳的電平狀態(tài),或者采用單片引腳外部中斷方式,然后在死循環(huán)或者中斷服務程序里面處理按鍵被按下
    的頭像 發(fā)表于 11-14 11:44 ?850次閱讀
    基于<b class='flag-5'>狀態(tài)機</b>和面向?qū)ο蟮乃枷朐O計按鍵檢測模塊

    mosfet的三種工作狀態(tài)及工作條件是什么

    )的不同,可以工作在三種主要狀態(tài):截止狀態(tài)、線性區(qū)和飽和區(qū)。 1. 截止狀態(tài) 工作狀態(tài)描述
    的頭像 發(fā)表于 10-06 16:51 ?5269次閱讀

    晶體管的工作狀態(tài)判斷方法

    晶體管的工作狀態(tài)判斷是電子工程領域中的一項重要技能,它對于確保電路的正常運行和性能優(yōu)化至關重要。晶體管的工作狀態(tài)通常根據(jù)其內(nèi)部PN結的偏置情況來判斷,主要包括截止狀態(tài)、放大狀態(tài)和飽和
    的頭像 發(fā)表于 09-23 18:16 ?4143次閱讀

    單片io口的四工作狀態(tài)

    )是單片與外部世界進行數(shù)據(jù)交換的接口。每個I/O口可以配置為輸入或輸出狀態(tài),或者同時具備這兩功能。I/O口的狀態(tài)可以通過編程來控制,以滿足不同的應用需求。 2. 單片
    的頭像 發(fā)表于 09-14 14:24 ?3442次閱讀

    時序邏輯電路的描述方法有哪些

    圖、狀態(tài)表、有限狀態(tài)機、卡諾圖、布爾差分方程、布爾函數(shù)、時序邏輯仿真等。 狀態(tài)狀態(tài)圖是一圖形化的
    的頭像 發(fā)表于 08-28 11:37 ?1191次閱讀

    NPN型晶體管三種狀態(tài)判斷方法

    NPN型晶體管作為電子學中的基礎元件,具有放大、開關等多種功能。其工作狀態(tài)根據(jù)基極、發(fā)射極和集電極之間的電壓和電流關系可分為截止狀態(tài)、放大狀態(tài)和飽和狀態(tài)。以下是對NPN型晶體管
    的頭像 發(fā)表于 08-13 17:33 ?4467次閱讀

    觸發(fā)器和狀態(tài)機的關系是什么

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

    MCUXpresso IDE下在線聯(lián)合調(diào)試雙核MCU工程的三種方法

    大家好,我是痞子衡,是正經(jīng)搞技術的痞子。今天痞子衡給大家分享的是MCUXpresso IDE下在線聯(lián)合調(diào)試i.MXRT1170雙核工程的三種方法。
    的頭像 發(fā)表于 08-08 15:18 ?1177次閱讀
    MCUXpresso IDE下在線聯(lián)合調(diào)試雙核MCU工程的<b class='flag-5'>三種方法</b>

    如何在FPGA中實現(xiàn)狀態(tài)機

    在FPGA(現(xiàn)場可編程門陣列)中實現(xiàn)狀態(tài)機是一常見的做法,用于控制復雜的數(shù)字系統(tǒng)行為。狀態(tài)機能夠根據(jù)當前的輸入和系統(tǒng)狀態(tài),決定下一步的動作和新的
    的頭像 發(fā)表于 07-18 15:57 ?1079次閱讀

    態(tài)緩沖器的三種狀態(tài)分別是什么

    態(tài)緩沖器之所以得名,是因為它具備三種不同的工作狀態(tài):正常邏輯狀態(tài)輸出、高阻狀態(tài)和使能狀態(tài)。這
    的頭像 發(fā)表于 06-27 16:01 ?1933次閱讀

    玩轉(zhuǎn)Spring狀態(tài)機

    說起Spring狀態(tài)機,大家很容易聯(lián)想到這個狀態(tài)機和設計模式中狀態(tài)模式的區(qū)別是啥呢?沒錯,Spring狀態(tài)機就是狀態(tài)模式的一
    的頭像 發(fā)表于 06-25 14:21 ?1259次閱讀
    玩轉(zhuǎn)Spring<b class='flag-5'>狀態(tài)機</b>

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品