## Asynchronous sequence circuits

- An asynchronous sequence machine is a sequence circuit without flip-flops
- Asynchronous sequence machines are based on combinational gates with feedback

Upon analysis it is assumed: Only one signal at a time in the gate circuit can change its value at any time

## Golden rule



William Sandqvist william@kth.se

## Asynchronous state machine

Asynchronous state machines are used when it is necessary to maintain a state, but when there is no clock available.

- All flip-flops and latches are themselfes asynchronous state machines
- They are useful to synchronize events in situations where metastability is/can be a problem


## SR-latch with NOR-gates

To analyze the behavior of an asynchronous circuit one assumes ideal gates and summarizes all the delay to a single block with delay $\Delta$.


William Sandqvist william@kth.se

## Analysis of sequence circuits

By having a delay block we can consider
$\boldsymbol{y}$ as the present state
$\boldsymbol{Y}$ as next state


William Sandqvist william@kth.se

## State function

Thus, we can develop a functional relationship of the next state $\boldsymbol{Y}$ depending on the input signals $\boldsymbol{S}$ and $\boldsymbol{R}$ and the current state $\boldsymbol{y}$

$Y=\overline{R+\overline{(S+y)}}$

William Sandqvist william@kth.se

## state tabin

From statefunction to truth table


## ( at exercise, analysis of SR )



$$
Q^{+}=\overline{R+\overline{S+Q}}=\bar{R} \cdot \overline{\overline{(S+Q)}}=\bar{R} \cdot(S+Q)=S \bar{R}+\bar{R} Q
$$



| Present <br> state $\boldsymbol{Q}$ | Next state $\boldsymbol{Q}^{+}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Input signals SR |  |  |  |  |
|  | 00 | 01 | 11 | 10 |  |
| 0 | 0 | 0 | 0 | 1 |  |
| 1 | 1 | 0 | 0 | 1 |  |
| For binary order |  |  |  |  |  |

William Sandqvist william@kth.se

## Stable states

| Present <br> state | Nexstate |  |  |  |
| :---: | ---: | ---: | ---: | ---: |
|  | $S R=00$ | 01 | 10 | 11 |
| 0 | $Y$ | $Y$ | $Y$ | $Y$ |
| 1 | 0 | 0 | 1 | 0 |
|  | 1 | 0 | 1 | 0 |

- Since we do not have flip-flops, but only combinational circuits, a state change can result in additional state changes
- A state is
- stable if $Y(t)=y(t+\Delta)$
- unstable if $Y(t) \neq \mathrm{y}(t+\Delta)$

$$
Y=y ~ s t a b l e ~
$$

## Exitation table

The asynchronous coded state table is called Excitation table
The stable states (those with next state = present state) will be "encircled"


William Sandqvist william@kth.se

## Terminology

When dealing with asynchronous sequential circuits a different terminology is used

- The asynchronous uncoded state table is called flow table


## Flowtable and Statediagram (Moore type)

| Present <br> state | Next state |  |  |  | Output |
| :---: | ---: | ---: | ---: | ---: | :---: |
|  | $S R=00$ | 01 | 10 | 11 |  |
| $A$ | A | A | B | A | 0 |
| $B$ | B | $A$ | B | $A$ | 1 |



William Sandqvist william@kth.se

## Flowtable and Statediagram (Mealy type)



Don’t care ( '-’’) has been selected for the output decoder. It does not matter if the output is changed before or after the state transition (= simpler gate array).

## Asynchronous Moore compatible



- Asynchronous sequential circuits have similar structure as synchronous sequential circuits
- Instead of flip-flops one have a "delay block"


## Asynchronous Mealy compatible



- Asynchronous sequential circuits have similar structure as synchronous sequential circuits
- Instead of flip-flops one have a "delay block"


## Analysis of asynchronous circuits

## The analysis is done in the following steps :

1) Replace the feedbacks in the circuit with delay element
$\Delta_{\mathrm{i}}$. Input signal to delay-element forms the next state $Y_{\mathrm{i}}$, while the output signal $y_{\mathrm{i}}$ represents the present state.
2) Find out the next-state and output expressions
3) Set up the corresponding excitationstable
4) Create a flow table by replacing the encoded states by symbolic states
5) Draw a state diagram if needed

## First: D-latch state function



D-latch statefunction. Functional relationship between the current state $y$ and next state $Y$

