# PEARSON

# **Chapter 9 – MSI Logic Circuits**

**ELEVENTH EDITION** 

# Digital Systems

**Principles and Applications** 



**Ronald J. Tocci** 

Monroe Community College

**Neal S. Widmer** 

**Purdue University** 

**Gregory L. Moss** 

**Purdue University** 

#### **Chapter 9 Objectives**

- Selected areas covered in this chapter:
  - Analyzing/using decoders & encoders in circuits.
  - Advantages and disadvantages of LEDs and LCDs.
  - Observation/analysis techniques to troubleshoot digital circuits.
  - Operation of multiplexers and demultiplexers in circuit applications.
  - Comparing two binary numbers by using the magnitude comparator circuit.
  - Function and operation of code converters.
  - Precautions when connecting digital circuits using the data bus concept.
  - Using HDL to implement MSI logic circuits equivalents.

- G
- Digital systems obtain data and information continuously operated on in some manner:
  - Decoding/encoding.
  - Multiplexing/demultiplexing,.
  - Comparison; Code conversion; Data busing.
- These and other operations have been facilitated by the availability of numerous ICs in the MSI (medium-scale-integration) category.

#### 9-1 Decoders

- Decoders are used when an output or a group of outputs is to be activated only on the occurrence of a specific combination of input levels.
  - Often provided by outputs of a counter or a register.

 A decoder accepts a set of inputs that represents a binary number—activating only the output that corresponds to the input number.

For each of these input combinations, only one of the *M* outputs will be active (HIGH); all the other outputs are LOW.



Many decoders are designed to produce active-LOW outputs, where only the selected output is LOW while all others are HIGH.

#### Circuitry for a decoder with three inputs and 8 outputs.



## Circuitry for a decoder with three inputs and 8 outputs.



This can be called a *3-line-to-8-line decoder*—it has three input lines and eight output lines.

Also called a binary-to-octal decoder or converter—taking three-bit binary input code and activating one of eight (octal) outputs.

Also referred to as a 1-of-8 decoder—only 1 of the 8 outputs is activated at one time.

#### 9-1 Decoders

- Some decoders have one or more enable inputs used to control the operation of the decoder.
  - The decoder is enabled only if ENABLE is HIGH.
- With common ENABLE line connected to a fourth input of each gate:
  - If ENABLE is HIGH, the decoder functions normally.
    - A, B, C input will determine which output is HIGH.
  - If ENABLE is LOW, all outputs will be forced LOW.
    - Regardless of the levels at the A, B, C inputs.

#### The 74ALS138 decoder.



7442 BCD-to-decimal decoder.

This decoder does *not* have an enable input.





Inputs

| D    | С           | В           | Α           | Active Output                                                               |
|------|-------------|-------------|-------------|-----------------------------------------------------------------------------|
|      | L<br>L<br>L | L<br>H<br>H | L<br>H<br>L | $ \overline{O}_0 $ $ \overline{O}_1 $ $ \overline{O}_2 $ $ \overline{O}_3 $ |
|      | H<br>H<br>H | L<br>H<br>H | L<br>H<br>L | $ \overline{O}_4 $ $ \overline{O}_5 $ $ \overline{O}_6 $ $ \overline{O}_7 $ |
| H    | L           | L           | L<br>H      | Ō <sub>8</sub><br>Ō <sub>9</sub>                                            |
| H    | L           | Н           | Н           | None<br>None                                                                |
| HHHH | H<br>H<br>H | LHH         | L<br>H<br>L | None<br>None<br>None<br>None                                                |

H = HIGH Voltage Level L = LOW Voltage Level

#### 7445 BCD-to-decimal decoder/driver.



Suitable for directly driving loads such as indicator LEDs or lamps, relays, or dc motors.



Termed a *driver* because this IC has open-collector outputs that operate at higher current/voltage limits than a normal TTL output.

- The 7-segment display is a common way to display decimal or hexadecimal characters.
  - One common arrangement uses light emitting diodes (LEDs) for each segment.



Diodes allow current to flow in one direction, but block flow in the other direction.



When the LED anode is more positive than the cathode by approximately 2 V, the LED will light up.

- The 7-segment display is a common way to display decimal or hexadecimal characters.
  - One common arrangement uses light emitting diodes (LEDs) for each segment.



#### BCD-to-7-segment decoder/driver.

The 7446/47 activates specific segment patterns in response to input codes





#### BCD-to-7-segment decoder/driver.

This is a **common- anode** LED display.

The anodes all of segments are tied together to  $V_{\rm CC}$ .



