题解 | #边沿检测#

边沿检测

https://www.nowcoder.com/practice/fed4247d5ef64ac68c20283ebace11f4

`timescale 1ns/1ns
module edge_detect(
	input clk,
	input rst_n,
	input a,
	
	output reg rise,
	output reg down
);
	
/*
两级寄存来做边缘检测的思路是对的 测试用例就是过不了 
	reg [1:0] a_reg;

	always@(posedge clk or negedge rst_n)begin
		if(!rst_n)begin
			a_reg <= 2'b00;
		end
		else begin
			a_reg[0] <= a        ;
		    a_reg[1] <= a_reg[0] ;
		end
	end


    assign rise = (a_reg == 2'b01)? 1'b1 : 1'b0 ;
	assign down = (a_reg == 2'b10)? 1'b1 : 1'b0 ;

*/
reg  a_reg;

	always@(posedge clk or negedge rst_n)begin
		if(!rst_n)begin
			a_reg <= 1'b0;
		end
		else begin
			a_reg <= a        ;
		end
	end

always@(posedge clk or negedge rst_n)begin
	if(!rst_n)begin
		rise <= 1'b0;
		down <= 1'b0;
	end
	else begin
		if({a,a_reg}== 2'b10)begin
			rise <= 1'b1;
			down <= 1'b0;
		end
		else if({a,a_reg}== 2'b01)begin
			rise <= 1'b0;
			down <= 1'b1;
		end
	    else begin
			rise <= 1'b0;
			down <= 1'b0; 
		end
	end
end

endmodule

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-10 14:00
林子大了什么鸟都有啊,我觉得我说的已经很客气了,阴阳谁呢
牛客62656195...:应该不是阴阳吧?你第一次注册的时候boss就说你是牛人
点赞 评论 收藏
分享
牛客刘北:如果暑期实习是27届的话,你要晚一年才会毕业,企业为什么会等你呢?要搞清时间逻辑呀!27届现在实习只能是在暑假实习,这是日常实习,不是暑期实习。所以多去投日常实习吧,暑期实习肯定不会要你的
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务