

## Lab Member

Table Number : <24>

| Name                        | Student Number |
|-----------------------------|----------------|
| Nantapong Ruangsukswiwong   | 6632107621     |
| Worralop Srichainont        | 6632200221     |
| Weerapat Lerdcharoenvorakul | 6632209021     |
| Pakapim Eua-anant           | 6632162021     |

## Objectives

1. Introducing the workflow of the FPGA development.
2. Understand the combinational logic on Verilog.

## 7-Segments Display on Basys3 Board

The Basys 3 board features a four-digit common anode seven-segment LED display. Each digit consists of 8 LEDs, corresponding to segments A, B, C, D, E, F, G, and DP, as illustrated in Figure 1. All LEDs within the same digit share a common anode. Additionally, identical segments across all digits share the same cathode; for instance, the "A" segments in all digits are connected to the same cathode pin, labeled CA. This configuration minimizes the number of pins required to control the 7-segment display.



**Figure 1 : 7-Segment Display Configuration**

To illuminate each segment, the corresponding anode (AN) must be set to 0. As shown in Figure 2, each anode is connected to a transistor, and setting the corresponding cathode (CX) to 0 allows current to flow from the anode to the cathode, thereby turning on the segment.



Figure 2 : 7-Segment Display Pin

To illuminate multiple digits simultaneously, a technique called multiplexing is used. This involves rapidly turning each digit on and off at a rate imperceptible to the human eye. However, this functionality is not the focus of this lab exercise and the module handling this functionality will be provided.

## Lab Exercise

In this lab exercise, you are tasked with developing a system that takes input from 8 onboard switches (SW0 to SW7) to represent two hexadecimal values. SW0 to SW3 form the first hexadecimal value, with SW0 as the least significant bit (LSB), while SW4 to SW7 form the second hexadecimal value, with SW4 as the LSB. The system should display the first hexadecimal value on the first digit of the 7-segment display and the second hexadecimal value on the second digit. The third and fourth digits of the 7-segment display will not be used.



**Figure 3: System Overview.**

Figure 3 illustrates the System Overview to be implemented in this lab exercise. The system comprises four modules: **System**, **Multiplexer**, **SevenSegmentDecoder**, and **Controller**. The roles of each module are as follows:

1. **System Module**: Serves as the top-level module, integrating and connecting the other submodules.
2. **Multiplexer Module**: Selects which hexadecimal value is sent to the SevenSegmentDecoder module for translation into control signals for the 7-segment display.
3. **SevenSegmentDecoder Module**: Converts a 4-bit binary input into control signals for the segments of the 7-segment display.

4. **Controller Module:** Controls the on/off cycling of each digit on the 7-segment display to ensure all digits appear visible to the observer. It does this by sending a selector signal to the Multiplexer to determine the active switch data and manipulating the AN signal to turn each digit on or off. **This module is pre-implemented for you.**

## Part 1 : Multiplexer

In this part of the lab, you are tasked with completing the **Multiplexer** module. The module has 3 input ports: **In0[3:0]**, **In1[3:0]**, and **Selector**, and 1 output port: **DataOut[3:0]**. The module must be implemented as combinational logic according to the truth table provided below.

| Selector | DataOut [3:0] |
|----------|---------------|
| 0        | In0           |
| 1        | In1           |

**Table 1: Multiplexer Truth table**

### Instruction

1. Create a new project and import all the necessary files from the following source:

<https://github.com/2110363-HW-SYN-LAB/lab/tree/main/Lab1> or MCV.

Follow the instructions provided in the Lab1 Guide file for setup.

2. Modify the **Multiplexer** module to implement the behavior described in the truth table above

Insert your modified Multiplexer module here



