

ELEC 204

Digital Design Preliminary

Lab Report

Pre Lab: 04

Name: Burhan Karakas

Date: 27.12.2020

## LED PING-PONG GAME

---

Qn.1 In the given code, there are two processes; one for clock dividing and another one demanded purpose. The clock divider process is sensitive to clock change and it increases a counter at the rising edges. When counter reaches to a previously assigned value, it causes an alteration in the output signal. In this code the clock divider decreases the frequency from 50MHz to  $\frac{1}{2}$  Hz. The second process is sensitive to the alternating signal -

P

## State Diagram

There are 4 LED outputs whose names are A, B, C and D respectively. I defined 6 different states called  $A_1, B_1, C_1, D_1, C_2$  and  $B_2$ . Names indicate which LED is on, for example, B LED gives high when the present state is either  $B_1$  or  $B_2$ .

I defined 2 inputs called Left and Right which are taking their values from two push buttons. I defined two more outputs namely X and Y which represent the score earned for players.



(2)

# State Table

| <u>Present State</u>    | <u>Next State</u> | <u>Output</u>                                                                                                                                                       |
|-------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A: 000001               | 000010            | LR = $\begin{array}{cccc} 00 & 01 & 10 & 11 \\ \overline{00} & \overline{00} & \overline{10} & \overline{10} \\ 00 & 00 & 00 & 00 \\ 00 & 00 & 00 & 00 \end{array}$ |
| B <sub>1</sub> : 000010 | 000100            |                                                                                                                                                                     |
| C <sub>1</sub> : 000100 | 001000            |                                                                                                                                                                     |
| D: 001000               | 010000            |                                                                                                                                                                     |
| C <sub>2</sub> : 010000 | 100000            |                                                                                                                                                                     |
| B <sub>2</sub> : 100000 | 000001            |                                                                                                                                                                     |

L = Left Push

R = Right Push

X = catch for A

Y = catch for D

State Equations (D-type FF)

$$D_6 = Q_6^+ = Q_5$$

$$X = Q_1 L$$

$$D_5 = Q_5^+ = Q_4$$

$$Y = Q_4 R$$

$$D_4 = Q_4^+ = Q_3$$

$$A = Q_1$$

$$D_3 = Q_3^+ = Q_2$$

$$B = Q_2 + Q_6$$

$$D_2 = Q_2^+ = Q_1$$

$$C = Q_5 + Q_3$$

$$D_1 = Q_1^+ = Q_6$$

$$D = Q_4$$

# Circuit Design

(3)



# Score Counter

⑨

X and Y will be the inputs of score counter component.

The circuit I use is normally a clock divider circuit whose last output gives the clock in demanded period. However, if we take all of the outputs as a vector then it becomes a binary counter clock. For the score counting purpose we define the first input as X (or Y). It utilizes 4 D type FFS.