Another type uses a **common-cathode** method, with each segment requiring 10 to 20 mA of current.

TTL/CMOS devices are normally not used to drive a common-cathode display directly—a transistor interface circuit is often used

- A liquid-crystal display (LCD) controls reflection of available light.
  - The light may be ambient (room, sun) light.
    - Reflective LCDs use ambient light.
  - Available light might be provided by a small light source—part of the display unit.
    - Backlit LCDs use this method.
- LCDs have gained wide acceptance due to their very low power consumption—compared to LEDs.
  - LEDs have the advantage of a much brighter display that is easily visible in dark or poorly lit areas.

#### Liquid-crystal display.

Basic arrangement.

Applying voltage between the segment and the backplane turns the segment ON.



Zero voltage turns the segment OFF.

# Driving a 7segment display.

It is common to produce required ac voltage by applying out-of-phase square waves to the segment and the backplane.





- Liquid crystals are available as multidigit 7segment decimal numeric displays.
  - Alphanumeric LCD modules are available in many formats—up to 4 lines by 40 characters.
- Other LCD modules allow the user to create a graphical display by controlling individual dots on the screen called pixels.
- Larger LCD panels can be scanned at a high rate, producing high quality video motion pictures.
  - Control lines are arranged in rows & columns.
- A digital system must activate a matrix row/column to control the amount of light at each pixel.

 Each pixel on a color display is made up of three subpixels, which control light passing through a red, green, or blue filter to produce pixel color.

A 640 x 480 LCD screen would have 640 x 3 connections for columns and 480 connections for rows—a total of 2400 connections to the LCD.



- Older screens are called Twisted Nematic (TN) or Super Twisted Nematic (STN).
  - Referred to as passive LCDs.
- Newer displays are called active matrix TFT LCDs.
  - An active element on the display is used to switch pixels on and off.
- Other display technologies—vacuum fluorescent, gas discharge plasma, and electroluminescence.
  - Optical physics for each of these displays varies.
    - The means of controlling all of them is the same.

#### 9-4 Encoders

- Most decoders accept an input code & produce a HIGH (or LOW) at one and only one output line.
  - A decoder identifies, recognizes, or detects a particular code.

- The opposite of decoding process is encoding.
  - Performed by a logic circuit called an encoder.

An encoder has a number of input lines, only **one** of which is activated at a given time.

Shown is an encoder with *M* inputs and *N* outputs.

Inputs are active-HIGH, which means that they are normally LOW.

It produces an *N*-bit output code, depending on which input is activated.



 An octal-to-binary encoder (8-line-to-3-line encoder) accepts eight input lines, producing a three-bit output code corresponding to the input.



\*Only one LOW input at a time

Logic circuit for an octal-to-binary (8-line-to-3-line) encoder. Only one input should be active at one time.

 A priority encoder ensures that when two or more inputs are activated, the output code will correspond to the highest-numbered input.



It has nine active-LOW inputs represent decimal digits 1 through 9, producing *inverted* BCD code corresponding to the highest-numbered activated input.

- 9
- A switch encoder can be used when BCD data must be entered manually into a digital system.
  - The 10 switches might be the keyboard switches on a calculator—representing digits 0 through 9.

#### 9-4 Encoders

The switches are of the normally open type, so the encoder inputs are all normally HIGH.

BCD output is 0000.

When a key is depressed, the circuit will produce the BCD code for that digit.

The 74LS147 is a *priority* encoder, so simultaneous key depressions produce the BCD code for the *higher-numbered* key.



#### 9-5 Troubleshooting

- More complex circuitry increases possible reasons for failure
  - Applying observation and analysis will narrow the focus and simplify testing
- After using observation and analysis to determine the possible faults, repeatedly use the divide and conquer technique to reduce possible causes by half.

#### 9-6 Multiplexers (Data Selectors)

- A multiplexer (MUX) selects 1 of N input data sources and transmits the selected data to a single output—called multiplexing.
  - A digital multiplexer or data selector is a logic circuit that performs the same task.



#### 9-6 Multiplexers (Data Selectors)

- A two-input MUX could be used in a digital system that uses two different MASTER CLOCK signals.
  - A high-speed clock in one mode and a slow-speed clock for the other.



#### 9-6 Multiplexers (Data Selectors)

- Two-, four-, eight-, and 16-input multiplexers are available in the TTL and CMOS logic families.
  - These basic ICs can be combined for multiplexing a larger number of inputs.





## The 74ALS157 contains four two-input multiplexers



