

## Chapter 3

# Combinational Circuits

1

First year – 2023/2024

Dr. Iness NEDJI MILAT (Lecturer)

[iness.nedji@ensia.edu.dz](mailto:iness.nedji@ensia.edu.dz)

Pr. Nasreddine LAGRAA

[Nasredine.lagraa@ensia.edu.dz](mailto:Nasredine.lagraa@ensia.edu.dz)



# Combinational Logic Circuit (CLC)

- Output of CLC depends **only** on the combination of its inputs
- Combinational logic circuits have **no feedback**



# Combinational Logic Circuits

Common combinational circuits made up from logic gates, are basically divided into 3 classes :

- Arithmetic and Logical circuits
  - Full and Half Adders, Multipliers, Comparator, ...
- Code converters circuits
  - Binary, Gray, BCD code converters
- Data transmission circuits
  - Multiplexers, Demultiplexers, Encoders, Decoders,

4

# Half and Full Adders

# Functional Block: Half-Adder

- Half adder is a CLC which has two single bit inputs and two single bit outputs. It performs the following computations:

$$\begin{array}{r}
 \begin{array}{c} A \\ + \\ B \\ \hline S \end{array}
 \end{array}
 \quad
 \begin{array}{cccc}
 & 0 & 0 & 1 \\
 & + & + & + \\
 & 0 & 1 & 0 \\
 & + & & \\
 & 1 & & 0
 \end{array}$$



- A **half adder** adds two bits to produce a two-bit sum
- The sum is expressed as
  - a **sum bit**, S and a **carry bit**, C
- The **half adder** can be specified as a **truth table** for S and C  $\Rightarrow$

| A | B | S | C |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |

# Logic Simplification: Half-Adder

- The K-Map for S is:

|   |   |   |   |
|---|---|---|---|
|   |   |   |   |
|   |   | 0 | 1 |
| A | B | 0 | 1 |
| 0 | 0 | 1 |   |
| 1 | 1 | 0 |   |



$$S = A \cdot \overline{B} + \overline{A} \cdot B = A \oplus B$$

- The K-Map for C is:

|   |   |   |   |
|---|---|---|---|
|   |   |   |   |
|   |   | 0 | 1 |
| A | B | 0 | 1 |
| 0 | 0 | 0 |   |
| 1 | 0 | 1 |   |



$$C = A \cdot B$$

- These equations lead to the following implementation.



# Functional Block: Full-Adder

- A full adder is similar to a half adder, but includes a carry-in bit from lower stages. It has Three single bit inputs and two single bit outputs.
- Like the half-adder, it computes a sum bit, S and a carry bit, C.

For a carry-in (R) of 0,  
it is the same as the half-adder:

For a carry- in (R) of 1:



$$\begin{array}{r}
 R \quad 0 \quad 0 \quad 0 \quad 0 \quad 0 \\
 A \quad 0 \quad 0 \quad 0 \quad 1 \quad 1 \\
 + \\
 B \quad 0 \quad 0 \quad 1 \quad 0 \quad 1 \\
 \hline
 S \quad 0 \quad 1 \quad 1 \quad 0 \quad 1 \\
 \end{array}$$

$$\begin{array}{r}
 R \quad 1 \quad 1 \quad 1 \quad 1 \quad 1 \\
 A \quad 0 \quad 0 \quad 1 \quad 1 \quad 1 \\
 + \\
 B \quad 0 \quad 1 \quad 0 \quad 1 \quad 1 \\
 \hline
 S \quad 1 \quad 0 \quad 0 \quad 1 \quad 1 \\
 \end{array}$$

$$\begin{array}{r}
 R \quad 0 \quad 1 \quad 0 \quad 1 \quad 1 \\
 A \quad 1 \quad 0 \quad 1 \quad 0 \quad 1 \\
 + \\
 B \quad 1 \quad 1 \quad 1 \quad 1 \quad 1 \\
 \hline
 S \quad 1 \quad 1 \quad 0 \quad 0 \quad 1 \\
 \end{array}$$

# Logic Simplification: Full-Adder

## Full-Adder Truth Table

| A | B | R | S | C |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 1 | 1 | 1 |

## Full-Adder K-Map:



## Full-Adder Equations :

$$S = A \cdot \overline{B} \cdot \overline{R} + \overline{A} \cdot B \cdot \overline{R} + \overline{A} \cdot \overline{B} \cdot R + A \cdot B \cdot R$$

$$S = A \oplus B \oplus R$$

$$C = A \cdot B + A \cdot R + B \cdot R \quad \text{X}$$

