### EEM16 Final

#### **TOTAL POINTS**

### 116.5 / 125

```
QUESTION 1
Problem #1 30 pts
1.1 (a), (b) 6 / 6

√ - 0 pts a is correct

√ - 0 pts b is correct

1.2 (C) - (i) 23 / 24

√ - 0 pts c - correct

√ - 0 pts d - correct

√ - 0.5 pts e - 3 product terms

√ - 0 pts f - correct

√ - 0 pts g - correct

√ - 0 pts h - correct

√ - 0.5 pts i - 12 states

QUESTION 2
2 Problem #2 14 / 15

√ - 1 pts Not fewest number of FAs, but correct

QUESTION 3
3 Problem #3 15 / 15

√ - 0 pts Correct

QUESTION 4
4 Problem #4 20 / 20

√ - 0 pts Correct

QUESTION 5
Problem #5 18 pts
5.1 (a)-(c) 11 / 11

√ - 0 pts Correct

5.2 (d)-(f) 7/7

√ - 0 pts Correct
```

√ - 0.5 pts (b) missing st[2:0]

#### **QUESTION 7**

7 Problem #7 9 / 15

√ - 4 pts (a)incorrect condition

√ - 2 pts (b)missing term !B!CD

**QUESTION 6** 

6 Problem #6 11.5 / 12

## Final Exam

Name (Last, First): Student Id #:

Do not start working until instructed to do so.

- 1. You must answer in the <u>space provided</u> for answers after every question. We will ignore answers written anywhere else in the booklet. <u>All pages in this booklet must be accounted</u> for otherwise it will not be graded.
- '2. You are permitted 2 page of notes 8.5x11 (front and back).
- 3. You may not use any electronic device.

Following table to be filled by course staff only

|            | Waxininin<br>Score | Your Score |
|------------|--------------------|------------|
| Question 1 | 30                 |            |
| Question 2 | 15·                |            |
| Question 3 | 15                 |            |
| Question 4 | 20                 |            |
| Question 5 | 18                 |            |
| Question 6 | 12                 | •          |
| Question 7 | 15                 | •          |
| TOTAL      | 125                |            |

### Question #1 State Machine to Logic (30)

A Mealy FSM state diagram is shown below. This is a decoder for a 3-level to 4-level encoding. A 4-level signal is communicated between two endpoints (A, B, C, and D). This signal is the input to the FSM. Transitions between the levels map to 3 symbols (X, Y, and Z); these symbols are the outputs. Note that some transitions are eliminated to enhance the quality of the communication.



(a) (2) Explain the difference between a Mealy and a Moore FSM.

A Mealy FSM additionally uses the input for its output logic, while a Moore FSM uses solely the current state. This means that Mealy FSMs after have fever states than an equivalent Moore FSM.

(b) (4) Fill in the blanks in this partial state transition table.

| state    | in  | out | nx_state |
|----------|-----|-----|----------|
| SA       | Α   | Χ   | ·SA      |
| SB       | B   | χ   | SB       |
| ZD       | B   | Z   | SB       |
| 2 C      | С   | Х   | 2C       |
| 2B \ 2 D | . C | Υ   | SC       |
| sc       | A   | Z   | SA       |
| SB       | , D | 7   | 2D       |

Prof. C.K. Yang

Assume for the following parts that inputs, outputs and states are all one-hot encoded,

(c) (3) How many bits are needed for the input, output, and states?

# bits for in =  $\frac{4}{3}$ 

# bits for state = 4

(d) (4) What is the logic for nx\_state:SA? out:Z? You can define your mapping for part (c) to write this Boolean function.

(e) (3) If nx\_state:SA is written as a fully-disjunctive normal form, how many product terms are there?

# product terms = 3

(f) (2) How many columns (inputs+outputs) and rows are in this truth table?

(g) (5) Use the Karnaugh map below to determine the logic for out[0]. How many prime implicants are there? How many are essential?

