| - |     |
|---|-----|
| 1 | /14 |
| 2 | /13 |
| 3 | /14 |
| 4 | /15 |
| 5 | /14 |
| 6 | /12 |

### MASSACHUSETTS INSTITUTE OF TECHNOLOGY DEPARTMENT OF ELECTRICAL ENGINEERING AND COMPUTER SCIENCE

# 6.004 Computation Structures

Updated Spring 2022

## Quiz #1

| Name                                                                                                                          | Ather                                                                                                  | ıa login name | Score                                           |
|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------|-------------------------------------------------|
| Recitation section   □ WF 10, 34-302 (Francis)   □ WF 11, 34-302 (Francis)   □ WF 12, 34-302 (Grace)   □ WF 1, 34-302 (Grace) | □ WF 2, 34-302 (Robert)<br>□ WF 3, 34-302 (Robert)<br>□ WF 10, 35-310 (Sara)<br>□ WF 11, 35-310 (Sara) |               | 2, 35-310 (Kendall)<br>, 35-310 (Kendall)<br>ut |

**Please enter your name, Athena login name, and recitation section above.** Enter your answers in the spaces provided below. Show your work for potential partial credit. You can use the extra white space and the backs of the pages for scratch work.

#### **Problem 1. Static Discipline (14 points)**

The F module below outputs 0.5V when  $0.5 * V_A + V_B > 2V$  for 25ns and outputs 5V when  $0.5 * V_A + V_B < 1.5V$  for 25ns. Furthermore,  $V_A$  and  $V_B$  are both between 0 and 5V. This is summarized in the equation below:



(A) (2 points) If we apply constant  $V_A$ ,  $V_B$  for 25ns and then measure a  $V_{out} = 5$ , what can we conclude about  $V_B$ ?

**C1:**  $V_B < 1.5V$  **C2:**  $V_B \le 2V$  **C3:**  $V_B > 2V$  **C4:**  $V_B \ge 1.5V$ **C5:** None of the above

#### Best conclusion about V<sub>B</sub> (Circle one): C1 ... C2 ... C3 ... C4 ... C5

(B) (2 points) If we apply constant  $V_A$ ,  $V_B$  for 25ns and then measure a  $V_{out} = 4$ , what can we conclude about  $V_A$ ?

C1:  $V_A < 3V$ C2:  $V_A \le 4V$ C3:  $V_A > 4V$ C4:  $V_A \ge 3V$ C5: None of the above

Best conclusion about V<sub>A</sub> (Circle one): C1 ... C2 ... C3 ... C4 ... C5

(C) (2 points) What Boolean expression does the F module implement? Specify an equation using A and B.

Boolean Expression: out = \_\_\_\_\_

(D) (4 points) What are the parameters that produce a maximum noise immunity for the F module shown above?

 $V_{OL} =$ \_\_\_\_\_,  $V_{IL} =$ \_\_\_\_\_,  $V_{IH} =$ \_\_\_\_\_,  $V_{OH} =$ \_\_\_\_\_

Noise Immunity = \_\_\_\_\_

(E) (4 points) Now suppose we have a new device G, whose voltage transfer characteristic (VTC) is depicted below. We want to use both F and G in the same circuit, but we want to use the same signaling specification for both devices. What are the parameters that will produce a maximum noise immunity while satisfying both devices?



$$V_{OL} =$$
\_\_\_\_\_,  $V_{IL} =$ \_\_\_\_\_,  $V_{IH} =$ \_\_\_\_\_,  $V_{OH} =$ \_\_\_\_\_

Noise Immunity = \_\_\_\_\_

# Problem 2. Boolean Algebra and Combinational Logic (13 points)

(A) (2 points) Consider the schematic of the circuit F(A, B, C) below. Derive its truth table.



| Α | В | С | F |
|---|---|---|---|
| 0 | 0 | 0 |   |
| 0 | 0 | 1 |   |
| 0 | 1 | 0 |   |
| 0 | 1 | 1 |   |
| 1 | 0 | 0 |   |
| 1 | 0 | 1 |   |
| 1 | 1 | 0 |   |
| 1 | 1 | 1 |   |

| А | В | С | G |
|---|---|---|---|
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 |

