前段时间写了一个BCD码转GRAY码的小程序,结果在做门级仿真时,出现了很多“毛刺”,听取了大家的意见后,重新改了程序,发现“毛刺”的个数是比上次的少了,但还是存在,麻烦斑竹给修改一下!谢谢……
PS:以前帖子的链接:
http://bbs.eeworld.com.cn/thread-254513-1-2.html
修改逻辑后的仿真图:
*******************************程序代码************************************
`timescale 1ns / 1ps
module BCD2GRAY( SysClk, SysRst_n, BCD, GRAY );
input SysRst_n, SysClk;
input [3:0] BCD;
output [3:0] GRAY;
reg [3:0] GRAY;
reg [3:0] BCDTemp;
always @ ( posedge SysClk or negedge SysRst_n )
if ( !SysRst_n )
BCDTemp <= 4'b0;
else
begin
BCDTemp[0] <= BCD[0];
BCDTemp[1] <= BCD[1];
BCDTemp[2] <= BCD[2];
BCDTemp[3] <= BCD[3];
end
always @ ( posedge SysClk or negedge SysRst_n )
if ( !SysRst_n )
GRAY <= 4'b0;
else
begin
GRAY[0] <= BCDTemp[0] ^ BCDTemp[1];
GRAY[1] <= BCDTemp[1] ^ BCDTemp[2];
GRAY[2] <= BCDTemp[2] ^ BCDTemp[3];
GRAY[3] <= BCDTemp[3];
end
endmodule
*************************************Testbech*********************************
`timescale 1ns / 1ps
module BCD2GRAY_TEST();
reg SysClk, SysRst_n;
reg [3:0] BCD;
wire [3:0] GRAY;
initial
begin
SysClk = 1'b1;
forever
#25 SysClk = ~SysClk;
end
initial
begin
SysRst_n = 1'b1;
#50 SysRst_n = 1'b0;
#200 SysRst_n = 1'b1;
#100000;
$stop;
end
always @ ( posedge SysClk )
begin
BCD = {$random} % 15;
end
/*
always @ ( posedge WrClk or negedge SysRst_n )
if ( !SysRst_n )
BCDTemp <= 4'b0;
else
BCDTemp <= BCD >> 1;
assign GRAY_r = BCDTemp ^ BCD;
*/
BCD2GRAY BCD2GRAY_INST(
.SysClk(SysClk),
.SysRst_n(SysRst_n),
.BCD(BCD),
.GRAY(GRAY)
);
endmodule
此帖出自
小平头技术问答
一周热门 更多>