$$
\begin{array}{r}
Y=D \cdot C+y \cdot \bar{C} \\
\text { follow } \\
\stackrel{\uparrow}{\text { latch }}
\end{array}
$$

## Exemple: Master-Slave-flip-flop

Master-slave D flip-flop is constructed from two asynchronous D-latches.


State
expression:

$$
\begin{aligned}
& Y_{m}=D \cdot C+y_{m} \cdot \bar{C} \\
& Y_{s}=y_{m} \cdot \bar{C}+y_{s} \cdot C
\end{aligned}
$$

William Sandqvist william@kth.se

## Exitationstable

From the expressions one can directly derive the excitation table (if you can keep it all in your head?)

$$
\begin{aligned}
& Y_{m}=D \cdot C+y_{m} \cdot \bar{C} \\
& Y_{s}=y_{m} \cdot \bar{C}+y_{s} \cdot C
\end{aligned}
$$

| Present <br> state $y_{m} y_{s}$ | Next state |  |  |  | Output Q |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $C D=00$ | 01 | 10 | 11 |  |
|  | $Y_{m} Y_{s}$ |  |  |  |  |
| 00 | 00 | (00) | (00) | 10 |  |
| 01 |  | 00 |  | 11 |  |
| 10 |  | 11 | 00 | (10) |  |
| 11 |  | (11) | 01 | (11) |  |

William Sandqvist william@kth.se

## or with help from K-map ...



## Flow table

We define four states S1, S2, S3, S4, which gives us the flow table

| Present <br> state <br> $y_{m} y_{s}$ | Next state |  |  |  | Output <br> $Q$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $C D=00$ | 01 | 10 |  |  |
|  | $Y_{m} Y_{s}$ |  |  |  |  |
| 00 | 00 | (00) | (00) | 10 | 0 |
| 01 | 00 | 00 | (01) | 11 | 1 |
| 10 | 11 | 11 | 00 | (10) | 0 |
| 11 | 11 | (11) |  | (11) | 1 |


| Present <br> state | Nextstate |  |  |  | Output |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{CD}=00$ | 01 | 10 | 11 |  |
| S 1 | S 1 | S 1 | S 1 | S 3 | 0 |
| S 2 | S 1 | S 1 | S 2 | S 4 | 1 |
| S 3 | S 4 | S 4 | S 1 | S | 0 |
| S 4 | $\mathrm{S4}$ | S 4 | S 2 | S 4 | 1 |

William Sandqvist william@kth.se

## Flow table

Remember: Only one input can be changed at a time

- Thus, some transitions will never be able to happen!

| Present <br> state | Nextstate |  |  |  | Output |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{CD}=00$ | 01 | 10 | 11 |  |
| S1 | S 1 | S 1 | S 1 | S 3 | 0 |
| S 2 | S 1 | S 1 | S 2 | S 4 | 1 |
| S3 | S 4 | S 4 | S 1 | S 3 | 0 |
| S 4 | $\mathrm{S4}$ | S 4 | S 2 | S 4 | 1 |

William Sandqvist william@kth.se

## Flowtable - impossible transitions



State S3
Only stable state for $\mathbf{S 3}$ is when input is 11
Only one input at a time can change $\rightarrow$ possible changes are $11 \rightarrow 01$, $11 \rightarrow 10$

- Theese combinations leaves S3!
- Input 00 in S3 is not possible!
- Input 00 is therefore don't care!

William Sandqvist william@kth.se

## Flowtable - impossible transitions



## State S2

Only stable state for $\mathbf{S 2}$ is when input is 10
Only one input at a time can change $\rightarrow$ possible changes are $10 \rightarrow 11,10$
$\rightarrow 00$

- Theese combinations leave S2!
- Input 01 in S2 is not possible!
- Input 01 is therefore don't care!


## D-flip-flop state diagram



Don't care can be used to simplify the circuit (the next state decoder).

William Sandqvist william@kth.se

## Synthesis of asynchronous circuits <br> The synthesis is carried out in the following steps :

1) Create a state diagram acording to the functional description
2) Create a flow table and reduce the number of states if possible
3) Assign codes to the states and create the excitationstable
4) Develop expressions (transfer functions) for next state and outputs
5) Design a circuit that implements the above expressions

## Exemple: serial paritety circuit

## Input $\boldsymbol{x}$ Output $\boldsymbol{y}$

$y=1$ if the number of pulses at
 input $\boldsymbol{x}$ is an odd number.

In other words, an "every other time" circuit ...


William Sandqvist william@kth.se

## Create state diagram



William Sandqvist william@kth.se

## Cteqte statetabe



| Pres <br> state | Next State |  | Q |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=0$ | 1 |  |
| A | A | B | 0 |
| B | C | B | 1 |
| C | C | D | 1 |
| D | A | D | 0 |

William Sandqvist william@kth.se

## What is a good state encoding? $00,01,10,11$ - binary code?

| Pres state | Next State | Q |
| :---: | :---: | :---: |
|  | $X=0 \longleftarrow 1$ |  |
| $\mathrm{y}_{2} \mathrm{y}_{1}$ | $\mathrm{Y}_{2} \mathrm{Y}_{1}$ |  |
| 00 | $00) 01$ | 0 |
| 01 | $10 \uparrow$ (61) | 1 |
| 10 | +(10) 11 | 1 |
| 11 | 100 | 0 |

Bad encoding (HD=2!)

- Suppose
$X=1 \quad Y_{2} Y_{1}=11$
- Then
$X \rightarrow 0 \rightarrow Y_{2} Y_{1}=00$ ?
$11 \rightarrow 10$ !
$11 \rightarrow 01 \rightarrow 10$ ! ? $\rightarrow 00$
We will never reach 00?


## What is a good state encoding? $00,01,11,10$ - gray code

- Suppose
$X=1 \quad Y_{2} Y_{1}=10$
- Then
$X \rightarrow 0 \rightarrow Y_{2} Y_{1}=00$
$10 \rightarrow 00$

| Pres <br> state | Next State | Q |
| :---: | :---: | :---: |
|  | $\mathrm{y}_{2} \mathrm{y}_{1}$ |  |
|  |  |  |
| 00 |  |  |
| 01 | 11 | 00 |
| 11 | 01 | 0 |
| 11 | 10 | 1 |
| 10 | 00 | 10 |
| 10 | 0 |  |

Good encoding (HD=1)

## State encoding

- In asynchronous sequential circuits,

Richard Hamming it is impossible to guarantee that the two state variables changes values simultaneously

- Thus, a transition $00 \rightarrow 11$ could result in
- A transition $00 \rightarrow 01 \rightarrow$ ???
- A transition $00 \rightarrow 10 \rightarrow$ ???
- To ensure the function all state transitions MUST have the Hamming distans 1
- The Hamming distans is the number of bits that differs in two binary numbers
- Hamming distans between 00 and 11 is 2
- Hamming distans between 00 and 01 is 1


## Good state encoding

- Procedure to obtain good codes:

1) Draw the transition diagram along the edges in hypercubes (Gray code) formed by the codes
2) Remove any crossing lines by
a) change the position of two adjacent nodes
b) utilize available unused codes
(exploit unstable conditions)
c) introduce hypercube of more dimensions

## Poor coding of the parity circuit

The poor state encoding


| Pres <br> state | Next State | Q |
| :---: | :---: | :---: |
|  |  |  |

William Sandqvist william@kth.se

## Good coding of the parity circuit

The good state encoding


Good encoding Hamming Distance $=1$ (no crossing lines)

William Sandqvist william@kth.se

William Sandqvist william@kth.se

## Problems with non-stable states

## Ex. an other circuit:

| Present <br> state | Nextstate |  |  |  | Output |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $r_{2} r_{1}=00$ | 01 | 10 | 11 | $g_{2} g_{1}$ |
| A 00 | A | B | C | - | 00 |
| B 01 | A | B | C | (B) | 01 |
| C 10 | A | B | C | C | 10 |



Bad encoding

At the transition between $\mathbf{B}$ to $\mathbf{C}$ (or $\mathbf{C}$ to $\mathbf{B}$ ) is the Hamming distans $2(10 \leftrightarrow 01)$ ! Chance to get stuck in an unspecified state (with the code 11)!

## Solution to unstable state

- Solution: The introduction of a transition state that ensure that you do not end up in an undefined state!



## Extra states - more dimensions

- One can increase the number of dimensions in order to implement secure state transitions


If there is no way redraw the chart to HD = 1 you may add states by increasing the dimension of the hypercube. You then drag the transitions through the then available non-stable states.

## Extra states - more dimensions

