Reputation: 1116
In the chapter "How Numbers Work" of the book "How JavaScript Works" by Douglas Crockford it is mentioned that a number in JavaScript is made up of 1 signed bit, 11 exponent bits, and 53 significant bits. This totals to 65 bits and some clever encoding allow these 65 bits to be stored in 64 bits, which we understand as a 64-bit floating-point number.
Going further the significant digits are stored as a binary fraction in the range 0.5 <= significand < 1.0
In that form, the most significant bit is always a 1. Since that bit is always a 1, it does not need to be stored in the number. This yields a bonus bit.
I do not understand
Please help me in understanding this concept or guide me in the direction that can help me.
Upvotes: 3
Views: 160
Reputation: 48113
Going further the significant digits are stored as a binary fraction in the range
0.5 <= significand < 1.0
Actually, no. An actual, normalized significand (which differs from the stored, encoded significand) is always in the range 1.0 ≤ significand < 2.0. Or, in binary, it's always in the range 0b1.00000…
to 0b1.11111…
.
That's the form in which the leading bit (the single bit to the left of the "decimal point") is always, always 1. And then it's true that
Since that bit is always a 1, it does not need to be stored in the number. This yields a bonus bit.
So the stored, encoded significand is the actual significand with the leading "1." stripped off.
Upvotes: 0
Reputation: 180958
The Fraction (mantissa) portion of the double-precision floating point format Crockford refers to has 52 bits, not 53:
The Wikipedia article refers to "effective precision." They explain it like this:
The format is written with the significand having an implicit integer bit of value 1. With the 52 bits of the fraction (F) significand appearing in the memory format, the total precision is therefore 53 bits (approximately 16 decimal digits, 53 log10(2) ≈ 15.955).
That must be what Crockford refers to as "clever encoding." From a programmer's perspective, it doesn't matter all that much unless you're doing something exotic like bit twiddling or integer casting. That's why Crockford doesn't explain it further.
Related: Is it 52 or 53 bits of floating point precision?
Upvotes: 1