



## DIGITAL SYSTEM DESIGN LABORATORY

### LAB 1

---

#### IMPLEMENTATION OF BASIC COMBINATION LOGIC CIRCUIT USING VERILOG

## I. LAB OBJECTIVES

This Lab experiments are intended to implement Basic Combination Logic and Sequential Circuit in Verilog. Students are require to write test bench to simulate the given example code and Top level module to implement these codes in DE2-115 FPGA Kit.

- a) For each experiment write the Verilog Code in three method ( dataflow, behavior and gate level)
- b) For each model, write the Verilog Code to implement the these modules in DE2-FPGA Kit  
(Show implementation results in Lab report)
- c) For each model, Write the testbench to simulate this module.  
(Do this task at home as a Home work 2 and show simulation results in Lab report)
- d) Analyze the FPGA implementation results and simulation results for these model

## II. PROCEDURE

### II.1 LAB EXPERIMENT 1 : WRITE HDL CODE TO REALIZE ALL LOGIC GATES

Refer to the tutorial “Quartus II Introduction Using Verilog Design” to create the first project in Quartus II. implement a simple circuit in DE2-115 Kit.

**AND GATE**



**OR GATE**



**NOT GATE**



| A | B | Output |
|---|---|--------|
| 0 | 0 | 0      |
| 0 | 1 | 0      |
| 1 | 0 | 0      |
| 1 | 1 | 1      |

| A | B | Output |
|---|---|--------|
| 0 | 0 | 0      |
| 0 | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | 1      |

| A | $\bar{A}$ |
|---|-----------|
| 0 | 1         |
| 1 | 0         |

**NAND GATE**



**NOR GATE**



**XOR GATE**



**XNOR GATE**



| A | B | Output |
|---|---|--------|
| 0 | 0 | 1      |
| 0 | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | 0      |

| A | B | Output |
|---|---|--------|
| 0 | 0 | 1      |
| 0 | 1 | 0      |
| 1 | 0 | 0      |
| 1 | 1 | 0      |

| A | B | Output |
|---|---|--------|
| 0 | 0 | 0      |
| 0 | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | 0      |

| A | B | Output |
|---|---|--------|
| 0 | 0 | 1      |
| 0 | 1 | 0      |
| 1 | 0 | 0      |
| 1 | 1 | 1      |

**Top module**

```

module Lab1_EX1(SW,LEDG,LEDR);
    input[17:0] SW;
    output[7:0] LEDG;
    output[17:0] LEDR;
    assign LEDR=SW;
    allgate_DF
DUT(SW[1],SW[0],LEDG[6],LEDG[5],LEDG[4],LEDG[3],LEDG[2],LEDG[1],LEDG[0]);
endmodule

```

| <b>Structural</b>                                                                                                                                                                                                                                                                                                                     | <b>Dataflow</b>                                                                                                                                                                                                                                                                                                                                             | <b>Behavior</b>                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre> module allgate_GL ( a, b, yand,yor,ynot,ynand,ynor,yxor,yx nor );     input a,b;     output yand, yor, ynot, ynand, ynor, yxor, yxnor;      and  G1(yand,a,b);     or   G2(yor,a, b);     not  G3(ynot,a) ;     nand G4 (ynand,a,b);     nor   G5(ynor,a,b);     xor   G6(yxor,a,b);     xnor  G7(yxnor,a,b);  endmodule </pre> | <pre> module allgate_DF ( a, b, yand,yor,ynot,ynand,ynor,yxor,yx nor );     input a,b;     output yand, yor, ynot, ynand, ynor, yxor, yxnor;      assign yand = a &amp; b;     assign yor = a   b;     assign ynot = ~a ;     assign ynand = ~(a &amp; b);     assign ynor = ~(a   b);     assign yxor = a ^ b;     assign yxnor =~(a^b);  endmodule </pre> | <pre> module allgate_BH ( a, b, yand,yor,ynot,ynand,ynor,yxor,yx nor );     input a,b;     output reg yand, yor, ynot, ynand, ynor, yxor, yxnor      always @(*) begin         yand &lt;= a &amp; b;         yor &lt;= a   b;         ynot &lt;= ~a ;         ynand &lt;= ~(a &amp; b);         ynor &lt;= ~(a   b);         yxor &lt;= a ^ b;         yxnor &lt;=~(a^b);      end endmodule </pre> |



## II.2 LAB EXPERIMENT 2 : WRITE VERILOG HDL CODES TO SIMULATE AND IMPLEMENT THE HALF ADDER CIRCUIT:



Truth Table

| A | B | Sum (S) | Carry (Cout) |
|---|---|---------|--------------|
| 0 | 0 | 0       | 0            |
| 0 | 1 | 1       | 0            |
| 1 | 0 | 1       | 0            |
| 1 | 1 | 0       | 1            |

### Top module

```
module Lab1_EX2(SW, LEDG, LEDR);
    input [17:0] SW;
    output [7:0] LEDG;
    output [17:0] LEDR;
    assign LEDR = SW;
    half_adder_DF DUT (
        .a(SW[1]),
        .b(SW[0]),
        .S(LEDG[0]),
        .Cout(LEDG[1])
    );
    assign LEDG[7:2] = 6'b0;
endmodule
```

| Structural                                                                                                                            | Dataflow                                                                                                                                        | Behavior                                                                                                                                                                             |
|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>module half_adder_GL( a, b, S, Cout);     input a,b;     output S,Cout;     xor G1(S,a,b);     and G2(Cout,a,b); endmodule</pre> | <pre>module half_adder_DF( a, b, S, Cout);     input a,b;     output S,Cout;     assign S = a ^ b;     assign Cout = a &amp; b; endmodule</pre> | <pre>module half_adder_BH( a, b, S, Cout);     input a,b;     output reg S,Cout;     always @(a,b) begin         S &lt;= a ^ b;         Cout &lt;= a&amp;b ;     end endmodule</pre> |



### II.3 EXPERIMENT 3: WRITE VERILOG HDL CODES TO SIMULATE AND IMPLEMENT THE FULL ADDER CIRCUIT:



| Inputs |   |          | Outputs |           |
|--------|---|----------|---------|-----------|
| A      | B | $C_{in}$ | S       | $C_{out}$ |
| 0      | 0 | 0        | 0       | 0         |
| 0      | 0 | 1        | 1       | 0         |
| 0      | 1 | 0        | 1       | 0         |
| 0      | 1 | 1        | 0       | 1         |
| 1      | 0 | 0        | 1       | 0         |
| 1      | 0 | 1        | 0       | 1         |
| 1      | 1 | 0        | 0       | 1         |
| 1      | 1 | 1        | 1       | 1         |

#### Top module

```

module Lab1_EX3(SW, LEDG, LEDR);
    input [17:0] SW;
    output [7:0] LEDG;
    output [17:0] LEDR;

    assign LEDR = SW;

    full_adder_GL FA1(
        .a(SW[0]),
        .b(SW[1]),
        .cin(SW[2]),
        .S(LEDG[0]),
        .Cout(LEDG[1])
    );
endmodule

```



