# 同济大学计算机系

# 数字逻辑课程实验报告



| 学  | 号 _     | 2252941  |  |
|----|---------|----------|--|
| 姓  | 名 _     | 杨瑞灵      |  |
| 专  | 业_      | 计算机科学与技术 |  |
| 授课 | -<br>老师 | 张冬冬      |  |

## 一、实验内容

#### (1)6.3 13-8 译码

使用 Verilog 语言实现 3-8 译码器并用 logicsim 验证逻辑, modelsim 波形仿真,以及下板验 证。 功能:输入二进制代码,输出一组高低电平信号其包含 3 个编码输入,8 个输出和两个使能 输入端,在使用时使能端必须满足 G1=1,G2=0



图 6.11 3-8 译码器及其真值表

#### (2)6.3 2 七段数码管译码驱动器

图 6.3.2 为所要建模的七段数码管译码驱动原理图,它由译码驱动器和荧光数码管组成。荧光数 码管是分段式半导体显示器件,7 个发光二极管组成 7 个发光段,发光二极管可以将电能转换成光能,从而发出清晰悦目的光线。本实验采用的是共阳极电路,故译码器的输出 a~g 分别加到 7 个阴极上。只 有在阴极上呈低电平的二极管导通发光,显示 0~9 中相应的十进制数字。表 6.3.1 所示为七段数码管 译码驱动器逻辑功能真值表,四个输入和七个输出以及对应显示的字符。



图 6.3.2 七段数码管译码驱动原理图

#### (3)6.3\_3 普通 8-3 编码器

用来完成编码工作的电路称为编码器。它可以实现对一组输入信号的二进制编码。图 6.3.3 为所 要建模的普通 8-3 编码器及其真值表。它有 8 个输入以及 3 个输出,真值表中每行 只有一个输入电平 有效 (高电平为 1, 低电平为 0)。



| D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | $D_4$ | D <sub>3</sub> | D <sub>2</sub> | $D_1$ | D <sub>0</sub> | Y <sub>2</sub> | Y <sub>1</sub> | Y <sub>0</sub> |
|----------------|----------------|----------------|-------|----------------|----------------|-------|----------------|----------------|----------------|----------------|
| 1              | 0              | 0              | 0     | 0              | 0              | 0     | 0              | 1              | 1              | 1              |
| 0              | 1              | 0              | 0     | 0              | 0              | 0     | 0              | 1              | 1              | 0              |
| 0              | 0              | 1              | 0     | 0              | 0              | 0     | 0              | 1              | 0              | 1              |
| 0              | 0              | 0              | 1     | 0              | 0              | 0     | 0              | 1              | 0              | 0              |
| 0              | 0              | 0              | 0     | 1              | 0              | 0     | 0              | 0              | 1              | 1              |
| 0              | 0              | 0              | 0     | 0              | 1              | 0     | 0              | 0              | 1              | 0              |
| 0              | 0              | 0              | 0     | 0              | 0              | 1     | 0              | 0              | 0              | 1              |
| 0              | 0              | 0              | 0     | 0              | 0              | 0     | 1              | 0              | 0              | 0              |
|                |                |                |       |                |                |       |                |                |                |                |

图 6.3.3 普通 8-3 编码器及其真值表

#### (4)6.3\_4 具有优先级的 8-3 编码器

普通编码器对输入线是有限制的,即在任意一时刻所有输入线中只允许一个输入线信号有效,否则 编码器将发生混乱。为解决这一问题可以采用具有优先级的编码器。图 6.3.4 为所要建模的具有优先 级的 8-3 编码器及其真值表,它有八个输入端、三个输出端、一个选通输入端 EI 以及一个扩展输出端 EO。从真值表可以看出,输入输出的有效信号是低电平,在输入中,角标越大,优先级越高。 图 6.3.4 具有优先级的 8-3 编码器及其真值表



