• Combinational Logic has no control inputs. When the inputs to a combinatorial network change, the output changes ____________________________.
1.1 Combinational Logic - Basic Logic Gates

AND: \( C = A \cdot B \)

OR: \( C = A + B \)

NOT: \( C = A' \)

EXCLUSIVE OR: \( C = A \oplus B \)

### Module Truth Table

<table>
<thead>
<tr>
<th>X</th>
<th>Y</th>
<th>Cin</th>
<th>Cout</th>
<th>Sum</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

### m-form

\[
\text{Sum} = \text{Cout} \text{Cin} A B \\
\text{Cout} = \text{Cout} \text{Cin} A B 
\]
1.1 Combinational Logic - Full Adder (Maxterm Form)

Module

<table>
<thead>
<tr>
<th>X</th>
<th>Y</th>
<th>Cin</th>
<th>Cout</th>
<th>Sum</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

Sum =

Cout =

Cout = m-form

1.2 Boolean Algebra and Algebraic Simplification

Operations with 0 and 1:

\( X + 0 = X \)  \( X + 1 = X + 1 \)

Idempotent laws:

\( X + X = X \)  \( X \cdot X = X \)  \( X \cdot 0 = 0 \)  \( X \cdot X = X \)  \( X \cdot 0 = 0 \)

Involution law:

\( (X')' = X \)  \( (X')' = X \)

Commutative laws:

\( X + Y = Y + X \)  \( XY = YX \)

Associative laws:

\( (X + Y) + Z = X + (Y + Z) \)  \( (X \cdot Y) + Z = X + (YZ) = XYZ \)

Distributive laws:

\( X(Y + Z) = XY + XZ \)  \( X + YZ = (X + Y)(X + Z) \)
1.3 More Boolean Algebra and Algebraic Simplification

Simplification theorems:

\[
XY + XY' = X \quad \text{(1-13)} \\
X + XY' = X \quad \text{(1-14)} \\
(X + Y')(XY) = XY \\
\text{(A15)} \\
XY + Y = X + Y \\
\text{(1-15D)}
\]

DeMorgan’s laws:

\[
(X + Y + Z + \ldots)' = X'Y'Z' \ldots \quad \text{(1-16)} \\
(XYZ + \ldots)' = X' + Y' + Z' + \ldots \quad \text{(1-16D)} \\
[f(X_1, X_2, \ldots, X_m, 0, 1, +, \cdot)]' = f(X_1', X_2', \ldots, X_m', 1, 0, +, \cdot) \quad \text{(1-17)}
\]

Duality:

\[
(X + Y + Z + \ldots) = XYZ + \ldots \quad \text{(1-18)} \\
(XYZ + \ldots)' = X + Y + Z + \ldots \quad \text{(1-18D)} \\
[f(X_1, X_2, \ldots, X_m, 0, 1, +, \cdot)] = f(X_1', X_2', \ldots, X_m', 1, 0, +, \cdot) \quad \text{(1-19)}
\]

Theorem for multiplying out and factoring:

\[
(X + Y)(X + Z) = XZ + XY \quad \text{(1-20)} \\
XY + X'Z = (X + Z)(X' + Y) \quad \text{(1-20D)}
\]

Consensus theorem:

\[
XY + Y'Z + X'Z = XZ + X'Z \quad \text{(1-21)} \\
(X + Y)'(X' + Z)(Y' + Z) = (X + Y)(X' + Z) \quad \text{(1-21D)}
\]

1.2 Boolean Algebra with Exclusive OR

\[
X \oplus 1 = X' \\
X \oplus 0 = X \\
X \oplus X = 0 \\
X \oplus X' = 1 \\
X \oplus Y = Y \oplus X \quad \text{(Commutative law)} \\
(X \oplus Y) \oplus Z = X \oplus (Y \oplus Z) \\
X(Y \oplus Z) = XY \oplus XZ \quad \text{(Distributive law)} \\
(X \oplus Y)' = X \oplus Y' = Y \oplus X = XY + X'Y'
\]
1.3 Karnaugh Maps

- Convenient way to simplify logic functions of 3, 4, 5, (6) variables
- Four-variable K-map
  - Each square
    - 1
    - 0
    - d
  - adjacent cells

1.3 Karnaugh Maps - Examples

<table>
<thead>
<tr>
<th>CD</th>
<th>00</th>
<th>01</th>
<th>11</th>
<th>10</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>0</td>
<td>4</td>
<td>12</td>
<td>8</td>
</tr>
<tr>
<td>01</td>
<td>1</td>
<td>5</td>
<td>13</td>
<td>9</td>
</tr>
<tr>
<td>11</td>
<td>3</td>
<td>7</td>
<td>15</td>
<td>11</td>
</tr>
<tr>
<td>10</td>
<td>2</td>
<td>6</td>
<td>14</td>
<td>10</td>
</tr>
</tbody>
</table>
1.3 Karnaugh Maps - Sum of Products

• Function consists of a sum of ________________

• Prime implicant

  ______________________________________________________________________
  ______________________________________________________________________
  ______________________________________________________________________

• Prime implicant is ______________ if it contains a 1 that is not contained in any other prime implicant

1.3 Karnaugh Maps - Prime Implicant Selection

• Two minimum forms

  $f =$

  $f =$
1.3 Karnaugh Maps - Selection Procedure

1. Choose a 1 (______) that has not been covered yet
2. Find all _s and __s adjacent to that minterm. (Check the n adjacent squares on an n-variable map.)
3. If a single term covers the minterm and all the adjacent 1s and ds, then that term is an ________ prime implicant, so select that term.
4. Repeat steps 1, 2, 3 until all essential prime implicants have been chosen
5. Find a ________ set of prime implicants that cover the remaining 1s on the map. If there is more than one such set, choose a set with a ______________

1.4 Designing with NAND and NOR Gates

• Implementation of NAND and NOR gates is easier than that of AND and OR gates (e.g., CMOS)

NAND:

A
B
C

NOR:

A
B
C

C

C
1.4 Designing with NAND and NOR Gates (continued)

- Any logic function can be realized using only NAND or NOR gates -
  - 1:
  - 0:
  - a':
  - ab:
  - a+b:

1.4 Designing with NAND and NOR Gates - Conversion to NOR Gates

- Start with POS (______________)
  - circle 0s in K-maps
- Find network of OR and AND gates

(a) AND-OR network

(b) Equivalent NOR-gate network
1.4 Designing with NAND and NOR Gates - Conversion to NAND Gates

- Start with SOP (Sum of Products)
  - circle 1s in K-maps
- Find network of OR and AND gates

(a) AND OR network

(b) First step in NAND conversion

(c) Completed conversion

1.13 Tristate Logic and Busses

- Four kinds of tristate buffers
  - B is a control input used to enable and disable the output

(a) (b) (c) (d)
1.6 Flip-Flops and Latches – Sequential Networks

- Have memory (state)
  - Present state depends not only on the __________, but also on all previous inputs (history)
  - Future state depends on the __________ and ________

```
\begin{align*}
Z(t) &= F(X(t), Q(t)) \\
Q(t^+) &= G(X(t), Q(t))
\end{align*}
```

Flip-flops are commonly used as storage devices: D-FF, JK-FF, T-FF
1.6 Flip-Flops and Latches - Clocked D Flip-Flop with Rising-edge Trigger

The next state in response to the ______ of the clock is equal to the ______ input before the rising edge.

<table>
<thead>
<tr>
<th>D</th>
<th>Q</th>
<th>Q⁺</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

Q⁺ = D

1.6 Flip-Flops and Latches - Clocked JK Flip-Flop

<table>
<thead>
<tr>
<th>J</th>
<th>K</th>
<th>Q</th>
<th>Q⁺</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

JK = 00 =>
JK = 10 =>
JK = 01 =>
JK = 11 =>

Next state
# 1.6 Flip-Flops and Latches – Clocked T Flip-Flop

**Next state**

$$T = 1 \Rightarrow Q^+ = Q$$

$$T = 0 \Rightarrow Q^+ = \overline{Q}$$

<table>
<thead>
<tr>
<th>$T$</th>
<th>$Q$</th>
<th>$Q^+$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

# 1.6 Flip-Flops and Latches – S-R Latch

$$Q^+ = S + R'Q$$

<table>
<thead>
<tr>
<th>$S$</th>
<th>$R$</th>
<th>$Q$</th>
<th>$Q^+$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>-</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-</td>
</tr>
</tbody>
</table>
1.6 Flip-Flops and Latches – Transparent D Latch

<table>
<thead>
<tr>
<th>G</th>
<th>D</th>
<th>Q</th>
<th>Q⁺</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

Q⁺ = DG + G'Q + (DQ)
1.7 Mealy Sequential Network Design – General Model of Mealy Sequential Machine

(1) X inputs are changed to a new value
(2) After a delay, the Z outputs and next state appear at the output of CN
(3) The next state is clocked into the state register and the state changes

1.7 Mealy Sequential Network Design - 8421 BCD to Excess3 BCD Code Converter Example

<table>
<thead>
<tr>
<th>X (inputs)</th>
<th>Z (outputs)</th>
</tr>
</thead>
<tbody>
<tr>
<td>t3 t2 t1 t0</td>
<td>t3 t2 t1 t0</td>
</tr>
<tr>
<td>0 0 0 0</td>
<td>0 0 1 1</td>
</tr>
<tr>
<td>0 0 0 1</td>
<td>0 1 0 0</td>
</tr>
<tr>
<td>0 0 1 0</td>
<td>0 1 0 1</td>
</tr>
<tr>
<td>0 0 1 1</td>
<td>0 1 1 0</td>
</tr>
<tr>
<td>0 1 0 0</td>
<td>0 1 1 1</td>
</tr>
<tr>
<td>0 1 0 1</td>
<td>1 0 0 0</td>
</tr>
<tr>
<td>0 1 1 0</td>
<td>1 0 0 1</td>
</tr>
<tr>
<td>0 1 1 1</td>
<td>1 0 1 0</td>
</tr>
<tr>
<td>1 0 0 0</td>
<td>1 0 1 1</td>
</tr>
<tr>
<td>1 0 0 1</td>
<td>1 1 0 0</td>
</tr>
</tbody>
</table>
1.7 Mealy Sequential Network Design – State Graph and Table for Code Converter

![State Graph Image]

1.9 Equivalent States and Reduction of State Tables – Code Converter Example

I. States which have the same next state (NS) for a given input should be given adjacent assignments (look at the columns of the state table).

II. States which are the next states of the same state should be given adjacent assignments (look at the rows).

III. States which have the same output for a given input should be given adjacent assignments.

I. \((1,2)\) \((3,4)\) \((5,6)\) (in the \(X=1\) column, \(S_1\) and \(S_2\) both have NS \(S_4\), in the \(X=0\) column, \(S_3\) & \(S_4\) have NS \(S_5\), and \(S_5\) & \(S_6\) have NS \(S_3\)).

II. \((1,2)\) \((3,4)\) \((5,6)\) (\(S_1\) & \(S_2\) are NS of \(S_0\); \(S_3\) & \(S_4\) are NS of \(S_1\), and \(S_5\) & \(S_6\) are NS of \(S_4\)).

III. \((0,1,4,6)\) \((2,3,5)\)
1.9 Equivalent States and Reduction of State Tables – Code Converter Transition Table

<table>
<thead>
<tr>
<th>NS</th>
<th>Z</th>
<th>Q1(Q2Q3)</th>
<th>Z</th>
</tr>
</thead>
<tbody>
<tr>
<td>S0</td>
<td>X = 0 X = 1</td>
<td>X = 0 X = 1</td>
<td>X = 0 X = 1</td>
</tr>
<tr>
<td>S1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S4</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S6</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

1.9 Equivalent States and Reduction of State Tables – Code Converter K-maps

![K-maps](image-url)
1.9 Equivalent States and Reduction of State Tables – Code Converter Realization

- Code converter
  - \( X = 0010\_1001 \Rightarrow Z = 1110\_0011 \)

1.10 Sequential Network Timing – Code Converter

- Code converter
  - \( X = 0010\_1001 \Rightarrow Z = 1110\_0011 \)
1.10 Sequential Network Timing – Timing Diagram for Code Converter

Timing diagram assuming a propagation delay of 10 ns for each flip-flop and gate
(State has been replaced with the state of three flip-flops)

1.11 Setup and Hold Times – D Flip-Flop

- For a real D-FF
  - D input must be stable for a certain amount of time before the active edge of clock cycle
  - D input must be stable for a certain amount of time after the active edge of the clock
- Propagation time: from the time the clock changes to the time the output changes

Manufacturers provide minimum $t_{su}$, $t_{hp}$, and maximum $t_{plh}$, $t_{phl}$
1.11 Setup and Hold Times –
Maximum Clock Frequency Calculation

- $t_{c\ max}$ - Max propagation delay through the combinational network
- $t_{p\ max}$ - Max propagation delay from the time the clock changes to the flip-flop output changes \{ = max($t_{plh}, t_{phl}$)\}
- $t_{ck}$ - Clock period

$t_{c\ max} + t_{p\ max} \leq t_{ck} - t_{su}$
$t_{ck} \geq t_{c\ max} + t_{p\ max} + t_{su}$

Example:

$t_{p\ max} = 15 \text{ ns}$, $t_{su} = 5 \text{ ns}$, $t_{gate} = 15 \text{ ns}$

$t_{ck} = 2 \times 15 + 15 + 5 = 50 \text{ ns}$

$f_{\ max} = \frac{1}{50 \text{ ns}} = 20 \text{ MHz}$

---

1.11 Setup and Hold Times –
Hold Time Violations (from Q)

- Occurs if the change in Q that is fed back through the combinational network causes input D to change too soon after the clock edge

Hold time is satisfied if:

$t_{p\ min} + t_{c\ min} \geq t_{h}$

- $t_{c\ min}$ - Min propagation delay through - the combinational network
- $t_{p\ min}$ - Min propagation delay from - the time the clock changes to - the flip-flop output changes - \{ = min($t_{plh}, t_{phl}$)\}
1.11 Setup and Hold Times – Setup Time Violations (from X)

- Occurs if the change in X that is fed back through the combinational network causes input D to change too soon after the clock edge.

\[ t_x \geq t_{cx,\text{max}} + t_{su} \]

- Max propagation delay through the combinational network from input X (or any other input) to the flip-flop input D.

1.11 Setup and Hold Times – Hold Time Violations (from X)

- Occurs if the change in X that is fed back through the combinational network causes input D to change too soon after the clock edge.

Make sure that X does not change too soon after the clock.

If X changes at time \( t_y \) after the active edge, hold time is satisfied if

\[ t_y \geq t_{h} - t_{cx,\text{min}} \]

- Min propagation delay through the combinational network from input X (or any other input) to the flip-flop input D.
Synchronous Design

- Use a clock to synchronize the operation of all flip-flops, registers, and counters in the system
  - all changes occur immediately following the active clock edge
  - clock period must be long enough so that all changes flip-flops, registers, counters will have time to stabilize before the next active clock edge
- Typical design: Control section + Data Section

Synchronous Design Example

- Data section  // s = n*(n+a) //
  R1=n, R2=a // R1=s
- Design flowchart for SMUL operation
- Design Control section
  - S0 S1 F
    0 0 B
    0 1 B – C0
    1 0 B + C0
    1 1 A + B
Moore Sequential Networks

Outputs depend only on present state!

\[ X = x_1 x_2 \ldots x_n \]
\[ Q = Q_1 Q_2 \ldots Q_k \]
\[ Z = z_1 z_2 \ldots z_m \]

\[ Z(t) = F(Q(t)) \]
\[ Q(t^+) = G(X(t), Q(t)) \]

General Model of Moore Sequential Machine

Outputs depend only on present state!

\[ X = x_1 x_2 \ldots x_n \]
\[ Q = Q_1 Q_2 \ldots Q_k \]
\[ Z = z_1 z_2 \ldots z_m \]

\[ Z(t) = F(Q(t)) \]
\[ Q(t^+) = G(X(t), Q(t)) \]
Code Converter: Moore Machine

Moore Machine: State Table

<table>
<thead>
<tr>
<th>PS</th>
<th>NS</th>
<th>Z</th>
<th>X=0</th>
<th>X=1</th>
</tr>
</thead>
<tbody>
<tr>
<td>S0</td>
<td>S1</td>
<td>S2</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>S1</td>
<td>S3</td>
<td>S4</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>S2</td>
<td>S4</td>
<td>S5</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>S3</td>
<td>S6</td>
<td>S7</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>S4</td>
<td>S7</td>
<td>S8</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>S5</td>
<td>S7</td>
<td>S8</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>S6</td>
<td>S9</td>
<td>S10</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>S7</td>
<td>S9</td>
<td>S10</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>S8</td>
<td>S10</td>
<td>-</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>S9</td>
<td>S1</td>
<td>S2</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>S10</td>
<td>S1</td>
<td>S2</td>
<td>1</td>
<td></td>
</tr>
</tbody>
</table>
Moore Machine Timing

- X = 0010_1001 => Z = 1110_0011

State Assignments

<table>
<thead>
<tr>
<th>Ps</th>
<th>Ns</th>
<th>Z</th>
</tr>
</thead>
<tbody>
<tr>
<td>X=0</td>
<td>X=1</td>
<td></td>
</tr>
<tr>
<td>S0</td>
<td>S1</td>
<td>S2</td>
</tr>
<tr>
<td>S1</td>
<td>S3</td>
<td>S4</td>
</tr>
<tr>
<td>S2</td>
<td>S4</td>
<td>S5</td>
</tr>
<tr>
<td>S3</td>
<td>S6</td>
<td>S7</td>
</tr>
<tr>
<td>S4</td>
<td>S7</td>
<td>S8</td>
</tr>
<tr>
<td>S5</td>
<td>S7</td>
<td>S8</td>
</tr>
<tr>
<td>S6</td>
<td>S9</td>
<td>S10</td>
</tr>
<tr>
<td>S7</td>
<td>S9</td>
<td>S10</td>
</tr>
<tr>
<td>S8</td>
<td>S10</td>
<td></td>
</tr>
<tr>
<td>S9</td>
<td>S1</td>
<td>S2</td>
</tr>
<tr>
<td>S10</td>
<td>S1</td>
<td>S2</td>
</tr>
</tbody>
</table>

I. States which have the same next state (Ns) for a given input should be given adjacent assignments (look at the columns of the state table).

II. States which are the next states of the same state should be given adjacent assignments (look at the rows).

III. States which have the same output for a given input should be given adjacent assignments.

Rule I: (S0, S9, S10), (S4, S5), (S6, S7)
Rule II: (S1, S2), (S3, S4), (S4, S5), (S6, S7), (S7, S8), (S9, S10)
Rule III: (S0, S2, S4, S6, S8, S9) (S1, S3, S5, S7, S10)
## Chapter 1

### State Assignments

<table>
<thead>
<tr>
<th>PS</th>
<th>NS</th>
<th>Z</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>X=0</td>
<td></td>
</tr>
<tr>
<td>Q</td>
<td>Q</td>
<td>Q</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>X=1</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Q</td>
<td>Q</td>
<td>Q</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Logic Reduction

\[ Q_A^+ = Q_D + Q_A' Q_B Q_C \]

\[ Q_B^+ = Q_C' + Q_B' Q_D + X' Q_A' Q_D + Q_A' Q_B' + X Q_A \]
Logic Reduction

\[ Q_C^+ = X'Q_D + X'Q_A + Q_A'Q_C + Q_A'Q_B + Q_BQ_D \]

\[ Q_D^+ = X'Q_A + Q_A'Q_BQ_C \]

Logic Reduction

\[ Z = Q_A'Q_BQ_C' + Q_AQ_BQ_C + Q_C'Q_D + Q_BQ_D \]
Electrical and Computer Engineering

Chapter 1

Altera Logic Implementation

• \( X = 0010_1001 \) => \( Z = 1110_0011 \)

Reset Portion

Altera Simulation

• \( X = 0010_1001 \) => \( Z = 1110_0011 \)
Moore Machine: Another Example – NRZ to Manchester Converter

- Coding schemes for serial data transmission
  - NRZ: ______________
  - NRZI: ______________
    - 0 in input sequence – ______________
    - 1 in input sequence – ______________
  - RZ: return-to-zero
    - 0 – ___________; 1 – ______________
  - Manchester

NRZ-to-Manchester Converter: Timing

NRZ data $\rightarrow$ Conversion Network $\rightarrow$ Manchester data
1.12 Synchronous Design: Control Signal Timing Issues

- Change in state of the flip-flops in control section determined by the propagation delay
- Time control signals change depend upon this FF propagation delay and combinational network delay
- Glitches and spikes may occur in the control signals due to hazards in the network
- Noise may be introduced on the control signals by changing signals in another part of the circuit
- **THIS MEANS THAT THERE IS A TIME INTERVAL AFTER THE ACTIVE EDGE OF THE CLOCK WHERE THE STATE OF THE CONTROL SIGNAL IS NOT KNOWN AND MAY NOT BE STABLE**
1.12 Synchronous Design: Timing Chart for System with Falling-edge Devices

![Timing Chart for Falling-edge Devices](image1)

(a) Falling-edge device

1.12 Synchronous Design: Timing Chart for System with Rising-edge Devices

![Timing Chart for Rising-edge Devices](image2)

Figure 1-35 Incorrect Design

Figure 1-36 Correct Design

(a) with gated clock

(b) With enable
Principles of Synchronous Design

- **Method**
  - All clock inputs to flip-flops, registers, counters, etc., are driven directly from the system clock or from the clock ANDed with a control signal

- **Result**
  - All state changes occur immediately following the active edge of the clock signal

- **Advantage**
  - All switching transients, switching noise, etc., occur between the clock pulses and have no effect on system performance

---

Asynchronous Design

- **Disadvantage - More difficult**
  - Problems
    - Race conditions:
    - Hazards
  - Special design techniques are needed to cope with races and hazards

- **Advantages = Disadvantages of Synchronous Design**
  - In high-speed synchronous design propagation delay in wiring is significant => clock signal must be carefully routed so that it reaches all devices at essentially same time
  - Inputs are not synchronous with the clock – need for synchronizers
  - Clock cycle is determined by the worst-case delay
Equivalent States

- Two states are equivalent if we cannot tell them apart by observing input and output sequences.

\[ \text{State Equivalence Theorem} \]

- Two states are equivalent if and only if for every single input, the outputs are the same and the next states are equivalent.
Implication Table Method

1. Construct a chart that contains a square for each pair of states.
2. Compare each pair in the state table. If the outputs associated with states i and j are different, place an X in square i-j to indicate that i!=j.
   If outputs are the same, place the implied pairs in square i-j.
   If outputs and next states are the same (or i-j implies only itself), i==j.
3. Go through the implication table square by square.
   If square i-j contains the implied pair m-n, and square m-n contains X, then i!=j, and place X in square i-j.
4. If any Xs were added in step 3, repeat step 3 until no more Xs are added.
5. For each square i-j that does not contain an X, i==j.

State Table Reduction

<table>
<thead>
<tr>
<th>Present State</th>
<th>Next State</th>
</tr>
</thead>
<tbody>
<tr>
<td>X = 0, 1</td>
<td>X = 0, 1</td>
</tr>
<tr>
<td>a</td>
<td>c, f</td>
</tr>
<tr>
<td>b</td>
<td>d, e</td>
</tr>
<tr>
<td>c</td>
<td>a, g</td>
</tr>
<tr>
<td>d</td>
<td>b, g</td>
</tr>
<tr>
<td>e</td>
<td>b</td>
</tr>
<tr>
<td>f</td>
<td>a</td>
</tr>
<tr>
<td>g</td>
<td>c, g</td>
</tr>
<tr>
<td>h</td>
<td>e, f</td>
</tr>
</tbody>
</table>

1) States a and h have the same next states and outputs (when X=0 and X=1)
2) Eliminate h from the table and replace with a
3) States a and b have the same output => they are same iff c==d and f==e.
   We say c-d and e-f are implied pairs for a-b.
   To keep track of the implied pairs we make an implication chart.
State Table Reduction

<table>
<thead>
<tr>
<th>Present State</th>
<th>Next State</th>
<th>Present Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>X = 0</td>
<td>I</td>
<td>X = 0</td>
</tr>
<tr>
<td>a</td>
<td>c</td>
<td>f</td>
</tr>
<tr>
<td>b</td>
<td>d</td>
<td>e</td>
</tr>
<tr>
<td>c</td>
<td>l</td>
<td>a</td>
</tr>
<tr>
<td>d</td>
<td>b</td>
<td>g</td>
</tr>
<tr>
<td>e</td>
<td>a</td>
<td>b</td>
</tr>
<tr>
<td>f</td>
<td>f</td>
<td>a</td>
</tr>
<tr>
<td>g</td>
<td>c</td>
<td>g</td>
</tr>
<tr>
<td>h</td>
<td>e</td>
<td>i</td>
</tr>
</tbody>
</table>

4) Make another pass through the chart. E-g cell contains c-e and b-g; since c-e cell contains x, c!=e => e!=g (put X).

