## Page 1 of 11

# King Fahd University of Petroleum and Minerals College of Computer Science and Engineering Computer Engineering Department

# COE 202: Digital Logic Design (3-0-3) Term 141 (Fall 2014) Major Exam II Saturday November 29, 2014

## Time: 150 minutes, Total Pages: 11

Name:\_\_\_\_\_\_ ID:\_\_\_\_\_ Section: \_\_\_\_\_

## Notes:

- Do not open the exam book until instructed
- Calculators are not allowed (basic, advanced, cell phones, etc.)
- Answer all questions
- All steps must be shown
- Any assumptions made must be clearly stated

| Question | Maximum Points | Your Points |
|----------|----------------|-------------|
| 1        | 17             |             |
| 2        | 14             |             |
| 3        | 10             |             |
| 4        | 12             |             |
| 5        | 12             |             |
| Total    | 65             |             |

# Page 2 of 11 (17 Points)

# **Question 1**

For the given K-map representing the Boolean function F, answer the following questions:

(i) Which one of the following is an Implicant of F:

| Term               | A'C' | A'BD | AC | A'B'C' | BCD' |
|--------------------|------|------|----|--------|------|
| Implicant<br>(Y/N) |      |      |    |        |      |



(ii) Which one of the following is a Prime Implicant (PI) of F:

| Term        | AC' | A'BC | BC'D | C'D | AD' |
|-------------|-----|------|------|-----|-----|
| PI<br>(Y/N) |     |      |      |     |     |

(iii) Which one of the following is an Essential Prime Implicant (EPI) of F:

|              | C'D | A'BC | A'C' | BC'D | AD' |
|--------------|-----|------|------|------|-----|
| EPI<br>(Y/N) |     |      |      |      |     |

(iv) Obtain a simplified sum-of-product (SOP) expression for F.

(v) The following Boolean expression F = AD + A'C'D' is a simplified version of the expression F = A'B'C'D' + ABCD + AB'C'D. Are there any don't care conditions? If so, what are they?

(vi) Implement the circuit given below <u>using only 2-input NAND gates</u>. Redraw the circuit to obtain a multi-level NAND circuit implementation. Assume that only the true form of each input variable is available.



# Page 4 of 11

## (14 Points)

# Question 2.

(i) Fill in all blank cells in the two tables below.

|          | Equivalent decimal value with the binary interpreted as: |                  |                   |                       |  |
|----------|----------------------------------------------------------|------------------|-------------------|-----------------------|--|
| Binary   | Unsigned                                                 | Signed-magnitude | Signed-1's        | Signed-2's complement |  |
|          | number                                                   | number           | complement number | number                |  |
| 10110110 |                                                          |                  |                   |                       |  |

|         | Binary representation in 8 bits: |                                      |                                      |  |  |
|---------|----------------------------------|--------------------------------------|--------------------------------------|--|--|
| Decimal | Signed-magnitude representation  | Signed-1's complement representation | Signed-2's complement representation |  |  |
| + 100   |                                  |                                      |                                      |  |  |
| - 100   |                                  |                                      |                                      |  |  |

(ii) Show how the following arithmetic operations are performed using 5-bit signed 2's-complement system. Check for overflow and mark clearly any overflow occurrences.

| 01001<br>- 11110 | (i)                       | 10100<br>+_11100 | (ii)                     |
|------------------|---------------------------|------------------|--------------------------|
| 11111<br>+ 11111 | Overflow: Yes/No<br>(iii) | 01101<br>- 11101 | Overflow: Yes/No<br>(iv) |
|                  | Overflow: Yes/No          |                  | Overflow: Yes/No         |

## **Question 3.**

Page 5 of 11

#### (10 points)

- (i) It is required to design a combinational circuit that receives a 4-bit input number, X3X2X1X0, and computes the number of leading zero's in the input. For example, if the input X3X2X1X0=0111 or X3X2X1X0=0100, the output should produce a result indicating that there is a single leading zero. Construct the truth table of the circuit. You do not need to derive the Boolean expressions of the outputs. (5 points)
- Using a block diagram of the design of the 4-bit leading-zero detector circuit in (i) and any other needed MSI blocks (e.g. Adder, Comparator, Multiplexer, Decoder, etc.), design a combinational circuit that receives an 8-bit input number, X7X6X5X4X3X2X1X0, and computes the number of leading zero's in the input. (5 points)

