nand2tetris/projects/02/FullAdder.hdl

23 lines
563 B
Plaintext
Raw Normal View History

2020-05-19 12:42:52 +00:00
// 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/02/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:
2020-05-20 11:08:32 +00:00
HalfAdder(a=b, b=c, sum=is, carry=ic);
Not(in=is, out=nis);
Mux(a=is, b=nis, sel=a, out=sum);
Or(a=is, b=ic, out=carryifaisone);
Mux(a=ic, b=carryifaisone, sel=a, out=carry);
}