

# CSCI 150 Introduction to Digital and Computer System Design Lecture 4: Sequential Circuit I



Jetic Gū

#### Overview

- Focus: Basic Information Retaining Blocks
- Architecture: Sequential Circuit
- Textbook v4: Ch5 5.1, 5.2; v5: Ch4 4.1 4.2
- Core Ideas:
  - 1. Introduction
  - 2. SR and  $\overline{SR}$  Latches, D Latch

P0 Review

# Combinational Logic Circuit Design

- Design Principles
  - Knows: fixed-Length input and output
  - Knows: input/output mapping relations
  - Optimisation: Minimise overall delay



P0 Review

# Combinational Logic Circuit Design

- Features
  - Fixed-Length input and output
  - The same input will always give the same output
  - Operations are simultaneous with minimum delay



P0 Review

# Combinational Logic Circuit Design

- Cannot handle variable length input
- Cannot store information
- Cannot perform multi-step tasks



# Introduction to Sequential Circuit

#### Solution

- Cannot handle variable length input
- Cannot store information
- Cannot perform multi-step tasks



Color

# Solution: Storage!

- Cannot handle variable length input
- Cannot store information
- Cannot perform multi-step tasks



Coucse

# Solution: Storage!

Your Favourite
Combinational
Circuit

- Cannot handle variable length input
- Storage of partial input

Cannot store information

Storage of partial results and states

- Cannot perform multi-step tasks
- Storage of instructions

# Sequential Circuits

- Handle variable-length input
- Store information
- Multi-step tasks
- State Transition from time t to t+1



#### Definitions

- 1. Storage Elements circuits that can store binary information
- 2. **State** partial results, instructions, etc.
- 3. Synchronous Sequential Circuit
  Signals arrive at discrete instants of time,
  outputs at next time step
- 4. Asynchronous Sequential Circuit
  Signals arrive at any instant of time,
  outputs when ready



#### Definitions

- 3. Synchronous Sequential Circuit
  Signals arrive at discrete instants of time,
  outputs at next time step
  - Has Clock
- 4. Asynchronous Sequential Circuit
  Signals arrive at any instant of time,
  outputs when ready
  - May not have Clock



- 1. Are calculators designed using **Combinational Circuits** or **Sequential Circuits**?
  - What about your microwave and toaster?
  - What about your digital watch (not smart)?
  - What about computers/smartphones?



2. Is this calculator using **Asynchronous Sequential Circuit** or **Synchronous Sequential Circuit**?



- 2. Is this calculator using **Asynchronous Sequential Circuit** or **Synchronous Sequential Circuit**?
  - What are the states for this calculator?



- 2. Is this calculator using **Asynchronous Sequential Circuit** or **Synchronous Sequential Circuit**?
  - What are the states for this calculator?
  - What kind of information is stored?





3. Is this calculator using **Asynchronous Sequential Circuit** or **Synchronous Sequential Circuit**?



- 3. Is this calculator using **Asynchronous Sequential Circuit** or **Synchronous Sequential Circuit**?
  - What are the states for this calculator?



- 3. Is this calculator using **Asynchronous Sequential Circuit** or **Synchronous Sequential Circuit**?
  - What are the states for this calculator?
  - What kind of information is stored?





4. Is your laptop/PC/smartphone using Asynchronous Sequential Circuit or Synchronous Sequential Circuit?



- 4. Is your laptop/PC/smartphone using Asynchronous Sequential Circuit or Synchronous Sequential Circuit?
  - What are the Input/Output devices of these computers?



- 4. Is your laptop/PC/smartphone using Asynchronous Sequential Circuit or Synchronous Sequential Circuit?
  - What are the Input/Output devices of these computers?
  - What are the storage devices?



- 4. Is your laptop/PC/smartphone using Asynchronous Sequential Circuit or Synchronous Sequential Circuit?
  - What are the Input/Output devices of these computers?
  - What are the storage devices?
  - What about CPU?



#### Latches

SR and  $\overline{SR}$  Latches, D Latch

• Stable State: the values in a circuit after brief changing due to delay in passing information, reaches a state where it doesn't change anymore -



• Stable State: the values in a circuit after brief changing due to delay in passing information, reaches a state where it doesn't change anymore -



• Stable State: the values in a circuit after brief changing due to delay in passing information, reaches a state where it doesn't change anymore -



• Stable State: all values in a circuit after some changes due to delay in passing signals, reach a state where they don't anymore



• Stable State: all values in a circuit after some changes due to delay in passing signals, reach a state where they don't anymore



• Stable State: all values in a circuit after some changes due to delay in passing signals, reach a state where they don't anymore



 Stable State: all values in a circuit after some changes due to delay in passing signals, reach a state where they don't anymore



What other scenarios might bring about these instabilities?

Course

#### Latches

- Basic Storage Elements
  - Maintain a binary state indefinitely, as long as there's power
  - The binary state inside can be changed



# Summary

- SR Latches and  $\overline{SR}$  Latches
- D Latches















































































#### Exercise

• Draw the SR Latch in LogicWorks as below, make sure it works as intended



or ciss

#### P2 Latches

# SR Latch



| $\overline{S}$ $\overline{R}$               | $Q \overline{Q}$ |             |
|---------------------------------------------|------------------|-------------|
| <ul><li>0</li><li>1</li><li>1</li></ul>     | 1 0<br>1 0       | Set state   |
| <ol> <li>1</li> <li>1</li> <li>1</li> </ol> | 0 1<br>0 1       | Reset state |
| 0 0                                         | 1 1              | Undefined   |

• Design similar to SR latches, but with NANDS



• Functions equivalent to  $S\!\!\!\!R^R\!\!\!$  atches with S and R inverted

P2 Latches

#### D Latch



| C | D | Next state of Q    |
|---|---|--------------------|
| 0 | X | No change          |
| 1 | 0 | Q = 0; Reset state |
| 1 | 1 | Q = 1; Set state   |

- Implemented using  $\overline{SR}$  latches
- C: Signals changes to the stored states; D the value to change to  $S\overline{R}$

#### Latches

- Implement  $\overline{SR}$  latch, save as a component in your library
- ullet Implement D latch, save as a component in your library



e is