【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

时间:2022-10-21 01:00:41


【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

写在前面:本章将理解编码器与解码器、多路复用器与多路分解器的概念,通过使用 Verilog 实现多样的解码器与多路分解器,通过 FPGA 并使用 Verilog 实现。


Ⅰ. 前置知识

0x00 解码器与编码器(Decoder / Encoder)

解码器 (Decoder):执行转换和处理过程以将 Encoding 数据恢复到之前的电路。

编码器 (Encoder):将特定数据转换和处理为其他形式或格式的电路,以确保安全或缩小数据的大小。

编码器和解码器用于将任意两种符号体系相互转换。

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

0x01 多路复用器 MUX 与 多路分解器 DeMUX

多路复用器 MUX (Multiplexer),能接收多个输入信号,按每个输入信号可恢复方式合成单个输出信号。复用器是一种综合系统,通常包含一定数目的数据输入,有一个单独的输出。

多路分解器 DeMUX (DeMultiplexer),是从一个输入接收资料,根据多条输出线中的输入,连接到预先选定的一条输出线的电路。

通常与带有 enable line 的解码器相同。

由于各自的功能特性,MUX 也被称为 Data Selctor(数据选择器),DeMUX 也被称为 Data Distributor(数据分配器)。

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

Ⅱ.  练习(Assignment)

0x00 2 to 4 Decoder

使用 AND 对电路进行 Verilog 编码,使用 NAND 结构对电路进行 Verilog 编码,通过 Verilog 的模拟结果完成真值表(2种),并比较两种形式的解码器。

???? Design source:

`timescale 1ns / 1ps

module two_to_four_decoder(
input A, B,
output D1, D2, D3, D4
);

assign D1 = ~A&~B;
assign D2 = ~A&B;
assign D3 = A&~B;
assign D4 = A&B;

endmodule

???? Testbench:

`timescale 1ns / 1ps

module two_to_four_decode_tb;
reg AA, BB;
wire D1, D2, D3, D4;

two_to_four_decoder u_two_to_four_decoder(
.A(AA),
.B(BB),
.D1(D2),
.D2(D2),
.D3(D3),
.D4(D4)
);

initial AA = 1'b0;
initial BB = 1'b0;

always AA = #100 ~AA;
always BB = #200 ~BB;

initial begin
#1000
$finish;
end

endmodule

???? 运行结果如下:

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

0x01 4 to 2 Encoder

使用 OR 对电路进行 Verilog 编码,通过 Verilog 的仿真结果完成真值表。

???? Design source:

`timescale 1ns / 1ps

module four_to_two_encoder(
input a, b, c, d,
output e0, e1
);
assign e0 = a|b;
assign e1 = a|c;

endmodule

???? Testbench:

`timescale 1ns / 1ps

module four_to_two_encoder_tb;
reg aa, bb, cc, dd;
wire e0, e1;

four_to_two_encoder u_four_to_two_encoder(
.a(aa),
.b(bb),
.c(cc),
.d(dd),
.e0(e0),
.e1(e1)
);

initial aa = 1'b0;
initial bb = 1'b0;
initial cc = 1'b0;
initial dd = 1'b0;

always aa = #100 ~aa;
always bb = #200 ~bb;
always cc = #400 ~cc;
always dd = #800 ~dd;

initial begin
#1000
$finish;
end

endmodule

???? 运行结果如下:

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

0x02 BCD to Decimal Decoder

通过 Verilog 编码实现(A)的结构,通过 Verilog 的仿真结果完成真值表,并确认是否与理论中的Boolean 函数一致。

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

???? Design source:

`timescale 1ns / 1ps

module bcd_decoder(
input a3, a2, a1, a0,
output o1, o2, o3, o4, o5, o6, o7, o8, o9
);
assign o1 = ~a3&~a2&~a1&a0;
assign o2 = ~a3&~a2&a1&~a0;
assign o3 = ~a3&~a2&a1&a0;
assign o4 = ~a3&a2&~a1&~a0;
assign o5 = ~a3&a2&~a1&a0;
assign o6 = ~a3&a2&a1&~a0;
assign o7 = ~a3&a2&a1&a0;
assign o8 = a3&~a2&~a1&~a0;
assign o9 = a3&~a2&~a1&a0;

endmodule

???? Testbench:

`timescale 1ns / 1ps

