

### **PREPARED BY**

Md Sahil

BCSE-IV

001710501029

Jadavpur University

# Description

Creating a package for different procedures of adders and using them to implement various adders.

- 1. Half Adder
- 2. Full Adder
- 3. 4-bit ripple carry Adder
- 4. Adder/Subtractor
- 5. BCD Adder

# Half Adder

### **Block Diagram**



## Circuit Diagram



### Truth Table

| Inp | uts | Outputs |     |  |  |  |
|-----|-----|---------|-----|--|--|--|
| Α   | В   | Carry   | Sum |  |  |  |
| 0   | 0   | 0       | 0   |  |  |  |
| 0   | 1   | 0       | 1   |  |  |  |
| 1   | 0   | 0       | 1   |  |  |  |
| 1   | 1   | 1       | 0   |  |  |  |

Code

### Package code

```
procedure half adder proc(a: in std logic; b: in std logic; c: out
      std_logic; s: out std_logic) is
      begin
          s:= a xor b;
          c:= a and b;
      end procedure;
Implementation
      architecture Behavioral of half adder is
         p1: process(a, b)
         variable c,s: std_logic;
         begin
             proc: half_adder_proc(a, b, c, s);
             carry <= c;</pre>
             sum <= s;
         end process;
      end Behavioral;
Test Bench
      ARCHITECTURE behavior OF half adder test bench IS
      -- Component Declaration
              COMPONENT half_adder
              PORT (
                       a : in STD LOGIC;
                       b : in STD_LOGIC;
                       sum : out STD LOGIC;
                       carry : out STD_LOGIC
              END COMPONENT;
              SIGNAL a : std_logic;
              SIGNAL b : std_logic;
              SIGNAL sum: std_logic;
              SIGNAL carry: std logic;
      BEGIN
         uut: half_adder PORT MAP (
```

```
a \Rightarrow a
      b \Rightarrow b
          sum => sum,
         carry => carry
    );
tb : PROCESS
BEGIN
         a <= '0';
        b <= '0';
        wait for 1ps;
        a <= '0';
        b <= '1';
        wait for 1ps;
        a <= '1';
        b <= '0';
        wait for 1ps;
        a <= '1';
        b <= '1';
         wait for 1ps;
END PROCESS tb;
```

END;

### **Timing Diagram**



# Full Adder

### **Block Diagram**



## Circuit Diagram



Truth Table

|   | Inputs |     | Outputs |     |  |  |  |
|---|--------|-----|---------|-----|--|--|--|
| Α | В      | Cin | Carry   | Sum |  |  |  |
| 0 | 0      | 0   | 0       | 0   |  |  |  |
| 0 | 0      | 1   | 0       | 1   |  |  |  |
| 0 | 1      | 0   | 0       | 1   |  |  |  |
| 0 | 1      | 1   | 1       | 0   |  |  |  |
| 1 | 0      | 0   | 0       | 1   |  |  |  |
| 1 | 0      | 1   | 1       | 0   |  |  |  |
| 1 | 1      | 0   | 1       | 0   |  |  |  |
| 1 | 1      | 1   | 1       | 1   |  |  |  |

#### Code

#### Package code

```
procedure full_adder_proc(a: in std_logic; b: in std_logic; c: in
std_logic; carry: out std_logic; sum: out std_logic) is
    variable c1, s1, c2, s2: std_logic;
begin
    proc1: half_adder_proc(b, c, c1, s1);
    proc2: half_adder_proc(a, s1, c2, s2);
    carry := c1 or c2;
    sum := s2;
end procedure;
```

#### Implementation

```
architecture Behavioral of full_adder is
begin
   p1: process(a, b, c)
   variable s, c_out: std_logic;
   begin
        proc: full_adder_proc(a, b, c, c_out, s);
        sum <= s;
        carry <= c_out;
   end process;
end Behavioral;</pre>
```

```
ARCHITECTURE behavior OF full_adder_test_bench IS

COMPONENT full_adder

PORT(

a : IN std_logic;

b : IN std_logic;

c : IN std_logic;

sum : OUT std_logic;

carry : OUT std_logic

);

END COMPONENT;

--Inputs

signal a : std_logic := '0';

signal b : std_logic := '0';

signal c : std logic := '0';
```

