



# Written exam with solutions IE1204/5 Digital Design Monday 23/10 2017 14.00-18.00

#### General Information

Examiner: Ingo Sander.

Teacher: Kista, William Sandqvist

Exam text has to be returned when you hand in your writing.

Aids: No aids are allowed!

The exam consists of three parts with a total of 14 tasks, and a total of 30 points:

**Part A1** (**Analysis**) containes ten short questions. Right answer will give you one point. Incorrect answer will give you zero points. The total number of points in Part A1 is 10 points. To pass the **Part A1** requires at least 6p, if fewer points we will not look at the rest of your exam.

Part A2 (Methods) contains two method problems on a total of 10 points.

To **pass the exam** requires at least **11 points** from A1 + A2, if fewer points we will not look at the rest of your exam.

**Part B (Design problems)** contains two design problems of a total of 10 points. Part B is corrected only if there are at **least 11p** from the exam A- Part.

**NOTE!** At the end of the exam text there is a submission sheet for Part A1, which shall be separated and be submitted together with the solutions for A2 and B.

For a passing grade (**E**) requires at **least 11 points on the exam**. If exactly 10p from A1(6p)+A2(4p), (FX), completion to (E) will be offered.

**Grades** are given as follows:

| 0 – | 11 – | 16 – | 19 – | 22 – | 25 |
|-----|------|------|------|------|----|
| F   | Е    | D    | C    | В    | A  |

The result is expected to be announced before Monday 13/11 2017.

# Part A1: Analysis

Only answers are needed in Part A1. Write the answers on the submission sheet for Part A1, which can be found at the end of the exam text.

#### **1.** 1p/0p

A function f(x, y, z) is described as:

$$f(x, y, z) = y(\overline{x \oplus z}) + x \oplus z$$

Write down the function as a product of sums (maxterms).  $f(x, y, z) = \{PoS_{Maxterms}\} = ?$ 

## 1. Proposed solution.

$$f(x, y, z) = y(\overline{x \oplus z}) + x \oplus z = \overline{xyz} + xyz + \overline{xz} + \overline{xz} = \overline{z}$$
$$= \overline{xyz} + xyz + \overline{xyz} + \overline{xyz} + x\overline{yz} + x\overline{yz}$$



$$f(x, y, z) = \{PoS_{Maxterms}\} = (x + y + z) \cdot (\overline{x} + y + \overline{z})$$

#### **2.** 1p/0p

A counter consists of four D-flip-flops and a 4-bit adder. The flip-flops are clocked simultaneously. See the figure. The counter starts with all flip-flop at zero  $q_3q_2q_1q_0 = 0000$ . What will the sequence bee from start and for the following four clockpulses?  $s_3s_2s_1s_0 = \rightarrow \rightarrow \rightarrow \dots$ ?



#### 2. Proposed solution.

$$0000+0111+1=1000 \rightarrow 1000+0111+1=(1)0000 \rightarrow 1000 \rightarrow 0000 \rightarrow 1000 \dots$$

#### **3.** 1p/0p

Two, two's complement 4-bit numbers are (hexadecimal)  $x = B_{16}$  och  $y = E_{16}$ . What will the subtraction s = x - y be? Express this number s as a decimal number with sign  $\pm s_{10} = ?$ 

2

$$x = B_{16} = -5$$
  $y = E_{16} = -2$ .  $s_{10} = (-5) - (-2) = -3$ 

Given is a Karnaugh map for a function of four variables  $Y = f(x_3, x_2, x_1, x_0)$ . Write the function  $Y_{\min}$ , as a minimized product of sums, on **PoS** form. "-" in the map means "don't care".

| $x_3x_2$ | х<br>00        | 01             | 11             | 10             |
|----------|----------------|----------------|----------------|----------------|
| 00       | 0              | <sup>1</sup> 1 | о<br>З         | <sup>2</sup> 1 |
| 01       | 4 _            | 5 <b>-</b>     | <sup>7</sup> 0 | <sup>6</sup> 0 |
| 11       | <sup>1</sup> 0 | 13             | 16             | 1.4            |
| 10       | <sup>8</sup> 1 | °O             | 10             | 1 <u>0</u>     |

3

## **4.** Proposed solution

| x <sub>3</sub> x <sub>2</sub> x <sub>1</sub> | ×<br>00        | 01             | 11             | 10             |
|----------------------------------------------|----------------|----------------|----------------|----------------|
| 00                                           | O <b>-</b>     | <sup>1</sup> 1 | <sup>3</sup> 0 | <sup>2</sup> 1 |
| 01                                           | 4 -            | 5              | <sup>7</sup> 0 | 0              |
| 11_                                          | <sup>1</sup> 0 | 13 <b>1</b>    | <sup>1</sup> 6 | 1 4            |
| 10                                           | <sup>8</sup> 1 | 0              | 11             | 1 <u>0</u>     |

$$Y_{\min} = (\bar{x}_1 + \bar{x}_0)(\bar{x}_2 + x_0)(\bar{x}_3 + x_2 + \bar{x}_0)$$

## **5**. 1p/0p

**ACT1** are cheap programable circuits with multiplexors. The figure shows how such a logic element is constructed.

Which function F(A, B) is implemented with this logic element? Write the function on minimized SoP-form.

$$F(A,B) = \{SoP\}_{\min} = ?$$



$$F1 = A \cdot 0 + \overline{A} \cdot 1 = \overline{A}$$
  $F2 = A \cdot 1 + \overline{A} \cdot 0 = A$ 

$$F = B \cdot F2 + \overline{B} \cdot F1 = B \cdot A + \overline{B} \cdot \overline{A}$$
 xnor

What function has this CMOS gate? Unfortunately some part of the PullDown net is unreadable (coated with green color), but probably you can still figure out the function?

$$Y(A, B) = ?$$



## **6**. Proposed solution.

The gate has an inverter at the output.

The PullUp-net before the inverter is then  $\overline{Y}$ .

$$\overline{Y} = \overline{A} + \overline{B}$$
  $Y = \overline{\overline{A} + \overline{B}} = \{dM\} = A \cdot B$ 



## **7**. 1p/0p



Write the transition conditions for w at the arrows in the state diagram. Answer on the submission sheet.





A T-flip-flop starts with Q = 0. The signal x is connected to the T-input. Complete the timing diagram for the output signal Q. Answer on the submission sheet.

## 8. Proposed solution.



## **9.** 1p/0p

The function f in the Karnaugh map is to be used in an asynchronous sequence circuit. Two groupings (terms) are done in the map. Which extra term has to be added as a Hazard Cover?

HazardCover = ?



## 9. Proposed solution

 $HazardCover = \overline{db}$ 



The VHDL code below describes some kind of "frequency divider". Suppose that the **Input clock** clk has the frequency 100 MHz. What will then the frequency for **Output clock** cout be?

```
ENTITY clk_div IS
PORT (
        cout :out std_logic; -- Output clock
             :in std_logic; -- Input clock
     );
END ENTITY;
ARCHITECTURE rtl OF clk div IS
     SIGNAL flipflop_q :std_logic;
BEGIN
     PROCESS(clk) BEGIN
          IF (rising_edge(clk)) THEN
            flipflop_q <= not flipflop_q;</pre>
          END IF;
     END PROCESS;
     cout <= flipflop_q;</pre>
END ARCHITECTURE;
```

#### 10. Proposed solution

flipflop\_q <= not flipflop\_q; innebär att en D-vippa togglar, vilket ger en frekvensdelning till hälften. Frekvensen för cout  $f_{\text{cout}}$  blir  $f_{\text{clk}}/2$  100/2 = **50 MHz**.

## Part A2: Methods

*Note! Part A2 will only be corrected if you have passed part A1* ( $\geq 6p$ )

#### **11.** 4p

# Automatic sliding door



limit switch opened limit switch closed

An automatic door is controlled by a SR-latch. The S input opens the door and the R input closes the door, but after at least a 4 seconds delay (this delay circuit is included in the figure and will not have to be constructed).

You will have to construct the logical circuits needed in step a) b) c) d). Use any optional gates. You don't need to minimize the logic, but strive to not use unnecessary many gates.



The block diagram below shows where the gates from the different sub tasks (a, b, c, d) will fit in.







