# 2019~2020 学年

数

字

逻

辑

电

路

实

验

C

东南大学电工电子实验中心 2020年1月

# 目 录

| 教学计划和要求         | 3        |
|-----------------|----------|
| 基本情况:           | 3        |
| 教学要求:           | 3        |
| 实验教学计划          |          |
| 评分和考核方法         | 5        |
| 本学期开放时间安排       | 5        |
| 课程准备事项          | <i>6</i> |
| 准备导线            | <i>6</i> |
| 准备面包板           | <i>6</i> |
| 准备工具            | <i>6</i> |
| 下载并安装相关软件       |          |
| 预习报告样例          | 8        |
| 实验内容            | 8        |
| 实验设计方案          | 8        |
| 测试方案            | 9        |
| 电路搭接调试方法样例      | 11       |
| 分析电路            | 11       |
| 合并器件            | 11       |
| 查询数据手册          | 11       |
| 根据数据手册选择器件,分配管脚 |          |
| 元件布局            |          |
| 布线              |          |
| 通电前检查           |          |
| 通电验证            |          |
| 故障调试            |          |
| 故障举例:           |          |
| 实验一 门电路组合逻辑     |          |
|                 |          |
| 时间要求:           |          |
| 预习要求            |          |
| 必做实验            |          |
| 选做实验            |          |
| 实验二 中规模组合逻辑     |          |
| 学习目标            |          |
| 时间要求:           |          |
| 预备知识            |          |
| 必做实验            |          |
| 选做实验            |          |
| 实验三 仪器使用        |          |

| 学习目标                   | 20 |
|------------------------|----|
| 时间要求:                  | 20 |
| 实验预习                   | 20 |
| 必做实验                   | 20 |
| 实验结果分析:                | 22 |
| 实验注意事项:                | 22 |
| 实验四 脉冲信号测量             | 23 |
| 学习目标                   | 23 |
| 时间要求:                  | 23 |
| 实验预习                   | 23 |
| 必做实验:                  | 23 |
| 实验五 时序逻辑电路             | 25 |
| 学习目标                   | 25 |
| 时间要求:                  | 25 |
| 预备知识                   | 25 |
| 必做实验                   | 25 |
| 实验六 可编程数字逻辑设计基础        | 27 |
| 学习目标                   | 27 |
| 时间要求                   | 27 |
| 预备知识                   | 27 |
| 预习要求                   | 28 |
| 必做实验                   | 29 |
| 选做实验                   | 29 |
| 实验七 可编程小系统设计           | 30 |
| 学习目标                   | 30 |
| 时间要求:                  | 30 |
| 预备知识                   | 30 |
| 必做实验                   | 31 |
| 附录一 Fritzing 简明操作指南    |    |
| 附录二 Quartus II 简明操作指南  | 35 |
| 一、 设计项目输入              | 35 |
| 1.1 建立工程项目             | 35 |
| 1.2 建立原理图输入文件          | 36 |
| 二、 设计项目处理              | 39 |
| 三、 设计项目校验              | 40 |
| 3.1 建立输入激励波形文件 (.vmf): | 40 |
| 3.2 为输入信号建立输入激励波形:     | 40 |
| 3.3 功能仿真               | 41 |
| 3.4 时序仿真               | 41 |
| 四、 器件编程                | 41 |
| 4.1 Quartus II 器件编程    | 41 |

# 教学计划和要求

## 基本情况:

1、 总 学 时: 32 学时

2、 学时比例: 1.0 (课内): 1.0 (课外)

3、 学 分: 1.0 学分

4、 适用范围: 2019 级计算机类学生

5、 先修课程: 高等数学、物理、数字逻辑电路

6、时间: 2020.2~2020.6

7、 实验教材: 《数字逻辑设计实践》徐莹隽、常春等编著,高等教育出版社

# 教学要求:

## 预习要求:

- 1. 进实验室前要求完成本次实验预习报告,内容包括
  - a) 实验电路功能描述、系统框图和详细设计过程
  - b) 实验电路原理图
  - c) 实验电路硬件连接图(无要求则非必须)
  - d) 如果实验有预习思考题,提交预习思考题答案
- 2. 预习报告写在实验报告的实验原理部分,如没有把握,也可先写在其他纸上,实验完成后重誊写到实验报告上
- 3. 实验电路要求在进实验室前完成搭接,实验室内以电路调试为主
- 4. 电工电子实验中心的网站地址为: <a href="http://223.3.70.102/LimsCMS">http://223.3.70.102/LimsCMS</a>, 预习时请访问该平台以了解您准备完成的实验内容是否有变动、提示或其他通知。

#### 实验要求:

- 1、实验采用集中授课+开放实验模式,课内教师传授学生实验方法和技能,引导学生完成必做实验项目,课外学生完成选做和自主性实验项目,教师进行适当辅助。第一次实验时请仔细阅读开放实验规章制度,并在以后的实验中认真遵守
- 2、每次实验要带校园卡、元器件、单股连接线、丁字线和所发的面包板。丁字线和面包板请妥善保管, 勿丢失或损坏,否则将照价赔偿
- 3、在进入实验室时,请在刷卡机上出示您的校园卡,在刷卡机分配的实验室和实验座位上完成实验, 严禁串座
- 4、实验前先检查自己座位上的仪器、如有缺失或损坏请及时通知指导老师处理。实验过程中如果发生 仪器故障,也请和值班教师联系,值班教师检查确认后用备用仪器更换,严禁自己用其他实验座位 上的仪器更换
- 5、 按实验设计方案搭接和测试电路, 认真检查确保无误后方可通电测试
- 6、认真记录实验数据和实验波形,所有数据和波形都要分析判断,确认正确
- 7、要求实物验收的实验内容,完成并记录所有实验数据后,提请指导老师验收,验收通过后方可拆除 电路结束实验
- 8、实验过程中遇到故障要独立思考,耐心查找故障原因并排除,记录故障现象、排除故障过程和方法

- 9、 实验中若发生异常现象, 应立即切断电源, 通知指导老师处理。如有元器件损坏, 可到仪表室购买
- 10、 实验中途请勿随意离开实验室, 如确实有特殊情况请向指导教师请假
- 11、 实验完成后请将仪器归位并关闭仪器电源、整理线缆、打扫干净实验桌面, 然后刷卡下机

### 实验报告要求:

- 1. 实验报告应该包括以下几个部分
  - ◆ 实验目的和要求
  - ◆ 实验原理,包括实验电路的设计过程、系统框图、原理图、硬件连接图、测试方案等,要求在实验前完成
  - ◆ 实验仪器,实验中用到的仪器设备
  - ◆ 实验记录,记录实验具体步骤、原始数据、实验过程、实验中遇到的故障现象、排除故障的过程和方法等
  - ◆ 实验分析,对实验结果进行分析比对
  - ◆ 实验小结,总结实验完成情况,对设计方案和实验结果做必要的讨论,简述实验收获和体会
  - ◆ 实验思考题,如有,提交思考题答案
  - ◆ 参考资料,记录实验过程阅读的有关资料,包含资料名称、作者等
- 2. 数字电路实验结果验证一般包括真值表验证、波形验证、功能验证
  - ◆ 真值表验证结果,要求用表格记录
  - ◆ 波形验证结果,要求记录在坐标纸上,记录的时候注意多路波形之间的时序关系
  - ◇ 功能验证结果,要求用表格记录
- 3. 实验报告必须在指定时间完成并提交

# 实验教学计划

| 周次         | 内容          | 实验模式      | 学时 | 教材  |
|------------|-------------|-----------|----|-----|
| 06         | 门电路组合逻辑     | 网络授课 虚拟仿真 | 3  | 第2章 |
| 07         | 中规模组合逻辑     | 网络授课      | 3  | 第3章 |
| 08         | 17. 观快组日之4  | 虚拟仿真      | 3  | カリ早 |
| 09         | 仪器使用        | 集中授课      | 3  | 第1章 |
| 10         | 脉冲信号测量      | 集中授课      | 3  | 第1章 |
| 11, 12, 13 | 时序逻辑电路      | 集中授课      | 9  | 第4章 |
| 14         | 可编程数字系统设计基础 | 集中授课      | 3  | 第7章 |
| 15         | 可编程小系统设计    | 集中授课      | 3  | 第7章 |
| 16         | 期末考试        | 集中上课      | 3  |     |

# 评分和考核方法

本课程最终成绩由平时实验成绩、和期末考试成绩组成。其中期末考试采取给定电路参数,设计并搭试电路的模式。具体成绩组成如下:

| 实验名称        | 各实验环 | 占总成绩 |      |     |
|-------------|------|------|------|-----|
| <u> </u>    | 预习预搭 | 实验验收 | 实验报告 | 比例  |
| 仪器使用        | 0%   | 60%  | 40%  | 5%  |
| 脉冲信号测量      | 0%   | 60%  | 40%  | 5%  |
| 门电路组合逻辑     | 20%  | 60%  | 20%  | 10% |
| 中规模组合逻辑     | 20%  | 60%  | 20%  | 10% |
| 时序逻辑电路      | 20%  | 60%  | 20%  | 25% |
| 可编程数字系统设计基础 | 20%  | 60%  | 20%  | 10% |
| 可编程小系统设计    | 20%  | 60%  | 20%  | 15% |
|             | 期末考试 |      |      | 20% |

