计数器的设计

预习报告

内容一

使用 JK 触发器设计一个 16 进制异步减法计数器,并用逻辑分析仪观察并记录 CP 和每一位的输出波形。

JK 触发器功能/真值表

CP 时钟JK工作状态$Q^+$
$\downarrow$00保持Q
$\downarrow$01置零0
$\downarrow$10置一1
$\downarrow$11翻转$\overline Q$

用 Proteus 设计电路,并运行仿真

如图,$A_0\dots A_3$分别对应模拟的$Q_0\dots Q_3$端口。

可以看出,在一个周期内$Q_3Q_2Q_1Q_0$的变化顺序依次为

$0000\to1111\to1110\to1101\to1100\to1011\to1010\to1001\to1000\to0111\to0110\to0101\to0100\to0011\to0010\to0001\to0000\to\dots$

符合设计预期。

这里写图片描述

内容二

使用 JK 触发器设计一个 16 进制同步加法计数器,并用逻辑分析仪观察并记录 CP 和每一位的输出波形。

用 Proteus 设计电路,并运行仿真

如图,$A_0\dots A_3$分别对应模拟的$Q_0\dots Q_3$ 端口。

可以看出,在一个周期内$Q_3Q_2Q_1Q_0$的变化顺序依次为

$0000\to0001\to0010\to0011\to0100\to0101\to0110\to0111\to1000\to1001\to1010\to1011\to1100\to1101\to1110\to1111\to0000\dots$

符合设计预期。

这里写图片描述

内容三

使用 JK 触发器和门电路设计实现一个二进制四位计数器模仿 74LS194 功能。要求在实验箱上设计实现左移或右移功能;在 proteus 软件上实现置零,保持,左移,右移,并行送数功能。

74LS194 功能/真值表

CP 时钟$\overline{Cr}$清零${S_1}$${S_0}$工作状态$Q_A^+$$Q_B^+$$Q_C^+$$Q_D^+$
$\uparrow$0XX置零0000
$\uparrow$100保持$Q_A$$Q_B$$Q_C$$Q_D$
$\uparrow$101右移$D_{SR}$$Q_A$$Q_B$$Q_C$
$\uparrow$110左移$Q_B$$Q_C$$Q_D$$D_{SL}$
$\uparrow$111并行送数$D_0$$D_1$$D_2$$D_3$

用 Proteus 设计电路,并运行仿真

这里写图片描述

内容四

用 JK 触发器和门电路设计一个特殊的 12 进制同步计数器如下:

$0001\to0010\to0011\to0100\to0101\to0110\to0111\to1000\to1001\to1010\to1011\to1100\to0001\to\dots$

并用逻辑分析仪观察并记录 CP 和每一位的输出波形。

注意:这个 12 进制同步计数器没有 00 状态,要考虑自启动。

次态卡诺图

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00xxxx001001000011
010101011010000111
110001xxxxxxxxxxxx
101001101011001011

卡诺图化简得到每个触发器方程

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00x000
010010
110xxx
101111

$Q_3^+=Q_3\overline{Q_2}+\overline{Q_3}Q_2Q_1Q_0$

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00x010
011101
110xxx
100010

$Q_2^+=\overline{Q_3}Q_2\overline{Q_1}+\overline{Q_2}Q_1Q_0+\overline{Q_3}Q_2\overline{Q_0}$

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00x101
010101
110xxx
100101

$Q_1^+=Q_1\overline{Q_0}+\overline{Q_1}Q_0$

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00x001
011001
111xxx
101001

$Q_0^+=\overline{Q_0}$

驱动器方程

$J_3=Q_2Q_1Q_0,K_3=Q_2$

$J_2=Q_1Q_0,K_2=\overline{\overline{Q_3}(\overline{Q_1}+\overline{Q_0})}=Q_3+Q_1Q_0$

$J_1=K_1=Q_0$

$J_0=K_0=1$

用 Proteus 设计电路,并运行仿真

这里写图片描述

在图中 $A_0\dots A_3$对应$Q_0\dots Q_3$。在波形的一个周期里,其变化符合设计预期。

内容五

使用 Protues 和 Vivado 实现一个有控制变量 D 的 12 进制计数器(12 进制计数器状态转换图如内容四),并在 7 段数码管上显示计数结果。

由于 D=0 时(加)的驱动方程已在内容四得出,下面仅涉及 D=1(减)的状态。

次态卡诺图

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00xxxx110000100001
010011010001100101
111011xxxxxxxxxxxx
100111100010101001

卡诺图化简得到每个触发器方程

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00x100
010000
111xxx
100111

$Q_3^+=Q_3Q_2+Q_3Q_1+Q_3Q_0+\overline{Q_3}\,\overline{Q_2}\,\overline{Q_1}$

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00x100
010111
110xxx
101000

$Q_2^+=\overline{Q_3}\,\overline{Q_2}\,\overline{Q_1}+\overline{Q_2}\,\overline{Q_1}\,\overline{Q_0}+Q_2Q_1+Q_2Q_0$

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00x010
011010
111xxx
101010

$Q_1^+=Q_1Q_0+\overline{Q_1}\,\overline{Q_0}$

$Q_3^+Q_2^+\setminus Q_1^+Q_0^+$00011110
00x001
011001
111xxx
101001

$Q_0^+=\overline{Q_0}$

驱动方程

$J_3=\overline{Q_2}\,\overline{Q_1},K_3=\overline{Q_2+Q_1+Q_0}=\overline{Q_2}\,\overline{Q_1}\,\overline{Q_0}$

$J_2=\overline{Q_1}\,\overline{Q_3}+\overline{Q_1}\,\overline{Q_0},K_2=\overline{Q_1+Q_0}=\overline{Q_1}\,\overline{Q_0}$

$J_1=K_1=\overline{Q_0}$

$J_0=K_0=1$

用 Proteus 设计电路,并运行仿真

这里写图片描述

用 Vivado 设计电路,并烧写到 Basys3 实验板

这里写图片描述

端口映射

这里写图片描述

烧写到 Basys3 实验板

这里写图片描述

这里写图片描述

实验报告

内容四

在实验箱上完成十二进制计数器,并在逻辑分析仪上得到其波形。

实验仪器及器件

数字电路实验箱、示波器;器件:74LS00*2,74LS08*2,74LS73*4、74LS197*1

代码转换电路设计

具体设计和仿真已在预习报告中完成。

转换电路的效果检验

这里写图片描述

波形分析

这里写图片描述

连续脉冲频率为 2kHz,可以看出一个周期内 $D_0\dots D_3$ 恰构成二进制的 1~12,符合预期。

实验心得和体会

  1. 通过本次实验,我了解了 portuse 仿真软件上开关的使用。
  2. 通过本次实验,我熟悉了时序逻辑电路的分析步骤和方法。
  3. 通过本次实验,我更熟悉了示波器的使用。
  4. 通过本次实验,我提高了对错误电路的调试能力。
  5. 通过本次实验,我提高了电路的推导和检查能力。