



**ELECTRICAL**  
Engineering KMITNB

Power | Control | Communication | Computer

# Digital Circuit and Logic Design

## Lecture 8-2 : Synchronous Sequential Circuits

# Objectives

- The concept of states and their implementation with flip-flops
- Sequential behavior of digital circuits
- A procedure for designing synchronous sequential circuits
- The concept of finite state machines

# Synchronous Sequential Circuits

- Use a **clock**
- Use combinational logic and one or more flip-flops
- Move from one state to another
- Moore type – outputs depend **only on present state**
- Mealy type – outputs depend on **present state AND inputs**
- Finite State Machines
  - Formal name
  - Functional behavior can be represented by a finite number of states



**Moore** type Finite State Machine



**Mealy** type Finite State Machine

# Basic Design Steps

1. Specify Desired Circuit
2. State Diagram
3. State Table
4. Minimize States (Optional) **is not include in this lecture slide.**
5. State Assignment
6. Choice of Flip-flops and Derivation of Next-state and Output Expressions
7. Timing Diagram

# 1. Specify Desired Circuit

- One input  $w$
- One output  $z$
- All changes occur on positive edge of clock
- Output  $z = 1$  if
  - During two immediately preceding clock cycles the input  $w$  was equal to 1
- Output  $z = 0$  otherwise

| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w:$        | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z:$        | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0        |

## 2. State Diagram



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| w:          | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| z:          | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0        |

## 2. State Diagram (cont.)



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w:$        | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z:$        | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0        |

## 2. State Diagram (cont.)



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w:$        | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z:$        | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0        |

# 3. State Table

| Present state | Next state |       | Output z |
|---------------|------------|-------|----------|
|               | w = 0      | w = 1 |          |
| A             | A          | B     | 0        |
| B             | A          | C     | 0        |
| C             | A          | C     | 1        |



# 5. State Assignment



| Present state | Next state |          | Output z |
|---------------|------------|----------|----------|
|               | w = 0      | w = 1    |          |
| $y_2y_1$      | $y_2y_1$   | $y_2y_1$ |          |
| A             | 00         | 00       | 0        |
| B             | 01         | 00       | 0        |
| C             | 10         | 00       | 1        |
|               | 11         | dd       | d        |

- **Moore type** – Output depends only on present state

# 6. Choice of Flip-flops and Derivation of Next-state and Output Expressions

- D Flip-flops
  - Most straight forward





Clock

| Present state                 | Next state                    |                               | Output z |   |
|-------------------------------|-------------------------------|-------------------------------|----------|---|
|                               | w = 0                         | w = 1                         |          |   |
| y <sub>2</sub> y <sub>1</sub> | Y <sub>2</sub> Y <sub>1</sub> | Y <sub>2</sub> Y <sub>1</sub> |          |   |
| A                             | 00                            | 00                            | 01       | 0 |
| B                             | 01                            | 00                            | 10       | 0 |
| C                             | 10                            | 00                            | 10       | 1 |
|                               | 11                            | dd                            | dd       | d |

**Y1 Truth Table**

| y <sub>2</sub> | y <sub>1</sub> | w | Y1 |
|----------------|----------------|---|----|
| 0              | 0              | 0 | 0  |
| 0              | 0              | 1 | 1  |
| 0              | 1              | 0 | 0  |
| 0              | 1              | 1 | 0  |
| 1              | 0              | 0 | 0  |
| 1              | 0              | 1 | 0  |
| 1              | 1              | 0 | d  |
| 1              | 1              | 1 | d  |

$$Y_1 = w \cdot \overline{y_1} \cdot \overline{y_2}$$



Clock

| Present state | Next state |          | Output z |
|---------------|------------|----------|----------|
|               | w = 0      | w = 1    |          |
| $y_2y_1$      | $y_2y_1$   | $y_2y_1$ |          |
| A             | 00         | 00       | 01       |
| B             | 01         | 00       | 10       |
| C             | 10         | 00       | 10       |
|               | 11         | dd       | dd       |

|   | $y_2$ | $y_1$ |    |    |
|---|-------|-------|----|----|
| w | 00    | 01    | 11 | 10 |
| 0 | 0     | 0     | d  | 0  |
| 1 | 0     | 1     | d  | 1  |

$$\begin{aligned}
 Y_2 &= w \cdot y_1 + w \cdot y_2 \\
 &= w(y_1 + y_2)
 \end{aligned}$$

## Y2 Truth Table

| <u>y2</u> | <u>y1</u> | <u>w</u> | <u>Y2</u> |
|-----------|-----------|----------|-----------|
| 0         | 0         | 0        | 0         |
| 0         | 0         | 1        | 0         |
| 0         | 1         | 0        | 0         |
| 0         | 1         | 1        | 1         |
| 1         | 0         | 0        | 0         |
| 1         | 0         | 1        | 1         |
| 1         | 1         | 0        | d         |
| 1         | 1         | 1        | d         |



| Present state | Next state |          | Output<br>$z$ |
|---------------|------------|----------|---------------|
|               | $w = 0$    | $w = 1$  |               |
| $y_2y_1$      | $y_2y_1$   | $y_2y_1$ |               |
| A             | 00         | 00       | 01            |
| B             | 01         | 00       | 10            |
| C             | 10         | 00       | 10            |
|               | 11         | $dd$     | $dd$          |

|       |       |   |
|-------|-------|---|
|       | $y_1$ |   |
| $y_2$ | 0     | 1 |
| 0     | 0     | 0 |
| 1     | 1     | d |

$z = y_2$

## z Truth Table

| <u><math>y_2</math></u> | <u><math>y_1</math></u> | <u><math>z</math></u> |
|-------------------------|-------------------------|-----------------------|
| 0                       | 0                       | 0                     |
| 0                       | 1                       | 0                     |
| 1                       | 0                       | 1                     |
| 1                       | 1                       | d                     |

# 7. Timing Diagram



# Example

## Specify Desired Circuit

- Swap R1 & R2 Using R3 as a temporary register
  - $R2 \Rightarrow R3$
  - $R1 \Rightarrow R2$
  - $R3 \Rightarrow R1$
- Swapping started by a 1 clock cycle pulse on w
- Indicate task complete by setting Done = 1



# State Diagram

- What are the inputs?
- What are the outputs?
- How many states are required?
- What is the value of the outputs in those states?



A No transfer

$$w = 0$$

A No transfer

$R_2 \Rightarrow R_3$

$R_1 \Rightarrow R_2$

$R_3 \Rightarrow R_1$



$R_2 \Rightarrow R_3$   
 $R_1 \Rightarrow R_2$   
 $R_3 \Rightarrow R_1$



$R_2 \Rightarrow R_3$   
 $R_1 \Rightarrow R_2$   
 $R_3 \Rightarrow R_1$



$R_2 \Rightarrow R_3$   
 $R_1 \Rightarrow R_2$   
 $R_3 \Rightarrow R_1$



$R_2 \Rightarrow R_3$   
 $R_1 \Rightarrow R_2$   
 $R_3 \Rightarrow R_1$



$R_2 \Rightarrow R_3$   
 $R_1 \Rightarrow R_2$   
 $R_3 \Rightarrow R_1$



$R_2 \Rightarrow R_3$

$R_1 \Rightarrow R_2$

$R_3 \Rightarrow R_1$



| Present state | Next state |       | Outputs    |           |            |           |            |           |      |
|---------------|------------|-------|------------|-----------|------------|-----------|------------|-----------|------|
|               | w = 0      | w = 1 | $R_{1out}$ | $R_{1in}$ | $R_{2out}$ | $R_{2in}$ | $R_{3out}$ | $R_{3in}$ | Done |
| A             | A          | B     | 0          | 0         | 0          | 0         | 0          | 0         | 0    |
| B             | C          | C     | 0          | 0         | 1          | 0         | 0          | 1         | 0    |
| C             | D          | D     | 1          | 0         | 0          | 1         | 0          | 0         | 0    |
| D             | A          | A     | 0          | 1         | 0          | 0         | 1          | 0         | 1    |

# State Table

| Present state | Next state |         | Outputs    |           |            |           |            |           |        |
|---------------|------------|---------|------------|-----------|------------|-----------|------------|-----------|--------|
|               | $w = 0$    | $w = 1$ | $R1_{out}$ | $R1_{in}$ | $R2_{out}$ | $R2_{in}$ | $R3_{out}$ | $R3_{in}$ | $Done$ |
| A             | A          | B       | 0          | 0         | 0          | 0         | 0          | 0         | 0      |
| B             | C          | C       | 0          | 0         | 1          | 0         | 0          | 1         | 0      |
| C             | D          | D       | 1          | 0         | 0          | 1         | 0          | 0         | 0      |
| D             | A          | A       | 0          | 1         | 0          | 0         | 1          | 0         | 1      |

| Present state | Next state |          | Outputs    |           |            |           |            |           |        |
|---------------|------------|----------|------------|-----------|------------|-----------|------------|-----------|--------|
|               | $w = 0$    | $w = 1$  | $R1_{out}$ | $R1_{in}$ | $R2_{out}$ | $R2_{in}$ | $R3_{out}$ | $R3_{in}$ | $Done$ |
| $y_2y_1$      | $Y_2Y_1$   | $Y_2Y_1$ | $R1_{out}$ | $R1_{in}$ | $R2_{out}$ | $R2_{in}$ | $R3_{out}$ | $R3_{in}$ | $Done$ |
| A             | 00         | 00       | 01         | 0         | 0          | 0         | 0          | 0         | 0      |
| B             | 01         | 10       | 10         | 0         | 0          | 1         | 0          | 0         | 1      |
| C             | 10         | 11       | 11         | 1         | 0          | 0         | 1          | 0         | 0      |
| D             | 11         | 00       | 00         | 0         | 1          | 0         | 0          | 1         | 1      |



| Present state | Next state          |           | Outputs    |           |            |           |            |           |        |
|---------------|---------------------|-----------|------------|-----------|------------|-----------|------------|-----------|--------|
|               | $w = 0 \quad w = 1$ |           |            |           |            |           |            |           |        |
|               | $y_2 y_1$           | $Y_2 Y_1$ | $R1_{out}$ | $R1_{in}$ | $R2_{out}$ | $R2_{in}$ | $R3_{out}$ | $R3_{in}$ | $Done$ |
| A             | 00                  | 00        | 0          | 0         | 0          | 0         | 0          | 0         | 0      |
| B             | 01                  | 10        | 0          | 0         | 1          | 0         | 0          | 1         | 0      |
| C             | 10                  | 11        | 1          | 0         | 0          | 1         | 0          | 0         | 0      |
| D             | 11                  | 00        | 0          | 1         | 0          | 0         | 1          | 0         | 1      |

## Y1 Truth Table

y<sub>2</sub> y<sub>1</sub> w    Y<sub>1</sub>

|   | y <sub>2</sub> | y <sub>1</sub> |    |    |
|---|----------------|----------------|----|----|
| w | 00             | 01             | 11 | 10 |
| 0 |                |                |    |    |
| 1 |                |                |    |    |

Y<sub>1</sub>=

## Y2 Truth Table

y<sub>2</sub> y<sub>1</sub> w    Y<sub>2</sub>

|   | y <sub>2</sub> | y <sub>1</sub> |    |    |
|---|----------------|----------------|----|----|
| w | 00             | 01             | 11 | 10 |
| 0 |                |                |    |    |
| 1 |                |                |    |    |

Y<sub>2</sub>=

**Present state**

**Next state**

**Outputs**

| ELECTRICAL<br>Engineering MB | Present state |       | Next state |           | Outputs    |           |            |           |            |           |             |
|------------------------------|---------------|-------|------------|-----------|------------|-----------|------------|-----------|------------|-----------|-------------|
|                              | w = 0         | w = 1 | $Y_2 Y_1$  | $Y_2 Y_1$ | $R1_{out}$ | $R1_{in}$ | $R2_{out}$ | $R2_{in}$ | $R3_{out}$ | $R3_{in}$ | <i>Done</i> |
| A                            | 00            | 00    | 01         |           | 0          | 0         | 0          | 0         | 0          | 0         | 0           |
| B                            | 01            | 10    | 10         |           | 0          | 0         | 1          | 0         | 0          | 1         | 0           |
| C                            | 10            | 11    | 11         |           | 1          | 0         | 0          | 1         | 0          | 0         | 0           |
| D                            | 11            | 00    | 00         |           | 0          | 1         | 0          | 0         | 1          | 0         | 1           |

## Y1 Truth Table

y2 y1 w    Y1

0 0 0 0

0 0 1 1

0 1 0 0

0 1 1 0

1 0 0 1

1 0 1 1

1 1 0 0

1 1 1 0

