版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第5章时序状态机设计第5章时序状态机设计21有限状态机状态机设计实例5.1有限状态机
有限状态机及其设计技术是数字系统设计中的重要组成部分,是实现高效率、高可靠和高速控制逻辑系统的重要途径。有限状态机FSM(FiniteStateMachine),其在任意时刻都处于有限状态集合中的某一种状态。有限状态机是指输出取决于过去输出部分和当前输入部分的时序逻辑电路。有限状态机又可以认为是组合逻辑和寄存器逻辑的一种组合。状态机特别适合描述那些发生有先后顺序或者有逻辑规律的事件,其实这就是状态机的本质。状态机就是对具有逻辑顺序或时序规律的事件进行描述的一种方法。5.2状态机设计实例1.穆尔型状态机设计实例“1101”序列检测器【例5.2-1】
穆尔型状态机的VerilogHDL三always块描述实例。modulemoore(inputclk,inputrst,inputdin,outputregdout);5.2状态机设计实例parameters0=3'b000,s1=3'b001,s2=3'b010,s3=3'b011,s4=3'b100;//状态说明reg[2:0]present_state,next_state; //现态、次态//状态模块always@(posedgeclkorposedgerst)beginif(rst)present_state=s0;elsepresent_state=next_state;end//次态always@(*)begincase(present_state)s0:if(din==1)next_state<=s1;elsenext_state<=s0;s1:if(din==1)next_state<=s2;elsenext_state<=s0;5.2状态机设计实例s2:if(din==0)next_state<=s3;elsenext_state<=s2;s3:if(din==1)next_state<=s4;elsenext_state<=s0;s4:if(din==0)next_state<=s0;elsenext_state<=s2;default:next_state<=s0;endcaseendalways@(*)beginif(present_state==s4)dout<=1;elsedout<=0;endendmodule5.2状态机设计实例【例5.2-2】穆尔型状态机的Testbench仿真测试。5.2状态机设计实例2.米利型状态机设计实例“1101”序列检测器【例5.2-3】米利型状态机的VerilogHDL三always块描述实例。modulemealy(inputclk,inputrst,inputdin,outputregdout);5.2状态机设计实例parameters0=2'b00,s1=2'b01,s2=2'b10,s3=2'b11;reg[1:0]present_state,next_state;//状态模块always@(posedgeclkorposedgerst)beginif(rst)present_state=s0;elsepresent_state=next_state;end//次态模块always@(*)begincase(present_state)s0:if(din==1)next_state<=s1;elsenext_state<=s0;s1:if(din==1)next_state<=s2;elsenext_state<=s0;5.2状态机设计实例s2:if(din==0)next_state<=s3;elsenext_state<=s2;s3:if(din==1)next_state<=s1;elsenext_state<=s0;default:next_state<=s0;endcaseend//输出模块always@(*)beginif((present_state==s3)&&(din==1))dout<=1;elsedout<=0;endendmodule5.2状态机设计实例【例5.2-4】米利型状态机的VerilogHDL双always块描述实例。modulemealy(inputclk,inputrst,inputdin,outputregdout);parameters0=2'b00,s1=2'b01,s2=2'b10,s3=2'b11;reg[1:0]present_state,next_state;//状态模块always@(posedgeclkorposedgerst)beginif(rst)present_state=s0;elsepresent_state=next_state;end5.2状态机设计实例//次态和输出模块always@(*)begindout<=0;case(present_state)s0:if(din==1)next_state<=s1;elsenext_state<=s0;s1:if(din==1)next_state<=s2;elsenext_state<=s0;s2:if(din==0)next_state<=s3;elsenext_state<=s2;s3:if(din==1)beginnext_state<=s1;dout<=1;endelsenext_state<=s0;default:next_state<=s0;endcaseendendmodule5.2状态机设计实例【例5.2-5】米利型状态机的VerilogHDL单always块描述实例。modulemealy(inputclk,inputrst,inputdin,outputregdout);parameters0=2'b00,s1=2'b01,s2=2'b10,s3=2'b11;reg[1:0]state;//状态模块always@(posedgeclkorposedgerst)beginif(rst)beginstate=s0;dout<=0;end5.2状态机设计实例elsebegindout<=0;case(state)s0:if(din==1)state<=s1;elsestate<=s0;s1:if(din==1)state<=s2;elsestate<=s0;s2:if(din==0)state<=s3;elsestate<=s2;s3:if(din==1)beginstate<=s1;dout<=1;endelsestate<=s0;default:state<=s0;endcaseendendendmodule5.2状态机设计实例米利型状态机的Testbench仿真测试米利型状态机仿真:单always块描述5.2状态机设计实例【例5.2-6】状态机描述实例,A是输入,X是穆尔型输出,Y是米利型输出。modulemealy_moore( inputclk, inputrst_n, inputa, outputregx,y ); parameters0=2'b00,s1=2'b01,s2=2'b10,s3=2'b11;
reg[1:0]present_state,next_state; //状态模块 always@(posedgeclkornegedgerst_n)begin if(!rst_n)present_state<=s0;//在rst_n下降沿设s0为初态 elsepresent_state<=next_state; end
5.2状态机设计实例//第二个always是将present_state和输入a作为敏感变量 always@(present_stateora)begin
case(present_state)
s0:begin
x<=0;y<=0;
next_state<=(a==1)?s2:s0; end s1:begin
x<=1;
if(a==0)begin
y<=1;next_state<=s0;
end elsebegin
y<=0;
next_state<=s1;
end
end5.2状态机设计实例 s2:begin
x<=0;
if(a==0)begin
y<=1;
next_state<=s0;
end elsebegin
y<=0;
next_state<=s3;
end
end s3:begin
x<
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 常州市溧阳中学高三地理一轮复习第二章城市化作业
- 2025年高职模具设计与制造(复杂模具设计)试题及答案
- 大学(临床医学)儿科学基础2026年试题及答案
- 2025年中职(烹饪工艺)宴席菜品设计阶段测试题及答案
- 2025年大学大一(轮机工程)轮机自动化试题及答案
- 2025年高职(船舶电子电气技术)船舶电气设备试题及答案
- 2025年大学测绘工程(地图注记设计)试题及答案
- 2025年大学大二(种子科学与工程)种子生产学基础试题及答案
- 2025年中职(健康服务与管理)健康档案管理试题及答案
- 2025年高职汽车电子技术(汽车诊断技术)试题及答案
- 《李时珍》课件内容
- 2026高考化学复习难题速递之化学反应速率与化学平衡(解答题)(2025年11月)
- 2025年山东省枣庄市辅警(协警)招聘考试题库及答案
- 重庆试管婴儿合同协议
- 2025广西投资集团有限公司招聘4人笔试历年参考题库附带答案详解
- 基层医疗机构医疗质量精细化管理策略
- (安徽省十联考)合肥一中2026届高三12月份教学质量测生物试卷(含答案)
- 民兵军事训练的组织与实施
- 2025年广西公需科目答案2卷(含答案)
- DB11-T 2493-2025 餐饮服务单位使用丙类液体燃料消防安全管理规范
- 超星尔雅学习通《动手学AI人工智能通识与实践(理工版)》章节测试附答案
评论
0/150
提交评论