

南开大学电子信息与光学工程学院

## 第二次 实验报告

实验序号 实验十

实验名称 组合逻辑电路设计

计算机学院 计算机 系

姓名 王乐之 学号 2411302 实验台号 23

实验日期及时间 12.24

### 一. 实验目的:

- 1、了解数据选择器的电路结构和特点，掌握其逻辑功能。
- 2、掌握基本门电路进行组合逻辑电路设计的方法
- 3、掌握中规模集成电路设计组合电路的方法

## 二. 实验仪器及元器件

| 实验仪器    | 型号 | 备注 |
|---------|----|----|
| 数字逻辑实验箱 |    |    |
|         |    |    |
|         |    |    |
|         |    |    |
|         |    |    |

| 电子元器件                | 规格 | 数量  |
|----------------------|----|-----|
| 7400,7420,7486,74153 |    | 1-2 |
| 导线                   |    | 若干  |
|                      |    |     |
|                      |    |     |
|                      |    |     |
|                      |    |     |
|                      |    |     |

## 二. 实验原理:

根据逻辑功能的不同特点，可以把数字电路分成两大类：组合逻辑电路和时序逻辑电路。在组合逻辑电路中，任意时刻的输出仅仅取决于当前时刻的输入，与电路原来的状态无关，这就是组合逻辑电路在逻辑功能上的共同特点。组合逻辑电路的逻辑功能一般有三种表达方式：逻辑图、函数表达式和真值表。

对于组合逻辑电路，通常采用的分析方法是从电路的输入到输出逐级写出逻辑函数式，然后得到表示输出与输入关系的函数表达式。最后用公式化简或卡诺图化简，使逻辑关系简单明了。

逻辑电路的设计方法一般遵循下列步骤：

- 1、根据逻辑功能描述进行逻辑抽象，确定输入和输出变量；
- 2、列出真值表，由真值表得出最小项表达式；
- 3、选定所使用器件的类型；
- 4、根据器件的逻辑功能，化简或变换最小项表达式；
- 5、根据化简变换后的逻辑表达式画出逻辑电路连接图。

前面实验所做的编码译码电路和数据选择器，都属于组合逻辑电路。

**竞争冒险：**在数字电路中，任何一个门电路只要输入的信号同时反方向变化其输出端就可能产生窄脉冲。信号由于经过不同的路径传输达到某一汇合点的时间有先有后的现象，就称之为竞争，由于竞争现象所引起的电路输出发生瞬间错误的现象，就称之为冒险。有竞争不一定有冒险，但出现了冒险就一定存在竞争。由于从输入到输出的过程中，不同通路上门的级数不同，或者门电路平均延迟时间的差异，使信号从输入经不同通路传输到输出级的时间不同。由于这个原因，可能会使逻辑电路产生错误输出。通常把这种现象称为竞争冒险。

消除竞争冒险的方法：

- 1、输出端接入滤波电容；
- 2、输出端引入选通脉冲；
- 3、增加冗余项，修改逻辑设计；
- 4、引入封锁脉冲。

#### 四. 实验内容、步骤与要求:

##### 1. 使用 2 个 7400 选择器完成四人表决器

电路图仿真实验如下



表达式推导:

利用德摩根律

$$\begin{aligned} Q &= ABC + ACD + ABD + BCD = (AB + CD)(AC + BD) \\ &= (\overline{AB} * \overline{CD})(\overline{AC} * \overline{BD}) \\ &= \overline{(\overline{AB} * \overline{CD})(\overline{AC} * \overline{BD})} * \overline{(\overline{AB} * \overline{CD})(\overline{AC} * \overline{BD})} \end{aligned}$$

共计使用 8 个与非门，也就是 2 个 7400 即可实现。

电路结构为 U1A 和 U2A 分别求了 AB, CD 的与非，U1B 和 U2C 分别求了 AC, BD 的与非。U2B 和 U1C 分别求得上面两个结果的与非。最后将得到两个结果用 U1D 得到 Q 的非，通过反相器 U2D 得到最终结果。仿真得到真值表为当输入至少三个一的时候才会输出 1（灯泡亮），因此符合实验要求。

#### 四、实验内容、步骤与要求:

##### 2. 使用 7400 和 7486 实现全加器

输入为 A,B 以及上次进位 Ci, 则本位为

$$\text{sum} = A \oplus B \oplus C$$

而若 A,B 都为 1, 则进位 Si 必定为 1, 若 A,B 有 1 个 1(也就是异或为真), 则 Ci 为 1 时才会输出 1, A,B 没有 1 时则不进位。

于是有

$$\begin{aligned} Si &= AB + (A \oplus B)C \\ &= \overline{AB} * \overline{(A \oplus B)C} \end{aligned}$$

对应电路图实现如下:



仿真得到真值表如下

| A | B | Ci | Sum | Si |
|---|---|----|-----|----|
| 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  |

### 3. 使用 74153 (双 4 选 1 选择器) 完成 3 人表决器

核心思想输入 B 和 C 决定选择，接入选择器的 A 和 B，当 BC 输入为 11 时，此时与 A 无关，于是选择为 1，BC 输入为 00 时，输出与 A 也无关，选择恒为 0。BC 输入为 01 和 10 时，当且仅当 A 为 1 时输出 1，因此选择为 A。

根据上述原理，电路图如下所示：



仿真电路输出的真值表

| A | B | C | Y(通过) |
|---|---|---|-------|
| 0 | 0 | 0 | 0     |
| 0 | 0 | 1 | 0     |
| 0 | 1 | 0 | 0     |
| 0 | 1 | 1 | 1     |
| 1 | 0 | 0 | 0     |
| 1 | 0 | 1 | 1     |
| 1 | 1 | 0 | 1     |
| 1 | 1 | 1 | 1     |

#### 4. 使用 7400,7420,7486 实现密码锁

密码锁的原理为逐位比对，这就需要同或运算，也就是异或加非的运算。其中 S1-S4 为输入区，S5-S8 为设定区 S9 为启动器。

那么就应当让  $S_i$  与  $S_{(i+4)}$  做同或运算，得到四个值  $S_c$ ，若密码正确， $S_c$  应当为 1，否则为 0。这四个值放入 7420 中做四输入的与非运算，得到结果  $\overline{X_{correct}}$ 。最终输出  $S9 * \overline{X_{correct}}$  以及  $S9 * X_{correct}$ ，这两个只需要 7400 与非门就可以轻松实现。

仿真实验电路图如下：



经过测试，当 S9 闭合且密码正确，X2 亮，X1 不亮。S9 闭合但密码错误，X1 亮，X2 不亮；S9 断开则都不亮。

## 五、实验思考题 (本实验暂无)

附录：电路仿真文件地址

[https://github.com/justleming/nku-digital\\_logic](https://github.com/justleming/nku-digital_logic)