module AOI_4_Unit(y_out,X_in1,X_in2,X_in3,X_in4);
input X_in1,X_in2,X_in3,X_in4;
output y_out;
wire y1,y2;
and #1 (y1,X_in1,X_in2);
and #1 (y2,X_in3,X_in4);
nor #1 (y_out,y1,y2);
endmodule
module system_clock(clk);
parameter PERIOD = 100;
output clk;
reg clk;
initial
clk = 0;
always
begin
#(PERIOD/2) clk = ~clk;
#(PERIOD/2) clk = ~clk;
#(PERIOD/2) clk = ~clk;
#(PERIOD/2) clk = ~clk;
end
always @(posedge clk)
if ($time > 1000) #(PERIOD-1) $stop;
endmodule
module test;
wire X_in1,X_in2,X_in3,X_in4;
wire y_out;
system_clock #100 clock1(X_in1);
system_clock #50 clock2(X_in2);
system_clock #20 clock3(X_in3);
system_clock #10 clock4(X_in4);
AOI_4_Unit AAA(y_out,X_in1,X_in2,X_in3,X_in4);
endmodule
input X_in1,X_in2,X_in3,X_in4;
output y_out;
wire y1,y2;
and #1 (y1,X_in1,X_in2);
and #1 (y2,X_in3,X_in4);
nor #1 (y_out,y1,y2);
endmodule
module system_clock(clk);
parameter PERIOD = 100;
output clk;
reg clk;
initial
clk = 0;
always
begin
#(PERIOD/2) clk = ~clk;
#(PERIOD/2) clk = ~clk;
#(PERIOD/2) clk = ~clk;
#(PERIOD/2) clk = ~clk;
end
always @(posedge clk)
if ($time > 1000) #(PERIOD-1) $stop;
endmodule
module test;
wire X_in1,X_in2,X_in3,X_in4;
wire y_out;
system_clock #100 clock1(X_in1);
system_clock #50 clock2(X_in2);
system_clock #20 clock3(X_in3);
system_clock #10 clock4(X_in4);
AOI_4_Unit AAA(y_out,X_in1,X_in2,X_in3,X_in4);
endmodule
這次的作業還算順利的做出來了
可能是上次有遇過的瓶頸突破了
覺得自己越來越有這方面的邏輯 很高興