1-bit full adder using Verilog

1. Requirement: write 1-bit full adder module

  module add1 ( input a, input b, input cin, output sum, output cout );

2. 想法1:画出真值表,列出逻辑表达式,化简

sum =  abc + abc‘ + ab’c+a‘bc;

cout =  abc + ab’c‘ + a’b‘c + a’bc‘;

a

b

cin

sum

cout

1

1

1

1

1

1

1

0

0

1

1

0

0

1

0

1

0

1

0

1

0

1

1

0

1

0

1

0

1

0

0

0

1

1

0

0

0

0

0

0

3. 想法2:用两个半加器组合

半加器只有两个input,经过两个add_half组合得到sum,两个进位相或得到最终的进位。

感觉这种方法更好理解些。

module add_half (input a, input b, output sum, output cout);
    assign sum = a ^ b;
    assign cout = a & b;
endmodule    
    
module add1 ( input a, input b, input cin,   output sum, output cout );
    wire cout_lo, sum_lo, cout_hi;
    add_half add_lo(a, b, sum_lo, cout_lo);
    add_half add_hi(cin, sum_lo, sum, cout_hi);
    
    assign cout = cout_lo | cout_hi;
endmodule

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值