# 注: 期末卷面成绩低于 45 分,总成绩不及格

# 本学期开放时间安排

1. 开放实验时间

| $\diamond$     | 周一 | $14:00 \sim 21:00$ |
|----------------|----|--------------------|
| $\diamond$     | 周二 | 09:30 $\sim$ 21:00 |
| <b></b>        | 周三 | 09:30 $\sim$ 21:00 |
| $\diamond$     | 周四 | 09:30 $\sim$ 21:00 |
| <b></b>        | 周五 | $09:30 \sim 16:30$ |
| $\diamondsuit$ | 周六 | $09:30 \sim 16:30$ |

- 2. 法定假期和校历规定的假期,实验室不开放
- 3. 开放时间临时变更,将在实验中心主页上提前通知,来实验室前最好访问实验中心主页确认是否开放

# 课程准备事项

在第3次实验课前,每位同学必须完成以下准备工作

# 准备导线

面包板搭试电路时,使用的是直径为 0.6mm 左右的单股导线。在课程开始前,请按下表准备好导线,所有导线两侧线头都要剥好,线头剥离长度约为 6mm 左右,线头剪成 45° 斜口。这样有利于线头全部插入底板以保证接触良好,同时裸线又不会露在外面与其它导线断路。表格内的线长**不包含两边线头的长度**,也可自行从市场上购买成品面包板用跳线,如下图所示。

第一次上课时,指导老师将检查导线准备情况,检查结果计入第一次实验的预习成绩。

| 线长 (mm) | 数量 |
|---------|----|
| 2.5     | 6  |
| 5       | 6  |
| 7.5     | 6  |
| 10      | 4  |
| 20      | 4  |
| 50      | 4  |



## 准备面包板

我们实验主要通过面包板完成电路搭试,在首次实验课前,请按下图所示连接好跳线。请根据面包板的 结构,自己分析一下,这样的跳线有什么好处。

第一次上课时,指导老师将检查面包板准备情况,检查结果计入第一次实验的预习成绩



# 准备工具

为了提高实验效率,我们建议自备以下实验工具:

**剥线钳:** 用于剥除电线头部的表面绝缘层,常用的剥线钳有两种,如图所示,两种功能基本相同,下面的那种更省力些。剥线钳使用时要掌握以下要点:



- 1. 根据导线直径,选好剥线钳刀片的孔径。
- 2. 根据缆线的粗细型号,选择相应的剥线刀口
- 3. 将准备好的电缆放在剥线工具的刀刃中间,选择好要剥线的长度
- 4. 握住剥线工具手柄,将电缆夹住,缓缓用力使电缆外表皮慢慢剥落
- 5. 松开工具手柄,取出电缆线,这时电缆金属整齐露出外面,其余绝缘塑料完好无损





**镊子:** 我们平时搭电路时,如果用手直接拿住导线往插孔里插,很容易造成导线弯曲,而用镊子夹住导线或元器件的引脚送入到指定的面包板插孔,导线则不易弯曲。镊子也常用于折弯、捋直导线或元件管脚,起拔集成电路等。镊子的种类很多,我们实验中一般选择左图所示的尖头镊子。

**剪刀或斜口钳:** 用来剪断导线、元件脚,其中斜口钳切断能力要比剪刀强很多,剪切不费力。斜口钳剪线时,应将线头朝向下,以防止断线时伤及眼睛或其他同学,不要用来剪断铁丝或其他金属的物体,也不要用来剪线径过粗的导线,以免损伤刃口。斜口钳在很多场合也可以用指甲钳代替。





**DIP 封装集成电路起拔器:** 用于将双列直插封装的集成电路从面包板上取下,同时不损伤器件。使用时,将起拔器的两个爪,插入到集成电路的两侧,然后握紧夹子,轻轻上提将集成电路拔出。无该工具时,可用镊子代替将镊子插入面包板的中间槽中,在集成电路的两头来回轻轻地往上撬,切不可仅在一头用力撬,那样容易将集成电路的引脚折弯。

# 下载并安装相关软件

数字逻辑设计实践课程要用到的软件包括电路仿真软件 Multisim 2012, Intel 公司 FPGA 开发平台 Quartus II。为了方便大家使用,实验中心提供了 Virtual Box 虚拟机镜像文件,该镜像文件中已经安装好所 有需要的软件,只要安装 Virtual Box 虚拟机软件并加载该镜像文件即可使用。请自行到实验中心网站(仅支持校内)、百度网盘下载,或上课时到指导老师处拷贝。

1、 Multisim 2012 (文件大小 552M) 校内网盘下载 百度网盘下载 (密码: fhcf)

2、 Quartus 9.1 sp2 Web Edition 校内网盘下载 Intel 网站下载

3、fritzing.0.9.3b 64bit: 校内网盘下载

4、 fritzing.0.9.3b 32bit: 校内网盘下载

# 预习报告样例

# 实验内容

人类有四种主要血型: A, B, AB和O型。为了避免输血反应,输血者和受血者之间要遵循下列原则:

- ◆ 同一血型之间可以相互输血。
- ◆ AB型受血者可以接受任何血型的输血。
- ◆ O型输血者可以给任何血型的受血者输血。

# 实验设计方案

## 输入、输出信号编码

输入信号: 用二位二进数  $G_1$ 、 $G_0$ 代表输血者的 4 种血型, $R_1$ 、 Ro代表输血者的4种血型,编码代表的具体意义如下表所示 输出信号: S 代表是否满足输血/受血条件, "1"满足, "0"不满足

|       | 输血    | L者   | 受血者   |       |      |  |
|-------|-------|------|-------|-------|------|--|
| $G_1$ | $G_0$ | 血型   | $R_1$ | $R_0$ | 血型   |  |
| 0     | 0     | O型   | 0     | 0     | O型   |  |
| 0     | 1     | A 型  | 0     | 1     | A 型  |  |
| 1     | 0     | B型   | 1     | 0     | B型   |  |
| 1     | 1     | AB 型 | 1     | 1     | AB 型 |  |

表 1 输入输出信号编码

## 列出真值表

根据题目要求,列出真值表

| G1 | G0 | R1 | R0 | S | G1 | G0 | R1 | R0 | S |
|----|----|----|----|---|----|----|----|----|---|
| 0  | 0  | 0  | 0  | 1 | 1  | 0  | 0  | 0  | 0 |
| 0  | 0  | 0  | 1  | 1 | 1  | 0  | 0  | 1  | 0 |
| 0  | 0  | 1  | 0  | 1 | 1  | 0  | 1  | 0  | 1 |
| 0  | 0  | 1  | 1  | 1 | 1  | 0  | 1  | 1  | 1 |
| 0  | 1  | 0  | 0  | 0 | 1  | 1  | 0  | 0  | 0 |
| 0  | 1  | 0  | 1  | 1 | 1  | 1  | 0  | 1  | 0 |
| 0  | 1  | 1  | 0  | 0 | 1  | 1  | 1  | 0  | 0 |
| 0  | 1  | 1  | 1  | 1 | 1  | 1  | 1  | 1  | 1 |

表 2 实验真值表



图 2 卡诺图

### 逻辑化简

根据真值表画出卡诺图,如图 2 所示,化简得到与或非表达式如式 1,考虑到只有与非门器件,转化,得 到与非表达式 2。

$$S = \overline{\overline{G_1}} \overline{G_0} + \overline{\overline{G_1}} R_0 + \overline{\overline{G_0}} R_1 + R_1 R_0$$

$$S = \overline{\overline{\overline{G_1}} \overline{\overline{G_0}}} \bullet \overline{\overline{\overline{G_1}} R_0} \bullet \overline{\overline{\overline{G_0}} R_1} \bullet \overline{\overline{R_1} R_0}$$
(2)

$$S = \overline{\overline{G_1}} \overline{\overline{G_0}} \bullet \overline{\overline{G_1}} R_0 \bullet \overline{\overline{G_0}} R_1 \bullet \overline{R_1} R_0$$
 (2)

#### 逻辑电路图

根据逻辑函数表达式(1),绘制出电路原理图如图3所示(反变量所需的非门未画出),其中输入信号的 原变量从实验箱上的逻辑电平开关获得,反变量需要另外接非门来实现。

### 硬件连接示意图

根据电路原理图,查询教材附录"常用集成电路型号和引脚图",可知,硬件电路需要4个两输入与非门,

可以选择 1 片 74HC00 实现;需要 1 个四输入与非门,可以选择 1 片 74HC20 实现。硬件连接示意图如图 4 所示,并将管脚分配反标注到电路原理图中。也可利用 Fritzing 软件绘制硬件连接示意图,Fritzing 软件的具体使用方法参看附录一。



图 5 用 Fritzing 软件绘制的硬件连接图

# 测试方案

4 个输入信号,用实验箱上的逻辑电平开关实现,1 个输出端连接到实验箱上的 LED,按照真值表的要

求,拨动逻辑电平开关改变输入信号值,遍历 16 种输入组合,并观察输出信号值,输出 LED 亮则输出为 1,灭则输出为 0,将测试结果填入表 3。