5) Repeat the step 4 until no additional squares are X-ed. (Put X in f-g, a-c, a-d, b-c, b-d squares).

6) The remaining squares indicate equivalent state pairs => a==b, c==d, e==f.

Hazards in Combinational Networks

- What are hazards in Combinational Networks?
  - Unwanted switching transients at the output (glitches)
- Example
  - ABC = 111, B changes to 0
  - Assume each gate has propagation delay of 10ns
Hazards in Combinational Networks

- Occur when different paths from input to output have different propagation delays
- Static 1-hazard
  - a network output momentarily go to 0 when it should remain a constant 1
- Static 0-hazard
  - a network output momentarily go to 1 when it should remain a constant 0
- Dynamic hazard
  - if an output change three or more times, when the output is supposed to change from 0 to 1 (1 to 0)

Hazards in Combinational Circuits

Why do we care about hazards?

- Combinational networks
  - don’t care – the network will function correctly
- Synchronous sequential networks
  - don’t care - the input signals must be stable within setup and hold time of flip-flops
- Asynchronous sequential networks
  - hazards can cause the network to enter an incorrect state
    - circuitry that generates the next-state variables must be hazard-free
- Power consumption is proportional to the number of transitions
**Detection of Static 1 and 0 Hazards**

- We only consider hazards which occur when a single input variable changes.
- Analysis begins by determining the Transient Output Function, $F^3$, which represents the behavior of the network under transient conditions.