```
--Outputs
  signal sum : std logic;
  signal carry : std_logic;
BEGIN
   -- Instantiate the Unit Under Test (UUT)
  uut: full_adder PORT MAP (
         a \Rightarrow a
         b \Rightarrow b
         c => c,
         sum => sum,
         carry => carry
       );
  tb :process
      variable bin: std_logic_vector(2 downto 0);
  begin
      for j in 0 to 8 loop
        proc_a: dec_to_bin_proc(j, 3, bin);
        a \le bin(2);
        b \le bin(1);
        c <= bin(0);
        wait for 1ps;
      end loop;
  end process;
END;
```

### **Timing Diagram**



# 4-bit Ripple Carry Adder

### **Block Diagram**



### Circuit Diagram



Truth Table

|     |    |    | 4  |    |    | B  | }  |    |    | Sı | ım |    | Carry |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|-------|
| Cin | А3 | A2 | A1 | A0 | В3 | B2 | B1 | В0 | S3 | S2 | S1 | S0 | Cout  |
| 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     |
| 0   | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0     |
| 0   | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0     |
| 0   | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 1  | 0  | 1  | 1  | 0  | 0     |
| 0   | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0     |
| 0   | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 1  | 0  | 1  | 0  | 0     |
| 0   | 0  | 1  | 1  | 0  | 0  | 1  | 1  | 0  | 1  | 1  | 0  | 0  | 0     |
| 0   | 0  | 1  | 1  | 1  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 0  | 0     |
| 0   | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1     |
| 0   | 1  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1     |

Md Sahil | Roll-29  $VLSI \mid 8$ Assignment - 4

| 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
| 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

Code

```
Package code
      procedure ripple carry adder 4bit proc(a: in std logic vector; b: in
std_logic_vector; c: in std_logic; s: out std_logic_vector) is
       variable c1, s1: std_logic_vector(4 downto 0);
       variable k: integer;
  begin
       c1(0) := c;
       for k in 0 to 3 loop
           proc: full_adder_proc(a(k), b(k), c1(k), c1(k+1), s1(k));
       end loop;
       s1(4) := c1(4);
       s := s1;
   end procedure;
Implementation
      entity ripple carry adder 4bit is
         Port ( a : in STD_LOGIC_VECTOR (3 downto 0);
```

```
b : in STD_LOGIC_VECTOR (3 downto 0);
             c : in STD_LOGIC;
          sum : out STD LOGIC VECTOR (4 downto 0));
end ripple carry adder 4bit;
architecture Behavioral of ripple carry adder 4bit is
begin
  p1: process(a, b, c)
      variable s: std_logic_vector(4 downto 0);
      proc: ripple_carry_adder_4bit_proc(a, b, c, s);
       sum <= s;
  end process;
end Behavioral;
```

```
ARCHITECTURE behavior OF ripple_carry_adder_4bit_test_bench IS
   -- Component Declaration for the Unit Under Test (UUT)
   COMPONENT ripple carry adder 4bit
   PORT (
        a : IN std_logic_vector(3 downto 0);
        b : IN std logic vector(3 downto 0);
        c : IN std logic;
        sum : OUT std_logic_vector(4 downto 0)
       );
  END COMPONENT;
  --Inputs
  signal a : std_logic_vector(3 downto 0) := (others => '0');
  signal b : std_logic_vector(3 downto 0) := (others => '0');
  signal c : std_logic;
  --Outputs
  signal sum : std_logic_vector(4 downto 0);
BEGIN
  -- Instantiate the Unit Under Test (UUT)
  uut: ripple carry adder 4bit PORT MAP (
         a \Rightarrow a
         b \Rightarrow b
         c => c,
         sum => sum
       );
  -- Stimulus process
  stim proc: process
     variable j,k: integer;
     variable bin a, bin b: std logic vector(3 downto 0);
  begin
     for j in 0 to 15 loop
        proc_a: dec_to_bin_proc(j, 4, bin_a);
        a <= bin a;
        for k in 0 to 15 loop
           proc_b: dec_to_bin_proc(k, 4, bin b);
           b <= bin b;
           c <= '0';
           wait for 1ps;
        end loop;
     end loop;
  end process;
END;
```

