

## $\begin{array}{c} {\bf Introduction\ to\ Logic\ Design} \\ {\bf EEF205E} \end{array}$

Homework 3

Rüzgar Erik 040240783

Istanbul Technical University
Faculty of Electrical and Electronics Engineering

## Part 1

1. Design a combinational circuit with three inputs, x, y and z, and three outputs, A, B, C. When the binary input is 0, 1, 2, or 3, the binary output is one greater than the input. When the binary input is 4, 5, 6, or 7, the binary output is two less than the input.

Solution: The truth table for the given problem is shown below.

| x | у | $\mathbf{z}$ | INPUT | A | В | $\mathbf{C}$ | OUTPUT |
|---|---|--------------|-------|---|---|--------------|--------|
| 0 | 0 | 0            | 0     | 0 | 0 | 1            | 1      |
| 0 | 0 | 1            | 1     | 0 | 1 | 0            | 2      |
| 0 | 1 | 0            | 2     | 0 | 1 | 1            | 3      |
| 0 | 1 | 1            | 3     | 1 | 0 | 0            | 4      |
| 1 | 0 | 0            | 4     | 0 | 1 | 0            | 2      |
| 1 | 0 | 1            | 5     | 0 | 1 | 1            | 3      |
| 1 | 1 | 0            | 6     | 1 | 0 | 0            | 4      |
| 1 | 1 | 1            | 7     | 1 | 0 | 1            | 5      |

Table 1: Truth Table for the given problem

Generating Kmaps For A, B, C outputs:



- (a) Kmap for A output
- (b) Kmap for B output
- (c) Kmap for C output

Figure 1: Karnaugh maps for outputs A, B, and C

Calculating the minimized expressions for A, B, C outputs:

$$A = yz + xy \tag{1}$$

$$B = xy' + y'z + x'yz' \tag{2}$$

$$C = z' + xz \tag{3}$$

2. A majority circuit is a combinational circuit whose output is equal to 1 if the input variables have more 1's than 0's. The output is 0 otherwise. Design a 3-input majority circuit by finding the circuit's truth table, Boolean equation, and a logic diagram.

Solution: The truth table for the given problem is shown below.

| Table 2: | Truth | Table | for | $_{ m the}$ | given | problem |
|----------|-------|-------|-----|-------------|-------|---------|
|----------|-------|-------|-----|-------------|-------|---------|

| Index | x | $\mathbf{y}$ | $\mathbf{z}$ | Out |
|-------|---|--------------|--------------|-----|
| 0     | 0 | 0            | 0            | 0   |
| 1     | 0 | 0            | 1            | 0   |
| 2     | 0 | 1            | 0            | 0   |
| 3     | 0 | 1            | 1            | 1   |
| 4     | 1 | 0            | 0            | 0   |
| 5     | 1 | 0            | 1            | 1   |
| 6     | 1 | 1            | 0            | 1   |
| 7     | 1 | 1            | 1            | 1   |

The kmap for the given problem is shown below:



Figure 2: Kmap for the majority circuit

The minimized expression for the majority circuit is:

$$Out = yz + xz + xy \tag{4}$$

The logic diagram for the majority circuit is shown below:



Figure 3: Logic diagram for the majority circuit

## Part 2

1. We will design a circuit called half adder (HA) which adds two 1-bit numbers, a, b and produces 2-bit output, c.

(a) Draw the truth table of the circuit.

Solution: The truth table for the given problem is shown below.

Table 3: Truth Table for the given problem (Part 2a)

| a | b | Carry | Sum |
|---|---|-------|-----|
| 0 | 0 | 0     | 0   |
| 0 | 1 | 0     | 1   |
| 1 | 0 | 0     | 1   |
| 1 | 1 | 1     | 0   |

(b) Find the Boolean functions of each bit of the output.

Solution: The Boolean functions for the given problem are shown below.

$$Carry = ab (5)$$

$$Sum = a \oplus b \tag{6}$$

It can be seen from the truth table that the carry bit is the AND of the inputs, and the sum bit is the XOR of the inputs.

To obtain an XOR gate we can draw the Kmap for the sum bit:



Figure 4: Kmap for the sum bit

The minimized expression for the sum bit is:

$$Sum = a'b + ab' \tag{7}$$

Or we can simply use the XOR gate.

(c) Optimize the Boolean functions of each bit of the output.

Solution: The optimized Boolean functions for the given problem are shown below.

$$Carry = ab (8)$$

$$Sum = a \oplus b \tag{9}$$

The functions are already optimized.

(d) Draw the logic diagram of the circuit.

Solution: The logic diagram for the given problem is shown below.



Figure 5: Logic diagram for the half-adder circuit

(e) Write the VHDL code of the logic diagrams by using "Dataflow modeling" method. Solution: The VHDL code for the given problem is shown below.

```
Listing 1: half_adder.vhd
 library IEEE;
 use IEEE.STD_LOGIC_1164.ALL;
  entity half_adder is
      Port (a: in
                      STD_LOGIC;
              b: in
                      STD_LOGIC;
                       STD_LOGIC;
               : out
                       STD_LOGIC);
               : out
10 end half_adder;
  architecture Behavioral of half_adder is
        \leq a xor b;
      c \le a and b;
 end Behavioral;
```