| Structural                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Dataflow                                                                                                                                                                                                | Behavior using always                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>module full_adder_GL(a,b,cin,S,Cout);     output S,Cout;     input a,b,cin;     wire x,y,z;      xor g1(x,a,b);     xor g2(S,x,cin);     and g3(y,x,cin);     and g4(z,a,b);     or g5(Cout,z,y); endmodule</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <pre>module full_adder_DF(a, b,     cin,S, Cout);     input a,b,cin;     output S, Cout;     assign S = a ^ b ^ cin;     assign Cout = (a &amp; b)   (b &amp;     cin)   (a &amp; cin); endmodule</pre> | <pre>module full_adder_BH3(a,b,cin,S,Cout);     output reg S,Cout;     input a,b,cin;     always @ (a,b,cin)         begin             S &lt;= a^ b^cin;             Cout &lt;=(a&amp;b)               (b&amp;cin)   (cin&amp;a);         end     endmodule</pre>                                                                                                                                                                                                                                                                                                                                                                                  |
| Behavior using if else                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                         | Behavior using case                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <pre>module full_adder_BH2( a, b, cin, S, Cout);     input wire a, b, cin;     output reg S, Cout;     always @ (a or b or cin) begin         if(a==0 &amp;&amp; b==0 &amp;&amp; cin==0)             begin                 S=0;Cout=0;             end         else if(a==0 &amp;&amp; b==0 &amp;&amp; cin==1)             begin                 S=1;Cout=0;             end         else if(a==0 &amp;&amp; b==1 &amp;&amp; cin==0)             begin                 S=1;Cout=0;             end         else if(a==0 &amp;&amp; b==1 &amp;&amp; cin==1)             begin                 S=0;Cout=1;             end         else if(a==1 &amp;&amp; b==0 &amp;&amp; cin==0)             begin                 S=1;Cout=0;             end         else if(a==1 &amp;&amp; b==0 &amp;&amp; cin==1)             begin                 S=0;Cout=1;             end         else if(a==1 &amp;&amp; b==1 &amp;&amp; cin==0)             begin                 S=0;Cout=1;             end         else if(a==1 &amp;&amp; b==1 &amp;&amp; cin==1)             begin                 S=1;Cout=1;             end     end</pre> |                                                                                                                                                                                                         | <pre>module full_adder_BH1 (a, b, cin, S, Cout);     input a,b,cin;     output reg S,Cout;     always @ (a or b or cin)         begin             case ({a , b , cin})                 3'b000: begin S = 0; Cout = 0; end                 3'b001: begin S = 1; Cout = 0; end                 3'b010: begin S = 1; Cout = 0; end                 3'b011: begin S = 0; Cout = 1; end                 3'b100: begin S = 1; Cout = 0; end                 3'b101: begin S = 0; Cout = 1; end                 3'b110: begin S = 0; Cout = 1; end                 3'b111: begin S = 1; Cout = 1; end             endcase         end     endmodule</pre> |

```

begin
  S=1;Cout=1;
end
end
endmodule

```



#### II.4 EXPERIMENT 4 : WRITE VERILOG HDL CODES TO SIMULATE AND IMPLEMENT THE RIPPLE CARRY ADDER CIRCUIT:

**Ripple Carry Adder-Truth Table**



| $A_1$ | $A_2$ | $A_3$ | $A_4$ | $B_4$ | $B_3$ | $B_2$ | $B_1$ | $S_4$ | $S_3$ | $S_2$ | $S_1$ | Carry |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 1     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1     | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |
| 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 0     | 1     | 0     | 0     | 1     |
| 1     | 1     | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 0     | 0     | 0     | 1     |
| 1     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1     | 1     | 0     | 0     | 1     |
| 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 0     |



### Top module

```
module Lab1_ex4(SW,LEDG,LEDR);
```

```
endmodule
```

