# **Digital Techniques**

#### 1. Binary System

The digital computer is the best example of a digital system. A main characteristic of digital system is its ability to manipulate discrete elements of information.

Discrete elements of information are represented in a digital system by physical quantities called signals. Electrical signals such as voltages and currents are the most common. A block diagram of the digital computer is shown in Figure (1). The memory unit stores programs as well as input, output, and intermediate data. The processor unit performs arithmetic and other data processing tasks as specified by a program. The control unit supervise the flow of information between the various units. The programmed data prepared by the user are transferred into the memory unit by means of an input device such as keyboard, punch-card reader. An output device such as a printer.

The central processor unit (CPU) is enclosed in a small integrated circuit that is called a microprocessor. The memory unit, as well as the part that controls the interface between the microprocessor and the I/O devices is called a microcomputer. The digital computer manipulates discrete elements of information and that these elements are represented in the binary form.



#### 2. Binary numbers

The binary numbers system has two possible values: "0" and "1", called a <u>**Bit**</u>. The physical manifestation of these binary quantities may be one of two voltages, for example, "0" volts or ground for logic "0" and "5" volts for logic "1". To convert from binary to decimal. Each coefficient  $a_j$  is multiplied by  $2^j$ . For example, the decimal equivalent of the binary number  $110)_2$  is  $6)_{10}$  as shown from the multiplication of the coefficients by powers of 2:

$$2^2 \times 1 + 2^1 \times 1 + 2^0 \times 0 = 4 + 2 + 1 = 6$$

#### So 110)2 equals to 6)10

The conversion from decimal to binary by dividing of by "2" to give an integer quotient of no. and a remainder. The division quotient is again divided by "2" to give a new quotient and remainder. The process is continued until the integer quotient becomes "0".

#### Example 1: Convert decimal 6)10 to binary

| <b>Integer</b> |                 | <u>Remainder</u> |                             |
|----------------|-----------------|------------------|-----------------------------|
| 6              | $2 \rightarrow$ | 0                | L.S.B Least Significant Bit |
| 3              | $2 \rightarrow$ | 1                |                             |
| 1              | $\rightarrow$   | 1                | M.S.B Most Significant Bit  |

So 6)10 equals to 110)2

## Example 2: Convert 41)<sub>10</sub> to binary

| <b>Integer</b> |                 | <u>Remainder</u> |                             |
|----------------|-----------------|------------------|-----------------------------|
| 41             | $2 \rightarrow$ | 1                | L.S.B Least Significant Bit |
| 20             | $2 \rightarrow$ | 0                |                             |
| 10             | $2 \rightarrow$ | 0                |                             |
| 5              | $2 \rightarrow$ | 1                |                             |
| 2              | $2 \rightarrow$ | 0                |                             |
| 1              | $\rightarrow$   | 1                | M.S.B Most Significant Bit  |
|                |                 |                  |                             |

## So 41)10 equals to 101001)2

| 32 | 16 | 8 | 4 | 2 | 1 | 1+8+32=41 |
|----|----|---|---|---|---|-----------|
| 1  | 0  | 1 | 0 | 0 | 1 | 1+0+32=41 |

## Example 3: Convert 0.75)<sub>10</sub> to binary

|                       | <u>Integer</u> | <b>Fraction</b> |
|-----------------------|----------------|-----------------|
| $0.75 \times 2 = 1.5$ | 1              | 0.5             |
| $0.5 \times 2 = 1$    | 1              | 0               |

So 0.75)<sub>10</sub> equals to 0.11)<sub>2</sub>

Dr Waleed Al-Saedi

#### Example 4: Convert 9.6875)<sub>10</sub> to binary

The integer

| <u>Integer</u> |                 | <u>Remainder</u> |                             |
|----------------|-----------------|------------------|-----------------------------|
| 9              | $2 \rightarrow$ | 1                | L.S.B Least Significant Bit |
| 4              | $2 \rightarrow$ | 0                |                             |
| 2              | $2 \rightarrow$ | 0                |                             |
| 1              | $\rightarrow$   | 1                | M.S.B Most Significant Bit  |

The fraction

|                           | <b>Integer</b> | <b>Fraction</b> |
|---------------------------|----------------|-----------------|
| $0.6875 \times 2 = 1.375$ | 1              | 0.375           |
| $0.375 \times 2 = 0.75$   | 0              | 0.75            |
| $0.75 \times 2 = 1.5$     | 1              | 0.5             |
| 0.5×2=1                   | 1              | 0               |

## So 9.6875)10 equals to 1001.1011)2

## Example 4: Convert 11010.11)<sub>2</sub> to decimal

$$[(2^{4}\times1)+(2^{3}\times1)+(2^{2}\times0)+(2^{1}\times1)+(2^{0}\times0)].[(2^{-1}\times1)+(2^{-2}\times1)] =$$

$$[16+8+0+2+0].[0.5+0.25] = 26.75$$

## So 11010.11)2 equals to 26.75)10

## 3. Logic Gates

A gate is a circuit with one output that implements one of the basic functions such as inverter, OR and AND gates. Gates are available with one, two, three, four, and eight inputs.

<u>**Truth table (T.T):**</u> is a table of all possible combination of the variables showing the relation between the values that the variables may take and the result of the operation.

# 3.1. Inverter "Not" gate

An inverter is a gate with only one input and one output. It is called an inverter because the output state is always the opposite of the input state. Specifically, when the input voltage is high the output is low. On the other hand, when the input voltage is low the output is high.

| T.T (Truth Table) |  |  |
|-------------------|--|--|
| O/P (y)           |  |  |
| 1                 |  |  |
| 0                 |  |  |
|                   |  |  |



Symbol for digital logic cct.



**Integrated Circuit IC** 

# 3.2. OR Gate

An OR gate has two or more input signals but only one output signal. It is called an OR gate because the output voltage is high if any or all of the input voltages are high.

|   | <b>T.</b> ] | Г (Truth T | able)   |                                                                                            |
|---|-------------|------------|---------|--------------------------------------------------------------------------------------------|
|   | Ι           | /Ps        | O/P     |                                                                                            |
|   | А           | В          | У       |                                                                                            |
|   | 0           | 0          | 0       | B y                                                                                        |
|   | 0           | 1          | 1       |                                                                                            |
|   | 1           | 0          | 1       | Symbol for digital logic cct.                                                              |
|   | 1           | 1          | 1       |                                                                                            |
|   |             |            | y=A+B   | 12 11 10 9 8<br>7432<br>7432                                                               |
| Ь |             | 1          | 2<br>In | $\frac{3}{3}  \frac{4}{4}  \frac{5}{5}  \frac{6}{6}  \overline{7}$ tegrated Circuit IC $4$ |

## 3.3. AND Gate

The AND gate has a high output only when all inputs are high. In other words the AND gate is an all or nothing gate, a high output occurs only when all inputs are high.

| T.T (Truth Table) |     |   |  |
|-------------------|-----|---|--|
| I                 | O/P |   |  |
| А                 | В   | У |  |
| 0                 | 0   | 0 |  |
| 0                 | 1   | 0 |  |
| 1                 | 0   | 0 |  |
| 1                 | 1   | 1 |  |



Symbol for digital logic cct.



**Algebraic Function** 



**Integrated Circuit IC** 

# 3.4. NOR Gate

Read this as **y** equals Not(A OR B). The only way to get a high output is to have both inputs low.



| T.T (Truth Table) |    |     |  |
|-------------------|----|-----|--|
| I/]               | Ps | O/P |  |
| A=                | В  | у   |  |
| 0                 | 0  | 1   |  |
| 1                 | 1  | 0   |  |
| 0                 | 0  | 1   |  |
| 1                 | 1  | 0   |  |

If A=B i.e. I/Ps are shorted



So, we get an inverter (Not gate)

# 3.5. NAND Gate

Read this as **y** equals Not(A AND B). The only way to get a low output is for both inputs to be high.

| T.T         | T.T (Truth Table) |     |  |  |
|-------------|-------------------|-----|--|--|
| <b>I</b> /] | Ps                | O/P |  |  |
| А           | В                 | у   |  |  |
| 0           | 0                 | 1   |  |  |
| 0           | 1                 | 1   |  |  |
| 1           | 0                 | 1   |  |  |
| 1           | 1                 | 0   |  |  |



Symbol for digital logic cct.

y=A.B Algebraic Function If A=B i.e. I/Ps are shorted

| T.T (Truth Table) |    |     |  |
|-------------------|----|-----|--|
| I/2               | Ps | O/P |  |
| A=                | В  | у   |  |
| 0                 | 0  | 1   |  |
| 1                 | 1  | 0   |  |
| 0                 | 0  | 1   |  |
| 1                 | 1  | 0   |  |



So, we get an inverter (Not gate)

## 4. De-Morgan's Theorems

Much of today logic implementation is based upon a set of rules called De-Morgan's theorems. Basically these theorems demonstrate that, any logic function can be formed from AND and NOT gates (NAND) or from OR and NOT gates (NOR). These rules can be summarized as follows:

## 4.1. The complement of sum equals the product of the complements i.e.:



2016-2017

Dr Waleed Al-Saedi

| Truth | Table  | ТТ  |
|-------|--------|-----|
| IIuui | 1 auto | 1.1 |

| A | В | $y = \overline{A.B}$ | Ā | $\overline{B}$ | $y = \bar{A} + \bar{B}$ |
|---|---|----------------------|---|----------------|-------------------------|
| 0 | 0 | 1                    | 1 | 1              | 1                       |
| 0 | 1 | 1                    | 1 | 0              | 1                       |
| 1 | 0 | 1                    | 0 | 1              | 1                       |
| 1 | 1 | 0                    | 0 | 0              | 0                       |

A NAND gate and bubbled OR gate are equivalent

## 5. Laws and theorems of Boolean Algebra

## **Properties of Boolean Algebra**

When we simplify a complicated Boolean expression we change a complicated digital circuit into simpler one.

## 5.1. The first group of laws are backbone of Boolean algebra

| • x=0        |                    | if x≠1         | ٠ | x+0=x                |
|--------------|--------------------|----------------|---|----------------------|
| x=1          |                    | if x≠0         |   | x.0=0                |
| • x.y=1      | ٦                  | if x=1 and y=1 | • | x+1=x                |
| =0           | ŀ                  | otherwise      |   | x.1=x                |
| x+y=0        | Ī                  | if x=0 and y=0 | • | $x+\bar{x}=1$        |
| =1           | ſ                  | otherwise      |   | $x.\overline{x} = 0$ |
| • if x=0 the | $n \overline{x} =$ | = 1            | • | x+x=x                |

if x=1 then  $\bar{x} = 0$ 

x.x=x

## 5.2. The second group of Boolean algebra

#### • Distributive laws

| x(y+z) | ) = xy   | +xz | OR distributive law |  |  |  |
|--------|----------|-----|---------------------|--|--|--|
| _      | <i>.</i> |     |                     |  |  |  |

- x + yz = (x + y)(x + z) AND distributive law
- Commutative laws

x + y = y + x

xy = yx

• Associative laws

(x + y) + z = x + (y + z) = x + y + z

(x.y).z = x.(y.z) = x.y.z

| Morgan's theorems                                                                                                                                                                                                                                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\overline{\overline{X}} = X$                                                                                                                                                                                                                    |
| $\overline{x+y+z+w} = \overline{x}.\overline{y}.\overline{z}.\overline{w}$                                                                                                                                                                       |
| $\overline{x.y.z.w} = \overline{x} + \overline{y} + \overline{z} + \overline{w}$                                                                                                                                                                 |
| Ex: $\overline{x + y + z + w} = \overline{\overline{x} \cdot \overline{y} \cdot \overline{z} \cdot \overline{w}} = \overline{\overline{x}} + \overline{\overline{y}} + \overline{\overline{z}} + \overline{\overline{w}} = x + y + z + w$        |
| <ul> <li>5.4. Other theorems</li> <li>A+AB=A</li> <li>A(A+B)=A</li> <li>(A+B)(A+C)=A+BC</li> <li>A+ĀB=A+B</li> <li>L.H.S=A(1+B)+ ĀB=A+AB+ĀB=A+B(A+Ā)=A+B=R.H.S</li> <li>A(Ā+B)=AB</li> <li>(A+B)(Ā+C)=AC+ĀB</li> <li>AB+ĀC=(A+C)(Ā+B)</li> </ul> |
| Example 5:                                                                                                                                                                                                                                       |
| To build $y = ABC + A\overline{B}C + AB\overline{C}$                                                                                                                                                                                             |
|                                                                                                                                                                                                                                                  |

The third group of laws are the double complement theorem an De-

So we need 3-input OR gate, three 3-input AND gates, and two Not gates to build above cct. Using laws and theorems of Boolean algebra to simplify the following expression.

 $y = ABC + A\overline{B}C + AB\overline{C} = AB(C + \overline{C}) + A\overline{B}C$  since  $C + \overline{C} = 1$ 

5.3.

Dr Waleed Al-Saedi

Y



Example 6: write the Boolean equation for the output of the circuit then find the T.T.



| T.T (Truth Table) |   |    |   |  |  |
|-------------------|---|----|---|--|--|
| В                 | Α | y1 | У |  |  |
| 0                 | 0 | 0  | 0 |  |  |
| 0                 | 1 | 1  | 1 |  |  |
| 1                 | 0 | 1  | 0 |  |  |
| 1                 | 1 | 1  | 1 |  |  |

Example 7: write the Boolean equation for the output of the circuit then find the T.T.



| T.T (Truth Table) |   |    |   |  |  |
|-------------------|---|----|---|--|--|
| В                 | А | y1 | У |  |  |
| 0                 | 0 | 0  | 0 |  |  |
| 0                 | 1 | 1  | 0 |  |  |
| 1                 | 0 | 1  | 1 |  |  |
| 1                 | 1 | 1  | 1 |  |  |





## 6. Arithmetic Circuits

Digital electronics enables us to build circuits that duplicate some of processes for our minds. By combining AND, OR and NOT circuits in the right way, we can build circuits that add and subtract.

The basics of the arithmetic circuits are:

- 1. Exclusive OR Gate.
- 2. Half and Full Adder.
- 3. Half and Full Subtractor.
- 4. 8421 adders.

## 6.1. Exclusive OR (XOR) Gate

XOR gate has two or more input signals but only one output signal. A 2-input XOR has an output of "1" if one of the inputs is "1" and an output of "0" if both inputs are equivalents, i.e. the inputs must be different to get a high O/P.





#### 6.2. Applications of XOR gate

#### 6.2.1. Parity checking bit:

The basic of most error protection in the odd or even parity check. A single bit will be added to each N-bit word so that the number of ones is always odd or even. The XOR gate is the most suitable circuit to provide parity checker.

#### How to build a circuit of four-bit parity generator "even parity"



Check bit is a bit added to the end of string of binary code that indicates whether the no. of bits in the string with value "1" is even or odd.

## Another way of building a 4-bit parity checker



Four-bit parity checker

| J |     |         |        |         |          |
|---|-----|---------|--------|---------|----------|
| - | The | T.T. fo | or the | 4-I/P v | variable |
|   | D   | С       | В      | А       | у        |
|   | 0   | 0       | 0      | 0       | 0        |
|   | 0   | 0       | 0      | 1       | 1        |
|   | 0   | 0       | 1      | 0       | 1        |
|   | 0   | 0       | 1      | 1       | 0        |
|   | 0   | 1       | 0      | 0       | 1        |
|   | 0   | 1       | 0      | 1       | 0        |
|   | 0   | 1       | 1      | 0       | 0        |
|   | 0   | 1       | 1      | 1       | 1        |
|   | 1   | 0       | 0      | 0       | 1        |
|   | 1   | 0       | 0      | 1       | 0        |
|   | 1   | 0       | 1      | 0       | 0        |
|   | 1   | 0       | 1      | 1       | 1        |
|   | 1   | 1       | 0      | 0       | 0        |
|   | 1   | 1       | 0      | 1       | 1        |
|   | 1   | 1       | 1      | 0       | 1        |
|   | 1   | 1       | 1      | 1       | 0        |

**Hint:** In odd parity generator we need to complement the O/P.

**Hint:** The error will be accepted as true. The check is only reliable as a single error detecting code.

6.2.2. Controlled inverter (programmed inverter)

The controlled inverter is used in the complement for subtraction.



#### 6.2.3. Binary to Gray conversion

Gray code is unweighted code, not suitable for arithmetic usage. It has a lot of applications in I/P-O/P devices such as encoder, analog-to-digital converters (ADC), etc.  $y_1$ 

One of the main problems in a binary number system when going from one number to the next is that more than one position may change at the same time. For example, when  $0111_2$  advances to  $1000_2$ . Four digits must change simultaneously, so we can use gray code instead of binary in which every number differs from the preceding number by a single bit.

#### How to convert from binary to gray?

- 1. Gray digit is the same as the first binary digit.
- 2. Add the 1<sup>st</sup> binary to the 2<sup>nd</sup> binary.





2016-2017

#### 6.3. Half-Adder (H.A)

It adds two binary digits at a time.

0+0=0 0+1=1 1+0=1

 $1+1=0 \rightarrow \text{with a carry } c=1$ 

Example 10: Add the two binary numbers A (=1010<sub>2</sub>) and B (=0010<sub>2</sub>).

| carry |   |   | 1 |   |
|-------|---|---|---|---|
| А     | 1 | 0 | 1 | 0 |
| В     | 0 | 0 | 1 | 0 |
|       | 1 | 1 | 0 | 0 |

Example 11: Add the two floating point numbers A  $(=1101.1010_2)$  and B  $(=0110.1100_2)$ .



 $Sum = \overline{A}B + A\overline{B} = A \bigoplus B$ 

Carry=AB





## 6.4. Full-Adder (F.A)

When adding two binary numbers, you may have a carry one column to the next. Practically, we need a logic circuit that adds (or handle) binary digits at a time. This next circuit is named Full-Adder.

| С | В | А | Sum | Carry |
|---|---|---|-----|-------|
| 0 | 0 | 0 | 0   | 0     |
| 0 | 0 | 1 | 1   | 0     |
| 0 | 1 | 0 | 1   | 0     |
| 0 | 1 | 1 | 0   | 1     |
| 1 | 0 | 0 | 1   | 0     |
| 1 | 0 | 1 | 0   | 1     |
| 1 | 1 | 0 | 0   | 1     |
| 1 | 1 | 1 | 1   | 1     |



 $Sum = A\overline{B}\overline{C} + \overline{A}B\overline{C} + \overline{A}\overline{B}C + ABC = \overline{C}(A\overline{B} + \overline{A}B) + C(\overline{A}\overline{B} + AB) = \overline{C}(A \oplus B) + C(\overline{A} \oplus B)$ Let  $(A \oplus B) = X$ 

 $Sum = \overline{C}X + C\overline{X} = C \bigoplus X = C \bigoplus A \bigoplus B$ 

 $Carry=AB\overline{C} + A\overline{B}C + \overline{A}BC + ABC = AB\overline{C} + C(A\overline{B}+\overline{A}B) + ABC = AB(\overline{C}+C) + C(A \bigoplus B)$ Since  $C+\overline{C}=1$ 

Carry=AB + C(A $\oplus$ B)



## 6.5. Parallel Adder

Several full adders can be connected as shown below to add two binary numbers.  $A=A_0A_1A_2A_3...A_n$ 

 $B=B_0B_1B_2B_3...B_n$ 

Only the 1<sup>st</sup> column requires a half-adder while other columns uses full adders since there may be a carry from the preceding columns.



#### 6.6. Half-Subtractor (H.S)

In binary subtraction:



## 6.7. Full-Subtractor (F.S)

| С | В | А | Diff | Borrow |
|---|---|---|------|--------|
| 0 | 0 | 0 | 0    | 0      |
| 0 | 0 | 1 | 1    | 0      |
| 0 | 1 | 0 | 1    | 1      |
| 0 | 1 | 1 | 0    | 0      |
| 1 | 0 | 0 | 1    | 1      |
| 1 | 0 | 1 | 0    | 0      |
| 1 | 1 | 0 | 0    | 1      |
| 1 | 1 | 1 | 1    | 1      |
|   |   |   |      |        |

2016-2017

Dr Waleed Al-Saedi

Diff=  $A\overline{B}\overline{C} + \overline{A}B\overline{C} + \overline{A}\overline{B}C + ABC = \overline{C}(A\overline{B} + \overline{A}B) + C(\overline{A}\overline{B} + AB) = \overline{C}(A \oplus B) + C(\overline{A} \oplus B)$ Let  $(A \oplus B) = X$ Diff= $\overline{C}X + C\overline{X} = C \oplus X = C \oplus A \oplus B$ Borrow= $\overline{A}B\overline{C} + \overline{A}\overline{B}C + \overline{A}BC + ABC = \overline{A}B(\overline{C}+C) + C(\overline{A}\overline{B}+AB)$ Since  $C + \overline{C} = 1$ Borrow= $\overline{A}B + C(A \oplus B)$ 



**Full-Subtractor** 

# 6.8. Subtraction using 1's and 2's complement 6.8.1. 1's complement subtraction

Instead of subtracting a number, we can add the 1's complement of the number. The last carry is then added to get the final answer. If there is no carry the final answer will have a negative sign and it is in the 1's complement form. To get the true answer take the 1's complement and put a negative sign.

Example 12:

2016-2017

Example 13:

Example 14:

|   | 6  | 1 | 1 | 0 | <b>1's</b>    | 1 | 1 | 0 |   |
|---|----|---|---|---|---------------|---|---|---|---|
| _ | 7  | 1 | 1 | 1 | $\rightarrow$ | 0 | 0 | 0 | + |
|   | -1 |   |   |   |               | 1 | 1 | 0 | - |

No carry which means that the no. is negative.

Example 15:

| 10   | 1 | 0 | 1 | 0 | 1's           | 1 | 0 | 1 | 0 |   |          |               |    |   |   |   |
|------|---|---|---|---|---------------|---|---|---|---|---|----------|---------------|----|---|---|---|
| - 14 | 1 | 1 | 1 | 0 | $\rightarrow$ | 0 | 0 | 0 | 1 | + |          | 1's           |    |   |   |   |
| -4   |   |   |   |   | -             | 1 | 0 | 1 | 1 | - | No carry | $\rightarrow$ | -0 | 1 | 0 | 0 |

#### 6.8.2. 1's complement subtraction

We can add the 2's complement of the number instead of subtracting it. **Hint:** if there is carry neglect it to get the true answer. If there is no carry take 2's complement of the result and put a negative sign to get the true answer.

```
Example 15:
```

14 1 1 1 0 1's 2's 1 1 0 1 0  $\rightarrow$  0 1 0 1  $\rightarrow$ 0 1 0 1 10 4 1 + 1 1 0 0 Then Note: If the final carry over the 1 1 1 1 1 sum is 1. It is dropped and the 0 1 result is positive. 0 1 0 + 1 0 1 00 22

**Example 16:** 5 1's 2's 0 1 0 1 1 1 1 0 0 0 1 0 0 0 1 0  $\rightarrow$ 14 1 -9 0 1 0 Then 0 1 0 1 0 0 1 0 + 1 1  $\rightarrow$  Note: The two's complement of the No carry sum will be the result and it is ↓ 1's negative.  $1 \ 0 \ 0 \ 0$  $\downarrow$  2's <u>1</u> + 0 1 0

#### 6.9. Parallel four-bit Adder-Subtractor

A four-bit Adder-Subtractor is shown below. The I/P Z controls the operation of the circuit. When Z=0 the circuit functions as an adder, and when Z=1 the circuit functions as a Subtractor. Each XOR gate receives input Z and one of the inputs of B. when Z=0, we have  $B \oplus 0=B$ . the full adders receive the value of B, the input carry is '0', and the circuit performs A+B.

When Z=1, we have  $B \bigoplus 1 = \overline{B}$  and  $C_0 = 1$ . The B inputs are all complemented and a '1' is added through the input carry. The circuit performs the operation A plus the 2's complement of B. the XOR with output y is for detecting an over flow.



2016-2017

Dr Waleed Al-Saedi