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
相关推荐
小南家的青蛙6 分钟前
LeetCode面试题 04.06 后继者
算法·leetcode·职场和发展
IT·小灰灰14 分钟前
基于Python的机器学习/数据分析环境搭建完全指南
开发语言·人工智能·python·算法·机器学习·数据分析
wefg11 小时前
【C++】智能指针
开发语言·c++·算法
搂鱼1145141 小时前
一类判断包含颜色整体的题目
算法
Demon--hx1 小时前
[c++]string的三种遍历方式
开发语言·c++·算法
九鼎创展科技1 小时前
九鼎创展发布X3588SCV4核心板,集成LPDDR5内存,提升RK3588S平台性能边界
android·人工智能·嵌入式硬件·硬件工程
无敌最俊朗@1 小时前
力扣hot100 - 合并两个有序链表21
算法·leetcode·链表
墨染点香1 小时前
LeetCode 刷题【168. Excel 表列名称】
算法·leetcode·职场和发展
hans汉斯1 小时前
基于改进YOLOv11n的无人机红外目标检测算法
大数据·数据库·人工智能·算法·yolo·目标检测·无人机
Swift社区2 小时前
LeetCode 431 - 将 N 叉树编码成二叉树
算法·leetcode·职场和发展