Normal number (computing) explained

In computing, a normal number is a non-zero number in a floating-point representation which is within the balanced range supported by a given floating-point format: it is a floating point number that can be represented without leading zeros in its significand.

The magnitude of the smallest normal number in a format is given by:

b^

where b is the base (radix) of the format (like common values 2 or 10, for binary and decimal number systems), and E_ depends on the size and layout of the format.

Similarly, the magnitude of the largest normal number in a format is given by

b^\cdot\left(b - b^\right)

where p is the precision of the format in digits and E_ is related to E_ as:

E_\, \overset\, 1 - E_ = \left(-E_\right) + 1

In the IEEE 754 binary and decimal formats, b, p, E_, and E_ have the following values:

+Smallest and Largest Normal Numbers for common numerical FormatsFormat

b

p

Emin

Emax

Smallest Normal NumberLargest Normal Number
binary16211−1415

2-14\equiv0.00006103515625

215\left(2-21-11\right)\equiv65504

binary32224−126127

2-126\equiv

1
2126

2127\left(2-21-24\right)

binary64253−10221023

2-1022\equiv

1
21022

21023\left(2-21-53\right)

binary1282113−1638216383

2-16382\equiv

1
216382

216383\left(2-21-113\right)

decimal32107−9596

10-95\equiv

1
1095

1096\left(10-101-7\right)\equiv9.9999991096

decimal641016−383384

10-383\equiv

1
10383

10384\left(10-101-16\right)

decimal1281034−61436144

10-6143\equiv

1
106143

106144\left(10-101-34\right)

For example, in the smallest decimal format in the table (decimal32), the range of positive normal numbers is 10-95 through 9.999999 × 1096.

Non-zero numbers smaller in magnitude than the smallest normal number are called subnormal numbers (or denormal numbers).

Zero is considered neither normal nor subnormal.

See also