

# 数字逻辑设计

高翠芸

School of Computer Science

gaocuiyun@hit.edu.cn

# 利用中规模芯片设计时序逻辑电路

---

- 计数器芯片
  - 计数器芯片的级联
  - 计数器芯片的应用
- 寄存器芯片
- 综合应用——序列信号发生器的设计

# 利用中规模计数器芯片设计时序逻辑电路

## 计数器芯片

- 同步十进制加法计数器：74LS160（异步清零）, 74LS162（同步清零）
- 同步4位二进制加法计数器：74LS161（异步清零）, 74LS163（同步清零）
- 异步二-五-十进制加法计数器：74LS90（异步清零）, 74LS290（异步清零）
- 同步十进制加/减计数器：74LS192（双时钟）, 74LS190（单时钟）
- 同步4位二进制加/减计数器：74LS193（双时钟）, 74LS191（单时钟）

置数功能

时钟边沿

到来时，且置数使能信号有效，向计数器装入用户指定的初始值

| 芯片型号    | 计数进制 | 输出特点     | 置数方式 | 清零方式 |
|---------|------|----------|------|------|
| 74LS160 | 十进制  | 8421BCD码 | 同步   | 异步   |
| 74LS161 | 十六进制 | 4位二进制码   | 同步   | 异步   |
| 74LS162 | 十进制  | 8421BCD码 | 同步   | 同步   |
| 74LS163 | 十六进制 | 4位二进制码   | 同步   | 同步   |

清零只需要1个条件：清零端给有效信号立即回零

清零需要2个条件同时具备：清零端给有效信号+时钟边沿到来

# 用计数器芯片设计模10计数器

例1：利用74LS161设计模10计数器

## ① 清零法



异步清零只需要1个条件：清零端给有效信号立即回零

设计M进制计数器：  
需要M+1个状态

| 芯片型号    | 计数进制 | 输出特点     | 置数方式 | 清零方式 |
|---------|------|----------|------|------|
| 74LS160 | 十进制  | 8421BCD码 | 同步   | 异步   |
| 74LS161 | 十六进制 | 4位二进制码   | 同步   | 异步   |
| 74LS162 | 十进制  | 8421BCD码 | 同步   | 同步   |
| 74LS163 | 十六进制 | 4位二进制码   | 同步   | 同步   |

74LS161/160功能表

| CP | 输入   |     |     | 输出  |                |                |                |                |
|----|------|-----|-----|-----|----------------|----------------|----------------|----------------|
|    | CLRN | LDN | ENT | ENP | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| X  | 0    | X   | X   | X   | 0              | 0              | 0              | 0              |
| ↑  | 1    | 0   | X   | X   | D              | C              | B              | A              |
| X  | 1    | 1   | 0   | X   | 保持             |                |                |                |
| X  | 1    | 1   | X   | 0   | 保持             |                |                |                |
| ↑  | 1    | 1   | 1   | 1   | 计数,计满时RCO=1    |                |                |                |



用74LS161实现

1010只在极短的瞬态出现，不包括在稳定的循环中



# 模10计数器

## 例2：利用74LS163 设计模10 计数器

### ① 清零法



同步清零需要2个条件同时具备：清零端给有效信号+时钟边沿到来

设计M进制计数器：  
需要M个状态

| 芯片型号    | 计数进制 | 输出特点     | 置数方式 | 清零方式 |
|---------|------|----------|------|------|
| 74LS160 | 十进制  | 8421BCD码 | 同步   | 异步   |
| 74LS161 | 十六进制 | 4位二进制码   | 同步   | 异步   |
| 74LS162 | 十进制  | 8421BCD码 | 同步   | 同步   |
| 74LS163 | 十六进制 | 4位二进制码   | 同步   | 同步   |

74LS163/162功能表