Page 6 of 11

Page 7 of 11

## **Question 4.**

(12 Points)

Using <u>only</u> the following modules:

- One 2-to-4 Decoder with enable,
- One 4-to-1 MUX,
- A maximum of five 1-to-2 DeMUXs /Decoders, and
- The minimum number of 2-input NAND gates (*If needed*)

Implement the following assuming that <u>signals are available only in the "True" but not the</u> <u>complement</u> form:

- (i) A 3-to-8 Decoder (*you may use this decoder as a black-box in solving* (ii) and/or (iii) below)
- (ii) F1(a,b)= ab+a'b'
- (iii) F2(a,b,c)= m0+ m1+m2+m4+m7

Label all your signals (inside and outside MSI components).

Page 8 of 11

#### **Question 5.**

It is required to design an *n*-bit magnitude comparator. The circuit receives two *n*-bit unsigned numbers A and B and produces two outputs **GT** and **EQ** as given in the table to the right.

The input operands are processed in a bitwise manner <u>starting with the</u> <u>most significant bit (MSB)</u>. The comparator circuit is constructed using *n* identical copies of the basic 1-bit *cell* shown to the right. *Cell i* processes the *i*<sup>th</sup> input bits ( $A_i$  and  $B_i$ ) together with information passed to it from its predecessor cell ( $GT_{i+1}$  and  $EQ_{i+1}$ ). It produces two output bits ( $GT_i$  and  $EQ_i$ ). The *cell* output  $GT_i = 1$  <u>iff</u> ( $A_{n-1}A_{n-2}$ ...  $A_{i+1}A_i > B_{n-1}B_{n-2}$ ...  $B_{i+1}B_i$ ) and  $EQ_i = 1$  iff ( $A_{n-1}A_{n-2}$ ...  $A_{i+1}A_i = B_{n-1}$  $B_{n-2}$ ...  $B_{i+1}B_i$ ).

The Figure below shows the *n*-bit comparator circuit implemented using *n* copies of the basic 1bit cell. The output of the *n*-bit comparator is that of the  $\underline{n}^{th}$  cell copy (cell 0; the leastsignificant). Note that the inputs  $GT_n$  and  $EQ_n$  to the <u>first</u> cell (cell *n*-1; the most significant) are set to <u>0 and 1</u> respectively as there are no more significant bits.



Boolean expressions of the outputs of <u>cell i</u> and its gate-level implementation are given below:

| $GT_i = GT_{i+1} + A_i \overline{B}_i EQ_{i+1}$ , and |
|-------------------------------------------------------|
| $EQ_i = (A_i \odot B_i) \cdot EQ_{i+1}$               |

Assuming that the **XOR** and **XNOR** gates have a delay of  $2\tau$  while <u>all OTHER gates (including inverters) have a delay of</u>  $1\tau$ , calculate:



Page 9 of 11

(**12** Points)

|            | GT | EQ |
|------------|----|----|
| IF $A > B$ | 1  | 0  |
| IF $A = B$ | 0  | 1  |
| IF $A < B$ | 0  | 0  |
| IF $A < B$ | 0  | 0  |



# Page 10 of 11

#### (i) The worst case delay of the 3-bit comparator (as a function of $\tau$ ) shown below



(ii) The worst case delay of an n-bit comparator (as a function of n and  $\tau$ ) (3 Points)

#### Page 11 of 11

(iii) Suggest a design for a cascadeable 3-bit comparator with lookahead capability. What is the worst case delay of this unit (using the same delay model of  $2\tau$  for XOR/XNOR gates and  $1\tau$  for all other gates (irrespective of their fanin)? (5 Points)

For convenience, the comparator circuit and Boolean expressions of the cell are repeated here.



Boolean expressions of the outputs of <u>cell i</u> and its gate-level implementation are given below:

 $GT_i = GT_{i+1} + A_i \overline{B}_i EQ_{i+1}$ , and  $EQ_i = (A_i \odot B_i) \cdot EQ_{i+1}$