#### **CHAPTER 2**

THE LOGIC OF COMPOUND STATEMENTS

Copyright © Cengage Learning. All rights reserved.



Copyright © Cengage Learning. All rights reserved.

The drawing in Figure 2.4.1(a) shows the appearance of the two positions of a simple switch. When the switch is closed, current can flow from one terminal to the other; when it is open, current cannot flow.

Imagine that such a switch is part of the circuit shown in figure 2.4.1(b). The light bulb turns on if, and only if, current flows through it. And this happens if, and only if, the switch is closed.



Now consider the more complicated circuits of Figures 2.4.2(a) and 2.4.2(b).



In the circuit of Figure  $2.4 \mathfrak{P}(a)^2$  current flows and the light bulb turns on if, and only if, *both* switches *P* and *Q* are closed. The switches in this circuit are said to be **in series**.

In the circuit of Figure 2.4.2(b) current flows and the light bulb turns on if, and only if, *at least one* of the switches *P* or *Q* is closed. The switches in this circuit are said to be **in parallel**. All possible behaviors of these circuits are described by Table 2.4.1.

| Switches |        | Light Bulb |
|----------|--------|------------|
| Р        | Q      | State      |
| closed   | closed | on         |
| closed   | open   | off        |
| open     | closed | off        |
| open     | open   | off        |

| Switches |        | Light Bulb |
|----------|--------|------------|
| Р        | Q      | State      |
| closed   | closed | on         |
| closed   | open   | on         |
| open     | closed | on         |
| open     | open   | off        |

(b) Switches in Parallel

(a) Switches in Series

Observe that if the words *closed* and *on* are replaced by T and *open* and *off* are replaced by F, Table 2.4.1(a) becomes the truth table for *and* and Table 2.4.1(b) becomes the truth table for *or*.

Consequently, the switching circuit of Figure 2.4.2(a) is said to correspond to the logical expression  $P \land Q$ , and that of Figure 2.4.2(b) is said to correspond to  $P \lor Q$ .



More complicated circuits correspond to more complicated logical expressions. This correspondence has been used extensively in the design and study of circuits.

Electrical engineers continue to use the language of logic when they refer to values of signals produced by an electronic switch as being "true" or "false." But they generally use the symbols 1 and 0 rather than T and F to denote these values.

The symbols 0 and 1 are called **bits**, short for *b*inary dig*its*. This terminology was introduced in 1946 by the statistician John Tukey.

Combinations of signal bits (1's and 0's) can be transformed into other combinations of signal bits (1's and 0's) by means of various circuits.

Because a variety of different technologies are used in circuit construction, computer engineers and digital system designers find it useful to think of certain basic circuits as black boxes.

The inside of a black box contains the detailed implementation of the circuit and is often ignored while attention is focused on the relation between the **input** and the **output** signals.



The operation of a black box is completely specified by constructing an **input/output table** that lists all its possible input signals together with their corresponding output signals.

For example, the black box picture has three input signals. Since each of these signals can take the value 1 or 0, there are eight possible combinations of input signals.

One possible correspondence of input to output signals is as follows:

|   | Input | Output |   |
|---|-------|--------|---|
| Р | Q     | R      | S |
| 1 | 1     | 1      | 1 |
| 1 | 1     | 0      | 0 |
| 1 | 0     | 1      | 0 |
| 1 | 0     | 0      | 1 |
| 0 | 1     | 1      | 0 |
| 0 | 1     | 0      | 1 |
| 0 | 0     | 1      | 1 |
| 0 | 0     | 0      | 0 |

An Input/Output Table

An efficient method for designing more complicated circuits is to build them by connecting less complicated black box circuits. Three such circuits are known as NOT-, AND-, and OR-gates.

A **NOT-gate** (or **inverter**) is a circuit with one input signal and one output signal. If the input signal is 1, the output signal is 0.

Conversely, if the input signal is 0, then the output signal is 1. An **AND-gate** is a circuit with two input signals and one output signal. If both input signals are 1, then the output signal is 1.

Otherwise, the output signal is 0. An **OR-gate** also has two input signals and one output signal. If both input signals are 0, then the output signal is 0. Otherwise, the output signal is 1.

The actions of NOT-, AND-, and OR-gates are summarized in Figure 2.4.3, where *P* and *Q* represent input signals and *R* represents the output signal.





It should be clear from Figure 2.4.3 that the actions of the NOT-, AND-, and OR-gates on signals correspond exactly to those of the logical connectives  $\sim$ ,  $\wedge$ , and  $\vee$  on statements, if the symbol 1 is identified with T and the symbol 0 is identified with F.

Gates can be combined into circuits in a variety of ways. If the rules shown on the next page are obeyed, the result is a **combinational circuit**, one whose output at any time is determined entirely by its input at that time without regard to previous inputs.

### **Rules for a Combinational Circuit**

### Rules for a Combinational Circuit

Never combine two input wires. 2.4.1

A single input wire can be split partway and used as input for two separate gates. 2.4.2

An output wire can be used as input. 2.4.3

No output of a gate can eventually feed back into that gate. 2.4.4

Rule (2.4.4) is violated in more complex circuits, called **sequential circuits**, whose output at any given time depends both on the input at that time and also on previous inputs.

# The Input/Output Table for a Circuit

### The Input/Output Table for a Circuit

If you are given a set of input signals for a circuit, you can find its output by tracing through the circuit gate by gate.

#### Example 1 – Determining Output for a Given Input

Indicate the output of the circuits shown below for the given input signals.

a. P NOT AND R

b.

Input signals: P = 0 and Q = 1

Input signals: P = 1, Q = 0, R = 1



### Example 1(a) – Solution

Move from left to right through the diagram, tracing the action of each gate on the input signals.

The NOT-gate changes P = 0 to a 1, so both inputs to the AND-gate are 1; hence the output *R* is 1.

This is illustrated by annotating the diagram as shown below.

$$P \xrightarrow{0} NOT \xrightarrow{1} AND \xrightarrow{1} R$$
  
 $Q \xrightarrow{1}$ 

### Example 1(b) – Solution

The output of the OR-gate is 1 since one of the input signals, P, is 1. The NOT-gate changes this 1 into a 0, so the two inputs to the AND-gate are 0 and R = 1.

cont'd

Hence the output *S* is 0. The trace is shown below.



### The Boolean Expression Corresponding to a Circuit

#### The Boolean Expression Corresponding to a Circuit

In logic, variables such as p, q and r represent statements, and a statement can have one of only two truth values: T(true) or F(false).

A statement form is an expression, such as  $p \land (\sim q \lor r)$ , composed of statement variables and logical connectives.

As noted earlier, one of the founders of symbolic logic was the English mathematician George Boole. In his honor, any variable, such as a statement variable or an input signal, that can take one of only two values is called a **Boolean variable.** An expression composed of Boolean variables and the connectives  $\sim$ ,  $\wedge$ , and  $\vee$  is called a **Boolean expression**.

#### Example 3 – Finding a Boolean Expression for a Circuit

Find the Boolean expressions that correspond to the circuits shown below. A dot indicates a soldering of two wires; wires that cross without a dot are assumed not to touch.



### Example 3(a) – Solution

Trace through the circuit from left to right, indicating the output of each gate symbolically, as shown below.



The final expression obtained,  $(P \lor Q) \land \sim (P \land Q)$ , is the expression for exclusive or: *P* or *Q* but not both.

### Example 3(b) – Solution

The Boolean expression corresponding to the circuit is  $(P \land Q) \land \neg R$ , as shown below.

cont'd



### The Boolean Expression Corresponding to a Circuit

Observe that the output of the circuit shown in Example 3(b) is 1 for exactly one combination of inputs (P = 1, Q = 1, and R = 0) and is 0 for all other combinations of inputs.

For this reason, the circuit can be said to "recognize" one particular combination of inputs. The output column of the input/output table has a 1 in exactly one row and 0's in all other rows.

| P | Q | R | $(P \land Q) \land \sim R$ |
|---|---|---|----------------------------|
| 1 | 1 | 1 | 0                          |
| 1 | 1 | 0 | 1                          |
| 1 | 0 | 1 | 0                          |
| 1 | 0 | 0 | 0                          |
| 0 | 1 | 1 | 0                          |
| 0 | 1 | 0 | 0                          |
| 0 | 0 | 1 | 0                          |
| 0 | 0 | 0 | 0                          |

Input/Output Table for a Recognizer

#### Definition

A recognizer is a circuit that outputs a 1 for exactly one particular combination of input signals and outputs 0's for all other combinations.

### The Circuit Corresponding to a Boolean Expression

#### Example 4 – Constructing Circuits for Boolean Expressions

Construct circuits for the following Boolean expressions. **a.**  $(\sim P \land Q) \lor \sim Q$  **b.**  $((P \land Q) \land (R \land S)) \land T$ 

#### Solution:

**a.** Write the input variables in a column on the left side of the diagram. Then go from the right side of the diagram to the left, working from the outermost part of the expression to the innermost part.

Since the last operation executed when evaluating  $(\sim P \land Q) \lor \sim Q$  is  $\lor$ , put an OR-gate at the extreme right of the diagram.

cont'd

One input to this gate is  $\sim P \land Q$ , so draw an AND-gate to the left of the OR-gate and show its output coming into the OR-gate.

Since one input to the AND-gate is  $\sim P$ , draw a line from P to a NOT-gate and from there to the AND-gate. Since the other input to the AND-gate is Q, draw a line from Q directly to the AND-gate.

The other input to the OR-gate is  $\sim Q$ , so draw a line from Q to a NOT-gate and from the NOT-gate to the OR-gate. The circuit you obtain is shown below.



**b.** To start constructing this circuit, put one AND-gate at the extreme right for the  $\land$  between (( $P \land Q$ )  $\land$  ( $R \land S$ )) and *T*.

cont'd

To the left of that put the AND-gate corresponding to the  $\land$  between  $P \land Q$  and  $R \land S$ .

To the left of that put the AND-gates corresponding to the  $\wedge$ 's between *P* and *Q* and between *R* and S.

The circuit is shown in Figure 2.4.4.



Figure 2.4.4

#### The Circuit Corresponding to a Boolean Expression

# It follows from Theorem 2.1.1 that all the ways of adding parentheses to $P \land Q \land R \land S \land T$ are logically equivalent.

#### **Theorem 2.1.1 Logical Equivalences**

Given any statement variables p, q, and r, a tautology **t** and a contradiction **c**, the following logical equivalences hold.

| 1. Commutative laws:      | $p \wedge q \equiv q \wedge p$                              | $p \lor q \equiv q \lor p$                              |
|---------------------------|-------------------------------------------------------------|---------------------------------------------------------|
| 2. Associative laws:      | $(p \wedge q) \wedge r \equiv p \wedge (q \wedge r)$        | $(p \lor q) \lor r \equiv p \lor (q \lor r)$            |
| 3. Distributive laws:     | $p \wedge (q \vee r) \equiv (p \wedge q) \vee (p \wedge r)$ | $p \lor (q \land r) \equiv (p \lor q) \land (p \lor r)$ |
| 4. Identity laws:         | $p \wedge \mathbf{t} \equiv p$                              | $p \lor \mathbf{c} \equiv p$                            |
| 5. Negation laws:         | $p \lor \sim p \equiv \mathbf{t}$                           | $p \wedge \sim p \equiv \mathbf{c}$                     |
| 6. Double negative law:   | $\sim (\sim p) \equiv p$                                    |                                                         |
| 7. Idempotent laws:       | $p \land p \equiv p$                                        | $p \lor p \equiv p$                                     |
| 8. Universal bound laws:  | $p \lor \mathbf{t} \equiv \mathbf{t}$                       | $p \wedge \mathbf{c} \equiv \mathbf{c}$                 |
| 9. De Morgan's laws:      | $\sim (p \land q) \equiv \sim p \lor \sim q$                | $\sim (p \lor q) \equiv \sim p \land \sim q$            |
| 10. Absorption laws:      | $p \lor (p \land q) \equiv p$                               | $p \land (p \lor q) \equiv p$                           |
| 11. Negations of t and c: | $\sim t \equiv c$                                           | $\sim c \equiv t$                                       |

#### The Circuit Corresponding to a Boolean Expression

#### Thus, for example, $((P \land Q) \land (R \land S)) \land T \equiv (P \land (Q \land R)) \land (S \land T).$

It also follows that the circuit in Figure 2.4.5, which corresponds to  $(P \land (Q \land R)) \land (S \land T)$ , has the same input/ output table as the circuit in Figure 2.4.4, which corresponds to  $((P \land Q) \land (R \land S)) \land T$ .



Figure 2.4.5

Figure 2.4.4

#### The Circuit Corresponding to a Boolean Expression

Each of the circuits in Figures 2.4.4 and 2.4.5 is, therefore, an implementation of the expression  $P \land Q \land R \land S \land T$ . Such a circuit is called a **multiple-input AND-gate** and is represented by the diagram shown in Figure 2.4.6.





Multiple-input OR-gates are constructed similarly.

#### Finding a Circuit That Corresponds to a Given Input/Output Table

#### Example 5 – Designing a Circuit for a Given Input/Output Table

Design a circuit for the following input/output table:

|   | Input |   | Output |
|---|-------|---|--------|
| Р | Q     | R | S      |
| 1 | 1     | 1 | 1      |
| 1 | 1     | 0 | 0      |
| 1 | 0     | 1 | 1      |
| 1 | 0     | 0 | 1      |
| 0 | 1     | 1 | 0      |
| 0 | 1     | 0 | 0      |
| 0 | 0     | 1 | 0      |
| 0 | 0     | 0 | 0      |

First construct a Boolean expression with this table as its truth table. To do this, identify each row for which the output is 1—in this case, the first, third, and fourth rows.

For each such row, construct an *and* expression that produces a 1 (or true) for the exact combination of input values for that row and a 0 (or false) for all other combinations of input values.

For example, the expression for the first row is  $P \land Q \land R$ because  $P \land Q \land R$  is 1 if P = 1 and Q = 1 and R = 1, and it is 0 for all other values of P, Q, and R.

The expression for the third row is  $P \land \sim Q \land R$  because  $P \land \sim Q \land R$  is 1 if P = 1 and Q = 0 and R = 1, and it is 0 for all other values of P, Q, and R. Similarly, the expression for the fourth row is  $P \land \sim Q \land \sim R$ .

cont'd

Now any Boolean expression with the given table as its truth table has the value 1 in case  $P \land Q \land R = 1$ , or in case  $P \land \sim Q \land \sim R = 1$ , or in case  $P \land \sim Q \land \sim R = 1$ , and in no other cases.

It follows that a Boolean expression with the given truth table is

$$(P \land Q \land R) \lor (P \land \neg Q \land R) \lor (P \land \neg Q \land \neg R).$$
 2.4.5

The circuit corresponding to this expression has the diagram shown in Figure 2.4.7.

cont'd



Figure 2.4.7

#### Observe that expression $(P \land Q \land R) \lor (P \land \neg Q \land R) \lor (P \land \neg Q \land \neg R).$ 2.4.5

cont'd

is a disjunction of terms that are themselves conjunctions in which one of P or  $\sim P$ , one of Q or  $\sim Q$ , and one of R or  $\sim R$  all appear.

Such expressions are said to be in **disjunctive normal form** or **sum-of-products form**.

Consider the two combinational circuits shown in Figure 2.4.8.



Figure 2.4.8

If you trace through circuit (a), you will find that its input/ output table is

| Inj | put | Output |
|-----|-----|--------|
| Р   | Q   | R      |
| 1   | 1   | 1      |
| 1   | 0   | 0      |
| 0   | 1   | 0      |
| 0   | 0   | 0      |

which is the same as the input/output table for circuit (b). Thus these two circuits do the same job in the sense that they transform the same combinations of input signals into the same output signals.

Yet circuit (b) is simpler than circuit (a) in that it contains many fewer logic gates. Thus, as part of an integrated circuit, it would take less space and require less power.

#### Definition

Two digital logic circuits are **equivalent** if, and only if, their input/output tables are identical.

#### Example 6 – Showing That Two Circuits Are Equivalent

Find the Boolean expressions for each circuit in Figure 2.4.8. Use Theorem 2.1.1 to show that these expressions are logically equivalent when regarded as statement forms.



#### Theorem 2.1.1 Logical Equivalences

Given any statement variables p, q, and r, a tautology **t** and a contradiction **c**, the following logical equivalences hold.

cont'd

| 1. Commutative laws:      | $p \wedge q \equiv q \wedge p$                           | $p \lor q \equiv q \lor p$                              |
|---------------------------|----------------------------------------------------------|---------------------------------------------------------|
| 2. Associative laws:      | $(p \land q) \land r \equiv p \land (q \land r)$         | $(p \lor q) \lor r \equiv p \lor (q \lor r)$            |
| 3. Distributive laws:     | $p \land (q \lor r) \equiv (p \land q) \lor (p \land r)$ | $p \lor (q \land r) \equiv (p \lor q) \land (p \lor r)$ |
| 4. Identity laws:         | $p \wedge \mathbf{t} \equiv p$                           | $p \lor \mathbf{c} \equiv p$                            |
| 5. Negation laws:         | $p \lor \sim p \equiv \mathbf{t}$                        | $p \wedge \sim p \equiv \mathbf{c}$                     |
| 6. Double negative law:   | $\sim (\sim p) \equiv p$                                 |                                                         |
| 7. Idempotent laws:       | $p \wedge p \equiv p$                                    | $p \lor p \equiv p$                                     |
| 8. Universal bound laws:  | $p \lor \mathbf{t} \equiv \mathbf{t}$                    | $p \wedge \mathbf{c} \equiv \mathbf{c}$                 |
| 9. De Morgan's laws:      | $\sim (p \land q) \equiv \sim p \lor \sim q$             | $\sim (p \lor q) \equiv \sim p \land \sim q$            |
| 10. Absorption laws:      | $p \lor (p \land q) \equiv p$                            | $p \land (p \lor q) \equiv p$                           |
| 11. Negations of t and c: | $\sim t \equiv c$                                        | $\sim c \equiv t$                                       |

The Boolean expressions that correspond to circuits (a) and (b) are  $((P \land \neg Q) \lor (P \land Q)) \land Q$  and  $P \land Q$ , respectively.

By Theorem 2.1.1,

 $((P \land \sim Q) \lor (P \land Q)) \land Q$   $\equiv (P \land (\sim Q \lor Q)) \land Q \qquad \text{by the distributive law}$  $\equiv (P \land (Q \lor \sim Q)) \land Q \qquad \text{by the commutative law for } \lor$ 

 $\equiv (P \land \mathbf{t}) \land Q \qquad \qquad \text{by the negation law}$ 

It follows that the truth tables for  $((r \land \sim Q) \lor (r \land Q)) \land Q$ and  $P \land Q$  are the same.

Hence the input/output tables for the circuits corresponding to these expressions are also the same, and so the circuits are equivalent.

Another way to simplify a circuit is to find an equivalent circuit that uses the least number of different kinds of logic gates.

Two gates not previously introduced are particularly useful for this: NAND-gates and NOR-gates. A NAND-gate is a single gate that acts like an AND-gate followed by a NOT-gate. A NOR-gate acts like an OR-gate followed by a NOT-gate.

Thus the output signal of a NAND-gate is 0 when, and only when, both input signals are 1, and the output signal for a NOR-gate is 1 when, and only when, both input signals are 0.

The logical symbols corresponding to these gates are | (for NAND) and  $\downarrow$  (for NOR), where | is called a **Sheffer stroke** (after H. M. Sheffer, 1882–1964) and  $\downarrow$  is called a **Peirce arrow** (after C. S. Peirce, 1839–1914). Thus

$$P \mid Q \equiv \sim (P \land Q)$$
 and  $P \downarrow Q \equiv \sim (P \lor Q)$ .

The table below summarizes the actions of NAND and NOR gates.



It can be shown that any Boolean expression is equivalent to one written entirely with Sheffer strokes or entirely with Peirce arrows.

Thus any digital logic circuit is equivalent to one that uses only NAND-gates or only NOR-gates.

#### Example 7 – Rewriting Expressions Using the Sheffer Stroke

Use Theorem 2.1.1 and the definition of Sheffer stroke to show that

**a.** 
$$\sim P \equiv P \mid P$$
 and **b.**  $P \lor Q \equiv (P \mid P) \mid (Q \mid Q).$ 

#### Solution:

a.  $\sim P \equiv \sim (P \land P)$  by the idempotent law for  $\land$   $\equiv P \mid P$  by definition of  $\mid$ . b.  $P \lor Q \equiv \sim (\sim (P \lor Q))$  by the double negative law  $\equiv \sim (\sim P \land \sim Q)$  by De Morgan's laws

cont'd

# $\equiv \sim ((P | P) \land (Q | Q)) \quad \text{by part (a)}$ $\equiv (P | P) | (Q | Q) \quad \text{by definition of } |.$



#### Application: Number Systems and Circuits for Addition

Copyright © Cengage Learning. All rights reserved.

#### Application: Number Systems and Circuits for Addition

In elementary school, you learned the meaning of decimal notation: that to interpret a string of decimal digits as a number, you mentally multiply each digit by its place value.

For instance, 5,049 has a 5 in the thousands place, a 0 in the hundreds place, a 4 in the tens place, and a 9 in the ones place. Thus

 $5,049 = 5 \bullet (1,000) + 0 \bullet (100) + 4 \bullet (10) + 9 \bullet (1).$ 

#### Application: Number Systems and Circuits for Addition

Using exponential notation, this equation can be rewritten as  $5,049 = 5 \cdot 10^3 + 0 \cdot 10^2 + 4 \cdot 10^1 + 9 \cdot 10^0$ .

More generally, decimal notation is based on the fact that any positive integer can be written uniquely as a sum of products of the form

*d* ● 10<sup>*n*</sup>,

where each *n* is a nonnegative integer and each *d* is one of the decimal digits 0, 1, 2, 3, 4, 5, 6, 7, 8, or 9.

#### Application: Number Systems and Circuits for Addition

The word *decimal* comes from the Latin root *deci*, meaning "ten." Decimal (or base 10) notation expresses a number as a string of digits in which each digit's position indicates the power of 10 by which it is multiplied.

The right-most position is the ones place (or 10<sup>o</sup> place), to the left of that is the tens place (or 10<sup>1</sup> place), to the left of that is the hundreds place (or 10<sup>2</sup> place), and so forth, as illustrated below.

| Place         | 10 <sup>3</sup> | 10 <sup>2</sup> | 10 <sup>1</sup> | 10 <sup>0</sup> |
|---------------|-----------------|-----------------|-----------------|-----------------|
|               | thousands       | hundreds        | tens            | ones            |
| Decimal Digit | 5               | 0               | 4               | 9               |

In computer science, **base 2 notation**, or **binary notation**, is of special importance because the signals used in modern electronics are always in one of only two states. (The Latin root *bi* means "two.")

We can show that any integer can be represented uniquely as a sum of products of the form

$$d \bullet 2^n$$
,

where each *n* is an integer and each *d* is one of the binary digits (or bits) 0 or 1.

For example,

$$= 1 \cdot 2^4 + 1 \cdot 2^3 + 0 \cdot 2^2 + 1 \cdot 2^1 + 1 \cdot 2^0.$$

The places in binary notation correspond to the various powers of 2.

The right-most position is the ones place (or 2<sup>0</sup> place), to the left of that is the twos place (or 2<sup>1</sup> place), to the left of that is the fours place (or 2<sup>2</sup> place), and so forth, as illustrated below.

| Place        | 2 <sup>4</sup> | 2 <sup>3</sup> | 2 <sup>2</sup> | 2 <sup>1</sup> | 2 <sup>0</sup> |
|--------------|----------------|----------------|----------------|----------------|----------------|
|              | sixteens       | eights         | fours          | twos           | ones           |
| Binary Digit | 1              | 1              | 0              | 1              | 1              |

As in the decimal notation, leading zeros may be added or dropped as desired. For example,

$$003_{10} = 3_{10} = 1 \cdot 2^1 + 1 \cdot 2^0 = 11_2 = 011_2.$$

A list of powers of 2 is useful for doing binary-to-decimal and decimal-to-binary conversions. See Table 2.5.1.

| Power of 2   | 210  | 29  | 2 <sup>8</sup> | 27  | 2 <sup>6</sup> | 2 <sup>5</sup> | 24 | 2 <sup>3</sup> | 2 <sup>2</sup> | 21 | 20 |
|--------------|------|-----|----------------|-----|----------------|----------------|----|----------------|----------------|----|----|
| Decimal Form | 1024 | 512 | 256            | 128 | 64             | 32             | 16 | 8              | 4              | 2  | 1  |

Powers of 2

Table 2.5.1

#### Example 2 – Converting a Binary to a Decimal Number

Represent 110101<sub>2</sub> in decimal notation.

Solution:

 $110101_{2} = 1 \cdot 2^{5} + 1 \cdot 2^{4} + 0 \cdot 2^{3} + 1 \cdot 2^{2} + 0 \cdot 2^{1} + 1 \cdot 2^{0}$ 

= 32 + 16 + 4 + 1

 $= 53_{10}$ 

Alternatively, the schema below may be used.



#### Example 3 – Converting a Decimal to a Binary Number

Represent 209 in binary notation.

#### Solution:

Use Table 2.5.1 to write 209 as a sum of powers of 2, starting with the highest power of 2 that is less than 209 and continuing to lower powers.

| Power of 2   | 210  | 29  | 2 <sup>8</sup> | 27  | 26 | 2 <sup>5</sup> | 24 | 2 <sup>3</sup> | 2 <sup>2</sup> | 21 | 20 |
|--------------|------|-----|----------------|-----|----|----------------|----|----------------|----------------|----|----|
| Decimal Form | 1024 | 512 | 256            | 128 | 64 | 32             | 16 | 8              | 4              | 2  | 1  |

Powers of 2

Table 2.5.1

## Example 3 – Solution

Since 209 is between 128 and 256, the highest power of 2 that is less than 209 is 128. Hence

 $209_{10} = 128 + a$  smaller number.

cont'd

Now 209 - 128 = 81, and 81 is between 64 and 128, so the highest power of 2 that is less than 81 is 64. Hence

 $209_{10} = 128 + 64 + a$  smaller number.

# Example 3 – Solution

cont'd

Continuing in this way, you obtain

$$209_{10} = 128 + 64 + 16 + 1$$

$$= 1 \cdot 2^7 + 1 \cdot 2^6 + 0 \cdot 2^5 + 1 \cdot 2^4 + 0 \cdot 2^3 + 0 \cdot 2^2 + 0 \cdot 2^1 + 1 \cdot 2^0.$$

For each power of 2 that occurs in the sum, there is a 1 in the corresponding position of the binary number.

# Example 3 – Solution

For each power of 2 that is missing from the sum, there is a 0 in the corresponding position of the binary number.

Thus

 $209_{10} = 11010001_2$ 

cont'd

#### **Binary Addition and Subtraction**

#### Example 4 – Addition in Binary Notation

Add  $1101_2$  and  $111_2$  using binary notation.

#### Solution:

Because  $2_{10} = 10_2$  and  $1_{10} = 1_2$ , the translation of  $1_{10} + 1_{10} = 2_{10}$  to binary notation is

$$\frac{1_2}{-1_2}$$

$$\frac{1_2}{10_2}$$

It follows that adding two 1's together results in a carry of 1 when binary notation is used.

# Example 4 – Solution

Adding three 1's together also results in a carry of 1 since  $3_{10} = 11_2$  ("one one base two").

cont'd

$$1_{2}$$
  
+  $1_{2}$   
+  $1_{2}$   
 $1_{12}$ 

Thus the addition can be performed as follows:

#### Example 5 – Subtraction in Binary Notation

Subtract 1011<sub>2</sub> from 11000<sub>2</sub> using binary notation.

#### Solution:

In decimal subtraction the fact that  $10_{10} - 1_{10} = 9_{10}$  is used to borrow across several columns. For example, consider the following:

$$\begin{array}{r}
9 & 9 \\
1 & 1 \\
\hline
0 & 0 & 0_{10} \\
- & 5 & 8_{10} \\
\hline
9 & 4 & 2_{10}
\end{array}$$

# Example 5 – Solution

In binary subtraction it may also be necessary to borrow across more than one column. But when you borrow a  $1_2$  from  $10_2$ , what remains is  $1_2$ .

 $\begin{array}{r}
 10_2 \\
 - 1_2 \\
 1_2
 \end{array}$ 

Thus the subtraction can be performed as follows:

Consider the question of designing a circuit to produce the sum of two binary digits *P* and *Q*. Both *P* and *Q* can be either 0 or 1. And the following facts are known:

$$1_{2} + 1_{2} = 10_{2},$$
  

$$1_{2} + 0_{2} = 1_{2} = 01_{2},$$
  

$$0_{2} + 1_{2} = 1_{2} = 01_{2},$$
  

$$0_{2} + 0_{2} = 0_{2} = 00_{2}.$$

It follows that the circuit to be designed must have two outputs—one for the left binary digit (this is called the **carry**) and one for the right binary digit (this is called the **sum**).

The carry output is 1 if both *P* and *Q* are 1; it is 0 otherwise. Thus the carry can be produced using the AND-gate circuit that corresponds to the Boolean expression  $P \land Q$ . The sum output is 1 if either *P* or *Q*, but not both, is 1.

The sum can, therefore, be produced using a circuit that corresponds to the Boolean expression for *exclusive or*:  $(P \lor Q) \land \sim (P \land Q)$ . Hence, a circuit to add two binary digits *P* and *Q* can be constructed as in Figure 2.5.1. This circuit is called a **half-adder**.

#### HALF-ADDER



Circuit

Input/Output Table

| P | Q | Carry | Sum |
|---|---|-------|-----|
| 1 | 1 | 1     | 0   |
| 1 | 0 | 0     | 1   |
| 0 | 1 | 0     | 1   |
| 0 | 0 | 0     | 0   |

Circuit to Add P + Q, Where P and Q Are Binary Digits

**Figure 2.5.1** 

In order to construct a circuit that will add multidigit binary numbers, it is necessary to incorporate a circuit that will compute the sum of three binary digits. Such a circuit is called a **full-adder**.

Consider a general addition of three binary digits *P*, *Q*, and *R* that results in a carry (or left-most digit) *C* and a sum (or right-most digit) *S*.

$$\begin{array}{r}
P \\
+ Q \\
+ R \\
\hline
CS
\end{array}$$

The operation of the full-adder is based on the fact that addition is a binary operation: Only two numbers can be added at one time. Thus P is first added to Q and then the result is added to R. For instance, consider the following addition:

$$\begin{array}{c} 1_{2} \\ + & 0_{2} \\ + & 0_{2} \\ + & 1_{2} \\ \hline & 10_{2} \end{array} \right\} 1_{2} + 0_{2} = 01_{2} \\ 1_{2} + & 1_{2} = 10_{2} \\ \end{array}$$

The process illustrated here can be broken down into steps that use half-adder circuits.

**Step 1:** Add *P* and *Q* using a half-adder to obtain a binary number with two digits.

$$\frac{P}{C_1S_1}$$

**Step 2:** Add *R* to the sum  $C_1S_1$  of *P* and *Q*.

 $\frac{C_1S_1}{+R}$ 

To do this, proceed as follows:

**Step 2a:** Add *R* to  $S_1$  using a half-adder to obtain the two-digit number  $C_2S$ .

$$\frac{S_1}{C_2S}$$

Then S is the right-most digit of the entire sum of *P*, *Q*, and *R*.

**Step 2b:** Determine the left-most digit, *C*, of the entire sum as follows: First note that it is impossible for both  $C_1$  and  $C_2$  to be 1's. For if  $C_1 = 1$ , then *P* and *Q* are both 1, and so  $S_1 = 0$ . Consequently, the addition of  $S_1$  and *R* gives a binary number  $C_2S_1$  where  $C_2 = 0$ .

Next observe that *C* will be a 1 in the case that the addition of *P* and *Q* gives a carry of 1 or in the case that the addition of  $S_1$  (the right-most digit of *P* + *Q*) and *R* gives a carry of 1.

In other words, C = 1 if, and only if,  $C_1 = 1$  or  $C_2 = 1$ . It follows that the circuit shown in Figure 2.5.2 will compute the sum of three binary digits.



Circuit to Add P + Q + R, Where P, Q, and R Are Binary Digits

Figure 2.5.2

Two full-adders and one half-adder can be used together to build a circuit that will add two three-digit binary numbers *PQR* and *STU* to obtain the sum *WXYZ*. This is illustrated in Figure 2.5.3. Such a circuit is called a **parallel adder**.

Parallel adders can be constructed to add binary numbers of any finite length.



A Parallel Adder to Add PQR and STU to Obtain WXYZ

Figure 2.5.3

#### Two's Complements and the Computer Representation of Negative Integers

Typically, a fixed number of bits is used to represent integers on a computer, and these are required to represent negative as well as nonnegative integers.

Sometimes a particular bit, normally the left-most, is used as a sign indicator, and the remaining bits are taken to be the absolute value of the number in binary notation.

The problem with this approach is that the procedures for adding the resulting numbers are somewhat complicated and the representation of 0 is not unique. A more common approach, using *two's complements*, makes it possible to add integers quite easily and results in a unique representation for 0. The two's complement of an integer relative to a fixed bit length is defined as follows:

#### Definition

Given a positive integer *a*, the **two's complement of** *a* **relative to a fixed bit length** *n* is the *n*-bit binary representation of

 $2^{n} - a$ .

There is a convenient way to compute two's complements that involves less arithmetic than direct application of the definition. For an 8-bit representation, it is based on three facts:

$$2^8 - a = [(2^8 - 1) - a] + 1.$$

2. The binary representation of

```
2^8 - 1 is 11111111_2.
```

**3.** Subtracting an 8-bit binary number *a* from  $1111111_2$  just switches all the 0's in *a* to 1's and all the 1's to 0's. (The resulting number is called the **one's complement** of the given number.)

#### Two's Complements and the Computer Representation of Negative Integers

#### In general,

To find the 8-bit two's complement of a positive integer *a* that is at most 255:

- Write the 8-bit binary representation for *a*.
- Flip the bits (that is, switch all the 1's to 0's and all the 0's to 1's).
- Add 1 in binary notation.

#### Example 6 – *Finding a Two's Complement*

Find the 8-bit two's complement of 19.

#### Solution:

Write the 8-bit binary representation for 19, switch all the 0's to 1's and all the 1's to 0's, and add 1.

$$19_{10} = (16 + 2 + 1)_{10}$$

 $= 00010011_2 \xrightarrow{\text{flip the bits}} 11101100 \xrightarrow{\text{add 1}} 11101101$ 

# Example 6 – Solution

To check this result, note that

$$11101101_{2} = (128 + 64 + 32 + 8 + 4 + 1)_{10}$$
$$= 237_{10}$$
$$= (256 - 19)_{10}$$
$$= (2^{8} - 19)_{10},$$

cont'd

which is the two's complement of 19.

Two's Complements and the Computer Representation of Negative Integers

Observe that because

$$2^8 - (2^8 - a) = a$$

the two's complement of the two's complement of a number is the number itself, and therefore,

To find the decimal representation of the integer with a given 8-bit two's complement:

- Find the two's complement of the given two's complement.
- Write the decimal equivalent of the result.

Example 7 – Finding a Number with a Given Two's Complement

What is the decimal representation for the integer with two's complement 10101001?

Solution:

 $10101001_2 \xrightarrow{\text{flip the bits}} 01010110$ 

add 1  $01010111_2 = (64 + 16 + 4 + 2 + 1)_{10}$ 

 $= 87_{10}$ 

# Example 7 – Solution

To check this result, note that the given number is

$$10101001_2 = (128 + 32 + 8 + 1)_{10}$$

cont'd

 $= 169_{10}$ 

$$=(256-87)_{10}$$

$$=(2^8-87)_{10},$$

which is the two's complement of 87.

Now consider the two's complement of an integer *n* that satisfies the inequality  $1 \le n \le 128$ . Then

and  

$$-1 \ge -n \ge -128$$
the direction of the inequality  
 $2^8 - 1 \ge 2^8 - n \ge 2^8 - 128$ 
by adding  $2^8$  to all parts of the inequality.  
But  $2^8 - 128 = 256 - 128 = 128 = 2^7$ . Hence  
 $2^7 \le$  the two's complement of  $n < 2^8$ .

It follows that the 8-bit two's complement of an integer from 1 through 128 has a leading bit of 1. Note also that the ordinary 8-bit representation of an integer from 0 through 127 has a leading bit of 0.

Consequently, eight bits can be used to represent both nonnegative and negative integers by representing each nonnegative integer up through 127 using ordinary 8-bit binary notation and representing each negative integer from -1 through -128 as the two's complement of its absolute value.

#### That is, for any integer *a* from -128 through 127,



 $= \begin{cases} \text{the 8-bit binary representation of } a & \text{if } a \ge 0\\ \text{the 8-bit binary representation of } 2^8 - |a| & \text{if } a < 0 \end{cases}.$ 

#### The representations are illustrated in Table 2.5.2.

| Integer | 8-Bit Representation (ordinary 8-bit<br>binary notation if nonnegative or 8-bit two's<br>complement of absolute value if negative) | Decimal Form of<br>Two's Complement<br>for Negative Integers |
|---------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| 127     | 01111111                                                                                                                           |                                                              |
| 126     | 01111110                                                                                                                           |                                                              |
| :       | :                                                                                                                                  |                                                              |
| 2       | 00000010                                                                                                                           |                                                              |
| 1       | 00000001                                                                                                                           |                                                              |
| 0       | 0000000                                                                                                                            |                                                              |
| -1      | 1111111                                                                                                                            | $2^8 - 1$                                                    |
| -2      | 11111110                                                                                                                           | $2^8 - 2$                                                    |
| -3      | 11111101                                                                                                                           | $2^8 - 3$                                                    |
| :       | :                                                                                                                                  | :                                                            |
| -127    | 10000001                                                                                                                           | $2^8 - 127$                                                  |
| -128    | 1000000                                                                                                                            | $2^8 - 128$                                                  |

#### Computer Addition with Negative Integers

To add two integers in the range -128 through 127 whose sum is also in the range -128 through 127:

- Convert both integers to their 8-bit representations (representing negative integers by using the two's complements of their absolute values).
- Add the resulting integers using ordinary binary addition.
- Truncate any leading 1 (overflow) that occurs in the 2<sup>8</sup>th position.
- Convert the result back to decimal form (interpreting 8-bit integers with leading 0's as nonnegative and 8-bit integers with leading 1's as negative).

**Case 1, (both integers are nonnegative):** This case is easy because if two nonnegative integers from 0 through 127 are written in their 8-bit representations and if their sum is also in the range 0 through 127, then the 8-bit representation of their sum has a leading 0 and is therefore interpreted correctly as a nonnegative integer.

The example below illustrates what happens when 38 and 69 are added.



To be concrete, let the nonnegative integer be *a* and the negative integer be -b and suppose both *a* and -b are in the range -128 through 127. The crucial observation is that adding the 8-bit representations of *a* and -b is equivalent to computing

$$a + (2^8 - b)$$

because the 8-bit representation of -b is the binary representation of  $2^8 - b$ .

Case 2 (a is nonnegative and -b is negative and |a| < |b|): In this case, observe that a = |a| < |b| = b and

$$a + (2^8 - b) = 2^8 - (b - a),$$

and the binary representation of this number is the 8-bit representation of -(b - a) = a + (-b). We must be careful to check that  $2^8 - (b - a)$  is between  $2^7$  and  $2^8$ . But it *is* because

 $2^7 = 2^8 - 2^7 \le 2^8 - (b - a) < 2^8$  since  $0 < b - a \le b \le 128 = 2^7$ . Hence in case |a| < |b|, adding the 8-bit representations of *a* and -b gives the 8-bit representation of a + (-b).

#### Example 8 – Computing a + (-b) Where $0 \le a < b \le 128$

Use 8-bit representations to compute 39 + (-89).

#### Solution:

**Step 1:** Change from decimal to 8-bit representations using the two's complement to represent –89.

Since  $39_{10} = (32 + 4 + 2 + 1)_{10} = 100111_2$ , the 8-bit representation of 39 is 00100111.

Now the 8-bit representation of -89 is the two's complement of 89.

# Example 8 – Solution

This is obtained as follows:

$$89_{10} = (64 + 16 + 8 + 1)_{10} = 01011001_2 \xrightarrow{\text{flip the bits}} 10100110 \xrightarrow{\text{add 1}} 10100111$$

cont'd

So the 8-bit representation of -89 is 10100111.

# Example 8 – Solution

**Step 2:** Add the 8-bit representations in binary notation and truncate the 1 in the 2<sup>8</sup>th position if there is one:

cont'd



# Example 8 – Solution

cont'd

**Step 3:** Find the decimal equivalent of the result. Since its leading bit is 1, this number is the 8-bit representation of a negative integer.

 $\begin{array}{cccc} 11001110 & \underline{\qquad \text{flip the bits}} & 00110001 & \underline{\qquad \text{add } 1} & 00110010 \\ & \leftrightarrow -(32+16+2)_{10} = -50_{10} \end{array}$ 

Note that since 39 - 89 = -50, this procedure gives the correct answer.

Case 3 (a is nonnegative and  $\neg b$  is negative and  $|b| \le |a|$ ): In this case, observe that  $b = |b| \le |a| = a$  and

$$a + (2^8 - b) = 2^8 + (a - b).$$

Also

$$2^8 \le 2^8 + (a - b) < 2^8 + 2^7$$
 because  $0 \le a - b \le a < 128 = 2^7$ .

So the binary representation of  $a + (2^8 - b) = 2^8 + (a - b)^3$ a leading 1 in the ninth (2<sup>8</sup>th) position. This leading 1 is often called "overflow" because it does not fit in the 8-bit integer format.

Now subtracting  $2^8$  from  $2^8 + (a - b)$  is equivalent to truncating the leading 1 in the  $2^8$ th position of the binary representation of the number. But

$$[a + (2^8 - b)] - 2^8 = 2^8 + (a - b) - 2^8 = a - b = a + (-b).$$

Hence in case  $|a| \ge |b|$ , adding the 8-bit representations of *a* and -b and truncating the leading 1 (which is sure to be present) gives the 8-bit representation of a + (-b).

#### Example 9 – Computing a + (-b) Where $1 \le b < a \le 127$

Use 8-bit representations to compute 39 + (-25).

#### Solution:

**Step 1:** Change from decimal to 8-bit representations using the two's complement to represent −25.

As in Example 8, the 8-bit representation of 39 is 00100111. Now the 8-bit representation of -25 is the two's complement of 25, which is obtained as follows:

 $25_{10} = (16 + 8 + 1)_{10} = 00011001_2 \xrightarrow{\text{flip the bits}} 11100110 \xrightarrow{\text{add 1}} 11100111$ 

# Example 9 – Solution

cont'd

So the 8-bit representation of -25 obtained as 11100111.

**Step 2:** Add the 8-bit representations in binary notation and truncate the 1 in the 2<sup>8</sup>th position if there is one:



# Example 9 – Solution

**Step 3:** Find the decimal equivalent of the result:

 $00001110_2 = (8+4+2)_{10}$ 

 $= 14_{10}$ .

Since 39 - 25 = 14, this is the correct answer.

**Case 4 (both integers are negative):** This case involves adding two negative integers in the range -1 through -128 whose sum is also in this range.

To be specific, consider the sum (-a) + (-b) where *a*, *b*, and a + b are all in the range 1 through 128. In this case, the 8-bit representations of -a and -b are the 8-bit representations of  $2^8 - a$  and  $2^8 - b$ .

So if the 8-bit representations of -a and -b are added, the result is

$$(2^8 - a) + (2^8 - b) = [2^8 - (a + b)] + 2^8.$$

We know that truncating a leading 1 in the ninth (2<sup>8</sup>th) position of a binary number is equivalent to subtracting 2<sup>8</sup>.

28

So when the leading 1 is truncated from the 8-bit representation of  $(2^8 - a) + (2^8 - b)$ , the result is -(a + b), which is the 8-bit representation of (a + b) = (-a) + (-b).

Example 10 – Computing (-a) + (-b) Where  $1 \le a, b \le 128$ , and  $1 \le a + b \le 128$ 

Use 8-bit representations to compute (-89) + (-25).

#### Solution:

**Step 1:** Change from decimal to 8-bit representations using the two's complements to represent –89 and –25.

The 8-bit representations of -89 and -25 were shown in Examples 2.5.8 and 2.5.9 to be 10100111 and 11100111, respectively.

# Example 10 – Solution

**Step 2:** Add the 8-bit representations in binary notation and truncate the 1 in the 2<sup>8</sup>th position if there is one:

cont'd



**Step 3:** Find the decimal equivalent of the result. Because its leading bit is 1, this number is the 8-bit representation of a negative integer.

 $10001110 \xrightarrow{\text{flip the bits}} 01110001 \xrightarrow{\text{add 1}} 01110010_2$  $\leftrightarrow -(64 + 32 + 16 + 2)_{10} = -114_{10}$ 

cont'd

Since (-89) + (-25) = -114, that is the correct answer.

## **Hexadecimal Notation**

# Hexadecimal Notation

**Hexadecimal notation** is even more compact than decimal notation, and it is much easier to convert back and forth between hexadecimal and binary notation than it is between binary and decimal notation.

The word *hexadecimal* comes from the Greek root *hex*-, meaning "six," and the Latin root *deci*-, meaning "ten." Hence *hexadecimal* refers to "sixteen," and hexadecimal notation is also called **base 16 notation**. Hexadecimal notation is based on the fact that any integer can be uniquely expressed as a sum of numbers of the form

where each *n* is a nonneg  $d \cdot 16^n$ , teger and each *d* is one of the integers from 0 to 15. In order to avoid ambiguity, each hexadecimal digit must be represented by a single symbol. The integers 10 through 15 are represented by the symbols A, B, C, D, E, and F.

# Hexadecimal Notation

The sixteen hexadecimal digits are shown in Table 2.5.3, together with their decimal equivalents and, for future reference, their 4-bit binary equivalents.

| Decimal | Hexadecimal | 4-Bit Binary<br>Equivalent | Decimal | Hexadecimal | 4-Bit Binary<br>Equivalent |
|---------|-------------|----------------------------|---------|-------------|----------------------------|
| 0       | 0           | 0000                       | 8       | 8           | 1000                       |
| 1       | 1           | 0001                       | 9       | 9           | 1001                       |
| 2       | 2           | 0010                       | 10      | А           | 1010                       |
| 3       | 3           | 0011                       | 11      | В           | 1011                       |
| 4       | 4           | 0100                       | 12      | С           | 1100                       |
| 5       | 5           | 0101                       | 13      | D           | 1101                       |
| 6       | 6           | 0110                       | 14      | Е           | 1110                       |
| 7       | 7           | 0111                       | 15      | F           | 1111                       |

Example 11 – Converting from Hexadecimal to Decimal Notation

Convert 3CF<sub>16</sub> to decimal notation.

#### Solution:

Consider the following schema.



So 3CF<sub>16</sub> = 975<sub>10</sub>.

# Hexadecimal Notation

Now consider how to convert from hexadecimal to binary notation.

The following sequence of steps will give the required conversion from hexadecimal to binary notation.

To convert an integer from hexadecimal to binary notation:

- Write each hexadecimal digit of the integer in 4-bit binary notation.
- · Juxtapose the results.

Example 12 – Converting from Hexadecimal to Binary Notation

Convert B09F<sub>16</sub> to binary notation.

Solution:

 $B_{16} = 11_{10} = 1011_2,$ 

$$0_{16} = 0_{10} = 0000_2,$$

and

 $9_{16} = 9_{10} = 1001_2,$ 

 $F_{16} = 15_{10} = 1111_2$ .

## Example 12 – Solution

cont'd

Consequently,

| В    | 0    | 9    | F    |
|------|------|------|------|
| \$   | \$   | \$   | \$   |
| 1011 | 0000 | 1001 | 1111 |

and the answer is 1011000010011111<sub>2</sub>.

## **Hexadecimal Notation**

To convert integers written in binary notation into hexadecimal notation, reverse the steps of the previous procedure.

To convert an integer from binary to hexadecimal notation:

- Group the digits of the binary number into sets of four, starting from the right and adding leading zeros as needed.
- Convert the binary numbers in each set of four into hexadecimal digits. Juxtapose those hexadecimal digits.

#### Example 13 – Converting from Binary to Hexadecimal Notation

#### Convert 1001101101001<sub>2</sub> to hexadecimal notation.

#### Solution:

First group the binary digits in sets of four, working from right to left and adding leading 0's if necessary.

0100 1101 1010 1001.

## Example 13 – Solution

Convert each group of four binary digits into a hexadecimal digit.

cont'd

| 0100           | 1101 | 1010 | 1001 |
|----------------|------|------|------|
| $\updownarrow$ | \$   | \$   | \$   |
| 4              | D    | Α    | 9    |

Then juxtapose the hexadecimal digits. 4DA9<sub>16</sub>