# **EEM16 Final**

ZHICHENG REN

TOTAL POINTS

## **93 / 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) **19 / 24**
	- **✓ 0 pts c correct**
	- **✓ 0.5 pts e 3 product terms**
	- **✓ 0.5 pts f columns or rows**
	- **✓ 0 pts g correct**
	- **✓ 0 pts h correct**
	- **✓ 4 pts i incorrect**

### QUESTION 2

- **2** Problem #2 **3 / 15**
	- **✓ 12 pts doesn't make sense or very wrong**

## QUESTION 3

- **3** Problem #3 **13 / 15**
	- **✓ 2 pts missing one thing or has an extra state**

## QUESTION 4

- **4** Problem #4 **14 / 20**
	- **✓ 2 pts (a)missing mux before reg (comb/n/k)**
	- **✓ 2 pts (a)incorrect connection of zero detect**
	- **✓ 2 pts addtional DFFs**

## QUESTION 5

Problem #5 18 pts

**5.1** (a)-(c) **7 / 11**

**✓ - 4 pts (c) incorrect**

**5.2** (d)-(f) **6 / 7**

**✓ - 1 pts (f) partial correct**

QUESTION 6

- **6** Problem #6 **11 / 12**
	- **✓ 1 pts (c) partial correct-procedural**

## QUESTION 7

**7** Problem #7 **14 / 15**

**✓ - 1 pts (e)incorrect setup**

Prof. C.K. Yang

# **Final Exam**

## Name (Last, First): Zhicheng Ren Student Id #:  $304972327$

## Do not start working until instructed to do so.

- 1. You must answer in the space provided for answers after every question. We will ignore answers written anywhere else in the booklet. All pages in this booklet must be accounted 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.

J

Following table to be filled by course staff only



## 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.

its state<br>both the state Moore FSM -> output is only dependent<br>Mealy FSM ->: output is dependent oh  $\mathscr{O}V$  $\dot{\iota}_{\mathfrak{k}}$ cend itsput

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



UCLA | EEM16/CSM51A | Spring 2018 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?

SA 0001<br>SB 001-0 # bits for in  $=$  $\overline{B}$ # bits for out  $=$ # bits for state  $=$  $\frac{5}{5}$   $\frac{6}{100}$ (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. f statef<br>loopol  $0000$  $\overline{r}$ nx\_state:SA =  $(n \Gamma_0)$ out:Z = {in [0]  $\Lambda$ 5tate [2]  $\lambda$  (in [2]  $\Lambda$  5tate [0]  $\int$   $V$  (in [1]  $\Lambda$  5tate (3))  $V$  (in [3]  $\Lambda$  5tate [1]  $\int$  (e) (3) If nx\_state:SA is written as a fully-disjunctive normal form, how many product terms are there? # product terms  $=$ Now assume that states, st[1:0], are assigned as gray code: SA=2'b00, SB=2'b01, SC=2'b11, SD=2'b10. The inputs, in[1:0], are also assigned as gray code where A=2'b00, B=2'b01, C=2'b11, D=2'b10; and outputs, out[1:0], are X=00, Y=01, Z=11. (f) (2) How many columns (inputs+outputs) and rows are in this truth table?  $#$  columns = #  $rows =$ (g) (5) Use the Karnaugh map below to determine the logic for out[0]. How many prime implicants are there? How many are essential?  $ln[1:0] = \sqrt{3}$ . "00" out[0] "ዕነ። "11" "00" M "01"  $\frac{1}{2}$ t $\frac{1}{2}$ 101  $n11$  $"10"$ # prime implicants = # essential prime implicants =  $4$ (h) (3) Write the Boolean expression for out[0]. (in [0] N T ST[0]) V( in[1]N T ST[1]) V ( T in [0] N ST[0])  $out[0] =$ (i) (4) How many states do you need if you want to convert the FSM to a Moore Machine?  $V$   $( \neg \ell nL) \wedge \ell \ell \bar \nu)$  $12$ # states  $=$ 3 of 14

Prof. C.K. Yang

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 weightedaverage 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}.$ 



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.



