实践内容:解释 2 至 4 解码器的结果和仿真过程 (包括真值表创建和 k 映射、AND 门)。
0x00 解码器(Decoder)
解码器是一种根据输入信号从多个输出 bit 中只选择一个的设备。
例如,如果有一个解码器接收一个 2 位二进制数值作为输入,它可以接收 00、01、10、11 四个数值作为输入,并通过为每个输入只选择四个位中的一个来输出 1000、0100、0010 和 0001 四个数值。只选择一个输出位为 1 的解码器称为主动高电平解码器,只选择一个输出位为 0 的解码器称为主动低电平解码器。当输入存储在特定存储器中的字地址时,主要用于解码操作数/地址,如发出信号选择相应的字(地址解码器)。
解码器分为两种类型:
- 主动高电平解码器:在输出中只有一个位是高电平(1),其他位都是低电平(0)。
- 主动低电平解码器:在输出中只有一个位是低电平(0),其他位都是高电平(1)。
Active High Decoder | |
Active High Decoder | |
0x01 2-4 解码器的实现
解释 2 至 4 解码器的结果和仿真过程 (包括真值表创建和 k 映射、AND 门)。
📃 真值表如下:
输入 | 输出 | ||||
A | B | D0 | D1 | D2 | D3 |
0 | 0 | 1 | 0 | 0 | 0 |
0 | 1 | 0 | 1 | 0 | 0 |
1 | 0 | 0 | 0 | 1 | 0 |
1 | 1 | 0 | 0 | 0 | 1 |
📜 K-map:
D0 | D1 |
D2 | D3 |
💬 Design source:(使用AND门实现)
`timescale 1ns / 1psmodule h_dec(input A,input B,output D0,output D1,output D2,output D3);assign D0 = (~A) & (~B);
assign D1 = B & (~A);
assign D2 = A & (~B);
assign D3 = A & B;endmodule
💬 Testbench:
`timescale 1ns / 1psmodule h_dec_tb;
reg A,B;
wire D0,D1,D2,D3;h_dec u_h_dec (.A(A ),.B(B ),.D0(D0 ),.D1(D1 ),.D2(D2 ),.D3(D3 )
);initial beginA = 1'b0;B = 1'b0;
endalways@(A or B) beginA <= #10 ~A;B <= #20 ~B;
endinitial begin#40$finish;
endendmodule
🚩 运行结果如下:
💭 Schematic:
输入 N 位的情况下返回 2^N 位的输出,其中只有一位为 1,其余为 0(高电平有效),或者只有一位为 0,其余为 1(低电平有效)。将 A、B 作为单个 2 位输入,并将 A 视为 MSB,因此如果 A、B 的值为 00,则 D0、D1、D2、D3 的输出为 1000,01 为 0100,10 为 0010,11 为 1111。
D0 = (~A) & (~B);
D0 输出被设置为A
和B
的取反的与操作。当A
和B
都为0时,D0 被激活,即输出为1。D1 = B & (~A);
D1 输出被设置为B
和A
的取反的与操作。当A
为0且B
为1时,D1 被激活,即输出为1。D2 = A & (~B);
D2 输出被设置为A
和B
的取反的与操作。当A
为1且B
为0时,D2 被激活,即输出为1。D3 = A & B;
D3 输出被设置为A
和B
的与操作。当A
和B
都为1时,D3 被激活,即输出为1。
根据输入的不同组合,解码器的四个输出信号中的一个会被激活。
📌 [ 笔者 ] 최역우
📃 [ 更新 ] 2023.12.14
❌ [ 勘误 ] /* 暂无 */
📜 [ 声明 ] 由于作者水平有限,本文有错误和不准确之处在所难免,本人也很想知道这些错误,恳望读者批评指正!
📜 参考资料 Introduction to Logic and Computer Design, Alan Marcovitz, McGrawHill, 2008 Microsoft. MSDN(Microsoft Developer Network)[EB/OL]. []. . 百度百科[EB/OL]. []. https://baike.baidu.com/. |