HDLBits刷题Day24,3.2.5.9 Design a Moore FSM

3.2.5.9 Design a Moore FSM

问题描述

分析:

1.s=000时,打开fr1,fr2,fr3和补充水dfr

2.s=001时,打开fr1,fr2

3.s=011时,打开fr1

4.s=111时,关闭

5.当水位下降时,打开dfr

绘制一下状态转移图

代码:

cs 复制代码
module top_module (
    input clk,
    input reset,
    input [3:1] s,
    output fr3,
    output fr2,
    output fr1,
    output dfr
); 
	parameter A=0,B=1,C=2,D=3,E=4,F=5;
    reg [2:0] state,next_state;
    always @(posedge clk) begin
        if(reset) state <= A;
        else state <= next_state;
    end
    
    
    always @(*) begin
        case(state)
            A:next_state = s[1]?B:A;
            B:next_state = s[2]?D:(s[1]?B:A);
            C:next_state = s[2]?D:(s[1]?C:A);
            D:next_state = s[3]?F:(s[2]?D:C);
            E:next_state = s[3]?F:(s[2]?E:C);
            F:next_state = s[3]?F:E;
        endcase
    end
    always @(*) begin
        case(state)
            A:{fr3,fr2,fr1,dfr} = 4'b1111; 
            B:{fr3,fr2,fr1,dfr} = 4'b0110;
            C:{fr3,fr2,fr1,dfr} = 4'b0111;
            D:{fr3,fr2,fr1,dfr} = 4'b0010;
            E:{fr3,fr2,fr1,dfr} = 4'b0011;
            F:{fr3,fr2,fr1,dfr} = 4'b0000;
        endcase
    end
endmodule
相关推荐
勤劳的进取家18 分钟前
数据链路层基础
网络·学习·算法
Advancer-35 分钟前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤1 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法
superior tigre2 小时前
78 子集
算法·leetcode·深度优先·回溯
天威?*2 小时前
bitset的数据结构用法
算法·动态规划
珞光电子USRP SDR软件无线电平台2 小时前
打破通用瓶颈:珞光电子发布 Luowave Driver V2 定制化驱动方案
fpga开发
9527华安2 小时前
FPGA实现PCIe数据通信培训课程,提供工程源码+视频教程+FPGA开发板
fpga开发·pcie·视频教程·培训
my_daling2 小时前
FPGA实现IIC主机读写,以及部分IIC传感器控制流程
fpga开发
hoiii1872 小时前
粒子滤波跟踪系统 - 蒙特卡洛方法实现
算法
乌恩大侠2 小时前
【AI-RAN】在空ubuntu服务器安装环境和生成TV,高达430G文件
服务器·人工智能·ubuntu·fpga开发·o-ru