| $\overline{D}_0$ | $\overline{D}_1$ | $\overline{D}_2$ | $\overline{D}_3$ | $\overline{D}_4$ | $\overline{D}_5$ | $\overline{D}_6$ | $\overline{D}_7$ | Ÿ | $\overline{Y}_{2}\overline{Y}_{1}$ | <u>7</u> 0 | EI | EO |
|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|---|------------------------------------|------------|----|----|
| ×                | ×                | ×                | ×                | ×                | ×                | ×                | ×                | 1 | 1                                  | 1          | 1  | 0  |
| 1                | 1                | 1                | 1                | 1                | 1                | 1                | 1                | 1 | 1                                  | 1          | 0  | 0  |
| ×                | ×                | ×                | ×                | ×                | ×                | ×                | 0                | 0 | 0                                  | 0          | 0  | 1  |
| ×                | ×                | ×                | ×                | ×                | ×                | 0                | 1                | 0 | 0                                  | 1          | 0  | 1  |
| ×                | ×                | ×                | ×                | ×                | 0                | 1                | 1                | 0 | 1                                  | 0          | 0  | 1  |
| ×                | ×                | ×                | ×                | 0                | 1                | 1                | 1                | 0 | 1                                  | 1          | 0  | 1  |
| ×                | ×                | ×                | 0                | 1                | 1                | 1                | 1                | 1 | 0                                  | 0          | 0  | 1  |
| ×                | ×                | 0                | 1                | 1                | 1                | 1                | 1                | 1 | 0                                  | 1          | 0  | 1  |
| ×                | 0                | 1                | 1                | 1                | 1                | 1                | 1                | 1 | 1                                  | 0          | 0  | 1  |
| 0                | 1                | 1                | 1                | 1                | 1                | 1                | 1                | 1 | 1                                  | 1          | 0  | 1  |

# 二、硬件逻辑图

(实验步骤中要求用 logisim 画图的实验,在该部分给出 logisim 原理图,否则该部分在实验报告中不用写)

### (1)6.3\_1



(2)6.3\_3



# 三、模块建模

## (1) 6.3\_1

### (2) 6.2\_2

```
module display7( input [3:0] iData,
```

```
output [6:0] oData
    );
    reg [6:0] oData_t;
    always @(*)
    begin
    case(iData)
         4'b0000: oData_t=7'b1000000;
         4'b0001: oData_t=7'b1111001;
         4'b0010: oData_t=7'b0100100;
         4'b0011: oData_t=7'b0110000;
         4'b0100: oData_t=7'b0011001;
         4'b0101: oData_t=7'b0010010;
         4'b0110: oData_t=7'b0000010;
         4'b0111: oData t=7'b1111000;
         4'b1000: oData_t=7'b0000000;
         4'b1001: oData_t=7'b0010000;
         default:;
    endcase
    end
    assign oData = oData_t;
endmodule
(3)6.3_3
module encoder83(
    input [7:0] iData,
    output reg [2:0] oData
    always @(*)
    begin
         if (iData[7]) oData = 3'b111;
         else if (iData[6]) oData = 3'b110;
         else if (iData[5]) oData = 3'b101;
         else if (iData[4]) oData = 3'b100;
         else if (iData[3]) oData = 3'b011;
         else if (iData[2]) oData = 3'b010;
         else if (iData[1]) oData = 3'b001;
         else if (iData[0]) oData = 3'b000;
    end
endmodule
(4)6.3_4
module encoder83_Pri(
    input [7:0] iData,
    input iEI,
```

```
output reg [2:0] oData,
     output reg oEO
     );
     always @(*)
     begin
         if (iEI)
              begin
                    oEO = 1;
                    oData = 3'b111;
              end
         else if (iData == 8'b111111111) oEO = 0;
         else
              begin
                   oEO = 1;
                   if (!iData[7]) oData = 3'b000;
                   else if (!iData[6]) oData = 3'b001;
                   else if (!iData[5]) oData = 3'b010;
                   else if (!iData[4]) oData = 3'b011;
                   else if (!iData[3]) oData = 3'b100;
                   else if (!iData[2]) oData = 3'b101;
                   else if (!iData[1]) oData = 3'b110;
                   else if (!iData[0]) oData = 3'b111;
              end
     end
endmodule
```

## 四、测试模块建模

(要求列写各建模模块的 test bench 模块代码)

## (1)6.3\_1

```
module decoder_tb();
reg [2:0]iData;
reg [1:0] iEna;
wire [7:0]oData;
decoder de(iData,iEna,oData);
initial
begin
iEna<=2'bx1;
#50 iEna<=2'b0x;
#50 iEna<=2'b10;
iData<=3'b000;
```

```
#50 iData<=3'b001;
#50 iData<=3'b010;
#50 iData<=3'b011;
#50 iData<=3'b100;
#50 iData<=3'b101;
#50 iData<=3'b110;
#50 iData<=3'b111;
end
endmodule
(2)6.3_2
module display7_tb();
reg [3:0] iData;
wire [6:0] oData;
display7 dp(.iData(iData),.oData(oData));
initial
begin
iData<='d0;
#50 iData<='d1;
#50 iData<='d2;
#50 iData<='d3;
#50 iData<='d4;
#50 iData<='d5;
#50 iData<='d6;
#50 iData<='d7;
#50 iData<='d8;
#50 iData<='d9;
end
endmodule
(3)6.3_3
module encoder83_tb();
reg [7:0] iData;
wire [2:0] oData;
encoder83 ec(.iData(iData),.oData(oData));
initial
begin
iData = 8'b10000000;
#50 iData = 8'b01000000;
#50 iData = 8'b00100000;
#50 iData = 8'b00010000;
#50 iData = 8'b00001000;
```

```
#50 iData = 8'b00000100;
#50 iData = 8'b00000010;
#50 iData = 8'b00000001;
end
endmodule
(4)6.3_4
module encoder83_pri_tb();
reg [7:0] iData;
reg iEI;
wire [2:0] oData;
wire oEO;
encoder83_Pri ecp(.iData(iData), .iEI(iEI), .oData(oData), .oEO(oEO));
initial
begin
iEI \ll 1;
#50 iEI<=0;
    iData<=8'b11111111;
#50 iData<=8'b0xxxxxxx;
#50 iData<=8'b10xxxxxx;
#50 iData<=8'b110xxxxx;
#50 iData<=8'b1110xxxx;
#50 iData<=8'b11110xxx;
#50 iData<=8'b111110xx;
#50 iData<=8'b1111110x;
#50 iData<=8'b11111110;
end
endmodule
```

## 五、实验结果

 $(1)6.3_1$ 

| 变量    | iData[0]~[2]  | iEna[0]~[1] | oData[0]~[7]      |  |  |  |
|-------|---------------|-------------|-------------------|--|--|--|
| N4 板上 | SW0~2         | SW14~15     | LD0~7             |  |  |  |
| 的管脚   |               | (V10、U11)   | (H17、K15、J13、N14、 |  |  |  |
| 即日即   | (J15、L16、M13) | (VIOV 011)  | R18、V17、U17、U16)  |  |  |  |









# (2)6.3\_2

| // Ave - Default                            |            |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
|---------------------------------------------|------------|------|------|------|------|------|------|-------|------|-------|------|--|--|--|---|
| •                                           | Msgs       |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| -🔷 /display7_tb/iData                       | 4h1        | 4ħ0  | [4h1 | 4h2  | 4h3  | 4h4  | 4h5  | 14'h6 | 4h7  | [4]h8 | 4h9  |  |  |  |   |
| <b>-</b> [3]                                | 0          |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| <del>-</del> [2]                            | 0          |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| <b>-</b> ♦ [1]                              | 0          |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| └ <b>→</b> [0]                              | 1          |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| / display7_tb/oData                         |            | 7h40 | 7h79 | 7h24 | 7h30 | 7h19 | 7h12 | 7h02  | 7h78 | 7h00  | 7h10 |  |  |  |   |
| <del>-</del> [6]                            | 1h1        | 1    |      |      |      |      |      |       |      |       |      |  |  |  | _ |
| <b>→</b> [5]                                | 1h1        |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| <b>-</b> ◆ [4]                              | 1h1        |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| <b>-</b> ♦ [3]                              | 1h1        |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| [2]                                         | 1'h0       |      |      |      |      | _    |      |       |      |       |      |  |  |  |   |
| - <b>4</b> [1]                              | 1'h0       |      |      |      |      |      |      |       |      |       |      |  |  |  |   |
| └ <b>-{</b> > [0]<br><b>{&gt;</b> /glbl/GSR | 1h1<br>1h1 |      |      |      |      |      |      |       |      |       |      |  |  |  |   |

| 变量    | iData[0]~[3] | oData[0]~[6]                        |  |  |  |  |  |  |
|-------|--------------|-------------------------------------|--|--|--|--|--|--|
| N4 板上 | SW0~3(J15、   | CA(T10), CB(R10), CC(K16), CD(K13), |  |  |  |  |  |  |
| 的管脚   | L16、M13、R15) | CE(P15)、CF(T11)、CG(L18)             |  |  |  |  |  |  |





# (3)6.3\_3



| Wayo Dofault                                       | Wave - Default :     |        |        |       |       |       |               |       |        |  |  |  |  |  |
|----------------------------------------------------|----------------------|--------|--------|-------|-------|-------|---------------|-------|--------|--|--|--|--|--|
| wave - Delauit                                     | Msgs                 |        |        |       |       |       |               |       |        |  |  |  |  |  |
| /encoder83_tb/iData                                | 8'h20<br>0           | (8'h80 | (8'h40 | 8'h20 | (8h10 | 8'h08 | (8'h04        | [8h02 | (8'h01 |  |  |  |  |  |
| - <b>→</b> [6]<br>- <b>→</b> [5]<br>- <b>→</b> [4] | 0<br>1<br>0          |        |        |       |       |       |               |       |        |  |  |  |  |  |
| - <b>4</b> [3]<br>- <b>4</b> [2]<br>- <b>4</b> [1] | 0<br>0               |        |        |       |       |       | ightharpoonup |       |        |  |  |  |  |  |
| [0] [0] // [0] // [0] // [0] // [0] // [0]         |                      | (3h7   | )(3'h6 | 3'h5  | (3/14 | 3'h3  | ), 3'h2       | 3h1   | (3'h0  |  |  |  |  |  |
| - (2)<br>- (1)<br>- (0)                            | 1'h1<br>1'h0<br>1'h1 |        |        |       |       |       |               |       | +      |  |  |  |  |  |
| ♦ /glbl/GSR                                        | 1'h0                 |        |        |       |       |       |               |       |        |  |  |  |  |  |

| 变量     | iData[0]~[7]                      | oData[0]~[2]  |
|--------|-----------------------------------|---------------|
| N4 板上的 | SW0~7                             | LD0~2         |
| 管脚     | (J15、L16、M13、R15、R17、T18、U18、R13) | (H17、K15、J13) |









## (4)6.3\_4

| Wave - Default           |              |     | 14    | 1.1   |       |       |       |       |       |       |       |      |
|--------------------------|--------------|-----|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|
| <b>\$1</b> •             | Msgs         |     |       |       |       |       |       |       |       |       |       |      |
| -/ /encoder83_pri_tb/i   | 8°hXx        |     | 8'hff | 8'hXx | 8'hXx | 8'hXx | 8'hex | 8"hfX | 8'hfX | 8'hfX | 8'hfe |      |
| <b>-</b> ∳ [7]           | 1            |     |       |       |       |       |       |       |       |       |       |      |
| - [6]<br>- [5]           | v<br>X       |     |       |       |       |       |       |       |       |       |       |      |
| - <b>→</b> [4]           | X            |     |       |       |       |       |       |       |       |       |       |      |
| <b>→</b> [3]             | X            |     |       |       |       |       |       |       |       |       |       |      |
| - <del>*</del> [2]       | X            |     |       |       |       |       |       |       |       |       |       |      |
| [1]                      | x<br>x       |     |       |       |       |       |       |       |       |       |       |      |
| /encoder83_pri_tb/iEI    | 1'h0         |     |       |       |       |       |       |       |       |       |       |      |
| =- /p /encoder83_pri_tb/ | 3h1          | 3h7 |       | 31h0  | 3h1   | 3h2   | 3'h3  | 3h4   | 3'h5  | 3h6   | 3h7   |      |
|                          | 1'h0<br>1'h0 |     |       |       |       |       |       |       |       |       |       |      |
|                          | 1h1          |     |       |       |       |       |       |       |       |       |       |      |
| /encoder83_pri_tb/       | 1h1          |     |       |       |       |       |       |       |       |       |       |      |
| /glbl/GSR                | 1'h0         | ,   |       |       | ļ     |       |       |       |       |       |       | <br> |
|                          |              |     |       |       |       |       |       |       |       |       |       |      |

| 变量           | iData[0]~[7]                                   | oData[0]~[2]           | iEI           | oEO           |
|--------------|------------------------------------------------|------------------------|---------------|---------------|
| N4 板上的<br>管脚 | SW0~7<br>(J15、L16、M13、R15、<br>R17、T18、U18、R13) | LD0~2<br>(H17、K15、J13) | SW15<br>(V10) | LD15<br>(V11) |









