

## Addition and Subtraction:

- \* Most computers use the signed 2's complement representation when performing arithmetic operations with integers.
- \* For floating-point operations, most computers use the signed-magnitude representation for mantissa.

## Addition and Subtraction with Signed-Magnitude

Data: →

- \* we designate the magnitude of the two numbers by A and B. When the signed numbers are added or subtracted, we find that there are eight different condition to consider depending on the sign of the numbers and operation performed. These condition are showed in the below (fig) Table.

Table: Addition and subtraction of signed Magnitude Number

| Operation     | Add<br>Magnitude | Subtract Magnitude |              |              |
|---------------|------------------|--------------------|--------------|--------------|
|               |                  | When $A > B$       | When $A < B$ | When $A = B$ |
| $(+A) + (+B)$ | $+ (A+B)$        |                    |              |              |
| $(+A) + (-B)$ |                  | $+ (A-B)$          | $- (B-A)$    | $+ (A-B)$    |
| $(-A) + (+B)$ |                  | $- (A-B)$          | $+ (B-A)$    |              |
| $(-A) + (-B)$ | $- (A+B)$        | $+ (A-B)$          | $- (B-A)$    | $+ (A-B)$    |
| $(+A) - (+B)$ |                  |                    |              |              |
| $(+A) - (-B)$ | $+ (A+B)$        |                    |              |              |
| $(-A) - (+B)$ | $- (A+B)$        |                    |              |              |
| $(-A) - (-B)$ |                  | $- (A-B)$          | $+ (B-A)$    | $+ (A-B)$    |

\* The algorithm for addition and subtraction can be derived from the table and can be stated as follows (The word inside parentheses should be used for the subtraction algorithm)

### Addition (Subtraction) Algorithm:

- \* When the signs of A and B are identical (different), add the two magnitudes and attach the sign of A to the result.
- \* When the signs of A and B are different (identical), compare the magnitudes and subtract the smaller number from the larger.
- \* Choose the sign of the result to be the same as A if  $A > B$  or the complement of the sign of A if  $A < B$ .
- \* If the two magnitudes are equal, subtract B from A and make the sign of the result positive.
- \* The two algorithms are similar except for the sign comparison. The procedure to be followed for identical signs in the addition algorithm is the same as for different signs in the subtraction algorithm, and vice versa.

### Hardware Implementation:

- \* Let A and B be two registers that hold the ~~representing~~ two numbers, and As and Bs be two F-F that holds the corresponding signs.

- \* The result of the operation may be transferred to a third register; however, saving is achieved if the result is transferred into A and B. They A and B together form a accumulator register.
- \* First, a parallel-adder is needed to ~~establish~~ perform the micro-operation A+B.
- \* Second the comparator circuit is needed to establish if  $A > B$ ,  $A = B$ , or  $A < B$ .
- \* Third two parallel-subtractor circuits are needed to perform the micro-operation  $A - B$  and  $B - A$ .
- \* The sign relationship can be determined from an EX-OR gate with As and Bs as inputs.
- \* Careful investigation of the alternatives reveals that the use of 2's complement of for subtraction and comparison is an efficient procedure that requires only one adder and a completer.
- \* Figure on the next page shows the HW for implementing the addition and subtraction operation.
- \* It consists of registers A and B and sign F-F. If A consists of registers A and B and sign F-F and B consists of registers A and B and sign F-F. Subtraction is done by adding A to B and B to A. The O/P carry is the 2's complement of B. The O/P carry is transferred to F-F E, where it can be checked to determine the relative magnitude of the

of the two numbers. The add-overflow FF AVF holds the overflow bit when A and B are added.

\* The A Register provides other microoperations that may be needed when we specify the sequence of steps in the algorithm.



Fig: Circuits for signed magnitude addition and subtraction.

- \* The addition of A plus B is done through the parallel adder. The S (sum) o/p of the adder is applied to the i/p of the A register.
- \* The complementors consists of EX-OR gates and the parallel adder consists of full-adder circuit.
- \* The M signal is also applied to the i/p carry of the adder. When M=0 the o/p of B is transferred to the adder, the i/p carry is 0, and the o/p of the adder is equal to the sum A+B.

\* When  $M=1$ , the 1's complement of  $B$  is applied to the adder, the 0/b carry is 1, and output  $S = A + \bar{B} + 1$ . This is equal to  $A + 2^k$ 's complement of  $B$ , which is equal to the subtraction  $A - B$ .

### Hardware Algorithm:

\* The flowchart for the H/W algorithm is presented in the below fig.

- \* The two signs  $A_s$  and  $B_s$  are compared by an EX-OR gate. If the 0/b of the gate is 0, the signs are identical; if it is 1, the signs are different.
- \* The magnitudes are added with a micro-operation  $F_A \leftarrow A + B$ , where  $F_A$  is a register that combines  $F$  and  $A$ .
- \* The carry in  $F$  is transferred into the add-overflow with a T-T AVF.
- \* The magnitudes are subtracted by adding  $A$  to the 2<sup>k</sup>'s complement of  $B$ . No overflow can occur if the number are subtracted so AVF is cleared to 0.
- \* A ~~0/b~~ in  $F$  indicates that  $A < B$  for this case. It is necessary to take the 2<sup>k</sup>'s complement of the value in  $A$ . This operation can be done with one micro-operation  $A \leftarrow A + 1$ .
- \* However, we suppose that the  $A$  register has circuit for microoperations complement and increment, so the 2<sup>k</sup>'s complement is obtained from these two micro-operations.



Fig: Flow chart for Add and subtract

\* In other paths of the flowchart, the sign of the result is the same as the sign of A, so no change in AS is required.

\* However, when  $A \oplus B$ , the sign of the result is the complement of the original sign of A. It is necessary to do complement A to obtain the correct sign.

\* The final result is found in the register A and its sign in As. The value of HVF provides an overflow indication. The final value of F is immaterial.

### Addition and subtraction with signed 2's complement data:

#### Complement Data:

\* The addition of two numbers in signed-2's complement form consists of adding the number with the sign bit treated the same as the other bits of the number.

\* A carry-out of the sign-bit position is discarded. The subtraction consists of first taking the 2's complement of the subtrahend and then adding it to the minuend.

\* When two numbers of n digits each are added and the sum occupies  $n+1$  digits, we say that an overflow occurred. An overflow can be detected by inspecting the last two nibbles out of the addition. When the two nibbles are applied to an Ex-or gate, the overflow is detected when the o/p of the gate is equal to 1.

\* The register configuration for the Hlw Hlw implementation is shown in fig in the next page.

- \* We move the A ~~register~~ Register AC and the B register BR. The leftmost bit in AC and BR represent the sign bits of the numbers.
- \* The two sign bits are added or subtracted together with the other bits in the completer and parallel adder.
- \* The overflow flag V is set to 1 if there is an overflow. The overflow bit V is discarded.



Fig: Flow for signed 2's complement addition and subtraction.

- \* The algorithm for adding and subtracting two binary numbers in signed 2's complement representation is shown in the flowchart in the next page.
- \* The sum is obtained by adding the content of AC and BR (including their sign bits). The overflow bit V is set to 1 if the Ex-OR of the last two numbers is 1, and it is cleared to 0 otherwise.

- \* The subtraction operation is accomplished by adding the contents of AC to the 2's complement of BR. Taking the 2's complement of BR has the effect of changing a positive number to negative, and vice versa.
- \* An overflow must be checked during this operation because the two numbers added should have the same sign.
- \* Programmers must realize that if an overflow occurs, there will be an erroneous result in the AC register.



- \* Comparing this algorithm with its signed-magnitude counterpart, we noted that it is much simpler to add and subtract numbers if negative numbers are maintained in signed-2's complement representation. That's why most of computers adopt this representation.