$$C = \overline{A} \cdot B \cdot R + A \cdot \overline{B} \cdot R + A \cdot B \cdot \overline{R} + A \cdot B \cdot R$$

$$C = R (\overline{A} \cdot B + A \cdot \overline{B}) + A \cdot B (\overline{R} + R)$$

$$C = A \cdot B + (A \oplus B) \cdot R$$

# Logic diagram of full adder

$$S = A \oplus B \oplus R$$

$$C = A \cdot B + (A \oplus B) \cdot R$$



# Implementation of adders

- Imitate Adding by Hand
  - One column at a time
    - Compute sum, add carry to next column
- Create component for each column
  - Four bits □ Fours adders
  - **1 half adder**
  - **and 3 full adders**



# Carry-Ripple Adder

- Using half-adder and full-adders, we can build adder that adds like we would by hand
- Called a **carry-ripple adder**
  - 4-bit adder shown: Adds two 4-bit numbers, generates 5-bit output
    - 5-bit output can be considered 4-bit “sum” plus 1-bit “carry out”
  - Can easily build any size adder



# Carry-Ripple Adder

- Using full-adder instead of half-adder for first bit, we can include a “carry in” bit in the addition
  - Will be useful later when we connect smaller adders to form bigger adders



13

# Magnitude Comparator

# One-bit Comparator



| A | B | Gt | Eq | Lt |
|---|---|----|----|----|
| 0 | 0 | 0  | 1  | 1  |
| 0 | 1 | 0  | 0  | 0  |
| 1 | 0 | 1  | 0  | 0  |
| 1 | 1 | 0  | 0  | 1  |

$$Gt = AB' \quad (A > B)$$

$$Eq = A'B' + AB \quad (A = B)$$

$$Lt = A'B \quad (A < B)$$



# Magnitude comparator

- **N-bit magnitude comparator**

- Indicates whether  $A > B$ ,  $A = B$ , or  $A < B$ , for its two N-bit inputs A and B

- **How design?**

- Consider how compare by hand.

- **Example:** compare A and B

A=1011      B=1001

- First compare a<sub>3</sub> and b<sub>3</sub>.

1011      1001      Equal

- If equal, compare a<sub>2</sub> and b<sub>2</sub>.

1011      1001      Equal

- And so on...

1011      1001      Unequal

- Stop if comparison not equal :

- whichever's bit is 1 is greater.

So A >  
B

- If never see unequal bit pair, A=B.

# Magnitude comparator

- By-hand example leads to idea for design
  - Start at left, compare each bit pair (MSB), pass results to the right
  - Each bit pair called a stage
  - Each stage has 3 inputs indicating results of higher stage, passes results to lower stage



# Magnitude comparator



- Each stage:
  - $out_{gt} = in_{gt} + (in_{eq} \cdot a \cdot b)$ 
    - A>B (so far) if already determined in higher stage,
    - or if higher stages equal but in this stage  $a=1$  and  $b=0$
  - $out_{lt} = in_{lt} + (in_{eq} \cdot a \bar{.} b)$ 
    - A<B (so far) if already determined in higher stage,
    - or if higher stages equal but in this stage  $a=0$  and  $b=1$
  - $out_{eq} = in_{eq} \cdot (a \text{ XNOR } b)$ 
    - A=B (so far) if already determined in higher stage and in this stage  $a=b$  too

# Magnitude comparator : Example

- Compare 1011 and 1001



- Final answer appears on the right
- Takes time for answer to “ripple” from left to right



19

# Decoder

# Decoders

- A **decoder** is a CLC that has **n inputs** representing a binary number (**Code of information**) and  **$2^n$  outputs** representing **information**.
- It activates only **one output** that corresponds to that input number, all other outputs remain inactive.
- It extracts “**Information**” from the code.

Example: 2 to 4 Binary Decoder (1/4)



# Decoders

- 2 to 4 Line Decoder



lsb

| $I_1$ | $I_0$ | $O_3$ | $O_2$ | $O_1$ | $O_0$ |
|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 1     |
| 0     | 1     | 0     | 0     | 1     | 0     |
| 1     | 0     | 0     | 1     | 0     | 0     |
| 1     | 1     | 1     | 0     | 0     | 0     |



# Decoders

- The decoder is useful in determining how to interpret a **bit pattern**
  - It could be the **address** of a row in DRAM, that the processor intends to read from
  - It could be an **instruction** in the program and the processor needs to decide what action to take (based on *instruction opcode*)



# Decoders

