CS 223 Digital Design

Section 01

Lab 03

**NAME:** Ferhat

**SURNAME:** Korkmaz

**ID:** 21901940

**DATE:** 08.03.2021

**TRAINER PACK NUMBER:** 14

**b-) Behavioral System Verilog**

module twoToFourDecoder(input logic a, b, output logic y0, y1,y2, y3);

assign y0 = ~a & ~ b;

assign y1 = ~a & b;

assign y2 = a & ~b;

assign y3 = a & b;

endmodule

**Testbench**

module testbenchForTwoToOneDecoder();

logic a,b, y0, y1, y2, y3;

twoToFourDecoder(a, b, y0, y1, y2, y3);

initial begin

a = 0; b = 0;#10;

a = 0; b = 1;#10;

a = 1; b = 0;#10;

a = 1; b = 1;#10;

end

endmodule

**c-)**

**Behavioral System Verilog**

module fourToOneMux(input logic a, b, c, d, s0, s1, output logic y);

assign y = s1 ? ( s0 ? d : c) : ( s0 ? b: a);

endmodule

**Testbench**

module testbenchForFourToOneMux();

logic a,b,c,d,s0,s1,y;

fourToOneMux test(a,b,c,d,s0,s1,y);

initial begin

a = 0; b = 0; c = 0; d = 0; s0 = 0; s1 = 0;#10;

a = 0; b = 0; c = 0; d = 0; s0 = 0; s1 = 1;#10;

a = 0; b = 0; c = 0; d = 0; s0 = 1; s1 = 0;#10;

a = 0; b = 0; c = 0; d = 0; s0 = 1; s1 = 1;#10;

a = 0; b = 0; c = 0; d = 1; s0 = 0; s1 = 0;#10;

a = 0; b = 0; c = 0; d = 1; s0 = 0; s1 = 1;#10;

a = 0; b = 0; c = 0; d = 1; s0 = 1; s1 = 0;#10;

a = 0; b = 0; c = 0; d = 1; s0 = 1; s1 = 1;#10;

a = 0; b = 0; c = 1; d = 0; s0 = 0; s1 = 0;#10;

a = 0; b = 0; c = 1; d = 0; s0 = 0; s1 = 1;#10;

a = 0; b = 0; c = 1; d = 0; s0 = 1; s1 = 0;#10;

a = 0; b = 0; c = 1; d = 0; s0 = 1; s1 = 1;#10;

a = 0; b = 0; c = 1; d = 1; s0 = 0; s1 = 0;#10;

a = 0; b = 0; c = 1; d = 1; s0 = 0; s1 = 1;#10;

a = 0; b = 0; c = 1; d = 1; s0 = 1; s1 = 0;#10;

a = 0; b = 0; c = 1; d = 1; s0 = 1; s1 = 1;#10;

a = 0; b = 1; c = 0; d = 0; s0 = 0; s1 = 0;#10;

a = 0; b = 1; c = 0; d = 0; s0 = 0; s1 = 1;#10;

a = 0; b = 1; c = 0; d = 0; s0 = 1; s1 = 0;#10;

a = 0; b = 1; c = 0; d = 0; s0 = 1; s1 = 1;#10;

a = 0; b = 1; c = 0; d = 1; s0 = 0; s1 = 0;#10;

a = 0; b = 1; c = 0; d = 1; s0 = 0; s1 = 1;#10;

a = 0; b = 1; c = 0; d = 1; s0 = 1; s1 = 0;#10;

a = 0; b = 1; c = 0; d = 1; s0 = 1; s1 = 1;#10;

a = 0; b = 1; c = 1; d = 0; s0 = 0; s1 = 0;#10;

a = 0; b = 1; c = 1; d = 0; s0 = 0; s1 = 1;#10;

a = 0; b = 1; c = 1; d = 0; s0 = 1; s1 = 0;#10;

a = 0; b = 1; c = 1; d = 0; s0 = 1; s1 = 1;#10;

a = 0; b = 1; c = 1; d = 1; s0 = 0; s1 = 0;#10;

a = 0; b = 1; c = 1; d = 1; s0 = 0; s1 = 1;#10;

a = 0; b = 1; c = 1; d = 1; s0 = 1; s1 = 0;#10;

a = 0; b = 1; c = 1; d = 1; s0 = 1; s1 = 1;#10;

a = 1; b = 0; c = 0; d = 0; s0 = 0; s1 = 0;#10;

a = 1; b = 0; c = 0; d = 0; s0 = 0; s1 = 1;#10;

a = 1; b = 0; c = 0; d = 0; s0 = 1; s1 = 0;#10;

a = 1; b = 0; c = 0; d = 0; s0 = 1; s1 = 1;#10;

a = 1; b = 0; c = 0; d = 1; s0 = 0; s1 = 0;#10;

a = 1; b = 0; c = 0; d = 1; s0 = 0; s1 = 1;#10;

