

# 编码器和译码器

# 实验目的

- 1. 掌握用逻辑门实现编码器的方法。
- 2.掌握中规模集成电路编码器和译码器的工作原理以及逻辑功能。
- 3. 掌握 74LS138 用作数据分配器的方法。
- 4.熟悉编码器和译码器的级联方法。
- 5.能够利用译码器进行组合逻辑电路设计。

# 实验原理

# 编码器 (Encoder)

- 在数字系统中,常常需要将某一信息(输入)变换为 某一特定的代码(输出)
- 把二进制码按一定的规律编排,例如8421码、格雷码等,使每组代码具有一特定的含义(代表某个数或控制信号)称为编码
- 具有编码功能的逻辑电路称为编码器
- 它的逻辑功能是将输入的每一个高、低电平信号编成 一个对应的二进制代码。



常用的编码器 { 普通编码器 优先编码器

#### 8线—3线优先编码器74LS148



S'为选通输入端,S'=0,编码器才能正常工作。

 $Y'_{S}$ 为选通输出端, $Y'_{S}=0$ ,表示电路工作,无编码输入。

 $Y'_{EX}$ 为扩展端, $Y'_{EX}=0$ ,表示电路工作,有编码输入。

#### 优先编码器74LS148功能表

|   |     |       | 输     |       | 入     |       |       |            |       | 输     |                  | 出                |          |
|---|-----|-------|-------|-------|-------|-------|-------|------------|-------|-------|------------------|------------------|----------|
| S | I o | $I_1$ | $I_2$ | $I_3$ | $I_4$ | $I_5$ | $I_6$ | <b>I</b> , | $Y_2$ | $Y_1$ | $Y_{\mathrm{o}}$ | $oldsymbol{Y_S}$ | $Y_{EX}$ |
| 1 | Х   | X     | Χ     | X     | X     | X     | X     | X          | 1     | 1     | 1                | 1                | 1        |
| 0 | 1   | 1     | 1     | 1     | 1     | 1     | 1     | 1          | 1     | 1     | 1                | 0                | 1        |
| 0 | Х   | Х     | Х     | X     | X     | X     | X     | 0          | 0     | 0     | 0                | 1                | 0        |
| 0 | X   | X     | Χ     | Χ     | Χ     | Χ     | 0     | 1          | 0     | 0     | 1                | 1                | 0        |
| 0 | X   | X     | Χ     | Χ     | Χ     | 0     | 1     | 1          | 0     | 1     | 0                | 1                | 0        |
| 0 | X   | X     | Χ     | X     | 0     | 1     | 1     | 1          | 0     | 1     | 1                | 1                | 0        |
| 0 | X   | X     | Χ     | 0     | 1     | 1     | 1     | 1          | 1     | 0     | 0                | 1                | 0        |
| 0 | X   | X     | 0     | 1     | 1     | 1     | 1     | 1          | 1     | 0     | 1                | 1                | 0        |
| 0 | X   | 0     | 1     | 1     | 1     | 1     | 1     | 1          | 1     | 1     | 0                | 1                | 0        |
| 0 | 0   | 1     | 1     | 1     | 1     | 1     | 1     | 1          | 1     | 1     | 1                | 1                | 0        |

■ 输入、输出均为低电平有效

### 两片74LS148组成16线一4线优先编码器





# 译码器 (Decoder)

- 译码是编码的逆过程
- 译码器将每个二进制代码赋予的特定含义"翻译"过来,转换成相应的信息符号(输出信号)
- 具有译码功能的逻辑电路被称为译码器
- 它的逻辑功能是将每个输入的二进制代码译成对应的输出高、低电平信号或另一个代码。



### 一、二进制译码器74LS138



 $S_1$ 、 $S_2$ 和 $S_3$ 是三个片选输入端,当 $S_1$ =1, $S_2$ + $S_3$ =0时,译码器工作。

### 3线-8线译码器74LS138功能表

|       | 输             |       | λ     |       |           |             | 输           |           |             | 出           |           |             |
|-------|---------------|-------|-------|-------|-----------|-------------|-------------|-----------|-------------|-------------|-----------|-------------|
| $S_1$ | $S_2' + S_3'$ | $A_2$ | $A_1$ | $A_0$ | $Y_0^{'}$ | $Y_{1}^{'}$ | $Y_{2}^{'}$ | $Y_3^{'}$ | $Y_{4}^{'}$ | $Y_{5}^{'}$ | $Y_6^{'}$ | $Y_{7}^{'}$ |
| 0     | Х             | Х     | Χ     | X     | 1         | 1           | 1           | 1         | 1           | 1           | 1         | 1           |
| X     | 1             | Х     | Х     | X     | 1         | 1           | 1           | 1         | 1           | 1           | 1         | 1           |
| 1     | 0             | 0     | 0     | 0     | 0         | 1           | 1           | 1         | 1           | 1           | 1         | 1           |
| 1     | 0             | 0     | 0     | 1     | 1         | 0           | 1           | 1         | 1           | 1           | 1         | 1           |
| 1     | 0             | 0     | 1     | 0     | 1         | 1           | 0           | 1         | 1           | 1           | 1         | 1           |
| 1     | 0             | 0     | 1     | 1     | 1         | 1           | 1           | 0         | 1           | 1           | 1         | 1           |
| 1     | 0             | 1     | 0     | 0     | 1         | 1           | 1           | 1         | 0           | 1           | 1         | 1           |
| 1     | 0             | 1     | 0     | 1     | 1         | 1           | 1           | 1         | 1           | 0           | 1         | 1           |
| 1     | 0             | 1     | 1     | 0     | 1         | 1           | 1           | 1         | 1           | 1           | 0         | 1           |
| 1     | 0             | 1     | 1     | 1     | 1         | 1           | 1           | 1         | 1           | 1           | 1         | 0           |

#### ■ 输出低电平有效

# 两片74LS138组成4线一16线译码器



#### (74LS138译码器)

$$\begin{cases} Y_0' = (A_2'A_1'A_0')' = m_0' \\ Y_1' = (A_2'A_1'A_0)' = m_1' \\ Y_2' = (A_2'A_1A_0')' = m_2' \\ Y_3' = (A_2'A_1A_0)' = m_3' \\ Y_4' = (A_2A_1'A_0')' = m_4' \\ Y_5' = (A_2A_1'A_0)' = m_5' \\ Y_6' = (A_2A_1A_0')' = m_6' \\ Y_7' = (A_2A_1A_0)' = m_7' \end{cases}$$

$$Y_{i}'=m_{i}'$$



一个3线-8线译码器能产生三个变量的全部最小项,所以 也将这种译码器称为**最小项译码器**。

# 译码器实现逻辑函数

例:用74LS138实现逻辑函数Y = A'B + AC'

$$Y = A'B + AC'$$

$$=A'BC'+A'BC+AB'C'+ABC'$$

$$= m_2 + m_3 + m_4 + m_6$$

$$= (m'_2 m'_3 m'_4 m'_6)'$$

$$=(Y_2'Y_3'Y_4'Y_6')'$$



### 二、显示译码器

能直接驱动数字显示器或能同显示器配合使用的译码器称为显示译码器。

常用的显示译码器能驱动七段字符显示器。







#### CD4511功能表

|    |    | 输  | j | λ. |   |   |   |   |   |     | 输 | 出 |   |      |
|----|----|----|---|----|---|---|---|---|---|-----|---|---|---|------|
| LE | ΒĪ | ΙΤ | D | С  | В | Α | a | ъ | с | d   | е | f | g | 显示字形 |
| ×  | ×  | 0  | × | ×  | × | × | 1 | 1 | 1 | 1   | 1 | 1 | 1 | 8    |
| ×  | 0  | 1  | × | ×  | × | × | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 消隐   |
| 0  | 1  | 1  | 0 | 0  | 0 | 0 | 1 | 1 | 1 | 1   | 1 | 1 | 0 | 0    |
| 0  | 1  | 1  | 0 | 0  | 0 | 1 | 0 | 1 | 1 | 0   | 0 | 0 | 0 | -    |
| 0  | 1  | 1  | 0 | 0  | 1 | 0 | 1 | 1 | 0 | 1   | 1 | 0 | 1 | 5    |
| 0  | 1  | 1  | 0 | 0  | 1 | 1 | 1 | 1 | 1 | 1   | 0 | 0 | 1 | 3    |
| 0  | 1  | 1  | 0 | 1  | 0 | 0 | 0 | 1 | 1 | 0   | 0 | 1 | 1 | 4    |
| 0  | 1  | 1  | 0 | 1  | 0 | 1 | 1 | 0 | 1 | 1   | 0 | 1 | 1 | 5    |
| 0  | 1  | 1  | 0 | 1  | 1 | 0 | 0 | 0 | 1 | 1   | 1 | 1 | 1 | O    |
| 0  | 1  | 1  | 0 | 1  | 1 | 1 | 1 | 1 | 1 | 0   | 0 | 0 | 0 | 7    |
| 0  | 1  | 1  | 1 | 0  | 0 | 0 | 1 | 1 | 1 | 1   | 1 | 1 | 1 | 8    |
| 0  | 1  | 1  | 1 | 0  | 0 | 1 | 1 | 1 | 1 | 0   | 0 | 1 | 1 | ٩    |
| 0  | 1  | 1  | 1 | 0  | 1 | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 消隐   |
| 0  | 1  | 1  | 1 | 0  | 1 | 1 | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 消隐   |
| 0  | 1  | 1  | 1 | 1  | 0 | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 消隐   |
| 0  | 1  | 1  | 1 | 1  | 0 | 1 | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 消隐   |
| 0  | 1  | 1  | 1 | 1  | 1 | 0 | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 消隐   |
| 0  | 1  | 1  | 1 | 1  | 1 | 1 | 0 | 0 | 0 | 0   | 0 | 0 | 0 | 消隐   |
| 1  | 1  | 1  | × | ×  | × | × |   |   | 4 | 锁 有 | Ē |   |   | 锁存   |

# 实验向客

1.试用逻辑门设计一个4线-2线的优先编码器。

用小规模逻辑门芯片设计一个4线-2线的优先编码器,要求输入端高电平有效。将输入端接拨位开关,输出端 Y<sub>0</sub>~Y<sub>1</sub> 分别接 2 个发光二极管,拨动拨位开关,根据发光二极管显示的变化,逐项验证 4-2 线编码器的功能。自拟表格记录实验数据。

要求:用与非门、反相器

2.试将74LS138用作数据分配器,将1Hz连续脉冲信号加到电路的控制输入端,输出接发光二极管,改变输入地址码 $A_2$ 、 $A_1$ 、 $A_0$ 的值,观察实验现象,记录实验结果。



若要求分配器的输出信号与输入脉冲信号同相,在不增加逻辑门的情况下,电路应如何改接。

#### 3、验证编码器74LS148和译码器74LS138的逻辑功能。



### 根据74LS148和74LS138的输出状态,填写下表,并分析结果。

|                |       | 74         | 4LS                                              | <b>S14</b>  | 8            | (编                             | 码品     | 器)             | 74LS138(译码器)  |                                    |  |  |  |
|----------------|-------|------------|--------------------------------------------------|-------------|--------------|--------------------------------|--------|----------------|---------------|------------------------------------|--|--|--|
| $I_{\epsilon}$ | $I_1$ | $I_1'I_2'$ | $\mathbf{I}_{2}^{\prime}\mathbf{I}_{3}^{\prime}$ | $I_3$ $I_4$ | $I_{1}I_{5}$ | $I_{6}^{\prime}I_{6}^{\prime}$ | $I_7'$ | $Y_2'Y_1'Y_0'$ | $A_2 A_1 A_0$ | $Y_0'Y_1'Y_2'Y_3'Y_4'Y_5'Y_6'Y_7'$ |  |  |  |
| 1              | 1     | 1          | 1                                                | 1           | 1            | 1                              | 1      |                |               |                                    |  |  |  |
| 0              | 1     | 1          | 1                                                | 1           | 1            | 1                              | 1      |                |               |                                    |  |  |  |
| X              | 0     | 1          | 1                                                | 1           | 1            | 1                              | 1      |                |               |                                    |  |  |  |
| X              | X     | 0          | 1                                                | 1           | 1            | 1                              | 1      |                |               |                                    |  |  |  |
| X              | X     | X          | 0                                                | 1           | 1            | 1                              | 1      |                |               |                                    |  |  |  |
| X              | X     | X          | X                                                | 0           | 1            | 1                              | 1      |                |               |                                    |  |  |  |
| X              | X     | X          | X                                                | X           | 0            | 1                              | 1      |                |               |                                    |  |  |  |
| X              | X     | X          | X                                                | X           | X            | 0                              | 1      |                |               |                                    |  |  |  |
| X              | X     | X          | X                                                | X           | X            | X                              | 0      |                |               |                                    |  |  |  |

# 4.设计一个具有3路报警信号的报警装置。

当第一路有报警信号时,数码管显示"1";当 第二路有报警信号时,数码管显示"2";当第三 路有报警信号时,数码管显示"3";当有两路或 两路以上有报警信号时,数码管显示"8";当无 报警信号时,数码管显示"0"。

要求:用74LS138、CD4511和逻辑门等器件设计该电路。

\*5.用两片74LS138和74LS20双与非门设计下面的多输出函数,画出逻辑电路图。

$$\begin{cases}
Y_1 = BC' \\
Y_2 = AB'CD + A'BC + AB'D
\end{cases}$$



# 实验设备与器件

- 1数字逻辑电路实验箱。
- 2 双踪示波器、数字万用表。
- 3 芯片 74LS/HC148, 74LS/HC138、74LS/HC04、74LS/HC00、74LS/HC20。

# 思考题

- 1. 如何判断一个数码管的好坏?
- 2. 共阴极和共阳极数字显示器有什么区别? 能否用 CD4511 直接驱动共阳极数字显示器?
- 3. 为什么用二进制译码器可以设计任意的组合逻辑电路?
- 4. 总结用集成电路进行功能扩展的方法。



## 数码管输入及电源



下次实验:数据选择器与加法器 (102室)

或 移位寄存器及应用 (102室)