# Pre-lab for Lab3

Xiaoyu Zhou, 1004081147

### Part I

1. Draw a schematic.



2. Write Verilog code for a 7-to-1 multiplexer

```
module mux(LEDR, SW);
         input [9:0] SW;
output [9:0] LEDR;
         mux1 u1(
.in1(SW[0]),
.in2(SW[1]),
.in3(SW[2]),
.in4(SW[3]),
                   .in4($W[5]),
.in5($W[4]),
.in6($W[5]),
.in7($W[6]),
.m($W[9:7]),
.out1(LEDR[0])
);
endmodule
module mux1(in1, in2, in3, in4, in5, in6, in7, m, out1);
         input in1;
input in2;
             input in3;
input in4;
              input in5;
             input in6;
             input in7;
         input m;
output out1; //output
reg out1;
             always @(*)
begin
                      case(m)
                                m)
3'b000: out1 = in1;
3'b001: out1 = in2;
3'b010: out1 = in3;
3'b011: out1 = in4;
3'b100: out1 = in5;
3'b101: out1 = in6;
                                 3'b111: out1 = in7; default: out1 = in1;
                  endcase
end
endmodule
```

3. Simulate the circuit.



### Part II

1. Draw a schematic.



2. Write a Verilog module for the full adder subcircuit and write another Verilog module that instantiates four instances of this full adder.

```
\label{eq:connect3}. \\ \text{s.}(\text{LEDR[3]}), \\ \text{s.}(\text{cout}(\text{LEDR[4]})); \\ \text{endmodule} \\ \\ \text{module full\_adder}(A, B, \text{cin, S, cout}); \\ \\ \text{input A;} \\ \\ \text{input B;} \\ \\ \\ \text{input cin;} \\ \\ \text{output Cout;} \\ \\ \text{assign cout} = A\&B \mid A\&\text{cin} \mid B\&\text{cin;} \\ \\ \\ \text{assign S} = A \land B \land \text{cin;} \\ \\ \end{aligned}
```

#### endmodule

3. Simulate the circuit.



## Part III

1. Draw a schematic.



2. Write a Verilog module for the full adder subcircuit and write another Verilog module that instantiates four instances of this full adder.

module mux(LEDR, SW, KEY, HEX0, HEX1, HEX2, HEX3, HEX4, HEX5); input [9:0] SW;

```
input [2:0] KEY;
output [9:0] LEDR;
      output [6:0] HEX0;
      output [6:0] HEX1;
      output [6:0] HEX2;
      output [6:0] HEX3;
      output [6:0] HEX4;
      output [6:0] HEX5;
      trans u1(
                 .A(SW[7:4]),
                 .B(SW[3:0]),
.in1(KEY[2:0]),
                 .out1(LEDR[7:0])
      hex u2(
                   .in2(LEDR[3]),
.in3(LEDR[2]),
.in4(LEDR[1]),
                   .in4(LEDR[1]),
.in5(LEDR[0]),
.o2(HEX4[6]),
.o3(HEX4[5]),
.o4(HEX4[4]),
.o5(HEX4[3]),
.o6(HEX4[2]),
.o7(HEX4[1]),
.o8(HEX4[0])
      hex u3(
                    .in2(LEDR[7]),
.in3(LEDR[6]),
                    .in4(LEDR[5]),
                   .in5(LEDR[4]),
.o2(HEX5[6]),
                   .o3(HEX5[5]),
.o4(HEX5[4]),
                   .04(HEX5[4]),
.05(HEX5[3]),
.06(HEX5[2]),
.07(HEX5[1]),
.08(HEX5[0])
                    .in2(SW[7]),
                   .in3(SW[6]),
.in4(SW[5]),
.in5(SW[4]),
                   .o2(HEX2[6]),
.o3(HEX2[5]),
                    .o4(HEX2[4]),
                   .o5(HEX2[3]),
.o6(HEX2[2]),
.o7(HEX2[1]),
                    .08(HEX2[0])
      hex B(
                   in2(SW[3]),
in3(SW[2]),
in4(SW[1]),
in5(SW[0]),
.02(HEX0[6]),
.03(HEX0[5]),
.04(HEX0[4]),
.05(HEX0[3]),
.06(HEX0[2]),
.07(HEX0[1]),
.08(HEX0[0])
                    .o8(HEX0[0])
      assign HEX1[6:0] = 0;
      assign HEX3[6:0] = 0;
endmodule
module trans(A, B, in1, out1);
parameter Width = 8;
      parameter Narrow = 4;
      parameter W = 3;
        input [Narrow-1:0] A;
      input [Narrow-1:0] B;
input [W-1:0] in1;
output [Width-1:0]out1;
```