- It's easier to draw a "flat" 3D cube (perspective, is then from the front)


William Sandqvist william@kth.se

## Karnaugh maps



Groupings in red are to avoid Hazard (see later in course)!
William Sandqvist william@kth.se

## The complete circuit



William Sandqvist william@kth.se

## ( easier with D-flip-flop )



We have made an "every other time" earlier in the course. Then with a D flip-flop. But now it was more exiting!

## What is Hazard?

- Hazard is a term that means that there is a danger that the output is not stable, but it may "flicker" at certain input combinations.
- Hazard occurs if there is a different distance from the various inputs to an output, there will be an signal-race.
- In order to counteract this, one must add the prime implikants to cover up the dangerous transition.


## Exemple of Hazard - MUX



At the transition from $\mathrm{xy}_{2} \mathrm{y}_{1}=(111) \rightarrow$ (011) the output $Q$ could flicker, because the road from $x$ to $Q$ are longer via the upper AND-gate than the lower (race).

MORE ABOUT HAZARD IN THE NEXT LECTURE!

William Sandqvist william@kth.se

## State Minimizing

Asynchronous state machines has many "unspecified" positions in the flow table that can be exploited to minimize the number of states.

The probability that less number of states leads to a simpler implementation is high in the case of asynchronous circuits!

## State Minimizing

## Two steps:

Equivalency - equivalent state. The same steps as the state minimization of synchronous sequential circuits, full flexibility remain.

Compatibility - compatible states will be different for Moore or Mealy compliant realization, the choices you make now affect the future flexibility.

## State Nitininititing

- Procedure for minimizing the number of states

1. Forming equivalence groups.

To be in the same group, the following shall apply:

- Outputs must have the same value
- Stable states must be in the same place (column)
- Don't cares for next state muste be at the same place (column)

2. Minimize equivalence groups (state-reduction)
3. Form merger diagram different for Mealy or Moore.
4. Merge compatible states in groups. Minimize the number of groups simultaneously. Each state may only be part of one group.
5. Construct the reduced flow table by merging rows in the selected groups
6. Repeat step 3-5 to see if more minimizations may be done

## Candy Machine ( BV p. 610 )

- Candy Machine has two inputs:
- $N$ : Nickel (5 cent)
- D: Dime (10 cent)
- A candy costs 10 cent
- The machine does not return any money if there are 15 cent in the machine ( one candy is returned )
- Output $\mathbf{z}$ is active when there is enough money for a candy


## State diagram, Flow table



- No "double changes" of input signals!
- You can't insert two coins at the same time!

| Pres state | Next State $\downarrow$ | Q |
| :---: | :---: | :---: |
|  | X=00 011011 |  |
| A | (A) $B \subset \square$ | 0 |
| B | $D$ (B) | 0 |
| C | A - (C) | 1 |
| D | (D) $E$ F | 0 |
| E | A E - | 1 |
| F | A $-(F)$ | 1 |
| ( $\mathrm{X}=\mathrm{ND}, \mathrm{Q}=\mathrm{z}$ ) |  |  |

A flow table that only has one stable state on each row is called a primitive flowtable.

William Sandqvist william@kth.se

## State Minimizing



State Minimization means that two states may be equivalent, and if so, replaced by one state to simplify the state diagram, and network.
One can easily see that state C and $F$ could be replaced by one state, as a candy always be ejected after a Dime regardless of previous state.

## Form/minimize equivalence groups

1. Form equivalence groups. To be in the same group, the following applies:

- Outputs must have the same value
- Stable states must be at same place (column)
- Don't cares for next state must be at same place (column)

2. Minimize equivalence groups (state reduction).

## - Equivalence groups

The states is divided in blocks after the output value.


$$
(X=N D, Q=z)
$$

ABD has output 0, CEF has output 1. $P_{1}=(A B D)(C E F)$
Stable states must be for same input signal (column), don't care must be for same column.

AD has a stable state for 00. B has a stable for 01. CF has a stable state for 10. E has a stable for 01. AD and CF has don't care for corresponding input signals.

$$
P_{2}=(A D)(B)(C F)(E)
$$

## Merge equivalence groups

Two rows could be "merged" if it does not conflikt their successor states

