# Finite State Machines (FSMs) and RAMs and CPUs

COS 116, Spring 2011 Sanjeev Arora



#### Recap

• Combinational logic circuits: no cycles, hence no "memory"

- Sequential circuits: cycles allowed; can have memory as well as "undefined"/ambiguous behavior
- Clocked sequential circuits: Contain D flip flops whose "Write" input is controlled by a clock signal



#### Recap: R-S Latch





- M becomes 1 if Set is turned on
- M becomes 0 if Reset is turned on
- Otherwise (if both are 0), M just remembers its value

Forbidden to turn on both Set and Reset simultaneously (value is "ambiguous")

### Recap: D Flip Flop

Basic Memory Block – stores 1 bit.



If we "toggle" the write input (setting it 1 then setting it 0) then M acquires the value of D.



#### M

### Finite State Machines (FSMs)



- Finite number of states
- Machine can produce outputs, these depend upon current state only ("Moore machine;" see Hayes article)
- Machine can accept one or more bits of input; reading these causes transitions among states.

# Implementing door FSM as synchronous circuit



#### **INPUT**

0 = No Person Detected

1 = Person Detected

#### STATE

0 = Door Closed

1 = Open

| Input | Present State | Next State |
|-------|---------------|------------|
| 0     | 0             | 0          |
| 1     | 0             | 1          |
| 0     | 1             | 0          |
| 1     | 1             | 1          |



#### Implementation of door FSM (contd)



#### M

#### Implementation: General Schematic



K Flip flops allow FSM to have 2<sup>K</sup> states





# Discussion Time

Example: 4-state machine; 1 bit of input; 1 bit of output

State variables: P, Q

Input variable: D

Next value of  $P = (P + Q) \cdot D$ 

Next value of Q = P

Output =  $P \cdot Q$ 

What is its state diagram? How can it be implemented as a clocked synchronous circuit?

Divide in groups of 3 and hand this in.



#### How to implement a FSM?

- •If number of states = 2<sup>k</sup> then represent "state" by k boolean variables.
- Identify number of input variables
- Write truth table expressing how "next state" is determined from "current state" and current values of the input. Convert to boolean circuit.
- Express as clocked synchronous circuit.



### How an FSM does "reasoning"



"If left infrared sensor detects an object, turn left"





Random Access Memory (RAM)

Memory where each location has an address



# Recall from last lecture: "Register" with 4 bits of memory



How can you set up an addressing system for large banks of memory?



#### **RAM**



2<sup>K</sup> bits; bank of flipflops



#### 0

#### If 4 locations, "address" has 2 bits





RAM: Implementing "Write"



The decoder selects which cell in the RAM gets its "Write" input toggled

(simple combinational circuit; see logic handout)



Ram: implementing "Read"



The multiplexer is connected to all cells in the RAM; selects the appropriate cell based upon the k-bit address (simple combinational circuit; see logic handout)

r,

Next, the secret revealed...

How computers execute programs.

CPU = Central Processing Unit





**F5** 

"Download to Robot"

(Compilation)

Point 1: Programs are "translated" into "machine language"; this is what's get executed.

#### Machine Executable Code



#### Similar to:

- •T-P programs represented in binary
- .exe files in the Wintel world

#### М

# Greatly simplified view of modern CPUs.

Program (in binary) of modern CPUs. stored in memory





**RAM** 

#### Examples of Machine Language Instructions

| ADD  | 3 | 7 12  | Add contents of Register 3 and Register 7 and store in Register 12 |
|------|---|-------|--------------------------------------------------------------------|
| LOAD | 3 | 67432 | Read Location 67432<br>from memory and load<br>into Register 3     |
| JUMP | 4 | 35876 | If register 4 has a number > 0 set IP to 35876                     |

Stored in binary (recall Davis's binary encoding of T-P programs)

### М

# Different CPUs have different machine languages

- Intel Pentium, Core, Xeon, etc. (PC, recent Mac)
- Power PC (old Mac)
- ARM (cellphones, mobile devices, etc.)

"Backwards Compatibility" – Core 2's machine language extends Pentium's machine language

Machine languages now allow complicated calculations (eg for multimedia, graphics) in a single instruction

## Main Insight

Computer = FSM controlling a larger (or infinite) memory.

# Meet the little green man..



The Fetch – Decode – Execute FSM



#### Fetch - Decode - Execute FSM





(output bits used to control circuits that add, multiply etc.)

#### м

#### CPU as a conductor of a symphony



Bus: "Everybody hears everybody else"



### Speculation: Brain as FSM?





- Network ("graph") of 100 billion neurons; each connected to a few thousand others
- Neuron = tiny Computational Element;
   "switching time" 0.01 s
- Neuron generates a voltage spike depending upon how many neighbors are spiking.