# 数字逻辑与部件设计实验报告

【实验一: 踢球裁决器】

姓名: 林艺奇 学号: 22300246009 日期: 2023-09-11

#### 一、实验内容

用 HDL 描述是否去踢球的逻辑功能,并在 NEXYS4 开发板上实现验证。判断准则为:如果不下雨,且有空,则去踢球。否则就不去踢球。

## 二、实验方案 设计文件代码如下图所示

```
led.sv (2) × led_Sim.sv (2) × Nexys4DDR_Master.xdc
C:/Users/17145/project_1_YIQI/project_1_YIQI.srcs/sources_1/new/led.sv
Q 🛗 🛧 🥕 🐰 🛅 🛍 🗙 // 🖩 🗘
18 // Additional Comments:
23 module led(
24 | input logic [15:0] SW,
25 output logic [15:0]LED
26
   );//定义端口
     assign LED[0] = SW[0];
27
      assign LED[15] = SW[15];
    assign LED[8] = SW[0]&SW[15];
30
   endmodul e
31
```

其中,SW[15]=1 表示晴天,SW[15]=0 表示下雨。LED[15]反映对应的 SW[15]高低。

SW[0] = 1 表示有空,SW[0] = 0 表示没空。LED[0]反映对应的 SW[0]高低。 LED[8] 高表示去踢球,否则表示不去踢球。

#### 仿真文件代码如下图所示:

```
× Nexys4DDR_Master.xdc
led.sv (2)
          × led_Sim.sv (2)
C:/Users/17145/project_1_YIQI/project_1_YIQI.srcs/sim_1/new/led_Sim.sv
     22
23 🖨 module led_Sim();
        logic [15:0]sw:
24
25
        logic [15:0]led;
        led A(.SW(sw),.LED(led));
26
        initial
27 🖨
28 □
        begin
            sw[15]=1; sw[0]=1;
29
            #10 sw[15]=0;
30
            #10 sw[0]=0;
31
            #10 sw[15]=1:
33 🗀
        end
34 A endmodule
35
```

#### 约束文件代码如下图所示:

```
11 ##Switches
15 set_property -dict { PACKAGE_PIN R15 IOSTANDARD LVCM0S33 } [get_ports { SW[3] }]; #IO_LI3N_T2_MRCC_14 Sch=sw[3]
17
19 set_property -dict { PACKAGE_PIN R13 IOSTANDARD LVCMOS33 } [get_ports { SW[7] }]; #IO_L5N_TO_D07_14 Sch=sw[7]
  20
21 | set_property -dict { PACKAGE_PIN U8 | IOSTANDARD LVCMOS18 } [get_ports { SW[9] }]; #IO_25_34 Sch=sw[9]
  24 set property -dict { PACKAGE PIN H6
               IOSTANDARD LVCMOS33 } [get ports { SW[12] }]; #IO L24P T3 35 Sch=sw[12]
25
  26 set_property -dict { PACKAGE_PIN U11 IOSTANDARD LVCMOS33 } [get_ports { SW[14] }]; #IO_L19N_T3_A09_D25_VREF_14 Sch=sw[14]
  30 | set_property -dict { PACKAGE_PIN H17 | IOSTANDARD LVCMOS33 } [get_ports { LED[0] }]; #IO_L18P_T2_A24_15 Sch=led[0]
35 | set_property -dict { PACKAGE_PIN V17
              IOSTANDARD LVCMOS33 } [get_ports { LED[5] }]; #IO_L18N_T2_A11_D27_14 Sch=led[5]
38 set property -dict { PACKAGE PIN V16 IOSTANDARD LVCMOS33 } [get ports { LED[8] }]; #10 L16N T2 A15 D31 14 Sch=led[8]
39 | set_property -dict { PACKAGE_PIN T15 | IOSTANDARD LVCMOS33 } [get_ports { LED[9] }]; #IO_L14N_T2_SRCC_14 Sch=led[9]
44 set_property -dict { PACKAGE_PIN V12 IOSTANDARD LVCM0S33 } [get_ports { LED[14] }]; #IO_L20N_T3_A07_D23_14 Sch=led[14]
45 set_property -dict { PACKAGE_PIN V11 IOSTANDARD LVCMOS33 } [get_ports { LED[15] }]; #IO_L2IN_T3_DQS_A06_D22_14 Sch=led[15]
46 :
```

# 三、实验分析

情况 1: led 15 亮,表示晴天; led 0 亮,表示有空。则 led 8 亮,可以去踢球。 如下图所示:



情况 2: led 15 不亮,表示下雨; led 0 不亮,表示没有空。则 led 8 不亮,不可以去踢球。如下图所示:



情况 3: led 15 不亮,表示下雨; led 0 亮,表示有空。则 led 8 不亮,不可以去踢球。 如下图所示:



情况 4: led 15 亮,表示晴天; led 0 不亮,表示没有空。则 led 8 不亮,不能去踢球。如下图所示:



以上四种情况中,只有 led 15 和 led 0 同时亮时,led 8 才亮,故符合判定标准。

### 四、总结与思考

遇到的问题:写好了文件运行的时候 led 灯一直都没有亮,后来才知道原来是板子有问题,于是换了一块板子。

总结与收获:在对 vivado 项目中三个文件进行编程与调试中,对 vivado、SystemVerilog 语言以及创造 bit 文件进行了初步的尝试。