a = 1; b = 0; c = 0; d = 1; s0 = 1; s1 = 0;#10;

a = 1; b = 0; c = 0; d = 1; s0 = 1; s1 = 1;#10;

a = 1; b = 0; c = 1; d = 0; s0 = 0; s1 = 0;#10;

a = 1; b = 0; c = 1; d = 0; s0 = 0; s1 = 1;#10;

a = 1; b = 0; c = 1; d = 0; s0 = 1; s1 = 0;#10;

a = 1; b = 0; c = 1; d = 0; s0 = 1; s1 = 1;#10;

a = 1; b = 0; c = 1; d = 1; s0 = 0; s1 = 0;#10;

a = 1; b = 0; c = 1; d = 1; s0 = 0; s1 = 1;#10;

a = 1; b = 0; c = 1; d = 1; s0 = 1; s1 = 0;#10;

a = 1; b = 0; c = 1; d = 1; s0 = 1; s1 = 1;#10;

a = 1; b = 1; c = 0; d = 0; s0 = 0; s1 = 0;#10;

a = 1; b = 1; c = 0; d = 0; s0 = 0; s1 = 1;#10;

a = 1; b = 1; c = 0; d = 0; s0 = 1; s1 = 0;#10;

a = 1; b = 1; c = 0; d = 0; s0 = 1; s1 = 1;#10;

a = 1; b = 1; c = 0; d = 1; s0 = 0; s1 = 0;#10;

a = 1; b = 1; c = 0; d = 1; s0 = 0; s1 = 1;#10;

a = 1; b = 1; c = 0; d = 1; s0 = 1; s1 = 0;#10;

a = 1; b = 1; c = 0; d = 1; s0 = 1; s1 = 1;#10;

a = 1; b = 1; c = 1; d = 0; s0 = 0; s1 = 0;#10;

a = 1; b = 1; c = 1; d = 0; s0 = 0; s1 = 1;#10;

a = 1; b = 1; c = 1; d = 0; s0 = 1; s1 = 0;#10;

a = 1; b = 1; c = 1; d = 0; s0 = 1; s1 = 1;#10;

a = 1; b = 1; c = 1; d = 1; s0 = 0; s1 = 0;#10;

a = 1; b = 1; c = 1; d = 1; s0 = 0; s1 = 1;#10;

a = 1; b = 1; c = 1; d = 1; s0 = 1; s1 = 0;#10;

a = 1; b = 1; c = 1; d = 1; s0 = 1; s1 = 1;#10;

end

endmodule

**d-) Schematic**

D0

D1

D2

D3

D4

D5

D6

D7

S2

S0 S1

S0 S1

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKAAAABOCAMAAACQX+3tAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAD2UExURQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgICAcHBwcHBwYGBgUFBQUFBQUFBQUFBQQEBAQEBAQEBAQEBAMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwUFBQUFBQUFBQUFBQQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAMDAwMDAwMDAwUFBQUFBQUFBQQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAMDAwUFBQQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBEVWMtQAAABRdFJOUwAEBQkKCw0PERIVFh4iJicoLzM0ODk7QURJTVBTVVhZWlxham5vdnl6goWHioyOj5CUlZejqaqvsbK1tri6w8rLz9PV2t7h5ebr7PHz9ff7/tKvqwUAAAAJcEhZcwAAIdUAACHVAQSctJ0AAAKzSURBVGhDzZrpVhNBEEZHURFUEFlUXMAFxX3DlSgobhAUef+XcZK6nUAyge7U1xPuv6+66laTcHJISDGQ9f3BrJfM0TcyXnGZCJpTzNQL2+N5zWBtsDeR00zXwF9WpvMLQ25YNxw7SHLynl3FO4MYzw9E2WDPPrGfhZd0DIbOPMxEL9mksxJ6csCG2BUPae9jjQY511lAjGKHmR4yvfxgT32Wphg7xCMOpawgJ6ZwjtEDfOFICeoXxESY7nKXAx1rmInpMN+BsoznAi+KAFUV2wrtYyQGRRUiKxqDmoY/Kqd5DEoSHK80PYxjakFJglD5EVfJJUoC/pmR5MRcLS5T8fPNhDNEJx/MVnKbih+EJDfohL+HmXzyH5kkAKFMqbW1wKhyIhsnKkApumB4gSVKQKl9CEkS7kidUhngXCH6QEbS8EQpVbo6IL1CdIGLJALpWaILXCQRSM8QXeAiiUB6kegCF0kE0gtEF7hIIpCOEV3gIolAOkF0gYskQilVugI4T/wFSU6kMgPlib1geLO9SHaCjaQAo0qptZUglBnFus79vpPd4CO5QacTjml92PTPiOhdHTbh/aTPcPjPi+jPGAMjyQWqklNUFKAkOTiPqeQaJQk4ScODpwUVDbvm9H4+OGuaNpREaKRY2lBSobDiaPOTmgy8pGHAYFDT8dTrtfkARSG+D/nv23SAqpKrHjWzgS3KUvbMTUph0Sa7UNeyNKT8HnNdOFCDfZsYx02mDsCJnnR/1bc+OMoAC2I30H2YXQ6zwI5l4lH8prcHTjPRjNsSvjbQxycassGer8R+lumo4i09GWFT1QO4wdEgntGXF5btEYv5eSrHQHt2WJfGLYbrgJXxfGawJpK+ZPuAoTph9bFM0l83rD+CN6u0jgZuUUFzmpaRwmXaNBqNG5TrpSj+AwLNa1uYQzsnAAAAAElFTkSuQmCC)

