#### Feedback and Flip-Flops

Philipp Koehn

7 September 2019



#### The Story So Far



- We can encode numbers
- We can do calculation
- ... but it's all a bit static
- How about a counter?
  - $\rightarrow$  this requires "memory"



## feedback

#### **A** Strange Contraption





#### Let's Turn It On





Electricity is on  $\rightarrow$  this opens the normally closed key

#### Let's Turn It On





Electricity is off  $\rightarrow$  this closes the normally closed key

#### What Do We Have?



- A Buzzer
- A Clock



• An Oscillator



(symbol)

## **Oscillator**



- **Period** of oscillator
- Frequency: cycles per second
- Unit: 1 cycle per second: 1 Hertz
- Modern computes:
  Billions of Hertz = Gigahertz (GHz)



Heinrich Hertz 1857--1894



## flip flop

#### Another Contraption













#### Same key configuration as initially

But: Now OUT is on --- we remembered the key turn









#### Back to initial state

Computer Systems Fundamental: Feedback and Flip-Flops

#### Memory



- We have memory -- called Reset-Set Flip-Flop
- Truth table

| UPPER | LOWER | OUT     |
|-------|-------|---------|
| 0     | 0     | OUT     |
| 0     | 1     | 0       |
| 1     | 0     | 1       |
| 1     | 1     | Illegal |

- UPPER = SET
- LOWER = RESET

#### **Re-Arranged**











#### Truth Table



| S | R | Q       | $\overline{Q}$ |
|---|---|---------|----------------|
| 1 | 0 | 1       | 0              |
| 0 | 1 | 0       | 1              |
| 0 | 0 | Q       | Q              |
| 1 | 1 | Illegal |                |



# d-type flip flop

## Vision



- Control bit ("clock")
  - on = write to memory
  - off = read from memory
- Data bit
  - data item to be written
- Output
  - current state of the memory









#### D-Type Flip-Flop



- Also called **D-type latch**
- Circuit latches on one bit of memory and keeps it around
- Truth table

| Data | Clock | Q | Q |
|------|-------|---|---|
| 0    | 1     | 0 | 1 |
| 1    | 1     | 1 | 0 |
| X    | 0     | Q | Q |

• Can also build these for multiple data bits



## accumulative adder

#### Design Goal



- Adder has initially value 0
- Adding a number
  - $\rightarrow$  value increases
- Resetting
  - $\rightarrow$  value goes back to 0

#### Ingredients







#### Ingredients







- Latch: current sum







- Adder
- Combines
  - current value
  - selected input

IN

8

В

CI

OUT



- Can we pass output directly to latch?
- Concerns
  - select between 0 and sum
  - only stored when clock on







• Still have runaway feedback loop...

OUT



- Two Latches
  - one to store the sum
  - one to store input to adder
- Clock 1
  - carry out addition
  - store result
- Clock 2
  - transfer to set up next addition





- Combine the clocks
- Pressing the add key
  - carry out addition
  - store result in upper latch
- Release the add key
  - transfer to lower latch
  - set up next addition



What Else?



NOT











• Each cycle of oscillator:

keeps adding



#### What Else?





# edge triggered flip-flop

#### **D-Type Latch**





- When clock is on, save data
- "Level-triggered"

#### **D-Type Latch**





• "Edge-triggered": changes value, when switched from 0 to 1





Symbol

#### Truth Table



| Data | Clock      | <b>Q</b> | Q |
|------|------------|----------|---|
| 0    | $\uparrow$ | 0        | 1 |
| 1    | $\uparrow$ | 1        | 0 |
| X    | 0          | <b>Q</b> | Q |



# ripple counter

#### **Oscillator and Latch**





| Data | Clock      | Q | Q |
|------|------------|---|---|
| 1    | 0          | 0 | 1 |
| 1    | $\uparrow$ | 1 | 0 |
| 0    | 1          | 1 | 0 |
| 0    | 0          | 1 | 0 |
| 0    | $\uparrow$ | 0 | 1 |
| 1    | 1          | 0 | 1 |
| 1    | 0          | 0 | 1 |

#### Oscillator and Latch





| Data | Clock      | Q | Q |
|------|------------|---|---|
| 1    | 0          | 0 | 1 |
| 1    | $\uparrow$ | 1 | 0 |
| 0    | 1          | 1 | 0 |
| 0    | 0          | 1 | 0 |
| 0    | $\uparrow$ | 0 | 1 |
| 1    | 1          | 0 | 1 |
| 1    | 0          | 0 | 1 |

## Halving of Frequency



| Data | Clock      | Q | $\overline{Q}$ |
|------|------------|---|----------------|
| 1    | 0          | 0 | 1              |
| 1    | $\uparrow$ | 1 | 0              |
| 0    | 1          | 1 | 0              |
| 0    | 0          | 1 | 0              |
| 0    | $\uparrow$ | 0 | 1              |
| 1    | 1          | 0 | 1              |
| 1    | 0          | 0 | 1              |



#### Multiple Bits











