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

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

https://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 = 2'd0,
			  s1 = 2'd1,
			  s2 = 2'd2,
			  s3 = 2'd3;
	
	reg [1:0] cur_st,nxt_st;

	always @(posedge clk or negedge rst) begin
		if(rst == 1'b0)
			cur_st <= s0;
		else
			cur_st <= nxt_st;
	end

	always @(*)(1444584) begin
		case(cur_st)
			s0:begin
				if(data == 1'b1)
					nxt_st = s1;
				else
					nxt_st = s0;
			end
			s1:begin
				if(data == 1'b1)
					nxt_st = s2;
				else
					nxt_st = s1;
			end
			s2:begin
				if(data == 1'b1)
					nxt_st = s3;
				else	
					nxt_st = s2;
			end
			s3:begin
				if(data == 1'b1)
					nxt_st = s0;
				else
					nxt_st = s3;
			end
			default: nxt_st = s0;
		endcase
	end

	always @(posedge clk or negedge rst)begin
		if(rst == 1'b0)
			flag <= 1'b0;
		else if(cur_st == s3 && data == 1'b1)
			flag <= 1'b1;
		else
			flag <= 1'b0;
	end

//*************code***********//
endmodule

全部评论

相关推荐

缓解焦虑的最好方法是回家。鼠鼠昨天上午考完了本科阶段的最后一场考试,大概率考得稀烂,但是没多想,考完立马收拾行李,坐上了提前约好的顺风车飞奔回家。虽然家和学校很近,只有一百多公里的路程,但距离上次回家也已经有三四个月了。每次想回家,期间总有考试、毕业设计、面试、实习等等各种各样的原因,没办法回去,待在学校和公司的每一天也都充斥着无形的压力和焦虑。现在终于完成了答辩,考完了试,公司那边也请了假,是时候回去一趟了。没有提前通知爸妈,想给他们一个惊喜。下午提前到了家,他俩还在上班,只好让外公外婆来给我开门。因为我的回家,晚上外婆在厨房格外忙碌,做了满满一大桌子菜,填饱了我天天吃外卖的肚子。晚上也没空...
梦想是成为七海千秋:取决于家庭吧?其实回家更焦虑了,每天起床父母都问实习找好了没简历投递了没今天有没有面试,但是又没有什么结果,玩两下手机父母就会说你看你啥也没找到为什么天天就知道刷手机,怎么不去学习…我现在就希望我能永远在外面实习,报喜不报忧,等拿到一个好offer再回家
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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