Department of Electrical and Computer Engineering COEN 312 Dec.15, 2009 Answer all Questions. All questions carry equal marks. Exam Duration 3 hour Examiners: Asim J. Al-Khalili, Shah Jahinuzzaman <u>No books / papers or electronic devices are allowed.</u>

#### Question 1

| a)Given F1 and F2 below, determine F1 $\bullet$ F2 and F1 + F2<br>F1= AB + C,<br>F2= A'C' + B'C'                                                                                                              | (3 Marks)         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| b) Minimize the following Boolean Function:<br>F(A,B,C,D)= ABC' + BC'D' + AC'D + ABC + BCD' + A                                                                                                               | (3 Marks)<br>ACD' |
| <ul> <li>c) Given f(A,B,C) = AB +A C' + BC</li> <li>i) Implement f in <u>NOR-NOR</u> format</li> <li>ii) Implement f in <u>AND-OR-INVERT</u> format</li> <li><u>Obtain optimum implementation.</u></li> </ul> | (4 Marks)         |

#### **Question 2**

a) Design a combinational circuit that implements (8 Marks)  $F=2t^2-2$ t can take the integer values of 1 or 2 <u>only</u>. <u>Show your design steps clearly starting with the Truth Table.</u> <u>Draw the final circuit</u>.

b) If the function is to be implemented on a ROM what size of ROM is required? (2 Marks)

# **Question 3**

a) Design a 1-bit full adder. Clearly show the truth table and logic diagram. (4 Marks)

b) Use a 1-bit full adder plus extra logic if required to design a 4-bit <u>serial subtractor for</u> <u>unsigned numbers</u>. The full adder can be assumed as a block having two 1-bit inputs, A and B, an input carry, an output SUM, and an output CARRY. (6 Marks)

### **Question 4**

a) Use 2 to 1 MUXes to build a 4 to 1 MUX.(2Marks)b) Use a 8 to1 MUX to implement F(2 Marks)F(A,B,C,D)= ABC' + BC'D' + AC'D + ABC + BCD' + ACD'

c) Use a 4 to1 MUX plus minimal extra logic to implement F. (4 Marks)

d) What is the delay of the circuit if any gate has a delay of d. Take the internal structure of the MUX into account. (2 Mark)

# **Question 5**

Design an <u>UP/DOWN BCD</u> counter, starting with a state diagram. Use D-Flip Flop for your implementation. (10 Marks)

### **Question 6**

The sequential circuit given below uses a PAL to implement the combinational logic.Analyze the circuit below fully. Derive the Transition Table, Excitation Table, StateDiagram and the Output.(8 Marks)State what the function does.(2 Marks)



Q1

a) 
$$F1 = AB + C$$
,  $F2 = A'C' + B'C'$ 

$$F1 \cdot F2 = (AB+C)(A'C'+B'C') = 0$$

$$F1+F2 = AB+C+A'C'+B'C'$$

$$AB+(C+A')(C+C')+B'C'$$

$$AB+C+A'+B'C'$$

$$(A'+A)(A'+B)+(C+B')(C+C')$$

$$A'+B+C+B'$$
1

b)  

$$F = ABC'+BC'D'+AC'D+ABC+BCD'+ACD'$$

$$F = AB(C'+C)+BD'(C'+C)+AC'D+ACD'$$

$$F = AB+BD'+AC'D+ACD'$$

c) 
$$f = AB + AC + BC$$
  
Apply consensus  $f = AC + BC$ 

i) NOR-NOR

$$f' = (A'+B')(A'+C)(B'+C')$$
  

$$f' = (A'+A'B'+A'C+B'C)(B'+C')$$
  

$$f' = (A'B'+A'B'C+B'C+A'C'+A'B'C')$$
  

$$f' = A'B'+B'C+A'C'$$

:. f = (A'B'+B'C+A'C')'f = [(C+C')+(B+C')'+(A+C)']' (consensus)



#### ii) AND-OR-INVERT

# f' = A'B'+B'C+A'C'f = (A'B'+B'C+A'C')'



Q2

a)  $F = 2t^2 - 2$ , t=1 or 2 only, so maximum input width 2bits (00 or 10) with t=2, F=2.2<sup>2</sup>-2=6, so maximum output width 3bits

| $t_1$ | $t_0$ |   | $F_2$ | $F_1$ | $F_0$ |
|-------|-------|---|-------|-------|-------|
| 0     | 0     | - | Х     | Х     | Х     |
| 0     | 1     | - | 0     | 0     | 0     |
| 1     | 0     | - | 1     | 1     | 0     |
| 1     | 1     | - | х     | х     | Х     |
|       |       |   |       |       |       |





