module Rmain(A0,A1,A2,A3,A4,A5,A6,Y); input A0,A1,A2,A3,A4,A5,A6; output reg Y; always@(A0,A1,A2,A3,A4,A5,A6,Y) begin Y=1'b0; if(A0==1'b0&&A1==1'b1&&A2==1'b1&&A3==1'b0&&A4==1'b1&&A5==1'b1&&A6==1'b0) begin Y=1'b1; end if(A0==1'b1&&A1==1'b0&&A2==1'b1&&A3==1'b1&&A4==1'b0&&A5==1'b0&&A6==1'b1) begin Y=1'b0; end end endmodule希望改成输出一直保持不变,不会因为到达上升沿而发生变化
时间: 2023-08-27 16:04:08 浏览: 132
你可以修改代码如下所示,使用非阻塞赋值语句(<=)来更新输出信号 Y,这样 Y 的更新不会受到 always 块中的条件语句影响,保持不变直到下一次赋值:
```
module Rmain(A0,A1,A2,A3,A4,A5,A6,Y);
input A0,A1,A2,A3,A4,A5,A6;
output reg Y;
always@(posedge A0, posedge A1, posedge A2, posedge A3, posedge A4, posedge A5, posedge A6)
begin
if(A0==1'b0 && A1==1'b1 && A2==1'b1 && A3==1'b0 && A4==1'b1 && A5==1'b1 && A6==1'b0) begin
Y <= 1'b1;
end
if(A0==1'b1 && A1==1'b0 && A2==1'b1 && A3==1'b1 && A4==1'b0 && A5==1'b0 && A6==1'b1) begin
Y <= 1'b0;
end
end
endmodule
```
这样修改后,当 A0 - A6 达到指定条件时,Y 会在下一次上升沿时更新为指定值,之后保持不变。
相关问题
module Rmain(A0,A1,A2,A3,A4,A5,A6,Y); input A0,A1,A2,A3,A4,A5,A6; output reg Y; always@(A0,A1,A2,A3,A4,A5,A6,Y) begin if(A0==1'b0 && A1==1'b0 && A2==1'b0 && A3==1'b0 && A4==1'b0 && A5==1'b0 && A6==1'b0) begin Y <= 1'b0; end if(A0==1'b0 && A1==1'b1 && A2==1'b1 && A3==1'b0 && A4==1'b1 && A5==1'b1 && A6==1'b0) begin Y <= 1'b1; end if(A0==1'b1 && A1==1'b0 && A2==1'b1&& A3==1'b0 && A4==1'b1 && A5==1'b1 && A6==1'b0) begin Y <= 1'b0; end if(A0==1'b1 && A1==1'b0 && A2==1'b1&& A3==1'b0 && A4==1'b1 && A5==1'b1 && A6==1'b1) begin Y <= 1'b1; end if(A0==1'b1 && A1==1'b0 && A2==1'b1&& A3==1'b1 && A4==1'b0 && A5==1'b0 && A6==1'b0) begin Y <= 1'b0; end if(A0==1'b1 && A1==1'b0 && A2==1'b1&& A3==1'b1 && A4==1'b0 && A5==1'b0 && A6==1'b1) begin Y <= 1'b1; end end endmodule这段代码解释一下
这段代码实现的是一个 7 位输入与 1 位输出的逻辑电路。根据输入的 7 位二进制数,输出对应的 1 位二进制数。具体实现方式是使用 always 块中的条件语句,根据输入的不同情况,分别给输出信号赋不同的值。在该代码中,使用了六个 if 语句来判断不同的输入情况,并给 Y 赋不同的值。如果输入不是上述情况之一,则会保持原来的输出值不变。
其中,输入变量 A0 到 A6 是 7 个输入信号,Y 是 1 个输出信号,这里使用了 reg 类型的寄存器来实现输出 Y 的存储。
阅读全文