「Verilog学习笔记」状态机-非重叠的序列检测

专栏前言

本专栏的内容主要是记录本人学习Verilog过程中的一些知识点,刷题网站用的是牛客网

根据题意 定义一个五位的中间变量lock 每次始终上升沿来临时 判断当前寄存器的低四位+新数据是否等于10111 如果等于 则下一时刻lock应被清空 否则lock等于当前的lock的低四位+新数据

复制代码
`timescale 1ns/1ns

module sequence_test1(
	input wire clk  ,
	input wire rst  ,
	input wire data ,
	output reg flag
);
//*************code***********//
	reg [4:0] lock ; 

	always @ (posedge clk or negedge rst) begin
		if (~rst) lock <= 'd0 ; 
		else 
			if ({lock[3:0], data} == 5'b10111) lock <= 'd0 ; 
			else lock <= {lock[3:0], data} ;
	end

	always @ (posedge clk or negedge rst) begin
		if (~rst) flag <= 'd0 ; 
		else 
			if ({lock[3:0], data} == 5'b10111) flag <= 1'd1 ; 
			else flag <= 'd0 ;
	end

//*************code***********//
endmodule
相关推荐
搞一搞汽车电子2 分钟前
S32K3平台eMIOS 应用说明
开发语言·驱动开发·笔记·单片机·嵌入式硬件·汽车
萧邀人2 分钟前
第二课、熟悉Cocos Creator 编辑器界面
学习
m0_5713728237 分钟前
嵌入式ARM架构学习2——汇编
arm开发·学习
大筒木老辈子1 小时前
Linux笔记---封装套接字
笔记
AlexMercer10121 小时前
[前端]1.html基础
前端·笔记·学习·html
楚肽生物小敏2 小时前
Cy3-Tyramide,Cyanine 3 Tyramide; 174961-75-2
笔记
健康平安的活着3 小时前
langchain4j笔记篇(阳哥)
笔记
一川月白7093 小时前
51单片机---硬件学习(跑马灯、数码管、外部中断、按键、蜂鸣器)
单片机·学习·51单片机·外部中断·蜂鸣器·数码管·跑马灯
励志不掉头发的内向程序员3 小时前
STL库——二叉搜索树
开发语言·c++·学习
ホロHoro4 小时前
学习笔记:MYSQL(4)
笔记·学习·mysql