Daisy I: Logic gates

All computer chips are made from the same building blocks: elementary logic gates. A logic gate is a physical device that implements a mathematical logic (Boolean) function. The simplest example of a logic gate is the NOT gate. It takes a single input and outputs its inverse. If the signal is ON, the inverter outputs OFF and vice versa. These gates can be constructed in many different ways but their logic behaviour remains consistent across all computers.

For this project, I started with the Nand gate and then built all other gates from it. These standard set of gates were then used to construct the computer’s processing and storage chips.

Nand: the special one

The Nand gate is designed to compute the following Boolean function:

| Input A | Input B | Nand(A, B) |
| ------- | ------- | ---------- |
| 0       | 0       | 1          |
| 0       | 1       | 1          |
| 1       | 0       | 1          |
| 1       | 1       | 0          |

The Nand function has an interesting property. Each one of the operations And, Or and Not can be constructed from it, and it alone.

E.g. x Or y = (x Nand x) Nand (y Nand y)

Since every Boolean function can be constructed from And, Or and Not operations using the canonical representation method, it follows that every Boolean function can be constructed from Nand function alone. This is why Nand gate was chosen as the primitive gate and the foundational element of all other gates in the project.

Elementary gates

  • Nand (primitive)
  • Not
  • And
  • Or
  • Xor
  • Mux
  • Dmux
  • Not16, a 2-input bitwise NOT, where each input is 16 bits wide
  • And16, a 2-input bitwise AND, where each input is 16 bits wide
  • Or16, a 2-input bitwise OR, where each input is 16 bits wide
  • Mux16, a 2-input, 16-bit multiplexor
  • Or8Way, a 8-input OR gate
  • Mux4Way16, a 4-input, 16-bit multiplexor
  • Mux8Way16, a 8-input, 16-bit multiplexor
  • DMux4Way, a 4-output demultiplexor
  • DMux8Way, a 8-output demultiplexor