Introduction to Digital Circuits

Module: SE1EB5  Computer and Internet Technologies

Lecturer: James Grimbleby
URL: http://www.elec.rdg.ac.uk/jbg.html
email: j.b.grimbleby@reading.ac.uk

Number of Lectures: 10

Recommended text book:
Alan Clements:
The Principles of Computer Hardware (3rd edition)
Oxford University Press 1999
ISBN 019856453-8
Introduction to Digital Circuits

The Principles of Computer Hardware

Third edition

Alan Clements

Includes free CD-ROM

Price: £25 (approx)

J. B. Grimbleby    School of Systems Engineering: Electronic Engineering    Slide 2
Engine Management System

- Engine Speed
- Crank Angle
- λ Sensor
- Throttle
- Knock detection
- Air Temperature
- Block Temperature
- Security Device
- Injectors
- Ignition
- Valve Timing
- Warning Indicators
Analogue vs digital; binary codes; error-detecting and error-correcting codes; Hamming distance

Boolean algebra; operations NOT, AND, OR; truth tables; Boolean identities and theorems; Boolean functions; Logic gates; combinational logic systems; analysis of combinational systems; duality

Karnaugh maps; Boolean simplification using K-maps; sum-of-products and product-of-sums forms; incompletely-specified Boolean functions; implementation using logic gates
Syllabus

Universal logic gates; simple implementation method; formal method for NAND implementation; formal method for NOR implementation

Hazards in combinational logic systems; static and dynamic hazards; origin of static hazards in 2-level NAND systems; origin of dynamic hazards; design of hazard-free NAND and NOR systems

Other types of logic gate: EXOR gates; MSI combinational functions: 7-segment, decoders and encoders, multiplexers; programmable logic
Syllabus

Sequential logic systems; RS Flip-flops; D-latch; edge-triggered flip-flops; edge-triggered D-type flip-flop

Asynchronous counters; synchronous counters; shift registers; design of synchronous counters using edge-triggered D-type flip-flops

Edge-triggered JK flip-flops; asynchronous counters, shift registers

Types of logic gate: TTL + variants, CMOS, ECL; comparisons of gate types; decoupling.
Analogue vs Digital

Analogue signals represent physical quantities by a simple proportional relationship.

The precision of analogue signals is limited by noise/drift relative to the maximum signal and by non-linearity.

Digital signals use numbers to represent physical quantities.

There is in principle no limit to the precision of digital signals.

Digital systems use binary numbers, rather than decimal, to define digital values.
Digital electronics uses binary values: 0 or 1

These are represented in digital circuits by voltages or currents, for example:

- Logic 0: 0 V → 0.8 V
- Logic 1: 2.0 V → 5.0 V

Binary digits are called *bits*

Bits are normally processed in groups: a group of binary digits is called a *binary word*, or more simply, a *word*
Binary Codes

Digital words can be transmitted / processed in serial or parallel form:

5-bit word - serial data 11010:

```
1 1 0 1 0
```

5-bit word - parallel data 11010:

```
1
1
1
0
1
0
```
Binary Codes

Words represent information by the use of binary codes

Examples of binary codes:

- Natural binary code
- Signed binary code
- Floating-point codes
- Gray code
- Alpha-numeric codes

Extra bits can be added to any of these codes to make them error-detecting or error-correcting
An $n$-bit word:

$$d_{n-1}, \ldots, d_2, d_1, d_0$$

where $d_r$ are the individual bits (value 0 or 1), represents the positive integer value:

$$2^{n-1}d_{n-1} + \ldots + 2^2d_2 + 2^1d_1 + 2^0d_0$$

So the 6-bit natural binary word 010110 represents the integer value:

$$2^5.0 + 2^4.1 + 2^3.0 + 2^2.1 + 2^1.1 + 2^0.0$$

$$= 16 + 4 + 2 = 22$$
Natural Binary Code

Natural binary is the most efficient code in the sense that it uses the minimum number of bits.

It is easy to perform arithmetic operations on natural binary code.

8-bit natural binary code represents: $0 \rightarrow 255$

16-bit natural binary code represents: $0 \rightarrow 65535$

32-bit natural binary code represents: $0 \rightarrow 4295M$

In general an $n$-bit natural binary code represents: $0 \rightarrow (2^n-1)$
### 4-Bit Natural Binary Code

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Natural binary</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0000</td>
</tr>
<tr>
<td>1</td>
<td>0001</td>
</tr>
<tr>
<td>2</td>
<td>0010</td>
</tr>
<tr>
<td>3</td>
<td>0011</td>
</tr>
<tr>
<td>4</td>
<td>0100</td>
</tr>
<tr>
<td>5</td>
<td>0101</td>
</tr>
<tr>
<td>6</td>
<td>0110</td>
</tr>
<tr>
<td>7</td>
<td>0111</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Natural binary</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>1000</td>
</tr>
<tr>
<td>9</td>
<td>1001</td>
</tr>
<tr>
<td>10</td>
<td>1010</td>
</tr>
<tr>
<td>11</td>
<td>1011</td>
</tr>
<tr>
<td>12</td>
<td>1100</td>
</tr>
<tr>
<td>13</td>
<td>1101</td>
</tr>
<tr>
<td>14</td>
<td>1110</td>
</tr>
<tr>
<td>15</td>
<td>1111</td>
</tr>
</tbody>
</table>
In many applications it is necessary to represent negative as well as positive numbers.

For example: audio signals, bank account.

The most common (and most satisfactory) representation for signed integers is 2s-complement binary.

The operations required to add or subtract 2s-complement numbers are identical to those for natural binary.
2s-Complement Binary Code

To obtain the 2s-complement representation of a negative number:

1. Obtain natural binary representation of its magnitude
2. Complement (0 → 1, 1 → 0)
3. Add 1

Example: -5

<table>
<thead>
<tr>
<th>Natural binary</th>
<th>Complement</th>
<th>Add 1</th>
</tr>
</thead>
<tbody>
<tr>
<td>000101</td>
<td>111010</td>
<td>111011</td>
</tr>
</tbody>
</table>

5
The sign of a 2s-complement number is determined by the most-significant (left-most) bit

8-bit signed binary code represents: $-128 \rightarrow +127$

16-bit signed binary code represents: $-32768 \rightarrow +32767$

32-bit signed binary code represents: $-2^{147}M \rightarrow +2^{147}M$

$n$-bit signed binary code represents: $-2^{n-1} \rightarrow +(2^{n-1}-1)$
Hamming Distance

The Hamming distance between two code words is the number of bits that must change to convert one code word into the other.

\[
\begin{array}{ccccccc}
1 & 0 & 1 & 1 & 0 & 0 & 1 & 1 \\
1 & 0 & 0 & 1 & 1 & 0 & 1 & 1
\end{array}
\]

Hamming distance = 2

The minimum distance of a code is the minimum Hamming distance between any pair of words belonging to the code.

An \( n \)-distance code is a code sequence where the Hamming distance between consecutive code words is \( n \).
Gray Code

Digital position transducer coded using natural binary:

Position = 1001 (binary) = 8 + 1 (decimal) = 9
Gray Code

This should work in principle, but fails in practice because the bits do not change simultaneously:

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th>1</th>
<th>1</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Indicated position: 7 3 11 10 8

Thus spurious positions of 3, 11, and 10 are generated between 7 and 8

This problem is overcome by using Gray code
## 4-Bit Gray Code

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Gray code</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0000</td>
</tr>
<tr>
<td>1</td>
<td>0001</td>
</tr>
<tr>
<td>2</td>
<td>0011</td>
</tr>
<tr>
<td>3</td>
<td>0010</td>
</tr>
<tr>
<td>4</td>
<td>0110</td>
</tr>
<tr>
<td>5</td>
<td>0111</td>
</tr>
<tr>
<td>6</td>
<td>0101</td>
</tr>
<tr>
<td>7</td>
<td>0100</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Gray code</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>1100</td>
</tr>
<tr>
<td>9</td>
<td>1101</td>
</tr>
<tr>
<td>10</td>
<td>1111</td>
</tr>
<tr>
<td>11</td>
<td>1110</td>
</tr>
<tr>
<td>12</td>
<td>1010</td>
</tr>
<tr>
<td>13</td>
<td>1011</td>
</tr>
<tr>
<td>14</td>
<td>1001</td>
</tr>
<tr>
<td>15</td>
<td>1000</td>
</tr>
</tbody>
</table>
Digital position transducer coded using Gray code (unit-distant):

- Infra-red detectors (×4)
- Infra-red emitters (×4)

Position = 1101 = 9
Alpha-Numeric Codes

ASCII (American Standard Code for Information Interchange) is a 7-bit code representing alpha-numeric characters.

The code includes control characters, punctuation, symbols, digits, letters:

- `0000000: nul`  `0001101: cr`
- `0011011: esc`  `0101011: +`
- `0110000: 0`  `0111001: 9`
- `1000001: A`  `1011010: Z`
- `1100001: a`  `1111010: z`
- `1111111: del`
Error-Detecting Codes

