题解 | #根据状态转移写状态机-三段式#

根据状态转移写状态机-三段式

http://www.nowcoder.com/practice/d8394a6d31754e73ace8c394e9465e2a

`timescale 1ns/1ns

module fsm1(
    input wire clk  ,
    input wire rst  ,
    input wire data ,
    output reg flag
);
//*************code***********//
    parameter S0 = 4'd0001;
    parameter S1 = 4'd0010;
    parameter S2 = 4'd0100;
    parameter S3 = 4'd1000;

    reg [3:0] c_state;
    reg [3:0] n_state;
    
    always @(posedge clk or negedge rst) begin
        if(!rst)
            c_state <= S0;
        else
            c_state <= n_state;
    end
    
    always @(*) begin
        case(c_state)
            S0: if(data == 1) n_state <= S1;else n_state <= c_state;
            S1: if(data == 1) n_state <= S2;else n_state <= c_state;
            S2: if(data == 1) n_state <= S3;else n_state <= c_state;
            S3: if(data == 1) n_state <= S0;else n_state <= c_state;
            default: n_state <= S1;
        endcase
    end
    
    always @(posedge clk or negedge rst) begin
        if(!rst)
            flag <= 1'b0;
        else begin
            case(c_state)
                S3:if(data) flag <= 1'b1;else flag <= 1'b0;
                default: flag <= 1'b0;
            endcase
        end
    end
    
//*************code***********//
endmodule
全部评论

相关推荐

05-20 21:57
已编辑
门头沟学院 Java
喜欢吃卤蛋的悲伤蛙在提需求:建信融通没消息吧,我2说有实习挂简历不理了
点赞 评论 收藏
分享
炫哥_:哥们项目描述里面vector和mysql之类的都要写吗,直接开头技术栈巴拉巴拉就行了,完全不是技术点啊
点赞 评论 收藏
分享
秋招不是要开始了吗,我都打算润了,看大家还在找不敢润了
一条从:因为不是人人都像佬一样有实习像我们这种二本仔秋招没有实习也是白忙活
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务