EGR 270

Fundamentals of Computer Engineering

File: N270L4

**Lab # 4**

**Decoders and Multiplexers**

**Lab Format**

* This is a **Individual Lab** so each student must design and test their own circuits.
* Students are free to assist each other in all labs.
* Each student must complete the Preliminary Work Section **before** lab begins. Preliminary Work will be checked in lab and will be part of the lab report grade.
* Each student must submit his or her own lab report.
* Lab reports will not be accepted until all required circuits have been demonstrated to the instructor.

A. **Objective**

 The objective of this laboratory is to investigate the design and use of decoders and multiplexers. Boolean functions will be implemented using both decoders and multiplexers.

B. **Materials**

|  |  |
| --- | --- |
| Breadboard5V Power SupplyWire, switches, etc.74LS151 8 x 1 Data Selector (multiplexer)74LS155 Dual 2 x 4 Decoder/Demultiplexer74LS04 Hex Inverter74LS08 Quad 2-input AND |  |

C. **Introduction**

**Decoders**

A decoder is a combinational logic circuit that activates one of several output lines based on the input code (typically binary or BCD). Shown below in Figure 1 is a block diagram and a truth table for a 2-line-to-4-line (or 2 x 4) decoder that has active-HIGH inputs and outputs.



Note that functionally the outputs of the decoder above correspond to minterms. So,

***Active-HIGH decoder outputs are equivalent to minterms***

For example,  (for 2 inputs) or  (for 4 inputs)

A combinational logic function that is expressed as a sum of minterms, therefore, can be implemented by summing decoder outputs, or

***F = ∑(minterms) = ∑(active-HIGH decoder outputs)***

For example, if f(A,B) = Σ(0, 2, 3) then f (A,B)= D0 + D2 + D3 so f can be implemented by the circuit shown in Figure 2.



Some decoders, such as the 74155, have active-LOW outputs. Figure 3 shows a block diagram and a truth table for a 2 x 4 decoder with active-LOW outputs.



Note that functionally the outputs of the decoder above correspond to maxterms. So,

***Active-LOW decoder outputs are equivalent to maxterms***

For example,

. A combinational logic function that is expressed as a product of maxterms, therefore, can be implemented by ANDing decoder outputs, or

***F = ∏(maxterms) = ∏(active-LOW decoder outputs)***

For example, if f(A,B) = Π(0, 1, 3) then f (A,B)= D0 • D1 • D3 so f can be implemented by the circuit shown in Figure 4.



**Multiplexers**

A multiplexer, or data selector, can be also be used to implement combinational logic circuits. A ***multiplexer implementation table*** is used to determine the input connections for the multiplexer.

 A 2 x 1 multiplexer can be used to implement a function of 2 variables, such as f(A,B)

 A 4 x 1 multiplexer can be used to implement a function of 3 variables, such as f(A,B,C)

 A 8 x 1 multiplexer can be used to implement a function of 4 variables, such as f(A,B,C,D)

**Procedure**:

1. Draw the truth table
2. Determine which inputs will be connected to the select lines (note which is the MSB)
3. Express the output F in terms of the other input.
4. Draw the MUX logic diagram.

**Example:** Implement the function f(A,B,C) = Σ(0, 3, 6, 7) using a 4 x 1 multiplexer.

The multiplexer implementation table is shown below in Figure 5.

F = C’ (so connect C’ to MUX input 0)

F = C

F = 1

F = 0

Connect A and B to select lines

Express F in terms of the other input (C)

MUX

Input 0

|  |  |  |  |
| --- | --- | --- | --- |
| A | B | C | F |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

 Figure 5: MUX implementation table

The circuit can be implemented as shown in Figure 6.

I0

I1

I2

I3

S1

S0

F(A,B,C) = Σ(0,3,6,7)

C

0

1

(MSB) A

B

Y

4x1 MUX

Figure 6: F(A,B,C) = Σ(0,3,6,7) implemented using a 4x1 multiplexer

 Keep in mind in the example above that bits A and B were connected to the select lines. If any other bits are connected to the select lines, then the implementation table needs to be rearranged.