| CP    | 输入   |     |              | 输出  |                |                |                |                |
|-------|------|-----|--------------|-----|----------------|----------------|----------------|----------------|
|       | CLRN | LDN | ENT          | ENP | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| ↑ 0 X | X    | X   | 0 0 0 0      |     |                |                |                |                |
| ↑ 1 0 | X    | X   | D C B A      |     |                |                |                |                |
| X 1 1 | 0 X  |     |              |     |                |                |                | 保持             |
| X 1 1 | X 0  |     |              |     |                |                |                | 保持             |
| ↑ 1 1 | 1 1  | 1 1 | 计数, 计满时RCO=1 |     |                |                |                |                |



用74LS163实现

# 用置数法设计模10计数器

74LS161/160功能表

| 输入 |      |     | 输出  |     |                |                |                |                |
|----|------|-----|-----|-----|----------------|----------------|----------------|----------------|
| CP | CLRN | LDN | ENT | ENP | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| X  | 0    | X   | X   | X   | 0              | 0              | 0              | 0              |
| ↑  | 1    | 0   | 1   | 0   | D              | C              | B              | A              |
| X  | 1    | 1   | 0   | X   | 保持             |                |                |                |
| X  | 1    | 1   | X   | 0   | 保持             |                |                |                |
| ↑  | 1    | 1   | 1   | 1   | 计数, 计满时RCO=1   |                |                |                |

74LS163/162功能表

| 输入 |      |     | 输出  |     |                |                |                |                |
|----|------|-----|-----|-----|----------------|----------------|----------------|----------------|
| CP | CLRN | LDN | ENT | ENP | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| ↑  | 0    | X   | X   | X   | 0              | 0              | 0              | 0              |
| ↑  | 1    | 0   | 1   | 0   | D              | C              | B              | A              |
| X  | 1    | 1   | 0   | X   | 保持             |                |                |                |
| X  | 1    | 1   | X   | 0   | 保持             |                |                |                |
| ↑  | 1    | 1   | 1   | 1   | 计数, 计满时RCO=1   |                |                |                |

| 芯片型号    | 计数进制 | 输出特点     | 置数方式 | 清零方式 |
|---------|------|----------|------|------|
| 74LS160 | 十进制  | 8421BCD码 | 同步   | 异步   |
| 74LS161 | 十六进制 | 4位二进制码   | 同步   | 异步   |
| 74LS162 | 十进制  | 8421BCD码 | 同步   | 同步   |
| 74LS163 | 十六进制 | 4位二进制码   | 同步   | 同步   |

例：利用74LS161或74163设计模10计数器

## ② 置数法

设计M进制计数器  
：需要M个状态



置数法



清零法

lus II File Edit View Node Assign Utilities Options Window Help



## m.scf - Waveform Editor

Ref: 0.0ns Time: 232.2ns Interval: 232.2ns



# 利用中规模芯片设计时序逻辑电路

---

- 计数器芯片
  - 计数器芯片的级联
  - 计数器芯片的应用
- 寄存器芯片
- 综合应用——序列信号发生器的设计

# 计数器芯片的级联

## □ 利用进位信号

例1：利用74LS161设计模256 加法计数器

### (1) 同步并行进位连接方式



用前一级的进位作后一级的时钟信号

### (2) 异步串行进位连接方式



用前一级的进位控制后一级的计数使能

| 芯片型号    | 计数进制 | 输出特点     | 置数方式 | 清零方式 |
|---------|------|----------|------|------|
| 74LS160 | 十进制  | 8421BCD码 | 同步   | 异步   |
| 74LS161 | 十六进制 | 4位二进制码   | 同步   | 异步   |
| 74LS162 | 十进制  | 8421BCD码 | 同步   | 同步   |
| 74LS163 | 十六进制 | 4位二进制码   | 同步   | 同步   |

# 计数器芯片的级联

## □ 利用进位信号

例2：利用74LS160采用置数法设计模60计数器