| Structural                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Dataflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Behavior                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>module full_adder_STRU(a,b,cin,s,cout);     output s,cout;     input a,b,cin;     wire x,y,z;     xor g1(x,a,b);     xor g2(s,x,cin);     and g3(y,x,cin);     and g4(z,a,b);     or g5(cout,y,z); endmodule  module four_bit_adder_STRU(cin,a,b, s,cout);     input [3:0] a,b;     input cin;     output [3:0] s;     output cout;     wire [2:0] w_carry;     full_adder_STRU C1(a[0],b[0],cin,s[0], w_carry[0]);     full_adder_STRU C2(a[1],b[1], w_carry[0],s[1], w_carry[1]);     full_adder_STRU C3(a[2],b[2], w_carry[1],s[2], w_carry[2]);     full_adder_STRU C4(a[3],b[3], w_carry[2],s[3], cout); endmodule</pre> | <pre>module full_adder_DF(a,b,cin,s,cout);     input a, b, cin;     output Sum, Carry;     assign Sum = a ^ b ^ cin;     assign Carry = (a &amp; b)   (b &amp; cin)   (cin &amp; a); endmodule  module four_bit_adder_DF(a,b,cin,s,cout);     input [3:0] a, b;     input cin;     output [3:0] s;     output cout;     wire [3:0] carry;     // Assign carry for each bit     assign carry[0] = (a[0] &amp; b[0])   (b[0] &amp; cin)   (cin &amp; a[0]);     assign carry[1] = (a[1] &amp; b[1])   (b[1] &amp; carry[0])   (carry[0] &amp; a[1]);     assign carry[2] = (a[2] &amp; b[2])   (b[2] &amp; carry[1])   (carry[1] &amp; a[2]);     assign carry[3] = (a[3] &amp; b[3])   (b[3] &amp; carry[2])   (carry[2] &amp; a[3]);     // Assign sum for each bit     assign s[0] = a[0] ^ b[0] ^ cin;     assign s[1] = a[1] ^ b[1] ^ carry[0];     assign s[2] = a[2] ^ b[2] ^ carry[1];</pre> | <pre>module half_adder_BH( a, b, s, cout);     input a,b;     output reg s,cout;     always @(a,b) begin         s &lt;= a ^ b;         cout &lt;= a&amp;b ;     end endmodule  module four_bit_adder_BH(a,b,cin,s,co ut);     input [3:0] a, b;     input cin;     output reg [3:0] s;     output reg cout;     reg [3:0] carry;     always @(*) begin         // Compute sums and         carries for each bit using non- blocking assignments         s[0] &lt;= a[0] ^ b[0] ^ cin;         carry[0] &lt;= (a[0] &amp; b[0])   (b[0] &amp; cin)   (cin &amp; a[0]);         s[1] &lt;= a[1] ^ b[1] ^ carry[0];         carry[1] &lt;= (a[1] &amp; b[1])   (b[1] &amp; carry[0])   (carry[0] &amp; a[1]);         s[2] &lt;= a[2] ^ b[2] ^ carry[1];         carry[2] &lt;= (a[2] &amp; b[2])  </pre> |

|  |                                                                                                                 |                                                                                                                                                                                              |
|--|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <pre> assign s[3] = a[3] ^ b[3] ^ carry[2];  // Assign final carry-out assign cout = carry[3]; endmodule </pre> | <pre> (b[2] &amp; carry[1])   (carry[1] &amp; a[2]);   s[3] &lt;= a[3] ^ b[3] ^ carry[2]; cout &lt;= (a[3] &amp; b[3])   (b[3] &amp; carry[2])   (carry[2] &amp; a[3]); end endmodule </pre> |
|--|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|



## II.5 EXPERIMENT 5 : WRITE VERILOG HDL CODES TO SIMULATE AND IMPLEMENT 2:1 MULTIPLEXER CIRCUIT:



**Truth Table**

| sel | y              |
|-----|----------------|
| 0   | i <sub>0</sub> |
| 1   | i <sub>1</sub> |

### Top module

```

module Lab1_EX5(SW,LEDG,LEDR);
    input[17:0] SW;
    output[7:0] LEDG;
    output [17:0] LEDR;

```

assign LEDR=SW;

```
//mux21_DF(.i(SW[2:1]),.sel(SW[0]),.y(LEDG[7]));
//mux21_BEH(.i(SW[2:1]),.sel(SW[0]),.y(LEDG[7]));
mux21_GL(.i(SW[2:1]),.sel(SW[0]),.y(LEDG[7]));
endmodule
```

