# 数季电路与逻辑设计

Digital circuit and logic design

● 第五章 同步时序逻辑电路

主讲教师赵贻竹



## 时序逻辑电路概述



给最小化状态表中用字母或数字表示的状态指定一个二进制代码,形成二进制状态表,也称状态分配,或者状态赋值。

- 确定状态编码的长度(所需触发器个数)
- 寻找一种最佳的或接近最佳的状态分配方案,以便使所设计的时序电路最简单



#### 二进制代码位数



设最小化状态表的状态数为N,状态编码的长度为m



$$2^{m} \ge N > 2^{m-1}$$

$$N=4$$
  $m=2$ 

$$N=6$$

$$m=3$$

#### 状态分配方案



状态与代码之间的对应种关系可以有许多



分配方案数Ks

$$K_s = A_{2m}^N = \frac{2^m !}{(2^m - N) !}$$



N=4

$$K_{S} = 24$$



相邻分配法

相邻分配 法的基本 思想 在选择状态编码时,尽可能使激励函数和输出函数在卡诺图上的"1"方格处在相邻位置,从而有利于激励函数和输出函数的化简



#### 相邻分配法的状态编码原则

- ①次态相同,现态相邻
- 相同输入条件下,具有相同次态的现态应尽可能分配相邻的二进制代码;
- ② 同一现态,次态相邻
- | 相邻输入条件下,同一现态的次态应尽可能分配相邻的二进制代码;
- ③ 输出相同,现态相邻
- 对应每一种输入取值均具有相同输出的现态应尽可能分配相邻的二进制代码。



#### ▶ 状态编码



- 某些状态表常常出现不能同时满足3条原则的情况,此时,可按从①至 ③的优先顺序考虑
- **№** 此外,从电路实际工作状态考虑,**一般将初始状态分配"0"状态**







## 对如下状态表进行状态编码(设A为初始状态)。

|    | 次态/输出 |     |
|----|-------|-----|
| 现态 | x=0   | x=1 |
| Α  | C/1   | B/0 |
| В  | A/0   | A/1 |
| c  | A/1   | D/1 |
| D  | D/1   | C/0 |







$$N = 4$$



$$m = 2$$



需要两个触发器

| 现态 | 次态/输出 |     |
|----|-------|-----|
|    | x=0   | x=1 |
| А  | C/1   | B/0 |
| В  | A/0   | A/1 |
| С  | A/1   | D/1 |
| D  | D/1   | C/0 |





原则



BC应相邻



原则 2



3

BC、AD、CD应相邻



原则



AD应相邻



总结



BC、AD、CD相邻

| 现态 | 次态/输出 |     |
|----|-------|-----|
|    | x=0   | x=1 |
| А  | C/1   | B/0 |
| В  | A/0   | A/1 |
| С  | A/1   | D/1 |
| D  | D/1   | C/0 |

# 析

- **BC、AD、CD相邻**
- 假定状态变量用y2y1表示
- 状态分配工具:卡诺图
- 初始状态为A





C=11 A = 00B = 01D=10

| 现态 | 次态/输出 |     |
|----|-------|-----|
|    | x=0   | x=1 |
| Α  | C/1   | B/0 |
| В  | A/0   | A/1 |
| С  | A/1   | D/1 |
| D  | D/1   | C/0 |



| 现态 | 次态/输出 |      |
|----|-------|------|
|    | x=0   | x=1  |
| 00 | 11/1  | 01/0 |
| 01 | 00/0  | 00/1 |
| 11 | 00/1  | 10/1 |
| 10 | 10/1  | 11/0 |



# 数季电路与逻辑设计

Digital circuit and logic design

● 谢谢,祝学习快乐!

主讲教师赵贻竹