| 芯片型号    | 计数进制 | 输出特点     | 置数方式 | 清零方式 |
|---------|------|----------|------|------|
| 74LS160 | 十进制  | 8421BCD码 | 同步   | 异步   |
| 74LS161 | 十六进制 | 4位二进制码   | 同步   | 异步   |
| 74LS162 | 十进制  | 8421BCD码 | 同步   | 同步   |
| 74LS163 | 十六进制 | 4位二进制码   | 同步   | 同步   |

用前一级的进位控制后一级的计数使能



# 计数器芯片的应用

## □ 节拍发生器

例：利用74LS163设计实现一个8节拍发生器

| 芯片型号    | 计数进制 | 输出特点     | 置数方式 | 清零方式 |
|---------|------|----------|------|------|
| 74LS160 | 十进制  | 8421BCD码 | 同步   | 异步   |
| 74LS161 | 十六进制 | 4位二进制码   | 同步   | 异步   |
| 74LS162 | 十进制  | 8421BCD码 | 同步   | 同步   |
| 74LS163 | 十六进制 | 4位二进制码   | 同步   | 同步   |



波形分析：

一个循环周期之内的波形与  
二进制译码器的输出相同

能把波形循环实现：计数器

3:8译码器  
模8计数器

# 利用中规模计数器芯片设计时序逻辑电路

## 计数器芯片

- 同步十进制加法计数器：74LS160（异步清零）, 74LS162（同步清零）
- 同步4位二进制加法计数器：74LS161（异步清零）, 74LS163（同步清零）
- 异步二-五-十进制加法计数器：74LS90（异步清零）, 74LS290（异步清零）
- 同步十进制加/减计数器：74LS192（双时钟）, 74LS190（单时钟）
- 同步4位二进制加/减计数器：74LS193（双时钟）, 74LS191（单时钟）



异步清零

74LS90/290功能表

| CP | 输入                 |                    |                                       | 输出             |                |                |                |
|----|--------------------|--------------------|---------------------------------------|----------------|----------------|----------------|----------------|
|    | R <sub>0</sub> (1) | R <sub>0</sub> (2) | S <sub>9</sub> (1) S <sub>9</sub> (2) | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| X  | 1                  | 1                  | 0 X                                   | 0              | 0              | 0              | 0              |
| X  | 1                  | 1                  | X 0                                   | 0              | 0              | 0              | 0              |
| X  | X                  | X                  | 1 1                                   | 1              | 0              | 0              | 1              |
| ↓  | X                  | 0                  | X 0                                   |                |                |                | 计数             |
| ↓  | 0                  | X                  | 0 X                                   |                |                |                | 计数             |
| ↓  | 0                  | X                  | X 0                                   |                |                |                | 计数             |
| ↓  | X                  | 0                  | 0 X                                   |                |                |                | 计数             |

# 计数器芯片的应用

## ① 8421-BCD 码模10计数器



74LS90/290功能表

| CP | 输入                 |                    | 输出                 |                    |                |                |                |                |
|----|--------------------|--------------------|--------------------|--------------------|----------------|----------------|----------------|----------------|
|    | R <sub>0</sub> (1) | R <sub>0</sub> (2) | S <sub>9</sub> (1) | S <sub>9</sub> (2) | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| X  | 1                  | 1                  | 0                  | X                  | 0              | 0              | 0              | 0              |
| X  | 1                  | 1                  | X                  | 0                  | 0              | 0              | 0              | 0              |
| X  | X                  | X                  | 1                  | 1                  | 1              | 0              | 0              | 1              |
| ↓  | X                  | 0                  | X                  | 0                  | 0              | 0              | 0              | 计数             |
| ↓  | 0                  | X                  | 0                  | X                  | 0              | 0              | X              | 计数             |
| ↓  | 0                  | X                  | X                  | 0                  | X              | 0              | 0              | 计数             |
| ↓  | X                  | 0                  | 0                  | X                  | 0              | X              | 0              | 计数             |



# 计数器芯片的应用

异步清零，  
多让出一个状态

## ② 模-45 计数器

Solution 1:



Solution 2:



# 计数器芯片的应用

## ③ 5421-BCD 码模10计数器



# 计数器芯片的应用

