Files
eceg431/02/FullAdder.hdl
Sean O'Connor 2b3da7a171 Implement Project 2: Arithmetic Logic Unit
 HalfAdder: XOR for sum, AND for carry
 FullAdder: Two half adders + OR
 Add16: Chain of 16 full adders with carry
 Inc16: Add16 with constant 1
 ALU: Complete arithmetic logic unit with all operations

Used concise, student-style comments throughout.
2025-08-30 19:49:23 -04:00

19 lines
546 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:
// Two half adders + OR gate
HalfAdder(a=a, b=b, sum=tmp1, carry=tmp2);
HalfAdder(a=tmp1, b=c, sum=sum, carry=tmp3);
Or(a=tmp2, b=tmp3, out=carry);
}