「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 小时前
Linux 进程概念
linux·c++·笔记·学习
yong15858553435 小时前
2. Linux C++ muduo 库学习——原子变量操作头文件
linux·c++·学习
老王熬夜敲代码6 小时前
C++中的atomic
开发语言·c++·笔记·面试
IDIOT___IDIOT7 小时前
KNN and K-means 监督与非监督学习
学习·算法·kmeans
Rousson7 小时前
硬件学习笔记--91 TMR型互感器介绍
笔记·学习
Ingsuifon7 小时前
yolov5模型迁移笔记
笔记·yolo
前端 贾公子7 小时前
Vue响应式原理学习:基本原理
javascript·vue.js·学习
Slaughter信仰8 小时前
图解大模型_生成式AI原理与实战学习笔记前四张问答(7题)
人工智能·笔记·学习
2401_834517079 小时前
AD学习笔记-26 Active Routing
笔记·学习
断剑zou天涯9 小时前
【算法笔记】Manacher算法
java·笔记·算法