- 3-to-8 Line Decoder (1/8 Decoder)

- Binary-to-Octal Decoder (3-to-8)



# Decoders

## Expansion

lsb

| $I_2$ | $I_1$ | $I_0$ | $O_0$ | $O_1$ | $O_2$ | $O_3$ | $O_4$ | $O_5$ | $O_6$ | $O_7$ |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 1     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 1     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     |
| 0     | 1     | 1     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     |
| 1     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 1     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     |
| 1     | 1     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |





25

# Encoders

# Encoders

- An encoder performs **the inverse operation** of a decoder.
- It has  **$2^n$  inputs** (information), and  **$n$  outputs** (Code of information).
- Only **one input** can be logic 1 at any given time (active input). All other inputs must be 0's.
- **Output** lines generate the **binary code** corresponding to the **active input**.



# Encoders

- Put “Information” into code
- Binary Encoder
  - Example: 4-to-2 Binary Encoder

**Truth table**

lsb  
↓

| $x_3$ | $x_2$ | $x_1$ | $y_1$ | $y_0$ |
|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 1     | 0     | 1     |
| 0     | 1     | 0     | 1     | 0     |
| 0     | 1     | 1     | x     | x     |
| 1     | 0     | 0     | 1     | 1     |
| 1     | 0     | 1     | x     | x     |
| 1     | 1     | 0     | x     | x     |
| 1     | 1     | 1     | x     | x     |

Code of  $x_1$   
Code of  $x_2$   
Code of  $x_3$

**Functional table**

| $x_3$ | $x_2$ | $x_1$ | $y_1$ | $y_0$ |
|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 1     | 0     | 1     |
| 0     | 1     | 0     | 1     | 0     |
| 1     | 0     | 0     | 1     | 1     |

$$y_1 = x_2 + x_3$$

$$y_0 = x_1 + x_3$$



Only one switch should be activated at a time



# Encoders

## Octal-to-Binary Encoder (8 to 3)



| $I_7$ | $I_6$ | $I_5$ | $I_4$ | $I_3$ | $I_2$ | $I_1$ | $I_0$ | $Y_2$ | $Y_1$ | $Y_0$ |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 1     |
| 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 1     | 0     |
| 0     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 1     | 1     |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 1     | 0     | 0     |
| 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 1     |
| 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 0     |
| 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 1     |

lsb  
↓

$$Y_2 = I_7 + I_6 + I_5 + I_4$$

$$Y_1 = I_7 + I_6 + I_3 + I_2$$

$$Y_0 = I_7 + I_5 + I_3 + I_1$$



29

# Multiplexer

# Example



# Multiplexer

- The multiplexer or *data selector*, shortened to “MUX” is a logic circuit that accepts several **Data inputs** and selects one of them at any given time to pass on to the **output**.
- This selection is controlled by **Select inputs** (often referred to as **Control** or **Address inputs**).
  - 4 input mux □ needs 2 select inputs to indicate which input to route through,
  - 8 input mux □ 3 select inputs,
  - $2^n$  inputs □ n select inputs
- Multiplexers can also be used to implement Boolean functions



# Mux Internal Design

□ Mux 2x1



• Mux 4x1



| $S_1$ | $S_0$ | $Y$   |
|-------|-------|-------|
| 0     | 0     | $I_0$ |
| 0     | 1     | $I_1$ |
| 1     | 0     | $I_2$ |
| 1     | 1     | $I_3$ |



# Muxes Commonly Together -- N-bit Mux

- Ex: Two 4-bit inputs, A ( $a_3 a_2 a_1 a_0$ ), and B ( $b_3 b_2 b_1 b_0$ )
  - 4-bit 2x1 mux (just four 2x1 muxes sharing a select line) can select between A or B



46

# Demultiplexer

# Demultiplexer



# Demultiplexer

- Demultiplexer (Demux) or Data distributors performs **the inverse operation** of a Mux.
- Given an input line and a set of selection lines, the demultiplexer will direct **data** from input to a **selected output** line.



| $\overline{S_1}$ | $S_0$ | $O_0$ | $O_1$ | $O_2$ | $O_3$ |
|------------------|-------|-------|-------|-------|-------|
| 0                | 0     | D     | 0     | 0     | 0     |
| 0                | 1     | 0     | D     | 0     | 0     |
| 1                | 0     | 0     | 0     | D     | 0     |
| 1                | 1     | 0     | 0     | 0     | D     |

- Data D is transmitted to only one of the outputs as determined by select input code  $S_1 S_0$ .