An extra bit added to each binary word allows single errors to be detected (but not corrected)

This bit is called the parity bit and is chosen to make the total number of 1s even (even parity) or odd (odd parity)

A single error will lead to the number of 1s changing from odd to even, or from even to odd; the change in parity then indicates an error

Parity codes are redundant, and have a minimum Hamming distance of 2
Error-Detecting Codes

Error-detecting codes have a minimum Hamming distance of 2:
## Natural Binary Code / Even Parity

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Even Parity</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>00000</td>
</tr>
<tr>
<td>1</td>
<td>10001</td>
</tr>
<tr>
<td>2</td>
<td>10010</td>
</tr>
<tr>
<td>3</td>
<td>00011</td>
</tr>
<tr>
<td>4</td>
<td>10100</td>
</tr>
<tr>
<td>5</td>
<td>00101</td>
</tr>
<tr>
<td>6</td>
<td>00110</td>
</tr>
<tr>
<td>7</td>
<td>10111</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Even Parity</th>
</tr>
</thead>
<tbody>
<tr>
<td>8</td>
<td>11000</td>
</tr>
<tr>
<td>9</td>
<td>01001</td>
</tr>
<tr>
<td>10</td>
<td>01010</td>
</tr>
<tr>
<td>11</td>
<td>11011</td>
</tr>
<tr>
<td>12</td>
<td>01100</td>
</tr>
<tr>
<td>13</td>
<td>11101</td>
</tr>
<tr>
<td>14</td>
<td>11110</td>
</tr>
<tr>
<td>15</td>
<td>01111</td>
</tr>
</tbody>
</table>
### Natural Binary Code / Odd Parity

<table>
<thead>
<tr>
<th>Decimal</th>
<th>Odd Parity</th>
<th>Decimal</th>
<th>Odd Parity</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>10000</td>
<td>8</td>
<td>01000</td>
</tr>
<tr>
<td>1</td>
<td>00001</td>
<td>9</td>
<td>11001</td>
</tr>
<tr>
<td>2</td>
<td>00010</td>
<td>10</td>
<td>11010</td>
</tr>
<tr>
<td>3</td>
<td>10011</td>
<td>11</td>
<td>01011</td>
</tr>
<tr>
<td>4</td>
<td>00100</td>
<td>12</td>
<td>11100</td>
</tr>
<tr>
<td>5</td>
<td>10101</td>
<td>13</td>
<td>01101</td>
</tr>
<tr>
<td>6</td>
<td>10110</td>
<td>14</td>
<td>01110</td>
</tr>
<tr>
<td>7</td>
<td>00111</td>
<td>15</td>
<td>11111</td>
</tr>
</tbody>
</table>
Error-Correcting Codes

Error-detecting codes are of little value in 1-way communications systems (cannot be corrected)

If a single bit error occurs in a code with a minimum distance of 3 or greater then the error can be both detected and corrected

This is because the single error generates a new word which is distance 1 from the original word; it is still distance 2 from any other code word

Sometimes called “forward error correction”
Error-Correcting Codes

Error-correcting code with minimum Hamming distance of 3:

- Valid codeword
- Invalid codeword (1 bit error)
- Valid codeword

1 bit 3 bits
Error-Correcting Codes

Error-correcting code with minimum Hamming distance of 5:

- Valid codeword
- Invalid codeword (2 bits error)
- Valid codeword

1 bit 5 bits
## Error-Correcting Codes

<table>
<thead>
<tr>
<th>Decimal</th>
<th>E-C code</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>000000</td>
</tr>
<tr>
<td>1</td>
<td>011001</td>
</tr>
<tr>
<td>2</td>
<td>110010</td>
</tr>
<tr>
<td>3</td>
<td>101011</td>
</tr>
<tr>
<td>4</td>
<td>101100</td>
</tr>
<tr>
<td>5</td>
<td>110101</td>
</tr>
<tr>
<td>6</td>
<td>011110</td>
</tr>
<tr>
<td>7</td>
<td>000111</td>
</tr>
</tbody>
</table>

Right-most 3 bits are natural binary, left-most 3 bits are error-correction

Example: 110110 is not a valid codeword

Nearest valid codeword is 110010 (decimal 2)
Error-Correcting Codes

This deliberately-damaged CD can be read without errors

J. B. Grimbleby  School of Systems Engineering: Electronic Engineering  Slide 31
Boolean Algebra

Boolean algebra is an algebra of 2-state variables

Boolean variables can have the values 0 or 1

Boolean Algebra is used to describe digital systems where the binary signals have 2 values

There are three fundamental operations in Boolean algebra: NOT, AND, OR

These are defined by the use of truth tables
Boolean Algebra