### **Timing Diagram**



# Adder/Subtractor

### **Block Diagram**



### Circuit Diagram



#### Code

#### Package code

```
procedure adder_subtractor_proc(a: in std_logic_vector; b: in
std_logic_vector; c: in std_logic; s: out std_logic_vector) is
    variable p: std_logic_vector(3 downto 0);
    variable s1: std_logic_vector(4 downto 0);
begin
    p(3 downto 0) := b(3 downto 0) xor (c & c & c & c);
    proc: ripple_carry_adder_4bit_proc(a(3 downto 0), p(3 downto 0),
c, s1(4 downto 0));
    if c = '1' then
        s1(4) := not s1(4);
    end if;
    s := s1;
end procedure;
entation
```

#### Implementation

```
architecture Behavioral of adder_subtractor is
begin
  p1: process(a, b, c)
     variable s: std_logic_vector(4 downto 0);
  begin
     proc: adder_subtractor_proc(a, b, c, s);
     sum <= s;
  end process;
end Behavioral;</pre>
```

```
ARCHITECTURE behavior OF adder subtractor test bench IS
   COMPONENT adder_subtractor
   PORT (
        a : IN std_logic_vector(3 downto 0);
        b : IN std_logic_vector(3 downto 0);
        c : IN std logic;
        sum : OUT std_logic_vector(4 downto 0)
       );
  END COMPONENT;
 --Inputs
 signal a : std_logic_vector(3 downto 0) := (others => '0');
 signal b : std_logic_vector(3 downto 0) := (others => '0');
 signal c : std_logic := '0';
  --Outputs
 signal sum : std_logic_vector(4 downto 0);
BEGIN
 -- Instantiate the Unit Under Test (UUT)
 uut: adder subtractor PORT MAP (
         a => a
         b \Rightarrow b
         c => c,
         sum => sum
       );
 -- Stimulus process
 stim_proc: process
 variable bin a, bin b: std logic vector(3 downto 0);
 begin
     for i in 0 to 15 loop
        dec to bin proc(i, 4, bin a);
        a <= bin_a;
        for j in 0 to 15 loop
           dec_to_bin_proc(j, 4, bin_b);
           b <= bin b;
           c <= '0'; -- for adding</pre>
           wait for 1ps;
           c <= '1'; -- for subtraction
           wait for 1ps;
        end loop;
     end loop;
 end process;
END;
```

### **Timing Diagram**



# **BCD** Adder

### **Block Diagram**



### Circuit Diagram



Truth Table

|   | Bi | nary Sur | n  |    |   |    | CD Su | m  |    |         |
|---|----|----------|----|----|---|----|-------|----|----|---------|
| С | В3 | B2       | B1 | В0 | С | S3 | S2    | S1 | S0 | Decimal |
| 0 | 0  | 0        | 0  | 0  | 0 | 0  | 0     | 0  | 0  | 0       |
| 0 | 0  | 0        | 0  | 1  | 0 | 0  | 0     | 0  | 1  | 1       |
| 0 | 0  | 0        | 1  | 0  | 0 | 0  | 0     | 1  | 0  | 2       |
| 0 | 0  | 0        | 1  | 1  | 0 | 0  | 0     | 1  | 1  | 3       |
| 0 | 0  | 1        | 0  | 0  | 0 | 0  | 1     | 0  | 0  | 4       |
| 0 | 0  | 1        | 0  | 1  | 0 | 0  | 1     | 0  | 1  | 5       |
| 0 | 0  | 1        | 1  | 0  | 0 | 0  | 1     | 1  | 0  | 6       |
| 0 | 0  | 1        | 1  | 1  | 0 | 0  | 1     | 1  | 1  | 7       |
| 0 | 1  | 0        | 0  | 0  | 0 | 1  | 0     | 0  | 0  | 8       |
| 0 | 1  | 0        | 0  | 1  | 0 | 1  | 0     | 0  | 1  | 9       |
| 0 | 1  | 0        | 1  | 0  | 1 | 0  | 0     | 0  | 0  | 10      |
| 0 | 1  | 0        | 1  | 1  | 1 | 0  | 0     | 0  | 1  | 11      |
| 0 | 1  | 1        | 0  | 0  | 1 | 0  | 0     | 1  | 0  | 12      |

