

**DATA REPRESENTATION**

ZATIN

CDA 2nd Year A

in digital computer is stored in memory or processor

Registers contain either data or control info.

Control Info: It is a bit or group of bits used to specify sequence of command signals needed for manipulation of data in other registers.

\* Registers are made up of flip-flops. Flip-flops are two state devices that can store only 1's & 0's.

**Number System +**

(1) Binary Number System

- Decimal Number System

- Octal & Hexadecimal Number System.

**Radix: or Base - ( $r$ ) +**

$r$  is a system that uses distinct symbols for  $r$  digits, from 0 to  $r-1$ .

Ex: <https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

(1) Decimal no system - radix = 10 -

Symbols are  $\Rightarrow 0, 1, 2, \dots, 9$ .

$$\text{Ex: } 728.79 = 7 \times 10^2 + 2 \times 10^1 + 8 \times 10^0 + 7 \times 10^{-1} + 9 \times 10^{-2}$$

(2) For Binary no system - radix = 2  
Symbols are  $\Rightarrow 0 \& 1$ .

(3) For octal no system - radix = 8  
Symbols are  $\Rightarrow 0, 1, 2, 3, \dots, 7$ .

(4) For Hexadecimal no. system - radix = 16  
Symbols are  $\Rightarrow 0, 1, 2, 3, \dots, 9, A, B, C, D, E, F$

(5) For  $r$  number system  $\rightarrow$  radix =  $r$   
Symbols are  $\Rightarrow 0, 1, 2, \dots, (r-1)$ .

**Conversion +**

(1) Any number system to decimal  $\rightarrow$

$$( \quad )_r \rightarrow ( \quad )_{10}$$

$$\Rightarrow (A_1 A_2 A_3 \dots A_n)_{r^n} \cdot (A_{n+1} A_{n+2} \dots A_m)_{r^m} = (A_1 A_2 A_3 \dots A_n + A_{n+1} r + A_{n+2} r^2 + \dots + A_m r^{m-1})_{10}$$

$$\Rightarrow (A_1 A_2 A_3 \dots A_n, B_1 B_2 \dots B_m) \Rightarrow$$

$$(A_1 r^{n-1} + A_2 r^{n-2} + \dots + A_n r^0 + A_{n+1} r^1 + A_{n+2} r^2 + \dots + A_m r^{m-1})_{10}$$

Ex:

$$(10110)_2 \rightarrow (\quad )_{10}$$

$$\Rightarrow \cancel{0} \cancel{1} \cancel{0} \cancel{1} \cancel{0} \cancel{0}$$

$$\Rightarrow 1 \times 2^4 + 0 \times 2^3 + 1 \times 2^2 + 1 \times 2^1 + 0 \times 2^0 \\ = \underline{16} + 0 + \underline{4} + \underline{2} + 0 = \underline{22}$$

$$(127)_8 \rightarrow (\quad )_{10}$$

$$\Rightarrow 1 \times 8^2 + 2 \times 8^1 + 7 \times 8^0 \\ = \underline{64} + \underline{16} + \underline{7} = (87)_{10}$$

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

$$(A12.B)_{16} \rightarrow (\quad )_{10}$$

$$\Rightarrow (10 \times 16^2 + 1 \times 16^1 + 2 \times 16^0 + 11 \times 16^{-1})_{10}$$

$$(4) (2\ 3\ 4)_{5} \rightarrow (\quad )_{10}$$

$$\Rightarrow \underline{2} \times 5^2 + \underline{3} \times 5^1 + \underline{4} \times 5^0 \\ = \underline{50} + \underline{15} + \underline{4} = (69)_{10}$$

(2) Decimal to any number system

- first separate the number into two parts - (1) Integer part  
(2) fractional part.

- Divide integer part by  $r$ , get quotient & remainder, again divide quotient by  $r$ , get produce again new quotient & remainder. This process is repeated until quotient becomes 0. Take first remainder in reverse order bit.

(2)

Multiply fractional part by 8. we get integer + fraction. fractional part again multiplied by 8. we get new integer + fraction.

This process repeated until we get zero fractional part or until no. of digits obtained gives required accuracy.

\* first integer computed being the digit to be placed next to decimal point.

$$(41.205)_{10} \rightarrow (\quad)_4$$

- finally two parts are combined.

(2) Octal to Hexadecimal  $\rightarrow$

$$(\quad)_8 \rightarrow (\quad)_{16}$$

$\downarrow$

$$\downarrow \rightarrow (\quad)_{10}$$

$$(\quad \quad \quad \quad \quad \quad \quad \quad \quad) \rightarrow (\quad)$$

$\boxed{3\text{bit}} \quad \boxed{3\text{bit}} \quad \boxed{2\text{bit}} \quad \boxed{3\text{bit}} \quad \boxed{3\text{bit}}$

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

Ex:

$$(127.6)_8 \rightarrow (\quad)_{16}$$

$$(\underline{\quad \quad \quad} \quad \underline{\quad \quad \quad} \quad \underline{\quad \quad \quad} \quad \underline{\quad \quad \quad})_8 \rightarrow (\quad \quad \quad \quad \quad)_{16}$$

$$\Rightarrow (57.C)_{16}$$

(4) Hexadecimal to Octal  $\rightarrow$

$$(\quad \quad \quad \quad \quad \quad \quad \quad \quad)_{16} \rightarrow (\quad \quad \quad \quad \quad \quad \quad \quad \quad)_{8}$$

$\boxed{3\text{bit}} \quad \boxed{3\text{bit}}$

(5) Any number system m to any number system n  $\rightarrow$

$$(\quad)_{\text{m}} \rightarrow (\quad)_{\text{n}}$$

$\downarrow$

$$\downarrow \rightarrow (\quad)_{10} \quad \uparrow$$

⇒ BCD (Binary Coded Decimal Numbers) ↗

| Decimal Number | BCD Number                |
|----------------|---------------------------|
| 0              | 0000                      |
| 1              | 0001                      |
| 2              | 0010                      |
| 3              | 0011                      |
| 4              | 0100                      |
| 5              | 0101                      |
| 6              | 0110                      |
| 7              | 0111                      |
| 8              | 1000                      |
| 9              | 1001                      |
| 10             | <del>1010</del> 0001 0000 |
| 20             | 0010 0000                 |

Complements ↗

1)  $(\gamma - 1)^S$  Complement ↗

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

$$(\underline{\gamma^n - 1}) - N.$$

in this a number N in base  $\gamma$  having  
n digits.

Ex:

(1) 9's complement of a number N -

$$(10 - 1)^S = 9^S \text{ Complement} = (10^n - 1) - N$$

$$\gamma = 10$$

(2) 1's complement of a binary number -

$$(2 - 1)^S = 1^S \text{ Complement} = (2^n - 1) - N$$

Ex: 1's complement of binary number 1001

$$= (2^4 - 1) - (1001)_2$$

$$= (1111)_2 - (1001)_2 = (0110)_2$$

$$\text{or } 1 \leftrightarrow 0$$

(3)

(3) 4's complement of a number N -  $(5^n - 1)_{10} - (N)_5$

$(5-1)^4$ 's complement = 4's complement

Base of number N must be 5  $\Leftrightarrow$

Ex:

$(412)_5$ , find 4's complement of this number

$$(5^3 - 1)_{10} - (412)_5$$

$$(124)_{10} - (412)_5$$

$$\begin{aligned}(124)_{10} - (107)_{10} &= (17)_{10} \\ &= (632)_5\end{aligned}$$

1.  $\rightarrow$

for  $(r-1)$ 's complement of any number N of base r, subtract each digit from  $(r-1)$ .

(B)

$r^k$ 's complement  $\Rightarrow$

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

$r^k$  complement of an n digit number N in base r is defined

$$\text{as } (r^n - N) \quad \text{for } N \neq 0$$

If  $N = 0$  then  $r^k$  complement is 0.

$$\boxed{r^k \text{ complement} = (r-1)^k \text{ complement} + 1}$$

Ex

$$r^k \text{ complement} = r^n - N.$$

Ex:

(1) 10's complement of number 6789 is -

(a) first 9's complement of this number = 3210

(b) Now add +1 or  $3210 + 1 = 3211$ .

(2) 2's complement of binary number 10001 is -

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

## FLOATING POINT REPRESENTATION

- \* Floating point describes a method of representing real numbers in a way that can support a wide range of values.
- Numbers are represented approx. to a fixed no. of significant digits & scaled using an exponent.

then representation is -

$$\text{Significant digits} \times \text{base}^{\text{Exponent}}$$

→ Floating point refers to the fact that the radix point (decimal point) can float, it can be placed anywhere relative to significant digits of number.

→ fixed point or integer representation :-

Ex: 7 decimal digits with two decimal places -

<https://www.youtube.com/watch?v=12345678912345&list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

→ Floating point format provide much wider range of values.

Ex: IEEE 754 decimal 32 format :-

\* Floating point representation requires more space for storage.

Ex:

$$152853.5047 = 1.528535047 \times 10^5$$

## Range of Floating point Number

Ex:  $0.12 \times 0.12 = 0.0144$  can be expressed as -

$$(1.2 \times 10^{-1}) \times (1.2 \times 10^{-1}) = (1.44 \times 10^{-2})$$

floating point with 3  
digit

with fixed point system with

$$0.120 \times 0.120 = 0.014$$

After decimal 3 digits

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

(7)

Range of floating point no's depends on the no. of bits or digits used for representation of the significand & for the exponent.

- for double precision (64-bit) binary floating point number has a coefficient of 52 bit, an exponent of 11 bits & one sign bit.

Range of exponent is  $(-1022, 1023)$

$$\log_{10} 2^{1023} = 308.$$

So range is  $(10^{-308} \text{ to } 10^{308})$ .

IEEE 754: FLOATING POINT REPRESENTATION:

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVHl5c4LG-L>

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVHl5c4LG-L>

(C)

## ERROR DETECTION CODE

Error: Due to external noise bits can be changed from  $1 \rightarrow 0$  or  $0 \rightarrow 1$  through communication medium. This is called error.

- Error detection code only detect the presence of error.
- If errors occur in frequent way, then erroneous info. is transmitted again.

Parity Bit: Error detection code. It is an extra bit included with binary message to make total number of 1's either odd or even.

Two types :-

(1) ODD Parity Bit  $\Rightarrow$  Total no. of 1's in message + parity bit should be odd.

(2) EVEN Parity Bit  $\Rightarrow$  Total no. of 1's in message + parity bit should be even.

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

- \* EVEN Parity scheme has disadvantage of having a bit combination of all 0s.
- \* ODD Parity scheme has disadvantage of having only one of the message bit equal to 1.

## Parity Generator



\* This method detects presence of one, three or any odd number of errors.

\* An even number of errors is not detected.

Error detection with odd parity bit  $\rightarrow$

| <u>Message</u> | <u>Odd Parity Bit</u> |
|----------------|-----------------------|
| 0 000          | 1                     |
| 1 001          | 0                     |
| 2 010          | 0                     |
| 3 011          | 1                     |
| 4 100          | 0                     |
| 5 101          | 1                     |
| 6 110          | 1                     |
| 7 111          | 0                     |

At Receiving  
End Odd Parity

| 0 |
|---|
| 0 |
| 0 |
| 0 |
| 0 |
| 0 |
| 0 |
| 0 |

| $x$ | $y$ | $z$ | 00 | 01 | 11 | 10 |
|-----|-----|-----|----|----|----|----|
| 0   | 1   |     | 1  |    | 1  |    |
| 1   |     | 1   | 1  | 1  | 1  | 1  |

| $x$ | $y$ | $z$ | $p$ | 00 | 01 | 11 | 10 |
|-----|-----|-----|-----|----|----|----|----|
| 00  | 1   |     | 1   | 1  |    | 1  |    |
| 01  |     | 1   | 1   | 1  | 1  |    |    |
| 11  |     |     | 1   | 1  |    |    | 1  |
| 10  |     |     | 1   | 1  | 1  | 1  | 1  |

$$(x \oplus y \oplus z \oplus p)$$

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>



Error detection with even parity bit  $\rightarrow$

| <u>Message</u> | <u>Even Parity Bit</u> |
|----------------|------------------------|
| 000            | 0                      |
| 001            | 1                      |
| 010            | 1                      |
| 011            | 0                      |
| 100            | 1                      |
| 101            | 0                      |
| 110            | 0                      |
| 111            | 1                      |

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

(6)

Hamming Code  $\rightarrow$  It can detect upto two & correct upto one bit errors.

\* Simple Parity bit can not correct errors.

Mathematically -

for each integer  $r \geq 2$ ,

Total Block length  $= n \leq 2^r - 1$

& Message length  $k \leq 2^r - r - 1$ .  $r$ : No of Parity Bit.

Rate of Hamming code  $= k/n = \frac{2^r - r - 1}{2^r - 1} = 1 - r/(2^r - 1)$ , which is highest possible for codes with distance 3 & block length  $2^r - 1$ .

Ex: for  $r = 4$ ,

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

$D_{14} D_{13} D_{12} D_{11} D_{10} D_9 D_8 D_7 D_6 D_5 D_4 D_3 D_2 D_1 D_0$

Bit  $D_0$  is responsible for checking errors for bit positions -

$D_1, D_3, D_5, D_7, D_9, D_{11}, D_{13}$

Bit  $D_1$  is responsible for checking errors for bit positions -

$D_2, D_3, D_6, D_7, D_{10}, D_{11}, D_{14}, D_{15}$ -

Bit  $D_3$  is responsible for detecting errors for bit positions -

$D_4, D_5, D_6, D_7, D_{12}, D_{13}, D_{14}, D_{15}$

Bit  $D_7$  is responsible for detecting errors for bit positions -

$D_8, D_9, D_{10}, D_{11}, D_{12}, D_{13}, D_{14}, D_{15}$

Ex: Generate Hamming code for 011110110

$$9 \leq 2^r - r - 1$$

$$10 \leq 2^r - r$$

$$\text{Here } r = 4.$$

# PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

Consider odd Parity -

|          |          |          |       |       |       |       |       |       |       |       |       |
|----------|----------|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0        | 1        | 1        | 1     | 1     | 0     | 1     | 1     | 0     |       |       |       |
| $D_{12}$ | $D_{11}$ | $D_{10}$ | $D_9$ | $D_8$ | $D_7$ | $D_6$ | $D_5$ | $D_4$ | $D_3$ | $D_2$ | $D_1$ |

$$D_0 \Rightarrow D_1, D_3, D_5, D_7, D_9, D_{11} \quad \begin{matrix} \downarrow \\ 1 \end{matrix} \quad \begin{matrix} \downarrow \\ 1 \end{matrix} \quad \begin{matrix} \downarrow \\ 1 \end{matrix} \Rightarrow D_0 \text{ should be } 0.$$

$$D_1 \Rightarrow D_2, D_3, D_6, D_7, D_{10}, D_{11}, D_{14}, D_{15} \quad \begin{matrix} \downarrow \\ 0 \end{matrix} \quad \begin{matrix} \downarrow \\ 0 \end{matrix} \quad \begin{matrix} \downarrow \\ 1 \end{matrix} \quad \begin{matrix} \downarrow \\ 1 \end{matrix} \Rightarrow D_1 \text{ should be } 1$$

$$D_3 \Rightarrow D_4, D_5, D_6, D_7, D_{12}, D_{13}, D_{14}, D_{15} \quad \begin{matrix} \downarrow \\ 1 \end{matrix} \quad \begin{matrix} \downarrow \\ 1 \end{matrix} \quad \begin{matrix} \downarrow \\ 0 \end{matrix} \quad \begin{matrix} \downarrow \\ 0 \end{matrix} \Rightarrow D_3 \text{ should be } 1$$

$$D_7 \Rightarrow D_8, D_9, D_{10}, D_{11}, D_{12} \quad \begin{matrix} \downarrow \\ 1 \end{matrix} \quad \begin{matrix} \downarrow \\ 0 \end{matrix} \Rightarrow D_7 \text{ should be } 1$$

Now Message block -

0 1 1 1 1 0 1 1 0 0 0 0

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

Now error occurs & message becomes →

0 1 0 1 1 0 1 1 0 0 0 0

Again find value of parity bits -

|          |          |          |       |       |       |       |       |       |       |       |       |
|----------|----------|----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0        | 1        | 0        | 1     | 1     | 0     | 1     | 1     | 0     |       |       |       |
| $D_{12}$ | $D_{11}$ | $D_{10}$ | $D_9$ | $D_8$ | $D_7$ | $D_6$ | $D_5$ | $D_4$ | $D_3$ | $D_2$ | $D_1$ |

$$D_0 \Rightarrow 0$$

$$D_1 \Rightarrow 0$$

$$D_3 \Rightarrow 1$$

$$D_7 \Rightarrow 0$$

$$\begin{array}{r} 1110 \\ 0100 \\ \hline 1010 \\ \textcircled{D}_{10} \end{array}$$

Now find X-OR between previous parity bits & newly calculated parity bits.

$$\begin{array}{r} 1110 \\ 0100 \\ \hline 1010 \end{array} \Rightarrow D_0 \text{ is changed}$$

2

(2)

### Subtraction $\Rightarrow$

- ... Arithmetic opr<sup>n</sup> — Addition
  - Subtraction
  - Multiplication
  - Division
- \* Arithmetic processor is a part of processor unit that executes arithmetic operations.
- \* Negative no. can be represented as -
  - first bit is 1 (from left).
  - rest of the no. may be represented in one of 3 possible ways -
    - (a) Sign & Magnitude representation
    - (b) Signed -1<sup>st</sup> complement representation
    - (c) Signed -2<sup>nd</sup> complement representation.

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

Ex: ① +14 will be stored in 8 bit Register as -

00001110

(2) -14 will be stored in 8 bit register in one of 3 ways as -  
in sign magnitude -

10001110

in Signed -1<sup>st</sup> complement - 11110001

in Signed -2<sup>nd</sup> complement - 11110010

\* For floating point operation most of computer uses signed - Magnitude representation for the mantissa.

### Addition & Subtraction with Signed-Magnitude Data:-

Magnitude of two numbers  $\rightarrow A \& B$ .

\* When two equal no. are subtracted, result should be +0 m.

| 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)$      |                    |              |              |
| $(+A) - (+B)$ |                  | $+ (A - B)$        | $- (B - A)$  | $+ (A - B)$  |
| $(+A) - (-B)$ | $+ (A + B)$      |                    |              |              |
| $(-A) - (+B)$ | $- (A + B)$      |                    |              |              |
| $(-A) - (-B)$ |                  | $- (A - B)$        | $+ (B - A)$  | $+ (A - B)$  |

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

### Addition (Subtraction) Algo:

- (1) When signs of  $A \& B$  are identical (different), add the two magnitudes & attach the sign of  $A$  to the result.
- (2) When signs of  $A \& B$  are different (identical), compare the magnitudes & subtract smaller number from the larger. Choose sign of result to be same as  $A$  if  $A > B$  or complement of the sign of  $A$  if  $A < B$ .
- (3) If two magnitude are equal, subtract  $B$  from  $A$  & make the sign of result positive.
- (4) Sign can be determined from an exclusive OR gate with  $A \& B$  as inputs.

## H/W Implementation:-

(2)

- A & B : Two Registers hold magnitude of numbers.
- $A_S \& B_S$  : Two flipflops hold corresponding sign.
- Result of operation may be transferred to third register.
- Scaling is achieved if result is transferred into A & A<sub>S</sub>.
- A & A<sub>S</sub> : Together form accumulator register.

→ H/W :

- (1) A parallel adder is needed to perform microoperation A+B.
- (2) A comparator circuit is needed to establish if  $A > B$ ,  $A = B$  or  $A < B$ .
- (3) Two parallel - subtractor circuits are needed to perform microoperations  $A - B$  &  $B - A$ .

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>  
 (4) Sign relationship can be determined from an X-OR gate with  $A_S \& B_S$  as inputs.

## Different Procedure:-

- (1) Subtraction can be accomplished by means of complement & add.
- ↪ Result of complementation can be determined from the end carry after the subtraction.
- ↪ So requires only an adder & complementer.



# PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

It consist -

- Register A & B, & sign flip flop  $A_S$  &  $B_S$ .
- Subtraction is done by adding A to  $2^k$  complement of B.
- O/P carry is transferred to flip flop E. (It determine relative magnitude of two numbers).
- AVF: Add overflow flip flop : It holds the overflow bit when A & B are added.
- Sum(S), O/P of adder is applied to the input of register A.

\* Complementor consist of ex-OR gates.

\* Parallel adder consist of full adder circuits.

\* When  $M=0$ , O/P of B is transferred to adder, input carry is 0, O/P of adder is equal to sum  $A+B$ .

\* When  $M=1$ ,  $i^k$  complement of B is applied to adder, input carry is 1 & O/P  $S = A + \bar{B} + 1$ . (At  $2^k$  complement of B) i.e.  $(A-B)$ .

$M=0$  : for Addition

$M=1$  : for Subtraction.

## 1.1.2 Algorithm (flow chart) :-



EA: Register that  
contains E & A.

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

Addition & Subtraction with Signed 2's Complement data -

- \* If addition of two no in Signed-2's Complement form consists of adding two numbers with sign bit treated the same as other bits of the number.
  - A carry out of sign bit position is discarded.
  - Subtraction consists of first taking 2's complement of subtrahend then adding it to minuend.
  - \* If two nos of n digits each are added & sum occupies (n+1) digits, we say an overflow occurred.
  - \* An overflow can be detected by inspecting last two carries out of the addition.
  - \* When two carries are applied to an X-OR gate, overflow is detected when O/P of gate is equal to 1.
- <https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

H/w3 -



A Register  $\rightarrow$  AC (Accumulator) ] leftmost bits in AC & BR represent  
 B Register  $\rightarrow$  BR ] sign bits of numbers.

- $\rightarrow$  Overflow flip flop (V) is set to 1. (If there is an overflow).
- $\rightarrow$  O/P carry in this case is discarded.

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

Flowchart -



V : 1 when XOR of last two carries is 1. Otherwise it is 0.

\* An overflow must be checked during this opn' bcoz two nos added

Could have same sign.

\* <https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>  
If an overflow occurs, then will be an unusual result in AC register.

## MULTIPLICATION ALGORITHM

Ex:

|                   |              |
|-------------------|--------------|
| 10111             | Multiplicand |
| X 10011           | Multiplier   |
| <hr/>             |              |
| 10111             |              |
| 10111 X           |              |
| 00000 XX          |              |
| 000000 XXX        |              |
| 10111             |              |
| <hr/>             |              |
| 110110101 Product |              |

\* Successive Shift & Add operation.

\* If Multiplier is 1 then same multiplicand is copied otherwise 0s are copied.

\* Sign of product depends on signs of multiplicand & multiplier.

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

The Implementation



Steps

- (1) Instead of providing registers to store & add simultaneously as many binary numbers as there are bits in multiplier, it is convenient to provide an adder for the summation of only two binary nos & successively accumulate partial products in register.
  - (2) Instead of shifting multiplicand to the left, partial product is shifted to the right, which results in leaving partial product & multiplicand in the required relative position.
  - (3) If corresponding bit of multiplier is 0, then it is no need to add all zeros to the partial product.
- Ex. 31/2 -
- Multiplicand is stored in Register Q & sign is stored in Qs.
  - Sequence counter (Sc) is initially set to a number equal to number of bits in multiplier.
  - Counter is decremented by 1 after forming each partial product.
  - When content of counter reaches to zero, product is formed & process stops.
  - Initially Multiplicand is in Register B & Multiplier is in Register Q.

# PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

- Arithmetic Shift left multiplies a binary number by 2.
- Arithmetic Shift Right divides a number by 2.



Arithmetic Shift Right (R<sub>0</sub> is lost).

\* Sum of A + B forms a partial product which is transferred to EA Register.

\* Both partial product & multiplier are shifted to right.

\* This shift will be denoted by statement SFT EA Q to designate the right ~~bit~~ shift.

\* L.S.B. of A is shifted into M.S.B. of Q.

\* Bit from E is shifted into most significant position of A, & 0 is shifted into E.

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>  
Right most ~~bit~~ in Register Q, (designated by R<sub>n</sub>), will hold the bit of multiplier, which must be inspected next, because after the shift, one bit of partial product is shifted into Q, pushing multiplier bits one position to right.

## How Algorithm



# PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

$$\begin{array}{r} \text{Ex:-} \\ \begin{array}{r} 1011 \\ \times 101 \\ \hline \end{array} \end{array}$$

$$\begin{array}{r} 11 \\ \times 15 \\ \hline 35 \end{array}$$

(26)



A  $\leftarrow 0$ , E  $\leftarrow 0$ , SC  $\leftarrow 2$

$$\begin{array}{l} B \leftarrow 1011 \\ Q \leftarrow 101 \end{array}$$

(i)  $Q_n = 1 \rightarrow$

$$EA \leftarrow 1011$$

$$\begin{array}{ll} \text{SRF_EAQ:} & 1011 \quad 101 \\ & 0101 \quad 110 \quad SC \leftarrow 2 \end{array}$$

(ii)  $Q_n = 0$

$$\text{SRF_EAQ: } 0010 \quad 111 \quad SC \leftarrow 1$$

$$\begin{array}{r} 1011 \\ \times 101 \\ \hline 1101 \end{array}$$

(iii)  $Q_n = 1$

$$\begin{array}{l} EA \leftarrow 1101 \\ \text{SRF_EAQ: } 1101 \quad 111 \\ \downarrow \\ 0110 \quad 111 \quad SC \leftarrow 0 \end{array}$$

(55)

# PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

Another Example:- Initially multiplier will be init.

| Multiplicand B = 10111 | E | A.    | Q <sup>14</sup> | SC  |
|------------------------|---|-------|-----------------|-----|
|                        | 0 | 00000 | 10011           | 101 |

-  $Q_n = 1$ , add A+B = 0       $\boxed{10111}$        $\boxed{10011}$       101

SHR EA & S  
SC ← SC-1

|   |       |       |     |
|---|-------|-------|-----|
| 0 | 01011 | 11001 | 100 |
|---|-------|-------|-----|

-  $Q_n = 1$ , add A+B = 0       $\boxed{00010}$       11001      100

$$\begin{array}{r} 10111 \\ 01011 \\ \hline 10010 \end{array}$$

SHR EA & S  
SC ← SC-1

|   |       |       |     |
|---|-------|-------|-----|
| 0 | 10001 | 01100 | 011 |
|---|-------|-------|-----|

-  $Q_n = 0$ ,  
SHR EA & S  
SC ← SC-1

|   |                   |       |     |
|---|-------------------|-------|-----|
| 0 | <del>001100</del> | 01011 | 010 |
|---|-------------------|-------|-----|

-  $Q_n = 0$ , ~~add A+B~~  
SHR EA & S  
SC ← SC-1

|   |       |       |     |
|---|-------|-------|-----|
| 0 | 11011 | 01011 | 001 |
|---|-------|-------|-----|

SHR EA & S  
SC ← SC-1

|   |                  |       |     |
|---|------------------|-------|-----|
| 0 | <del>01101</del> | 10101 | 000 |
|---|------------------|-------|-----|

Final result is =  $0110110101$

$\begin{array}{r} \text{in 16} \\ \text{in 32} \\ \text{in 64} \end{array}$       4      1

# PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

(27)

## Booth's MULTIPLICATION ALGORITHM

- It gives a procedure for multiplying binary integer in signed 2's complement representation.
- It operates on the fact that strings of 0's in the multiplier require no addition but just shifting & string of 1's in the multiplier from bit weight  $2^K$  to weight  $2^m$  can be treated as  $2^{K+1} - 2^m$ .

Ex: Binary no. 001110 (+14) has a string of 1's from  $2^3$  to  $2^1$ . Here

$k=3, m=1$  then number can be represented as

$$2^{K+1} - 2^m = 2^4 - 2^1 = 16 - 2 = 14.$$

then multiplication  $M \times 14$       M: Multiplicand  
14: Multiplier.

$$M \times 14 : M \times 2^4 - M \times 2^1$$

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

- \* So product can be obtained by shifting Multiplicand four times left & subtracting M after shifting left once.

\* Section Alg. requires -

(1) Examination of multiplier bits.

(2) Shifting of partial product.

## Rules →

- Multiplicand is subtracted from partial product upon encountering the first least significant 1 in a string of 1's in multiplier.
- Multiplicand is added to partial product upon encountering first 0 (provided that there was a previous 1) in a string of 0's in multiplier.
- Partial product does not change when multiplier bit is identical to previous multiplier bit.

63

Multiply:  $63 \times 110$

M

-M

0 0 1 1 1 1 1 1    1 1 0 0 0 0 0 1



110

| A               | Q               | Q-1 | Count   |                        |
|-----------------|-----------------|-----|---------|------------------------|
| 0 0 0 0 0 0 0 0 | 0 1 1 0 1 1 1 0 | 0   | 1 0 0 0 | Initial; just shift    |
| 0 0 0 0 0 0 0 0 | 0 0 1 1 0 1 1 1 | 0   | 0 1 1 1 | Entering block; add -M |
| 1 1 0 0 0 0 0 1 | 0 0 1 1 0 1 1 1 | 0   | 0 1 1 1 | Shift                  |
| 1 1 1 0 0 0 0 0 | 1 0 0 1 1 0 1 1 | 1   | 0 1 1 0 | In block; just shift   |
| 1 1 1 1 0 0 0 0 | 0 1 0 0 1 1 0 1 | 1   | 0 1 0 1 | In block; just shift   |
| 1 1 1 1 1 0 0 0 | 0 0 1 0 0 1 1 0 | 1   | 0 1 0 0 | Exiting block; add M   |
| 0 0 1 1 0 1 1 1 | 0 0 1 0 0 1 1 0 | 1   | 0 1 0 0 | Shift                  |
| 0 0 0 1 1 0 1 1 | 1 0 0 1 0 0 1 1 | 0   | 0 0 1 1 | Entering block; add -M |
| 1 1 0 1 1 1 0 0 | 1 0 0 1 0 0 1 1 | 0   | 0 0 1 1 | Shift                  |
| 1 1 1 0 1 1 1 0 | 0 1 0 0 1 0 0 1 | 1   | 0 0 1 0 | In block; just shift   |
| 1 1 1 1 0 1 1 1 | 0 0 1 0 0 1 0 0 | 1   | 0 0 0 1 | Exiting block; add M   |
| 0 0 1 1 0 1 1 0 | 0 0 1 0 0 1 0 0 | 1   | 0 0 0 1 | Shift                  |
| 0 0 0 1 1 0 1 1 | 0 0 0 1 0 0 1 0 | 0   | 0 0 0 0 | Done                   |

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

Figure 11.7: Using Booth's algorithm to multiply  $63_{10} \times 110_{10}$ .

Next, we see that we are about to enter a block of 1s, since bit 0 of  $Q$  is 1 and  $Q-1$  is 0. We subtract  $M$  from  $A$  by adding  $-M$ , and then shift. The next two steps just shift everything, since we are within the 1s block. However, the following step requires us to add  $M$  to  $A$ , since we are leaving the block of 1s. We then shift. Immediately, we discover that we are about to enter another block, and so we add  $-M$  to  $A$  and shift. The next two steps require us to shift, then add  $M$  and shift. At this point, the Count register is 0, signaling that we are done. The result is contained in the combined  $A/Q$  registers: 0001101100010010, which is  $6930_{10}$ , the product of  $63 \times 110$ .

To see how this works when one of the numbers is negative, Figure 11.8 shows the algorithm computing  $-63 \times 110$ .

**PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

**PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

Multiply:  $-63 \times 110$

M            -M  
11000001    00111111



| A        | Q        | Q-1 | Count |                        |
|----------|----------|-----|-------|------------------------|
| 00000000 | 01101110 | 0   | 1000  | Initial; just shift    |
| 00000000 | 00110111 | 0   | 0111  | Entering block; add -M |
| 00111111 | 00110111 | 0   | 0111  | Shift                  |
| 00011111 | 10011011 | 1   | 0110  | In block; just shift   |
| 00001111 | 11001101 | 1   | 0101  | In block; just shift   |
| 00000111 | 11100110 | 1   | 0100  | Exiting block; add M   |
| 11001000 | 11100110 | 1   | 0100  | Shift                  |
| 11100100 | 01110011 | 0   | 0011  | Entering block; add -M |
| 00100011 | 01110011 | 0   | 0011  | Shift                  |
| 00010001 | 10111001 | 1   | 0010  | In block; just shift   |
| 00001000 | 11011100 | 1   | 0001  | Exiting block; add M   |
| 11001001 | 11011100 | 1   | 0001  | Shift                  |
| 11100100 | 11101110 | 0   | 0000  | Done                   |

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

Figure 11.8: Using Booth's algorithm to multiply  $-63_{10} \times 110_{10}$ .

#### 11.4 Conclusion

#### 11.5 Further Reading

Sources:

#### 11.6 Exercises

1. Give the two's complement representation of the following numbers (use 8 bits):
  - (a) 9
  - (b) -15
  - (c) 68
  - (d) -79
  - (e) -152

**PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

(28)



\* This algo works for +ve or -ve multipliers in 2's complement representation.

\*  $-14 \Rightarrow -2^4 + 2^2 - 2^1 = -14$

Start operation is for subtraction.

Acc to rules for last opn subtraction, string of multiplier ends with 1. So Algo works for -ve number also.

How for Booth Algo →

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>



\* Sign bits are not separated from rest of registers.

BR: Multiplicand

QR: Multiplier

Qmt: Flipflop to facilitate double bit inspection of multiplier.

Initially - AC: 0

Qmt: 0

SC: N



<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

\* Overflow can not occur b/cz addition & subtraction of multiplicand follow each other.

ASHR (AC + QR): - Arithmetic shift right operation which shifts AC & QR to the right & leaves the sign bit in AC unchanged.

\* Final value of  $Q_{n+1}$  is original sign bit of multiplier.

|     |  | Multiplicand : 10111 (2's comp of -9) | Multiplier : 10011 (2's comp of -13) | Qn    Qn+1    BR = 10111 | AC                  | QR    | Qn+1  | SC |       |
|-----|--|---------------------------------------|--------------------------------------|--------------------------|---------------------|-------|-------|----|-------|
| Ex: |  |                                       |                                      | 1    0                   | Subtract BR from AC | 00000 | 10011 | 0  | 101   |
|     |  |                                       |                                      | - - - - -                | ansr AC, QR         | 00100 | 11001 | 1  | 100   |
|     |  |                                       |                                      | - - - - -                | SC ← SC - 1         | 00010 | 01100 | 1  | 011   |
|     |  |                                       |                                      | - - - - -                | ansr + SC ← SC - 1  | 00010 | 01100 | 0  | 010   |
|     |  |                                       |                                      | - - - - -                | add BR to AC        | 11001 | 11100 | 1  | 11001 |
|     |  |                                       |                                      | - - - - -                | ansr + SC ← SC - 1  | 11100 | 10110 | 0  | 010   |

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>



### array Multiplier

\* Multiplication can be done with one microoperation by means of a combinational circuit that forms product bits all at once.

- It requires ~~array multiplier~~ large no. of gates so it is not economical until development of IC.

Ex: <https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>  
2 bit by 2 bit array multiplier -

$$\begin{array}{r}
 b_1 \quad b_0 \\
 \times \quad \quad \\
 a_1 \quad a_0 \\
 \hline
 a_0 b_1 \quad a_0 b_0 \\
 a_1 b_1 \quad a_1 b_0 \\
 \hline
 c_3 \quad c_2 \quad c_1 \quad c_0
 \end{array}$$



\* If we have more than two bits in partial product for addition, Full adders are used to produce sum.

regarding: A bit of multiplier is added with each bit of multiplicand in as many levels as there are bits in multiplier.

- Binary op in each level of AND gates is added in parallel with partial product of previous level to form a new partial product.
- Least level produced product.
- For  $j$  multiplier bits &  $K$  multiplicand bits we need  $j \times K$  AND gates.
- &  $(j-1) K$ -bit adders to produce a product of  $j+K$  bits.

### DIVISION ALGORITHMS:

Ex:-

Divisor  
 $B = 10001$

$$\begin{array}{r} 110 \\ \hline 0111\ 000\ 00\ 0 \\ 01110 \\ \hline 01100 \\ -10001 \\ \hline 01010 \\ -10001 \\ \hline 001010 \end{array}$$

Quotient = 0

Dividend = A

5 bits of A  $\geq$  B, Quotient had 5 bits.

6 bits of A  $\geq$  B

Shift Right B & Subtract : enter 1 in Q.

6 bits of remainder  $\geq$  B

Shift Right B & Subtract : enter 1 in Q.

Remainder  $\leq$  B ; enter 0 in Q ; Shift right B

Remainder  $\geq$  B

Shift Right B & Subtract ; enter 1 in Q

Remainder  $\leq$  B ; enter 0 in Q.

----- 00110 final remainder

- Partial Remainder / Division could have stopped here to obtain a quotient of 1.
- If partial remainder  $\geq$  divisor ; quotient bit is equal to 1.
- Divisor is then shifted right & subtracted from partial remainder.
- If partial remainder is less than divisor, quotient bit is 0 & no subtraction is needed.

### H/W Implementation:

- Instead of shifting divisor to the right, dividend or partial remainder, is shifted to left.
- Subtraction is achieved by adding A to 2's complement of B.

(30)



\* Register EAQ is now shifted to the left with 0 inserted into  $Q_n$  & previous value of E went.

### Example

Divisor B = 10001,

Double length dividend is stored in A & Q.

\* Dividend is shifted to the left & divisor is subtracted by adding its 2's complement value.

\* E: Contain info abt relative magnitude.

If  $E=1$ , it means  $A \geq B$ .

then quotient bit 1 is inserted into  $Q_n$ .

& partial remainder is shifted to left.

If  $E=0$ , it means  $A < B$ .

then  $Q_n$  remains 0.

- Value of B is then added to earlier partial remainder in A to its previous value.

- Partial remainder is shifted to left & process is repeated again until all five quotient bits are formed.

\* Finally quotient is in Q & final remainder will be in A.

# PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

Ex:

Divisor B = 10001

$$\overline{B+1} = 01111$$

|                                                                                                                                                                 | E | A            | Q     | SC |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------------|-------|----|
| Dividend:                                                                                                                                                       |   | 01110        | 00000 | 5  |
| SRL EAQ                                                                                                                                                         | 0 | 11100        | 00000 |    |
| Add $\overline{B+1}$                                                                                                                                            |   | <u>01111</u> |       |    |
| <u>E=1</u>                                                                                                                                                      | 1 | <u>01011</u> |       |    |
| Set $Q_n=1$                                                                                                                                                     | 1 | 01011        | 00001 | 4  |
| SRL EAQ                                                                                                                                                         | 0 | 10110        | 00010 |    |
| Add $\overline{B+1}$                                                                                                                                            |   | <u>01111</u> |       |    |
| <u>E=1</u>                                                                                                                                                      | 1 | <u>00101</u> |       |    |
| Set $Q_n=1$                                                                                                                                                     | 1 | 00101        | 00011 | 3  |
| SRL EAQ                                                                                                                                                         | 0 | 01010        | 00110 |    |
| Add $\overline{B+1}$                                                                                                                                            | 0 | <u>01111</u> |       |    |
| <a href="https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L">https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L</a> | 0 | <u>11001</u> | 00110 |    |
| $E=0$ ; $Q_n=0$                                                                                                                                                 |   | 11001        |       |    |
| Add B                                                                                                                                                           |   | <u>10001</u> |       |    |
| Restore Remainder                                                                                                                                               | 1 | <u>01010</u> |       | 2  |
| SRL EAQ                                                                                                                                                         | 0 | 10100        | 01100 |    |
| Add $\overline{B+1}$                                                                                                                                            |   | <u>01111</u> |       |    |
| <u>E=1</u>                                                                                                                                                      | 1 | <u>00011</u> |       |    |
| Set $Q_n=1$                                                                                                                                                     | 1 | 00011        | 01101 | 1  |
| SRL EAQ                                                                                                                                                         | 0 | 00110        | 11010 |    |
| Add $\overline{B+1}$                                                                                                                                            | 0 | <u>01111</u> |       |    |
| $E=0$ ; $Q_n=0$                                                                                                                                                 | 0 | <u>10101</u> | 11010 | 0  |
| Add B                                                                                                                                                           |   | <u>10001</u> |       |    |
| Restore Remainder                                                                                                                                               | 1 | <u>00110</u> | 11010 |    |
| Neglect E                                                                                                                                                       |   |              |       |    |
| Remainder in A:                                                                                                                                                 |   | 00110        |       |    |
| Quotient in Q:                                                                                                                                                  |   |              | 11010 |    |

## DIVIDE OVERFLOW:

(3)

\* Division operation may result in a quotient with an overflow.

\* In given example, quotient will consist of 6 bits of five most significant bits of dividend constitute a number greater than divisor.

\* Overflow bit will require one more flip-flop for storing the sixth bit.

- When dividend is twice as long as the divisor, condition for overflow can be stated as - A divide overflow condition occurs if the high order half bits of dividend constitute a number greater than or equal to divisor.

- Division by zero problem must be avoided.

\* This occurs b/c any dividend will be greater than or equal to a divisor which is equal to zero.

DVF ( Divide-Overflow flip-flop): This is set when overflow condition

hpsition for handling divide overflow →

- (1) In some computers, it is responsibility of programmer to check if DVF is set after each divide instruction.
- (2) In older computers, occurrence of divide overflow stopped the computer  
→ this condition was referred to as divide stop.
- (3) To provide an interrupt request when DVF is set. Interrupt causes the computer to suspend the current program & branch to a service routine to take a corrective measure. (To generate an error message explaining the reason why program could not be completed).

(E) To use floating point data,

# PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

H/w Algorithm - H



PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA

(32)

## FLOATING POINT ARITHMETIC OPERATIONS

Basic :- Floating point number can be represented as -  
 $m \times r^e$       m: Mantissa may be a fraction or integer.

Ex:-  $53.725 = 0.53725 \times 10^3 = e$   
 $M$

- \* A floating point number is normalized if most significant digit of mantissa is non zero.
- \* Floating point representation increases range of numbers that can be accommodated in a given register.

### 38-bit words

Range of fixed point integer -  $\pm (2^{47} - 1) \approx \pm 10^{14}$

for floating point representation -

36 Bits Mantissa + 12 Bits for exponent.

<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>  
Range of numbers -

$$\pm (1 - 2^{-35}) \times 2^{2047}$$

### Addition & Subtraction:-

- Adding or subtracting two numbers requires first an alignment of radix point since exponent parts must be made equal before adding or subtracting mantissa.

Ex:-  
 $.5372400 \times 10^2$   
 $+ .1580000 \times 10^{-1}$

- Shifting to the left : loss of most significant digits,  $\rightarrow$  gt causes an error.
- Shifting to the right : loss of least significant digits. (Preferable)  
 $\hookrightarrow$  gt only reduce Accuracy

\* Visual Alignment procedure - To shift the mantissa that has smaller exponent to the right by a number of places equal to difference b/w exponents.

$$\begin{array}{r} .5372400 \times 10^2 \\ + .0001580 \times 10^2 \\ \hline \end{array}$$

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

\* Overflow: When two normalized mantissas are added, sum may contain an overflow digit.

- An overflow can be corrected by shifting sum one to the right & incrementing exponent.

- When two numbers are subtracted, result may contain most significant zeros as -

$$\begin{array}{r} 156780 \times 10^5 \\ 156430 \times 10^5 \\ \hline 100350 \times 10^5 \end{array}$$

Underflow: - If there is 0 in most significant position of mantissa.

Solution: Shift the mantissa to the left & decrement the exponent until a nonzero digit appears in first position.

\* A normalization procedure is performed after each operation to ensure that all results are in normalized form.  
<https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>

\* Floating point multiplication & division do not require alignment of ~~mantissa~~ exponent.

\* Operations performed with mantissas are same as in fixed-point numbers. (Some registers & circuit).

\* Operations performed with exponents are compare, & increment (for aligning mantissa), add & subtract (for multiplication & division) & decrement (to normalize the result).

\* Exponent may be represented as -

- sign magnitude
- Signed -2's complement
- Signed -1's complement.

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

## Register Configuration:

(33)

- Same registers & adder are used for fixed point arithmetic as used for processing the mantissa.
- There are 3 registers - BR, AC & QR.
- \* Mantissa part has same uppercase letter symbols as in fixed point representation.
- \* Exponent part uses correspondingly lowercase letter symbol.

## biased Exponent:

- \* Bias is a fixe number that is added to each exponent as floating point number is formed, so that internally all exponents are positive.

S: <https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>  
Exponent has range -50 to 49.

Add bias of 50, then exponent register contains number  $e+50$ .  $e$ : actual exponent.

Exponents are represented in registers as positive numbers in the range of 00 to 99.

Adv: - They contain only fixe numbers.

- Simpler to compare their relative magnitudes w/o being concerned with their signs.



\* So each floating point number has a mantissa in signed magnitude representation & a biased exponent.



BR

E

Parallel Adder

Parallel Adder  
& comparator



AC



QR

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

AC: Has mantissa, sign in A & magnitude in A.

- Exponent is stored in a register.

A<sub>s</sub>: Most significant bit of A. (for normalized number, this bit position must be a 1).

BR: Subdivided into S<sub>s</sub>, B & b.

QR: Subdivided into Q<sub>s</sub>, Q & q.

\* Parallel adder adds the two mantissas & transfer the sum into A & carry into E.

\* A separate parallel adder is used for exponents.

\* Floating point numbers are so large that the chance of an exponent overflow is very less. For this reason, exponent overflow will be neglected.

# **PREPARED BY: MR. PIYUSH GUPTA, MR. ZATIN GUPTA**

## **Arithmetic Logic Unit (ALU) Design**

An arithmetic logic unit (ALU) represents the fundamental building block of the central processing unit of a computer.

An ALU is a digital circuit used to perform arithmetic and logic operations.

### **What Is an ALU?**

An arithmetic logic unit (ALU) is a digital circuit used to perform arithmetic and logic operations.

It represents the fundamental building block of the central processing unit (CPU) of a computer. Modern CPUs contain very powerful and complex ALUs. In addition to ALUs, modern CPUs contain a control unit (CU).

Most of the operations of a CPU are performed by one or more ALUs, which load data from input registers.

A register is a small amount of storage available as part of a CPU. The control unit tells the ALU what operation to perform on that data, and the ALU stores the result in an output register.

The control unit moves the data between these registers, the ALU, and memory. <https://www.youtube.com/watch?v=PLqisrLSFbMDKZRViED3mwBVHl5c4LG-L>

### **How an ALU Works**

An ALU performs basic arithmetic and logic operations. Examples of arithmetic operations are addition, subtraction, multiplication, and division. Examples of logic operations are comparisons of values such as NOT, AND, and OR.

All information in a computer is stored and manipulated in the form of binary numbers, i.e. 0 / 1.

Transistor switches are used to manipulate binary numbers since there are only two possible states of a switch: open or closed. An open transistor, through which there is no current, represents a 0. A closed transistor, through which there is a current, represents a 1.

Operations can be accomplished by connecting multiple transistors. One transistor can be used to control a second one - in effect, turning the transistor switch on or off depending on the state of the second transistor.

This is referred to as a gate because the arrangement can be used to allow or stop a current. The simplest type of operation is a NOT gate.

This uses only a single transistor. It uses a single input and produces a single output, which is always the opposite of the input.

This figure shows the logic of the NOT gate:



Other gates consist of multiple transistors and use two inputs.

The OR gate results in a 1 if either the first or the second input is a 1. The OR gate only results in a 0 if both inputs are 0. This figure shows the logic of the OR gate:



The AND gate results in a 1 only if both the first and second input are 1s. This figure shows the logic of the AND gate: <https://www.youtube.com/playlist?list=PLqisrLSFbMDKZRViIED3mwBVH15c4LG-L>



The XOR gate, also pronounced X-OR gate, results in a 0 if both the inputs are 0 or if both are 1. Otherwise, the result is a 1. This figure shows the logic of the XOR gate:



## Design of ALU:

ALU or Arithmetic Logical Unit is a digital circuit to do arithmetic operations like addition, subtraction, division, multiplication and logical operations like and, or, xor, nand, nor etc.

A simple block diagram of a 4-bit ALU for operations and, or, xor and Add is shown here:



The 4-bit ALU block is combined using 4 1-bit ALU blocks

## Design Issues:

The circuit functionality of a 1-bit ALU is shown here, depending upon the control signal  $S_1$  and  $S_0$  the circuit operates as follows:

for Control signal  $S_1 = 0, S_0 = 0$ , the output is **A And B**,

for Control signal  $S_1 = 0, S_0 = 1$ , the output is **A Or B**,

for Control signal  $S_1 = 1, S_0 = 0$ , the output is **A Xor B**,

for Control signal  $S_1 = 1, S_0 = 1$ , the output is **A Add B**.