## ④ 设计节拍发生器



### 1) 设计模7计数器



### 2) 以模7计数器为输入，设计译码器

| 输入             |                |                | 译码输出           |                |                |                |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> | Y <sub>1</sub> | Y <sub>2</sub> | Y <sub>3</sub> | Y <sub>4</sub> | Y <sub>5</sub> | Y <sub>6</sub> | Y <sub>7</sub> |
| 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              |
| 0              | 0              | 1              | 0              | 1              | 0              | 0              | 0              | 0              | 0              |
| 0              | 1              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              |
| 0              | 1              | 1              | 0              | 0              | 0              | 1              | 0              | 0              | 0              |
| 1              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              |
| 1              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 1              | 0              |
| 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              |



# 利用中规模计数器芯片设计时序逻辑电路

## 计数器芯片

- 同步十进制加法计数器：74LS160（异步清零）, 74LS162（同步清零）
- 同步4位二进制加法计数器：74LS161（异步清零）, 74LS163（同步清零）
- 异步二-五-十进制加法计数器：74LS90（异步清零）, 74LS290（异步清零）
- 同步十进制加/减计数器：74LS192（双时钟）, 74LS190（单时钟）
- 同步4位二进制加/减计数器：74LS193（双时钟）, 74LS191（单时钟）



异步清零  
异步置数

74LS192/193功能表

| 输入   |    |     |     | 输出             |                |                |                |
|------|----|-----|-----|----------------|----------------|----------------|----------------|
| CLRN | LD | CP+ | CP- | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| 1    | X  | X   | X   | 0              | 0              | 0              | 0              |
| 0    | 0  | X   | X   | D              | C              | B              | A              |
| 0    | 1  | ↑   | 1   | 加计数            |                |                |                |
| 0    | 1  | 1   | ↑   | 减计数            |                |                |                |
| 0    | 1  | 1   | 1   | 保持             |                |                |                |

没有清零端，可借助  
异步置数功能实现

74LS190/191功能表

| 输入 |    | 输出  |    |                |                |                |                |
|----|----|-----|----|----------------|----------------|----------------|----------------|
| LD | CT | D/U | CP | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| 0  | X  | X   | X  | D              | C              | B              | A              |
| 1  | 0  | 0   | ↑  | 加计数            |                |                |                |
| 1  | 0  | 1   | ↑  | 减计数            |                |                |                |
| 1  | 1  | X   | X  | 保持             |                |                |                |



# 计数器芯片的综合应用

可变模值计数器——利用一片4位数码比较器74LS85及一片模16计数器芯片74LS193设计一个模N计数器（ $N < 16$ ）。



- 设计思路
- 比较器：  
 $A_3 \sim A_0$ ：输入计数器模值N（例如 $N=10$ ）  
 $B_3 \sim B_0$ ：连接计数器当前计数输出值
  - 如果计数器当前输出值  $Q_D Q_C Q_B Q_A = \text{模值} N$   
比较器输出端  $Y_{A=B}=1$ , 该信号使计数器清零

# 计数器芯片的综合应用



# 利用中规模芯片设计时序逻辑电路

---

- 计数器芯片
  - 计数器芯片的级联
  - 计数器芯片的应用
- 寄存器芯片
- 综合应用——序列信号发生器的设计

# 利用中规模寄存器芯片设计时序逻辑电路

4-bit 双向移位寄存器芯片——74194 (Serial /Parallel input, Parallel out )



74LS194功能表

| 输入 |    |       | 输出    |          |       |       |          |
|----|----|-------|-------|----------|-------|-------|----------|
| CP | CR | $S_1$ | $S_0$ | $Q_A$    | $Q_B$ | $Q_C$ | $Q_D$    |
| X  | 0  | X     | X     | 0        | 0     | 0     | 0        |
| 0  | 1  | X     | X     |          |       |       | 保持       |
| X  | 1  | 0     | 0     |          |       |       | 保持       |
| ↑  | 1  | 0     | 1     | $D_{SR}$ | $Q_A$ | $Q_B$ | $Q_C$    |
| ↑  | 1  | 1     | 0     | $Q_B$    | $Q_C$ | $Q_D$ | $D_{SL}$ |
| ↑  | 1  | 1     | 1     | A        | B     | C     | D        |