```
reg [Width-1:0]out1;
        always @(*)
        begin
                   case(in1)
                               \begin{array}{l} \text{n11} \\ \text{3'b000: out1} = \{A,B\}; \\ \text{3'b001: out1} = \{A \mid B,A \land B\}; \\ \text{3'b010: out1} = \{A \& B \mid A \& 0 \mid B \& 0,A \land B \land 0\}; \\ \text{3'b011: out1} = A + B; \\ \text{3'b100: out1} = \{A \& 1 \mid A \& 0 \mid 1 \& 0,A \land 1 \land 0\}; \\ \text{3'b101: out1} = |A \mid |B; \\ \text{default: out1} = 8'b0000\_0000; \\ \end{array}
             endcase
       end
endmodule
module hex(in2, in3, in4, in5, o2, o3, o4, o5, o6, o7, o8);
       input in2;
input in3;
input in3;
input in4;
input in5;
output o2;
output o3;
output o4;
output o5;
output o6;
output o6;
output o7:
        output o7;
        output o8;
        hex0 u1(
                     .c3(in2),
                     .c2(in3),
                        .c1(in4),
                     .c0(in5),
.out1(o2)
        hex1 u2(
                     .c3(in2),
                     .c2(in3),
                        .c1(in4),
                     .c0(in5),
                     .out2(o3)
        hex2 u3(
                    .c3(in2),
.c2(in3),
.c1(in4),
                     .c0(in5),
.out3(o4)
         );
hex3 u4(
.c3(in2),
.c2(in3),
.c1(in4),
.c0(in5),
.out4(o5)
          hex4 u5(
                     .c3(in2),
                     .c2(in3),
                     .c1(in4),
.c0(in5),
                     .out5(o6)
          hex5 u6(
                     .c3(in2),
                     .c2(in3),
                        .c1(in4),
                    .c0(in5),
.out6(o7)
          hex6 u7(
                    .c3(in2),
                     .c2(in3),
                     .c1(in4),
.c0(in5),
                     .out7(08)
endmodule
module hex0(c3, c2, c1, c0, out1); input c3; //selected when s is 0
```

```
input c2; //selected when s is 1 input c1; //select signal
             input c0;
             output out1; //output
             assign out1 = \simc3 & c2 & \simc1 & \simc0 | c3 & c2 & \simc1 & c0 | c3 & \simc2 & c1 & c0 | \simc3 & \simc2 & \simc1 & c0;
      module hex1(c3, c2, c1, c0, out2);
            input c3; //selected when s is 0 input c2; //selected when s is 1 input c1; //select signal
             input c0;
             output out2; //output
             assign out2 = c2 & c1 & \sim c0 | c3 & c1 & c0 | \sim c3 & c2 & \sim c1 & c0 | c3 & c2 & \sim c0;
      endmodule
      module hex2(c3, c2, c1, c0, out3);
            input c0; //selected when s is 0 input c2; //selected when s is 1 input c1; //select signal input c0;
             output out3; //output assign out3 = ~c3 & ~c2 & c1 & ~c0 | c3 & c2 & c1 | c3 & c2 & ~c0;
      endmodule
      module hex3(c3, c2, c1, c0, out4);
             input c3; //selected when s is 0 input c2; //selected when s is 1
             input c1; //select signal
             input c0;
             output out4; //output
             assign out4 = \simc3 & c2 & \simc1 & \simc0 | \simc2 & \simc1 & c0 | c2 & c1 & c0 | c3 & \simc2 & c1 & \simc0;
      endmodule
      module hex4(c3, c2, c1, c0, out5);
             input c3; //selected when s is 0 input c2; //selected when s is 1
             input c1; //select signal
             input c0;
             output out5; //output
             assign out5 = \simc3 & c2 & \simc1 | \simc2 & \simc1 & c0 | \simc3 & c0;
      module hex5(c3, c2, c1, c0, out6);
input c3; //selected when s is 0
input c2; //selected when s is 1
            input c1; //select signal input c0;
             output out6; //output
             assign out6 = \simc3 & \simc2 & c0 | \simc3 & \simc2 & c1 | \simc3 & c1 & c0 | c3 & c2 & \simc1 & c0;
      endmodule
      module hex6(c3, c2, c1, c0, out7);
input c3; //selected when s is 0
input c2; //selected when s is 1
             input c1; //select signal
             input c0;
             output out7; //output
             assign out7 = ~c3 & ~c2 & ~c1 | c3 & c2 & ~c1 & ~c0 | ~c3 & c2 & c1 & c0;
endmodule
```

#### 3. Simulate the circuit.

