How Python Compares Floats and Ints: When Equals Isn’t Really Equal - eviltoast
  • magic_lobster_party@kbin.run
    link
    fedilink
    arrow-up
    35
    arrow-down
    1
    ·
    edit-2
    6 months ago

    TL;DR:

    In Python, following returns False.

    9007199254740993 == 9007199254740993.0

    The floating point number 9007199254740993.0 is internally represented in memory as 9007199254740992.0 (due to how floating point works).

    Python has special logic for comparing int with floats. Here it will try to compare the int 9007199254740993 with the float 9007199254740992.0. Python sees that the integer parts are different, so it will stop there and return False.

      • Cethin@lemmy.zip
        link
        fedilink
        English
        arrow-up
        6
        arrow-down
        1
        ·
        6 months ago

        Comparing is fine, but it should be fuzzy. Less than and greater than are fine, so you basically should only be checking for withing a range of values, not a specific value.

    • kakes@sh.itjust.works
      link
      fedilink
      English
      arrow-up
      18
      ·
      edit-2
      6 months ago

      I assume this is because that number is so large that it loses precision, in which case this is more of a quirk of floating point than a quirk of Python.

      Disclaimer: Have not read the article yet.

      • magic_lobster_party@kbin.run
        link
        fedilink
        arrow-up
        16
        ·
        6 months ago

        It’s both. As you said it’s because of loss of floating point precision, but it’s also with some of the quirks how Python compares int with float. These two together causes this strange behavior.