| Pres state | Next State | Q |
| :---: | :---: | :---: |
|  | $\begin{array}{lllll}X=00 & 01 & 10 & 11\end{array}$ |  |
| A | (A) B C | 0 |
| B | D (B) - | 0 |
| C | A - (C) | 1 |
| D | (D) E F | 0 |
| E | A (E) - | 1 |
| F | A - (F) | 1 |
| $(X=N D, Q=z)$ |  |  |

$\mathrm{P}_{2}=(\mathrm{AD})(\mathrm{B})(\mathrm{CF})(\mathrm{E})$
$P_{3}=(A)(D)(B)(C)(E)$
$P_{4}=P_{3}$.

Rows $\mathbf{C}$ and $\mathbf{F}$ can be merged with a new name $\mathbf{C}$, while $\mathbf{A}$ and $\mathbf{D}$ which has successors in different groups not can merge.


## Compatibility Groups

3. Form merger charts either for Mealy or Moore
4. Merge compatible states into groups. Minimize the number of groups simultaneously. Each state may only be part of a group.
5. Construct the reduced flow table by merging rows in the selected groups
6. Repeat steps $3-5$ to see if more minimizations can be done

## Merging rules

- Two states are "compatible", and can be merged if the following applies

1. at least one of the following conditions apply to all input combinations

- both $\mathrm{S}_{\mathrm{i}}$ and $\mathrm{S}_{\mathrm{j}}$ has the same successor state, or
- both $\mathrm{S}_{\mathrm{i}}$ and $\mathrm{S}_{\mathrm{j}}$ are stable, or
- The successor to $S_{i}$ or $S_{j}$ are both unspecified

2. Then if you want to construct a Moore-compatible statemachine it also apply

- both $\mathrm{S}_{\mathrm{i}}$ and $\mathrm{S}_{\mathrm{j}}$ has the same output value (this is not necessary when you construct a Mealy-compatible statemachine)


## Merger diagram

Resulting flowtable

| Pres state | Next State |  | Q |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{X}=000110$ | 11 |  |
| $\xrightarrow{ } \rightarrow$ | (A) B C | - | 0 |
| B | $D$ (B) - | - | 0 |
| $\xrightarrow{\square} \mathrm{C}$ | A - C | - | 1 |
| D | (D) $E C$ | - | 0 |
| $\longrightarrow E$ | A (E) - | - | 1 |

- When there are there are several possibilities ...

Compatibily graph


Mealy-compatible: In state $\mathbf{A}(X=00)$ the output is 0 , in state $\mathbf{C}$ output is 1

$$
\begin{array}{ll}
C(1): & A-C- \\
A(0): & A B C- \\
\hline
\end{array}
$$

William Sandqvist william@kth.se

## An illustrative example (BV 9.8)

## equivalence classes

Primitive flowtable


The same output, same position for stable states and do not care conditions (AG) (BL) (HK)

$$
P_{1}=(A G)(B L)(C)(D)(E)(F)(H K)(J)
$$

Successor state: A, G are not equivalent

$$
\begin{aligned}
& \mathrm{A}, \mathrm{G}_{00} \rightarrow(\mathrm{AG}),(\mathrm{AG}) \mathrm{A}, \mathrm{G}_{01} \rightarrow(\mathrm{~F}),(\mathrm{BL}) \\
& \mathrm{A}, \mathrm{G}_{10} \rightarrow(\mathrm{C}),(\mathrm{J}) \mathrm{A}, \mathrm{G}_{11} \rightarrow-,-- \\
& \hline
\end{aligned}
$$

| $\mathrm{B}, \mathrm{L}_{00} \rightarrow(\mathrm{AG}),(\mathrm{AG}) \mathrm{B}, \mathrm{L}_{01} \rightarrow(\mathrm{BL}),(\mathrm{BL})$ |
| :--- |
| $\mathrm{B}, \mathrm{L}_{10} \rightarrow-,-\quad \mathrm{B}, \mathrm{L}_{11} \rightarrow(\mathrm{HK}),(\mathrm{HK})$ |
| $\mathrm{H}, \mathrm{K}_{00} \rightarrow-,-\mathrm{H}, \mathrm{K}_{01} \rightarrow(\mathrm{BL}),(\mathrm{BL})$ |
| $\mathrm{H}, \mathrm{K}_{10} \rightarrow(\mathrm{E}),(\mathrm{E}) \mathrm{H}, \mathrm{K}_{11} \rightarrow(\mathrm{HK}),(\mathrm{HK})$ |

$$
P_{2}=(A)(G)(B L)(C)(D)(E)(F)(H K)(J) \quad P_{3}=P_{2}
$$

William Sandqvist william@kth.se

## An illustrative example (BV 9.8)

## equivalence classes

Primitive flowtable

| Pres state | Next State | Q |
| :---: | :---: | :---: |
|  | $\mathrm{X}=000101011$ |  |
| A | (A) F C | 0 |
| B | $A$ (B) - H | 1 |
| C | G - (C) D | 0 |
| D | - F - D | 1 |
| E | G - (E) D | 1 |
| F | - F - K | 0 |
| G | (G) B J | 0 |
| H | - L E H) | 1 |
| J | G - J | 0 |
| K | - B K | 1 |
| L | A (L) - K | 1 |

$$
\begin{aligned}
& \mathbf{P}_{1}=(\mathrm{AG})(\mathrm{BL})(\mathrm{C})(\mathrm{D})(\mathrm{E})(\mathrm{F})(\mathrm{HK})(\mathrm{J}) \\
& \mathrm{P}_{2}=(\mathrm{A})(\mathrm{G})(\mathrm{BL})(\mathrm{C})(\mathrm{D})(\mathrm{E})(\mathrm{F})(\mathrm{HK})(\mathrm{J}) \\
& \mathrm{P}_{3}=\mathrm{P}_{2}
\end{aligned}
$$

B for (BL)

$$
\mathbf{H} \text { for (HK) }
$$

No unspecified states has yet been used!

## An illustrative example - Compatibility <br> Compatibility-graph

| Reduced flowtable |  |  |
| :---: | :---: | :---: |
| Pres state | Next State | Q |
|  | $\mathrm{X}=00001010$ |  |
| $\rightarrow \mathrm{A}$ | (A) $F \mathrm{C}$ | 0 |
| $\rightarrow \mathrm{B}$ | $A$ B - $H$ | 1 |
| $\rightarrow \mathrm{C}$ | G - C D | 0 |
| $\longrightarrow \mathrm{D}$ | - F- (D) | 1 |
| $\rightarrow \mathrm{E}$ | G - D | 1 |
| $\longrightarrow F$ | - (F)-H | 0 |
| $>\mathrm{G}$ | (G) B J - | 0 |
| $\longrightarrow \mathrm{H}$ | - B E (H) | 1 |
| $\longrightarrow \mathrm{J}$ | G - J | 0 |



| Pres <br> state | Next State |  |  |  | Q |
| :---: | ---: | ---: | ---: | ---: | :---: |
|  | X=00 | 01 | 10 | 11 |  |
| A | A | A | C | B | 0 |
| B | A | B | D | B | 1 |
| C | G | - | C | D | 0 |
| D | G | A | D | D | 1 |
| G | G | B | G | - | 0 |

New names B(BH), A (AF), G (JG), D (DE) William Sandqvist william@kth.se

## An illustrative example ...

 Compatibility-graphMore reduced flowtable

| $\begin{aligned} & \text { Pres } \\ & \text { state } \end{aligned}$ | Next State | Q |
| :---: | :---: | :---: |
|  | $\mathrm{X=00} 0110 \quad 11$ |  |
| A | (A) (A) $C \quad B$ | 0 |
| B | A (B) D (b) | 1 |
| $\rightarrow$ C | G - © D | 0 |
| D | G A (D) (D) | 1 |
| $\longrightarrow$ G | ( $)^{\text {B ( }}$ | 0 |


| B | A |
| :--- | :--- |
| $\bullet$ | - |

- 



New name $\mathbf{C}$ for (CG)

| Slutlig flödestabell |  |  |
| :---: | :---: | :---: |
| Pres <br> state | Next State | Q |
|  | $X=000011011$ |  |
| A | (A) (A) $C$ B | 0 |
| B | $A$ (B) $D$ ( ${ }^{\text {a }}$ | 1 |
| C | (C) $B$ (C) $D$ | 0 |
| D | C A (D) (D) | 1 |

Now all the unspecified conditions are used!

## Summary

- Asynchronous state machines
- Based on analysis of feedback combinational networks
- All flip-flops and latches are asynchronous state machines
- A similar theory as for synchronous state machines can be applied
- Only one input or state variable can be changed at a time!
- One must also take into account the race problem

William Sandqvist william@kth.se

