我正在编写Verilog代码,使用Floyd-Stiengburg算法将8位像素转换为半色调像素。以下是将 6 像素(8位)转换为半色调像素的代码。我在Modelsim上成功编译了这段代码,但在模拟时,输出(半色调像素值)是XXXXXX(未定义)。
module half_tone(pixel,htpv);
input [0:47]pixel;
output reg [1:6]htpv;
reg [8:1]error[1:6];
reg [8:1]pixel_1;
reg [9:0]cpv,cpv_round,e_av;
parameter threshold =128;
integer i=1;
initial
begin
error[0]=8'b00;
for(i=0;i<6;i=i+1)
begin
e_av=(2*error[i])>>4;
cpv=pixel[(i*8)+:8]+e_av;
cpv_round=(cpv<threshold)?0:255;
htpv[i]=(cpv_round==0)?0:1;
error[i]=cpv-cpv_round;
#10;
end
end
endmodule
我无法理清输出为XXXXXX(未定义)的原因。
答案 0 :(得分:2)
当我用Incisive模拟器编译你的代码时,我收到了这条警告信息:
error[0]=8'b00;
|
ncelab: *W,BNDMEM (./half_tone.v,11|7): Memory index out of declared bounds [4.2.2(IEEE)].
您需要正确初始化error
。也许error[1]=8'b00;
?