a) Full adder: Inputs A, B, Cin Outputs S, Cout

| А | В | Cin |   | S | Cout |
|---|---|-----|---|---|------|
| 0 | 0 | 0   | - | 0 | 0    |
| 0 | 0 | 1   | - | 1 | 0    |
| 0 | 1 | 0   | - | 1 | 0    |
| 0 | 1 | 1   | - | 0 | 1    |
| 1 | 0 | 0   | - | 1 | 0    |
| 1 | 0 | 1   | - | 0 | 1    |
| 1 | 1 | 0   | - | 0 | 1    |
| 1 | 1 | 1   | - | 1 | 1    |



| BC.   |     |    |    |    |
|-------|-----|----|----|----|
| A ~ m | 0.0 | 01 | 11 | 10 |
| 0     | 0   | 1  | 0  | 1  |
| 1     | 1   | 0  | 1  | 0  |

$$S = A \oplus B \oplus C_{in}$$

| BC |     |    |    |    |
|----|-----|----|----|----|
| A  | 0 0 | 01 | 11 | 10 |
| 0  | 0   | 0  | 1  | 0  |
| 1  | 0   | 1  | 1  | 1  |

$$C_{out} = BC_{in} + AC_{in} + AB$$
$$= AB + C_{in}(A \oplus B)$$





OR



Substraction can be done using the addition of two operands when one of the operands is in 2's complement form. 2's complement of an operand can be obtained by inverting all the bits and adding a 1 to the operand. In a full adder, the addition of 1 to the inverted bits can be done by setting the input carry to 1. For a serial adder, the input carry should be

'set' to 1 only at the first clock cycle.



Q4 a)

4-to-1 MUX from 2-to-1 MUX



b)

| А | В | С | D | F |                            |
|---|---|---|---|---|----------------------------|
| 0 | 0 | 0 | 0 | 0 | $\mathbf{F} = 0$           |
| 0 | 0 | 0 | 1 | 0 |                            |
| 0 | 0 | 1 | 0 | 0 | $\mathbf{F} = 0$           |
| 0 | 0 | 1 | 1 | 0 | $\Gamma = 0$               |
| 0 | 1 | 0 | 0 | 1 | F - D'                     |
| 0 | 1 | 0 | 1 | 0 | $\Gamma = D$               |
| 0 | 1 | 1 | 0 | 1 | $\mathbf{F} - \mathbf{D}'$ |
| 0 | 1 | 1 | 1 | 0 | г – D                      |
| 1 | 0 | 0 | 0 | 0 | E – D                      |
| 1 | 0 | 0 | 1 | 1 | $\Gamma = D$               |
| 1 | 0 | 1 | 0 | 1 | E – D                      |
| 1 | 0 | 1 | 1 | 0 | $\Gamma = D$               |
| 1 | 1 | 0 | 0 | 1 | $\mathbf{F} = 1$           |
| 1 | 1 | 0 | 1 | 1 | $1^{\circ} - 1$            |
| 1 | 1 | 1 | 0 | 1 | $\mathbf{E} = 1$           |
| 1 | 1 | 1 | 1 | 1 | $\Gamma - 1$               |



c)

| Α | В | С | D | F |                              |
|---|---|---|---|---|------------------------------|
| 0 | 0 | 0 | 0 | 0 | AB = 0                       |
| 0 | 0 | 0 | 1 | 0 | $\mathbf{F} = 0$             |
| 0 | 0 | 1 | 0 | 0 |                              |
| 0 | 0 | 1 | 1 | 0 |                              |
| 0 | 1 | 0 | 0 | 1 | $\Delta \mathbf{D} = 0.1$    |
| 0 | 1 | 0 | 1 | 0 | AD = 01 $E = C'D' + CD'$     |
| 0 | 1 | 1 | 0 | 1 | $\Gamma = C D + CD$<br>= D'  |
| 0 | 1 | 1 | 1 | 0 | - D                          |
| 1 | 0 | 0 | 0 | 0 | $\Delta \mathbf{D} = 10$     |
| 1 | 0 | 0 | 1 | 1 | AD = 10<br>$F = C'D \pm CD'$ |
| 1 | 0 | 1 | 0 | 1 | F = C D + CD                 |
| 1 | 0 | 1 | 1 | 0 | $-C \oplus D$                |
| 1 | 1 | 0 | 0 | 1 |                              |
| 1 | 1 | 0 | 1 | 1 | AB = 11                      |
| 1 | 1 | 1 | 0 | 1 | F = 1                        |
| 1 | 1 | 1 | 1 | 1 |                              |



b)

To calculate the delay, we consider the internal structure of the 4-to-1 MUX: So for the above circuit implementation with MUX, the number of gates is:

From A to F = 3From B to F = 3From C to F = 3From D to F = 3

So the worst case delay = 3 gate delays = 3d.





| Control | P | resen | t Stat | e |   | Next | State | e | Fli   | ip-Flo         | p Inpu         | ıts            |
|---------|---|-------|--------|---|---|------|-------|---|-------|----------------|----------------|----------------|
| Е       | А | В     | С      | D | Α | В    | С     | D | $D_A$ | D <sub>B</sub> | D <sub>C</sub> | D <sub>D</sub> |
| 0       | 0 | 0     | 0      | 0 | 1 | 0    | 0     | 1 | 1     | 0              | 0              | 1              |
| 0       | 0 | 0     | 0      | 1 | 0 | 0    | 0     | 0 | 0     | 0              | 0              | 0              |
| 0       | 0 | 0     | 1      | 0 | 0 | 0    | 0     | 1 | 0     | 0              | 0              | 1              |
| 0       | 0 | 0     | 1      | 1 | 0 | 0    | 1     | 0 | 0     | 0              | 1              | 0              |
| 0       | 0 | 1     | 0      | 0 | 0 | 0    | 1     | 1 | 0     | 0              | 1              | 1              |
| 0       | 0 | 1     | 0      | 1 | 0 | 1    | 0     | 0 | 0     | 1              | 0              | 0              |
| 0       | 0 | 1     | 1      | 0 | 0 | 1    | 0     | 1 | 0     | 1              | 0              | 1              |
| 0       | 0 | 1     | 1      | 1 | 0 | 1    | 1     | 0 | 0     | 1              | 1              | 0              |
| 0       | 1 | 0     | 0      | 0 | 0 | 1    | 1     | 1 | 0     | 1              | 1              | 1              |
| 0       | 1 | 0     | 0      | 1 | 1 | 0    | 0     | 0 | 1     | 0              | 0              | 0              |
| 0       | Х | Х     | Х      | Х | 0 | 0    | 0     | 0 | 0     | 0              | 0              | 0              |
| 1       | 0 | 0     | 0      | 0 | 0 | 0    | 0     | 1 | 0     | 0              | 0              | 1              |
| 1       | 0 | 0     | 0      | 1 | 0 | 0    | 1     | 0 | 0     | 0              | 1              | 0              |
| 1       | 0 | 0     | 1      | 0 | 0 | 0    | 1     | 1 | 0     | 0              | 1              | 1              |
| 1       | 0 | 0     | 1      | 1 | 0 | 1    | 0     | 0 | 0     | 1              | 0              | 0              |
| 1       | 0 | 1     | 0      | 0 | 0 | 1    | 0     | 1 | 0     | 1              | 0              | 1              |
| 1       | 0 | 1     | 0      | 1 | 0 | 1    | 1     | 0 | 0     | 1              | 1              | 0              |
| 1       | 0 | 1     | 1      | 0 | 0 | 1    | 1     | 1 | 0     | 1              | 1              | 1              |
| 1       | 0 | 1     | 1      | 1 | 1 | 0    | 0     | 0 | 1     | 0              | 0              | 0              |
| 1       | 1 | 0     | 0      | 0 | 1 | 0    | 0     | 1 | 1     | 0              | 0              | 1              |
| 1       | 1 | 0     | 0      | 1 | 0 | 0    | 0     | 0 | 0     | 0              | 0              | 0              |
| 1       | Х | Х     | Х      | Х | 0 | 0    | 0     | 0 | 0     | 0              | 0              | 0              |



Q6)

| Q(t) | Α | В |   | Q(t+1) | D |
|------|---|---|---|--------|---|
| 0    | 0 | 0 | - | 0      | 0 |
| 0    | 0 | 1 | - | 1      | 1 |
| 0    | 1 | 0 | - | 0      | 0 |
| 0    | 1 | 1 | - | 0      | 0 |
| 1    | 0 | 0 | - | 1      | 1 |
| 1    | 0 | 1 | - | 0      | 0 |
| 1    | 1 | 0 | - | 0      | 0 |
| 1    | 1 | 1 | - | 0      | 0 |

$$D_A = Q'A'B + QA'B'$$
$$= A'(Q'B + QB')$$
$$= A'(Q \oplus B)$$



Whenever A=0 & Q not equal to B, output becomes '1' on next state

| Q | Α | В |              |
|---|---|---|--------------|
| 0 | 0 | 0 | Hold State   |
| 1 | 0 | 0 | Hold State   |
| 0 | 0 | 1 | Tagala Stata |
| 1 | 0 | 1 | Toggle State |
| 0 | 1 | Х | Pasat        |
| 1 | 1 | Х | Keset        |