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

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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐ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)機當(dāng)前狀態(tài)的時序邏輯電路,三是輸出組合邏輯電路。

2、根據(jù)狀態(tài)機的輸出信號是否與電路的輸入有關(guān)分為Mealy型狀態(tài)機和Moore型狀態(tài)機。電路的輸出信號不僅與電路當(dāng)前狀態(tài)有關(guān),還與電路的輸入有關(guān),稱為 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)編碼通常有很多方法包含自然二進(jìn)制編碼,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)機是應(yīng)該避免使用的,該寫法僅僅適用于非常簡單的狀態(tài)機設(shè)計,不符合組
合邏輯與時序邏輯分開的原則,整個結(jié)構(gòu)代碼也不清晰,不利用維護(hù)和修改。

(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)機設(shè)計方法。

(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)機也是比較推崇的,主要是由于維護(hù)方便,組合邏輯與時序邏輯完全獨立。

編輯:hfy


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

    關(guān)注

    13

    文章

    494

    瀏覽量

    42609
  • Verilog
    +關(guān)注

    關(guān)注

    28

    文章

    1351

    瀏覽量

    110075
  • 觸發(fā)器
    +關(guān)注

    關(guān)注

    14

    文章

    2000

    瀏覽量

    61132
  • 狀態(tài)機
    +關(guān)注

    關(guān)注

    2

    文章

    492

    瀏覽量

    27529
收藏 人收藏

    評論

    相關(guān)推薦

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

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

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

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

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

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

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

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

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

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

    關(guān)于SMU狀態(tài)機的問題求解

    我有一些關(guān)于 SMU 狀態(tài)機的問題。 假設(shè)由于某種原因,SMU 已進(jìn)入故障狀態(tài)。 手冊指出,要返回運行狀態(tài)并將 FSP 恢復(fù)到無故障狀態(tài),應(yīng)調(diào)用IfxSmu_releaseFSP()。
    發(fā)表于 05-29 08:18

    晶體管的三種工作狀態(tài)

    晶體管作為現(xiàn)代電子技術(shù)的基石,其工作狀態(tài)直接影響電子設(shè)備的性能和功能。晶體管通常具備三種基本的工作狀態(tài):截止狀態(tài)、放大狀態(tài)和飽和
    的頭像 發(fā)表于 05-28 14:53 ?1420次閱讀

    在Verilog中實現(xiàn)Moore型和Mealy型狀態(tài)機方法簡析

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

    嵌入式編程,如何用 C 語言實現(xiàn)狀態(tài)機設(shè)計?

    狀態(tài)機模式是一行為模式,通過多態(tài)實現(xiàn)不同狀態(tài)的調(diào)轉(zhuǎn)行為的確是一很好的方法,只可惜在嵌入式環(huán)境下,有時只能寫純C代碼,并且還需要考慮代碼的
    發(fā)表于 04-23 11:00

    求助LabVIEW,狀態(tài)機里面反饋節(jié)點如何初始化問題

    求助labview,狀態(tài)機里面反饋節(jié)點如何初始化,下次執(zhí)行這個狀態(tài)的時候初始化一次!謝謝謝謝!
    發(fā)表于 03-25 18:17

    如何采用“狀態(tài)機”解析UART數(shù)據(jù)幀

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

    什么是有限狀態(tài)機?如何解決傳統(tǒng)有限狀態(tài)機狀態(tài)爆炸」問題?

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

    Verilog狀態(tài)機+設(shè)計實例

    在verilog中狀態(tài)機的一很常用的邏輯結(jié)構(gòu),學(xué)習(xí)和理解狀態(tài)機的運行規(guī)律能夠幫助我們更好地書寫代碼,同時作為一思想方法,在別的代碼設(shè)計中
    的頭像 發(fā)表于 02-12 19:07 ?4059次閱讀
    Verilog<b class='flag-5'>狀態(tài)機</b>+設(shè)計實例

    狀態(tài)機該怎么監(jiān)控

    狀態(tài)機卡住的場景——通過狀態(tài)跳轉(zhuǎn)條件的DFX信號去判斷卡住的原因
    的頭像 發(fā)表于 01-15 10:03 ?416次閱讀
    <b class='flag-5'>狀態(tài)機</b>該怎么監(jiān)控

    Spring狀態(tài)機的實現(xiàn)原理和使用方法

    說起 Spring 狀態(tài)機,大家很容易聯(lián)想到這個狀態(tài)機和設(shè)計模式中狀態(tài)模式的區(qū)別是啥呢?沒錯,Spring 狀態(tài)機就是狀態(tài)模式的一
    的頭像 發(fā)表于 12-26 09:39 ?1977次閱讀
    Spring<b class='flag-5'>狀態(tài)機</b>的實現(xiàn)原理和使用<b class='flag-5'>方法</b>
    主站蜘蛛池模板: 黄色a三级免费看| 男人和女人全黄一级毛片| 777午夜精品久久AV蜜臀| 色欲AV亚洲午夜精品无码| 精品久久久噜噜噜久久久app| 欧美特级特黄AAAAA片| 好色女博士| 寂寞夜晚在线视频观看| 狠狠躁天天躁小说| 韩国免费啪啪漫画无遮拦健身教练| 国产精品青草久久福利不卡| 国产精品999| 国产精品久久久久影院免费| 国产精品JIZZ在线观看A片| 国产成人综合在线观看网站| 国产AV高清怡春院| 国产AV麻豆出品在线播放| 国产精品A久久777777| 国产乱码一区二区三区| 国产亚洲va在线电影| 国产亚洲AV无码成人网站| 精品久久久麻豆国产精品| 久久xxxx| 免费视频网站嗯啊轻点| 欧美四虎精品二区免费| 日日噜噜噜噜夜夜爽亚洲精品| 受被三个攻各种道具PLAY| 欧洲内射VIDEOXXX3D| 噜噜噜狠狠夜夜躁精品| 精品国产品在线18年| 国内精自品线一区91| 国产精一品亚洲二区在线播放 | 果冻传媒AV精品一区| 国产成人免费在线观看| 99婷婷久久精品国产一区二区| 最近中文字幕在线看免费完整版| 亚洲精品成A人在线观看| 亚洲 中文 自拍 无码| 文中字幕一区二区三区视频播放 | 欧美牲交A欧美牲交VDO| 凌馨baby|