Files
nand2tetris/projects/01/DMux8Way.hdl
2021-04-21 17:01:42 +03:00

32 lines
946 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/01/DMux8Way.hdl
/**
* 8-way demultiplexor:
* {a, b, c, d, e, f, g, h} = {in, 0, 0, 0, 0, 0, 0, 0} if sel == 000
* {0, in, 0, 0, 0, 0, 0, 0} if sel == 001
* etc.
* {0, 0, 0, 0, 0, 0, 0, in} if sel == 111
*/
CHIP DMux8Way {
IN in, sel[3];
OUT a, b, c, d, e, f, g, h;
PARTS:
DMux4Way(in=in, sel=sel[0..1], a=pa, b=pb, c=pc, d=pd);
DMux4Way(in=in, sel=sel[0..1], a=pe, b=pf, c=pg, d=ph);
Not(in=sel[2], out=notsel2);
And(a=pa, b=notsel2, out=a);
And(a=pb, b=notsel2, out=b);
And(a=pc, b=notsel2, out=c);
And(a=pd, b=notsel2, out=d);
And(a=pe, b=sel[2], out=e);
And(a=pf, b=sel[2], out=f);
And(a=pg, b=sel[2], out=g);
And(a=ph, b=sel[2], out=h);
}