a) Signal q opens the door by having  $m_{\rm open}=1$  until the door reaches the limit switch  $l_{\rm opened}$ . Signal q closes the door by having  $m_{\rm close}=1$  until the door reaches the limit switch  $l_{\rm closed}$ . Limit switches:  $l_{\rm opened}=0$  when the doors are full open.  $l_{\rm opened}=1$  otherwise.  $l_{\rm closed}=0$  when doors are closed.  $l_{\rm closed}=1$  otherwise.

Draw gates for this function.

**b**) An operator should be able to open and close the doors directly, with a key, *K*, regardless of the signals from the SR-latch.

 $k_{\text{open}} = 1 \text{ door must open.}$ 

 $k_{\rm close} = 1$  door must close.

When  $k_{\text{open}}$  and  $k_{\text{close}} = 0$  the operator will not effect the function any more. Draw gates for this function.





**c**) Motion sensors  $s_{\text{out}}$  and  $s_{\text{in}}$  becomes = 1 when any person is close to respective sensor. This should activate the latch S input to open the door.

If *no* person is close to the sensors, and if the door is fully open, this should activate the latch R input (after the 4s delay) to close the door. Draw gates for this function.

**d**) A timer H ( with two separate actions/output signals per day ) controls the door during the day. The door will be closed at night

 $h_{\rm day}=1$  during open daytime. The door should then open by the motion sensors for visitors to *enter* or to *leave* the building.  $h_{\rm day}=0$  all other time (at night).

 $h_{\text{evening}} = 1$  during 30 minutes after the building closes. Door should then *open* for visitors *leaving* the building, but be *closed* for visitors to *enter*.  $h_{\text{evening}} = 0$  other time. Draw gates for this function..



## **12**. 6p

Construct a synchronous binary code counter with an input signal w that follows the state diagram below.





a) (1p) Set up the encoded state table.

$$q_2^+ q_1^+ = f(w q_2 q_1)$$

(1p) Derive minimized expressons for next state

$$q_2^+ = ? \quad q_1^+ = ?$$

**b**) (1p) Realize the sequence network with D flip-flops. Use NAND-gates for function  $q_1^+$  according to the figure.

(1p) Use a 4:1 Multiplexor for function  $q_2^+$  according to the figure. The answer must be motivated. Draw your solution.

$$q_2^+(q_2q_1,w)$$
:  $mux_{00} = ?$ ,  $mux_{01} = ?$   $mux_{10} = ?$ ,  $mux_{11} = ?$ 



c) (2p) At right there are a state diagram for *another* synchronous sequential circuit with eight states  $(A \dots H)$ .

State minimize this diagram.

Answer with the *minimized* state table and state diagram.



## 12. Proposed solution.

a) (1p)

|          | $q_2^{\scriptscriptstyle +}$ | $q_1^+$ | $q_2^+$  |       |   | $q_1^+$                                            |                     |   |
|----------|------------------------------|---------|----------|-------|---|----------------------------------------------------|---------------------|---|
| $q_2q_1$ | w = 0                        | w = 1   | $q_2q_1$ | $w_0$ | 1 | $q_{\scriptscriptstyle 2}q_{\scriptscriptstyle 1}$ | <sup>w</sup> 0      | 1 |
| 00       | 00                           | 01      | 00       | 0     | 0 | 00                                                 | 0                   | 1 |
| 01       | 01                           | 10      | 01       | 0     | 1 | 01                                                 | 1                   | 0 |
| 11       | 11                           | 00      | 11       | 1     | 0 | 11                                                 | $\lfloor 1 \rfloor$ | 0 |
| 10       | 10                           | 11      | 10       | 1     | 1 | 10                                                 | 0                   | 1 |

(1p) 
$$q_2^+ = q_2 \overline{w} + q_2 \overline{q}_1 + \overline{q}_2 q_2 w \quad q_1^+ = \overline{q}_1 w + q_1 \overline{w} = q_1 \oplus w$$



c) (2p)

state 0 1 out (ABCDFGH)(E)

