首页 技术 正文
技术 2022年11月21日
0 收藏 453 点赞 2,538 浏览 984 个字

状态机由状态寄存器和组合逻辑电路构成,能够根据控制信号按照预先设定的状态进行状态转移,是协调相关信号动作、完成特定操作的控制中心。有限状态机简写为FSM(Finite State Machine),主要分为2大类:第一类,若输出只和状态有关而与输入无关,则称为Moore状态机。第二类,输出不仅和状态有关而且和输入有关系,则称为Mealy状态。

module FSM(
input clk,
input clr,
input x,
output reg z,
output reg [:] current_state,next_state
);//101序列检测器;
//FSM中主要包含现态CS、次态NS、输出逻辑OL;
parameter S0='b00,S1=2'b01,S2='b11,S3=2'b10;//状态编码,采用格雷编码方式,S0为IDLE;/*------------------次态和现态的转换---------------*/
always @(posedge clk or negedge clr) begin
if(clr)
current_state<=S0;
else
current_state<=next_stateend/*------------------现态在输入情况下转换为次态的组合逻辑---------------*/
always @(current_state or x) begin
case(current_state)
S0:begin
if(x)
next_state<=S1;
else
next_state<=S0;
end
S1:begin
if(x)
next_state<=S1;
else
next_state<=S2;
end
S2:begin
if(x)
next_state<=S3;
else
next_state<=S0;
end
S3:begin
if(x)
next_state<=S1;
else
next_state<=S2;
end
default:next_state<=S0;
endcase
end
/*------------------现态到输出的组合逻辑---------------*/
always @(current_state) begin
case(current_state)//从S3要变化到S2这一刻;
S3:z='b1;
default:z='b0;
endcase
end
endmodule
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,028
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,518
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,366
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,146
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,780
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,858