combinational 20

## Sequential logic design

Vikas Dhiman for ECE275

October 26, 2022

#### 1 **Objectives**

- 1. Building blocks of sequential circuits
- 2. Analyze a sequential circuit and derive a state-table and a state-graph
- 3. Derive a state graph or state table from a word description of the problem

Understanding the structure of an FPGA Why do we need sequential

**Example 1.** Think about this problem: Design an occupancy counter that depends on a sensor S at the class door. The sensor is triggered every time a person passes through the door. The counter can be reset to zero with a reset button. Assume we only need up to two bit counter  $C_1C_0$ . Draw a truth table for this circuit. Do you have requisite knowledge for designing this circuit? Can this

circuit be designed without a memory element. 0

How to create memory element from circuits

Two types of memory

- 1. Volatile memory. For example, RAM, CPU registers.
- 2. Non-volatile memory. For example, SSD, Flash drives. (Not covered in this course)

Slowest

Random (a) Memories that require periodic refreshing. For example, DRAM: Dynamica Random Access memory (Not covered in this course)



**Example 2** (Ring oscillator ). [1, Sec 3, 31] How many stable states does the following circuit have?



Example 3. Analyze the timing diagram of the following circuit.

 $<sup>^1\</sup>mathrm{Image\ source}$ : allaboutcircuits.com/technical-articles/introduction-to-dram-dynamic-random-access-memory/







### 4.2 Gated SR latch [2, Sec 5.2]

2

 $\textbf{Definition 5} \ (\textbf{Gated SR latch}). \ \textit{The following circuit is called the Gated SR latch}.$ 





# Toronsparent latch

### 4.3 D (Data) latch [1, Sec 3.2.2]

**Definition 6** (D latch). The following circuit is called the D latch.



- 1. Draw its characteristic table.
- 2. Draw the D latch symbol



-> T-lip flok





4.4 D flip-flop [1, Sec 3.2.2]

**Definition 7** (D flip-flop). The following circuit is called the D flip-flop.



- 1. Draw its timing diagram
- 2. Draw its characteristic table.
- 3. Draw the D flip-flop symbol

Remark 1. What is the difference between a latch and a flip flop?

The flop flops edge the edge the edge the floor the edge the e

Example 4. Add a RESET signal to the D flip-flop that resets the state of

**Example 5.** The toggle (T) flip-flop has one input, CLK, and one output, Q. On each rising edge of CLK, Q toggles to the complement of its previous value. Draw a schematic for a T flip-flop using a D flip-flop and an inverter.



Toggle How con we construct
from D-f-lip flop? Toriangler trisgered **Problem 2.** A JK flip-flop receives a clock and two inputs, J and K. On the rising edge of the clock, it updates the output, Q. If J and K are both 0, Q retains its old value. If only J is 1, Q becomes 1. If only K is 1, Q becomes 0. If both J and K are 1, Q becomes the opposite of its present state.

1. Construct a JK flip-flop using a D flip-flop and some combinational logic.

- 2. Construct a D flip-flop using a JK flip-flop and some combinational logic.
- 3. Construct a T flip-flop (see Exercise 3.9) using a JK flip-flop.

# 5 Finite State Machines [1, Sec 3.4]

**Example 6.** Design an occupancy counter that depends on a sensor S at the class door. The sensor is triggered every time a person passes through the door. Assume that the counter starts at zero. Assume we only need up to two bit counter  $C_1C_0$ . Draw a state table for this circuit.

**Problem 3.** A divide-by-N counter has one output and no inputs. The output Y is HIGH for one clock cycle out of every N. In other words, the output divides the frequency of the clock by N. The waveform for a divide-by-3 counter is shown here:

<u>Y</u> (a)

Sketch circuit designs for such a counter

2

**Problem 4.** Design a 3-bit counter which counts in the sequence: 001, 011, 010, 110, 111, 100, (repeat) 001, ...

**Example 7.** Design an odd-even counter for an single bit input. The output of this circuit should be 1 if the number of 1s to the input have been odd so far and 0 otherwise.

**Example 8** (Sequence detectors). A sequential circuit has one input and one output. The output becomes 1 and remain 1 thereafter when at least two 0's and at least two 1's have occurred as inputs regardless of the order of

**Example 9.** Consider the problem of inventing a controller for a traffic light at a busy intersection on campus. There are two traffic sensors,  $T_A$  and  $T_B$ , on Academic Ave. and Bravado Blvd., respectively. Each sensor indicates TRUE if students are present and FALSE if the street is empty. There are two traffic lights,  $L_A$  and  $L_B$ , to control traffic. Each light receives digital inputs specifying whether it should be green, yellow, or red. When the system is reset, the lights are green on Academic Ave. and red on Bravado Blvd. As long as traffic is present on Academic Ave., the lights do not change. When there is no longer traffic on Academic Ave., the light on Academic Ave. becomes yellow for 5 seconds before it turns red and Bravado Blvd.'s light turns green. Similarly, the Bravado Blvd. light remains green as long as traffic is present on the boulevard, then turns

<sup>&</sup>lt;sup>2</sup>These notes will not fit on your note sheet.

yellow and eventually red.



- 1. Draw a state transition diagram
- 2. Draw a state table
- 3. Assign binary encodings to each of the states
- 4. Redraw the state table with binary encodings. Design a minimal SOP boolean expression.
- 5. Assign binary encodings to each of the output and redraw the output table. Design a minimal SOP boolean expression for the outputs.

**Problem 5.** Design a circuit for a 2x2 pixel resolution pong game, where the ball can only occupy 4 possible pixels and a single paddle occupies another 2 pixels. The ball bounces of the paddle when the paddle is in the correct row. To keep it interesting, the ball takes a different path from the source path. Track the score with a single bit counter.

### References

- [1] Sarah L Harris and David Harris. Digital design and computer architecture. Morgan Kaufmann, 2022.
- [2] Brown Stephen and Vranesic Zvonko. Fundamentals of digital Logic with Verilog design. McGraw Hill, 2022.

Example 6: occupancy counter D-flip flop \_\_\_ D Qt + ve edgetnisgred \_\_ >cekal--ve cage truggered - D Q -Charateriste table of Pflipfelop?  $\frac{Qk}{A} \frac{D}{D} \frac{Q}{Q} \frac{Q^{+}}{Q} = Q(++t_{c})$   $\frac{Q}{A} \frac{Q}{D} \frac{Q}{D} = Q(++t_{c})$ charateriste table



How to design a wait from State transitum table? Synthetonous sequentic anaut template 2-bit state turym Register = bw





Odd-even counter the conten! it èven need state memon (2) How many bits of memory? =1











Problem 2. A JK flip-flop receives a clock and two inputs, J and K. On the rising edge of the clock, it updates the output, Q. If J and K are both 0, Q retains its old value. If only J is 1, Q becomes 1. If only K is 1, Q becomes 0. If both J and K are 1, Q becomes the opposite of its property state. Construct a JK flip-flop using a D flip-flop and some combinational logic. 2. Construct a D flip-flop using a JK flip-flop and some combinational logic. Construct a T flip-flop (see Exercise 3.9) using a JK flip-flop.  $\Diamond$ 

Excitation Touth table for 4 table for D-ff a D-ff mmg









2 mgm J-K Pradice wing ) -K wsm, T D wy T T Juswy flip flop wing X-ff ony sequential using

Design a Cost of red desoud rowl nextclock Design









# states = 2 (# off) of possible 3-states with minimum # of ff How many ff do we need? If we mederd 5 states, How many ff? C160 1 2 2 5 5 2 3 4 4 0 1 f So = 00

S<sub>1</sub> = 01 -> State assignment

Sz=10 (assigning binary number to each unique state)

Desired State transition takk state next state State next state Homework