| A | A | В | 0 | (ABC  | FH  | )(D | G)(E) |
|---|---|---|---|-------|-----|-----|-------|
| В | D | F | 0 | (AC)  | -   | H)( | DG)(  |
| C | A | В | 0 | a,b,a | l,e |     |       |
| D | C | Ε | 0 | state | 0   | 1   | out   |
| E | D | F | 1 | а     | а   | b   | 0     |
| F | G | H | 0 | b     | d   | b   | 0     |
| G | C | Ε | 0 | d     | а   | е   | 0     |
| H | G | H | 0 | e     | d   | b   | 1     |



## Part B. Design Problems

*Note! Part B will only be corrected if you have passed part A1+A2* ( $\geq$ 11p).

two ones ..11.. in the sequence of synchronous bits entering the input w.

**13.** 5p Synchronous sequential circuit. Detector for specific events. Detect when there are at least two zeroes following after each other ..00.. or at least



The circuit starts with w = 0 which means that one zero has entered the input.

w: 010101101010001010 z: 000000010000011000

Detector output z should be '1' in the clock interval directly after the sequences has occurred.

The sequence circuit is a Moore machine with positive edge triggered D-flip-flops.

- a) (2p) Draw the **State Diagram** and set up the **State Table**.
- **b**) (2p) Set up the **Encoded State Table**, and use optional state code. Derive minimized expressions for **Next State decoder** and **Output decoder**
- c) (1p) Draw Schematic, use any optional gates.



#### **14.** 5p Synchronized burst.



An **asynchronous sequential** circuit has two inputs, *enable en* and *clock pulses cp*. As long as en = 1 complete pulses (synchronized with cp) should be output on *burst b*. This should happen as fast as a complete pulse (cp = 1) is possible. If en gets = 0 during an ongoing pulse then this pulse will also be output completly. The signal en is allways longer than the pulse en and the signal en will arrive with long intervals. See timing diagram for a typical case.

An **asynchronous sequential** circuit has two inputs, *enable en* and *clock pulses cp*. As long as *en* = 1 complete pulses (synchronized with cp) should be output as *burst b*. This should happen as fast as a complete pulse (cp = 1) is possible. If *en* gets = 0 during an ongoing pulse then this pulse will also be output completly. The signal *en* is allways longer than the pulse cp and the signal en will arrive with long intervals. See the timing diagram for a typical case.

## 14. Proposed solution.



All state transitions have Haming distance 1 when Gray code is used. Extra hazard cover is not needed.

$$q_1^+ = q_0 cp + q_1 cp$$
  $q_0^+ = \overline{cp} \cdot en + q_0 \cdot en$   $b = q_1$ 



# Good Luck!

# Submission sheet for Part A1 Sheet 1

( remove and hand in together with your answers for part A2 and part B )

| Last name:     | Given name: |   |
|----------------|-------------|---|
| Parsonal code: | Sheet:      | 1 |

| Write    | down your answers for the questions from Part A1 ( 1 to 10 ) |
|----------|--------------------------------------------------------------|
| Question | Answer                                                       |
| 1        | $f(x, y, z) = \{PoS_{Maxterms}\} = ?$                        |
| 2        | $s_3s_2s_1s_0 = \longrightarrow \longrightarrow \dots$       |
| 3        | (Two complement numbers) $B_{16} - E_{16} = \pm s_{10} = ?$  |
| 4        | $Y = \{PoS\}_{\min} = ?$                                     |
| 5        | $F(A,B) = \{SoP\}_{\min} = ?$                                |
| 6        | Y(A,B) = ?                                                   |
| 7        | $w = Q \qquad w = Q \qquad w = Q \qquad 1$                   |
| 8        | cp                                                           |
| 9        | HazardCover = ?                                              |
| 10       | $f_{\rm cout}$ = [MHz]                                       |

This table is completed by the examiner!!

| This taste is completed by the chammer. |              |    |                    |                   |     |       |  |  |
|-----------------------------------------|--------------|----|--------------------|-------------------|-----|-------|--|--|
| <b>Part A1</b> (10)                     | Part A2 (10) |    | <b>Part B</b> (10) | <b>Total</b> (30) |     |       |  |  |
| Points                                  | 11           | 12 | 13 14              |                   | Sum | Grade |  |  |
|                                         |              |    |                    |                   |     |       |  |  |
|                                         |              |    |                    |                   |     |       |  |  |