| _          | ·      | A: ( B In[1:0] C D |      |      | D    |
|------------|--------|--------------------|------|------|------|
| 1          | out[0] | "00"               | "io" | "11" | "10" |
| St[1:0] Sc | "00"   | 0                  | 7    | (I)  | X    |
|            | ″01"   |                    | 0    |      | 1    |
|            | "11"   |                    | 1    | 0    |      |
| 50         | "10"   | X                  | 5    |      | 0    |

# prime implicants =

# essential prime implicants = 4

(h) (3) Write the Boolean expression for out[0].

(i) (4) How many states do you need if you want to convert the FSM to a Moore Machine?

# states = 12

# UCLA | EEM16/CSM51A | Spring 2018 Question #2 Logic Design (15)

A field of black ("0") and white ("1") pixels can be "blurred" into gray values by taking a weighted-average that includes neighboring pixels as shown in the figure. Each converted gray-valued pixel, gpix, is a 4-bit value and is computed from 9 binary inputs,  $p_{xy}$ , based on the equation  $gpix_0[3:0] = 3 \cdot p_0 + 2 \cdot \sum p_{1n} + \sum p_{2n}$ .

| p <sub>21</sub> | p <sub>11</sub> | p <sub>20</sub> |  |
|-----------------|-----------------|-----------------|--|
| p <sub>12</sub> | $p_0$           | $p_{10}$        |  |
| p <sub>22</sub> | p <sub>13</sub> | p <sub>23</sub> |  |

You have available 1-bit Full Adders (FA with 3-inputs and 2-outputs) as building blocks for implementing a design. The design should output *gpix*[3:0]. Use the fewest number of FAs to achieve this task. Show your design.



The input to an FSM, Y, is a string of 1's and 0's. Design a Moore FSM that detects when a "01" sequence is followed a "10" sequence. The FSM is reset/initialized to a state for which prior inputs are all 0's. An example of the input and output is shown below and key transitions are underlined. Note that "010" does not constitute a "01" followed by a "10". The output, Z, asserts for only 1 cycle when the sequence is detected. As a design constraint, use the fewest number of states.

Y = 0000111000100101010111111

z = 000000001000001000001000



# UCLA | EEM16/CSM51A | Spring 2018 Question #4 System Partitioning (20)

The following algorithm calculates the combinatorics function C(n,k)=n!/(n-k)!k! (commonly referred to as n-choose-k or nCk).

```
n = n_in;
k = k_in;
comb = 1;
while (n > 0) {
   if (n>k)
       comb = comb*n;
   else
       comb = comb/n;
   n--
}
done = 1
```

The flow diagram is already designed as shown below. A signal, go, is an input to the controller that triggers this algorithm. Output, done, is asserted by the controller when the algorithm completes and is waiting for the go signal. The previous computation is held in the register, comb: You are to complete the controller and datapath design.

(a) (10) The datapath blocks available to you are also shown below (a combined multiply/divide module, an add/subtract module, and a zero detect module). You may also use as many 2:1 MUX as you choose (Note that you can only use 2:1 MUX so the select signals for each MUX is a single-bit signal from the controller). You can ignore the bit-width of any of the signals. Show the necessary connections within the datapath and any signals that need to pass as inputs to/from the controller.



Prof. C.K. Yang

(b) (10) Design a Moore FSM for the controller. Indicate the desired control signals from controller to the datapath on the FSM state diagram.



Prof. C.K. Yang

### Question #5 Timing and Pipelining (18)

The following combinational logic block can be broken down into modules. Each module have their delay as shown. For each module, the propagation and contamination delay are the same  $(t_c = t_d)$  with the except of two blocks where the  $(t_c, t_d)$  is shown in the block. The registers comprise of DFF with the properties  $t_S = 3$ ,  $t_H = 1$ ,  $t_{CQ} = (1,2)$ .



(a) (4) Determine the contamination and propagation delay of the combinational logic block.

$$t_{cCL} = 14$$

$$t_{dCL} = 43$$

11.

(b) (3) What is the minimum cycle time of the combinational logic block? min(T<sub>cycle</sub>) = 48

(c) (4) We can minimize the cycle time by inserting registers. Show on the diagram below where to insert the register(s). Indicate a register with a line. Use as few registers as possible.



(d) (2) Based on the answer in (c) determine the new minimum cycle time.  $min(T_{cycle}) = 20$ 

15+3+2

(e) (3) During verification of the design in (d), an engineer found that the DFF hold time is actually longer, t<sub>H</sub>=3. Does this pose a problem? Explain your answer.

Explain: There is a combinational module with contamination delay 1, in which case there would be a hold violentian since thold: > text to: 3>2.

- (f) (2) Name as many ways as you can to fix this problem?
  - 1. Artificially create additional contamination delay in the combinational module with short contamination delay
  - 2. Introduce a clock skew in the offeeted DFF so that  $t_{hold}$  decreases at the expense of a lorger solup time and eycle time.
  - 3. Introduce a clock skew in the "DFF , for the combinational module with short contamination delay so that top increases for that DFF.

CLK

D'

Q!

9 of 14

### UCLA | EEM16/CSM51A | Spring 2018 Question #6 (12)

An incomplete Verilog code for a module is shown below:

```
module final (
   input [3:0] st,
   output [3:0] nx_st,
   input [1:0] in,
   output [1:0] out,
   input go, reset, done, clock
);
<(a) missing TYPE> [2:0] ,nx_st;
always @(<(b) missing activation list>) begin
   case (st)
      3'b000: nx_st=3'b001;
      3'b001: nx_st=3'b010;
      3'b010:
         if (in[0] != go)
             nx_st=3'b100;
           else
             nx_st=3'b010;
        3'b100:
           if (in[0] 1= go)
             nx_st=3'bl00;
         , else
             nx_st=3'b001;
        default:
           nx st = {in[0],1'b0, reset};
    endcase
end
assign out[0] = nx_st[1] | in[1];
//(c) out[1] is the output of a mux that selects 1'b0 when reset else nx_st[0]
endmodule
```

(a) (2) What should be the declared type for the following signals:

```
_______ [1:0] out;
_______ [2:0] nx_st;
```

. .

(b) (2) What should go in the activation list of the always @()? Choose only the signals that needs to be there. You may not use \*.

```
Activation list = in [0] or go or reset
```

(c) (5) The signal, out[1], is the output of a 2:1 MUX that uses input, reset, to choose between input of 1'b0 (when reset==1), and nx\_st[0] (when reset==0). Write the Verilog code for this signal in three different ways (continue next page):

```
is input B out [1]

reset

reset
```

```
// Library module provided
module mux21(muxout, muxselA, inputA, inputB);
   // muxselA ==1 chooses inputA
   // module details not shown
endmodule.
```

Structural Verilog (using the library module above)

```
mux21 out-1-mux (out[1], reset, 1'60, nx-st[0]);
```

Procedural Verilog (note that out variable will need to be declared differently):

(d) (3) Four different ways of implementing a function is shown below. Which of them are the same? Circle all that are the same.

```
always (@posedge clock) begin
y <= z;
x <= y;
end
(2)
always (@posedge clock) begin
y = z;
x = y;
end
(3)
always (@posedge clock) begin
x = y;
y = z;
end
(4)
always (@posedge clock) begin
z = y;
y = x;
end
```

Prof. C.K. Yang

Question #7 Short Answers (15)

(a) (4) For the following Karnaugh map, the Boolean expression for the function  $Z = (\neg A \land \neg B \land \neg C) \lor (A \land \neg B \land D) \lor (A \land \neg B \land C)$ 

|    |      | AB   |      |      |        |
|----|------|------|------|------|--------|
|    | Z    | "00" | "01" | "11" | "10"   |
| CD | "00" | 1 €  | DE   | 0    | 0      |
|    | "01" | 1 😽  | 100  |      | # 11   |
|    | "11" | 04   | 100  | XO V | 1      |
|    | "10" | 0 💆  | 0 1  | 0    | >> 1 V |

What input conditions and transition has a potential for causing a glitch (static hazard) at the

output? . 
$$|010 \iff 1001$$
  $|0001 \iff 1011$   $|0001 \iff 1010$   $|0000 \iff 1010$   $|0000 \iff 1000$   $|0010|$   $|0000 \iff 1001$   $|0000 \iff 1001$   $|0000 \iff 1001$   $|0000 \iff 1001$   $|0000 \iff 1000$ 

(b) (2) How would you resolve the issue in (a) by adjusting the Boolean expression?

(c) (3) If you only have 2-input AND gates and Inverters available, how would you build a 2:1/multiplexer? (out selects between inpA and inpB with the select signal, selA)



(d) (3) If you only have 2:1 MUX and Inverters available, how would you implement Z = X xor Y?



Prof. C.K. Yang

(e) (3) A designer modified the basic DFF as shown below to make a GDFF where the clock signal is ANDed with an Enable signal. This approach is known as "clock gating". How does the GDFF's characteristics compare to that of the DFF? Select the answer.



Setup:

 $t_{S\_GDFF} > t_{S\_DFF}$ 

 $t_{S\_GDFF} = t_{S\_DFF}$ 

ts\_gdff < ts\_dff

Hold:

th\_GDFF > th\_DFF

th\_GDFF = th\_DFF

th\_GDFF < th\_DFF

Clock-Q Delay: tc2

tc2Q\_GDFF > tc2Q\_DFF

tc2Q\_GDFF = tc2Q\_DFF

tc20\_GDFF < tc20\_DFF '



Prof. C.K. Yang