「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
相关推荐
qq_3597162312 分钟前
Openvla的原理学习
学习
LaoZhangGong12321 分钟前
学习TCP/IP的第2步:ICMP数据包
网络·网络协议·学习·tcp/ip·以太网
中屹指纹浏览器25 分钟前
指纹浏览器网络隔离技术详解:IP绑定与泄漏防护的实现方案
经验分享·笔记
菩提小狗31 分钟前
vulnhub靶场实战-prime|课堂笔记|网络安全|
网络·笔记·web安全
符哥200831 分钟前
Swift开发app常见第三方库
学习·swift
BullSmall1 小时前
《庄子・逍遥游》对照版
学习
@zulnger1 小时前
python 学习笔记(文件和目录操作)
笔记·python·学习
科技林总1 小时前
【系统分析师】2.5 工程伦理
学习
_李小白1 小时前
【AlohaMini学习笔记】第二天:初见LeRobot
笔记·学习
我命由我123452 小时前
Android Studio - Android Studio 去除 import 的未使用的类
android·java·ide·学习·java-ee·android studio·学习方法