# Multiplexer

- **Multiplexer** is a combinational circuit that has maximum of 2<sup>n</sup> data inputs, 'n' selection lines and single output line. One of these data inputs will be connected to the output based on the values of selection lines.
- Since there are 'n' selection lines, there will be 2<sup>n</sup> possible combinations of zeros and ones. So, each combination will select only one data input. Multiplexer is also called as **Mux**.

### 4x1 Multiplexer

4x1 Multiplexer has four data inputs  $I_3$ ,  $I_2$ ,  $I_1$  &  $I_0$ , two selection lines  $s_1$  &  $s_0$  and one output Y. The **block diagram** of 4x1 Multiplexer is shown in the following figure.



One of these 4 inputs will be connected to the output based on the combination of inputs present at these two selection lines. **Truth table** of 4x1 Multiplexer is shown below.

| Selection Lines |                | Output         |
|-----------------|----------------|----------------|
| S <sub>1</sub>  | S <sub>0</sub> | Υ              |
| 0               | 0              | I <sub>0</sub> |
| 0               | 1              | I <sub>1</sub> |
| 1               | 0              | l <sub>2</sub> |
| 1               | 1              | I <sub>3</sub> |

From Truth table, we can directly write the **Boolean function** for output, Y as

$$Y = S_1'S_0'I_0 + S_1'S_0I_1 + S_1S_0'I_2 + S_1S_0I_3$$

We can implement this Boolean function using Inverters, AND gates & OR gate. The **circuit diagram** of 4x1 multiplexer is shown in the following figure.



We can easily understand the operation of the above circuit. Similarly, you can implement 8x1 Multiplexer and 16x1 multiplexer by following the same procedure.

### Implementation of Higher-order Multiplexers.

Now, let us implement the following two higher-order Multiplexers using lower-order Multiplexers.

- 8x1 Multiplexer
- 16x1 Multiplexer

#### 8x1 Multiplexer

In this section, let us implement 8x1 Multiplexer using 4x1 Multiplexers and 2x1 Multiplexer. We know that 4x1 Multiplexer has 4 data inputs, 2 selection lines and one output. Whereas, 8x1 Multiplexer has 8 data inputs, 3 selection lines and one output.

So, we require two **4x1 Multiplexers** in first stage in order to get the 8 data inputs. Since, each 4x1 Multiplexer produces one output, we require a **2x1 Multiplexer** in second stage by considering the outputs of first stage as inputs and to produce the final output.

Let the 8x1 Multiplexer has eight data inputs  $I_7$  to  $I_0$ , three selection lines  $s_2$ ,  $s_1$  &  $s_2$  and one output Y. The **Truth table** of 8x1 Multiplexer is shown below.

| Selection Inputs |                |                | Output         |
|------------------|----------------|----------------|----------------|
| S <sub>2</sub>   | S <sub>1</sub> | S <sub>0</sub> | Υ              |
| 0                | 0              | 0              | I <sub>0</sub> |
| 0                | 0              | 1              | I <sub>1</sub> |
| 0                | 1              | 0              | $I_2$          |
| 0                | 1              | 1              | I <sub>3</sub> |
| 1                | 0              | 0              | I <sub>4</sub> |
| 1                | 0              | 1              | I <sub>5</sub> |
| 1                | 1              | 0              | I <sub>6</sub> |
| 1                | 1              | 1              | I <sub>7</sub> |

We can implement 8x1 Multiplexer using lower order Multiplexers easily by considering the above Truth table. The **block diagram** of 8x1 Multiplexer is shown in the following figure.



## 16 x 1 MUX