| ĒS                | Z <sub>a</sub> Z <sub>b</sub> Z <sub>c</sub> Z <sub>d</sub>                                                                             |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| H X<br>L L<br>L H | L L L L I <sub>0a</sub> I <sub>0b</sub> I <sub>0c</sub> I <sub>0d</sub> I <sub>1a</sub> I <sub>1b</sub> I <sub>1c</sub> I <sub>1d</sub> |





#### 9-7 Multiplexer Applications

- Multiplexer circuits find numerous and varied applications in digital systems of all types.
  - Data selection/routing, parallel-to-serial conversion.
  - Operation sequencing.
  - Waveform/logic-function generation.

#### 9-7 Multiplexer Applications



# 9

#### Parallel-to-serial converter.



# Multiplexer used to implement a logic function described by the truth table.



| С                          | В | А | Z                |  |  |
|----------------------------|---|---|------------------|--|--|
| 0                          | 0 | 0 | 0                |  |  |
| 0<br>0<br>0<br>0<br>1<br>1 | 0 | 1 | 1                |  |  |
| 0                          | 1 | 0 | 930              |  |  |
| 0                          | 1 | 1 | 0                |  |  |
| 1                          | 0 | 0 | 1<br>0<br>0<br>0 |  |  |
| 1                          | 0 | 1 | 0                |  |  |
| 1                          | 1 | 0 | 0                |  |  |
| 1                          | 1 | 1 | 1                |  |  |

- A demultiplexer (DEMUX) takes a single input and distributes it over several outputs.
  - The select input code determines to which output the DATA input will be transmitted.











# Security monitoring system using the 74ALS138.



The system shown can handle eight doors, but can be expanded to any number.

The door switches are data inputs to the MUX.

They produce a HIGH when a door is open and a LOW when it is closed.





This timing diagram shows the parallel data loaded into the transmitter, the serial data stream, and distribution/storage of the four data values in the receiver registers.



# •

# Apply observation and analysis to this example:



### 9-10 Magnitude Comparator

- Another useful MSI is a magnitude comparator.
  - A combinational logic circuit that compares two input binary quantities and generates outputs to indicate which one has the greater magnitude.



Cascading inputs are not necessary on a megafunction—simply specify larger data input ports.



# 9-10 Magnitude Comparator

- Another useful MSI is a magnitude comparator.
  - A combinational logic circuit that compares two input binary quantities and generates outputs to indicate which one has the greater magnitude.

TRUTH TABLE

H = HIGH Voltage Level
L = LOW Voltage Level
X = Immaterial

|                                 | COMPARI                         | NG INPUTS                       |                                 | CAS                 | CADING II                      | NPUTS            |                     | OUTPUT                         | 3                |
|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------|--------------------------------|------------------|---------------------|--------------------------------|------------------|
| A <sub>3,</sub> B <sub>3</sub>  | A <sub>2</sub> , B <sub>2</sub> | A <sub>1</sub> , B <sub>1</sub> | A <sub>0</sub> , B <sub>0</sub> | I <sub>A&gt;B</sub> | I <sub>A<b< sub=""></b<></sub> | I <sub>A=B</sub> | O <sub>A&gt;B</sub> | O <sub>A<b< sub=""></b<></sub> | O <sub>A=B</sub> |
| A <sub>3</sub> >B <sub>3</sub>  | X                               | X                               | Х                               | Х                   | X                              | Х                | Н                   | L                              | L                |
| A <sub>3</sub> <b<sub>3</b<sub> | X                               | X                               | X<br>X<br>X                     | X<br>X              | ×<br>×                         | X<br>X<br>X      | L                   | Н                              | L                |
| $A_3 = B_3$                     | $A_2 > B_2$                     | ×                               | X                               |                     | X                              | X                | Н                   | L                              | L                |
| $A_3 = B_3$                     | $A_2 < B_2$                     | X                               | X                               | Х                   | X                              | X                | L                   | н                              | L                |
| $A_3=B_3$                       | $A_2 = B_2$                     | $A_1 > B_1$                     | ×                               | Х                   | X                              | X<br>X<br>X      | Н                   | L                              | L                |
| $A_3 = B_3$                     | $A_2 = B_2$                     | A <sub>1</sub> <b<sub>1</b<sub> | X                               | X                   | X                              | X                | L                   | Н                              | L                |
| $A_3 = B_3$                     | $A_2 = B_2$                     | $A_1 = B_1$                     | $A_0 > B_0$                     | X                   | X                              | X                | Н                   | L                              | L                |
| $A_3 = B_3$                     | $A_2 = B_2$                     | $A_1=B_1$                       | A <sub>0</sub> <b<sub>0</b<sub> | ×                   | X                              | X                | L                   | н                              | L                |
| $A_3 = B_3$                     | $A_2 = B_2$                     | $A_1 = B_1$                     | $A_0=B_0$                       | Н                   | L                              | L                | Н                   | L                              | L                |
| $A_3 = B_3$                     | $A_2 = B_2$                     | $A_1 = B_1$                     | $A_0=B_0$                       | L                   | Н                              | L                | L                   | Н                              | L                |
| $A_3 = B_3$                     | $A_2 = B_2$                     | $A_1 = B_1$                     | $A_0 = B_0$                     | X                   | X                              | Н                | L                   | L                              | H                |
| $A_3 = B_3$                     | $A_2 = B_2$                     | $A_1 = B_1$                     | $A_0 = B_0$                     | L                   | L                              | L                | H                   | H                              | L                |
| $A_3 = B_3$                     | $A_2 = B_2$                     | $A_1 = B_1$                     | $A_0 = B_0$                     | Н                   | Н                              | L                | L                   | L                              | L                |

