「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
相关推荐
学编程的闹钟5 小时前
PHP变量类型转换机制全解析
学习
日更嵌入式的打工仔8 小时前
LAN9253中文注释第三章
笔记
AI360labs_atyun8 小时前
字节AI双王炸来了!Seedance 2.0 + Seedream 5.0
人工智能·科技·学习·百度·ai
玩c#的小杜同学9 小时前
源代码保卫战:给C# 程序(混淆、加壳与反逆向实战)
开发语言·笔记·c#
不用89k9 小时前
SpringBoot学习新手项初识请求
java·spring boot·学习
Yeh2020589 小时前
2月7日笔记
笔记
汐汐咯9 小时前
CNN学习
深度学习·学习·cnn
shadow fish10 小时前
react学习记录(三)
javascript·学习·react.js
Aliex_git10 小时前
浏览器 API 兼容性解决方案
前端·笔记·学习
四谎真好看10 小时前
SSM学习笔记(Spring篇 Day02)
笔记·学习·学习笔记·ssm