# Fundamental Algorithms for System Modeling, Analysis, and Optimization 

## Stavros Tripakis

## UC Berkeley

EECS 144/244
Fall 2016

Copyright © 2010-date, E. A. Lee, J. Roychowdhury, S. A. Seshia, S. Tripakis, All rights reserved

## Discrete Systems

## Reminder: systems

- System: atomic system | composite system
- Atomic system: state + dynamics (+ inputs/outputs)
- Composite system: set of subsystems + composition
- Dynamics: rules defining how state evolves in time
- Composition: rules defining how subsystems interact


## Classes of systems/models considered in this course

- Continuous: differential equations, ... ???
- Discrete: state machines, transition systems, ...
- Timed: discrete-event, timed automata, ...
- Dataflow: process networks, SDF, ...
- Probabilistic: Markov chains, ...


## Discrete systems

Automata, state machines, transition systems, ...

- States
- Transitions: discrete moves from one state to the next
- "logical" time = order of transitions
- As opposed to quantitative, "real-time" models such as differential equations or timed automata (we will see those later).


## Finite State Machines

Machines of type Moore or Mealy

Main application: digital circuits

## Moore machines

States: $\{q 0, q 1, q 2, q 3\}$
Initial state: q0
Input symbols: $\{x, y, z\}$
Output symbols: $\{\mathrm{a}, \mathrm{b}, \mathrm{c}\}$
Output function:

out: States $\rightarrow$ Outputs
Transition function:

$$
\text { next: States } \times \text { Inputs } \rightarrow \text { States }
$$

## Moore machine: a circuit view



## Mealy machines

States: $\{\mathrm{SO}, \mathrm{S} 1, \mathrm{~S} 2\}$
Initial state: S0
Input symbols: $\{0,1\}$
Output symbols: $\{0,1\}$
Output function:

out : States $\times$ Inputs $\rightarrow$ Outputs
Transition function:

$$
\text { next: States } \times \text { Inputs } \rightarrow \text { States }
$$

## Mealy machine: a circuit view



## Finite State Machines - Formal Definition

An FSM is a tuple

$$
\left(I, O, S, s_{0}, \delta, \lambda\right)
$$

- $I$ : set of inputs
- $O$ : set of outputs
- $S$ : set of states
- $s_{0} \in S$ : initial state
- $\delta: S \times I \rightarrow S:$ transition function
- $\lambda$ : output function
- If the FSM is of type Moore:

$$
\lambda: S \rightarrow O
$$

- If the FSM is of type Mealy:

$$
\lambda: S \times I \rightarrow O
$$

## Example: Mealy Machine

structure:

behavior:


## CIRCUITS

## Synchronous Circuits - Generic structural view:



- Combinational logic part: a network of logical gates (AND, OR, NOT, XOR, ...).
- Memory/state of the circuit: some type of digital memory element (e.g., D-type flip-flop).
- Synchronous: clock arriving conceptually synchronously (simultaneously) at all flip-flops.
- Circuit: a network of connected gates and flip-flops ("netlist").


## Memory element: D flip-flop



Behavior (simplified ${ }^{1}$ ):

- Clock input defines a set of times $t_{1}, t_{2}, t_{3}, \ldots$ (e.g., up-edges of a periodic pulse).
- The value of output remains constant during the interval $\left[t_{k}, t_{k+1}\right)$ and equal to the value of the input D at $t_{k}$.
- "Door-opening" metaphor.
- Memory elements often have more inputs (e.g., resets to initialize state).

[^0]
## Is the D flip-flop a state machine?

## Combinational logic gates



## Are logic gates state machines?

## Digital Circuits: Networks of Flip-Flops and Logic Gates

For now, we consider acyclic circuits: they can have feedback, but any feedback loops are "broken" by flip-flops:


Are the dynamics of such circuits well-defined? How?

## From Circuits to State Machines



Is this a state machine?

## From Circuits to State Machines



Is this a state machine? Is it a Mealy or Moore machine?
How are ( $I, O, S, s_{0}, \delta, \lambda$ ) defined?
What would a Moore Machine look like?

## State Machines and Synchronous Circuits



Is this a good drawing?


## Drawing Mealy Machines Correctly

Traditional drawing mixes transition and output functions, although these are independent (this matters in the case of circuits, for instance, where outputs might change multiple times before stabilizing - c.f. discussion on circuits that follows):


Better drawing:


## Modeling and Implementation/Synthesis

What we have done / what we will do next:
Modeling


## From FSMs to Circuits

"Brute-force" implementation:

- $\log n$ flip-flops, where $n=|S|=$ number of states of the FSM.
- $\log k$ input wires, where $k=|I|=$ number of input symbols.
- $\log m$ output wires, where $m=|O|=$ number of output symbols.
- Multiplexers to implement transition and output functions.

More efficient implementations: the logic synthesis problem.
Several subproblems:

- State encoding (or state assignment)
- Logic minimization
- ...


## From FSMs to Circuits

Let's implement this FSM (on whiteboard):


## From FSMs to Circuits

Several combinatorial optimization problems.
E.g., state assignment (state encoding): how to encode the states of a given FSM as boolean vectors. Which of the many possible encodings to choose?
Example (taken from [Kohavi, 1978]):

Table 12.1 Machine $M_{1}$

|  | $N S$ |  |  | $z$ |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $P S$ | $x=0$ | $x=1$ |  | $x=0$ | $x=1$ |
| $A$ | $A$ | $D$ | 0 | 1 |  |
| $B$ | $A$ | $C$ | 0 | 0 |  |
| $C$ | $C$ | $B$ | 0 | 0 |  |
| $D$ | $C$ | $A$ | 0 | 1 |  |


|  |  | $Y_{1} Y_{2}$ |  |  | $z$ |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :---: |
|  | $y_{1} y_{2}$ | $x=0$ | $x=1$ |  | $x=0$ |  |
| $A$ | 00 | 00 | 10 |  | $x=1$ |  |
| $B$ | 01 | 00 | 11 |  | 1 |  |
| $C$ | 11 | 11 | 01 |  | 0 |  |
| $D$ | 10 | 11 | 00 |  | 0 |  |

(a) Assignment $\alpha$


## From FSMs to Circuits

The two state encodings result in two very different circuits:

Fig. 12.1 First realization of $M_{1}$.


Fig. 12.2 Second realization of $M_{1}$.


Figures taken from [Kohavi, 1978].

# An elegant notation for (not necessarily finite) state machines: Lustre 

A program in the synchronous language
Lustre [Halbwachs et al., 1991]:
node Edge (X : bool) returns (E : bool);
let
E = false $->$ X and not pre $X$;
tel

## Can you guess its meaning?

$$
\begin{aligned}
E_{0} & =\text { false } \\
E_{k+1} & =X_{k+1} \wedge \neg X_{k}
\end{aligned}
$$

Quiz: write a counter in Lustre.

## Bibliography



Hachtel, G. D. and Somenzi, F. (1996)
Logic Synthesis and Verification Algorithms. Kluwer.

会Halbwachs, N., Caspi, P., Raymond, P., and Pilaud, D. (1991).
The synchronous dataflow programming language Lustre.
Proceedings of the IEEE, 79(9):1305-1320.
会
Hopcroft, J. E. and Ullman, J. D. (1990).
Introduction To Automata Theory, Languages, And Computation. Addison-Wesley.

Kohavi, Z. (1978)
Switching and finite automata theory, 2nd ed. McGraw-Hill.


[^0]:    ${ }^{1}$ More accurate description of timing behavior in timing analysis lecture. Stavros Tripakis (UC Berkeley)

