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

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創作中心

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

3天內不再提示

什么是狀態機 狀態機的描述三種方法

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

狀態機

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

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

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

4、(1)一段式狀態機

module detect_1(
input clk_i,
input rst_n_i,
output out_o
);
reg out_r;
//狀態聲明和狀態編碼
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

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

(2)兩段式狀態機

//狀態聲明和狀態編碼
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;
//時序邏輯:描述狀態轉換
always@(posedge clk_i)
begin
if(!rst_n_i)
Current_state<=0;
else
Current_state<=Next_state;
end
//組合邏輯:描述下一狀態和輸出
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

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

(3)三段式狀態機

module detect_3(
input clk_i,
input rst_n_i,
output out_o
);
reg out_r;
//狀態聲明和狀態編碼
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;
//時序邏輯:描述狀態轉換
always@(posedge clk_i)
begin
if(!rst_n_i)
Current_state<=0;
else
Current_state<=Next_state;
end
//組合邏輯:描述下一狀態
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,經過寄存器 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;

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

編輯:hfy


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

    關注

    13

    文章

    502

    瀏覽量

    43068
  • Verilog
    +關注

    關注

    28

    文章

    1364

    瀏覽量

    111404
  • 觸發器
    +關注

    關注

    14

    文章

    2029

    瀏覽量

    61747
  • 狀態機
    +關注

    關注

    2

    文章

    493

    瀏覽量

    27962
收藏 1人收藏

    評論

    相關推薦

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

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

    mosfet的三種工作狀態及工作條件是什么

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

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

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

    NPN型晶體管三種狀態判斷方法

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

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

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

    如何在FPGA中實現狀態機

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

    態緩沖器的三種狀態分別是什么

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

    玩轉Spring狀態機

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

    關于SMU狀態機的問題求解

    我有一些關于 SMU 狀態機的問題。 假設由于某種原因,SMU 已進入故障狀態。 手冊指出,要返回運行狀態并將 FSP 恢復到無故障狀態,應調用IfxSmu_releaseFSP()。
    發表于 05-29 08:18

    晶體管的三種工作狀態

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

    在GPIF設計器中設計狀態機時,無法訪問附件中所示的線程編號如何解決?

    在 GPIF 設計器中設計狀態機時,我無法訪問附件中所示的線程編號、 如何解決這個問題?
    發表于 05-23 07:18

    使用系統滴答定時中斷,基于按鍵的狀態機怎么只能1個1個+,不能連+?

    使用系統滴答定時中斷,基于按鍵的狀態機怎么只能1個1個+,不能連+ #define KEY1_USERGPIO_ReadInputDataBit(GPIOC,GPIO_Pin_13
    發表于 05-16 06:27

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

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

    極管的三種工作狀態是什么

    極管是一由兩個PN結構成的半導體器件。根據其基極、集電極和發射極的摻雜類型不同,可以分為NPN型和PNP型兩。在電子電路中,極管可以控制電流的大小,并有
    的頭像 發表于 05-02 16:24 ?6766次閱讀
    <b class='flag-5'>三</b>極管的<b class='flag-5'>三種</b>工作<b class='flag-5'>狀態</b>是什么

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

    編寫能夠被綜合工具識別的狀態機,首先需要理解狀態機的基本概念和分類。狀態機(FSM)是表示有限個狀態以及在這些狀態之間轉換的邏輯結構。
    的頭像 發表于 05-01 11:38 ?2171次閱讀
    主站蜘蛛池模板: 精品视频在线播放 | 国产人妻人伦精品836700 | 久久学生精品国产自在拍 | 在线观看99 | 日韩欧美一区二区三区在线视频 | 午夜DJ国产精华日本无码 | YELLOW视频直播在线观看 | 国产亚洲精品品视频在线 | 99视频免视看 | 久久久久综合 | 亚洲AV人无码综合在线观看蜜桃 | 久久精品电影久久电影大全 | 黑人巨摘花破女处 | 成人国产精品免费网站 | 老湿机一区午夜精品免费福利 | 久久久精品日本一区二区三区 | 内射后入在线观看一区 | a在线观看免费视频 | 二级片免费看 | 精品无码国产自产在线观看水浒传 | 精品精品国产自在现拍 | YIN荡的老师系列第6部分视频 | 伊人影院综合网 | 最新国产三级在线不卡视频 | 麻豆精品传媒2021网站入口 | 午夜dj影院视频观看 | 2020亚洲色噜噜狠狠网站 | 饥渴的40岁熟妇完整版在线 | 久久免费看少妇高潮A片JA | 亚洲 天堂 国产在线播放 | 精品久久久久中文字幕日本 | 歪歪爽蜜臀AV久久精品人人槡 | 午夜免费无码福利视频麻豆 | 中文字幕亚洲男人的天堂网络 | 高h 纯肉文| 精品午夜视频 | 内射白嫩少妇超碰 | 国产免费久久爱久久啪 | 强行撕开衣服捏胸黄文 | 日本理伦片午夜理伦片 | 成人在线免费视频观看 |

    電子發燒友

    中國電子工程師最喜歡的網站

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