#### State and Finite State Machines

Anne Bracy
CS 3410

Computer Science

Cornell University

The slides are the product of many rounds of teaching CS 3410 by Professors Weatherspoon, Bala, Bracy, and Sirer.

### **Stateful Components**

#### Combinational logic

- Output computed directly from inputs
- System has no internal state
- Nothing depends on the past!



- to record data
- to build stateful circuits
- a state-holding device

Enter: Sequential Logic & Finite State Machines

### **Goals for Today**

#### State

- Storing 1 bit
  - -Bistable Circuit
  - Set-Reset Latch
  - D Latch
  - D Flip-Flops
- Storing N bits:
  - Registers
  - -More options in later lectures

#### Finite State Machines (FSM)

- Mealy and Moore Machines
- Serial Adder Example

#### Round 1: Bistable Circuit

Stable and unstable equilibria?



In stable state,  $\overline{A} = B$ 



# Round 2: Set-Reset (SR) Latch







# Stores a value Q and its complement

| S | R | Q | $\overline{\overline{Q}}$ |
|---|---|---|---------------------------|
| 0 | 0 |   |                           |
| 0 | 1 |   |                           |
| 1 | 0 |   |                           |
| 1 | 1 |   |                           |

#### For reference:

| A | В | OR | NOR |
|---|---|----|-----|
| 0 | 0 | 0  | 1   |
| 0 | 1 | 1  | 0   |
| 1 | 0 | 1  | 0   |
| 1 | 1 | 1  | 0   |

$$\begin{array}{c} \overline{Q} \\ Q \\ \end{array}$$

$$Q$$
 $Q$ 
 $R$ 





# iClicker Question



# Round 3: D Latch (1)





| • | Inver | ter | prev  | ents  | SR  | Latch |
|---|-------|-----|-------|-------|-----|-------|
|   | from  | ent | ering | g 1,1 | sta | te    |

• C = enables change

| С | D | Q | $\overline{\overline{\mathbf{Q}}}$ |
|---|---|---|------------------------------------|
| 0 | O |   |                                    |
| 0 | 1 |   |                                    |
| 1 | О |   |                                    |
| 1 | 1 |   |                                    |

C = 1, D Latch *transparent*: set/reset (according to D)

C = 0, D Latch *opaque*: keep state (ignore D)



#### **Aside: Clocks**

#### Clock helps coordinate state changes

- Fixed period
- Frequency = 1/period



### **Clock Disciplines**

#### Level sensitive

State changes when clock is high (or low)



#### Edge triggered

State changes at clock edge



# **Clock Methodology**

#### Clock Methodology

Negative edge, synchronous



Edge-Triggered  $\rightarrow$  signals must be stable near falling edge "near" = before and after



# Round 3: D Latch (2)





- Level sensitive
- Inverter prevents SR Latch from entering 1,1 state
- clk = enables change

| clk | D | Q | $\overline{\mathbf{Q}}$ |
|-----|---|---|-------------------------|
| 0   | O |   |                         |
| 0   | 1 |   |                         |
| 1   | O |   |                         |
| 1   | 1 |   |                         |



### Round 4: D Flip-Flop



- Edge-Triggered
- Data captured when clock high
- Output changes only on falling edges

# Round 4: D Flip-Flop

D passes through L1 to X

Clock = 1: L1 transparent L2 opaque



X passes through L2 to Q

Clock = 0: L1 opaque L2 transparent

Thus, on edge of the clock (when *CLK* falls from  $1\rightarrow 0$ )

(D passes through to Q)

# DFF Activity: Fill in the timing graph



Clock = 1 D passes through L1 to X

Clock = 0 X passes through L2 to Q



X

Q



### **Goals for Today**

#### State

- Storing 1 bit
  - Bistable Circuit
  - Set-Reset Latch
  - D Latch
  - D Flip-Flops
- Storing N bits:
  - Registers
  - More options in later lectures

#### Finite State Machines (FSM)

- Mealy and Moore Machines
- Serial Adder Example

A word about clocks

A word about terminology

# Registers



- D flip-flops in parallel
- shared clock
- Additional (optional) inputs: writeEnable, reset, ...



### **Takeaways**

- Set-Reset (SR) Latch can store one bit and we can change the value of the stored bit. But, SR Latch has a forbidden state.
- D Latch can store and change a bit like an SR Latch while avoiding a forbidden state.
- A D Flip-Flip stores one bit. The bit can be changed in a synchronized fashion on the edge of a clock signal.
- An N-bit register stores N-bits. It is be created with N D-Flip-Flops in parallel plus a shared clock.

### **Goals for Today**

#### State

- Storing 1 bit
  - Bistable Circuit
  - –Set-Reset Latch
  - -D Latch
  - D Flip-Flops
- Storing N bits:
  - Registers
  - -More options in later lectures

#### Finite State Machines (FSM)

- Mealy and Moore Machines
- Serial Adder Example

#### Finite State Machines

#### An electronic machine which has

- external inputs
- externally visible outputs
- internal state

#### Output and next state depend on

- inputs
- current state

#### **Automata Model**

#### Finite State Machine



- inputs from external world
- outputs to external world
- internal state
- combinational logic

# FSM Example





Input: 1 or 0

Output: 1 or 0

States: A or B

What input pattern is the FSM "looking for"?

### Mealy Machine

General Case: Mealy Machine



Outputs and next state depend on both current state and input

### **Moore Machine**

Special Case: Moore Machine



Outputs depend only on current state

# Moore Machine FSM Example





Input: 1 or 0

Output: 1 or 0

States: A, B, or C

What input pattern is the FSM "looking for"?

#### Activity: Build a Logic Circuit for a Serial Adder

#### Add two infinite input bit streams

- streams are sent with least-significant-bit (lsb) first
- How many states are needed to represent FSM?
- Draw and Fill in FSM diagram



- (1) Draw a state diagram (e.g. Mealy Machine)
- (2) Write output and next-state tables
- (3) Encode states, inputs, and outputs as bits
- (4) Determine logic equations for next state and outputs

# FSM: State Diagram – start here



\_\_\_ states:

Inputs: ??? and ???

Output: ???



# FSM: State Diagram





\_\_\_ states:

Inputs: ??? and ???

Output: ???







| ?? | ?? | Current state | ? | Next<br>state |
|----|----|---------------|---|---------------|
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |

(2) Write down all input and state combinations



# FSM: State Diagram – start here



| ?? | ?? | Current state | ? | Next<br>state |
|----|----|---------------|---|---------------|
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |

(3) Encode states, inputs, and outputs as bits



# FSM: State Diagram

| ?? | ?? | Current state | ? | Next<br>state |
|----|----|---------------|---|---------------|
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |
|    |    |               |   |               |

(4) Determine logic equations for next state and outputs

### Sequential Logic Circuits



$$z = \overline{a}b\overline{s} + \overline{a}b\overline{s} + \overline{a}b\overline{s} + \overline{a}b\overline{s} + \overline{a}b\overline{s}$$
  
 $s' = ab\overline{s} + \overline{a}b\overline{s} + \overline{a}b\overline{s} + ab\overline{s}$ 

#### Strategy:

- (1) Draw a state diagram (e.g. Mealy Machine)
- (2) Write output and next-state tables
- (3) Encode states, inputs, and outputs as bits
- (4) Determine logic equations for next state and outputs

### Summary

#### We can now store data values

- Stateful circuit elements (D Flip Flops, Registers, ...)
- Clock synchronizes state changes
- State Machines or Ad-Hoc Circuits