I’ve written a small function in C, which almost do the same work as standart function `fcvt’. As you may know, this function takes a float/double and make a string, representing this number in ANSI characters. Everything works 😉
For example, for number 1.33334, my function gives me string: “133334” and set up special integer variable `decimal_part’, in this example will be 1, which means in decimal part only 1 symbol, everything else is a fraction.
Now I’m curious about what to do standart C function `printf’. It can take %a or %e as format string. Let me cite for %e (link junked):
“double” argument is output in scientific notation
[-]m.nnnnnne+xx
… The exponent always contains two digits.
It said: “The exponent always contains two digits”. But what is an Exponent? This is the main question. And also, how to get this ‘exponent’ from my function above or from `fcvt’.
The notation might be better explained if we expand the e:
So you have one digit of m (from 0 to 9, but it will only ever be 0 if the entire value is 0), and several digits of n. I guess it might be best to show with examples:
You can look up scientific notation off Google, but it is useful for expressing very large or small numbers like 1232100000000000000 would be 1.2321e24 (I didn’t actually count, exponent may be inaccurate).
In C, I think you can actually extract the exponent from the top 12 bits (the first being the sign which you will have to ignore). See: IEEE758-1985 Floating Point