The Transient Output Function, $F^3$, is determined in the same way as ordinary (steady-state) output Functions except each variable and its complement are treated as independent variables because under transient conditions these variables may assume the same values.

- Boolean manipulation of $F^3$ involves the use of theorems that do not involve a variable and its complement on the same side of the expression.

Allowed Theorems: Associate Law, Distributive Laws, DeMorgan's Law, $XX = X$, $X + XY = X$, etc.

---

**Hazards in Combinational Circuits**

To avoid hazards:
- every pair of adjacent 1s should be covered by a 1-term

$$f = AB' + BC$$

$$f = AB' + BC + AC$$
Detection of Static 1 Hazards

Each product term of $F^t$ is called a 1-term.
The 1-terms of $F^t$ are plotted on a Karnaugh map
If two 1’s in adjacent squares on the map of $F^t$ are covered by the same 1-term, changing the input to the network between the corresponding two input states cannot cause a hazard.
If two 1’s in adjacent squares on the map are not covered by a single 1-term, a hazard is present.

$$F^t = abc + (a+d)(a' + c') = abc + aa' + ac' + a'd + c'd$$
Detection of Static 0 Hazards

- Each sum term of $F^t$ is called a 0-term.
- The 0-terms of $F^t$ are plotted on a Karnaugh map.
- If two 0's in adjacent squares on the map of $F^t$ are covered by the same 0-term, changing the input to the network between the corresponding two input states cannot cause a hazard.
- If two 0's in adjacent squares on the map are not covered by a single 0-term, a hazard is present.

\[
F^t = abc + (a+d)(a'+c') = (a+d)(a'+a'+c')(b+a'+c')(c+a'+c')
\]
Design of Hazard Free Networks

To design a network that is free of static and dynamic hazards, the following procedure may be used:

1. Find a sum-of-products expression ($F'$) for the output in which every pair of adjacent 1s is covered by a 1-term. (The sum of all prime implicants will always satisfy this condition.) A two-level AND-OR network based on this $F'$ will be free of 1-, 0-, and dynamic hazards.

2. If a different form of network is desired, manipulate $F'$ to the desired form by simple factoring, DeMorgan's laws, etc. Treat each $x_i$ and $x'_i$ as independent variables to prevent introduction of hazards. Alternatively, you can start with a product-of-sums expression in which every pair of adjacent 0s is covered by a 0-term.