```

MultiplexerTB.v x Multiplexer.v x Untitled 3 x
C:/Users/TEAM/HW_synLab/lab-main/Lab1/src/Multiplexer.v

Q | H | ← | → | X | D | F | X | // | W | Q |

9 // Description: Multiplexer module to select between two hexadecimals input for 7-segment display
10 //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
11
12
13 module Multiplexer (
14     input wire [3:0] In0,
15     input wire [3:0] In1,
16     input wire Selector,
17     output wire [3:0] DataOut
18 );
19 // Add code here //
20     assign DataOut = (Selector) ? In1 : In0;
21 // End of code //
22
23 // cocotb dump waveforms
24 `ifndef COCOTB_SIM
25     initial begin
26         $dumpfile("waveform.vcd"); // Name of the dump file
27         $dumpvars(0, Multiplexer); // Dump all variables for the top module
28     end
29 `endif
30
31 endmodule

```

3. Run the testbench to verify that your module functions correctly.

Insert your Xilinx testbench (MultiplexerTB) result here.

```

Tcl Console  × Messages  | Log  |
Q | F | D | II | B | W | R | S | 

# set curr_wave [current_wave_config]
# if { [string length $curr_wave] == 0 } {
#   if { [llength [get_objects]] > 0 } {
#     add_wave /
#     set_property needs_save false [current_wave_config]
#   } else {
#     send_msg_id Add_Wave-1 WARNING "No top level signals found. Simulator will start without a wave window. If you want to open a
#   }
# }
# run 1000ns
All test cases pass
$finish called at time : 512 ns : File "C:/Users/TEAM/HW_synLab/lab-main/Lab1/sim/MultiplexerTB.v" Line 68
INFO: [USF-XSim-96] XSim completed. Design snapshot 'MultiplexerTB_behav' loaded.
INFO: [USF-XSim-97] XSim simulation ran for 1000ns
launch_simulation: Time (s): cpu = 00:00:01 ; elapsed = 00:00:07 . Memory (MB): peak = 1268.730 ; gain = 0.000
run all

```

Insert your Cocotb testbench result (from folder /cocotb/MultiplexerTB/) here.

```

Command Prompt - conda in  × + ▾

registered
    0.00ns INFO      cocotb
    0.00ns INFO      cocotb
nvs\cocotb\lib\site-packages\cocotb
    0.00ns INFO      cocotb
    0.00ns INFO      cocotb.regression
    0.00ns INFO      cocotb.regression

    0.00ns INFO      cocotb.Multiplexer
VCD info: dumpfile waveform.vcd opened for output.
    512.00ns INFO      cocotb.Multiplexer
    512.00ns INFO      cocotb.regression
    512.00ns INFO      cocotb.regression
*****
E (s)  RATIO (ns/s) **
*****
0.03      16377.78  **
*****
0.08      6498.40   **

make[1]: Leaving directory '/c/Users/TEAM/HW_synLab/lab-main/Lab1/cocotb/MultiplexerTB'
(cocotb) C:\Users\TEAM\HW_synLab\lab-main\Lab1\cocotb\MultiplexerTB>

```

Insert your testbench result waveform here. (Either Cocotb or Xilinx Testbench)



4. Call TA to inspect your work.

## Part 2 : 7-Segment Decoder

In this part of the lab, you are tasked with completing the **SevenSegmentDecoder** module. This module has 1 input port: **DataIn[3:0]** and 1 output port: **Segments[7:0]**. The output segments are assigned as follows: **[CA, CB, CC, CD, CE, CF, CG, DP]**, where **CA** corresponds to **Segments[7]** and **DP** corresponds to **Segments[0]**.

This module must be implemented as combinational logic. The **DP** signal controls the decimal point (dot) on the 7-segment display. For this lab exercise, the decimal point should remain turned off.



**Figure 4 : 7-Segment Display of hexadecimal value**

### Instruction

1. Complete the truth table below, which converts 4 bit **DataIn** to the corresponding **Segments[7:0]**.

| DataIn [3:0] | Segments [7:0] |
|--------------|----------------|
| 0000         | 00000011       |
| 0001         | 10011111       |
| 0010         | 00100101       |
| 0011         | 00001101       |
| 0100         | 10011001       |
| 0101         | 01001001       |
| 0110         | 01000001       |

|      |          |
|------|----------|
| 0111 | 00011111 |
| 1000 | 00000001 |
| 1001 | 00001001 |
| 1010 | 00010001 |
| 1011 | 11000001 |
| 1100 | 01100011 |
| 1101 | 10000101 |
| 1110 | 01100001 |
| 1111 | 01110001 |

3. Create a testbench for this module to verify that it works correctly. You will need to create both **Xilinx** and **Cocotb** testbenches:

Insert your Xilinx testbench file (*SevenSegmentDecoderTB*) here.

```

`timescale 1ns / 1ps
///////////////////////////////
///////////////////
// Create Date: 12/23/2024 05:07:14 AM
// Design Name: Exercise1
// Module Name: SevenSegmentDecoderTB
// Project Name: Exercise1
// Target Devices: Basys3
// Tool Versions: 2023.2
// Description: Testbench for the SevenSegmentDecoder module
///////////////////////////////
///////////////////

module SevenSegmentDecoderTB ();
    // Declare the reg/wire
    reg [3:0] DataIn;                                // Input to the
SevenSegmentDecoder
    wire [7:0] Segments;                            // Output from the
SevenSegmentDecoder
    reg [7:0] segment_values[15:0];      // Expected segment patterns
for each DataIn value

    // Instantiate the SevenSegmentDecoder module

```

```
SevenSegmentDecoder SevenSegmentDecoderInst (
    .DataIn  (DataIn),
    .Segments(Segments)
);

// Instantiate variable
integer flag = 0;                                // Flag to track if any test
case fails
    integer TestCaseNo = 0;                         // Counter for test cases
    integer i;                                     // Loop variable

// Task to check the output
task check_output;
    input integer TestCaseNo;
    input reg [7:0] expected_Segments; // Expected output
begin
    if (Segments !== expected_Segments) begin
        $error("ERROR: TestCaseNo %0d | Time = %0t | DataIn = %b |
Segments = %b (Expected: %b)",
                TestCaseNo, $time, DataIn, Segments,
expected_Segments);
        flag = 1;
    end
end
endtask