|   |             | y2 y1       |   |  |
|---|-------------|-------------|---|--|
| w | 00 01 11 10 | 00 01 11 10 |   |  |
| 0 | 0 0 0 0     | 0 0 0 0     | 1 |  |
| 1 | 1 0 0 0     | 0 0 0 1     |   |  |

$$Y1 = y2 \cdot \overline{y1} + w \cdot \overline{y1}$$

## Y2 Truth Table

y2 y1 w    Y2

0 0 0 0

0 0 1 0

0 1 0 1

0 1 1 1

1 0 0 1

1 0 1 1

1 1 0 0

1 1 1 0

|   |             | y2 y1       |  |  |
|---|-------------|-------------|--|--|
| w | 00 01 11 10 | 00 01 11 10 |  |  |
| 0 | 0 1 0 1     | 0 1 0 1     |  |  |
| 1 | 0 1 0 1     | 0 1 0 1     |  |  |

$$Y2 = \overline{y2} \cdot y1 + y2 \cdot \overline{y1}$$



| Present state<br>$y_2y_1$ | Next state          |          | Outputs    |           |            |           |            |           |        |
|---------------------------|---------------------|----------|------------|-----------|------------|-----------|------------|-----------|--------|
|                           | $w = 0 \quad w = 1$ |          |            |           |            |           |            |           |        |
|                           | $Y_2Y_1$            | $Y_2Y_1$ | $R1_{out}$ | $R1_{in}$ | $R2_{out}$ | $R2_{in}$ | $R3_{out}$ | $R3_{in}$ | $Done$ |
| A 00                      | 00                  | 01       | 0          | 0         | 0          | 0         | 0          | 0         | 0      |
| B 01                      | 10                  | 10       | 0          | 0         | 1          | 0         | 0          | 1         | 0      |
| C 10                      | 11                  | 11       | 1          | 0         | 0          | 1         | 0          | 0         | 0      |
| D 11                      | 00                  | 00       | 0          | 1         | 0          | 0         | 1          | 0         | 1      |

$$R1_{out} =$$

$$R2_{in} =$$

$$R1_{in} =$$

$$R3_{out} =$$

$$Done =$$

$$R2_{out} =$$

$$R3_{in} =$$

| Present state | Next state          |          | Outputs  |            |           |            |           |            |           |        |
|---------------|---------------------|----------|----------|------------|-----------|------------|-----------|------------|-----------|--------|
|               | $w = 0 \quad w = 1$ |          |          |            |           |            |           |            |           |        |
|               | $y_2y_1$            | $Y_2Y_1$ | $Y_2Y_1$ | $R1_{out}$ | $R1_{in}$ | $R2_{out}$ | $R2_{in}$ | $R3_{out}$ | $R3_{in}$ | $Done$ |
| A             | 00                  | 00       | 01       | 0          | 0         | 0          | 0         | 0          | 0         | 0      |
| B             | 01                  | 10       | 10       | 0          | 0         | 1          | 0         | 0          | 1         | 0      |
| C             | 10                  | 11       | 11       | 1          | 0         | 0          | 1         | 0          | 0         | 0      |
| D             | 11                  | 00       | 00       | 0          | 1         | 0          | 0         | 1          | 0         | 1      |

$$R1_{out} = R2_{in} = y_2 \cdot \overline{y_1}$$

$$R1_{in} = R3_{out} = Done = y_2 \cdot y_1$$

$$\overline{R2_{out}} = R3_{in} = \overline{y_2} \cdot y_1$$



# FSM Model Variants

- Moore-type
  - Outputs depend only on Present State
- Mealy-type
  - Outputs depend on Present State AND Inputs

# Mealy State Model

## Specify Desired Circuit

- One input  $w$
- One output  $z$
- All changes occur on positive edge of clock
- Output  $z = 1$  if
  - During immediately preceding clock cycle the input  $w$  was equal to 1 AND is currently equal to 1
- Output  $z = 0$  otherwise

| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w:$        | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z:$        | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |

## New Machine (Mealy)

| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w:$        | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z:$        | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |

## Old Machine (Moore)

| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w:$        | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z:$        | 0     | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0        |



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| w:          | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| z:          | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |





| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| w:          | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| z:          | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |





| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| w:          | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| z:          | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w$ :       | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z$ :       | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w$ :       | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z$ :       | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| w:          | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| z:          | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| w:          | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| z:          | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |





ELECTRICAL  
Engineering KMITLB

| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w$ :       | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z$ :       | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| $w$ :       | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| $z$ :       | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |



| Clockcycle: | $t_0$ | $t_1$ | $t_2$ | $t_3$ | $t_4$ | $t_5$ | $t_6$ | $t_7$ | $t_8$ | $t_9$ | $t_{10}$ |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| w:          | 0     | 1     | 0     | 1     | 1     | 0     | 1     | 1     | 1     | 0     | 1        |
| z:          | 0     | 0     | 0     | 0     | 1     | 0     | 0     | 1     | 1     | 0     | 0        |



During present clock cycle output value on arc from Present State node  
**Note** difference from Moore model in where output is shown output changes asynchronously

# State Table & State Assignment

| Present state | Next state |         | Output $z$ |         |
|---------------|------------|---------|------------|---------|
|               | $w = 0$    | $w = 1$ | $w = 0$    | $w = 1$ |
| A             | A          | B       | 0          | 0       |
| B             | A          | B       | 0          | 1       |

| Present state | Next state |         | Output  |         |
|---------------|------------|---------|---------|---------|
|               | $w = 0$    | $w = 1$ | $w = 0$ | $w = 1$ |
| $y$           | Y          | Y       | $z$     | $z$     |
| A             | 0          | 1       | 0       | 0       |
| B             | 1          | 0       | 0       | 1       |

# Derivation of Next-state and Output Expressions

| Present state | Next state |         | Output  |         |
|---------------|------------|---------|---------|---------|
|               | $w = 0$    | $w = 1$ | $w = 0$ | $w = 1$ |
| $y$           | Y          | Y       | z       | z       |
| A             | 0          | 1       | 0       | 0       |
| B             | 1          | 0       | 0       | 1       |

Y Truth Table

| <u>y</u> | <u>w</u> | <u>Y</u> |
|----------|----------|----------|
| 0        | 0        | 0        |
| 0        | 1        | 1        |
| 1        | 0        | 0        |
| 1        | 1        | 1        |

|   | y |   |
|---|---|---|
| w | 0 | 1 |
| 0 | 0 | 0 |
| 1 | 1 | 1 |

$$Y = w$$

z Truth Table

| <u>y</u> | <u>w</u> | <u>z</u> |
|----------|----------|----------|
| 0        | 0        | 0        |
| 0        | 1        | 0        |
| 1        | 0        | 0        |
| 1        | 1        | 1        |

|   | y |   |
|---|---|---|
| w | 0 | 1 |
| 0 | 0 | 0 |
| 1 | 0 | 1 |

$$z = y \cdot w$$

# Asynchronous Behavior of Mealy Model



- If z is connected to another synchronous clock no problem
- If z is connected to another circuit not controlled by the same clock a potential problem exists

# Analysis of Synchronous State Machines





## How many states?

Create Present State/Next State/Output table

| Present state | Next State | Output<br>$z$ |
|---------------|------------|---------------|
|               |            |               |
|               |            |               |
|               |            |               |
|               |            |               |



| Present state<br>$y_2y_1$ | Next State |          | Output<br>$z$ |
|---------------------------|------------|----------|---------------|
|                           | $w = 0$    | $w = 1$  |               |
|                           | $Y_2Y_1$   | $Y_2Y_1$ |               |
| 00                        | 00         | 01       | 0             |
| 01                        | 00         | 10       | 0             |
| 10                        | 00         | 11       | 0             |
| 11                        | 00         | 11       | 1             |

# Exercise#1: Counter Using Sequential State Machine

- Counting Sequence is  
 $0,1,2,\dots,6,7,0,1,\dots$
- Input w
  - If  $w = 0$  present count remains the same
  - If  $w = 1$  count is incremented
- Create State Diagram
- Create State Table
- Create State Assignments

# Exercise#2: FSM with Two Inputs

- Inputs  $w_1$  and  $w_2$
- Outputs  $z$
- If  $w_1 = w_2$  during any four consecutive clock cycles  $z = 1$
- Otherwise  $z = 0$

|    |                           |
|----|---------------------------|
| w1 | 0 1 1 0 1 1 1 0 0 0 1 1 0 |
| w2 | 1 1 1 0 1 0 1 0 0 0 1 1 1 |
| z  | 0 0 0 0 1 0 0 0 0 1 1 1 0 |

# Homework

- 8.3 & 8.5 (Brown)
  - Create
    - State Diagram
    - State Table
    - State Assignment Table