# Magnitude comparator used in a digital thermostat.



 A code converter is a logic circuit that changes data presented in one type of binary code to another type of binary code.



Basic idea of a two-digit BCD-to-binary converter.

### 9-11 Code Converters

- The bits in a BCD representation have decimal weights that are 8, 4, 2, 1 within each code group.
  - That differ by a factor of 10 from one code group (decimal digit) to the next.

The decimal weight of each bit in the BCD representation can be converted to its binary equivalent.

|         | Decimal<br>Weight | Binary Equivalent     |                       |                       |                       |                       |                       |                       |
|---------|-------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| BCD Bit |                   | <b>b</b> <sub>6</sub> | <b>b</b> <sub>5</sub> | <b>b</b> <sub>4</sub> | <b>b</b> <sub>3</sub> | <b>b</b> <sub>2</sub> | <i>b</i> <sub>1</sub> | <b>b</b> <sub>0</sub> |
| $A_0$   | 1                 | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     |
| $B_0$   | 2                 | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 0                     |
| $C_0$   | 4                 | 0                     | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     |
| $D_0$   | 8                 | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     | 0                     |
| $A_1$   | 10                | 0                     | 0                     | 0                     | 1                     | 0                     | 1                     | 0                     |
| $B_1$   | 20                | 0                     | 0                     | 1                     | 0                     | 1                     | 0                     | 0                     |
| $C_1$   | 40                | 0                     | 1                     | 0                     | 1                     | 0                     | 0                     | 0                     |
| $D_1$   | 80                | 1                     | 0                     | 1                     | 0                     | 0                     | 0                     | 0                     |

### 9-11 Code Converters



One way to implement the logic circuit that performs conversion process is to use binary adder circuits.

# 9-12 Data Busing

- In computers, transfer of data takes place over a common set of connecting lines called a data bus.
  - Devices tied to the data bus will often have tri-state outputs, or be tied to the data bus by tristate buffers.
- Devices commonly connected to a data bus:
  - Microprocessors; Semiconductor memory chips.
  - Digital-to-analog and analog-to-digital converters.

# 9-12 Data Busing



### 9-13 The 74ALS173/HC173 Tristate Register

- The devices connected to a data bus will contain registers (usually flip-flops) that hold device data.
  - Outputs of these registers are usually connected to tristate buffers allowing them to be tied to a data bus.

# 9-13 The 74ALS173/HC173 Tristate Register

# TTL 74ALS173 tristate register.



# 9-14 Data Bus Operation

Tristate registers connected to a data bus.

The contents of any one of the three registers can be parallel-transferred over the data bus to one of the other registers through proper application of logic levels to the register enable inputs.



 The timing diagram shows various signals involved in the transfer of the data 1011 from register A to register C.



#### NOTES:

4////// = floating (Hi-Z)

t<sub>1</sub>: Register A outputs are enabled. Its data are placed on the data bus lines.

t<sub>2</sub>: The PGT of the clock transfers valid data from the data bus into register C.

t<sub>3</sub>: Register A outputs are disabled and the data bus lines return to Hi-Z state.

# Simplified representation of bus arrangement.



Simplified way to show signal activity on data bus lines.



# 9-14 Data Bus Operation

- Manufacturers have developed ICs that connect inputs & outputs internal to the chip.
  - To reduce the number of IC pins & bus connections.

Each I/O line will function as an input or an output depending on the states of the enable inputs—bidirectional data lines.





# END

# Digital Systems

**Principles and Applications** 



Neal S. Widmer Purdue University

Gregory L. Moss

**Purdue University** 