异步清零



# 双向移位寄存器芯片74194的应用

## ① 4-bit 扭环形计数器



## ② 寄存器级联

构造8位双向移位寄存器

| S <sub>1</sub> S <sub>0</sub> | 工作方式 |
|-------------------------------|------|
| 0 0                           | 保持   |
| 0 1                           | 右移   |
| 1 0                           | 左移   |
| 1 1                           | 并入   |



# 利用中规模芯片设计时序逻辑电路

---

- 计数器芯片
  - 计数器芯片的级联
  - 计数器芯片的应用
- 寄存器芯片
- 综合应用——序列信号发生器的设计

# 序列信号发生器的设计

**序列信号发生器：**能循环产生一组特定的串行数字序列信号的电路。

**序列的长度：**序列信号的位数。如：序列为00011，则序列长度为5。



# 序列信号发生器的设计-1

## 任意类型

- 使用D触发器设计
- 使用计数器 + 数据选择器设计；
- 用移位寄存器 + 反馈电路设计(逻辑门 or译码器 or数据选择器)
- 用计数器 + PROM设计

大体思路：

1. 实现序列信号一个周期之内的波形
2. 将此波形循环再现

例1：用D触发器设计一个 110100 序列信号发生器

### 方法1：利用D触发器

- 序列信号长度为 L，则取 L个不同的状态
- 每个状态下时序电路的输出就是序列信号中的一位。

### 1. 画状态转换图

时序电路的不同状态对应输出序列中的各位。



# 序列信号发生器的设计-1

## 2. 状态编码

$S_0$  —— 000,  $S_3$  —— 011  
 $S_1$  —— 001,  $S_4$  —— 100  
 $S_2$  —— 010,  $S_5$  —— 101

## 3. 状态转换真值

| $Q_2 Q_1 Q_0$ | $Q_2^{n+1}$ | $Q_1^{n+1}$ | $Q_0^{n+1}$ | $Y$ |
|---------------|-------------|-------------|-------------|-----|
| 0 0 0         | 0           | 0           | 1           | 1   |
| 0 0 1         | 0           | 1           | 0           | 1   |
| 0 1 0         | 0           | 1           | 1           | 0   |
| 0 1 1         | 1           | 0           | 0           | 1   |
| 1 0 0         | 1           | 0           | 1           | 0   |
| 1 0 1         | 0           | 0           | 0           | 0   |

## 4. 卡诺图化简

| $Q_2 Q_1 Q_0$ | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             | 1  | 0  | 0  | 1  |
| 1             | 1  | 0  | X  | X  |

$$D_0 = Q_0'$$

| $Q_2 Q_1 Q_0$ | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             | 0  | 0  | 1  | 0  |
| 1             | 1  | 0  | X  | X  |

$$D_2 = Q_2 Q_0' + Q_1 Q_0$$

| $Q_2 Q_1 Q_0$ | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             | 0  | 1  | 0  | 1  |
| 1             | 0  | 0  | 0  | X  |

$$D_1 = Q_2' Q_1' Q_0 + Q_1 Q_0'$$

| $Q_2 Q_1 Q_0$ | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 0             | 1  | 1  | 1  | 0  |
| 1             | 0  | 0  | X  | X  |

$$Y = Q_2' Q_1' + Q_1 Q_0$$

# 序列信号发生器的设计-1

## 5. 电路实现(略)

## 6. 检查无关项



时序电路可以自启动。

### 方法1：利用D触发器

- 序列信号长度为  $L$ ，则取  $L$  个不同的状态
- 每个状态下时序电路的输出就是序列信号中的一位。

# 序列信号发生器的设计-1

例1：设计一个 110100 序列信号发生器