| G1 | G0 | R1 | R0 | S | 测试<br>结果 | G1 | G0 | R1 | R0 | S | 测试<br>结果 |
|----|----|----|----|---|----------|----|----|----|----|---|----------|
| 0  | 0  | 0  | 0  | 1 |          | 1  | 0  | 0  | 0  | 0 |          |
| 0  | 0  | 0  | 1  | 1 |          | 1  | 0  | 0  | 1  | 0 |          |
| 0  | 0  | 1  | 0  | 1 |          | 1  | 0  | 1  | 0  | 1 |          |
| 0  | 0  | 1  | 1  | 1 |          | 1  | 0  | 1  | 1  | 1 |          |
| 0  | 1  | 0  | 0  | 0 |          | 1  | 1  | 0  | 0  | 0 |          |
| 0  | 1  | 0  | 1  | 1 |          | 1  | 1  | 0  | 1  | 0 |          |
| 0  | 1  | 1  | 0  | 0 |          | 1  | 1  | 1  | 0  | 0 |          |
| 0  | 1  | 1  | 1  | 1 |          | 1  | 1  | 1  | 1  | 1 |          |

表 3 实验结果测试记录表

# 电路搭接调试方法样例

我们以教材 1.8 节电路为例,来介绍如何正确搭接和调试电路,实验电路如图 1 所示:

# 分析电路

分析可知,图中包含了3个2输入与非门、1个非门、1个3输入与非门,查询教材附录"常用集成电路型号和引脚图",可知需要用到以下器件

- **♦** 7400
- 2输入与非门
- **♦** 7404
- 非门
- **♦** 7420
- 4输入与非门



# 合并器件

图 1 实验电路原理图

为了减少所用器件种类,可以根据门电路特点,合并一些门,其中非门可以用 2 输入与非门代替,有以下两种方法,如图 2 所示。因为没有 3 输入与非门,可以用 4 输入与非门代替 3 输入与非门,常用的也有两种方法,如图 3 所示,经过合并后的电路如图 4 所示



图 2 非门的常用替换方法

图 3 输入与非门常用替换方法



图 4 合并后的电路原理图

# 查询数据手册

集成电路的数据手册给出了芯片的所有参数指标以及使用方法,熟练阅读数据手册是一个电子设计人员的必备技能。数据手册的获取途径包括:

- ◇ 芯片制造商的官方网站
- ◆ 专门的 Datasheet 下载网,例如 <a href="http://www.alldatasheet.com/">http://www.icpdf.com/</a>
- ◆ 直接用网络搜索引擎,如 Google、Baidu等
- ◆ 为了提高搜索准确度,最好在搜索的关键词后面加上 pdf, 如搜索 "74HC00"的数据手册,可用关键词 "74HC00"pdf"

通过查询数据手册,可知74HC00和74HC20的元件符号和管脚封装如图5和图6所示。



图 5 74HC00 4-2 输入与非门



图 5 74HC20 2-4 输入与非门

# 根据数据手册选择器件,分配管脚

根据数据手册的器件功能和管脚排列,合理分配逻辑门和管脚,然后在原理图上加上文字说明及数字标号,作为实验接线的依据。如图 6 所示。U1 代表 7400, U2 代表 7420。在每个门的输入、输出端标注所用的器件的引脚号。



图 6 己标注管教的电路原理图

# 元件布局

元器件布局要合理,信号流清晰,连线便捷,集成电路跨插在宽条面包板的凹槽上,两排引脚分别插在凹槽上下两侧的小孔中。插入集成电路之前先看清方向,一般使芯片缺口在左边,芯片第一脚在左下方。插入前微调管脚的角度,使管脚和集成电路本体之间呈近90度,所有管脚对准面包板对应孔位,然后均匀用力按下,确保芯片引脚能与面包板内的金属条可靠接触。如图7所示。



图 7 元件布局

## 布线

布线时使用直径为 0.6mm 左右的单股导线,使用前要用剥线钳剥离导线两侧线头,线头剥离长度约为 6mm 左右,线头剪成 45°斜口。布线要求走线整齐,清楚,切忌混乱,电源、地和信号尽量使用不同颜色的导线,以示区别。导线应在集成电路芯片周围走线,切忌在集成块上方悬空跨过避免导线之间的互相交叉重叠,也不要过多地遮盖其他插孔,所有走线尽可能贴近面包板表面

在合理布线的前提下,导线尽可能短些布线顺序一般为先布电源线和地线,再布固定电平的规则线,最后按照信号流程逐级连接各逻辑控制线。

1、 **布电源线:** 7400 和 7420 的 14 脚是电源脚,用导线将 14 脚连接 5V 电源,如图 8 中红线所示



图 8 布电源线

2、 **布地线**: 7400 和 7420 的 7 脚是地线脚,用导线将 7 脚连接电源地线,如图 9 中黑线所示



图 9 布地线

3、 **布固定电平线:在**设计中有两个固定电平管脚,分别为 U1 的 12 脚和 U2 的 5 脚,要求置"1",可将这些管脚直接和 5V 电源相连,如图 9 所示。如要求是置"0",则可将这些管脚和电源地相连。



图 9 布地线

4、 **布信号线**:按信号流向布线,先布最左侧的线,如图 10 所示所示;再布中间的线,如图 11 所示,最后布最右侧的线,如图 12 所示



图 12 布最右侧信号线

5、 **连接输入信号**,将输入信号 A、B、C、D 对应管脚,用一头直一头弯的丁字线,与实验箱上的逻辑 电平开关连接,如图 13 所示



6、 连接输出信号,将输出 Y 对应管脚,同样用丁字线,与实验箱上发光二极管连接,如图 14 所示

# 通电前检查

在通电验证前,必须仔细检查,主要包括

- ◆ 集成芯片是否选择正确,方向是否插对,引脚有无折弯、互碰情况
- ◆ 集成电路多余输入端处理是否正确,是否有两个以上输出端错误地连在一起
- ◆ 布线是否合理,是否有相碰短路现象
- ◆ 电源线与地线在内的连线是否有漏线与错线
- ◆ 用万用表"欧姆×10"挡,测量实验电路的电源端与地线端之间的电阻值,排除电源与地线的短路现象
- ◆ 用万用表的"直流电压挡"测量直流稳压电源输出电压是否为所需值

## 通电验证

接通电源,根据真值表,按顺序,拨动逻辑电平开关,改变输入值从"0000"到"1111",观察输出 LED 指示, LED 灭则输出"0", LED 亮则输出"1"。记录测试结果。

## 故障调试

如果测试该电路时,某种输入下的输出与理论分析有悖,则要排除故障。排除故障的第一步是要确定<mark>集成电路上所加的电源电压是否正确</mark>,可以用万用表的直流电压档测量。可靠的检查方法是如图 15 (a) 那样,用万用表的测试表笔直接测量集成芯片电源端和地线两引脚之间的电压。这种方法可以检查出断线、引线虚接、因芯片管脚折断或折弯而未能插入实验底板的情况。图 15 (b) 中的测量方法,虽然能判断出电源是否已经接到面包板的窄条上,但如果从窄条接到集成电路管脚的连线有问题或者集成电路没有插好,集成电路还是不能正常工作。



(a) 正确的电源测量方法



(b) 错误的电源测量方法

图 15 用万用表测量电源电压

对于组合电路,可根据逻辑表达式或真值表由前向后逐级检查。但 更快的检查方法,应该是由后向前逐级检查。测试方法是用万用表测量 每个节点的电压。 测量的时候一定要注意尽量**直接测量集成电路的管脚** 上的电压,理由和前面测电源电压一样。

为了方便调试节点电压,我们在面包板上,用单股导线将黑色接线柱和绿色或黄色接线柱连接起来,如图 16 所示。这样在用万用测量节点电压的时候,可以空出一只手出来。



图 16 连接黑色和黄色接线柱

# 故障举例:

## 故障现象

输入逻辑开关 "ABCD" 置在 "0011" 状态,根据真值表,输出应为 "0",即逻辑电平指示灯应该灭,实际输出逻辑电平指示灯是亮,即输出为 "1",电路存在故障。

## 排除故障

用万用表从后向前测各点的电平并与理论值比较

1、 测量最后一级 2 输入与非门(U1-3)

#### 理论分析:

- ◆ 输出 U1-38 脚应为"0"
- ◆ 输入 U1-3 的 9、10 脚应为"1"

#### 万用表实测

- ◆ U1-9 脚对地电压,约为 5V,等效逻辑"1",信号正确
- ◆ U1-10 脚对地电压,约为 OV ,等效逻辑"O" ,信号错误

## 结论

◆ 因为 U1-10 脚连接到 4 输入与非门输出( U2-1 6 脚),排查 U2-1

## 2、 排查 4 输入与非门 U2-1

### 理论分析

- ◆ 如 U2-6 脚为 "1",则 U2-6 脚和 U1-10 之间的连线有问题
- ◆ 如 U2 6 脚为 "0",则需检查 U2-1 的 4 个输入信号
- ◆ 根据原理图, U2-1、2、5 脚应为都"1", 4 脚应为 "0"

## 万用表实测

- ◆ U2-1、 2、 5 脚对地电压,约为 5V,等效逻辑"1",信号正常
- ◆ U2-4 脚对地电压,约为 0~1V,等效逻辑 "X",信号错误

### 结论

- ◆ 因为 U2-4 脚信号连接到 2 输入与非门输出(U1-4 11 脚), 需排查 U1-4
- 3、 排查 2 输入与非门 U1-4

### 理论分析