\[ \text{NOT } A \quad \text{or} \quad \overline{A} \quad \text{or} \quad A' \]

\[ \begin{array}{c|c}
A & \overline{A} \\
\hline
0 & 1 \\
1 & 0 \\
\end{array} \]

\[ \text{A AND } B \quad \text{or} \quad A.B \]

\[ \begin{array}{c|c|c}
A & B & A.B \\
\hline
0 & 0 & 0 \\
0 & 1 & 0 \\
1 & 0 & 0 \\
1 & 1 & 1 \\
\end{array} \]
Boolean Algebra

\[ A \ OR \ B \quad \text{or} \quad A + B \]

<table>
<thead>
<tr>
<th></th>
<th></th>
<th>( A + B )</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>1</td>
</tr>
</tbody>
</table>

There are other Boolean operators such as \( \oplus \) (exclusive OR) and \( \Rightarrow \) (implies), but these can be written in terms of the operators NOT, AND, OR:

\[
A \oplus B \equiv A \overline{B} + \overline{A}.B
\]
Boolean Algebra

The operations of AND and OR obey the usual laws of algebra:

**Associative laws:**

\[ A.(B.C) \equiv (A.B).C \]
\[ A + (B + C) \equiv (A + B) + C \]

**Commutative laws:**

\[ A.B \equiv B.A \]
\[ A + B \equiv B + A \]

**Distributive laws:**

\[ A.(B + C) \equiv A.B + A.C \]
\[ A + (B.C) \equiv (A + B).(A + C) \]
Proof:  $A.(B+C) \equiv A.B + A.C$

<p>| | | | | | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>$A$</td>
<td>$B$</td>
<td>$C$</td>
<td>$B+C$</td>
<td>$A.(B+C)$</td>
<td>$A.B$</td>
<td>$A.C$</td>
</tr>
<tr>
<td>---</td>
<td>---</td>
<td>---</td>
<td>---</td>
<td>---</td>
<td>---</td>
<td>---</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<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>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

$A.(B+C) = A.B + A.C$ for all combinations of the variables: thus $A.(B+C) \equiv A.B + A.C$
Boolean Identities

A number of other identities follow from the definitions of NOT, AND, OR:

\[
\begin{align*}
A + 0 & \equiv A & A.0 & \equiv 0 \\
A + 1 & \equiv 1 & A.1 & \equiv A \\
A + A & \equiv A & A.A & \equiv A \\
A + \overline{A} & \equiv 1 & A.\overline{A} & \equiv 0
\end{align*}
\]

Theorems of DeMorgan:

\[
\begin{align*}
\overline{A.B} & \equiv \overline{A} + \overline{B} \\
\overline{A + B} & \equiv \overline{A}.\overline{B}
\end{align*}
\]
## Proof of DeMorgan’s Theorems

### Table 1: Proof of DeMorgan’s Theorems for $A \cdot B$

<table>
<thead>
<tr>
<th>$A$</th>
<th>$B$</th>
<th>$A \cdot B$</th>
<th>$\overline{A \cdot B}$</th>
<th>$\overline{A}$</th>
<th>$\overline{B}$</th>
<th>$\overline{A \cdot B}$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### Table 2: Proof of DeMorgan’s Theorems for $A + B$

<table>
<thead>
<tr>
<th>$A$</th>
<th>$B$</th>
<th>$A + B$</th>
<th>$\overline{A + B}$</th>
<th>$\overline{A}$</th>
<th>$\overline{B}$</th>
<th>$\overline{A \cdot B}$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
There is no unique form for a Boolean algebraic expression. Consider the function:

\[ F = \overline{A}.(B + C + \overline{B}.\overline{C}) + A.B.(\overline{C} + D) \]

By "multiplying out" the brackets and using DeMorgan’s Theorems:

\[ F = \overline{A}.B + \overline{A}.C + \overline{A}.\overline{B}.\overline{C} + A.B.\overline{C}.\overline{D} \]

This is the *sum-of-products* standard form. An alternative standard form is the *product-of-sums*:

\[ F = (\overline{A} + B).(\overline{A} + \overline{B} + D).(\overline{A} + B + \overline{C}) \]
Algebraic Manipulation of Boolean Functions

Some simplification can be achieved by multiplying out brackets and using Boolean identities (including DeMorgan’s theorems):

\[ F = A + C.D + A.B + \overline{(C.D) + A} \]
\[ = A + C.D + A.B + \overline{C + D + A} \]
\[ = A + C.D + A.B + C.D.\overline{A} \]
\[ = A.(1 + B) + C.D.(1 + \overline{A}) \]
\[ = A.1 + C.D.1 \]
\[ = A + C.D \]

This is the simplest *sum-of-products* form for \( F \)
Algebraic Manipulation of Boolean Functions

This process does not guarantee to produce the simplest sum-of-products form.

Consider the function:

\[ F = X.Y + \overline{X}.Z + Y.Z \]

There is no obvious way of simplifying this function algebraically. Nevertheless, the simplest form of the function is:

\[ F = X.Y + \overline{X}.Z \]

Graphical methods for obtaining the simplest form will be discussed later.
Switch Logic

\[ F = A \cdot B \cdot C \]

\[ F = A + B + C \]

\[ F = A \cdot B \cdot (C + D) \]
Logic Gates

Binary signals are processed in electronic digital systems by logic gates:

- **NOT**
  \[ A \overrightarrow{\rightarrow} \bar{A} \]

- **AND**
  \[ \begin{array}{ccc} A & B & C \\ \hline \end{array} \]

- **NAND**
  \[ \begin{array}{ccc} A & B & C \\ \hline \end{array} \]

- **OR**
  \[ \begin{array}{ccc} A & B & C \\ \hline \end{array} \]

- **NOR**
  \[ \begin{array}{ccc} A & B & C \\ \hline \end{array} \]
Logic Gates
Logic Gates

Through-hole

Surface-mount
Binary values are normally represented by voltages. For example in HCT logic:

Logic 1
- Outputs: 5.0 V, 2.4 V
- Inputs: 5.0 V, 2.0 V

Logic 0
- Outputs: 0.55 V, 0.0 V
- Inputs: 0.8 V, 0.0 V

Noise immunity:
- Logic 0 = 0.25 V
- Logic 1 = 0.4 V
Combinational Logic Systems

Systems of logic gates where there is no feedback are called *combinational* logic systems.

Combinational logic systems have the property that the output or outputs depend only on the present state of the inputs.

Combinational systems can therefore be specified by a Boolean expression.

Logic systems with feedback have the property of memory and cannot be specified by a single Boolean expression.
This combinational system implements the Boolean function:

\[ F = \overline{A}.(B + C + \overline{B}.\overline{C}) + A.B.(C + D) \]
Duality

A Boolean equation remains valid when converted to its dual by changing all variables and constants to their inverses, and replacing AND by OR, and OR by AND.

For example if: \( F = \overline{A}.(B + C + \overline{B}.\overline{C}) + A.B.(\overline{C} + D) \)

or: \( F = \{\overline{A}.(B + C + \{\overline{B}.\overline{C}\})\} + \{A.B.(\overline{C} + D)\} \)

then: \( \overline{F} = \{A + (\overline{B}.\overline{C}.\{B + C\})\}.\{\overline{A} + \overline{B} + (\overline{C}.\overline{D})\} \)

or: \( \overline{F} = \{A + \overline{B}.\overline{C}.\{B + C\}\}.\{\overline{A} + \overline{B} + \overline{C}.\overline{D}\} \)
Karnaugh maps (or K-maps) are graphical representations of Boolean functions and are used to simplify Boolean expressions.

A K-map has one square for each combination of values of the variables.

1-variable K-Map:

\[
F = \overline{A}
\]

<table>
<thead>
<tr>
<th></th>
<th>0</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td></td>
<td>0</td>
</tr>
</tbody>
</table>
Karnaugh Maps

2-variable K-map:

\[ F = \overline{A} + B \]

3-variable K-map:

\[ F = C.(A + \overline{B}) \]
Karnaugh Maps

4-variable K-map:

\[ F = A + B.C.D \]

Note that adjacent columns and adjacent rows are unit-distant.
Karnaugh Maps

A complication of 3- and 4-variable maps is that they must be regarded as being wrapped around on themselves:

\[ F = \overline{B}.\overline{C} \]
\[ F = \overline{A}.\overline{B}.\overline{D} \]
\[ F = \overline{B}.\overline{D} \]
Boolean Simplification

The preferred method for simplifying Boolean expressions in 4 variables or less uses K-maps.

The first stage is to obtain the *sum-of-products* standard form using algebraic manipulation.

The function is then represented in K-map form.

Finally, the simplest form for the expression is extracted from the K-map.

To obtain the simplest *sum-of-products* form, the K-map is inspected for the largest groups first; then for progressively smaller groups.

J. B. Grimbleby School of Systems Engineering: Electronic Engineering
### Boolean Simplification

The simplest sum-of-products form for $F$ is:

$$F = \overline{A} + B.C.D$$

#### Truth Table

<table>
<thead>
<tr>
<th>A</th>
<th>B</th>
<th>C</th>
<th>D</th>
<th>F</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>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</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>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

- **Groups of 16:** none
- **Groups of 8:** $\overline{A}$
- **Groups of 4:** none
- **Groups of 2:** $B.C.D$
- **Groups of 1:** none
The simplest *sum-of-products* form for $F$:

$$F = \overline{A} + B.C.D$$

can now be implemented using a combination of AND, OR and NOT gates:
Boolean Simplification

To obtain a function $F$ in simplest product-of-sums form, the first step is to obtain $\overline{F}$ in simplest sum-of-products form:

Simplest sum-of-products form for $\overline{F}$ is:

$$\overline{F} = A.B + A.D + A.C$$
Boolean Simplification

\[ \overline{F} = A\overline{B} + A.D + A.C \]

Now use duality to obtain \( F \) in simplest \textit{product-of-sums} form:

\[ \overline{F} = (A\overline{B}) + (A.D) + (A.C) \]
\[ F = (\overline{A} + B). (\overline{A} + \overline{D}). (\overline{A} + \overline{C}) \]

OR invert and use DeMorgan’s Theorems twice to obtain \( F \) in simplest \textit{product-of-sums} form:

\[ \overline{F} = \overline{(A.B)} + \overline{(A.D)} + \overline{(A.C)} \]
\[ = (\overline{A}.\overline{B}) . (\overline{A}.\overline{D}) . (\overline{A}.\overline{C}) \]
\[ F = (\overline{A} + B). (\overline{A} + \overline{D}). (\overline{A} + \overline{C}) \]
Boolean Implementation

\[ F = (\overline{A} + B).(\overline{A} + \overline{D}).(\overline{A} + \overline{C}) \]
Incompletely-Specified Functions

It often happens that the value of a function is not specified for some combinations of the input variables.

In other words the value of the function is "don't-care" and this is represented by X.

K-maps can be used to simplify incompletely-specified functions, with the don't-care conditions being assigned either 0 or 1.

Incompletely-specified functions cannot be defined by a Boolean expression; instead a truth table is used.
Incompletely-Specified Functions

Function $F$ defined by a truth table:

<table>
<thead>
<tr>
<th>$A$</th>
<th>$B$</th>
<th>$C$</th>
<th>$D$</th>
<th>$F$</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>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</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>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>X</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>$A$</th>
<th>$B$</th>
<th>$C$</th>
<th>$D$</th>
<th>$F$</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</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>0</td>
<td>X</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>X</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<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>
<td>1</td>
</tr>
</tbody>
</table>
Incompletely-Specified Functions

Each row of the truth table corresponds to one square of the K-map:

<table>
<thead>
<tr>
<th></th>
<th>C=0</th>
<th>C=1</th>
</tr>
</thead>
<tbody>
<tr>
<td>D=0</td>
<td>0 0 1 0</td>
<td></td>
</tr>
<tr>
<td>D=1</td>
<td>1 1 X 1</td>
<td></td>
</tr>
<tr>
<td>D=0</td>
<td>1 1 1 1</td>
<td></td>
</tr>
</tbody>
</table>

Simplest *sum-of-products* form for $F$ is:

\[ F = B + C.D \]
Incompletely-Specified Functions

Simplest \textit{sum-of-products} form for $\overline{F}$ is:
\[ \overline{F} = \overline{B}.\overline{C} + \overline{B}.D \]

Simplest \textit{product -of-sums} form for $F$ is:
\[ F = (B + C).(B + D) \]
A Boolean function can be implemented by first obtaining the simplest \textit{sum-of-products} form:

$$F = B + C.D$$

The overall OR function is then implemented using an OR gate, each of the terms is implemented using AND gates, and NOT gates are used where required to invert the inputs:
Boolean Implementation

Alternatively implementation can start from the simplest *product-of-sums* form:

\[ F = (B + C).(B + D) \]

The overall AND function is then implemented using an AND gate, each of the factors is implemented using OR gates, and NOT gates are used where required to invert the inputs:
Universal Logic Gates

NAND gates:

- **NOT** \( A \)
  \[ (A.A) = \overline{A} \]

- **NOT** \( A \) with input 1
  \[ (A.1) = \overline{A} \]

- **AND** \( A, B \)
  \[ (A.B) = A.B \]

- **OR** \( A, B \)
  \[ (A.B) = A + B \]
Universal Logic Gates

NOR gates:

- **NOT**
  \[ (A + A) = \overline{A} \]

- **NOT**
  \[ (A + 0) = \overline{A} \]

- **AND**
  \[ (\overline{A} + \overline{B}) = A \cdot B \]

- **OR**
  \[ (\overline{A} + \overline{B}) = A + B \]
Implementation in NAND

1. Obtain the function in simplest *sum-of-products* form:

   \[ F = A.B + C.D.E + \ldots \]

2. Invert the function twice (thus leaving it unchanged):

   \[ F = \overline{A.B + C.D.E + \ldots} \]

3. Use DeMorgan’s theorem on lower inversion:

   \[ F = (A.B).(C.D.E).\ldots \]

4. The function can now be implemented using only NAND gates
Example:

\[ F = \overline{A} + B.C.D \]

\[ = A + B.C.D \]

\[ = A \cdot (B.C.D) \]

\[ = A \cdot (\overline{B.C.D}) \]
Design Example

The days of the week are represented by a 3-bit binary code:

<table>
<thead>
<tr>
<th>Day</th>
<th>P</th>
<th>Q</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sunday</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Monday</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Tuesday</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Wednesday</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Thursday</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Friday</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Saturday</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

The code 000 will never occur.

Design a NAND system to give 1 for the work-days, and 0 for the rest-days.
Design Example

The first stage is to construct a K-map:

\[
\begin{array}{c|c|c}
 & R=0 & R=1 \\
\hline
P=0 & & \\
Q=0 & X & 0 \\
Q=1 & 1 & 1 \\
\hline
P=1 & & \\
Q=0 & 1 & 1 \\
\end{array}
\]

Note the use of X for the unused code: 000

The simplest sum-of-products form is:

\[ F = \overline{R} + \overline{P}.Q + P.\overline{Q} \]
Design Example

\[ F = R + P.Q + P.Q \]
\[ = R \cdot (P.Q) \cdot (P.Q) \]
\[ = R \cdot (P.Q) \cdot (P.Q) \]
The numbers 0 to 15 are represented by the 4-bit natural binary code $ABCD$ ($A$ is the most-significant bit, $D$ the least-significant).

A function $F$ is required to have a value of 1 for prime numbers, and to have a value of 0 for composite (non-prime) numbers.

For the purpose of this design example the numbers 0 and 1 will be taken to be composite.

Design a combinational logic system consisting of NAND gates to implement the function $F$ of the variables $A$, $B$, $C$ and $D$. 
Design Example

The 1s on the K-map can be grouped in a different way:

\[ F = \overline{B}.C.D + \overline{A}.B.C + B.\overline{C}.D + \overline{A}.B.D \]

\[ F = \overline{B}.C.D + \overline{A}.B.C + B.\overline{C}.D + \overline{A}.C.D \]
Design Example

\[ F = \overline{B.C.D} + \overline{A.B.C} + B.C.D + \overline{A.B.D} \]

\[ \overline{B.C.D} + \overline{A.B.C} + B.C.D + \overline{A.B.D} \]

\[ (B.C.D) \cdot (A.B.C) \cdot (B.C.D) \cdot (A.B.D) \]
Implementation in NOR

1. Obtain the function in simplest product-of-sums form:

\[ F = (A + B).(B + C + D) \ldots \]

2. Invert the function twice (thus leaving it unchanged):

\[ F = (A + B).(B + C + D) \ldots \]

3. Use DeMorgan’s theorem on lower inversion:

\[ F = (A + B) + (B + C + D) + \ldots \]

4. The function can now be implemented using only NOR gates
Implementation in NOR

Example:

\[ F = (\overline{A} + B).\overline{(A + D)}.(\overline{A} + \overline{C}) \]

\[ = (\overline{A} + B).\overline{A}.(\overline{A} + \overline{C}) \]

\[ = (A + B) + (A + D) + (A + C) \]
Design Example

The days of the week are represented by a 3-bit binary code:

<table>
<thead>
<tr>
<th></th>
<th>P</th>
<th>Q</th>
<th>R</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sunday</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Monday</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Tuesday</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Wednesday</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Thursday</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Friday</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Saturday</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

The code 000 will never occur

Design a NOR system to give 1 for the work-days, and 0 for the rest-days
The first stage is to construct a K-map:

<table>
<thead>
<tr>
<th></th>
<th>R=0</th>
<th>R=1</th>
</tr>
</thead>
<tbody>
<tr>
<td>P=0</td>
<td>Q=0</td>
<td>X</td>
</tr>
<tr>
<td></td>
<td>Q=1</td>
<td>1</td>
</tr>
<tr>
<td>P=1</td>
<td>Q=0</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Unused</th>
<th>Sunday</th>
</tr>
</thead>
<tbody>
<tr>
<td>Monday</td>
<td>Tuesday</td>
</tr>
<tr>
<td>Friday</td>
<td>Saturday</td>
</tr>
<tr>
<td>Wednesday</td>
<td>Thursday</td>
</tr>
</tbody>
</table>

The simplest *sum-of-products* form for $\overline{F}$ is:

$$\overline{F} = \overline{P}.\overline{Q} + P.Q.R$$

The simplest *product-of-sums* form for $F$ is:

$$F = (P + Q). (\overline{P} + \overline{Q} + \overline{R})$$
Design Example

\[ F = (P + Q).(\overline{P} + \overline{Q} + \overline{R}) \]

\[ = (P + Q).\overline{(P + Q + R)} \]

\[ = (P + Q) + (\overline{P + Q + R}) \]
Hazards in Combinational Logic Systems

A hazard is a transient change that occurs in a logic system following a change in an input.

Hazards are the result of gate delays.

The output $C$ is given by:

$$ C = A + B = A + \overline{A} = 1 $$

Thus the output should stay at logic 1, and be independent of the input.
Hazards in Combinational Logic Systems

In fact an output pulse occurs following the $1 \rightarrow 0$ input transition:

\[ A \]
\[ B = \overline{A} \]
\[ C = A + B \]

Hazard exists for a time equal to the gate delay (typically a few ns)
There are two types of hazard: static hazards and dynamic hazards.

Static hazard: 

Dynamic hazard: 

Whether hazards are significant depends on the application.

Hazards are always a problem if they occur in logic providing the input to a system with memory.
Hazards in NAND Systems

2-level NAND system:

Suppose that an input $Q$ changes: no input gate can have both $Q$ and $\overline{Q}$ for inputs because:

$$Q \cdot \overline{Q} \ldots = 0 = 1$$
Hazards in NAND Systems

Case 1: (potential dynamic hazard)

Input gate 1
Input gate 2
Output

No Hazard
Case 2: (potential static hazard)

No Hazard
Dynamic hazards do not occur in 2-level NAND systems

Static hazards can occur if one input gate changes from 0→1 whilst another input gate changes from 1→0
Properties of K-maps

Moving one square horizontally or vertically corresponds to changing a single input variable.

Each input gate corresponds to a group of 1s on the K-map: moving in or out of a group causes the corresponding input gate to change state.

If 2 groups of 1s on the K-map are adjacent and non-overlapping (horizontally or vertically) then changing a single input variable can move out of one group and into the other.

This is the condition for a static hazard.
Example of a Static Hazard

\[ F = \overline{A}.\overline{C} + B.C.D + A.B.C \]

\[ \begin{array}{cccc}
C=0 & & C=1 & \\
D=0 & & D=1 & D=0 \\
A=0 & \{ & B=0 & 1 \\
 & & & 1 \\
 & & B=1 & 1 \\
B=0 & A=1 & 0 & 0 \\
 & & & 0 \\
 & A=1 & 0 & 0 \\
B=0 & & & 0 \\
\end{array} \]

\[ F = \overline{A}.\overline{C} + B.C.D + A.B.C \]

A static hazard may occur if the inputs change from \( A=0, B=1, C=0, D=1 \) to \( A=0, B=1, C=1, D=1 \)
Example of a Static Hazard

\[ F = \overline{A.C} + B.C.D + A.B.C \]
\[ = \overline{A.C} + B.C.D + A.B.C \]
\[ = \overline{A.C} \cdot (B.C.D) \cdot (A.B.C) \]
\[ = Q1 \cdot Q2 \cdot Q3 \]

<table>
<thead>
<tr>
<th>(ABCD)</th>
<th>(ABCD)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0101</td>
<td>0111</td>
</tr>
</tbody>
</table>

\(Q1 = (A.C)\)
\(Q2 = (B.C.D)\)
\(Q3 = (A.B.C)\)

This is condition for a static hazard
Eliminating Static Hazards

Static hazards are eliminated by including extra groups which overlap the offending transitions:

\[ F = \overline{A}.\overline{C} + B.C.D + A.B.C + \overline{A}.B.D \]

The input gate corresponding to the new group remains at 0 throughout the transition.
Eliminating Static Hazards

\[ F = \overline{A.C} + B.C.D + A.B.C + \overline{A.B.D} \]
\[ = \overline{A.C} + B.C.D + A.B.C + \overline{A.B.D} \]
\[ = \overline{A.C} \cdot (B.C.D) \cdot (A.B.C) \cdot (A.B.D) \]
\[ = Q1 \cdot Q2 \cdot Q3 \cdot Q4 \]

<table>
<thead>
<tr>
<th></th>
<th>ABCD</th>
<th>ABCD</th>
</tr>
</thead>
<tbody>
<tr>
<td>Q1</td>
<td>(\overline{A.C})</td>
<td>0</td>
</tr>
<tr>
<td>Q2</td>
<td>(\overline{B.C.D})</td>
<td>1</td>
</tr>
<tr>
<td>Q3</td>
<td>(\overline{A.B.C})</td>
<td>1</td>
</tr>
<tr>
<td>Q4</td>
<td>(\overline{A.B.D})</td>
<td>0</td>
</tr>
</tbody>
</table>

Static hazard has been eliminated
Design Example

Implement the function: \( F = A.D + B.C + B.D \overline{D} \)
in hazard-free form using NAND gates

Simplest sum-of-products form:

\[
F = A.D + B.C + B.D
\overline{D}
\]
Design Example

Include an extra group to overlap the border between the adjacent groups:

Hazard-free sum-of-products form:

\[ F = A.D + B.C + B.D + A.B \]
Design Example

\[ F = A.D + B.C + B.D + A.B \]

\[ = A.D + B.C + B.D + A.B \]

\[ = (A.D) \cdot (B.C) \cdot (B.D) \cdot (A.B) \]
Hazards in NOR Systems

Dynamic hazards do not occur in 2-level NOR systems

Static hazards can occur if one input gate changes from $0 \rightarrow 1$ whilst another input gate changes from $1 \rightarrow 0$

If 2 groups of 0s on the K-map are adjacent and non-overlapping (horizontally or vertically) then changing a single input variable can move out of one group and into the other

This is the condition for a static hazard
Example of a Static Hazard

\[ F = A.B + A.D + \overline{A}.\overline{C} + B.\overline{C} + \overline{C}.D \]

A static hazard may occur if the inputs change from \( A=1, B=0, C=1, D=0 \) to \( A=0, B=0, C=1, D=0 \)

\[ \overline{F} = \overline{A}.C + A.\overline{B}.\overline{D} \]
Example of a Static Hazard

\[ F = (\overline{A}.C) + (A.B.D) \]
\[ F = (A + \overline{C}).(\overline{A} + B + D) \]
\[ = (A + \overline{C}).(\overline{A} + B + D) \]
\[ = (A + \overline{C}) + (\overline{A} + B + D) \]
\[ = Q1 + Q2 \]

<table>
<thead>
<tr>
<th>ABCD</th>
<th>ABCD</th>
</tr>
</thead>
<tbody>
<tr>
<td>1010</td>
<td>0010</td>
</tr>
</tbody>
</table>

Q1 = (A + C)
Q2 = (A + B + D)

This is condition for a static hazard
Eliminating Static Hazards

Static hazards are eliminated by including extra groups which overlap the offending transitions:

\[
\begin{align*}
A=0 & \quad B=0 & & 1 & & 1 & & 0 & & 0 \\
A=0 & \quad B=1 & & 1 & & 1 & & 0 & & 0 \\
A=1 & \quad B=0 & & 1 & & 1 & & 1 & & 1 \\
A=1 & \quad B=1 & & 1 & & 1 & & 1 & & 0 \\
\end{align*}
\]

\[F = \overline{A}.C + A.\overline{B}.D + \overline{B}.C.\overline{D}\]

The input gate corresponding to the new group remains at 1 throughout the transition
Eliminating Static Hazards

\[
\overline{F} = (\overline{A}.C) + (A.\overline{B}.D) + (B.C.D)
\]

\[
F = (A + \overline{C}).(\overline{A} + B + D).(B + \overline{C} + D)
\]

\[
= (A + \overline{C}).(\overline{A} + B + D).(B + \overline{C} + D)
\]

\[
= (A + \overline{C}) + (\overline{A} + B + D) + (B + \overline{C} + D)
\]

\[
= Q1 + Q2 + Q3
\]

<table>
<thead>
<tr>
<th></th>
<th>ABCD</th>
<th>ABCD</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1010</td>
<td>0010</td>
</tr>
<tr>
<td>Q1</td>
<td>(A + \overline{C})</td>
<td>0</td>
</tr>
<tr>
<td>Q2</td>
<td>(\overline{A} + B + D)</td>
<td>1</td>
</tr>
<tr>
<td>Q3</td>
<td>(B + \overline{C} + D)</td>
<td>1</td>
</tr>
</tbody>
</table>

Static hazard has been eliminated
Design Example

Implement the function: $F = \overline{A}.C + B.\overline{C} + A.B.C$

in hazard-free form using NOR gates

Simplest sum-of-products form for $\overline{F}$:

$$\overline{F} = \overline{A}.C + A.\overline{B}$$
Design Example

Include an extra group to overlap the border between the adjacent groups:

\[
\begin{align*}
A = 0 & \quad B = 0 \\
& \quad B = 1 \\
A = 1 & \quad B = 0
\end{align*}
\]

Hazard-free sum-of-products form:

\[
\overline{F} = \overline{A}.C + A.\overline{B} + \overline{B}.C
\]
Design Example

\[ F = (\overline{A}.C) + (A.\overline{B}) + (\overline{B}.C) \]
\[ F = (A + \overline{C}).(\overline{A} + B).(B + \overline{C}) \]
\[ = (A + \overline{C}).(\overline{A} + B).(B + \overline{C}) \]
\[ = (A + \overline{C}) + (\overline{A} + B) + (B + \overline{C}) \]
Dynamic Hazards

There must be at least three paths between the input and output to give the minimum of three transitions that constitute a dynamic hazard:

\[ D = \overline{C} \]
\[ E = A.C \]
\[ F = B.D = B.\overline{C} \]
\[ G = E + F = A.C + B.\overline{C} \]
\[ H = D.G = \overline{C}.(A.C + B.\overline{C}) = B.\overline{C} \]
Dynamic Hazards

Let $A=1$
$B=1$

$D = \overline{C}$
$E = A.C$
$F = B.D = B.\overline{C}$
$G = E + F = A.C + B.\overline{C}$
$H = D.G = \overline{C}.(A.C + B.\overline{C}) = B.\overline{C}$
Exclusive-OR Gates

\[ A \text{ XOR } B \text{ or } A \oplus B \]

This function is similar to the normal (inclusive) OR function except for the case \( A=1, \ B=1 \)

Electrical symbol:

<p>| | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>( A )</td>
<td>( B )</td>
<td>( A+B )</td>
</tr>
<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>

Identities:

\[ A \oplus B \equiv B \oplus A \]
\[ (A \oplus B) \oplus C \equiv A \oplus (B \oplus C) \]
Exclusive-OR functions of more than 2 variables can be generated by using several 2-input gates:

\[ A \oplus B \oplus C \]

\[ A \oplus B \oplus C \oplus D \]

Operating between several variables the exclusive-OR function is 1 if an odd number of the input variables are 1.
Exclusive-OR Gates

\[
\begin{array}{c|c|c}
B=0 & B=1 & \\hline
A=0 & 0 & 1 \\
A=1 & 1 & 0 \\
\end{array}
\]

\[
A \oplus B
\]

\[
\begin{array}{c}
A=0 \\
A=1 \\
\end{array}
\begin{align*}
B=0 & \quad B=1 \\
B=0 & \quad B=1 \\
\end{align*}
\]

\[
A \oplus B \oplus C
\]

\[
\begin{array}{c|c|c}
C=0 & C=1 & \\hline
B=0 & 0 & 1 \\
B=1 & 1 & 0 \\
B=0 & 0 & 1 \\
B=1 & 1 & 0 \\
\end{array}
\]

\[
\begin{array}{c|c|c|c}
D=0 & D=1 & D=0 & \\hline
B=0 & 0 & 1 & 0 & 1 \\
B=1 & 1 & 0 & 1 & 0 \\
B=0 & 0 & 1 & 0 & 1 \\
B=1 & 1 & 0 & 1 & 0 \\
\end{array}
\]

\[
A \oplus B \oplus C \oplus D
\]
7-Segment Decoder

7-segment display:

Diagram of 7-segment display with segments labeled a to g and a common line.

Numbers displayed: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9.
7-Segment Decoder

To reduce the number of connections the cathodes or anodes of the LEDs are connected in common:

Common anode

Common cathode

a b c d e f g

common

a b c d e f g

common
## 7-Segment Decoder

<table>
<thead>
<tr>
<th>Value</th>
<th>Binary</th>
<th>7-Segment Display</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>$D\ AB\ C\ DA$</td>
<td>$a\ b\ c\ d\ e\ f\ g$</td>
</tr>
<tr>
<td>0</td>
<td>0 0 0 0 0</td>
<td>1 1 1 1 1 1 0</td>
</tr>
<tr>
<td>1</td>
<td>0 0 0 1 0</td>
<td>0 1 1 0 0 0 0</td>
</tr>
<tr>
<td>2</td>
<td>0 0 1 0 1</td>
<td>0 1 1 0 1 1 0 1</td>
</tr>
<tr>
<td>3</td>
<td>0 0 1 1 1</td>
<td>1 1 1 1 1 0 0 1</td>
</tr>
<tr>
<td>4</td>
<td>0 1 0 0 0</td>
<td>0 1 1 0 0 0 1 1</td>
</tr>
<tr>
<td>5</td>
<td>0 1 0 1 1</td>
<td>1 0 1 1 0 1 1</td>
</tr>
<tr>
<td>6</td>
<td>0 1 1 0 1</td>
<td>1 0 1 1 1 1 1</td>
</tr>
<tr>
<td>7</td>
<td>0 1 1 1 1</td>
<td>1 1 1 1 1 0 0 0</td>
</tr>
<tr>
<td>8</td>
<td>1 0 0 0 1</td>
<td>1 1 1 1 1 1 1</td>
</tr>
<tr>
<td>9</td>
<td>1 0 0 1 1</td>
<td>1 1 1 1 1 0 1 1</td>
</tr>
</tbody>
</table>
7-Segment Decoder

Functions $a$, $b$, $c$, $d$, $e$, $f$ of the binary code $A$, $B$, $C$, $D$ can now be obtained using a K-map:

Function $a$:

The simplest *sum-of-products* form for $a$ is:

$$a = B + D + A.C + \overline{A}.\overline{C}$$
Medium-Scale Integration (MSI) devices are available which implement these Boolean functions and also provide current drive:

\[
\begin{array}{c}
A \\
B \\
C \\
D
\end{array}
\quad \begin{array}{c}
a \\
b \\
c \\
d \\
e \\
f \\
g
\end{array}
\]

74HCT47

200Ω

+5V

Devices are also available to drive Liquid-CrystalDisplays (LCD) and multi-digit displays.
Decoders

A decoder converts the information on $n$ input lines to $2^n$ output lines.

For any input combination one, and only one, output line is set to logical 1.

For example, a 3-to-8 line decoder

74HCT138
## Decoders

Truth table for a 3-to-8 line decoder:

<table>
<thead>
<tr>
<th>C</th>
<th>B</th>
<th>A</th>
<th>Y0</th>
<th>Y1</th>
<th>Y2</th>
<th>Y3</th>
<th>Y4</th>
<th>Y5</th>
<th>Y6</th>
<th>Y7</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<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>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<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>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
</tbody>
</table>
Encoders

Encoders have $2^n$ input lines, $n$ output lines, and perform the opposite operation to decoders.

If one of the input lines is at logical 1 then the output lines indicate the code for this input.

For example, an 8-to-3 line encoder

74HCT148
## Priority Encoders

Truth table for an 8-to-3 line priority encoder:

<table>
<thead>
<tr>
<th>Y0</th>
<th>Y1</th>
<th>Y2</th>
<th>Y3</th>
<th>Y4</th>
<th>Y5</th>
<th>Y6</th>
<th>Y7</th>
<th>C</th>
<th>B</th>
<th>A</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>X</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>
A multiplexer (MUX) is a combinational logic device that selects binary information from one of several input lines.

For example, an 8-to-1 line MUX

74HCT152
Truth table for a 1-to-8 line multiplexer:

<table>
<thead>
<tr>
<th>C</th>
<th>B</th>
<th>A</th>
<th>W</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>\textit{D0}</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>\textit{D1}</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>\textit{D2}</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>\textit{D3}</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>\textit{D4}</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>\textit{D5}</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>\textit{D6}</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>\textit{D7}</td>
</tr>
</tbody>
</table>
Programmable Logic

Programmable logic is increasingly being used instead of standard gates

Programmable logic often leads to lower cost (both design costs and hardware costs)

Types of programmable logic include: PROMs, PALs, GALs and FPGAs

The function of programmable logic is determined by the state of “fuses” on the integrated circuit

These fuses are programmed in a special-purpose programmer connected to a PC
Programmable Array Logic

Inputs:

Programmable AND matrix

Outputs:

W X Y Z

Fixed OR matrix

A B C
HDL Definition File

Name      EX1;
Part no   EX0000;
Date      6/10/98;
Rev       01;
Designer  J. B. Grimbleby;
Company   University of Reading;
Assembly  None;
Location  None;
Device    p16l8;

/* input pins */
PIN 1   = A;
PIN 2   = B;
PIN 3   = C;
PIN 4   = D;

/* output pins */
P1N 19  = F;

/* equations */
F = !A & (B # C # !B & !C) # A & B & !(C # D);

Boolean Operator Symbols:
! → NOT
& → AND
# → OR
Expanded Product Terms:

\[ !F \quad \Rightarrow \quad A \land !B \land \# A \land C \land \# A \land D \]

Symbol Table:

<table>
<thead>
<tr>
<th>Pin Variable</th>
<th>Pol</th>
<th>Name</th>
<th>Ext</th>
<th>Pin Type</th>
<th>Pterms</th>
<th>Max</th>
<th>Min</th>
<th>Level</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>1</td>
<td>V</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>B</td>
<td>2</td>
<td>V</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>C</td>
<td>3</td>
<td>V</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>D</td>
<td>4</td>
<td>V</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>F</td>
<td>19</td>
<td>V</td>
<td>3</td>
<td>7</td>
<td>1</td>
<td>-</td>
<td>-</td>
<td>-</td>
</tr>
</tbody>
</table>
Sequential Logic Systems

Any logic system that has feedback can have memory.

The output is not simply a function of the present value of the inputs, but also of previous states of the system.

Digital circuits with memory are termed *sequential*.

General sequential logic systems are formalised as Finite-State Machines (FSMs).

This course will only cover counters which are a subset of FSMs.
RS Flip-Flops

Logic circuits having two stable states are called flip-flops.

The simplest flip-flop consists of two cross-coupled NOT gates:

\[ A = \overline{B} \]
\[ B = \overline{A} \]

There are two stable states:

\[ A=0, B=1 \]
\[ A=1, B=0 \]
RS Flip-Flops

Replacing the inverters by NOR gates:

\[ R \quad Q = (R + P) \]

\[ S \quad P = (S + Q) \]

\[
R = 0, S = 0: \quad Q = (0 + P) = \overline{P} \quad P = (0 + Q) = \overline{Q}
\]

\[
R = 1, S = 0: \quad Q = (1 + P) = 1 = 0 \quad P = (0 + Q) = 0 = 1
\]

\[
R = 0, S = 1: \quad P = (1 + Q) = 1 = 0 \quad Q = (0 + P) = 0 = 1
\]
RS Flip-Flops

The behaviour of the RS flip-flop can be summarised in the table:

<table>
<thead>
<tr>
<th>S</th>
<th>R</th>
<th>Q</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Q-</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>X</td>
</tr>
</tbody>
</table>

where Q- represents the previous value of Q, and X means that the result is undetermined

RS flip-flops can be used to store 1 bit of data
RS Flip-Flops

An alternative RS flip-flop using NAND gates:

\[
S \quad Q = \overline{(S \cdot P)}
\]

\[
R \quad P = \overline{(R \cdot Q)}
\]

- \( R = 1, S = 1 \): \( Q = \overline{(1 \cdot P)} = \overline{P} \quad P = \overline{(1 \cdot Q)} = \overline{Q} \)
- \( R = 1, S = 0 \): \( Q = \overline{(0 \cdot P)} = \overline{0} = 1 \quad P = \overline{(1 \cdot Q)} = \overline{1} = 0 \)
- \( R = 0, S = 1 \): \( P = \overline{(0 \cdot Q)} = \overline{0} = 1 \quad Q = \overline{(1 \cdot P)} = \overline{1} = 0 \)
RS Flip-Flops

The behaviour of the NAND RS flip-flop can be summarised in the table:

<table>
<thead>
<tr>
<th>S</th>
<th>R</th>
<th>Q</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1</td>
<td>Q-</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>X</td>
</tr>
</tbody>
</table>

Like NOR-based RS flip-flops, NAND RS flip-flops are not normally used for data storage.

A common application is switch de-bouncing.
Switch De-Bouncer

Assume break before make

\[ R \quad S \quad Q \]

\[ +5V \]

\[ 47k\Omega \quad 47k\Omega \]

J. B. Grimbleby

School of Systems Engineering: Electronic Engineering
The D-Latch

With the addition of two AND gates and an inverter the RS flip-flop becomes a D-latch:

\[ \text{le} = 0 \rightarrow S = 0, R = 0 : \quad Q = Q \quad \text{(latch holds data)} \]
\[ \text{le} = 1 \rightarrow S = D, R = \overline{D} : \quad Q = D \quad \text{(latch accepts data)} \]

NB: S = 1, R = 1 cannot occur
The D-Latch

The operation of the D-latch is to accept data when \( le=1 \), and to store the data when \( le=0 \).

Most D-latches also have an inverted output \( \overline{Q} \).

Note that the control terminal is level-sensitive: as long as \( le=1 \) the latch remains transparent (the output \( Q \) follows the input \( D \)).
Edge-Triggered Flip-Flops

Level-sensitive flip-flops are not suitable for use in clocked sequential systems such as counters.

For such applications it is necessary to use a different type of flip-flop which is edge-sensitive.

Edge-sensitive flip-flops respond only to a change in the value of the control input (clock).

In an edge-sensitive flip-flop the output can only change at the instant of the clock transition.

The output value depends on the data inputs immediately before the clock transition.
Edge-Triggered Flip-Flops

The edge-triggered D-type flip-flop has a single data input $D$, and a clock input $clk$

![Flip-Flop Diagram]

The output $Q$ changes only on a 0-to-1 transition of $clk$:

$$Q^+ = D^-$$

where $Q^+$ is the output value after the transition and $D^-$ is the data input value immediately before the transition.
Sequential systems using edge-triggered flip-flops are classified according to how the clock inputs of the flip-flops are connected.

**Synchronous systems:**
The clocks of all flip-flops are connected together to a common source.

**Asynchronous systems:**
The clocks of the flip-flops are derived from different sources (usually the outputs of other flip-flops).
Asynchronous Counters

A divide-by-2 counter can be constructed by connecting the $D$ input to the inverted output.

\[ D = \overline{Q} \]
Divide-by-2 stages can be cascaded to construct a natural binary counter:

Asynchronous Counters
Asynchronous Counters

Delays in the flip-flops cause spurious outputs while the flip-flops are in the process of changing state following an input transition:

\[
\begin{align*}
Q1 &:  1  0  0  0  0 \\
Q2 &:  1  1  0  0  0 \\
Q3 &:  0  0  0  1
\end{align*}
\]
Synchronous Counters

In synchronous counters the clock terminals of all the flip-flops are connected to the input.
Synchronous Counters

Synchronous counters can easily be made to count in any modulo:

Input

Q1

Q2

D2

J. B. Grimbleby  School of Systems Engineering: Electronic Engineering  Slide 141
Shift Registers

Input

Clock

Q1

Q2

Q3

Q4

Clock

Input

Q1

Q2

Q3

Q4

J. B. Grimbleby

School of Systems Engineering: Electronic Engineering
Serial data can be clocked into the shift register until the complete data word is stored.

The data is then available in parallel form at the outputs of the shift register stages.

Parallel-to-serial conversion is more difficult using the standard D-type flip-flop.

Some flip-flops have asynchronous load which allows data to be forced onto the output.

Data loaded in parallel into the flip-flops can be clocked out in serial form.
Johnson-Code Counters

Johnson-code counters are shift registers with feedback from the inverting output.

They are synchronous and count modulo $2n$ where $n$ is the number of flip-flops

3-stage Johnson-code counter:
Precautions must be taken to prevent the counter getting into one of the unused states:

J. B. Grimbleby
School of Systems Engineering: Electronic Engineering
Chain-Code Generators

Input

Q1 Q2 Q3 Q4

D Q

D Q

D Q

D Q

Q

Q

Q

Q

Q

Q

Input

Q1

Q2

Q3

Q4

D1
Design of Synchronous Counters

Counter is required to count modulo-$m$: then $n$ flip-flops will be required where $2^n \geq m$

The counter will consist of the $n$ flip-flops connected to a common clock, each with a combinational logic network generating its $D$ input from all the outputs:
Design of Synchronous Counters

Modulo-3 counter with 2 outputs $A$ and $B$:

<table>
<thead>
<tr>
<th>State</th>
<th>$A$</th>
<th>$B$</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>3</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

etc.

Y-map shows next state for each present state:

$$\begin{array}{cc}
B=0 & B=1 \\
A=0 & 1 | 1 | X | X \\
A=1 & 0 | 0 | 1 | 0
\end{array}$$

Present state $A=1, B=1$
Next state $A=1, B=0$

State $A=0, B=1$ does not occur in the required sequence, and is termed an *unused state*
Design of Synchronous Counters

Now split Y-map into separate K-maps:

Thus:

\[ DA = \overline{A} + B \]
\[ DB = \overline{A} \]
Design of Synchronous Counters

Check unused states:

\[ DA = \overline{A} + B \quad DB = \overline{A} \]

\( A=0, B=1 : DA=1+1=1, DB=1 \rightarrow A=1, B=1 \checkmark \)
Design of Synchronous Counters

If the counter gets into any unused state it should regain the correct counting sequence after a limited number of input clock cycles.

If necessary modify K-maps to force the unwanted state (01) back to a correct sequence state (00):

\[
\begin{array}{c|cc}
B=0 & B=1 \\
\hline
A=0 & 1 & 0 \\
A=1 & 0 & 1 \\
\end{array}
\]

\[
\begin{array}{c|cc}
B=0 & B=1 \\
\hline
A=0 & 1 & 0 \\
A=1 & 0 & 0 \\
\end{array}
\]

\[
DA = \overline{A} \overline{B} + A.B
\]

\[
DB = \overline{A} \overline{B}
\]

These functions are more complex than originals.
Design Example

Design a modulo-5 synchronous counter, using D-type flip-flops and NAND gates, that has 3 outputs A, B, C and counts in the sequence:

<table>
<thead>
<tr>
<th>State</th>
<th>A</th>
<th>B</th>
<th>C</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

etc.

The number of flip-flops $n$ required is given by:

$$2^n \geq 5 \rightarrow n = 3$$
## Design Example

<table>
<thead>
<tr>
<th>State</th>
<th>$A$</th>
<th>$B$</th>
<th>$C$</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

**Y-map:**

<table>
<thead>
<tr>
<th>$A$=0</th>
<th>$B$=0</th>
<th>$B$=1</th>
<th>$C$=0</th>
<th>$C$=1</th>
</tr>
</thead>
<tbody>
<tr>
<td>XXX</td>
<td>011</td>
<td>100</td>
<td>110</td>
<td></td>
</tr>
<tr>
<td>100</td>
<td>110</td>
<td>010</td>
<td>XXX</td>
<td></td>
</tr>
<tr>
<td>001</td>
<td>XXX</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Present state 011**

**Next state 110**

**DA DB DC**
Design Example

$$\begin{align*}
A = 0 & \quad B = 0 \\
A = 0 & \quad B = 1 \\
A = 1 & \quad B = 0 \\
A = 1 & \quad B = 1
\end{align*}$$

$$\begin{align*}
D_A &= \overline{A}.B \\
D_B &= C + A.B \\
D_C &= \overline{B}
\end{align*}$$
Design Example

\[ DA = \overline{A}.B \quad DB = C + A.B \quad DC = \overline{B} \]

Unwanted states:

\[ A=0, B=0, C=0 : DA=0, DB=0, DC=1 \rightarrow A=0, B=0, C=1 \checkmark \]
\[ A=1, B=0, C=1 : DA=0, DB=1, DC=1 \rightarrow A=0, B=1, C=1 \checkmark \]
\[ A=1, B=1, C=1 : DA=0, DB=1, DC=0 \rightarrow A=0, B=1, C=0 \checkmark \]

Convert to NAND form:

\[ DA = \overline{A}.B \quad DB = \overline{C}.(\overline{A}.B) \quad DC = \overline{B} \]
Design Example

\[ DA = \overline{A}B \]  \[ DB = \overline{C} \cdot (A \cdot B) \]  \[ DC = \overline{B} \]
Design Example

Design a modulo-5 synchronous counter, using D-type flip-flops and NOR gates, that has 3 outputs $A$, $B$, $C$ and counts in the sequence:

<table>
<thead>
<tr>
<th>State</th>
<th>$A$</th>
<th>$B$</th>
<th>$C$</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>5</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
</tbody>
</table>

The number of flip-flops $n$ required is given by:

$$2^n \geq 5 \quad \Rightarrow \quad n = 3$$
Design Example

<table>
<thead>
<tr>
<th></th>
<th>C=0</th>
<th>C=1</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>A=0</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B=0</td>
<td>X 0</td>
<td>X 1</td>
</tr>
<tr>
<td>B=1</td>
<td>1 1</td>
<td>0 1</td>
</tr>
<tr>
<td><strong>A=1</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B=0</td>
<td>0 X</td>
<td>0 X</td>
</tr>
</tbody>
</table>

\[
\overline{DA} = A + \overline{B} \quad \overline{DB} = A.B + \overline{A}.\overline{C} \quad \overline{DC} = B
\]

Duality:

\[
DA = \overline{A}.B \quad DB = (\overline{A} + B).(A + C) \quad DC = \overline{B}
\]
Design Example

\[ DA = \overline{A}.B \quad DB = (\overline{A} + B).(A + C) \quad DC = \overline{B} \]

Unwanted states:

\[ A=0, \ B=0, \ C=0 : DA=0, \ DB=0, \ DC=1 \rightarrow A=0, \ B=0, \ C=1 \ \checkmark \]
\[ A=1, \ B=0, \ C=1 : DA=0, \ DB=0, \ DC=1 \rightarrow A=0, \ B=0, \ C=1 \ \checkmark \]
\[ A=1, \ B=1, \ C=1 : DA=0, \ DB=1, \ DC=0 \rightarrow A=0, \ B=1, \ C=0 \ \checkmark \]

Convert to NOR form:

\[ DA = A + \overline{B} \quad DB = (\overline{A} + B) + (\overline{A} + C) \quad DC = \overline{B} \]
Design Example

\[ DA = A + B \]
\[ DB = (A + B) + (A + C) \]
\[ DC = B \]
The edge-triggered JK flip-flop has 2 data inputs $J$, $K$, and a clock input $clk$.

The output $Q$ changes only on a 0-to-1 transition of $clk$.

The output $Q^+$ immediately after the clock transition depends on the output $Q^-$ and the inputs $J^-$, $K^-$ immediately before the transition.
Edge-Triggered JK Flip-Flops

A divide-by-2 counter can be constructed by connecting the $J$ and $K$ inputs to logic 1:

<table>
<thead>
<tr>
<th>$J$</th>
<th>$K$</th>
<th>$Q^+$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>$Q^-$</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>$Q^-$</td>
</tr>
</tbody>
</table>

Input

Output
**Edge-Triggered JK Flip-Flops**

Asynchronous natural binary counter:

![Diagram of JK flip-flops connected in a counter configuration](image)

- Input
- Q1
- Q2
- Q3

Input waveform:
- Input
- Q1
- Q2
- Q3

---

J. B. Grimbleby  School of Systems Engineering: Electronic Engineering  Slide 163
Edge-Triggered JK Flip-Flops

Shift register:

![Diagram of JK flip-flops](image)

JK flip-flops can be used to design synchronous counters. The design process is more complicated than design with D-type flip-flops, but the result is often more economical.
Types of Logic Gate

Electromechanical relays: slow (~ 10 ms), poor reliability, physically large (~ 5 cm³), high power consumption

Vacuum tubes: faster (~ 10 μs), poor reliability, physically large (~ 2 cm³), high power consumption

Semiconductor devices: fast, (~ 10 ns), excellent reliability, very small (~ 10⁻⁹ cm³), low power consumption

Three main families of semiconductor logic gates: TTL, CMOS and ECL
The important parameters of a logic family are:

Power dissipation: this is usually dependent on the transition frequency at the gate output.

Propagation delay: determines the maximum operating speed

Noise margin: high value reduces the susceptibility to interference

Fan-out: the maximum number of gates inputs that can be connected to a single gate output
Transistor-Transistor Logic (TTL)

TTL was the first integrated logic family and is still the most commonly used.

Logic levels:

- Logic 0: 0.0 → 0.8 V
- Logic 1: 2.0 → 5.0 V

Basic TTL logic gate is NAND.

Available in a number of variants including 74xxx, 74Sxxx, 74Lxxx, 74LSxxx, 74ASxxx, 74ALSxxx, 74Fxxx.

Only the 74ALSxxx and 74Fxxx should be used in new designs.
Properties of TTL Logic

(Values apply to the 74ALSxxx logic family)

Supply voltage: 5 V ± 0.25 V

Propagation delay: 4 ns

Speed-power product (10 MHz): 5 pJ

Quiescent power consumption: 1 mW

Noise margin: 0.3 V

Fan-out: 20

Cost: Medium
Transistor-Transistor Logic (TTL)

The bipolar transistor:

When used as a switch the transistor has two states:

OFF: \( I_B = 0 \) \( I_C = 0 \)
ON: \( I_B \gg I_C/\beta \) \( V_{BE} = 0.6V \) \( V_{CE} < 0.2V \)
Transistor-Transistor Logic (TTL)

Resistor-transistor logic gate:
Logic 0: 0.0V → 0.5V
Logic 1: 3.0V → 5.0V

\[
\begin{array}{c|c|c}
A=0 & B=0 & 0 \\
B=1 & 0 & 0 \\
A=1 & 0 & 0 \\
\end{array}
\]

\[
F = \overline{A} \overline{B} \overline{C} \quad \text{NOR gate}
\]

\[
F = A + B + C
\]
Complementary Metal-Oxide Semiconductor (CMOS) Logic

CMOS was introduced after TTL and is the technology used in nearly all LSI devices.

It is now replacing TTL in most SSI and MSI applications because of its speed and lower power consumption.

Logic levels:
- logic 0: 0.0 → 1.5 V
- logic 1: 3.5 → 5.0 V

(Typical)

There are also TTL-compatible CMOS logic families: 74HCTxxx and 74VHCT.
Properties of CMOS Logic

(Values apply to the 74HCxxx logic family)

Supply voltage: 2V → 6V

Propagation delay: 10 ns

Speed-power product (10 MHz): 50 pJ

Quiescent power consumption: 10 μW

Noise margin: 1.25 V

Fan-out: 20

Cost: low
CMOS Logic

Metal-oxide semiconductor (MOS) transistors:

n-channel MOSFET

\[
\begin{align*}
\text{OFF: } & \quad V_{GS} = 0.0 \rightarrow 1.5V \\
& \quad R_{DS} > 1M\Omega \\
\text{ON: } & \quad V_{GS} = 3.5 \rightarrow 5.0V \\
& \quad R_{DS} < 10\Omega
\end{align*}
\]

p-channel MOSFET

\[
\begin{align*}
\text{OFF: } & \quad V_{GS} = -1.5 \rightarrow 0.0V \\
& \quad R_{DS} > 1M\Omega \\
\text{ON: } & \quad V_{GS} = -5.0 \rightarrow -3.5V \\
& \quad R_{DS} < 10\Omega
\end{align*}
\]
Thus when input is low, output is high, and when input is high, output is low.

<table>
<thead>
<tr>
<th>$V_{IN}$</th>
<th>Q1</th>
<th>Q2</th>
<th>$V_{OUT}$</th>
</tr>
</thead>
<tbody>
<tr>
<td>0.0 → 1.5V</td>
<td>OFF</td>
<td>ON</td>
<td>5.0V</td>
</tr>
<tr>
<td>3.5 → 5.0V</td>
<td>ON</td>
<td>OFF</td>
<td>0.0V</td>
</tr>
</tbody>
</table>
CMOS NOR Gate

\[ V_{DD} = 5.0V \]

<table>
<thead>
<tr>
<th>A</th>
<th>B</th>
<th>Q1</th>
<th>Q2</th>
<th>Q3</th>
<th>Q4</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>lo</td>
<td>lo</td>
<td>OFF</td>
<td>OFF</td>
<td>ON</td>
<td>ON</td>
<td>hi</td>
</tr>
<tr>
<td>lo</td>
<td>hi</td>
<td>OFF</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td>lo</td>
</tr>
<tr>
<td>hi</td>
<td>lo</td>
<td>ON</td>
<td>OFF</td>
<td>OFF</td>
<td>ON</td>
<td>lo</td>
</tr>
<tr>
<td>hi</td>
<td>hi</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td>OFF</td>
<td>lo</td>
</tr>
</tbody>
</table>
CMOS NAND Gate

<table>
<thead>
<tr>
<th>A</th>
<th>B</th>
<th>Q1</th>
<th>Q2</th>
<th>Q3</th>
<th>Q4</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>lo</td>
<td>lo</td>
<td>OFF</td>
<td>OFF</td>
<td>ON</td>
<td>ON</td>
<td>hi</td>
</tr>
<tr>
<td>lo</td>
<td>hi</td>
<td>OFF</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td>hi</td>
</tr>
<tr>
<td>hi</td>
<td>lo</td>
<td>ON</td>
<td>OFF</td>
<td>OFF</td>
<td>ON</td>
<td>hi</td>
</tr>
<tr>
<td>hi</td>
<td>hi</td>
<td>ON</td>
<td>ON</td>
<td>OFF</td>
<td>OFF</td>
<td>lo</td>
</tr>
</tbody>
</table>

$V_{DD} = 5.0V$
Emitter-Coupled Logic (ECL)

ECL is the fastest, and most difficult to use, logic family

Logic levels:  
- Logic 0: -1.850 → -1.475 V
- Logic 1: -1.105 → -0.810 V

Basic ECL logic gate is OR / NOR

Difficult to interface to other logic families

Extreme switching speed means that length of interconnections becomes significant

Used only when the fastest switching speed is essential
Properties of ECL Logic

(Values apply to the 100K logic family)

Supply voltage: -4.5 V

Propagation delay: 0.75 ns

Speed-power product: 80 pJ

Quiescent power consumption: 40 mW

Noise margin: 0.125 V

Fan-out: 20

Cost: high
All logic devices take current pulses from the power supply when switching output state.

This causes negative-going pulse on the power supply (because of supply impedance).

Thus switching in one device could affect another device.

This problem is overcome by decoupling: capacitors are placed across the supply close to the logic devices.

Typically 47 nF ceramic capacitors are used.

For high-speed logic a decoupling capacitor is required close to each device.