




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第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年萍乡市税务系统遴选面试真题附解析含答案
- 落实安全管理措施
- 新时期市民热线数智化改革的模式创新研究
- 2025至2030生物杀虫剂行业项目调研及市场前景预测评估报告
- 2024年10月兴业银行龙岩分行国际业务岗位招考笔试历年参考题库附带答案详解
- 2024年10月中国光大银行滨州分行营业部副总经理(主管零售)(滨州)招聘笔试历年参考题库附带答案详解
- 2025至2030手机壳行业发展趋势分析与未来投资战略咨询研究报告
- 县城区排水防涝整治项目可行性研究报告
- 2025年中国PE防静电自封袋数据监测报告
- 2025至2030中国汽车金融行业市场深度调研及发展战略与投资前景报告
- 期末试卷(含答案)2024-2025学年四年级下册数学北师大版
- 《客舱安全与应急处置》-课件:火灾的基础知识
- 自然资源执法监察工作规范培训课件
- 部编版《语文》三年级下册全册教案及反思
- 《干部履历表》(1999版电子版)
- 大学生创新创业训练计划项目(模板)
- 巨量引擎O-5A人群资产经营方法论
- 置信度-可靠度-存活率
- 2023年最新的汉语言文学社会实践调查报告
- JJG 30-2012 通用卡尺-(高清现行)
- 工厂制造中心上半年工作总结报告精编ppt
评论
0/150
提交评论