题解 | #含有无关项的序列检测#相对复杂的状态机处理方法

含有无关项的序列检测

https://www.nowcoder.com/practice/cba67d06d6834a5d9b93e1087b56c8d8

`timescale 1ns/1ns
module sequence_detect(
	input clk,
	input rst_n,
	input a,
	output reg match
);
parameter IDLE = 1'b0,S1 = 1'b1,S2 = 2'b10,S3 = 2'b11;
parameter SX_1  = 3'b100,SX_2  = 3'b101,SX_3  = 3'b110;
reg [2:0] current_state,next_state;
reg match_change;

//
always@(posedge clk or negedge rst_n)begin
  if(!rst_n)
    current_state <= IDLE;
  else
    current_state <= next_state;
end

//根据是否检查完中间的无关项来判断状态机的循环状态
//复用了前面的状态机
always@(*)begin
  if(!match_change)begin
	case(current_state)
	  IDLE:next_state = a?IDLE:S1;
	  S1:next_state = a?S2:S1;
	  S2:next_state = a?S3:S1;
	  S3:next_state = a?SX_1:SX_1;
	  SX_1:next_state = a?SX_2:SX_2;
	  SX_2:next_state = a?SX_3:SX_3;
	  SX_3:next_state = a?S1:IDLE;
	  default:next_state = next_state;
	endcase
  end
  else begin
	case(current_state)
	S1 :next_state = a?S2:IDLE;
	S2 :next_state = a?IDLE:S3;
	S3 :next_state = a?IDLE:IDLE;
	endcase
  end
end

//为了拍子不乱用了组合逻辑电路
always@(*)begin
  if(!rst_n)
    match_change = 1'b0;
  else if((current_state == SX_3)&&(next_state == S1))
    match_change = 1'b1;
  else if(current_state == IDLE)
    match_change = 1'b0;
  else
    match_change = match_change;
end

//三段式状态机的输出最好用时序逻辑电路
//判断条件使用current_state还是next_state取决于你的设置的状态机状态个数
//如果状态个数正好,就需要用next_state,如果有一个冗余,就可以用current_state
always@(posedge clk or negedge rst_n)begin
  if(!rst_n)
   match <= 1'b0;
  else if((current_state == S3)&&(match_change == 1'b1))
   match <= 1'b1;
  else
   match <= 1'b0;
end
  
endmodule

全部评论

相关推荐

刚刷到字节跳动官方发的消息,确实被这波阵仗吓了一跳。在大家还在纠结今年行情是不是又“寒冬”的时候,字节直接甩出了史上规模最大的转正实习计划——ByteIntern。咱们直接看几个最硬的数,别被花里胡哨的宣传词绕晕了。首先是“量大”。全球招7000多人是什么概念?这几乎是把很多中型互联网公司的总人数都给招进来了。最关键的是,这次的资源分配非常精准:研发岗给了4800多个Offer,占比直接超过六成。说白了,字节今年还是要死磕技术,尤其是产品和AI领域,这对于咱们写代码的同学来说,绝对是今年最厚的一块肥肉。其次是大家最关心的“转正率”。官方直接白纸黑字写了:整体转正率超过50%。这意味着只要你进去了,不划水、正常干,每两个人里就有一个能直接拿校招Offer。对于2027届(2026年9月到2027年8月毕业)的同学来说,这不仅是实习,这简直就是通往大厂的快捷通道。不过,我也得泼盆冷水。坑位多,不代表门槛低。字节的实习面试出了名的爱考算法和工程实操,尤其是今年重点倾斜AI方向,如果你简历里有和AI相关的项目,优势还是有的。而且,转正率50%也意味着剩下那50%的人是陪跑的,进去之后的考核压力肯定不小。一句话总结:&nbsp;27届的兄弟们,别犹豫了。今年字节这是铁了心要抢提前批的人才,现在投递就是占坑。与其等到明年秋招去千军万马挤独木桥,不如现在进去先占个工位,把转正名额攥在手里。
喵_coding:别逗了 50%转正率 仔细想想 就是转正与不转正
字节7000实习来了,你...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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