# Notes for ECE 27000 - Introduction to Digital System Design Zeke Ulrich January 18, 2025

#### Contents

Course Description 1
Number Systems 2
Boolean Algebra 3
Logic Gates 4

### Course Description

An introduction to digital system design, with an emphasis on practical design techniques and circuit implementation.

#### *Number Systems*

In daily life, we primarily interact with the familiar base-10 numbers. However, when interaction with digital systems, we must also concern ourselves with base-2, base-8, base-16, and other bases which are friendly to binary states. Unless completely unambiguous, the base of a number is written as a right subscript such as 144<sub>10</sub> for base-10 or 1001<sub>2</sub> for base-2.

For binary numbers, each digit represents a power of two. To convert a binary number to decimal, you sum the products of each binary digit with its corresponding power of two. For example, the binary number 1001 is calculated as

$$2^{3} \times 1 + 2^{2} \times 0 + 2^{1} \times 0 + 2^{0} \times 1 = 8 + 0 + 0 + 1 \tag{1}$$

$$=9_{10}$$
 (2)

To convert from hexadecimal to decimal, each digit represents a power of sixteen. For instance, the hexadecimal number f1 is calculated as

$$15 \times 161 + 1 \times 160 = 240 + 1 \tag{3}$$

$$=241_{10}$$
 (4)

where f represents the decimal value 15. When converting to another base, reverse the process by dividing the decimal number by the target base, recording the remainder, and repeating with the quotient until it reaches zero. The remainders give you the digits of the number in the new base, read in reverse order.

To convert a decimal number into binary, for example, you repeatedly divide the number by 2 and record the remainders. For the decimal number 9, dividing by 2 gives a quotient of 4 and a remainder of 1. Dividing 4 by 2 gives a quotient of 2 and a remainder of 0. Dividing 2 by 2 gives a quotient of 1 and a remainder of 0, and finally, dividing 1 by 2 gives a quotient of 0 and a remainder of 1. Reading the remainders from bottom to top, the binary representation of 9 is 1001.

In SystemVerilog, numbers are written in format [size]'[base][number], for example:

- 4'b1001 // binary, 9 in decimal, bit width 4 bits
- 8'hf1 //hex, equals 421, bit width 8 bits
- 3'03 // octal, 3, bit width 3 bits
- 32'b1001\_1101\_0101\_1111 // binary, 40255, bit width 32 bits

# Boolean Algebra

Computers operate in binary. To represent the state of a computer we require a suitable mathematical framework, provided by boolean algebra.

| Rule                    | Expression                                                              | T.1.1 D. 1 A.1 1           |
|-------------------------|-------------------------------------------------------------------------|----------------------------|
| Commutativity           | X + Y = Y + X                                                           | Table 1: Boolean Algebra   |
|                         | $X \cdot Y = Y \cdot X$                                                 |                            |
| Associativity           | (X+Y)+Z=X+(Y+Z)                                                         |                            |
|                         | $(X \cdot Y) \cdot Z = X \cdot (Y \cdot Z)$                             |                            |
| Distributivity          | $X \cdot Y + X \cdot Z = X \cdot (Y + Z)$                               |                            |
|                         | $(X+Y)\cdot(X+Z) = X+Y\cdot Z$                                          |                            |
| Covering                | $X + X \cdot Y = X$                                                     |                            |
|                         | $X \cdot (X + Y) = X$                                                   |                            |
| Combining               | $X \cdot Y + X \cdot Y = X$                                             |                            |
|                         | $(X+Y)\cdot(X+Y)=X$                                                     |                            |
| Consensus               | $X \cdot Y + X \cdot Z + Y \cdot Z = X \cdot Y + X' \cdot Z$            |                            |
|                         | $(X+Y)\cdot (X+Z)\cdot (Y+Z) = (X+Y)\cdot (X+Z)$                        |                            |
| Generalized Idempotency | $X + X + \dots + X = X$                                                 |                            |
|                         | $X \cdot X \cdot \cdots \cdot X = X$                                    |                            |
| DeMorgan's Theorems     | $(X_1 \cdot X_2 \cdot \cdots \cdot X_n)' = X_1' + X_2' + \cdots + X_n'$ |                            |
|                         | $(X_1 + X_2 + \cdots + X_n)' = X_1' \cdot X_2' \cdot \cdots \cdot X_n'$ |                            |
| Generalized DeMorgan's  | $F(X_1, X_2,, X_n, +, \cdot) = F(X_1, X_2,, X_n, \cdot, +)'$            |                            |
| Shannon's Expansion     | $F(X_1, X_2,, X_n) = X_1 \cdot F(1, X_2,, X_n) + X_1' \cdot X_n'$       | $F(0, X_2, \ldots, X_n)$   |
|                         | $F(X_1, X_2,, X_n) = [X_1 + F(0, X_2,, X_n)] \cdot [X_1']$              | $+ F(1, X_2, \ldots, X_n)$ |

## Logic Gates

We represent boolean operations in circuit diagrams with gates. Below are their symbols and corresponding truth tables.

| D |   | cc |    |
|---|---|----|----|
| D | u | п  | eı |

| A | Output |
|---|--------|
| О | О      |
| 1 | 1      |



**AND** 

| A | В | Output |
|---|---|--------|
| 0 | 0 | О      |
| О | 1 | О      |
| 1 | 0 | О      |
| 1 | 1 | 1      |



|  |  | ) |
|--|--|---|
|  |  |   |

|  | 1 | 2 | • |  |
|--|---|---|---|--|

| Α | В | Output |
|---|---|--------|
| О | 0 | О      |
| О | 1 | 1      |
| 1 | О | 1      |
| 1 | 1 | 1      |





| Α | Output |
|---|--------|
| О | 1      |
| 1 | О      |



| NAND |
|------|

| Α | В | Output |
|---|---|--------|
| О | 0 | 1      |
| О | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | О      |





NOR

| A | В | Output |
|---|---|--------|
| О | 0 | 1      |
| О | 1 | О      |
| 1 | 0 | О      |
| 1 | 1 | О      |

Output

1 1





|     | A | В |
|-----|---|---|
|     | О | О |
| XOR | О | 1 |
|     | 1 | О |
|     | l |   |





| YN                                     | OR |
|----------------------------------------|----|
| \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ | OI |

| A | В | Output |  |
|---|---|--------|--|
| О | О | 1      |  |
| О | 1 | О      |  |
| 1 | О | О      |  |
| 1 | 1 | 1      |  |