Y

**Structural System Verilog**

module eightToOneMux(input logic d0, d1, d2, d3, d4, d5, d6, d7, s0, s1, s2, output logic y);

logic a, b, c, d, e;

fourToOneMux mux1 (d0, d1, d2, d3, s0, s1, a);

fourToOneMux mux2(d4, d5, d6, d7, s0, s1, b);

and(d, b, s2);

not(e, s2);

and(c, a, e);

or(y, c, d);

endmodule

**Testbench**

module testbenchForEightToOneMux();

logic d0, d1, d2, d3, d4, d5, d6, d7, s0, s1, s2, y;

eightToOneMux mux(d0, d1, d2, d3, d4 ,d5, d6, d7, s0, s1, s2, y);

initial begin

d0 = 0; d1 = 0; d2 = 1; d3 = 1; d4 = 0; d5 = 0; d6 = 1; d7 = 1; s0 = 0; s1 = 0; s2 = 0; #10;

d0 = 0; d1 = 0; d2 = 1; d3 = 1; d4 = 0; d5 = 0; d6 = 1; d7 = 1; s0 = 0; s1 = 0; s2 = 1; #10;

d0 = 0; d1 = 0; d2 = 1; d3 = 1; d4 = 0; d5 = 0; d6 = 1; d7 = 1; s0 = 0; s1 = 1; s2 = 0; #10;

d0 = 0; d1 = 0; d2 = 1; d3 = 1; d4 = 0; d5 = 0; d6 = 1; d7 = 1; s0 = 0; s1 = 1; s2 = 1; #10;

d0 = 0; d1 = 0; d2 = 1; d3 = 1; d4 = 0; d5 = 0; d6 = 1; d7 = 1; s0 = 1; s1 = 0; s2 = 0; #10;

d0 = 0; d1 = 0; d2 = 1; d3 = 1; d4 = 0; d5 = 0; d6 = 1; d7 = 1; s0 = 1; s1 = 0; s2 = 1; #10;

d0 = 0; d1 = 0; d2 = 1; d3 = 1; d4 = 0; d5 = 0; d6 = 1; d7 = 1; s0 = 1; s1 = 1; s2 = 0; #10;

d0 = 0; d1 = 0; d2 = 1; d3 = 1; d4 = 0; d5 = 0; d6 = 1; d7 = 1; s0 = 1; s1 = 1; s2 = 1; #10;

end

endmodule

**e-)**

S3 S2 S1

000

001

010

011

100

101

110

111

S0

VDD

Y

**System Verilog Module**

module eightToOneMuxForF(input logic s0, s1, s2, s3, output logic y);

eightToOneMux forF(s0, ~s0, s0, s0, 1, ~s0, ~s0, s0, s1, s2, s3, y);

endmodule

**TESTBENCH**

module testbenchForEightToOneMuxForF();

logic s0,s1,s2,s3,y;

eightToOneMuxForF test(s0 ,s1 ,s2 , s3, y);

initial begin

s0 = 0; s1 = 0; s2 = 0; s3 = 0;#10;

s0 = 0; s1 = 0; s2 = 0; s3 = 1;#10;

s0 = 0; s1 = 0; s2 = 1; s3 = 0;#10;

s0 = 0; s1 = 0; s2 = 1; s3 = 1;#10;

s0 = 0; s1 = 1; s2 = 0; s3 = 0;#10;

s0 = 0; s1 = 1; s2 = 0; s3 = 1;#10;

s0 = 0; s1 = 1; s2 = 1; s3 = 0;#10;

s0 = 0; s1 = 1; s2 = 1; s3 = 1;#10;

s0 = 1; s1 = 0; s2 = 0; s3 = 0;#10;

s0 = 1; s1 = 0; s2 = 0; s3 = 1;#10;

s0 = 1; s1 = 0; s2 = 1; s3 = 0;#10;

s0 = 1; s1 = 0; s2 = 1; s3 = 1;#10;

s0 = 1; s1 = 1; s2 = 0; s3 = 0;#10;

s0 = 1; s1 = 1; s2 = 0; s3 = 1;#10;

s0 = 1; s1 = 1; s2 = 1; s3 = 0;#10;

s0 = 1; s1 = 1; s2 = 1; s3 = 1;#10;

end

endmodule