# **CHAPTER 14**

# DERIVATION OF STATE GRAPHS AND TABLES



#### This chapter in the book includes:

Objectives

Study Guide

- 14.1 Design of a Sequence Detector
- 14.2 More Complex Design Problems
- 14.3 Guidelines for Construction of State Graphs
- 14.4 Serial Data Code Conversion
- 14.5 Alphanumeric State Graph Notation

Programmed Exercises

**Problems** 

#### **Design of a Sequence Detector**

To illustrate the design of a clocked Mealy sequential circuit, we will design a sequence detector. The circuit is of the form:



Figure 14-1: Sequence Detector to be Designed

Suppose we want to design the sequence detector so that any input sequence ending in 101 will produce an output Z = 1 coincident with the last 1. The circuit does not reset when a 1 output occurs. A typical input sequence and the corresponding output sequence are:

Initially, we do not know how many flip-flops will be required, so we will designate the circuit states as  $S_0$ ,  $S_1$ , etc. We will start with a reset state designated  $S_0$ . If a 0 input is received, the circuit can stay in  $S_0$  because the input sequence we are looking for does not start with a 0.

However, if a 1 is received, the circuit must go to a new state ( $S_1$ ) to "remember" that the first input in the desired sequence has been received.



Figure 14-2

When in state  $S_1$ , if we receive a 0, the circuit must change to a new state ( $S_2$ ) to remember that the first two inputs of the desired sequence (101) have been received.



If a 1 is received in state  $S_2$ , the desired input sequence (101) is complete and the output should be 1. Since the last 1 in a sequence can also be the first 1 in a new sequence,

we should return to  $S_1$ .



*Figure 14-3* 

If a 1 input occurs when in state  $S_1$ , we can stay in  $S_1$  because the sequence is simply restarted. If a 0 input occurs in state  $S_2$ , we have received two 0's in a row and must reset the circuit to  $S_0$  because 00 is not part of the desired sequence.

Figure 14-4: Mealy State Graph for Sequence Detector

We can then convert our state graph to a state table:

**Table 14-1** 

|                |                |                | Pres  | ent   |
|----------------|----------------|----------------|-------|-------|
| Present        | Next State     |                | Out   | put   |
| State          | X = 0          | X = 1          | X = 0 | X = 1 |
| S <sub>0</sub> | S <sub>o</sub> | S <sub>1</sub> | 0     | 0     |
| S <sub>1</sub> | $S_2$          | $S_1$          | 0     | 0     |
| $S_2$          | $S_0$          | $S_1$          | 0     | 1     |



Since there are 3 states, we only need 2 flip-flops for the circuit (2 memory bits).

Figure 14-4

Now we can convert our state table into a transition table:

**Table 14-1** 

|                |       |                | Pres  | ent   |
|----------------|-------|----------------|-------|-------|
| Present        | Next  | State          | Out   | out   |
| State          | X = 0 | <i>X</i> = 1   | X = 0 | X = 1 |
| S <sub>0</sub> | So    | S <sub>1</sub> | 0     | 0     |
| S <sub>1</sub> | $S_2$ | $S_1$          | 0     | 0     |
| $S_2$          | $S_0$ | $S_1$          | 0     | 1     |

#### **Table 14-2**

|    | $A^+B^+$ |       | Z     |       |
|----|----------|-------|-------|-------|
| AB | X = 0    | X = 1 | X = 0 | X = 1 |
| 00 | 00       | 01    | 0     | 0     |
| 01 | 10       | 01    | 0     | 0     |
| 10 | 00       | 01    | 0     | 1     |

From the transition table, we can plot the next-state maps for the flip-flops and the map for the output function *Z*:



**Section 14.1 (p. 433)** 

Now we can draw the circuit corresponding to the equations we derived:



*Figure 14-5* 

The procedure for finding the state graph for a Moore machine is similar to that used for a Mealy machine, except that the output is written with the state.

We will rework the previous example as a Moore machine: the circuit should produce an output of 1 only if an input sequence ending in 101 has occurred.

The design is similar to that for the Mealy machine up until the input sequence 10 has occurred, except that 0 output is associated with states  $S_0$ ,  $S_1$ , and  $S_2$ :



Now, when a 1 input occurs to complete the 101 sequence, the output must become 1; therefore, we cannot go back to state  $S_1$  and must create a new state  $S_3$  with a 1 output:



We now complete the graph, as shown below. Note the sequence 100 resets the circuit to  $S_0$ . A sequence 1010 takes the circuit back to  $S_2$  because another 1 input should cause Z to become 1 again:



#### **Table 14-3 and Table 14-4**

| Present<br>State                                   | X = 0          | State<br><i>X</i> = 1       | Present<br>Output( <i>Z</i> ) |                            |
|----------------------------------------------------|----------------|-----------------------------|-------------------------------|----------------------------|
| S <sub>0</sub>                                     | S <sub>0</sub> | S <sub>1</sub>              | 0                             |                            |
| S <sub>1</sub>                                     | $S_2$          | S <sub>1</sub>              | 0                             |                            |
| S <sub>1</sub><br>S <sub>2</sub><br>S <sub>3</sub> | $S_0$          | S₃<br>S₁                    | 0                             | As with the                |
| S <sub>3</sub>                                     | $S_2$          | S <sub>1</sub>              | 1                             | Mealy machine,             |
|                                                    |                |                             |                               | we can derive              |
|                                                    | A              | <sup>+</sup> B <sup>+</sup> |                               | the state and              |
| AB                                                 | X = 0          | X = 1                       | Z                             | transition tables          |
| 00                                                 | 00             | 01                          | 0                             | for the Moore machine from |
| 01                                                 | 11             | 01                          | 0                             | the state graph.           |
| 11                                                 | 00             | 10                          | 0                             | J                          |
| 10                                                 | 11             | 01                          | 1                             |                            |

### **More Complex Design Problems**

Now we will derive a state graph for a sequential circuit of somewhat greater complexity than the previous examples.

For this circuit, the output Z should be 1 if the input sequence ends in either 010 or 1001, and Z should be 0 otherwise.

**Section 14.2 (p. 435)** 

## **Mealy Example**

We will start construction of the state graph by working with the two sequences which lead to a 1 output. Then, we will later add arrows and states as required to make sure that the output is correct for other cases.



*Figure 14-7* 



Next, we construct the part of the graph corresponding to the sequence 1001, starting from the reset state  $S_0$ .

| state                 | sequence ends in |
|-----------------------|------------------|
| S <sub>0</sub>        | reset            |
| S <sub>1</sub>        | 0 (but not 10)   |
| S <sub>2</sub>        | 01               |
| S <sub>3</sub>        | 10               |
| S <sub>4</sub>        | 1 (but not 01)   |
| <b>S</b> <sub>5</sub> | 100              |

*Figure 14-8* 



Now we fill in the missing arcs. With each arc, we first ask if we can go back to one of the previous states or do we have to create a new state?

| <u>state</u>   | sequence ends in |
|----------------|------------------|
| S <sub>0</sub> | reset            |
| S <sub>1</sub> | 0 (but not 10)   |
| S <sub>2</sub> | 01               |
| S <sub>3</sub> | 10               |
| S <sub>4</sub> | 1 (but not 01)   |
| S <sub>5</sub> | 100              |

*Figure 14-9* 

#### **Moore Example**

Design a Moore sequential circuit with one input *X* and one output *Z*. The output *Z* is to be 1 if the total number of 1's received is odd and at least two consecutive 0's have been received. A typical input and output sequence is:



Figure 14-10



*Figure 14-11* 



*Figure 14-12* 

### **Guidelines for Construction of State Graphs**

Although there is no one specific procedure which can be used to derive state graphs or tables for every problem, the following guidelines should prove helpful:

- 1. First, construct some sample input and output sequences to make sure that you understand the problem statement.
- 2. Determine under what conditions, if any, the circuit should reset to its initial state.
- 3. If only one or two sequences lead to a nonzero output, a good way to start is to construct a partial state graph for those sequences.

**Section 14.3 (p. 439)** 

- 4. Another way to get started is to determine what sequences or groups of sequences must be remembered by the circuit and set up states accordingly.
- 5. Each time you add an arrow to the state graph, determine whether it can go to one of the previously defined states or whether a new state must be added.
- 6. Check your graph to make sure there is one and only one path leaving each state for each combination of values of the input variables.
- 7. When your graph is complete, test it by applying the input sequences formulated in part 1 and making sure the output sequences are correct.

## **Example 1**

A sequential circuit has one input (X) and one output (Z). The circuit examines groups of four consecutive inputs and produces an output Z = 1 if the input sequence 0101 or 1001 occurs. The circuit resets after every four inputs. Find a Mealy state graph.

1. First, construct some sample input and output sequences to make sure that you understand the problem statement.

A typical sequence of inputs and outputs is

$$X = 0101 \mid 0010 \mid 1001 \mid 0100$$
  
 $Z = 0001 \mid 0000 \mid 0001 \mid 0000$ 

**Section 14.3 (p. 439)** 

2. Determine under what conditions, if any, the circuit should reset to its initial state.

Since the circuit examines groups of four consecutive inputs and resets after each group of four, the circuit should reset to  $S_0$  after every fourth input is received.

4. Another way to get started is to determine what sequences or groups of sequences must be remembered by the circuit and set up states accordingly.



| state          | sequence received |
|----------------|-------------------|
| S <sub>0</sub> | reset             |
| S <sub>1</sub> | 0                 |
| S <sub>2</sub> | 1                 |
| S <sub>3</sub> | 01 or 10          |
| S <sub>4</sub> | 010 or 100        |

Figure 14-13: Partial State Graph for Example 1

6. Check your graph to make sure there is one and only one path leaving each state for each combination of values of the input variables.



Figure 14-14: Complete State Graph for Example 1

©2010 Cengage Learning

#### Example 2

A sequential circuit has one input (X) and two outputs( $Z_1$  and  $Z_2$ ). An output  $Z_1$  = 1 occurs every time the input sequence 100 is completed, provided that the sequence 010 has never occurred. An output  $Z_2$  = 1 occurs every time the input sequence 010 is completed. Note that once a  $Z_2$  = 1 output has occurred,  $Z_1$  = 1 can never occur but not vice versa. Find a Mealy state graph and table.

A typical sequence of inputs and outputs is:

Section 14.3 (p. 440-441)



Figure 14-15: Partial Graphs for Example 2
©2010 Cengage Learning

Keeping track of what is remembered by each state will help us make the correct state graph.

#### **Table 14-5 State Descriptions for Example 2**

| <b>State</b>            | <u>Description</u>    |                       | <b>:</b><br>:          |
|-------------------------|-----------------------|-----------------------|------------------------|
| $\overline{S_0}$        | No progress on 100    | No progress on 010    | :                      |
| $S_1$                   | Progress of 1 on 100  | No progress on 010    | <b>:</b><br>=          |
| $S_2$                   | Progress of 10 on 100 | Progress of 0 on 010  | 010 has never occurred |
| $S_3$                   | No progress on 100    | Progress of 0 on 010  | :<br>:                 |
| $S_4$                   | Progress of 1 on 100  | Progress of 01 on 010 | :                      |
| $S_5$                   |                       | Progress of 0 on 010  | F                      |
| ${\sf S}_5$ ${\sf S}_6$ | <u>:</u>              | Progress of 01 on 010 | 010 has occurred       |
| $S_7$                   | <b>:</b><br>:         | No progress on 010    | <b>:</b>               |



Figure 14-16: State Graphs for Example 2 CEUTIO Cengage Learning

**Table 14-6.** 

| Present<br>State      | Next<br>X = 0         | State<br>X = 1        | Output<br>X =0 | $(Z_1Z_2)$ $X = 1$ |
|-----------------------|-----------------------|-----------------------|----------------|--------------------|
| S <sub>0</sub>        | S <sub>3</sub>        | S <sub>1</sub>        | 00             | 00                 |
| $S_1$                 | S <sub>2</sub>        | $S_1$                 | 00             | 00                 |
| $S_2$                 | S <sub>3</sub>        | S <sub>4</sub>        | 10             | 00                 |
| $S_3$                 | S <sub>3</sub>        | $S_4$                 | 00             | 00                 |
| $S_4$                 | S <sub>5</sub>        | $S_1$                 | 01             | 00                 |
| $S_5$                 | S <sub>5</sub>        | $S_6$                 | 00             | 00                 |
| $S_6$                 | S <sub>5</sub>        | <b>S</b> <sub>7</sub> | 01             | 00                 |
| <b>S</b> <sub>7</sub> | <b>S</b> <sub>5</sub> | <b>S</b> <sub>7</sub> | 00             | 00                 |

### Example 3

A sequential circuit has two inputs  $(X_1, X_2)$  and one output (Z). The output remains a constant value unless one of the following input sequences occurs:

- (a) The input sequence  $X_1X_2 = 01$ , 11 causes the output to become 0.
- (b) The input sequence  $X_1X_2 = 10$ , 11 causes the output to become 1.
- (c) The input sequence  $X_1X_2 = 10$ , 01 causes the output to change value.

(The notation  $X_1X_2 = 01$ , 11 means  $X_1 = 0$ ,  $X_2 = 1$  followed by  $X_1 = 1$ ,  $X_2 = 1$ .)

Derive a Moore state graph for the circuit.

**Section 14.3 (p. 443)** 

| Previous         | Output | State                 |
|------------------|--------|-----------------------|
| Input $(X_1X_2)$ | (Z)    | Designation           |
| 00 or 11         | 0      | <b>S</b> <sub>0</sub> |
| 00 or 11         | 1      | <i>S</i> <sub>1</sub> |
| 01               | 0      | $S_2$                 |
| 01               | 1      | <b>S</b> <sub>3</sub> |
| 10               | 0      | $S_4$                 |
| 10               | 1      | $S_5$                 |

### **Table 14-7**

| Present        |   | Next State     |                |       |                |
|----------------|---|----------------|----------------|-------|----------------|
| State          | Z | $X_1X_2 = 00$  | 01             | 11    | 10             |
| S <sub>0</sub> | 0 | S <sub>o</sub> | S <sub>2</sub> | So    | S <sub>4</sub> |
| $S_1$          | 1 | S <sub>1</sub> | $S_3$          | $S_1$ | $S_5$          |
| $S_2$          | 0 | $S_0$          | $S_2$          | $S_0$ | $S_4$          |
| $S_3$          | 1 | S <sub>1</sub> | $S_3$          | $S_0$ | $S_5$          |
| $S_4$          | 0 | $S_0$          | $S_3$          | $S_1$ | $S_4$          |
| $S_5$          | 1 | S <sub>1</sub> | $S_2$          | $S_1$ | $S_5$          |



Figure 14-17: State Graph for Example 3

### **Serial Data Code Conversion**

As a final example of state graph construction, we will design a converter for serial data. Binary data is frequently transmitted between computers as a serial stream of bits.

A clock signal is often transmitted along with the data so the receiver can read the data at the proper time.

Alternatively, only the serial data is transmitted, and a clock recovery circuit (called a digital phase-locked loop) is used to regenerate the clock signal at the receiver.

**Section 14.4 (p. 444)** 



Figure 14-18: Serial Data Transmission

©2010 Cengage Learning



Figure 14-19: Coding Schemes for Serial Data Transmission



Figure 14-20a: Mealy Circuit for NRZ-to-Manchester Conversion



Figure 14-20b: Mealy Circuit for NRZ-to-Manchester Conversion

| Present        | Next State     |                | Output (Z) |       |  |
|----------------|----------------|----------------|------------|-------|--|
| State          | X = 0          | X = 1          | X = 0      | X = 1 |  |
| S <sub>0</sub> | S <sub>1</sub> | S <sub>2</sub> | 0          | 1     |  |
| $S_1$          | $S_0$          | _              | 1          | _     |  |
| $S_2$          | _              | $S_0$          | _          | 0     |  |



(d) State table

(c) State graph

## Figure 14-20cd: Mealy Circuit for NRZ-to-Manchester Conversion



Figure 14-21a:

Moore Circuit for NRZ-to-Manchester Conversion

#### ©2010 Cengage Learning



# Figure 14-21bc: Moore Circuit for NRZ-to-Manchester Conversion

(b) State graph

| ( | (c)                                          | State | table |
|---|----------------------------------------------|-------|-------|
| 1 | \ <b>\                                  </b> |       |       |

| Present        | Next           | State          | Present    |
|----------------|----------------|----------------|------------|
| State          | X = 0          | <i>X</i> = 1   | Output (Z) |
| S <sub>0</sub> | S <sub>1</sub> | S <sub>3</sub> | 0          |
| $S_1$          | $S_2$          | _              | 0          |
| $S_2$          | S <sub>1</sub> | $S_3$          | 1          |
| S <sub>3</sub> | _              | $S_0$          | 1          |

### **Alphanumeric State Graph Notation**

When a state sequential circuit has several inputs, it is often convenient to label the state graph arcs with alphanumeric input variable names instead of 0's and 1's.

**Section 14.5 (p. 448)** 



Figure 14-22: State Graphs with Variable Names on Arc Labels

### Table 14-8. State Table for Figure 14-22

| PS             | NS             |                |                | Output         |                                                        |
|----------------|----------------|----------------|----------------|----------------|--------------------------------------------------------|
|                | FR=00          | 01             | 10             | 11             | Output<br>Z <sub>1</sub> Z <sub>2</sub> Z <sub>3</sub> |
| S <sub>0</sub> | S₀<br>S₁<br>S₂ | S <sub>2</sub> | S <sub>1</sub> | S <sub>1</sub> | 1 0 0                                                  |
| $S_1$          | S <sub>1</sub> | $S_0$          | $S_2$          | $S_2$          | 0 1 0                                                  |
| $S_2$          | S <sub>2</sub> | $S_1$          | $S_0$          | $S_0$          | 0 0 1                                                  |

### **Properly Specified State Graphs**

In general, a completely specified state graph has the following properties:

- 1. When we OR together all input labels on arcs emanating from a state, the result reduces to 1.
- 2. When we AND together any pair of input labels on arcs emanating from a state, the result is 0.

**Section 14.5 (p. 449)** 

## Alphanumeric Notation for Mealy State Graphs

 $X_iX_j/Z_pZ_q$  means if inputs  $X_i$  and  $X_j$  are 1 (we don't care what the other input values are), the outputs  $Z_p$  and  $Z_q$  are 1 (and the other outputs are 0). That is, for a circuit with four inputs  $(X_1, X_2, X_3, \text{ and } X_4)$  and four outputs  $(Z_1, Z_2, Z_3, \text{ and } Z_4), X_1X_4'/Z_2Z_3$  is equivalent to 1--0 / 0110.

This type of notation is very useful for large sequential circuits where there are many inputs and outputs.

**Section 14.5 (p. 449)**