Full Adder is a combinational logic circuit that adds three inputs and produces two outputs. The diagram below illustrates the basic block diagram and circuit diagram of a Full Adder, where A, B, and C_in are the inputs, and Sum and C_out are the outputs. Here, C_in is commonly referred to as the carry input, and C_out is known as the carry output.
data:image/s3,"s3://crabby-images/f8862/f8862ac32da96cf3762788588bec1ff4e9840f08" alt=""
The table below presents the truth table of a Full Adder.
data:image/s3,"s3://crabby-images/84c3f/84c3fcd47a513ac6b80eb94b09bfadfe66eb4a29" alt=""
From the input, we can observe that the sum output is high only when at least one input is equal to 1 or when all inputs are equal to 1. C_out is equal to 1 when two or three inputs are equal to 1. The output equations of a Full Adder are as follows:
data:image/s3,"s3://crabby-images/79479/794791b94d89fef651fd7a41ebf59129ccc86230" alt=""
If we want to design the Full Adder using half adders, the circuit diagram and block diagram for it will be as follows:
data:image/s3,"s3://crabby-images/da502/da5029631987f48ca0727261134a95e042c7dfaf" alt=""
data:image/s3,"s3://crabby-images/ff771/ff7717ee7d15630f2721657f7bd76795b77aac21" alt=""
Therefore, we need two Half Adders and one OR gate to design a Full Adder.
In this project, we will design and implement the Full Adder using Half Adders with the Xilinx Vivado design tool.
Step 1: Click on New Project -> Next
data:image/s3,"s3://crabby-images/d89ea/d89eac67e62c99ac59d9b0aa6492f7c7ff15d177" alt=""
Step 2: Enter Project Name and Select appropriate Project Location -> Next
data:image/s3,"s3://crabby-images/70450/70450e99d2447ecc20bf82e6e353bd3718ac3bbc" alt=""
Step 3: Select RTL Project -> Next
data:image/s3,"s3://crabby-images/7a57c/7a57cfe1ed117c486adfc5c1e4b8bdd2de4f0cf7" alt=""
Step 4: Click on Create File and create 3 files with file names or_gate, half_adder and full_adder -> Next
data:image/s3,"s3://crabby-images/0d7f8/0d7f83874d7fdbc4bd3b2b5fa79f3847dae349b4" alt=""
Step 5: We will not add the Constraint file So click on Next
data:image/s3,"s3://crabby-images/754d9/754d9352f46e834ef53551d3e83343152e3de495" alt=""
Step 6: For Default Part click on Next as we are not using any development Board
data:image/s3,"s3://crabby-images/621f4/621f46aa0900f7e24ec14be250f3e54dcba7e6f0" alt=""
Step 7: Check the New Project Summary and click on Finish
data:image/s3,"s3://crabby-images/fa303/fa303b939ee86e36c82075d50d56da459776ba87" alt=""
Step 8: Now you will be prompted with the Define module page but we will create the complete code from scratch so click on cancel and Yes
Step 9: Now on the Home Page click on Sources -> Design Sources -> Non-module Files
data:image/s3,"s3://crabby-images/2b6d2/2b6d273949f1ac2d55c02bd79a5eae46662a2002" alt=""
Step 10: Enter the below codes in the “.v” files
or_gate.v
module or_gate(a,b,y);
input a, b;
output y;
or(y,a,b);
endmodule
half_adder.v
module half_adder(a,b,sum,carry);
input a, b;
output sum, carry;
xor(sum,a,b);
and(carry,a,b);
endmodule
full_adder.v
module full_adder(a,b,cin,sum,carry);
input a,b, cin;
output sum, carry;
wire c1,c2,s1;
half_adder uut1 (a,b,s1,c1);
half_adder uut2 (cin,s1,sum,c2);
or_gate uut3(c1,c2,carry);
endmodule
Here, we have written verilog code for or gate, half adder and full adder.
Step 11: Now to write the testbench code for above design right click on Design Sources -> Add Sources -> Add or create design sources -> Create File -> Add File name as tb_full_adder -> Finish -> Ok -> Yes
Step 12: Now open the testbench file and enter the below testbench code
module tb_full_adder;
reg a;
reg b;
reg cin;
wire sum;
wire carry;
full_adder UUT (.a(a), .b(b),.cin(cin), .sum(sum), .carry(carry));
initial begin
$display(“Testing Full Adder gate”);
a = 0; b=0; cin=0;
#10;
$display(“Input_A = %b, Input_B = %b, Input_Cin = %b, Sum = %b, Carry = %b” , a,b,cin,sum,carry);
a = 0; b=0; cin=1;
#10;
$display(“Input_A = %b, Input_B = %b, Input_Cin = %b, Sum = %b, Carry = %b” , a,b,cin,sum,carry);
a = 0; b=1; cin=0;
#10;
$display(“Input_A = %b, Input_B = %b, Input_Cin = %b, Sum = %b, Carry = %b” , a,b,cin,sum,carry);
a = 0; b=1; cin=1;
#10;
$display(“Input_A = %b, Input_B = %b, Input_Cin = %b, Sum = %b, Carry = %b” , a,b,cin,sum,carry);
a = 1; b=0; cin=0;
#10;
$display(“Input_A = %b, Input_B = %b, Input_Cin = %b, Sum = %b, Carry = %b” , a,b,cin,sum,carry);
a = 1; b=0; cin=1;
#10;
$display(“Input_A = %b, Input_B = %b, Input_Cin = %b, Sum = %b, Carry = %b” , a,b,cin,sum,carry);
a = 1; b=1; cin=0;
#10;
$display(“Input_A = %b, Input_B = %b, Input_Cin = %b, Sum = %b, Carry = %b” , a,b,cin,sum,carry);
a = 1; b=1; cin=1;
#10;
$display(“Input_A = %b, Input_B = %b, Input_Cin = %b, Sum = %b, Carry = %b” , a,b,cin,sum,carry);
$finish;
end
endmodule
Here, in testbench code we do not define values in entity hence we have kept it empty. Then in architecture we have copied the components of full_adder and defined signals for connecting the ports of full adder. Inside the process statement we write all 8 test cases from truth table and define a delay.
Step 13: Now as we have written all the codes let’s launch the simulation. Enter launch_simulation in the Tcl Console and press Enter
data:image/s3,"s3://crabby-images/c8588/c8588e381b06e7c2f643273dcabaf7f7956f7bf8" alt=""
We have successfully implemented full adder using half adder with testbench code. Click on Zoom Fit to see the output waveform more clearly and verify the outputs.
data:image/s3,"s3://crabby-images/d291e/d291e764fbf40b56f20a0763cbce2c287b655819" alt=""
No comments:
Post a Comment