summaryrefslogtreecommitdiff
path: root/chips/Xor.hdl
blob: 5ec457994e74dd79db904951aff97570f7617579 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// 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/01/Xor.hdl

/**
 * Exclusive-or gate:
 * out = not (a == b)
 */

CHIP Xor {
    IN a, b;
    OUT out;

    PARTS:
    // Put your code here:
    Not (in=a, out=nota);
    Not (in=b, out=notb);
    And (a=a, b=notb, out=aandnotb);
    And (a=nota, b=b, out=notaandb);
    Or (a=aandnotb, b=notaandb, out=out);
}