mirror of
https://github.com/soconnor0919/eceg431.git
synced 2025-12-11 06:34:43 -05:00
✅ 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.
18 lines
464 B
Plaintext
18 lines
464 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/HalfAdder.hdl
|
|
/**
|
|
* Computes the sum of two bits.
|
|
*/
|
|
CHIP HalfAdder {
|
|
IN a, b; // 1-bit inputs
|
|
OUT sum, // Right bit of a + b
|
|
carry; // Left bit of a + b
|
|
|
|
PARTS:
|
|
// sum = a XOR b, carry = a AND b
|
|
Xor(a=a, b=b, out=sum);
|
|
And(a=a, b=b, out=carry);
|
|
}
|