tutorial: IEEE754 standard, to store floating point variables in memory, with C18 compiler.
IEEE754 standard for the representation of real numbers in floating point format: When you define a variable of type "float" in memory, the value is stored in 4 bytes, or 32 bits, distributed as follows: a sign bit, 8 bit exponent and a mantissa of 23 bits.
The numbers represented in floating point are generated from a mantissa and an exponent and can take values very large or very small. The exponent moves the binary point value expressed in the mantissa, to positions +127...127 shifting the binary point right or left respectively. To convert the floating point format to a decimal value, an implicit "1" is added to the 23 bit mantissa forming a 24 bit mantissa. The complete 32 bit representation of the floating point value is organized as follows. Please see picture. Sign: is bit 7 of byte 1. If the value is 0, the number is positive, if 1, negative. Exponent: is an 8 bit value, with an offset of 7FH. To find the real value of the exponent, you must subtract 7FH to the value stored in memory. The 8 bits of the exponent forms with the seven least significant bits of byte 1 and the most significant bit of byte 2. The real exponent expresses the number of positions to the right (when the value is positive) or left (when the value is negative) that should move the binary point in the mantissa. Mantissa: consists of 23 bits. These bits are the least significant 7 bits of byte 2 and the 8 bit bytes 3 and 4. When converting to its real value, you must add an implicit "1", as indicated below. The implicit "1": when converting to decimal the binary value stored in memory, the mantissa must be added a "1" to the left of the binary value of 23 bits, to form the 24bit representation. The binary point position: the position of the binary point that separates the integer part of the fractional part, is always after (right) the implicit "1" of the mantissa. This initial position will move to the right or left, according to the real exponent value. Please see the examples below.
Examples:
DEFINITION OF A FLOATING POINT VARIABLE IN C:
