



## DIGITAL DESIGN

## ASSIGNMENT REPORT

**ASSIGNMENT ID: 2**

**Student Name:** 张嘉浩

**Student ID:** 12010423

## PART 1: DIGITAL DESIGN THEORY

Provide your answers here:

张嘉浩 12010423

$$1. (a) F_1 = \sum m_i, F_2 = \sum m_j, F = F_1 + F_2 = \sum m_i + m_j$$

$$F = F_1 + F_2 = \sum m_i + \sum m_j = \sum (m_i + m_j)$$

$$(b) G = F_1 F_2 = \sum m_i \sum m_j$$

$$m_i m_j = \begin{cases} 0 & , i \neq j \\ 1 & , i = j \end{cases}$$

thus only common minterms.

|   |   |   | y  |    |    |    |   |
|---|---|---|----|----|----|----|---|
|   | x | y | 00 | 01 | 11 | 10 |   |
| x | 0 | 0 | 0  | 1  | 3  | 1  | 2 |
| x | 1 | 1 | 4  | 5  | 7  | 1  | 6 |
|   |   | z | 0  | 1  | 3  | 1  | 2 |

$$\begin{aligned} F(x, y, z) &= \sum(3, 5, 7) = m_3 + m_5 + m_7 \\ F &= \cancel{z'} + \cancel{x'y'} \quad F(x, y, z) = \sum(0, 1, 2, 4, 6) \\ &= \cancel{z(x+y)} \quad = m_0 + m_1 + m_2 + m_4 + m_6. \end{aligned}$$

$$\begin{aligned} \text{#} \quad F(A, B, C, D) &= (F(x, y, z))' = (m_0 + m_1 + m_2 + m_4 + m_6)' \\ F(x, y, z) &= m_0' m_1' m_2' m_4' m_6' \\ &= M_0 M_1 M_2 M_4 M_6 \\ &= \prod(0, 1, 2, 4, 6) \end{aligned}$$

$$(b) F(A, B, C, D) = \prod(3, 5, 8, 11, 12, 15)$$

$$\begin{aligned} &= M_3 M_5 M_8 M_{11} M_{12} M_{15} \\ &= m_3' m_5' m_8' m_{11}' m_{12}' m_{15}' \\ &= (m_3 + m_5 + m_8 + m_{11} + m_{12} + m_{15})' \end{aligned}$$

$$\cancel{(F(x, y, z))'} = (F(A, B, C, D))'$$

$$\text{thus } F(A, B, C, D) = \sum(0, 1, 2, 4, 6, 7, 9, 10, 13, 14)$$

3.

$$(a) \cancel{F(a,b,c,d) = (a'b' + b'c + a'd + cd)(a+b'+c)(d+d')}$$

|          | <u>ab</u> | <u>cd</u> |          |
|----------|-----------|-----------|----------|
|          | 00        | 01        | <u>c</u> |
| <u>a</u> | 00        | 1         | 1        |
|          | 01        | 0         | 0        |
|          | 10        | 0         | 0        |
|          | 11        | 0         | 1        |

d

$$F(a,b,c,d) = a'b' + a'd + cd + b'c$$

|          | <u>xz</u> | <u>yz</u> |           | <u>y</u> |
|----------|-----------|-----------|-----------|----------|
|          | 00        | 01        | <u>11</u> | 10       |
| <u>x</u> | 0         | 1         | 1         | 1        |
| <u>z</u> | 1         | 0         | 1         | 1        |

$$F' = \cancel{x}y'z + xy'$$

$$F = (y+z')(x'+y)$$

$$(a) y'z' + yz' + x'z = xy'z' + x'y'z' + xyz' + x'yz' + x'yz + x'y'z$$

$$\cancel{(a) y'z' + yz' + x'z = z'(y+y') + x'z}$$

$$x' + xz' = x'(y+y') (z+z') + x(y+y')z' = x'yz + x'y'z + x'y'z + x'y'z' \\ \Rightarrow \cancel{x' + xz'} \cancel{x' + xz'}, \cancel{\text{false}} + xy'z' + x'y'z'$$

(cannot exchange  $x$  and  $z$ ). thus True.

(b)  $(x'y + xz + y'z')' = (xy') (x'z') (yz)$ , which is definitely not the complement of  $xy' + x'z' + yz$ , thus false.

$$xy'z'$$

$$x'y + xz + y'z' = x'yz + x'y'z' + xyz + xy'z' + \cancel{x'z'} + xyz'$$

|          | <u>wx</u> | <u>yz</u>      |                |
|----------|-----------|----------------|----------------|
|          | 00        | 01             | <u>11</u>      |
| <u>w</u> | 00        | m <sub>0</sub> | m <sub>3</sub> |
|          | 01        | m <sub>4</sub> | m <sub>5</sub> |
|          | 11        | m <sub>6</sub> | m <sub>7</sub> |
|          | 10        | m <sub>8</sub> | m <sub>9</sub> |

z

$$F(x,y,z)$$

$$F(w,x,y,z) = wz' + wxz'$$

$$xy' + x'z' + yz = xy'z + xy'z' + x'yz' + x'yz + x'y'z$$

thus True.

5.(b)  $\begin{array}{c} CD \\ AB \end{array}$

|   |  | D  |    |    |    |    |
|---|--|----|----|----|----|----|
|   |  | 00 | 01 | 11 | 10 |    |
| A |  | 00 | 0  | 1  | 3  | 2  |
|   |  | 01 | 4  | 5  | 7  | 6  |
| A |  | 11 | 12 | 13 | 15 | 14 |
|   |  | 10 | 8  | 9  | 11 | 10 |

$\underbrace{\hspace{1cm}}_C$        $\underbrace{\hspace{1cm}}_C$

$$F(A, B, C, D) = BD + B'D'$$

(a) 见下.

(c)  $\begin{array}{c} CD \\ AB \end{array}$

|   |  | D  |    |    |    |    |
|---|--|----|----|----|----|----|
|   |  | 00 | 01 | 11 | 10 |    |
| A |  | 00 | 0  | 1  | 3  | 2  |
|   |  | 01 | 4  | 5  | 7  | 6  |
| A |  | 11 | 12 | 13 | 15 | 14 |
|   |  | 10 | 8  | 9  | 11 | 10 |

$\underbrace{\hspace{1cm}}_C$        $\underbrace{\hspace{1cm}}_C$

$$F(A, B, C, D) = AC' + AD + BCD$$

(d)

|   |  | C  |    |    |    |   |
|---|--|----|----|----|----|---|
|   |  | 00 | 01 | 11 | 10 |   |
| A |  | 00 |    | 1  |    |   |
|   |  | 01 | 1  | 1  |    |   |
| A |  | 11 |    |    | 1  |   |
|   |  | 10 |    | 1  | 1  | 1 |

$\underbrace{\hspace{1cm}}_{AD}$

$$F(A, B, C, D) = A'BC' + A'C'D + AB'D + ACD + AB'C$$

5. (a)

|   |   |   |   |
|---|---|---|---|
|   |   |   |   |
| 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 |

$$F(A, B, C, D) = AD' + ABC'$$

$$F(W, X, Y, Z) = WZ' + WX'Y'$$

6. (a)  $F(A, B, C, D) = CD + C'D' + A'B'D$   
 thus  $F(A, B, C, D) = (C+D)(C'+D')(A'+B'+D')$



(b)  $F(A, B, C, D) = AB'C'$   
 thus  $F(A, B, C, D) = A' + B + C$



7.

(a)

| AB |    | CD |    | C  | F                    |
|----|----|----|----|----|----------------------|
| 00 | 01 | 11 | 10 |    |                      |
| X  | 1  | 3  | 2  |    |                      |
| 01 | 4  | 5  | 7  | 6  | $B'D' + A'BC + C'D'$ |
| 11 | 12 | 13 | 15 | 14 |                      |
| 10 | X  | 9  | 11 | 10 |                      |

(b)

| AB |    | CD |    | C  | F                                       |
|----|----|----|----|----|-----------------------------------------|
| 00 | 01 | 11 | 10 |    |                                         |
| X  | 1  | 3  | 2  |    |                                         |
| 01 | 4  | 5  | 7  | 6  | <del><math>AD + CD' + A'BD</math></del> |
| 11 | 12 | 13 | 15 | 14 | $ACD' + B'CD' + CD'$                    |
| 10 | X  | 9  | 11 | 10 |                                         |

$$\begin{aligned}
 8. F &= A'B'C'D + AB'CD' + ABC'D' + A'B'CD \\
 &= AD'(B'C + BC') + A'D(BC' + B'C) \\
 &= (AD' + A'D)(B'C + BC') \\
 &= (A \oplus D)(B \oplus C)
 \end{aligned}$$



## PART 2: DIGITAL DESIGN LAB (TASK1)

### DESIGN

**(This part is always REQUIRED)**

Describe the design of your system by providing the following information:

- Verilog design (provide the Verilog code)

```
3  module lab7_7_segment_tube(
4    input[0:0] order,
5    input [3:0] in,
6    output reg [7:0] seg_out,
7    output [7:0] seg_en );
8
9  reg [3:0] show;
10 always @(*)
11 begin
12   //递减
13   if (order[0])
14     if(in[0] == 1)      show=4'h0;
15   else if(in[1] == 1)  show=4'h1;
16   else if(in[2] == 1)  show=4'h2;
17   else if(in[3] == 1)  show=4'h3;
18   else                  show=4'hf;
19   //递增
20   if (order[1])
21     if(in[3] == 1)  show=4'h3;
22   else if(in[2] == 1) show=4'h2;
23   else if(in[1] == 1) show=4'h1;
24   else if(in[0] == 1) show=4'h0;
25   else                  show=4'hf;
26 end
27
28
29 assign seg_en=8'b01111111;
30 always @(*)]
31 begin
32   case(show)
33   4'h0: seg_out=8'b1100_0000;
34   4'h1: seg_out=8'b1111_1001;
35   4'h2: seg_out=8'b1010_0100;
36   4'h3: seg_out=8'b1011_0000;
37   4'h4: seg_out=8'b1001_1001;
38   4'h5: seg_out=8'b1001_0010;
39   4'h6: seg_out=8'b1000_0010;
40   4'h7: seg_out=8'b1111_1000;
41   4'h8: seg_out=8'b1000_0000;
42   4'h9: seg_out=8'b1001_0000;
43   4'ha: seg_out=8'b1000_1000;
44   4'hb: seg_out=8'b1000_0011;
45   4'hc: seg_out=8'b1100_0110;
46   4'hd: seg_out=8'b1010_0001;
47   4'he: seg_out=8'b1000_0110;
48   4'hf: seg_out=8'b1111_1111;
49   default: seg_out = 8'b0000_0000;
50 endcase
51 end
52 endmodule
```

## CONSTRAINT FILE AND THE TESTING

---

*(This part is optional depending on the requirement of the lab task)*

*Describe how you test your design on the Minisys Practice platform.*

- *Constraint file (provide the screen shots on the feature of a pin and the binding info between pins and the input /output ports)*

```
1 set_property IOSTANDARD LVCMOS33 [get_ports {seg_en[0]}]
2 set_property IOSTANDARD LVCMOS33 [get_ports {seg_en[1]}]
3 set_property IOSTANDARD LVCMOS33 [get_ports {seg_en[2]}]
4 set_property IOSTANDARD LVCMOS33 [get_ports {seg_en[3]}]
5 set_property IOSTANDARD LVCMOS33 [get_ports {seg_en[4]}]
6 set_property IOSTANDARD LVCMOS33 [get_ports {seg_en[5]}]
7 set_property IOSTANDARD LVCMOS33 [get_ports {seg_en[6]}]
8 set_property IOSTANDARD LVCMOS33 [get_ports {seg_en[7]}]
9 set_property IOSTANDARD LVCMOS33 [get_ports {seg_out[0]}]
10 set_property IOSTANDARD LVCMOS33 [get_ports {seg_out[1]}]
11 set_property IOSTANDARD LVCMOS33 [get_ports {seg_out[2]}]
12 set_property IOSTANDARD LVCMOS33 [get_ports {seg_out[3]}]
13 set_property IOSTANDARD LVCMOS33 [get_ports {seg_out[4]}]
14 set_property IOSTANDARD LVCMOS33 [get_ports {seg_out[5]}]
15 set_property IOSTANDARD LVCMOS33 [get_ports {seg_out[6]}]
16 set_property IOSTANDARD LVCMOS33 [get_ports {seg_out[7]}]
17 set_property IOSTANDARD LVCMOS33 [get_ports {in[0]}]
18 set_property IOSTANDARD LVCMOS33 [get_ports {in[1]}]
19 set_property IOSTANDARD LVCMOS33 [get_ports {in[2]}]
20 set_property IOSTANDARD LVCMOS33 [get_ports {in[3]}]
21 set_property IOSTANDARD LVCMOS33 [get_ports {order[0]}]
22 set_property PACKAGE_PIN Y9 [get_ports {in[3]}]
23 set_property PACKAGE_PIN W9 [get_ports {in[2]}]
24 set_property PACKAGE_PIN Y7 [get_ports {in[1]}]
25 set_property PACKAGE_PIN Y8 [get_ports {in[0]}]
26 set_property PACKAGE_PIN W4 [get_ports {order[0]}]
27 set_property PACKAGE_PIN A18 [get_ports {seg_en[7]}]
28 set_property PACKAGE_PIN A20 [get_ports {seg_en[6]}]
29 set_property PACKAGE_PIN B20 [get_ports {seg_en[5]}]
30 set_property PACKAGE_PIN E18 [get_ports {seg_en[4]}]
31 set_property PACKAGE_PIN F18 [get_ports {seg_en[3]}]
32 set_property PACKAGE_PIN D19 [get_ports {seg_en[2]}]
33 set_property PACKAGE_PIN E19 [get_ports {seg_en[1]}]
34 set_property PACKAGE_PIN C19 [get_ports {seg_en[0]}]
35 set_property PACKAGE_PIN E13 [get_ports {seg_out[7]}]
36 set_property PACKAGE_PIN C15 [get_ports {seg_out[6]}]
37 set_property PACKAGE_PIN C14 [get_ports {seg_out[5]}]
38 set_property PACKAGE_PIN E17 [get_ports {seg_out[4]}]
39 set_property PACKAGE_PIN F16 [get_ports {seg_out[3]}]
40 set_property PACKAGE_PIN F14 [get_ports {seg_out[2]}]
41 set_property PACKAGE_PIN F13 [get_ports {seg_out[1]}]
42 set_property PACKAGE_PIN F15 [get_ports {seg_out[0]}]
```

- - *The testing result (provide the screen shots (at least 3 testing scene) to show state of inputs and outputs along with the related descriptions.)*

Scenarios:

- i. Only one ward's call bell is turned on





- ii. Two or more wards whose call bells are turned on while the priority order is set as priority increases as the number decreases.

For example, the call bell of ward #1, #2, #3 are turned on, number 1(the highest priority among 1, 2 and 3) is expected to be showed on the 7-seg tub.



- iii. Two or more wards whose call bells are turned on while the priority order is set as priority increases as the number increases.
- For example, the call bell of ward #1, #2, #3 are turned on, number 3(the highest priority among 1, 2 and 3) is expected to be showed on the 7-seg tub.





iv. No ward's call bell is turned on



## THE DESCRIPTION OF OPERATION

---

**(This part is always REQUIRED unless you can get full marks for this lab task)**

Describe the problem occurred while in the lab and your solution. Any suggestions are welcomed.

---

- *Problems and solutions*

I encountered a lot of problems during this process, and I'm only listing one of them here. For instance, I'm not quite familiar with the constraint files and have no idea how to edit it. But after looking back to the slides of lab and recall what teacher had shown us in the lab, I finally managed to do it.

## PART 2: DIGITAL DESIGN LAB (TASK2)

### DESIGN

*Describe the design of your system by providing the following information:*

- *Verilog design while using data flow (provide the Verilog code)*

```

1 : `timescale 1ns / 1ps
2 : //////////////////////////////////////////////////////////////////...
21
22
23 module XOR(a, b, c, x);
24   input a, b, c;
25   output x;
26
27   assign x = ((~a)&(~b)&c) | ((~a)&b&(~c)) | (a&(~b)&(~c)) | (a&b&c); //m1+m2+m4+m7
28 endmodule
29
30
1 : `timescale 1ns / 1ps
2 : //////////////////////////////////////////////////////////////////...
21
22
23 module XOR_Max(a, b, c, x2);
24   input a, b, c;
25   output x2;
26
27   assign x2 = (~a | ~b | c) & (~a | b | ~c) & (a | ~b | ~c) & (a | b | c); //M0+M3+M5+M6
28 endmodule
29

```

- *Truth-table and K-map*

$$\begin{aligned}
 F(a, b, c) &= a^{\wedge} b^{\wedge} c \\
 &= (a^{\wedge} b)^{\wedge} c \\
 &= (a'b + ab')^{\wedge} c \\
 &= (a'b + ab')c' + (a'b + ab')'c \\
 &= a'b'c' + abc' + (a'b)'(ab')'c \\
 &= a'b'c' + ab'c' + (a+b')(a'+b)c \\
 &= a'b'c' + ab'c' + \cancel{a'b'c} + abc = \sum(1, 2, 4, 7)
 \end{aligned}$$

|     |     |     |                |
|-----|-----|-----|----------------|
| $a$ | $b$ | $c$ | bc             |
| 0   | 0   | 0   | 00             |
| 0   | 0   | 1   | 01             |
| 0   | 1   | 0   | 10             |
| 0   | 1   | 1   | 11             |
| 1   | 0   | 0   | m <sub>0</sub> |
| 1   | 0   | 1   | m <sub>1</sub> |
| 1   | 1   | 0   | m <sub>2</sub> |
| 1   | 1   | 1   | m <sub>3</sub> |

Truth Table

| Inputs |   |   | Output |
|--------|---|---|--------|
| A      | B | C | X      |
| 0      | 0 | 0 | 0      |
| 0      | 0 | 1 | 1      |
| 0      | 1 | 0 | 1      |
| 0      | 1 | 1 | 0      |
| 1      | 0 | 0 | 1      |
| 1      | 0 | 1 | 0      |
| 1      | 1 | 0 | 0      |
| 1      | 1 | 1 | 1      |

$$F(a, b, c) = \prod(0, 3, 5, 6)$$

$$= M_0 + M_3 + M_5 + M_6$$

## SIMULATION

Describe how you build the test bench and do the simulation.

- Using Verilog (provide the Verilog code)

```

1 : *timescale 1ns / 1ps
2 : ///////////////////////////////////////////////////////////////////
21 :
22 :
23 : module XOR_sim();
24 :   reg sima, simb, simc;
25 :   wire simx;
26 :   XOR uXOR(.a(sima), .b(simb), .c(simc), .x(simx));
27 :
28 : initial
29 : begin
30 :   {sima, simb, simc} = 3'b000;
31 :   while ({sima, simb, simc} < 3'b111)
32 :   begin
33 :     #100 {sima, simb, simc} = {sima, simb, simc} + 1;
34 :   end
35 :   #100
36 :   $finish(1);
37 : end
38 : endmodule
39 :

```

```

1 : *timescale 1ns / 1ps
2 : ///////////////////////////////////////////////////////////////////
21 :
22 : module XOR_Max_sim();
23 :   reg sima, simb, simc;
24 :   wire simx2;
25 :   XOR_Max uXOR_Max(.a(sima), .b(simb), .c(simc), .x2(simx2));
26 :
27 : initial
28 : begin
29 :   {sima, simb, simc} = 3'b000;
30 :   while ({sima, simb, simc} < 3'b111)
31 :   begin
32 :     #100 {sima, simb, simc} = {sima, simb, simc} + 1;
33 :   end
34 :   #100
35 :   $finish(1);
36 : end
37 : endmodule
38 :

```

- Wave form of simulation result (provide screen shots)



- The description on whether the simulation result is same as the truth-table, is the function of the design meet the expectation

The simulation result is exactly the same as the truth-table. For example, when  $a = 0, b = 1, c = 0$ , we've got  $\text{simx} = \text{simx2} = 1$ , which is the same as the truth table above.

## THE DESCRIPTION OF OPERATION

---

Describe the problem occurred while in the lab and your solution. Any suggestions are welcomed.

- Problems and solutions

This task requires knowledge on XOR gate of multiple elements. First, I wasn't that familiar with the XOR gate, especially when it is applied to multiple elements. But after reviewing the lecture slides, I finally learnt to do so.