// Test cases
initial begin
    // Initialize the expected segment values
    segment_values[4'b0000] = 8'b00000011; // '0'
    segment_values[4'b0001] = 8'b10011111; // '1'
    segment_values[4'b0010] = 8'b00100101; // '2'
    segment_values[4'b0011] = 8'b00001101; // '3'
    segment_values[4'b0100] = 8'b10011001; // '4'
    segment_values[4'b0101] = 8'b01001001; // '5'
    segment_values[4'b0110] = 8'b01000001; // '6'
    segment_values[4'b0111] = 8'b00011111; // '7'
    segment_values[4'b1000] = 8'b00000001; // '8'
    segment_values[4'b1001] = 8'b00001001; // '9'
    segment_values[4'b1010] = 8'b00010001; // 'A'
    segment_values[4'b1011] = 8'b11000001; // 'b'
    segment_values[4'b1100] = 8'b01100011; // 'C'
```

```

segment_values[4'b1101] = 8'b10000101; // 'd'
segment_values[4'b1110] = 8'b01100001; // 'E'
segment_values[4'b1111] = 8'b01110001; // 'F'

// Apply test cases for all DataIn values (0-15)
for (i = 0; i < 16; i = i + 1) begin
    DataIn = i[3:0];                                // Set the input
    #10;                                         // Wait for 10 time units
    check_output(TestCaseNo, segment_values[i]); // Check output
    TestCaseNo = TestCaseNo + 1;           // Increment test case number
end

// Final test results
if (flag == 0) begin
    $display("All test cases pass");
end else begin
    $display("Some test cases fail");
end
$finish;
end
endmodule

```

Insert your Cocotb testbench file (from folder /cocotb/SevenSegmentDecoderTB/) here.

```

import cocotb
from cocotb.triggers import Timer

@cocotb.test()
async def SevenSegmentDecoderTB(dut):
    """Try accessing the design."""
    dut._log.info("Running test!")
    # create a testbench here
    test_cases = {
        0x0: 0b00000011, # 0
        0x1: 0b10011111, # 1
        0x2: 0b00100101, # 2
        0x3: 0b00001101, # 3
        0x4: 0b10011001, # 4
        0x5: 0b01001001, # 5
        0x6: 0b01000001, # 6
    }

```

```

    0x7: 0b00011111, # 7
    0x8: 0b00000001, # 8
    0x9: 0b00001001, # 9
    0xA: 0b00010001, # A
    0xB: 0b11000001, # B
    0xC: 0b01100011, # C
    0xD: 0b10000101, # D
    0xE: 0b01100001, # E
    0xF: 0b01110001, # F
}

for DataIn, expected_segments in test_cases.items() :
    #assign data input
    dut.DataIn.value = DataIn
    #wait to change
    await Timer(1, units='ns')

    assert dut.Segments.value == expected_segments

dut._log.info("Test Complete")

```

4. Modify the **SevenSegmentDecoder** module to work according to the truth table.

[Submit your modified 7SegmentDecoder module here.](#)

```

`timescale 1ns / 1ps
///////////////////////////////
///////////////////
// Create Date: 12/23/2024 04:17:24 AM
// Design Name: Exercisel
// Module Name: SevenSegmentDecoder
// Project Name: Exercisel
// Target Devices: Basys3
// Tool Versions: 2023.2
// Description: Decoder for 7-segment display
///////////////////////////////
///////////////////

module SevenSegmentDecoder (
    input wire [3:0] DataIn,           // 4-bit input
    output wire [7:0] Segments        // 8-bit output (active low)
);

```

```

// Declare intermediate reg to hold the value
reg [7:0] Segments_Reg;

// Continuous assignment from reg to wire
assign Segments = Segments_Reg;

// Combinational logic for 7-segment decoding
always @(*) begin
    case (DataIn)
        4'b0000: Segments_Reg = 8'b00000011; // Display '0'
        4'b0001: Segments_Reg = 8'b10011111; // Display '1'
        4'b0010: Segments_Reg = 8'b00100101; // Display '2'
        4'b0011: Segments_Reg = 8'b00001101; // Display '3'
        4'b0100: Segments_Reg = 8'b10011001; // Display '4'
        4'b0101: Segments_Reg = 8'b01001001; // Display '5'
        4'b0110: Segments_Reg = 8'b01000001; // Display '6'
        4'b0111: Segments_Reg = 8'b00011111; // Display '7'
        4'b1000: Segments_Reg = 8'b00000001; // Display '8'
        4'b1001: Segments_Reg = 8'b00001001; // Display '9'
        4'b1010: Segments_Reg = 8'b00010001; // Display 'A'
        4'b1011: Segments_Reg = 8'b11000001; // Display 'b'
        4'b1100: Segments_Reg = 8'b01100011; // Display 'C'
        4'b1101: Segments_Reg = 8'b10000101; // Display 'd'
        4'b1110: Segments_Reg = 8'b01100001; // Display 'E'
        4'b1111: Segments_Reg = 8'b01110001; // Display 'F'
        default: Segments_Reg = 8'b11111111; // Default: All segments
OFF
    endcase
end

// cocotb dump waveforms
`ifdef COCOTB_SIM
initial begin
    $dumpfile("waveform.vcd"); // Name of the dump file
    $dumpvars(0, SevenSegmentDecoder); // Dump all variables for the
top module
end
`endif

endmodule

```

5. Run the testbench and report the result here.

Insert your Xilinx testbench (SevenSegmentDecoderTB) result here.

```

3 Time resolution is 1 ps
5 source SevenSegmentDecoderTB.tcl
:
# set curr_wave [current_wave_config]
# if { [string length $curr_wave] == 0 } {
#   if { [llength [get_objects]] > 0 } {
#     add_wave /
#     set_property needs_save false [current_wave_config]
#   } else {
#     send_msg_id Add_Wave-1 WARNING "No top level signals found. Simulator will start without a wave window. If you want to open
#   }
# }
# run 1000ns
All test cases pass
$Finish called at time : 160 ns : File "C:/Users/TEAM/HW_synLab/lab-main/Lab1/sim/SevenSegmentDecoderTB.v" Line 76
INFO: [USF-XSim-96] XSim completed. Design snapshot 'SevenSegmentDecoderTB_behav' loaded.
INFO: [USF-XSim-97] XSim simulation ran for 1000ns
5 launch_simulation: Time (s): cpu = 00:00:00 ; elapsed = 00:00:08 . Memory (MB): peak = 1334.734 ; gain = 0.000
run all
:

```

Insert your Cocotb testbench (from folder /cocotb/SevenSegmentDecoderTB/) result here.

```

Command Prompt
registered
  0.00ns INFO    cocotb
  0.00ns INFO    cocotb
nvs\cocotb\lib\site-packages\cocotb
  0.00ns INFO    cocotb
  0.00ns INFO    cocotb.regression
  0.00ns INFO    cocotb.regression

  0.00ns INFO    cocotb.SevenSegmentDecoder
VCD info: dumpfile waveform.vcd opened for output.
  16.00ns INFO    cocotb.SevenSegmentDecoder
  16.00ns INFO    cocotb.regression
  16.00ns INFO    cocotb.regression
*****
E (s)  RATIO (ns/s) **
*****
0.00      inf  **
*****
0.24      67.94  **

*****
make[1]: Leaving directory '/c/Users/TEAM/HW_synLab/lab-main/Lab1/cocotb/SevenSegmentDecoderTB'
(cocotb) C:\Users\TEAM\HW_synLab\lab-main\Lab1\cocotb\SevenSegmentDecoderTB>

```

Insert your testbench result waveform here. (Either Cocotb or Xilinx Testbench)



6. Call TA to inspect your work.

## Part 3 : System Integration

Now that you have completed all the submodules, it's time to integrate them into the **System** module, which will serve as the top module.

### Instruction

1.Modify the System module to connect all the submodules according to figure 3.

[Submit your Modify System Module here](#)

```
`timescale 1ns / 1ps
///////////////////////////////
///////////////////
// Create Date: 12/23/2024 05:07:36 AM
// Design Name: Exercisel
// Module Name: SystemTB
// Project Name: Exercisel
// Target Devices: Basys3
// Tool Versions: 2023.2
// Description: Testbench for the System module
///////////////////
///////////////////

module SystemTB ();
    // declare the reg/wire
    reg [7:0] SW;
    reg      Reset;
    reg      Clk;
    wire [7:0] Segments;
    wire [3:0] AN;
    reg [7:0] segment_values[15:0];

    // instantiate the SevenSegmentDecoder module
    System SystemInst (
        .SW(SW),
        .Reset(Reset),
        .Clk(Clk),
        .Segments(Segments),
        .AN(AN)
    );

```

```
// instantiate variable
integer flag = 0;
integer TestCaseNo = 0;
integer sw;

// task to check the output
task check_output;
    input integer TestCaseNo;
    input reg [7:0] expected_Segments; // Expected output
    input reg [3:0] expected_AN; // Expected output
    begin
        if (Segments !== expected_Segments | AN !== expected_AN) begin
            $error(
                "ERROR: TestCaseNo %0d | Time = %0t | SW = %b, Reset = %b
                | Segments = %b (Expected: %b) | AN = %b (Expected: %b)",
                TestCaseNo, $time, SW, Reset, Segments,
                expected_Segments, AN, expected_AN);
            flag = 1;
        end
    end
endtask

localparam CLK_PERIOD = 2;
always #(CLK_PERIOD / 2.0) Clk = ~Clk;

// test cases
initial begin
    segment_values[4'b0000] = 8'b00000011;
    segment_values[4'b0001] = 8'b10011111;
    segment_values[4'b0010] = 8'b00100101;
    segment_values[4'b0011] = 8'b00001101;
    segment_values[4'b0100] = 8'b10011001;
    segment_values[4'b0101] = 8'b01001001;
    segment_values[4'b0110] = 8'b01000001;
    segment_values[4'b0111] = 8'b00011111;
    segment_values[4'b1000] = 8'b00000001;
    segment_values[4'b1001] = 8'b00001001;
    segment_values[4'b1010] = 8'b00010001;
    segment_values[4'b1011] = 8'b11000001;
    segment_values[4'b1100] = 8'b01100011;
    segment_values[4'b1101] = 8'b10000101;
    segment_values[4'b1110] = 8'b01100001;
```

```

segment_values[4'b1111] = 8'b01110001;
Clk = 0;
Reset = 1;
SW = 8'b0;
#(CLK_PERIOD) Reset = 0;
for (sw = 0; sw < 16; sw = sw + 1) begin
    SW = {4'b0, sw};
    #CLK_PERIOD;
    check_output(TestCaseNo, segment_values[sw], 4'b1110);
    TestCaseNo = TestCaseNo + 1;
end
#(CLK_PERIOD*150000);
for (sw = 0; sw < 16; sw = sw + 1) begin
    SW = {sw, 4'b0};
    #CLK_PERIOD;
    check_output(TestCaseNo, segment_values[sw], 4'b1101);
    TestCaseNo = TestCaseNo + 1;
end
if (flag == 0) begin
    $display("All test cases pass");
end else begin
    $display("Some test cases fail");
end
$finish;
end
endmodule

```

2. Run the testbench to verify your module (either Xilinx or Cocotb one).  
 Insert your testbench (SystemTB) result here.

```

source SystemTB.tcl
# set curr_wave [current_wave_config]
# if { [string length $curr_wave] == 0 } {
#   if { [llength [get_objects]] > 0 } {
#     add_wave /
#     set_property needs_save false [current_wave_config]
#   } else {
#     send_msg_id Add_Wave-1 WARNING "No top level signals found. Simulator will start without a wave window. If you want to open a wave window, run 'add_wave /' first."
#   }
# }
# run 1000ns
INFO: [USF-XSim-96] XSim completed. Design snapshot 'SystemTB_behav' loaded.
INFO: [USF-XSim-97] XSim simulation ran for 1000ns
launch_simulation: Time (s): cpu = 00:00:01 ; elapsed = 00:00:07 . Memory (MB): peak = 1334.734 ; gain = 0.000
run all
All test cases pass
$finish called at time : 300066 ns : File "C:/Users/TEAM/HW_synLab/lab-main/Lab1/sim/SystemTB.v" Line 94

```

3. Call TA to inspect your work.

## Part 4 : Programming the Hardware

Now that the entire system is complete and functions correctly according to the testbench, it is time to generate the bitstream and program it onto the **Basys3** board. To do this, we first need to create a **constraint file** to map the system's inputs and outputs to the appropriate pins on the **Basys3** board. Afterward, we will run synthesis, implementation, and generate the bitstream.

### Instruction

1. Complete this mapping table below to map your system's inputs and outputs onto the **Basys3** pins. This system uses **BTNU** for resetting purposes, and **AN[x]** is used to enable the corresponding digit of the 7-segment display.

**Hint, look up the Basys3 reference manual page 6 and 15.**

| System.v input/output | Basys3 Pins |
|-----------------------|-------------|
| Reset                 | T18         |
| Clk                   | W5          |
| SW[0]                 | V17         |
| SW[1]                 | V16         |
| SW[2]                 | W16         |
| SW[3]                 | W17         |
| SW[4]                 | W15         |
| SW[5]                 | V15         |
| SW[6]                 | W14         |
| SW[7]                 | W13         |
| AN[0]                 | U2          |
| AN[1]                 | U4          |
| AN[2]                 | V4          |
| AN[3]                 | W4          |
| Segments[0]           | V7          |

|             |    |
|-------------|----|
| Segments[1] | U7 |
| Segments[2] | V5 |
| Segments[3] | U5 |
| Segments[4] | V8 |
| Segments[5] | U8 |
| Segments[6] | W6 |
| Segments[7] | W7 |

2. Create the constraint file. Follow the instructions in the Lab1 Guide.

[Submit your constraint file here.](#)

```

set_property PACKAGE_PIN W4 [get_ports {AN[3]}]
set_property PACKAGE_PIN V4 [get_ports {AN[2]}]
set_property PACKAGE_PIN U4 [get_ports {AN[1]}]
set_property PACKAGE_PIN U2 [get_ports {AN[0]}]
set_property PACKAGE_PIN W7 [get_ports {Segments[7]}]
set_property PACKAGE_PIN W6 [get_ports {Segments[6]}]
set_property PACKAGE_PIN U8 [get_ports {Segments[5]}]
set_property PACKAGE_PIN V8 [get_ports {Segments[4]}]
set_property PACKAGE_PIN V5 [get_ports {Segments[2]}]
set_property PACKAGE_PIN U5 [get_ports {Segments[3]}]
set_property PACKAGE_PIN U7 [get_ports {Segments[1]}]
set_property PACKAGE_PIN V7 [get_ports {Segments[0]}]
create_clock -period 10.000 -name Clk -waveform {0.000 5.000} -add
[get_ports Clk]

set_property PACKAGE_PIN W13 [get_ports {SW[7]}]
set_property PACKAGE_PIN W14 [get_ports {SW[6]}]
set_property PACKAGE_PIN V15 [get_ports {SW[5]}]
set_property PACKAGE_PIN W15 [get_ports {SW[4]}]
set_property PACKAGE_PIN W17 [get_ports {SW[3]}]
set_property PACKAGE_PIN W16 [get_ports {SW[2]}]
set_property PACKAGE_PIN V16 [get_ports {SW[1]}]
set_property PACKAGE_PIN V17 [get_ports {SW[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {SW[7]}]
set_property IOSTANDARD LVCMOS33 [get_ports {SW[6]}]
set_property IOSTANDARD LVCMOS33 [get_ports {SW[5]}]
set_property IOSTANDARD LVCMOS33 [get_ports {SW[4]}]

```

```
set_property IOSTANDARD LVCMOS33 [get_ports {SW[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {SW[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {SW[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {SW[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {Segments[7]}]
set_property IOSTANDARD LVCMOS33 [get_ports {Segments[6]}]
set_property IOSTANDARD LVCMOS33 [get_ports {Segments[5]}]
set_property IOSTANDARD LVCMOS33 [get_ports {Segments[4]}]
set_property IOSTANDARD LVCMOS33 [get_ports {Segments[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {Segments[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {Segments[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {Segments[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {AN[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {AN[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {AN[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {AN[0]}]
set_property PACKAGE_PIN W5 [get_ports Clk]
set_property PACKAGE_PIN T18 [get_ports Reset]
set_property IOSTANDARD LVCMOS33 [get_ports Clk]
set_property IOSTANDARD LVCMOS33 [get_ports Reset]
```

3. Run the synthesis and then open the Schematic.

Explain what you observed in the schematic and submit a picture of the schematic here.



- Run the implementation, generate the bitstream, and program the **Basys3** device.

[Take a picture of your Board working after programming.](#)



5. Call TA to inspect your work.
6. Submit this sheet to the MCV.