问题从这里开始:为什么线变量会导致连续赋值中的非法左侧?
下面是我调整后的代码,但我仍然遇到在相同条件下协调b
(这是一个 reg)和Y
(这是一个电线)的问题。if
我知道必须将电线视为其所附加的组合的结果,并且不能仅仅为其分配一个值,当然也不能作为其自身的函数。所有关于不允许用于assign
regs 或电线不能在if
块中使用的东西。
但问题是b
计算一次,如果是b!=0
,我如何纠正第b位错误(Y[b]
)并让它从 1 翻转到 0,反之亦然?
// Hamming code 1-bit error correction
module HCG(I,e,O);
input [4:1] I; // input BCD
input [7:1] e; // noise simulation
wire [7:1] X; // Hamming code
wire [7:1] Y; // Hamming code after addition of noise
wire [3:1] P; // Parity at start
wire [3:1] S; // Parity at end
integer b; // the error bit
output [4:1] O; // corrected output
assign X[1]=I[1]^I[2]^I[4]; // Hamming code generator
assign X[2]=I[1]^I[3]^I[4];
assign X[3]=I[1];
assign X[4]=I[2]^I[3]^I[4];
assign X[5]=I[2];
assign X[6]=I[3];
assign X[7]=I[4];
assign P[1]=X[1]; // Parity at start
assign P[2]=X[2];
assign P[3]=X[4];
assign Y[1]=e[1]^X[1]; // noise added
assign Y[2]=e[2]^X[2];
assign Y[3]=e[3]^X[3];
assign Y[4]=e[4]^X[4];
assign Y[5]=e[5]^X[5];
assign Y[6]=e[6]^X[6];
assign Y[7]=e[7]^X[7];
assign S[1]=Y[3]^Y[5]^Y[7]; // Parity at end
assign S[2]=Y[3]^Y[6]^Y[7];
assign S[3]=Y[5]^Y[6]^Y[7];
always @(I,e)
begin
b=0; // initialize b to zero
if(S[1]!=P[1])
b=b+1;
if(S[2]!=P[2]) // b is cumulative if each of the conditions is true
b=b+2;
if(S[3]!=P[3])
b=b+4;
if(b!=0)
begin
Y[b]=!(Y[b]); // HOW TO CORRECT THIS?
end
end
assign O[1]=Y[3]; // assigning outputs
assign O[2]=Y[5];
assign O[3]=Y[6];
assign O[4]=Y[7];
endmodule