- ◆ 如 U1- 11 脚为 "0", 则 U1-11 脚和 U2-4 脚之间的 连线有问题
- ◆ 如 U1- 11 脚为 "1",则需检查 U1-4 的 2 个输入信号

#### 万用表实测

◆ U1-11 脚对地电压,约为 OV,等效逻辑"O",信号 正常

#### 结论

◆ U1-11 脚和 U2-4 脚之间的连线有问题



**U2-1** 

&



# 实验一 门电路组合逻辑

## 学习目标:

- 1. 认识数字集成电路,能识别各种类型的数字器件和封装
- 2. 掌握小规模组合逻辑的工程设计方法
- 3. 学习 Mulitisim 逻辑化简操作和使用方法
- 4. 学习基本的数字电路的故障检查和排除方法

## 时间要求:

- 1. 实验时间:第6周
- 2. 报告提交:第7周课内

# 预习要求

- 1. 预习实验教材第1章、第2章和本实验内容相关的知识
- 2. 查看 74HC00、74HC20、74HC01(或 74HC03)、74HC244 数据手册,掌握器件功能,了解管脚分布
- 3. 第 6 周课前完成"数值判别电路"、"数字密码锁"的电路设计,将设计方案、原理图、硬件连接示意图 (可用 Fritzing 画)写在实验报告的原理部分,并完成"数值判别电路"和"数字密码锁"的电路搭接
- 4. 学习利用 Multisim 软件实现自动逻辑化简

电子电路仿真软件已经深入到了电子设计的每个环节,大量传统的理论计算,都可以用仿真软件来实现。 在实际工作中,数字电路的设计绝大部分都是通过计算机软件辅助实现的。Multisim 是电路仿真软件的一种,它可以对模拟电路和数字电路进行精确仿真。在这里我们介绍 Multisim 软件中的逻辑转换器功能,它可以将分析好的真值表转换成逻辑表达式和电路原理图,将我们从繁重的电路化简工作中解脱出来。



图 1 Multisim 界面



图 2 逻辑转换器

打开 Multisim 软件,如图 1.1 所示,在菜单栏中选择 Simulate→Instruments→Logic Converter 菜单项打开如图 1.2 所示的仪器,双击,打开图 1.3 所示的界面。以前面预习报告样例中的血型配对为例,有四个输入变量,用鼠标点击,选中 A、B、C、D 四个输入,显示从"0000"到"1111"16 个值,在右侧用鼠标点击对应行的输出,按要求设置成 0、1 或 x。点击右侧 按钮,可以将真值表转换成最小项。点击 按钮,则可以将真值表转换成最简与或表达式。转换结果显示在逻辑转换器底部窗口中,化简结果"A'B'+A'D+B'C+CD"和用卡诺图化简的结果是一样的。点击 按钮,可以自动生成与

或电路如图 1.4 所示,点击 按钮,可以自动生成与非电路如图 1.5 所示。注意,自动生成的电路图,都是 2 输入门。





图 3 真值表输入界面

图 4 自动生成的与或电路图



图 5 自动生成的与非电路图

### 1. 参考资料:

- "如何读懂数字逻辑器件数据手册" (pdf 文档)
- "Multisim 软件使用手册" (pdf 文档)

## 预习要求

- 1. 第6周课前完成必做实验电路设计,撰写预习报告
- 2. 完成"数值判别电路"的电路虚拟面包板搭接(参看附录一 fritzing 软件说明)
- 3. 如果有余力也可完成内容 2 设计及电路虚拟面包板搭接(参看附录一 fritzing 软件说明)

## 必做实验

## 1. 数值判别电路(第6周实验,课内验收)

- 1) 用门电路设计一个组合逻辑电路,接收 8421BCD 码 B<sub>3</sub>B<sub>2</sub>B<sub>1</sub>B<sub>0</sub>, 当 2 < B<sub>3</sub>B<sub>2</sub>B<sub>1</sub>B<sub>0</sub> < 7 时输出 Y 为 1
- 2) 用门电路设计一个组合逻辑电路,接收 4 位 2 进制数 B<sub>3</sub>B<sub>2</sub>B<sub>1</sub>B<sub>0</sub>, 当 2 < B<sub>3</sub>B<sub>2</sub>B<sub>1</sub>B<sub>0</sub> < 7 时输出 Y 为 1

#### 2. 保险箱数字密码锁(选做实验,第6周实验课内验收,选做加分)

设计一个保险箱的数字密码锁,该锁有规定的 4 位代码  $A_1$ ,  $A_2$ ,  $A_3$ ,  $A_4$  的输入端和一个开箱钥匙孔信号 E 的输出端,锁的代码由实验者自编(例如 1011),当用钥匙开箱时(E=1),如果输入代码符合锁规定代码,保险箱被打开( $Z_1=1$ );如果不符,电路将发生报警信号( $Z_2=1$ )。要求使用最少数量的与非门实现电路,检测并记录实验结果。

# 实验二 中规模组合逻辑

## 学习目标

- 1. 掌握常用中规模组合逻辑器件的功能和使用方法;
- 2. 掌握逻辑函数工程设计方法;
- 3. 了解存储器实现复杂逻辑函数的原理和存储器的使用过程。

## 时间要求:

- 1. 实验时间: 第7、8周
- 2. 报告提交: 第9周课内

# 预备知识

实验教材:第3章

# 预习要求

- 1. 第7周课前完成必做实验1电路设计和虚拟面包板搭接(fritzing 软件实现),撰写预习报告
- 2. 第8周课前完成必做实验2、3电路设计和虚拟面包板搭接(fritzing 软件实现),撰写预习报告

# 必做实验

- 1. 设计一个3位二进制原码转补码电路,用三种方案实现(第7周检查预习,课内验收)
  - 1) 全部用门电路实现
  - 2) 用数据选择器 74151+门电路实现
  - 3) 用三八译码器 74138+门电路实现
  - 4) 提示: 异或逻辑可以直接选用 7486

注意: 不考虑符号位, 默认为 0 和负数, 异或逻辑可以直接选用 7486

2. 血型配对(必须用数据选择器实现,第8周检查预习,课内验收)

人类有四种血型: A、B、AB和O型。输血时,输血者与受血者必须符合下图的规定,否则有生命危险,利用数据选择器和最少数量的与非门,完成血型配对任务。(设计方案可参看数字逻辑电路实践教材 Page 86)



3. 发电机控制器(必须用译码器实现,第8周检查预习,课内验收)

设有三台用电设备 A、B、C 和两台发电机组 X、Y。X 机组功率为 10kW,Y 机组功率为 20kW。用电设备 A 用电量为 15kW,设备 B 用电量为 10kW,设备 C 用电量为 5kW,三台用电设备有时同时工作,有时只有其中部分设备工作,甚至均不工作。试用 3-8 译码器设计一个供电控制电路控制发电机组,以达到节电的目的。(设计方案可参看数字逻辑电路实践教材 Page 83)

# 选做实验

- 1. 用 MSI 器件设计 2 位全加器
- 2. 3.5 节实验: 用 ROM 设计组合逻辑函数电路

# 实验三 仪器使用

# 学习目标

- 1. 认识正弦信号及参数;
- 2. 学习阅读仪器说明书;
- 3. 掌握信号源和示波器的使用方法:
- 4. 掌握示波器测量波形参数的基本方法。

## 时间要求:

- 1. 实验时间:第9周
- 2. 报告提交:第10周课内

# 实验预习

1. 了解正弦波信号、交直流叠加信号的参数定义:



图 1 正弦波信号的参数定义

图 2 交直流叠加信号的参数定义

- 2. 学习《数字逻辑电路设计实践》第一章相关内容和仪器说明书,学习示波器的使用方法
  - 1) 了解面板上各按钮及旋钮的作用,各菜单的设置方法;
  - 2) 了解探头的作用及使用方法;
  - 3) 了解探头补偿,探头上衰减开关的作用及使用注意事项;
  - 4) 了解示波器垂直通道 DC 和 AC 耦合方式的区别, 及如何选择正确的耦合方式;
  - 5) 了解示波器触发,触发边沿、触发源、触发电平的基本概念
- 3. 了解函数/任意波形发生器的作用,查阅说明书,了解基本功能和使用方法。
  - 1) 了解面板上各按钮及旋钮的作用,各菜单的设置方法;
  - 2) 了解信号发生器与正弦波相关的参数和设置方法

# 必做实验

1. 观察你使用的示波器面板,并填写下表

表 1 示波器参数

| 示波器厂家 | 示波器型号 | 示波器带宽 | 最大实时采样率 |
|-------|-------|-------|---------|
|       |       |       |         |
|       |       |       |         |

## 2. 检查示波器及探头

- 1) 认识示波器前面板各按钮及名称。( *鼎阳示波器* 30 页; 固纬示波器 15-20 页)
- 2) 将机内的补偿信号输入到 CH1 通道,在示波器屏幕上观察该信号,检查是否需要探头补偿? (*鼎阳示波器 26-29 页: 固纬示波器 26-28 页*)
- 3) 将示波器探头切换到"X10",检查是否需要探头补偿。

### 3. 测量示波器校准信号(补偿信号)

测量机内校准(补偿)信号,将测量值记录到表 2(**老师验收**),三种方法测的波形图要保存到 U 盘,打印后,作为波形数据贴在实验报告中。

| 测量 方法 | 峰峰值    |        | 高电平电压   |        | 低电平电压  |         | 周期     |        |         | 频率     |    |         |  |
|-------|--------|--------|---------|--------|--------|---------|--------|--------|---------|--------|----|---------|--|
| 1     | 档<br>位 | 格<br>数 | 计算<br>值 | 档<br>位 | 格<br>数 | 计算<br>值 | 档<br>位 | 格<br>数 | 计算<br>值 | 档<br>位 | 格数 | 计算<br>值 |  |
| 1     |        |        |         |        |        |         |        |        |         |        |    |         |  |
| 2     |        |        |         |        |        |         |        |        |         |        |    |         |  |
| 3     |        |        |         |        |        |         |        |        |         |        |    |         |  |

表 2 机内补偿信号的测量

### 用数字示波器测量电压峰峰值、高电平、低电平的三种方法:

- 1) 在屏幕上先读出波形垂直所占格数或水平所占格数,然后用"格数×档位(V/DIV, S/DIV)"方式计算相应电压或时间(鼎阳说明书32-35页,44-51页,52-55页,多功能旋钮36页。固纬说明书36-42页,950101页水平视图,102-109页垂直视图,131页触发。);
- 2) 按下 "Measure"按钮,调出菜单,在显示屏上读数(鼎阳说明书154页,固纬说明书43页);
- 3) 用光标 "Cursor"来测量(鼎阳说明书145页,固纬说明书55页)。

## 4. 叠加在直流上的正弦波的测试



图 3 叠加在直流上的正弦波

1) 调节函数发生器,产生如图 3 所示叠加在直流上的正弦波信号,其中直流分量为 1V,交流分量峰 峰值为 4V,信号频率为 500Hz;

2) 用示波器测出信号的相关参数,其中用示波器测量交流分量的有效值时,通道耦合方式选择 AC。测量数据填入表 3 中。(**老师验收**)

|       |      | *** = :::: = :::: |     |    |       |  |  |  |  |
|-------|------|-------------------|-----|----|-------|--|--|--|--|
| 使用仪器  | 直流分量 | 交流分量              |     |    |       |  |  |  |  |
|       | 且机刀里 | 峰峰值               | 有效值 | 周期 | 频率    |  |  |  |  |
| 函数发生器 | 1V   | 4V                |     |    | 500Hz |  |  |  |  |
| 示波器   |      |                   |     |    |       |  |  |  |  |

表 3 叠加在直流上的正弦波测量数据

## 实验结果分析:

- 1. 在这个实验中我们为什么不能选择 AC 输入耦合方式,如果选择了 AC 输入耦合方式,测得的峰峰值、低电平电压、高电平电压各会有什么变化。
- 2. 若示波器提供的标准信号是 f=1kHz, Upp=3V 的方波, 假设示波器的读数误差为±0.1 格, 试计算示波器扫描速率取 2ms、1ms、0.5ms、0.2ms 时测量的相对误差是多少?并分析自己在测试中选择的扫描速率是否合适。
- 3. 总结一下示波器测量机内补偿信号的基本步骤和注意要点。

# 实验注意事项:

- 1. 用"格数×档位(V/DIV)"方式测量信号高、低电平时的步骤:
  - 1) 将信号从某个通道输入
  - 2) 将耦合方式调节到 DC 耦合
  - 3) 调节电压档位开关使得波形上下展开
  - 4) 调节上下位移旋钮使通道标记固定于某个标尺上,参考标尺读出高、低电平等电压值。

#### 2. 探头故障检测

示波器的探头线接入波形以后,如果出现的是扫描线或者干扰杂波信号,最常见的是示波器探头和连接电缆损坏,此时应首先检查探头。探头故障绝大部分是地线接触不良或断开。测量一根探头是否已经损坏可按以下步骤进行:

- 1) 示波器输入耦合选择 AC 或 DC, 电压灵敏度旋钮设置到 500mv/DIV 或者更灵敏的档位:
- 2) 用手指接触探头的尖端,如果有杂波出现则探头的信号线连接正常,如果显示的仍然是一条直线的话,则说明信号线可能开路了;
- 3) 如果 2 正常,再将探头的信号线和地线短接,再用手指接触探头的尖端,如果示波器上显示的是一条水平线,说明探头的地线正常,反之如果有很多杂波出现,说明探头的地线可能开路了;
- **4)** 有时探头和电缆本身是好的,但是电缆和示波器的连接处接触不良,可以试着用手扶着连接处,重复上述测试。

# 实验四 脉冲信号测量

# 学习目标

- 1. 认识脉冲信号及其主要参数;
- 2. 掌握用示波器测量脉冲信号的基本方法;
- 3. 掌握稳压电源和万用表的使用方法;

# 时间要求:

- 1. 实验时间:第10周
- 2. 报告提交:第11周课内

# 实验预习



图 1 脉冲信号的参数定义

- 1. 学习教材第 1.2 章相关内容,了解脉冲信号的主要参数;
- 2. 了解示波器测量脉冲信号的基本方法和测量注意事项;
- 3. 阅读稳压电源和万用表说明书,了解其基本功能和使用方法;

# 必做实验:

#### 

调节直流稳压电源 CH1 通道的电压为 5V, 保护电流为 10mA:

- 1) 用万用表测量并记录 CH1 输出电压;
- 2) 接图 2 连接电路,调节电位器,使稳压电源进入保护模式("CC"指示灯亮),用万用表再次测量 CH1 输出电压。



图 2 直流稳压电源设置

#### 2. TTL 脉冲信号测量

从信号源输出一个 TTL 脉冲信号到示波器的输入端。根据表 2 的要求完成实验,将测量结果记录在表中,每个实验的波形保存到 U 盘,打印后贴入实验报告中;

表 2 TTL 脉冲信号测量

| 信号源                |                    | 示波器        |               |                    |               |                |                |                     |                     |                    |                  |                  |
|--------------------|--------------------|------------|---------------|--------------------|---------------|----------------|----------------|---------------------|---------------------|--------------------|------------------|------------------|
| 频<br>率<br>(Hz)     | 占<br>空<br>比<br>(%) | 探头衰减       | 峰<br>峰<br>(V) | 高<br>电<br>平<br>(V) | 低<br>电<br>(V) | 周<br>期<br>(us) | 频<br>率<br>(Hz) | 正<br>脉<br>宽<br>(us) | 负<br>脉<br>宽<br>(us) | 占<br>空<br>比<br>(%) | 上升<br>时间<br>(ns) | 下降<br>时间<br>(ns) |
| 10×10 <sup>3</sup> | 50                 | "×1" "×10" |               |                    |               |                |                |                     |                     |                    |                  |                  |
| 1×10 <sup>6</sup>  | 50                 | "×1"       |               |                    |               |                |                |                     |                     |                    |                  |                  |
|                    |                    | "×10"      |               |                    |               |                |                |                     |                     |                    |                  |                  |

#### 3. 竞争和冒险现象观察

接图 3 连接电路,A 端输入 100kHz TTL 脉冲信号,用示波器观察输入信号 A 和输出信号 Y,测量 Y 输出"毛刺"的宽度,分析毛刺产生的原因



图 3 竞争和冒险测量电路

#### 测量注意事项:

1) Measure 方法测量脉冲信号电压参数时,如果脉冲信号有过冲或下冲,则不可以直接读取"最大值"、"最小值"和"峰峰值",而应读取"顶部(高)值"、"底部(低)值"和"幅度值",同时"顶部(高)值"和"底部(低)值"测量模式应该选择柱状图模式,该模式跳过过冲和下冲电压值,尤其适合脉冲类波形;



图 3 示波器有关电压参数的定义

2) 为了能准确测量上升和下降时间,可以调节水平扫描速率,将波形尽量展开一些。

## 实验结果分析讨论要点:

- 1) 比较探头 X1 和 X10 模式下上升和下降时间测量结果的差别,判断哪个结果是正确的并分析原因
- 2) 比较频率相同,占空比不同的脉冲信号波形的区别
- 3) 根据实验总结用示波器测量脉冲信号的基本步骤和注意点

# 实验五 时序逻辑电路

## 学习目标

- 1. 掌握时序逻辑电路的一般设计过程;
- 2. 掌握时序逻辑电路的时延分析方法,了解时序电路对时钟信号相关参数的基本要求;
- 3. 掌握时序逻辑电路的基本调试方法;
- 4. 熟练使用示波器或逻辑分析仪观察波形图,并会使用逻辑分析仪做状态分析。

## 时间要求:

- 1. 实验时间: 第11、12、13周
- 2. 报告提交:第14周课内

## 预备知识

1. 实验教材: 第4章

## 预习要求

- 1. 广告流水灯的设计方案、原理图、搭接(第11周)
- 2. 序列发生器设计方案、原理图、搭接(第12周)
- 3. 4位并行输入-串行输出曼切斯特编码设计方案、原理图(第12周)
- 4. 4位并行输入-串行输出曼切斯特编码电路搭接(第13周)

## 必做实验

### 1、广告流水灯(第11周课内验收)

用触发器、组合函数器件和门电路设计一个广告流水灯,该流水灯由8个LED组成,工作时始终为1暗7亮,且这一个暗灯循环右移。

- 1) 写出设计过程, 画出设计的逻辑电路图, 按图搭接电路
- 2) 将单脉冲加到系统时钟端,静态验证实验电路
- 3) 将 TTL 连续脉冲信号加到系统时钟端, 用示波器观察并记录时钟脉冲 CP、触发器的输出端 Q2、Q1、Q0 和 8 个 LED 上的波形。

#### 2、序列发生器 (第12周课内实物验收)

分别用 MSI 计数器和移位寄存器各设计一个具有自启动功能的 01011 序列信号发生器

- 1) 写出设计过程,画出电路逻辑图
- 2) 搭接电路,并用单脉冲静态验证实验结果
- 3) 加入 TTL 连续脉冲,用示波器观察观察并记录时钟脉冲 CLK、序列输出端的波形。
- 3、4位并行输入-串行输出曼切斯特编码电路(第13周课内验收,基础要求占70%,扩展要求占30%)



图 1 曼切斯特编码

在电信与数据存储中,曼彻斯特编码(Manchester coding),又称自同步码、相位编码(phase encoding, PE),它能够用信号的变化来保持发送设备和接收设备之间的同步,在以太网中,被物理层使用来编码一个同步位流的时钟和数据。曼彻斯特编码用电压的变化来分辨 0 和 1,从高电平到低电平的跳变代表 0,而从低电平到高电平的跳变代表 1。信号的保持不会超过一个比特位的时间间隔。即使是 0 或 1 的序列,信号也将在每个时间间隔的中间发生跳变。这种跳变将允许接收设备的时钟与发送设备的时钟保持一致,图 1 为曼切斯特编码的例子。

设计一个电路,它能自动加载 4 位并行数据,并将这 4 位数据逐个串行输出(高位在前),每个串行输出位都被编码成曼切斯特码,当 4 位数据全部传输完成后,重新加载新数据,继续传输,如图 3.2 所示。

- 1) 写出设计过程,画出电路逻辑图,设计不允许手动加载数据。
- 2) 加入 TTL 连续脉冲,用示波器观察观察并记录时钟脉冲 CLK、串行数据输出端的波形。
- 3) 给串行数据增加起始位和结束位,其中起始位为"0",结束位为"1",起始和结束位同样要编码成 曼切斯特码,波形图参看图 3 (扩展部分,选作)



图 3 扩展功能波形

# 实验六 可编程数字逻辑设计基础

## 学习目标

- 1、 了解可编程数字系统设计的流程
- 2、 掌握 Quartus 软件的使用方法
- 3、 掌握竞争和冒险的基本概念和电路时延分析方法

# 时间要求

- 1、实验时间: 第 14 周
- 2、报告提交:第15周课内

## 预备知识

### 1、 关于 Quartus 软件

Quartus 是 Altera(现已被 Intel 收购)公司可编程逻辑器件开发平台,根据功能的不同,可分为订购版(15.1 版本后改为专业版和标准版)和网络版(15.1 后称为精简版),可以直接在 Intel 网站下载,其中网络版是免费的,只要注册即可下载使用。由于 Quartus 后期的版本后取消了内置仿真器,需要用硬件描述语言写 Testbench 调用第三仿真器,不太适合本学期实验。如需要在自己电脑上安装,建议大家下载安装 Quartus 9.1 sp2 Web 版,使用方法参看附录一和教材第 7 章。

#### 2、 逻辑电路时延分析方法

下面以 1 位半加器为例,介绍一下时序仿真和电路时延分析方法。半加器有 2 个输入 A、B,两个输出 S、C。

- 1) 点击工具条▶按钮,编译项目,生成 Compilation Report
- 2) 在右栏 Report 列表中,点击"TimeQuest Timing Analyze"→"Multicorner Datasheet"→"Progagation Delay"项,查看电路时延信息,如图 1 所示。
- 3) 以时延信息表第 2 行为例, RR=5.102ns 表示当输入 端口 A 从"0"→"1"(Rising)后 5.102ns, 输出端口"S" 从"0"→"1"(Rising);
- 4) RF=4.987ns 表示当输入端口 A 由"0" → "1"(Rising) 后 4.987ns,输出端口"S" 从"1" → "0"(Falling);同样可以得到 FR 和 FF 的值。



图 1 电路时延信息



图 2 输入激励信号

- 5) 新建"Vector Waveform File"设置输入激励文件,为了仿真全部功能,同时为了更方便的查看时延,输入激励文件中信号 A 可选用周期为 20ns 的时钟信号,B 选用周期为 40ns 的时钟信号,如图所示。
- 6) 选择"Processing"→"Simulator Tool"打开仿真工具界面,选择 Timing 仿真,打开仿真结果,右键点击波形区域,选择"Time Bar"→"Insert Time Bar"或者"Time Bar"→"Time Bar Organizer"增加两条"Time Bar"。如图所示。



图 3 仿真波形时延分析

- 7) 从图中可以看到,输入信号 A 从"0"→"1",输出信号 S 并不立刻变化,有一定的延迟。将两条"Time Bar" 轮流设为"Mater Time Bar",点击 → 使 Time Bar 1 卡在输 A 信号的第一个上升沿,Time Bar2 卡在输出 S 信号的第一个上升沿,可以测出,输入 A 从"0"→"1"后 5.102ns 输出 S 从"0"→"1",这和前面查看时延信息表得到的结果一致。
- 8) 从图中可以看到,当输入 BA 从"01" →"10"时,输出信号 S 出现了一个很短的低电平,输出 C 则出现了一个很短的高电平,这表明出现了竞争和冒险现象。BA 从"01" →"10"是两个信号同时变化,而从时延信息表可知 A→S 的 FR=5.183ns,B→S 的 RF=4.656ns,也就是说,由于 B 信号变化的快,B 因此"0"→"1",A 还未从"1"→"0",短时间输入端出现了"11"状态,根据逻辑函数,此时 S 输出 0,C 输出 1。等到 A 从"1"→"0"后,输入稳定为"10",根据逻辑函数,S 输出 1,C 输出 0。。用 g 中的方法我们可以测出 S 和 C 的毛刺宽度如图所示。





## 3、参考资料

- "Cyclone || 器件数据手册" (pdf 文档)
- "Cyclone III 器件数据手册" (pdf 文档)

## 预习要求

- 1、学习实验教材 2.9 节 "竞争和冒险现象";
- 2、学习实验教材第7章"可编程数字系统设计基础";
- 3、参考附录"Quartus II 使用简介",课前完成必做实验的设计方案,用 Quartus 原理图输入法完成必做内容的原理图绘制,并将设计文件拷贝带至实验室,上课前交由指导教师检查

# 必做实验

- 1. 观察并记录实验箱上的 FPGA 型号,新建一个 Project,器件选用实验箱上的 FPGA;
- 2. 用 "AND2"和 "XOR"器件设计一个 1 位半加器,并用功能仿真进行验证;
- 3. 点击 "File" → "Create/Update" → "Create Symbol File for Current File" 菜单项,将 1 位半加器封装成元件。新建一个原理图文件,调用 2 个半加器实现一个 1 位全加器,并用功能仿真进行验证;
- 4. 将 1 位全加器封装成元件,新建原理图文件,调用 4 个全加器实现一个 4 位行波加法器,用功能仿真进行验证,用 "Tools" → "Netlist Viewers" → "RTL Viewer" 查看电路综合结果;
- 5. 适配编译,用 "Tools" → "Netlist Viewers" → "Technology Map Viewer" 查看电路 Map 结果;用 "Tools" → "Chip Planner" 查看器件适配结果;
- 6. 将 4 位全加器下载到实验箱,连接逻辑电平开关进行功能验证(课内验收);
- 7. 对 1 位半加器,进行时序仿真,并做时延分析,可参考预备知识相关内容;
- 8. 对1位全加器,进行时序仿真,并做时延分析,要求:
  - 1) 测量 A 第 1~4 个上升沿到对应的的 S 输出之间的延迟时间;
  - 2) 对输出 S 的毛刺进行测量和分析;
  - 3) 对输出 C 的毛刺进行测量和分析;
  - 4) 对测得的时延结果进行分析
- 9. 参看 7.6 节 "总线(Bus)功能",将 4 位全加器的输入输出信号用总线的方式引出,并封装成元件。

# 选做实验

- 1. 调用 2 个 4 位全加器模块,实现 1 个 8 位全加器,做时序仿真,测量 C<sub>in</sub>="1", B=(80)<sub>16</sub>, A 从(00)<sub>16</sub>→(7F)<sub>16</sub> 所对应输出 C<sub>out</sub> 的时延;
- 2. 查找资料,修改8位全加器的结构,选择更合理的方案,降低延迟,提高工作频率。

# 实验七 可编程小系统设计

# 学习目标

- 1. 了解可编程数字系统设计的流程
- 2. 掌握 Quartus II 软件的使用方法
- 3. 掌握原理图输入方式设计数字系统的方法和流程

# 时间要求:

1. 实验时间: 第15周

2. 报告提交:第16周课内

# 预备知识

- 1. 实验教材: 第7章
- 2. 二进制乘法串行实现方法

二进制乘法可以采用移位相加的方法。即用乘数的各位数码,从低位开始依次与被乘数相乘,每相乘一次得到的积称为部分积,将第一次(由乘数最低位与被乘数相乘)得到的部分积右移一位并与第二次得到的部分积相加,将加得的和右移一位再与第三次得到的部分积相加,再将相加的结果右移一位与第四次得到的部分积相加,……直到所有的部分积都被加过一次。

以被乘数 $(M_3M_2M_1M_0)$ 和乘数 $(N_3N_2N_1N_0)$ 分别为 1101 和 1001 为例,其计算过程如下:

1101

× 1001

| 01101    | N <sub>0</sub> 与被乘数相乘的部分积 |
|----------|---------------------------|
| 01101    | 部分积右移一位                   |
| + 0000   | N <sub>1</sub> 与被乘数相乘的部分积 |
| 001101   | 两个部分积之和                   |
| 001101   | 部分积之和右移一位                 |
| + 0000   | N <sub>2</sub> 与被乘数相乘的部分积 |
| 0001101  | 与前面部分积之和相加                |
| 0001101  | 部分积之和右移一位                 |
| + 1101   | N <sub>3</sub> 与被乘数相乘的部分积 |
| 01110101 | 与前面部分积之和相加                |
| 01110101 | 部分积之和右移一位(最终乘积)           |

可以用二个寄存器 A、B 分别存放被乘数 M、乘数 N,累加器 Y 存放部分积。A 和 B 中的数据在加法

器中相加后送人 Y 中。A 和 Y 相级联又构成了一个 8bit 的移位寄存器,当它工作于移位模式时,可以实现数据的右移。由于乘数的每一位不是 0 就是 1,对应的部分积不是 0 就是被乘数本身,所以实际作部分积相加这一步时,只要判断乘数的对应位,如该位为 1,则将累加器中的数据加上被乘数再移位;如该位为 0,就不加被乘数而直接移位。

运算时首先将累加 Y 清零,并将被乘数 M 和乘数 N 分别存入寄存器 A 和 B,然后依据寄存器 B 中最右一位  $B_0$ (数据  $N_0$ )确定第一个部分积。将此部分积送人 A 累加器以后,将 Y 连同寄存器 B 右移一位,部分积的最低位被移进寄存器 B 的最左位,乘数的最低位  $N_0$  被移出寄存器 B,而乘数的次低位  $N_1$  被移至寄存器 B 的  $B_0$  位。第二次仍然依据  $B_0$  位的数据( $N_1$ )来确定第二个部分积,将部分积与累加器中的数据相加后右移一位, $N_1$  又被移出寄存器,数据  $N_2$  被移到  $B_0$  位置 •,• · · · 。这样,经过 4 次部分积相加位的操作,完成 1 次乘法运算,乘数 N 恰好被移出寄存器 B,寄存器 B 中保存的就是运算积的低 4 位数据。移位相加的次数应用一个计数器来控制,每移位一次,计数器计一个数。当计数器计得 4 个数时,发出一个信号,使电路停止操作,并输出运算结果

## 必做实验

#### 1. 实验内容

1) 利用实验六设计的全加器,设计一个 4 位二进制串行乘法器,其中"被乘数"用 4 个逻辑电平开关输入,"乘数"也用 4 个逻辑电平开关输入,"积"用 2 个数码管显示(十六进制)

#### 2. 实验要求

- 根据设计要求划分设计层次、单元模块和接口信号,在预习报告上记录设计过程,绘制系统框图,每个模块的状态转移图或 ASM 图,并设计验证方案。
- 2) 用原理图输入法设计所有单元模块并编译,分析编译时产生的错误和警告信息
- 3) 对所有的单元模块进行功能仿真,并记录和分析全部仿真结果
- 4) 在顶层文件中连接全部单元模块并编译、综合、分配管脚和适配。
- 5) 对整个系统进行时序仿真,并记录和分析仿真结果。
- 6) 将仿真正确的设计下载到实验箱上,连接输入输出设备进行板级验证

# 附录一 Fritzing 简明操作指南

Fritzing 是一款完全免费的、绿色开源的电子设计自动化软件,下面简单介绍一下如何利用该软件绘制电路硬件连接示意图。在使用前需要根据操作系统版本下载对应的 32 bit Fritzing 软件或 64 bit Fritzing 软件。下载完成后在下载目录里找到压缩包,解压后打开目录里的"Fritzing.exe",即可运行 Fritzing。Fritzing 有 4种视图,分别是面包板、原理图、PCB、code,单击切换到"面包板"视图,如图 1 所示,需要绘制硬件连接图的电路原理图如图 2 所示。



图 1 Fritzing 面包板视图



图 2 电路原理图



图 3 IC 器件



图 4 指示栏

- 1、 在右侧 "元件" 栏中,选中 "CORE" 部件列表,下拉,找到 "IC" 器件。如图 3 所示,拖动 "IC" 器件 到面包,并放在合适的位置,如图 4 所示。
- 2、 修改针脚数为"14",修改芯片标签为"74HC00",电路如图 5 所示。
- 3、 用鼠标点中按"Del"键删除图中不用的连线, 如图 6 所示
- 4、 重复 1 到 3, 放置元件 74HC20, 如图 7 所示





图 5 修改后的电路

图 6 删除连线后的电路

- 5、 首先连接 7400 的 2 脚和 12 脚,鼠标移到准备连线的起点,按住左键,将鼠标移动到连线的终点,松 开,如图 8 所示
- 6、 鼠标点住连线,根据需要,修改连线形状,修改后的电路如图 9 所示
- 7、 重复上述步骤, 绘制全部电路, 如图 10 所示。
- 8、添加电源和地线,可以右键点击连线,修改连线颜色,如图 11 所示
- 9、添加输入输出信号,如图 12 所示
- 10、 点击文件菜单,选择保存电路文件。



图 7 添加 74HC20 后的电路



图 6 连线后的电路





图 9 修改连线后的电路



图 11 添加电源和地线后的电路

图 10 完成信号连线后的电路



图 10 完成信号连线后的电路

# 附录二 Quartus II 简明操作指南

在前面的实验里,我们所有的实验都是基于这样一个观点,即将一个数字系统划分成合适利用已有的中小规模数字集成电路的功能的模块,然后将这些集成电路通过外部引线连接起来。现在开始我们将研究用可编程逻辑器件(PLD/FPGA)来进行数字系统设计。

可编程逻辑器件是一种大规模的集成电路,其内部预置了大量易于实现各种逻辑函数的结构,同时还有一些用来保持信息或控制连接的特殊结构,这些保持的信息或连接确定了器件实现的实际逻辑功能,当改变这些信息或连接时器件的功能也将随之改变。可编程逻辑器件的设计过程和传统的中小规模数字电路设计也不一样,可编程数字系统,无论是 CPLD 还是 FPGA 器件都需要利用软件工具来进行设计。可编程数字系统设计总体上一般可以分为设计输入、项目处理、设计校验和器件编程这四个主要过程。下面我们将一个简单的模 60BCD 计数器为例,说明可编程数字系统设计的基本流程、概念和方法,掌握 Quartus II 软件的基本功能和操作,了解原理图输入方式的设计全过程。

## 一、 设计项目输入

设计输入是设计者对系统要实现的逻辑功能进行描述的过程。设计输入有多种表达方式,本次我们主要学习图形输入法。

# 1.1 建立工程项目

- 1. 打开 Quartus II,在 File 菜单中选择 New Project Wizard 项,将出现工程项目建立向导对话框。
- 2. 点击"Next",进入到相应的对话框,在最上面的文本输入框中输入项目所在的目录名(注意:不能用中文名,下同),在中间的文本输入框中输入项目名称,在图 1 中中额的文本输入框中输入最顶层模块的名称。



图 1 项目名称输入

- 3. 点击"Next",进入到设计文件选择对话框,由于在本例中还没有任何设计文件,所以不选择任何文件。
- 4. 点击"Next",进入到图 2 所示的器件选择对话框,在"Family"下拉菜单中选择"CycloneIII",在"Available Devices"列表栏中选择"EP3C5E144C8"。
- 5. 点击"Next"进入到第三方 EDA 工具选择对话框,在这个界面我们可以选择第三方的综合工具、仿真工具

和时延分析工具。由于在本例中我们的综合、仿真和时延分析都采用 Quartus II 内置的工具,所以在这个页面不作任何选择。

6. 点击"Next"进入到 "Summary"对话框,在这个窗口列出了前面所作设置的全部信息。点击"Finish"完成工程项目建立过程,回到主窗口。



图 2 器件选择对话框

# 1.2 建立原理图输入文件

在 Quartus II 中我们可以利用 Block Editor 以原理图的形式进行设计输入和编辑。Block Editor 可以读取并编辑后缀名为".bdf"的原理图设计文件以及在 MAX+PLUS II 中建立的后缀为".gdf"的原理图输入文件。

- 在 File 菜单中选择 New 项,将出现新建文件对话框。选择"Design File/Block Diagram/Schematic File"项。
- 2. 点击"OK",在主界面中将打开 "Block Editor"窗口。"Block Editor"包括 主绘图区和主绘图工具条两部分。主绘图区是用户绘制原理图的区域,绘图工具条包含了绘图所需要的一些工具。简要说明如下:
  - 选择工具:用于选择图中的器件、线条等绘图元素;
  - **插入器件**:从元件库内选择要添加的元件
  - **插入模块**:插入已设计完成的底层模块;
  - 下交线工具: 用于绘制水平和垂直方向的连线:



图 3 新建原理图文件