Prof. C.K. Yang

 $\tilde{\mathcal{L}}$ 

## UCLA | EEM16/CSM51A | Spring 2018 Question #3 FSM State Diagram (15)

Ð

Prof. C.K. Yang

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 = 00001110001001010101101111$ 



Prof. C.K. Yang

#### 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.

 $\tilde{\phantom{a}}$ 

(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.





6 of 14

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.



F

#### Prof. C.K. Yang

## UCLA | EEM16/CSM51A | Spring 2018

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_{ca} = (1,2)$ .



(a) (4) Determine the contamination and propagation delay of the combinational logic block.  $L [l] = [l]$  $\mathbf{f}$ 

$$
t_{\text{total}} = 5 + 1 + 10 - 14
$$
  

$$
5 + 6 + 4 + 8 + 6 + 4 + 10 = 43
$$

- (b) (3) What is the minimum cycle time of the combinational logic block?  $min(T_{cycle}) = 43 + 3 + 2 =$ <br>tdcL + tdca+tz
- (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.



<del>Ex</del>plain:

ÿ

Prof. C.K. Yang

rawiting proplem

 $\cdot$ 1

÷

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

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

$$
for (1, 15) model\n
$$
t_{cCL} + t_{cCR} = 1 + 1 = 2
$$
\n
$$
t_{H} = 3 > 2 \Rightarrow t_{H} > t_{cCL} + t_{CR}
$$
$$

tre tur piregisters

module

module<br>add one more block between

(f) (2) Name as many ways as you can to fix this problem?

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
\mathcal{E}\lt(a) missing TYPE>. [1:0] out;
<(a) missing TYPE> [2:0] nx_st;
always \ell(<b>b</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'bl00:
            if (in[0] != qo)nx_st=3'b100;
            else
               nx_st=3'b001;
         default:
            nx_st = \{in[0], 1'b0, reset\};endcase
_{\tt end}assign out[0] = nx_st[1] \mid 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:

 $W(Y \ell [1:0]$  out; 

(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 \*. 5t. 22 in 22 go 22 reset

Activation list =

(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):

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

UCLA | EEM16/CSM51A | Spring 2018 Declarative Verilog:

 $0$ utt $t$ ]= (reset  $ell$   $lb$ ) (-freset  $ell$  nx-st $c$ 0])

Structural Verilog (using the library module above)

$$
mux21 \quad maxg0 \quad (au4C1), \quad vee\overline{t}, \quad |'bU, \quad nx\text{-}5tU1
$$

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

if (105e{ = = 1)  
assign 
$$
out[1] = 1/b0
$$
;  
if (1050{ = 0)  
assign  $out[0] = nx-st[0]$ 

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

| (1)                           | always (êposedge clock) begin | 2 |
|-------------------------------|-------------------------------|---|
| $y \leq z$ ;                  | $x \leq y$ ;                  |   |
| end                           | (2)                           |   |
| always (êposedge clock) begin | 2                             |   |
| $y = z$ ;                     | $x = y$ ;                     |   |
| end                           | (3)                           |   |
| always (êposedge clock) begin | 1                             |   |
| $x = y$ ;                     | 1                             |   |
| end                           | (4)                           |   |
| always (êposedge clock) begin | 2                             |   |
| end                           | 2                             | 1 |
| 1                             | 2                             | 2 |
| end                           | 2                             |   |
| 1                             | 1                             |   |

Prof. C.K. Yang

### UCLA | EEM16/CSM51A | Spring 2018 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)
$$



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

<sup>output?</sup> when 
$$
f
$$
  $f$   $f$  <

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

 $(TAA \cap B \land \neg c)$   $V(A \land \neg B \land D)$   $V(A \land \neg B \land C)$   $V(\exists B \land \neg c \land D)$  $Z =$ 

(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?



í,

 $\overline{\mathcal{I}}$ 

#### 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.



E

## Prof. C.K. Yang

# UCLA | EEM16/CSM51A | Spring 2018<br><Extra blank page for work>

 $\bullet$ 

 $\phi$ 

 $\bar{\zeta}$ 14 of 14

 $\ddot{\phantom{0}}$