# Sample Solutions

**CprE 281: Digital Logic** 

Midterm 2: Friday Oct 27, 2017

Student Name: \_\_\_\_\_ Student ID Number: \_\_\_\_

Lab Section: Mon 9-12(N) Tue 11-2(U) Wed 8-11(J) Thur 11-2(Q) Fri 11-2(G)

(circle one) Mon 12-3(P) Tue 2-5(M) Wed 11-2(W) Thur 11-2(V)

Tue 2-5(Z) Wed 6-9(T) Thur 2-5(L)

Thur 5-8(K)

## 1. True/False Questions ( $10 \times 1p$ each = 10p)

(a) I forgot to write down my name and student ID number and lab section.

TRUE / (FALSE)

(b) When  $K=\overline{J}$  a JK flip-flop behaves just like a D flip-flop.

TRUE )/ FALSE

(c) Any Boolean function can be implemented using only 1-to-4 demultiplexers.

TRUE )/ FALSE

(d) The outputs of a demultiplexer are one-hot encoded.

TRUE / FALSE

(e) A D-Latch changes its value only when the clock is 1.

TRUE / FALSE

(f) XOR(XOR(A, B), B) = A.

TRUE / FALSE

(g) In 4-bit 2's complement: 1010 + 0111 results in an overflow.

TRUE / FALSE

(h) In 16-bit 2's complement: FACE<sub>16</sub> < CAFE<sub>16</sub>

TRUE (FALSE)

(i) A D-flip flop and a NOT gate can be used to implement a T-flip flop.

TRUE /(FALSE)

(j) According to George Lucas, Princes Leia got her Ph.D. at age 19.

TRUE / FALSE

## 2. Prime Numbers (5p)

Let f(a, b, c, d) be a Boolean function that is equal to 1 if and only if the 4-bit number abcd is prime. Use a K-map to derive the minimum SOP expression for the function f.



# 3. Binary Addition and Subtraction (4 x 3p each = 12p)

Convert the following integers into binary numbers and perform the addition or subtraction using 2's complement if necessary. Write your answers and all intermediary steps to the right of each problem. <u>Use 5-bit numbers</u> for all problems and indicate if any bits need to be ignored.

## 4. JK Flip-Flop (8pt)

Complete the wiring diagram below to implement a negative-edge-triggered JK flip-flop. Clearly label all inputs and outputs.



## 5. Code Converter (5p + 5p = 10p).

Your task is to design a code converter with two inputs  $(X_1 \text{ and } X_0)$  and four outputs  $(Y_3, Y_2, Y_1, \text{ and } Y_0)$  that has the following truth table:

| $X_1$ | $X_0$ | $\mathbf{Y}_3$ | Y <sub>2</sub> | $\mathbf{Y}_1$ | Y <sub>0</sub> |
|-------|-------|----------------|----------------|----------------|----------------|
| 0     | 0     | 1              | 1              | 1              | 0              |
| 0     | 1     | 1              | 1              | 0              | 1              |
| 1     | 0     | 1              | 0              | 1              | 1              |
| 1     | 1     | 0              | 1              | 1              | 1              |

a) Derive the correct Boolean expressions for the four outputs.

$$Y_3 = \overline{X_1 + X_0}$$

$$Y_2 = \overline{\times}_1 + \times_{\circ}$$

$$Y_1 = X_1 + \overline{X_0}$$

$$Y_0 = \times_t + \times_{\circ}$$

b) Draw the full wiring diagram of this code converter using basic logic gates. Label all inputs and outputs.



6. Computations with Adders ( $5 \times 3p$  each = 15p)

Let  $A = A_1 A_0$  be a 2-bit <u>unsigned</u> binary number. Let  $B = B_5 B_4 B_3 B_2 B_1 B_0$  be the result of the operation, interpreted as a number in 2's complement representation. For each of the following, write a formula for the value of B. The problem in a) is already solved.



$$B = A + 1$$



$$B = 2A + A + 1$$
$$= 3A + 1$$



$$B = 4A + A + 5 + 0$$
$$= 5A + 5$$



$$B = A + (-1) + 0$$
$$= A - 1$$



$$B = 8 + A - (2A + 1)$$
  
= 7 - A



$$B = (2A+1+4+A+1)2+1$$

$$= (3A+6)2+1$$

$$= 6A+13$$

## 7. Flip-Flops and Timing Diagrams ( $3 \times 5p = 15p$ )

Complete the timing diagram for the specified flip-flop such that the output Q will be as indicated. Assume that the input signal can change only on the <u>vertical lines</u>. Also, assume that the setup time  $t_{su}$  and the hold time  $t_h$  are <u>each</u> equal to the width of one square.

a) Complete the timing diagram for the D input to a negative-edge triggered D flip-flop.



b) Complete the timing diagram for the T input to a negative-edge triggered T flip-flop.



c) Complete the timing diagram for the J input to a <u>negative</u>-edge triggered JK flip-flop.



