Search code examples
floating-pointdecimalprecisionfloating-accuracy

If I reduce the precision of float to 8 will I get correct numbers when working with currency?


I know that if I use float numbers when calculating money, I will have the risk of getting incorrect results if the results are rounded to lower precision, isn't the results equal?

>>> 234042163/(2**24)
13.949999988079071
>>> (Decimal("234042163")/(Decimal("2")**Decimal("24")))
Decimal('13.949999988079071044921875')
>>> (Decimal("234042163")/(Decimal("2")**Decimal("24"))).quantize(Decimal("1.00000000"))
Decimal('13.94999999')
>>> round(234042163/(2**24), 8)
13.94999999

Solution

  • No, it isn't. Floating point numbers always have the full precision and when you do any operations with them the inaccuracies will cause issues. Also the main issue isn't the limited accuracy but the fact that some numbers cannot be represented accurately. Just like you can't represent 1/3 accurately as a decimal, you can't represent some numbers accurately with floats.

    If you perform operations with these numbers there will be problems even if you try to round them to a certain number of digits.

    The only way to ever have proper currency calculations is using scaled integers, meaning the decimal type in many languages. It can represent the numbers accurately on its range and will not cause issues.