方法2：利用计数器+数据选择器

计数器+数据选择器  
设计序列信号发生器的方法

- 数据选择器74151的输入 D<sub>0</sub>-D<sub>5</sub>接成110100。
- 74163接成模6加法计数器
- 计数器输出连接到数据选择器的选择控制端CBA，经  
过循环选择产生所需序列。

大体思路：

1. 实现序列信号一个周期之内的波形
2. 循环再现



# 序列信号发生器的设计-2

例2：设计一个 00010111 序列信号发生器

方法3：移位寄存器+反馈电路设计（逻辑门 or 译码器 or 数据选择器）



# 序列信号发生器的设计-2

例2：设计一个 00010111 序列信号发生器

方法3：移位寄存器+反馈电路设计（逻辑门 or 译码器 or 数据选择器）

## 具体方法

□ 确定移位寄存器的位数。

序列信号长度为 L，则移位寄存器的位数  $n$  应满足：

$$2^n \geq L$$

试探法： $n$  为满足条件的最小值，将序列数据 **循环左移**，画状态图。检查状态图中所有 L 个状态是否两两不同，是，则  $n$  值可用；否则取  $n+1$ ，重复上述操作。

- 画状态转换表，确定左移时最低位输入的卡诺图，求出表达式。如果有无关项，检察电路的自启动能力
- 实现最低位反馈输入（逻辑门 or 译码器 or 数据选择器）
- 取移位寄存器的某位输出即为所要求的序列信号。

## 1. 确定移位寄存器位数

序列长度  $L=8$ ，则  $n=3$

## 2. 状态转换图



用 74194 的低 3 位  $Q_B Q_C Q_D$  输出

# 序列信号发生器的设计-2

例2：设计一个 00010111 序列信号发生器

方法3：移位寄存器+反馈电路设计

## 3. 状态转换真值表

| $Q_B Q_C Q_D$ | $L_{IN}$ |
|---------------|----------|
| 0 0 0         | 1        |
| 0 0 1         | 0        |
| 0 1 0         | 1        |
| 1 0 1         | 1        |
| 0 1 1         | 1        |
| 1 1 1         | 0        |
| 1 1 0         | 0        |
| 1 0 0         | 0        |

$Q_B$  输出即为序列信号



# 序列信号发生器的设计-2

例2：设计一个 00010111 序列信号发生器 1~4. 同上

方法3：移位寄存器+反馈电路设计

$$\begin{aligned}L_{IN} &= Q_B Q_C' Q_D + Q_B' Q_C + Q_B' Q_D' \\&= \sum m (0, 2, 3, 5)\end{aligned}$$

转换为最小项表达式



Q<sub>B</sub>Q<sub>C</sub>Q<sub>D</sub> 分别接 74151 的选择控制端 CBA，则：

$$\begin{aligned}D_0 &= D_2 = D_3 = D_5 = 1, \\D_1 &= D_4 = D_6 = D_7 = 0\end{aligned}$$

反馈电路：  
数据选择器

# 序列信号发生器的设计-2

例2：设计一个 00010111 序列信号发生器 1~4. 同上

方法3：移位寄存器+反馈电路设计

$$\begin{aligned}L_{IN} &= Q_B Q_C' Q_D + Q_B' Q_C + Q_B' Q_D' \\&= \Sigma m (0, 2, 3, 5)\end{aligned}$$

转换为最小项表达式



QB输出即为序列信号

QBQCQD分别接74138的地址输入端CBA，则：

Y0, Y2, Y3, Y5 分别被译中时，反饋回1，否则反饋回0

反馈电路：  
译码器

# 序列信号发生器设计方法总结

## 方法总结

### 特殊类型

- 使用环形计数器设计
- 使用扭环计数器设计

### 任意类型

- 使用D触发器设计
- 使用计数器 + 数据选择器设计；
- 用移位寄存器+反馈电路设计（逻辑门 or 译码器 or 数据选择器）
- 用计数器 + PROM设计