# **ENR-325/325L Principles of Digital Electronics and Laboratory**

Xiang Li

Fall 2025



#### Hamming codes can be done in the EE way

Before that, we need to acquire some basic skillsets.

Pre-step: Data forms

Step 1: Data manipulation

Step 2: Information storage

**Step 3: Interface** 

3.1 Information flow

3.2 Physical contacts



### 3.1 Information flow and sequential logic

- Our previous logic circuits are mostly combinational.
- To expand the functions of their finite gates and I/Os, we need to introduce another dimension: time.
- It also allows us to synchronize the operations when we need to do iterations (loops).

Sequential logic diagram



#### 3.1 Information flow and sequential logic

- Our previous logic circuits are mostly combinational.
- To expand the functions of their finite gates and I/Os, we need to introduce another dimension: time.
- It also allows us to synchronize the operations when we need to do iterations (loops).

Clocked sequential logic diagram



#### From latch to flip flop

SR latch





## Understanding SR latch with truth table and timing diagram

SR latch



SR latch truth table

|        | Output (Q)     | R | S |
|--------|----------------|---|---|
| (HOLD) | Previous State | 0 | 0 |
|        | 0              | 1 | 0 |
|        | 1              | 0 | 1 |
|        | 0 (Invalid)    | 1 | 1 |

SR Latch Timing Diagram (NOR Gates)



#### Understanding and coding! a timing diagram

SR latch truth table

| S | R | Output (Q)     |  |
|---|---|----------------|--|
| 0 | 0 | Previous State |  |
| 0 | 1 | 0              |  |
| 1 | 0 | 1              |  |
| 1 | 1 | 0 (Invalid)    |  |

#### https://wavedrom.com/

#### SR Latch Timing Diagram (NOR Gates)





#### A latch with a "single" input

A gated D latch





## A latch with a "single" input

A gated D latch







## A latch with a "single" input

A gated D latch



Also known as: D latch/data latch



Gated D latch



#### D latch timing diagram code



#### Gated D latch



### Let's practice timing diagrams!

11-bits keyboard output via PS/2 port:





### Let's practice timing diagrams!

Turn this truth table into a timing diagram!

| A BC | 00 | 01 | 11 | 10 |
|------|----|----|----|----|
| 0    | 0  | 1  | 1  | 1  |
| 1    | 1  | 1  | 1  | 0  |



#### Let's practice timing diagrams!

Turn this Hamming encoding into a timing diagram!

Data: 01010101010

Adding P1:

Adding P2:

Adding P3:

Adding P4:

Adding P0:

Code:

