Files
eceg431/02/FullAdder.hdl

21 lines
606 B
Plaintext

// This file is part of www.nand2tetris.org
// and the book "The Elements of Computing Systems"
// by Nisan and Schocken, MIT Press.
// File name: projects/2/FullAdder.hdl
/**
* Computes the sum of three bits.
*/
CHIP FullAdder {
IN a, b, c; // 1-bit inputs
OUT sum, // Right bit of a + b + c
carry; // Left bit of a + b + c
PARTS:
// add first two inputs
HalfAdder(a=a, b=b, sum=absum, carry=c0);
// add third input to partial sum
HalfAdder(a=absum, b=c, sum=sum, carry=c1);
// combine both carry bits
Or(a=c0, b=c1, out=carry);
}