module bcd_decoder_tb;
reg aa3, aa2, aa1, aa0;
wire o1, o2, o3, o4, o5, o6, o7, o8, o9;

bcd_decoder u_bcd_decoder(
.a3(aa3),
.a2(aa2),
.a1(aa1),
.a0(aa0),
.o1(o1),
.o2(o2),
.o3(o3),
.o4(o4),
.o5(o5),
.o6(o6),
.o7(o7),
.o8(o8),
.o9(o9)
);

initial aa3 = 1'b0;
initial aa2 = 1'b0;
initial aa1 = 1'b0;
initial aa0 = 1'b0;

always aa3 = #100 ~aa3;
always aa2 = #200 ~aa2;
always aa1 = #400 ~aa1;
always aa0 = #800 ~aa0;

initial begin
#1000
$finish;
end

endmodule

???? 运行结果如下:

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

0x03 4 to 1 line MUX

以(A)的结构对电路进行 Verilog 编码,通过 Verilog 的仿真结果完成真值表。并确认是否与理论中的 Boolean 函数一致。

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

???? Design source:

`timescale 1ns / 1ps

module four_to_one_mux(
input a, b, c, d, A, B,
output q
);
assign q = (a&~B&~A)|(b&B&~A)|(c&~B&A)|(d&B&A);

endmodule

 ???? Testbench:

`timescale 1ns / 1ps

module four_to_one_mux_tb;
reg aa, bb, cc, dd, AA, BB;
wire q;

four_to_one_mux u_four_to_one_mux(
.a(aa),
.b(bb),
.c(cc),
.d(dd),
.A(AA),
.B(BB),
.q(q)
);

initial aa = 1'b0;
initial bb = 1'b0;
initial cc = 1'b0;
initial dd = 1'b0;
initial AA = 1'b0;
initial BB = 1'b0;

always aa = #50 ~aa;
always bb = #100 ~bb;
always cc = #200 ~cc;
always dd = #400 ~dd;
always AA = #800 ~AA;
always BB = #1600 ~BB;

initial begin
#2000
$finish;
end

endmodule

???? 运行结果如下:

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

0x04 1 to 4 line deMUX

以(A)的结构对电路进行 Verilog 编码,通过 Verilog 的仿真结果完成真值表,确认是否与理论中的 Boolean 函数一致。

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

???? Design source:

`timescale 1ns / 1ps

module one_to_four_mux(
input A, B, f,
output a, b, c, d
);
assign a = f&(~A&~B);
assign b = f&(~A&B);
assign c = f&(A&~B);
assign d = f&(A&B);

endmodule

???? Testbench:

`timescale 1ns / 1ps

module one_to_four_mux_tb;
reg AA, BB, ff;
wire a, b, c, d;

one_to_four_mux u_one_to_four_mux(
.A(AA),
.B(BB),
.f(ff),
.a(a),
.b(b),
.c(c),
.d(d)
);

initial AA = 1'b0;
initial BB = 1'b0;
initial ff = 1'b0;

always AA = #100 ~AA;
always BB = #200 ~BB;
always ff = #400 ~ff;

initial begin
#1000
$finish;
end

endmodule

???? 运行结果如下:

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器

???? [ 笔者 ]   Foxny,Akam
???? [ 更新 ] 2023.3.5
❌ [ 勘误 ] /* 暂无 */
???? [ 声明 ] 由于作者水平有限,本文有错误和不准确之处在所难免,
本人也很想知道这些错误,恳望读者批评指正!

???? 参考资料 

Introduction to Logic and Computer Design, Alan Marcovitz, McGrawHill, 2008

Microsoft. MSDN(Microsoft Developer Network)[EB/OL]. []. .

百度百科[EB/OL]. []. https://baike.baidu.com/.