(B) (3 points) Find the normal form and a minimal sum-of-products expression for G(A, B, C).

- 1. Normal form for G = \_\_\_\_\_
- 2. Minimal sum of products for G = \_\_\_\_\_

(C) (2 points) Is the circuit G(A, B, C) functionally complete? Explain.

(D) (4 points) Simplify the following Boolean expressions by finding a minimal sum-of-products expression for each one. (Note: These expressions can be reduced into a minimal SOP by repeatedly applying the Boolean algebra properties we saw in lecture.)

1. 
$$(x+y)(x+\bar{y})(\bar{x}+z)(\bar{x}+\bar{z})$$

2.  $(x + y + z)(x + \bar{y} + \bar{z})$ 

- (E) (2 points) For each of the expressions in part D, find a set of variable assignments that makes the expression true or explain why the expression cannot be satisfied with any variable assignment.
  - 1. x =\_\_\_\_, y =\_\_\_\_, z =\_\_\_\_ or UNSATISFIABLE.

2. x =\_\_\_, y =\_\_\_, z =\_\_\_ or UNSATISFIABLE.

#### Problem 3: CMOS (14 points)

(A) (3 points) The following 5-input circuit consists of two 2-input NAND gates, an inverter, and a 3-input AND gate. Write a Boolean expression for the function Z. If the function Z can be implemented using a single CMOS gate, please draw the corresponding single CMOS gate. For full credit, use a minimum number of FETs. If it cannot be implemented using a single CMOS gate, explain why not.