| <b>Structural</b>                                                                                                                                                                                            | <b>Dataflow</b>                                                                                                                          | <b>Behavior</b>                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>module mux21_GL(i,sel,y);   input sel;   input [1:0] i;   output y;   wire net1,net2,net3;   not g1(net1,sel);   and g2(net2,i[1],sel);   and g3(net3,i[0],net1);   or g4(y,net3,net2); endmodule</pre> | <pre>module mux21_DF(i,sel,y);   input sel;   input [1:0] i;   output y;   assign y   =(i[0]&amp;(~sel)) (i[1]&amp;sel); endmodule</pre> | <pre>module mux21_BEH(i,sel,y);   input sel;   input [1:0] i;   output reg y;   always@(*) begin     if(sel==0) y=i[0];     if(sel==1)y=i[1];   end endmodule</pre> |



## II.6 EXPERIMENT 6 : WRITE VERILOG HDL CODES TO SIMULATE AND IMPLEMENT 4:1 MULTIPLEXER CIRCUIT:



**Block Diagram**



**Truth Table**

| <b>sel[0]</b> | <b>sel[1]</b> | <b>y</b>       |
|---------------|---------------|----------------|
| 0             | 0             | i <sub>0</sub> |
| 0             | 1             | i <sub>1</sub> |
| 1             | 0             | i <sub>2</sub> |
| 1             | 1             | i <sub>3</sub> |



### Top module

```
module Lab1_EX6(SW,LEDR,LEDG);
```

```
endmodule
```

| Structural                                                                                                                                                                                                                                                                                                                                           | Dataflow                                                                                                                                                                                                                             | Behavior                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>module mux41_GL(i,s,y);   input [3:0] i;   input [1:0] s;   output y;   wire [1:0] n_s;   wire [3:0]a;   not g0(n_s[0],s[0]);   not g1(n_s[1],s[1]);   and   g2(a[0],i[0],n_s[0],n_s[1]);   and   g3(a[1],i[1],n_s[1],s[0]);   and   g4(a[2],i[2],s[1],n_s[0]);   and g5(a[3],i[3],s[1],s[0]);   or  g6(y,a[0],a[1],a[2],a[3]); endmodule</pre> | <pre>module mux41_df   (i0,i1,i2,i3,s0,s1,y);     input     i0,i1,i2,i3,s0,s1;     output y;     assign y=     i0&amp;(~s1)&amp;(~s0)   i1     &amp;(~s1)&amp;s0       i2&amp;s1&amp;(~s0)       i3&amp;s1&amp;s0;   endmodule</pre> | <pre>module mux41_BEH_v1(i,s,y );   output reg y ;   input [3:0] i ;   input [1:0] s ;   always @ ( i,s ) begin     if (s[1]==0&amp;s[0]==0)       y &lt;= i[0];     else if (s[1]==0&amp;s[0]==1)       y &lt;= i[1];     else if (s[1]==1&amp;s[0]==0)       y &lt;= i[2];     else       y &lt;= i[3];   end endmodule</pre> <p><b>Version 2:</b></p> <pre>module mux41_BEH_v2(i,s,y );   output reg y ;   input [3:0]i;   input [1:0]s;   always@(i,s) begin     case ({s[1],s[0]})       2'b00: y &lt;= i[0];       2'b01: y &lt;= i[1];       2'b10: y &lt;= i[2];       2'b11: y &lt;= i[3];     endcase   end endmodule</pre> |



## II.7 EXPERIMENT 7 : WRITE VERILOG HDL CODES TO SIMULATE AND IMPLEMENT 16:1 MULTIPLEXER CIRCUIT USING STRUCTURAL MODEL FROM FIVE 4:1 MULTIPLEXER MODULE



**16 to 1 Multiplexer**



