Half Adder is a combinational logic circuit that adds two inputs and produces two outputs. The diagram below illustrates the basic block diagram and circuit diagram of a Half Adder, where A and B are the inputs, and Sum and Carry are the outputs.
data:image/s3,"s3://crabby-images/68f01/68f0147066be095fef828df79b25fc70e11fa80e" alt=""
The table below presents the truth table of a Half Adder.
data:image/s3,"s3://crabby-images/5be3a/5be3a2f49ae91fefe0e4432d3b18571bc7dbb489" alt=""
The output equations of a Half Adder is as follows:
data:image/s3,"s3://crabby-images/3a5b4/3a5b40ba51f9a5dbaf012a82c64c3012480ae923" alt=""
In this project, we will design and implement the Half Adder using Testbench code 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/685a7/685a7f5df2737c9deab89531fb5c0f0f596f42fd" 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 name half_adder-> Next
data:image/s3,"s3://crabby-images/ef7f1/ef7f1e44b162435fcf3a95f6d596292e9547f585" 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/aa7da/aa7da975ae364d4624eb1ff34dad7dc4eaa69b32" 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/d4816/d48162f87a397836c93e0c9f877d9d857964669e" alt=""
Step 10: Enter the below codes in the “half_adder.vhd” files.
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity half_adder is
Port ( a : in STD_LOGIC;
b : in STD_LOGIC;
sum : out STD_LOGIC;
carry : out STD_LOGIC);
end half_adder;
architecture Behavioral of half_adder is
begin
sum <= a xor b;
carry <= a and b;
end Behavioral;
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_half_adder -> Finish -> Ok -> Yes
Step 12: Now open the testbench file and enter the below testbench code
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity tb_half_adder is
— Port ( );
end tb_half_adder;
architecture Behavioral of tb_half_adder is
component half_adder is port(
a : in STD_LOGIC;
b : in STD_LOGIC;
sum : out STD_LOGIC;
carry : out STD_LOGIC
);
end component;
signal a, b,sum, carry: std_logic:=’0';
begin
uut: half_adder port map(
a=>a,
b=>b,
sum=>sum,
carry=>carry
);
stim_proc: process
begin
a<=’0' ; b<=’0'; wait for 100ns;
a<=’0' ; b<=’1'; wait for 100ns;
a<=’1' ; b<=’0'; wait for 100ns;
a<=’1' ; b<=’1'; wait for 100ns;
end process;
end Behavioral;
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 half_adder and defined signals for connecting the ports of half adder. Inside the process statement we write all 4 test cases from truth table and define the respective delays.
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/beda3/beda3188059b3240c452bec8c53eadffed648c27" alt=""
We have successfully implemented 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/a08a4/a08a46dd029530738b1d1a4079b48366d8bb8977" alt=""
No comments:
Post a Comment