- (B) (3 Points) A single CMOS gate, consisting of an output node connected to a single pFETbased pullup circuit and a single nFET-based pulldown circuit (as described in lecture), computes F(A, B, C, D). It is observed that F(0, 1, 1, 1) = 1. What can you say about the following values? **Circle one of the options (0, 1, can't tell).** 
  - a.  $F(1, 1, 0, 1) = 0 \dots 1 \dots can't$  tell
  - b.  $F(0, 1, 0, 0) = 0 \dots 1 \dots can't tell$
  - c.  $F(1, 1, 1, 1) = 0 \dots 1 \dots can't$  tell
- (C) (8 Points) For each of the following Boolean functions, choose the appropriate pullup design, i.e., the one which, properly connected, implements that gate's pullup using the **minimum number of active** transistors (a FET that is never on is not active). You can connect one of the inputs (A, B, C, or D) or a constant (GND, or VDD) to each pFET.

For each expression, circle the name of your chosen pullup design (e.g. PU1) and label each pFET in your chosen design with the appropriate input or constant. You can use a design more than once. If none of the above pullups implements the function's pullup, circle "NONE".

a. 
$$F(A, B, C, D) = (\overline{ABC})\overline{D}$$





c.  $F(A, B, C, D) = (\overline{B+C})(\overline{A})(\overline{BD})$ 







d.  $F(A, B, C, D) = (\bar{A} + \bar{C})(\bar{B})(D + \bar{D})$ 



#### **Problem 4. Combinational Circuits (15 points)**

(A) (2 points) Fill out the truth table for the 3-input parity function parity that returns true if an odd number of bits are true.

| x[0] | x[1] | x[2] | out |
|------|------|------|-----|
| 0    | 0    | 0    |     |
| 0    | 0    | 1    |     |
| 0    | 1    | 0    |     |
| 0    | 1    | 1    |     |
| 1    | 0    | 0    |     |
| 1    | 0    | 1    |     |
| 1    | 1    | 0    |     |
| 1    | 1    | 1    |     |

(B) (2 points) Implement the function above in Minispec.

function Bit#(1) parity3(Bit#(3) x);

endfunction

(C) (6 points) Determine whether each of the following circuits implements the parity3 function. If it does not, change one gate in the circuit to have it implement parity3.





(D) (5 points) Implement the parametric function parity#(n) in Minispec, which computes the parity of an n-bit input, returning 1 if and only if an odd number of bits are 1. For full credit, parity#(n)must have logarithmic delay with respect to n. n is greater than or equal to 1, and not necessarily a power of two.

```
function Bit#(1) parity#(Integer n) (Bit#(n) x);
```

endfunction

# Problem 5. Combinational and Sequential Logic Timing (14 points)

(A) (3 points) Given the timing parameters in the table below, what is the propagation delay of this circuit?



| Gate | $t_{pd}$ (ns) | <i>t<sub>cd</sub></i> (ns) |
|------|---------------|----------------------------|
| OR2  | 4             | 1.5                        |
| INV  | 2             | 1                          |
| AND2 | 3             | 2                          |

Propagation delay (ns): \_\_\_\_\_

(B) (6 points) Given the timing parameters in the table below, please indicate whether or not each constraint is satisfied by the circuit below, and explain your answer. All registers are driven by a common clock with period  $t_{clk} = 10$ ns.



| Component                      | t <sub>pd</sub> (ns) | <i>t<sub>cd</sub></i> (ns) | t <sub>SETUP</sub> (ns) | t <sub>HOLD</sub> (ns) |
|--------------------------------|----------------------|----------------------------|-------------------------|------------------------|
| Register (R1, R2, R3, R4)      | 5.5                  | 1                          | 2                       | 1.5                    |
| Combinational Logic (CL1, CL2) | 2.5                  | 1                          | N/A                     | N/A                    |

Setup time constraint (select one):

SATISFIED

NOT SATISFIED

**Explanation:** 

Hold time constraint (circle one):

SATISFIED

NOT SATISFIED

**Explanation:** 

(C) (5 points) We would like for the circuit from (B) to be able to function with a clock period of 9ns. Using the replacement parts below, modify the circuit so that it can operate using a clock period of 9ns *while satisfying the setup and hold time constraints*. For full credit, minimize the number of replacements made.

| Component              | t <sub>pd</sub> (ns) | <i>t<sub>cd</sub></i> (ns) | t <sub>SETUP</sub> (ns) | t <sub>HOLD</sub> (ns) |
|------------------------|----------------------|----------------------------|-------------------------|------------------------|
| Register-New           | 3                    | 2                          | 2                       | 0.5                    |
| CombinationalLogic-New | 2                    | 0.5                        | N/A                     | N/A                    |

| CL1: | <b>REPLACED</b> (with CombinationalLogic-New) | NOT REPLACED |
|------|-----------------------------------------------|--------------|
| CL2: | <b>REPLACED</b> (with CombinationalLogic-New) | NOT REPLACED |
| R1:  | <b>REPLACED</b> (with Register-New)           | NOT REPLACED |
| R2:  | <b>REPLACED</b> (with Register-New)           | NOT REPLACED |
| R3:  | <b>REPLACED</b> (with Register-New)           | NOT REPLACED |
| R4:  | <b>REPLACED</b> (with Register-New)           | NOT REPLACED |

#### **Problem 6. Finite State Machines (12 points)**

Consider the following finite state machine. The initial state is A. The output of B is 1 and the output of all other states is 0.



(A) (3 points) Given the following inputs, determine what the next state will be after the last input is processed. Assume the FSM starts at initial State A for each series of inputs.

(i) 00010

(ii) 01000001

Final state: \_\_\_\_\_

Final state: \_\_\_\_\_

(iii) 010101010011111011101110101

Final state: \_\_\_\_\_

(B) (3 points) For the second sequence of inputs in the question above (copied below), determine what the outputs are for each cycle. Note that the FSM starts in State A in Cycle 1.

| Cycle  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 |
|--------|---|---|---|---|---|---|---|---|---|
| Input  | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| Output |   |   |   |   |   |   |   |   |   |

(C) (4 points) To encode the states, two bits  $S_1$  and  $S_0$  are used. States A, B, and C are encoded with bits 00, 01, and 10, respectively. Determine truth table for the FSM.

| $S_1^t$ | $S_0^t$ | input | $S_1^{t+1}$ | $S_0^{t+1}$ | output |
|---------|---------|-------|-------------|-------------|--------|
| 0       | 0       | 0     |             |             |        |
| 0       | 0       | 1     |             |             |        |
| 0       | 1       | 0     |             |             |        |
| 0       | 1       | 1     |             |             |        |
| 1       | 0       | 0     |             |             |        |
| 1       | 0       | 1     |             |             |        |

(D) (2 points) Find the minimal sum-of-products expression for the output.

output = \_\_\_\_\_

# END OF QUIZ 1!