| Select         |                |                |                | Inputs          |                 |                 |                 |                 |                 |                |                |                |                |                |                |                |                |                |                | Output |   |  |  |
|----------------|----------------|----------------|----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------|---|--|--|
| S <sub>3</sub> | S <sub>2</sub> | S <sub>1</sub> | S <sub>0</sub> | D <sub>15</sub> | D <sub>14</sub> | D <sub>13</sub> | D <sub>12</sub> | D <sub>11</sub> | D <sub>10</sub> | D <sub>9</sub> | D <sub>8</sub> | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |        |   |  |  |
| 0              | 0              | 0              | 0              | X               | X               | X               | X               | X               | X               | X              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      | 1 |  |  |
| 0              | 0              | 0              | 1              | X               | X               | X               | X               | X               | X               | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1              | X      | 1 |  |  |
| 0              | 0              | 1              | 0              | X               | X               | X               | X               | X               | X               | X              | X              | X              | X              | X              | X              | X              | 1              | X              | X              | 1      |   |  |  |
| 0              | 0              | 1              | 1              | X               | X               | X               | X               | X               | X               | X              | X              | X              | X              | X              | X              | 1              | X              | X              | X              | 1      |   |  |  |
| 0              | 1              | 0              | 0              | X               | X               | X               | X               | X               | X               | X              | X              | X              | X              | X              | 1              | X              | X              | X              | X              | 1      |   |  |  |
| 0              | 1              | 0              | 1              | X               | X               | X               | X               | X               | X               | X              | X              | X              | X              | 1              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 0              | 1              | 1              | 0              | X               | X               | X               | X               | X               | X               | X              | X              | 1              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 0              | 1              | 1              | 1              | X               | X               | X               | X               | X               | X               | X              | 1              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 1              | 0              | 0              | 0              | X               | X               | X               | X               | X               | X               | 1              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 1              | 0              | 0              | 1              | X               | X               | X               | X               | X               | 1               | X              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 1              | 0              | 1              | 0              | X               | X               | X               | X               | 1               | X               | X              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 1              | 0              | 1              | 1              | X               | X               | X               | 1               | X               | X               | X              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 1              | 1              | 0              | 0              | X               | X               | 1               | X               | X               | X               | X              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 1              | 1              | 0              | 1              | X               | X               | 1               | X               | X               | X               | X              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 1              | 1              | 1              | 0              | X               | 1               | X               | X               | X               | X               | X              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |
| 1              | 1              | 1              | 1              | X               | X               | X               | X               | X               | X               | X              | X              | X              | X              | X              | X              | X              | X              | X              | X              | 1      |   |  |  |

**Answer code:**

```
module Lab1_EX7(SW,LEDG,LEDR,KEY);
    input [17:0] SW;
    input [3:0] KEY;
    output [7:0] LEDG;
    output [17:0] LEDR;

    assign LEDR = SW;
    assign LEDG[7:4] = KEY;

    mux16_1(.i0(KEY[3:0]),.i(SW[11:0]),.s(SW[17:14]),.y(LEDG[0]));
endmodule

module mux41_GL(i,s,y);
    input [3:0] i;
    input [1:0] s;
    output y;
    wire n_s0,n_s1, a0,a1,a2,a3;
    not g0(n_s0,s[0]);
    not g1(n_s1,s[1]);
    and g2(a0,i[0],n_s0,n_s1);
    and g3(a1,i[1],n_s1,s[0]);
    and g4(a2,i[2],s[1],n_s0);
    and g5(a3,i[3],s[1],s[0]);
    or g6(y,a0,a1,a2,a3);
endmodule

module mux16_1(i0,i,s,y);
    input [3:0] i0;
    input [11:0] i;
    input [3:0] s;
```

```
output y;  
wire [3:0]a;
```

```
mux41_GL(i0[3:0],s[1:0],a[0]);  
mux41_GL(i[3:0],s[1:0],a[1]);  
mux41_GL(i[7:4],s[1:0],a[2]);  
mux41_GL(i[11:8],s[1:0],a[3]);
```

```
mux41_GL(a[3:0],s[3:2],y)  
endmodule
```





#### IV. LAB REPORT GUIDELINES

Students write up a report on the Verilog HDL implementation experiment projects created in this lab. The lab report should include Circuit Schematics, Truth Table, Verilog Module Codes, Verilog test bench codes, Top level module to implement the required circuit in FPGA KIT and evidences of data output evidences to validate the experiments (The Captured Screens, Photo of FPGA Kit implementation results).