- **了** 正交总线工具:用于绘制水平和垂直方向的总线;
- **打开/关闭橡皮筋连接功能**:按下,橡皮筋连接功能打开,此时移动元件连接在元件上的连线也跟着移动,不改变同其他元件的连接关系;
- **打开/关闭局部正交连线选择功能**:按下时打开局部正交连线选择功能,此时可以通过用鼠标选择两条正交连线的局部:
- **放大和缩小工具**:按下时,点击鼠标左键放大,右键缩小显示绘图工作区;
- **全屏显示**:将当前主窗口全屏显示;
- **垂直翻转**:将选中的元件或模块进行垂直翻转;
- ★ 水平翻转:将选中的元件或模块进行水平翻转;
- **旋转90度**:将选中的元件或模块逆时针方向旋转90度;

#### 3. 元件的添加:

在主绘图区双击鼠标左键,弹出图 4 所示的 Symbol 对话框,在 name 栏输入需添加的元件,如 7400 或 nand2(二输入与非门),not(非门),vcc(5v 电源、高电平), gnd(接地、低电平),input(输入引脚),output(输出引脚)等,回车或点击 ok,此时在鼠标光标处将出现该元件图标,并随鼠标的移动而移动,在 合适的位置点击鼠标左键,放置一个元件。也可以利用插入器件工具 \*\*\* 来添加元器件,方法类似。

在"Libraries"栏中显示目前你已经安装的元件库,一般缺省会有 mega functions、others 和 primitives 这 三个库。其中 mega functions 是参数化模块库,包含了一些参数可调、功能复杂的高级功能模块; others 库中则包含了原来 MAX+PLUS II 中的部分器件库,其中包括了大部分的 74 系列中规模逻辑器件; primitives 库是基本库包含一些基本的逻辑器件,如各种门、触发器等。



图 4 找出需要的器件名称



图 5 将器件放置在工作区

- 4. **命名输入输出引脚:** 双击输入输出引脚的"PIN NAME",输入自己定义的名字即可。
- 5. **器件的连接和修改:** 连接元器件的两个端口时,先将鼠标移到其中一个端口上,这时鼠标指示符自动变为"+"形状,然后一直按住鼠标的左键并将鼠标拖到第二个端口,放开左键,则一条连接线被画好了。如果需要删除一根连接线,可单击这根连接线使其成高亮线,然后按键盘上的"Delete"键即可。



图 6 连接好线和输入输出端口的原理图

- 注: 1、连线时走线请避开元件或端口的轮廓虚线;(图中浅绿色虚框)
  - 2、连线中线段可交叉,但如果出现连接点则表示两线段相连相通;
  - 3、输入端通常不可悬空。
- 6. **保存文件:**从"File"菜单下选择"Save",出现文件保存对话框。单击"OK",使用默认的文件名存盘。默认的文件名为项目项层模块名加上".bdf"后缀。

## 二、 设计项目处理

在完成输入后,设计项目必须经过一系列的编译处理才能转化为可以下载到器件内的编程文件。

- 点击主工具栏上的 按钮,开始"Analysis and Synthesis"编译过程。 注意应该将要编译的文件设置成项层文件才能对它进行编译,设置 方法为:点击左边 Project Navigator/files,打开 files/Device Design Files,选中要编译的 bdf 文件,点击鼠标右键,在图 7 所示弹出的 菜单中选择 Set as Top-level Entity。
- 2. 在项目处理过程期间,所有信息、错误和警告将会在自动打开的信息处理窗口中显示出来。如果有错误或警告发生,双击该错误或警告信息,就会找到该错误或警告在设计文件中的位置。其中错误必须要修改,否则无法执行后续的项目处理,对于警告则要分情况处理。
- 3. **分配引脚:** Analysis and Synthesis 全部通过后,为了把我们的设计下载到实际电路中进行验证,还必须把设计项目的输入输出端口和



图 7 设置项目顶层文件

器件相应的引脚绑定在一起。有两种方法可以实现这个过程,一种是给引脚分配信号,另一种则是给信号分配管脚。在此只介绍给信号分配管脚的方法:

选择菜单 Assignments → Pins,"Assignments Editor"窗口。选择菜单 View → Show All Known Pin Names,此时编辑器将显示所有的输入输出信号,其中"Node Name"列是信号列,"Location"列是引脚列,"General Function"列显示该引脚的通用功能。对于一个输入输出信号,双击对应的"Location"列,在弹出的下拉列表框内选择需要绑定的管脚号。完成所有引脚的绑定,保存修改,此时原理图设计文件将给输入输出端口添加引脚编号。



图 8 根据需要选取合适 I/O bank



图 9 给信号分配管脚

4. **布局布线、生成编程文件和时序分析:** Analysis and Synthesis 和管脚分配完成后,可以点击 进行全编译

# 三、 设计项目校验

在完成设计输入和编译后,我们可以通过软件来检验设计的逻辑功能和计算设计的内部定时是否符合设计要求。常见的设计项目校验包括功能仿真、定时分析和时序仿真。

# 3.1 建立输入激励波形文件(.vmf):

在做仿真之前,必须要先建立波形激励文件,具体步骤如下:

- 1. 在"File"菜单中选择"New"打开新建文件对话框,在"Verification/Debugging Files"中选择"Vector Waveform File"项后选择"OK"。
- 2. 编辑器窗口的节点名称栏(Name)空白处单击鼠标右键,在该菜单中选择"Insert Node or Bus..."项,弹出 Insert Node or Bus 对话框,点击"Node Finder"按钮,打开 "Node Finder"对话框,单击"List"按钮可以在 "Nodes Found"栏中看到在设计中的所有输入/输出信号,当选中信号时,蓝色高亮,表示被选中。单击 "≥"按钮可将选中的信号移动到"Selected Nodes"区,表示可对这些信号进行观测。点击"OK"按钮,回到 "Insert Node or Bus"对话框,再点击该对话框的"OK"按钮。
- 3. 从菜单"File"中选择"Save",将此波形文件保存为默认名,扩展名".vmf"表示仿真波形激励文件。

# 3.2 为输入信号建立输入激励波形:

在波形文件中添加好输入/输出信号后,就可开始为输入信号建立输入激励波形。

- 1. 在"Tools"菜单中选择"Options"项,打开参数设置对话框,选择"Waveform Editor"项设置波形仿真器参数。 在这个对话框里我们设置"Snap to grid"为不选中,其他为缺省值即可。
- 2. 从菜单"Edit"下选择"End Time"项,弹出终止时间设定对话框,根据设计需要设置仿真终止时间。
- 3. 利用波形编辑器工具栏提供的工具为输入信号赋值,工具栏中主要按钮的功能介绍如下:
  - **放大和缩小工具**:利用鼠标左键放大/右键缩小显示仿真波形区域;
  - **全屏显示**:全屏显示当前波形编辑器窗口;
  - **昼 赋值"0"**:对某段已选中的波形,赋值'0',即强 0;
  - **赋值"1"**: 对某段已选中的波形,赋值'1',即强 1;
  - **时钟赋值**:为周期性时钟信号赋值;
- 5. 选择"File"中"Save"存盘。到此完成激励波形输入。

# 3.3 功能仿真

可编程系统的仿真一般分为功能仿真和时序仿真。其中功能仿真,主要是检查逻辑功能是否正确。功能仿真方法如下:

- 1. 在"Processing"菜单下选择"Simulator Tool"项,打开 "Simulator Tool"对话框。在"Simulator Mode"下拉列 表框中选择"Functional"项,在"Simulation input"栏中指定波形激励文件。单击"Generator Functional Simulator Netlist"按钮,生成功能仿真网表文件。
- 2. 仿真网表生成成功后,点击"Start"按钮,开始功能仿真。仿真计算完成后,点击"Report"按钮,打开仿真结果波形。
- 3. 观察输出波形,检查是否满足设计要求。

# 3.4 时序仿真

时序仿真则是在功能仿真的基础上利用在布局布线中获得的精确延时参数进行的精确仿真,一般时序仿真的结果和实际结果非常的接近,但由于要计算大量的时延信息,仿真速度比较慢。时序仿真的详细步骤如下:

- 1. 在 "Simulator Tool"对话框的"Simulator Mode"下拉列表框中选择"Timing"项,在"Simulation input"栏中指 定波形激励文件。
- 2. 点击"Start"按钮,开始时序仿真。仿真计算完成后,点击"Report"按钮,打开和功能仿真类似仿真结果 波形。

# 四、 器件编程

器件编程是使用项目处理过程中生成的编程文件对器件进行编程的,在这个过程中可以对器件编程、校验、试验,检查是否空白以及进行功能测试。

# 4.1 Quartus II 器件编程

- 1. 用下载电缆将计算机并口和实验设备连接起来,接通电源。
- 2. 选择 Tools→Programmer 菜单,打开 Programmer 窗口。
  - a) 在开始编程之前,必须正确设置编程硬件。点击"Hardware Setup"按钮,打开硬件设置口。
- 3. 点击"Add Hardware"打开硬件添加窗口,在"Hardware type"下拉框中选择"Usb Blaster",点击 OK 按钮确认,关闭 Hardware Setup 窗口,完成硬件设置。
- 4. 将 Program/Configure 选中。
- 5. 点击"Start"按钮,开始编程。



图 10 下载电缆设置