D. **Preliminary Work**

 Include instructions with each step.

 1. ***3x8 Decoder Circuit***: Function f(A,B,C) is defined as follows: f(A,B,C) = Σ(1st 4 unique digits in your Student ID that are less than 8). If you do not have 4 digits that are less than 8, then add in as many of the following digits as are necessary: 7, 2, 6, 4. For example, if your Student ID is 1468413, then f(A,B,C) = Σ(1,3,4,6). Express f(A,B,C) as a sum of minterms and as a product of maxterms (shorthand notation).

 2. ***Logic Diagram for 3x8 decoder circuit using PSPICE***. Use PSPICE to generate a logic diagram that uses a 74155 3x8 decoder to implement f(A,B,C) from the previous step. The logic diagram should include:

* Display sssigned chip numbers and part numbers (For example: U1 – 74LS08)
* If multiple gates are used, use as many as possible from a given IC (for example, use U1A, U1B, U1C, etc., rather than U1A, U2A, U3A, etc.)
* Input switches (including DIP switches, resistors, etc)
* Label all inputs and outputs. Label input A as the MSB.
* Output LED, including current-limiting resistor
* Include text on the schematic page with information such as your name, course number, lab number, and the function to be implemented.
* ***Extra credit*** (5 points): If you simulate the circuit above using PSPICE, you can replace the dip switches with Digital Clocks. The output LED and current limiting resistor are also unnecessary. Be sure to use use the part LO if a 0 input is needed. The analog 0 ground cannot be used. Include the schematic and the output waveforms in your report.

 3. ***8x1 Multiplexer Circuit***. Design a multiplexer circuit using the 74151 to implement the function f(A,B,C,D) = Σ(1st 4 unique digits in your EmplID + minterms 10, 12, 13). In particular:

* State f(A,B,C,D) as a sum of minterms (shorthand notation) as described above.
* Show the ***multiplexer implementation table*** to implement this function.

 4. ***Logic Diagram for 8x1multiplexer circuit using PSPICE***. Use PSPICE to generate a logic diagram that uses a 74151 8x1 multiplexer to implement f(A,B,C,D) from the previous step. The logic diagram should include:

* Display assigned chip numbers and part numbers (For example: U1 – 74LS04)
* Input switches (including DIP switches, resistors, etc)
* Label all inputs and outputs. Label input A as the MSB.
* Output LED, including current-limiting resistor
* Include text on the schematic page with information such as your name, course number, lab number, and the function to be implemented.
* ***Extra credit*** (5 points): If you simulate the circuit above using PSPICE, you can replace the dip switches with Digital Clocks. The output LED and current limiting resistor are also unnecessary. Be sure to use use the part LO if a 0 input is needed. The analog 0 ground cannot be used. Include the schematic and the output waveforms in your report.

 5. ***Exercise using 4x1 Multiplexers***. Draw the multiplexer implementation table or a truth table for each circuit below and determine the output function f(A,B,C) in sum of minterms (shorthand) form.



E. **Laboratory Work**

 1. Construct the ***3x8 decoder circuit*** shown in the PSPICE logic diagram of step 2 in the Preliminary Work. Note any changes. Test the circuit to be sure that it produces the correct output for each input. Record the truth table. Demonstrate proper operation of the circuit to the instructor.

 2. Construct the ***8x1 multiplexer circuit*** shown in the PSPICE logic diagram of step 4 in the Preliminary Work. Note any changes. Test the circuit to be sure that it produces the correct output for each input. Record the truth table. Demonstrate proper operation of the circuit to the instructor.

F. **Report**

 Remember that each lab report should have the following four sections. Also see additional notes below.

**Title Page**

**Preliminary Work**

* Include instructions

**Lab Results**

* Include all measured results (truth tables).
* Include step numbers and titles or headings that make it clear what is being shown.
* Explain any changes that were made to the circuits as shown in the PSPICE schematics.

**Discussion/Conclusion**

* Discuss each circuit tested in lab.
* Compare the implementation of combinational logic circuits using basic logic gates (Labs 1 & 3) to implementing combinational logic circuits using decoders and multiplexers (Lab 4). Which method is easiest?
* Explain the difference between implementing a function using a decoder with active-HIGH outputs and a decoder with active-LOW outputs.
* What have you proven or demonstrated by completing the experiment?