2008年11月24日 星期一

2008年10月20日 星期一

10/20 上課教學-3



module top;


wire x_in1,x_in2,x_in3,x_in4;


wire y_out;


system_clock #200 clock1(x_in1);


system_clock #150 clock2(x_in2);


system_clock #100 clock1(x_in3);


system_clock #50 clock2(x_in4);


A01_4_Unit AH1(y_out,x_in1,x_in2,x_in3,x_in4);


endmodulemodule


A01_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);


endmodulemodule


system_clock(clk);


parameter PERIOD = 100;


output clk;reg clk;


initialclk = 0;


always


begin


#(PERIOD/4) clk = ~clk;


#(PERIOD/4) clk = ~clk;


#(PERIOD/4) clk = ~clk;


#(PERIOD/4) clk = ~clk;


end


always@(posedge clk)


if($time > 1000) #(PERIOD-1)$stop;


endmodule

10/20 上課教學-2

module A01_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;

reg y_out,y1,y2;

always

begin

#1 y1=x_in1&x_in2;

#1 y2=x_in3&x_in4;

#1 y1=x_in1 nor x_in2;

end

endmodule

10/20 上課教學-1

module A01_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

2008年10月13日 星期一

10/13 好困難的作業



module top;
wire a,b;
wire sum,c_out;
system_clock #100 clock1(a);
system_clock #50 clock2(b);
Add_half AH1(sum,c_out,a,b);
endmodulemodul
e Add_half(sum,c_out, a, b);
input a,b;
output sum,c_out;
wire c_out_bar;
xor(sum, a, b);
nand(c_out_bar, a, b);
not(c_out,c_out_bar);
endmodulemodule
system_clock(clk);
parameter PERIOD = 100;
output clk;
reg clk;
initial
clk = 0;
always
begin
#(PERIOD/2) clk = ~clk;
#(PERIOD/2) clk = ~clk;
end
always@(posedge clk)
if($time > 1000) #(PERIOD-1)$stop;
endmodule