| 0 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 13 |
|---|---|---|---|---|---|---|---|---|---|----|
| 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 14 |
| 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 15 |
| 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 16 |
| 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 17 |
| 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 18 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 19 |

#### Code

#### Package code

#### Implementation

```
architecture Behavioral of bcd_adder is
begin

pl: process(a, b)
    variable s: std_logic_vector(4 downto 0);
begin
    proc: bcd_adder_proc(a, b, s);
    sum <= s;
end process;
end Behavioral;</pre>
```

```
ARCHITECTURE behavior OF bcd adder_test_bench IS
   COMPONENT bcd adder
   PORT (
        a : IN std_logic_vector(3 downto 0);
        b : IN std_logic_vector(3 downto 0);
        sum : OUT std_logic_vector(4 downto 0)
       );
  END COMPONENT;
 --Inputs
 signal a : std logic_vector(3 downto 0) := (others => '0');
 signal b : std logic_vector(3 downto 0) := (others => '0');
--Outputs
 signal sum : std_logic_vector(4 downto 0);
BEGIN
 uut: bcd adder PORT MAP (
         a => a,
         b \Rightarrow b,
         sum => sum
       );
 -- Stimulus process
 stim_proc: process
  variable bin a, bin b: std logic vector(3 downto 0);
 begin
    for i in 0 to 15 loop
    dec_to_bin_proc(i, 4, bin_a);
     a <= bin_a;
     for j in 0 to 15 loop
       dec to bin proc(j, 4, bin b);
      b <= bin b;
      wait for 1ps;
     end loop;
  end loop;
 end process;
END;
```

### Timing Diagram

|                   |              |          |               |       |       |              |       | 14 ps  |         |
|-------------------|--------------|----------|---------------|-------|-------|--------------|-------|--------|---------|
| Name              | Value        | <b>-</b> | 9 ps          | 10 ps | 11 ps | 12 ps        | 13 ps | 14 ps  | 15 ps   |
| ▶ <b>%</b> a(3:0) | 0000         |          |               |       |       | 0000         |       |        |         |
| ▶ <b>™</b> b[3:0] | 1110         | 1000     | 1001          | 1010  | 1011  | 1100         | 1101  | 1110   | 1111    |
| ▶ ■ sum[4:0]      | 10100        | 01000    | 01001         | 10000 | 10001 | 10010        | 10011 | 10100  | 10101   |
|                   |              |          |               |       |       |              |       |        |         |
|                   |              |          |               |       |       |              |       |        |         |
|                   |              |          |               |       |       |              |       |        |         |
|                   |              |          |               |       |       |              |       |        |         |
|                   |              |          |               |       |       |              |       |        | 23 ps   |
|                   |              |          |               |       |       |              |       |        | 25   15 |
| Name              | Value        |          | 17 ps         | 18 ps | 19 ps | 120 ps       | 21 ps | 122 ns |         |
| ▶ 😽 a(3:0)        |              |          |               |       |       |              |       | 22 p3  | 23 ps   |
| p =⊕ a(J.∪)       | 0001         |          |               |       |       | 0001         |       | 22 p3  | 23 ps   |
|                   | 0001<br>0111 | 0000     | 0001          | 0010  | 0011  |              | 0101  | 0110   | 0111    |
|                   |              | 0000     | 0001<br>00010 |       |       | 0001         |       |        |         |
| ▶ 😽 b[3:0]        | 0111         |          |               | 0010  | 0011  | 0001<br>0100 | 0101  | 0110   | 0111    |
| ▶ 😽 b[3:0]        | 0111         |          |               | 0010  | 0011  | 0001<br>0100 | 0101  | 0110   | 0111    |
| ≻ 😽 b[3:0]        | 0111         |          |               | 0010  | 0011  | 0001<br>0100 | 0101  | 0110   | 0111    |