(f) Simulate the circuit that you have designed in 1.e. Prepare a simulation waveform for you report Solution: The simulation waveform for the given problem is shown below.



Figure 6: Simulation waveform for the half-adder circuit

(g) Produce the RTL schematic for the circuit that you have designed in 1.e. Solution: The RTL schematic for the given problem is shown below.



Figure 7: RTL schematic for the half-adder circuit

- 2. We will design a circuit called full adder (FA) which adds three 1-bit numbers, a, b, c and produces 2-bit output, d.
  - (a) Draw the truth table of the circuit.

Table 4: Truth Table for the given problem (Part 2.2.a)

| a | b | Carry_In | Carry_Out | 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   |

(b) Find the Boolean functions of each bit of the output.

Solution: The Boolean functions for the given problem are shown below.

$$Carry\_Out = a'bc + ab'c + abc' + abc$$
 (10)

$$Sum = a'b'c + a'bc' + ab'c' + abc$$
(11)

(c) Optimize the Boolean functions of each bit of the output.

Solution: The optimized Boolean functions for the given problem are shown below.

Using Kmaps for the Carry\_Out and Sum bits:



(a) Kmap for the Carry\_Out bit

bc00 01 11 10 1 0 0 0 1 a1 1 0 0 1

(b) Kmap for the Sum bit

Figure 8: Karnaugh maps for Carry\_Out and Sum bits

The optimized expressions for the Carry\_Out and Sum bits are:

$$Carry\_Out = ac + bc + ab \tag{12}$$

$$Sum = ab'c' + a'b'c + abc + a'bc'$$
(13)

Also we can use the XOR and AND gates to implement the circuit.

$$Carry\_Out = ac + bc + ab \tag{14}$$

$$Sum = a \oplus b \oplus c \tag{15}$$

(d) Draw the logic diagram of the circuit.

Solution: The logic diagram for the given problem is shown below.



Figure 9: Logic diagram for the full-adder circuit

(e) e. Write the VHDL code of the logic diagrams by using "Dataflow modeling". Solution: The VHDL code for the given problem is shown below.

```
Listing 2: full_adder.vhd
```

(f) Simulate the circuit that you have designed in 2.e. Prepare a simulation waveform for your report. Solution: The simulation waveform for the given problem is shown below.



Figure 10: Simulation waveform for the full-adder circuit

(g) Produce the RTL schematic for the circuit that you have designed in 2.e. Solution: The RTL schematic for the given problem is shown below.



Figure 11: RTL schematic for the full-adder circuit

- 3. We will design a circuit called ripple carry adder (RCA) which adds two 4-bit positive integers, A, B and produces 5-bit output, C.
  - (a) Draw the logic diagram of the circuit by using one HA and 4 FAs.



Figure 12: Logic diagram for the ripple carry adder circuit

"

(b) Write the VHDL code of the logic diagrams by using "Structural modeling" Solution: The VHDL code for the given problem is shown below.

Listing 3: ripple\_carry\_adder.vhd

```
1 library IEEE;
2 use IEEE.STD_LOGIC_1164.ALL;
  entity RippleCarryAdder is
      Port (
           A : in STD_LOGIC_VECTOR(3 downto 0);
           B : in STD_LOGIC_VECTOR(3 downto 0);
           Sum : out STD_LOGIC_VECTOR(3 downto 0);
           Cout : out STD_LOGIC
      );
10
  end RippleCarryAdder;
11
  architecture Structural of RippleCarryAdder is
13
      component half_adder
14
          Port (
               a : in STD_LOGIC;
               b : in STD_LOGIC;
               s : out STD_LOGIC;
               c : out STD_LOGIC
19
           );
      end component;
21
22
      component FullAdder
          Port (
               a : in STD LOGIC;
               b : in STD_LOGIC;
               c : in STD_LOGIC;
               Sum : out STD_LOGIC;
               Carry_Out : out STD_LOGIC
           );
      end component;
      signal carry_internal : STD_LOGIC_VECTOR(3 downto 0);
33
34
35 begin
      HAO: half_adder port map (
36
           a => A(0),
37
          b => B(0),
38
           s \Rightarrow Sum(0),
           c => carry_internal(0)
40
      );
41
42
      FA1: FullAdder port map (
43
          a => A(1),
44
           b => B(1),
45
           c => carry_internal(0),
           Sum => Sum(1),
           Carry_Out => carry_internal(1)
48
      );
49
      FA2: FullAdder port map (
51
           a => A(2),
52
           b => B(2),
53
           c => carry_internal(1),
54
           Sum => Sum(2),
```

(c) Produce the RTL schematic for the circuit that you have designed in 3.b. Solution: The RTL schematic for the given problem is shown below.



Figure 13: RTL schematic for the ripple carry adder circuit

(d) Simulate the circuit that you have designed in 3.b.

Solution: The simulation waveform for the given problem is shown below.



Figure 14: Simulation waveform for the ripple carry adder circuit