「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
相关推荐
YangYang9YangYan12 分钟前
2026年工作后学习数据分析的价值与路径
学习·数据挖掘·数据分析
qeen8733 分钟前
【数据结构】树的基本概念及存储
c语言·数据结构·c++·学习·
pluviophile_s5 小时前
第18讲:⾃定义类型:结构体
c语言·笔记
老唐7775 小时前
常见经典十大大机器学习算法分类与总结
人工智能·深度学习·神经网络·学习·算法·机器学习·ai
烟雨孤舟5 小时前
python 基础学习文档
学习
ECT-OS-JiuHuaShan6 小时前
渡劫代谢,好事多磨
数据库·人工智能·科技·学习·算法·生活
Wyc724096 小时前
软考笔记放大发
笔记
2301_780943847 小时前
第三阶段:Gem5-GPU集成学习
学习
~kiss~7 小时前
quantizers 学习
学习
暖阳之下7 小时前
学习周报四十二
学习