8. Multiplexers  $(3 \times 5p \text{ each} = 15p)$ 

a) Draw the truth table for the function  $f(x, y, z) = \overline{x} \overline{y} z + \overline{x} y \overline{z} + \overline{x} \overline{y} \overline{z}$ .

|   | 1     |     |     |     | 1 6 | •         | J          |
|---|-------|-----|-----|-----|-----|-----------|------------|
|   | XYZ   | XYZ | XYZ | XXZ | 1+  |           |            |
|   | 000   | 0   | 0   | 0   | 0   | $\supset$ |            |
|   | 001   | 1   | 0   | 0   | 1   | 5         | XOR (Y, Z) |
|   | 010   | 0   | 1   | 0   |     | (         | 0.7-)      |
|   | 011   | 0   | 0   | 0   | 0   | )         |            |
| - | 100   | Ø   | 0   | 1   | . ( | 7         |            |
|   | 101   | 0   | 0   | 0   | 0   | >         | NOR (Y, Z) |
|   | 110   | 0   | 0   | 0   | 0   |           |            |
|   | ( ( ) | 0   | 0   | 0   | 0   | J         |            |

b) Implement this function using <u>only</u> 2-to-1 multiplexers and <u>no other logic gates</u>. Assume that the signals x, y, and z are available <u>only</u> in their non-inverted form as well as the constants 0 and 1. Clearly label all inputs, outputs, and pins.



c) Implement this function using a 3-to-8 decoder (with enable) and one OR gate. Clearly label all inputs, outputs, and pins of the decoder.



## 9. Alternative Implementation (10p)

Implement the logic gates OR, XOR, and NAND in three different ways: 1) using a 2-to-1 multiplexer; 2) using AND-OR logic; and 3) using OR-AND logic. In this problem, you are not allowed to use any other logic gates. Assume that both x and y are available in their inverted and non-inverted form, along with the constants 0 and 1. If some implementation is not possible, then indicate that with words. Label all inputs and outputs.

a) Implement in three different ways: f = OR(x, y).











b) Implement in three different ways: f = XOR(x, y).













c) Implement in three different ways: f = NAND(x, y).





- 10. Mystery Circuit (5p + 10p = 15p)
- (a) The truth table and the graphical symbol for a mystery circuit are shown below. Implement this circuit using a 4-to-1 multiplexer and any number of basic logic gates (AND, OR, NOT). Assume that the input variables are available <u>only</u> in their regular (i.e., non-inverted form) as well as the constants 0 and 1. Label all inputs, outputs, and pins.



(b) Implement a 2-to-1 multiplexer using <u>only</u> copies of the mystery circuit and <u>no other</u> logic gates. Please use the graphical symbol of the mystery circuit to denote each copy. You can assume that the input variables are available <u>only</u> in their regular (i.e., non-inverted form) as well as the constants 0 and 1. Label all inputs, outputs, and pins of your circuit.



#### 11. Parallel Load and Shift Left/Right Register (15p)

Complete the following circuit diagram to implement a 4-bit register that has both parallel load and shift left/right functionality. The register has two control inputs  $(C_1 \text{ and } C_0)$ , four parallel input lines  $(I_3, I_2, I_1, \text{ and } I_0)$ , and four output lines  $(Q_3, Q_2, Q_1, \text{ and } Q_0)$ . Depending on the values of  $C_1$  and  $C_0$ , the register performs one of the following four operations:

| $\mathbf{C}_{1}$ | C <sub>0</sub> | Operation                                                                            |
|------------------|----------------|--------------------------------------------------------------------------------------|
| 0                | 0              | Hold the current value (i.e., Q3 Q2 Q1 Q0 are not changed)                           |
| 0                | 1              | Shift left (i.e., new $Q_3=Q_2$ , new $Q_2=Q_1$ , new $Q_1=Q_0$ , new $Q_0=I_0$ )    |
| 1                | 0              | Shift right (i.e., new $Q_3=I_3$ , new $Q_2=Q_3$ , new $Q_1=Q_2$ , new $Q_0=Q_1$ )   |
| 1                | 1              | Load new data (i.e., new $Q_3=I_3$ , new $Q_2=I_2$ , new $Q_1=I_1$ , new $Q_0=I_0$ ) |

Clearly label all inputs, outputs, and pins.



| Question                      | Max | Score |
|-------------------------------|-----|-------|
| 1. True/False                 |     |       |
| 2. Prime Numbers              | 5   |       |
| 3. Addition/Subtraction       | 12  |       |
| 4. JK Flip-Flop               | 8   |       |
| 5. Code Converter             | 10  |       |
| 6. Computations with Adders   | 15  |       |
| 7. Flip-Flops                 | 15  |       |
| 8. Multiplexers               | 15  |       |
| 9. Alternative Implementation | 10  |       |
| 10. Mystery Circuit           | 15  |       |
| 11. Register                  | 15  |       |
| TOTAL:                        | 130 |       |

.