You are provided with a BCD (binary-coded decimal) one-digit adder named bcd_fadd that adds two BCD digits and carry-in, and produces a sum and carry-out.
module bcd_fadd ( input [3:0] a, input [3:0] b, input cin, output cout, output [3:0] sum );
Instantiate 4 copies of bcd_fadd to create a 4-digit BCD ripple-carry adder. Your adder should add two 4-digit BCD numbers (packed into 16-bit vectors) and a carry-in to produce a 4-digit sum and carry out.
译:
为您提供了一个名为bcd_fadd的BCD(二进制编码的十进制)一位数加法器,它将两个BCD数字相加并带入,并生成一个总和和执行。
实例化4个bcd_fadd来创建一个4位BCD串行进位加法器。您的加法器应该将两个4位BCD数字(打包成16位向量)和一个进位相加,以产生一个4位和进位输出。
解法:
module top_module (
input [15:0] a, b,
input cin,
output cout,
output [15:0] sum );
wire [3:0] cout_mid;
bcd_fadd bcd_fadd1(a[3:0],b[3:0],cin,cout_mid[0],sum[3:0]);
genvar i;
generate
for(i=1;i<4;i++)begin:bcd_fadd_BDC
bcd_fadd bcd_fadd2(a[(4*i+3):(4*i)],b[(4*i+3):(4*i)],cout_mid[i-1],cout_mid[i],sum[(4*i+3):(4*i)]);
end:bcd_fadd_BDC
assign cout=cout_mid[3];
endgenerate
endmodule
分析:
结合长度截取、循环、 多实例化等多点合一;
如有更简单的解法,留言讨论;
运行结果: