Misplaced Pages

IEEE 754-1985: Difference between revisions

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editNext edit →Content deleted Content addedVisualWikitext
Revision as of 18:34, 3 February 2011 editDmcq (talk | contribs)Extended confirmed users, Pending changes reviewers29,599 edits Reverted 1 edit by Chbarts (talk); Read the second cite and discuss at History of computing hardware. (TW)← Previous edit Revision as of 20:47, 3 February 2011 edit undoChbarts (talk | contribs)Extended confirmed users1,014 edits Undid revision 411824114 by Dmcq (talk) Please stop trolling. Your opinion means nothing.Next edit →
Line 388: Line 388:
Even before it was approved, the draft standard had been implemented by a number of manufacturers.<ref>{{cite web|url=http://www.eecs.berkeley.edu/~wkahan/ieee754status/754story.html|title=An Interview with the Old Man of Floating-Point| author=Charles Severance |date=20 February 1998}}</ref><ref>{{cite web|publisher=Connexions |url=http://cnx.org/content/m32770/latest/ |title=History of IEEE Floating-Point Format|author=Charles Severance}}</ref> Even before it was approved, the draft standard had been implemented by a number of manufacturers.<ref>{{cite web|url=http://www.eecs.berkeley.edu/~wkahan/ieee754status/754story.html|title=An Interview with the Old Man of Floating-Point| author=Charles Severance |date=20 February 1998}}</ref><ref>{{cite web|publisher=Connexions |url=http://cnx.org/content/m32770/latest/ |title=History of IEEE Floating-Point Format|author=Charles Severance}}</ref>


The ], the world's first working computer, implemented floating point with infinities and undefined values which were passed through operations.<ref>{{citation |url=http://ed-thelen.org/comp-hist/Zuse_Z1_and_Z3.pdf |title=Konrad Zuse's Legacy: The Architecture of the Z1 and Z3| last=Rojas |first=Roúl | journal=IEEE Annals of the History of Computing |volume=19 |issue=2 |year=1997}}</ref><ref>{{citation |title=A Brief History of Computing |author=Gerard O'Regan |publisher=Springer |page=69 |isbn=971-1-84800-083-4 |year=2008}}</ref> These were not implemented properly in hardware in any other machine until the ], which was announced in 1980. This was the first chip to implement the draft standard. The ], according to some the world's first working computer, implemented floating point with infinities and undefined values which were passed through operations.<ref>{{citation |url=http://ed-thelen.org/comp-hist/Zuse_Z1_and_Z3.pdf |title=Konrad Zuse's Legacy: The Architecture of the Z1 and Z3| last=Rojas |first=Roúl | journal=IEEE Annals of the History of Computing |volume=19 |issue=2 |year=1997}}</ref><ref>{{citation |title=A Brief History of Computing |author=Gerard O'Regan |publisher=Springer |page=69 |isbn=971-1-84800-083-4 |year=2008}}</ref> These were not implemented properly in hardware in any other machine until the ], which was announced in 1980. This was the first chip to implement the draft standard.


==See also== ==See also==

Revision as of 20:47, 3 February 2011

The first IEEE Standard for Binary Floating-Point Arithmetic (IEEE 754-1985) set the standard for floating-point computation for 23 years. It became the most widely-used standard for floating-point computation, and is followed by many CPU and FPU implementations. Its binary floating-point formats and arithmetic are preserved in the new IEEE 754-2008 standard which replaced it.

The 754-1985 standard defines formats for representing floating-point numbers (including negative zero and denormal numbers) and special values (infinities and NaNs) together with a set of floating-point operations that operate on these values. It also specifies four rounding modes and five exceptions (including when the exceptions occur, and what happens when they do occur).

Summary

IEEE 754-1985 specifies four formats for representing floating-point values: single-precision (32-bit), double-precision (64-bit), single-extended precision (≥ 43-bit, not commonly used) and double-extended precision (≥ 79-bit, usually implemented with 80 bits). Only 32-bit values are required by the standard; the others are optional. Many languages specify that IEEE formats and arithmetic be implemented, although sometimes it is optional. For example, the C programming language, which pre-dated IEEE 754, now allows but does not require IEEE arithmetic (the C float typically is used for IEEE single-precision and double uses IEEE double-precision).

The full title of the standard is IEEE Standard for Binary Floating-Point Arithmetic (ANSI/IEEE Std 754-1985), and it is also known as IEC 60559:1989, Binary floating-point arithmetic for microprocessor systems (originally the reference number was IEC 559:1989). Later there was an IEEE 854-1987 for "radix independent floating point" as long as the radix is 2 or 10. In June 2008, a major revision to IEEE 754 and IEEE 854 was approved by the IEEE. See IEEE 754r.

Structure of a floating-point number

General layout

The three fields in an IEEE 754 float

Binary floating-point numbers in IEEE 754-1985 format consist of three fields: sign bit, exponent, and fraction. The fraction is the significand without its most significant bit.

Exponent biasing

Instead of being stored in two's complement format, the exponent is stored in "biased format" (offset binary): a constant, called the bias, is added to it so that the lowest representable exponent is represented as 1, and there is no sign bit. The bias is equal to 2−1, where n is the number of bits in the exponent field. Thus the actual number stored in the exponent field is the true exponent plus the bias.

For example, in single-precision format, where the exponent field is 8 bits long, the bias is 2−1 = 128 − 1 = 127. So, for example, an exponent of 17 would be represented as 144 in single precision (144 = 17 + 127).

Cases

The most significant bit of the significand (not stored) is determined by the value of biased exponent. If 0 < {\displaystyle 0<} exponent < 2 e 1 {\displaystyle <2^{e}-1} , the most significant bit of the significand is 1, and the number is said to be normalized. If exponent is 0 and fraction is not 0, the most significant bit of the significand is 0 and the number is said to be de-normalized. Three other special cases arise:

  1. if exponent is 0 and fraction is 0, the number is ±0 (depending on the sign bit)
  2. if exponent = 2 e 1 {\displaystyle 2^{e}-1} and fraction is 0, the number is ±infinity (again depending on the sign bit), and
  3. if exponent = 2 e 1 {\displaystyle 2^{e}-1} and fraction is not 0, the number being represented is not a number (NaN).

This can be summarized as:

Type Exponent Fraction
Zeroes 0 0
Denormalized numbers 0 non zero
Normalized numbers 1 {\displaystyle 1} to 2 e 2 {\displaystyle 2^{e}-2} any
Infinities 2 e 1 {\displaystyle 2^{e}-1} 0
NaNs 2 e 1 {\displaystyle 2^{e}-1} non zero

Single-precision 32-bit

The number 0.15625 represented as a single-precision IEEE 754-1985 floating-point number. See text for explanation.

A single-precision binary floating-point number is stored in 32 bits, as shown at right.

If the number is normalized (the most common case), it has this value:

( 1 ) s i g n × 1. f r a c t i o n × 2 e x p o 127 {\displaystyle (-1)^{sign}\times 1.fraction\times 2^{expo-127}}

where:

sign = the sign bit. (0 makes the number positive or zero; 1 makes it negative.)
expo = the 8-bit number stored in the exponent field. expo = the true exponent + 127. (See above for why.)
fraction = the 23 bits of the fraction field.

In the example, the sign is 0, so the number is positive; expo is 124, so the true exponent is –3; and fraction is .01. So, the represented number is:

1.01 2 × 2 3 = 1.25 10 × 1 8 = 0.15625 {\displaystyle 1.01_{2}\times 2^{-3}=1.25_{10}\times {\frac {1}{8}}=0.15625}

(Subscripts indicate the base of the number: base 2 or base 10.)

Notes

  1. Denormalized numbers are the same except that e = −126 and m is 0.fraction. (e is not −127 : The fraction has to be shifted to the right by one more bit, in order to include the leading bit, which is not always 1 in this case. This is balanced by incrementing the exponent to −126 for the calculation.)
  2. −126 is the smallest exponent for a normalized number
  3. There are two Zeroes, +0 (s is 0) and −0 (s is 1)
  4. There are two Infinities +∞ (s is 0) and −∞ (s is 1)
  5. NaNs may have a sign and a fraction, but these have no meaning other than for diagnostics; the first bit of the fraction is often used to distinguish signaling NaNs from quiet NaNs
  6. NaNs and Infinities have all 1s in the Exp field.
  7. The positive and negative numbers closest to zero (represented by the denormalized value with all 0s in the Exp field and the binary value 1 in the Fraction field) are
    ±2 ≈ ±1.4012985×10
  8. The positive and negative normalized numbers closest to zero (represented with the binary value 1 in the Exp field and 0 in the fraction field) are
    ±2 ≈ ±1.175494351×10
  9. The finite positive and finite negative numbers furthest from zero (represented by the value with 254 in the Exp field and all 1s in the fraction field) are
    ±(1-2)×2 ≈ ±3.4028235×10

Here is the summary table from the previous section with some 32-bit single-precision examples:

Type Sign Exp Exp+Bias Exponent Significand (Mantissa) Value
Zero 0 -127 0 0000 0000 000 0000 0000 0000 0000 0000 0.0
Negative zero 1 -127 0 0000 0000 000 0000 0000 0000 0000 0000 −0.0
One 0 0 127 0111 1111 000 0000 0000 0000 0000 0000 1.0
Minus One 1 0 127 0111 1111 000 0000 0000 0000 0000 0000 −1.0
Smallest denormalized number * -127 0 0000 0000 000 0000 0000 0000 0000 0001 ±2 × 2 = ±2 ≈ ±1.4×10
"Middle" denormalized number * -127 0 0000 0000 100 0000 0000 0000 0000 0000 ±2 × 2 = ±2 ≈ ±5.88×10
Largest denormalized number * -127 0 0000 0000 111 1111 1111 1111 1111 1111 ±(1−2) × 2 ≈ ±1.18×10
Smallest normalized number * -126 1 0000 0001 000 0000 0000 0000 0000 0000 ±2 ≈ ±1.18×10
Largest normalized number * 127 254 1111 1110 111 1111 1111 1111 1111 1111 ±(2−2) × 2 ≈ ±3.4×10
Positive infinity 0 128 255 1111 1111 000 0000 0000 0000 0000 0000 +∞
Negative infinity 1 128 255 1111 1111 000 0000 0000 0000 0000 0000 −∞
Not a number * 128 255 1111 1111 non zero NaN
* Sign bit can be either 0 or 1 .

Range and Precision Table

Precision is defined as the min. difference between two successive mantissa representations; thus it is function only in the mantissa; while the gap is defined as the difference between two successive numbers..

Some example range and gap values for given exponents:

Exponent Minimum Maximum Gap
0 1 1.999999880791 1.19209289551e-7
1 2 3.99999976158 2.38418579102e-7
2 4 7.99999952316 4.76837158203e-7
10 1024 2047.99987793 1.220703125e-4
11 2048 4095.99975586 2.44140625e-4
23 8388608 16777215 1
24 16777216 33554430 2
127 1.7014e38 3.4028e38 2.02824096037e31

As an example, 16,777,217 can not be encoded as a 32-bit float as it will be rounded to 16,777,216. This shows why floating point arithmetic is unsuitable for accounting software. However, all integers within the representable range that are a power of 2 can be stored in a 32-bit float without rounding.

A more complex example

Bit values for the IEEE 754 32bit float -118.625

The decimal number −118.625 is encoded using the IEEE 754 system as follows:

  1. The sign, the exponent, and the fraction are extracted from the original number. Because the number is negative, the sign bit is "1".
  2. Next, the number (without the sign; i.e., unsigned, no two's complement) is converted to binary notation, giving 1110110.101. The 101 after the binary point has the value 0.625 because it is the sum of:
    1. (2) × 1, from the first bit after the binary point
    2. (2) × 0, from the second bit
    3. (2) × 1, from the third bit.
  3. That binary number is then normalized; that is, the binary point is moved left, leaving only a 1 to its left. The number of places it is moved gives the (power of two) exponent: 1110110.101 becomes 1.110110101 × 2. After this process, the first binary digit is always a 1, so it need not be included in the encoding. The rest is the part to the right of the binary point, which is then padded with zeros on the right to make 23 bits in all, which becomes the significand bits in the encoding: That is, 11011010100000000000000.
  4. The exponent is 6. This is encoded by converting it to binary and biasing it (so the most negative encodable exponent is 0, and all exponents are non-negative binary numbers). For the 32-bit IEEE 754 format, the bias is +127 and so 6 + 127 = 133. In binary, this is encoded as 10000101.

Double-precision 64 bit

The three fields in a 64bit IEEE 754 float

Double precision is essentially the same except that the fields are wider:

The fraction part is much larger, while the exponent is only slightly larger. NaNs and Infinities are represented with Exp being all 1s (2047). If the fraction part is all zero then it is Infinity, else it is NaN.

For Normalized numbers the exponent bias is +1023 (so e is exponent − 1023). For Denormalized numbers the exponent is (−1022) (the minimum exponent for a normalized number—it is not (−1023) because normalised numbers have a leading 1 digit before the binary point and denormalized numbers do not). As before, both infinity and zero are signed.

Notes:

  1. The positive and negative numbers closest to zero (represented by the denormalized value with all 0s in the Exp field and the binary value 1 in the Fraction field) are
    ±2 ≈ ±5×10
  2. The positive and negative normalized numbers closest to zero (represented with the binary value 1 in the Exp field and 0 in the fraction field) are
    ±2 ≈ ±2.2250738585072020×10
  3. The finite positive and finite negative numbers furthest from zero (represented by the value with 2046 in the Exp field and all 1s in the fraction field) are
    ±((1-(1/2))2) ≈ ±1.7976931348623157×10


Some example range and gap values for given exponents:

Exponent Minimum Maximum Gap
0 1 1.9999999999999997 2.2204460492503130808472633e-16
1 2 3.9999999999999995 8.8817841970012523233890533447266e-16
2 4 7.9999999999999990 3.5527136788005009293556213378906e-15
10 1024 2047.9999999999997 2.27373675443232059478759765625e-13
11 2048 4095.9999999999995 4.5474735088646411895751953125e-13
52 4503599627370496 9007199254740991 1
53 9007199254740992 18014398509481982 2
1023 8.9884656743115800e+307 1.7976931348623157e308 1.9958403095347198116563727130368e292

Comparing floating-point numbers

Every possible bit combination is either a NaN or a number with a unique value in the affinely extended real number system with its associated order, except for the two bit combinations negative zero and positive zero, which sometimes require special attention (see below). The binary representation has the special property that, excluding NaNs, any two numbers can be compared like sign and magnitude integers (although with modern computer processors this is no longer directly applicable): if the sign bit is different, the negative number precedes the positive number (except that negative zero and positive zero should be considered equal), otherwise, relative order is the same as lexicographical order but inverted for two negative numbers; endianness issues apply.

Floating-point arithmetic is subject to rounding that may affect the outcome of comparisons on the results of the computations.

Although negative zero and positive zero are generally considered equal for comparison purposes, some programming language relational operators and similar constructs might or do treat them as distinct. According to the Java Language Specification, comparison and equality operators treat them as equal, but Math.min() and Math.max() distinguish them (officially starting with Java version 1.1 but actually with 1.1.1), as do the comparison methods equals(), compareTo() and even compare() of classes Float and Double.

Rounding floating-point numbers

The IEEE standard has four different rounding modes; the first is the default; the others are called directed roundings.

  • Round to Nearest – rounds to the nearest value; if the number falls midway it is rounded to the nearest value with an even (zero) least significant bit, which occurs 50% of the time (in IEEE 754r this mode is called roundTiesToEven to distinguish it from another round-to-nearest mode)
  • Round toward 0 – directed rounding towards zero
  • Round toward + {\displaystyle +\infty } – directed rounding towards positive infinity
  • Round toward {\displaystyle -\infty } – directed rounding towards negative infinity.

Extending the real numbers

The IEEE standard employs (and extends) the affinely extended real number system, with separate positive and negative infinities. During drafting, there was a proposal for the standard to incorporate the projectively extended real number system, with a single unsigned infinity, by providing programmers with a mode selection option. In the interest of reducing the complexity of the final standard, the projective mode was dropped, however. The Intel 8087 and Intel 80287 floating point co-processors both support this projective mode.

Functions and predicates

Standard operations

The following functions must be provided:

  • Add, subtract, multiply, divide
  • Square root
  • Floating point remainder. This is not like a normal modulo operation, it can be negative for two positive numbers. It returns the exact value of x-(round(x/y)*y).
  • Round to nearest integer. For undirected rounding when halfway between two integers the even integer is chosen.
  • Comparison operations. Besides the more obvious results, IEEE754 defines that -inf = -inf, inf = inf and x ≠ NaN for any x (including NaN).

Recommended functions and predicates

  • Under some C compilers, copysign(x,y) returns x with the sign of y, so abs(x) equals copysign(x,1.0). This is one of the few operations which operates on a NaN in a way resembling arithmetic. The function copysign is new in the C99 standard.
  • −x returns x with the sign reversed. This is different from 0−x in some cases, notably when x is 0. So −(0) is −0, but the sign of 0−0 depends on the rounding mode.
  • scalb(y, N)
  • logb(x)
  • finite(x) a predicate for "x is a finite value", equivalent to −Inf < x < Inf
  • isnan(x) a predicate for "x is a nan", equivalent to "x ≠ x"
  • x <> y which turns out to have different exception behavior than NOT(x = y).
  • unordered(x, y) is true when "x is unordered with y", i.e., either x or y is a NaN.
  • class(x)
  • nextafter(x,y) returns the next representable value from x in the direction towards y

History

In 1976 Intel began planning to produce a floating point coprocessor. Dr John Palmer, the manager of the effort, persuaded them that they should try to develop a standard for all their floating point operations. William Kahan was hired as a consultant; he had helped improve the accuracy of Hewlett Packard's calculators. Kahan initially recommended that the floating point base be decimal but the hardware design of the coprocessor was too far advanced to make that change.

The work within Intel worried other vendors, who set up a standardization effort to ensure a 'level playing field'. Kahan attended the second IEEE 754 standards working group meeting, held in November 1977. Here, he received permission from Intel to put forward a draft proposal based on the standard arithmetic part of their design for a coprocessor. The formats were similar to but slightly different from existing VAX and CDC formats and introduced gradual underflow. The arguments over gradual underflow lasted until 1981 when an expert commissioned by DEC to assess it sided against the dissenters.

Even before it was approved, the draft standard had been implemented by a number of manufacturers.

The Zuse Z3, according to some the world's first working computer, implemented floating point with infinities and undefined values which were passed through operations. These were not implemented properly in hardware in any other machine until the Intel 8087, which was announced in 1980. This was the first chip to implement the draft standard.

See also

References

  1. "Referenced documents". IEC 60559:1989, Binary Floating-Point Arithmetic for Microprocessor Systems (previously designated IEC 559:1989)
  2. ^ Prof. W. Kahan. "Lecture Notes on the Status of IEEE 754" (PDF). October 1, 1997 3:36 am. Elect. Eng. & Computer Science University of California. Retrieved 2007-04-12. {{cite journal}}: Cite journal requires |journal= (help)
  3. Computer Arithmetic; Hossam A. H. Fahmy, Shlomo Waser, and Michael J. Flynn; http://arith.stanford.edu/~hfahmy/webpages/arith_class/arith.pdf
  4. The Java Language Specification
  5. John R. Hauser (1996). "Handling Floating-Point Exceptions in Numeric Programs" (PDF). ACM Transactions on Programming Languages and Systems. 18 (2). {{cite journal}}: Unknown parameter |month= ignored (help)
  6. David Stevenson (1981). "IEEE Task P754: A proposed standard for binary floating-point arithmetic". IEEE Computer. 14 (3): 51–62. {{cite journal}}: Unknown parameter |month= ignored (help)
  7. William Kahan and John Palmer (1979). "On a proposed floating-point standard". SIGNUM Newsletter. 14 (Special): 13–21. doi:10.1145/1057520.1057522.
  8. W. Kahan 2003, pers. comm. to Mike Cowlishaw and others after an IEEE 754 meeting
  9. Charles Severance (20 February 1998). "An Interview with the Old Man of Floating-Point".
  10. Charles Severance. "History of IEEE Floating-Point Format". Connexions.
  11. Rojas, Roúl (1997), "Konrad Zuse's Legacy: The Architecture of the Z1 and Z3" (PDF), IEEE Annals of the History of Computing, 19 (2)
  12. Gerard O'Regan (2008), A Brief History of Computing, Springer, p. 69, ISBN 971-1-84800-083-4 {{citation}}: Check |isbn= value: invalid prefix (help)

Further reading

External links

IEEE standards
Current
802 series
802
802.1
802.3
(Ethernet)
802.11
(Wi-Fi)
802.15
Proposed
Superseded
Categories:
IEEE 754-1985: Difference between revisions Add topic