• magic_lobster_party@kbin.run
    link
    fedilink
    arrow-up
    31
    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
        5
        ·
        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
      17
      ·
      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
        15
        ·
        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.

  • Diabolo96@lemmy.dbzer0.com
    link
    fedilink
    English
    arrow-up
    19
    arrow-down
    5
    ·
    edit-2
    6 months ago

    I geuss it’s something like : if close enough, set to true.

    Now I’ll read the article and discover it’s like 100x more complex.

    Edit : It is indeed at least 100x more complex.

  • Eximius@lemmy.world
    link
    fedilink
    English
    arrow-up
    10
    ·
    6 months ago

    Did nobody read the manual?

    IEEE 754 double precision: The 53-bit significand precision gives from 15 to 17 significant decimal digits precision.

      • hades@lemm.ee
        link
        fedilink
        English
        arrow-up
        2
        ·
        6 months ago

        The “15 to 17” part is worded somewhat confusingly, but it’s not wrong.

        The number of bits contained in a double is equivalent to ~15.95 decimal digits. If you want to store exactly a decimal number with a fixed number of significant digits, floor(15.95) = 15 digits is the most you can hope for. However, if you want to store exactly a double by writing it out as a decimal number, you need 17 digits.

    • Valmond@lemmy.world
      link
      fedilink
      English
      arrow-up
      16
      ·
      6 months ago

      Probably more like the old precision problem. It ecists in C/C++ too and it’s just how fliats and ints work.

        • Blackmist@feddit.uk
          link
          fedilink
          English
          arrow-up
          16
          ·
          edit-2
          6 months ago

          I don’t think that’s how most programmers expect it to work at all.

          However most people would also expect 0.1+0.2==0.3 to return true, so what do I know.

          Floating point is something most of us ignore until it bites us in the ass. And then we never trust it again.

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

            I have to admit: If you (semi-)regularly use floating point comparisons in programming, I don’t know why you would ever expect 0.1 + 0.2 == 0.3 to return true. It’s common practice to check abs(a - b) < tol, where tol is some small number, to the point that common unit-testing libraries have built-in methods like assertEqual(a, b, tol) specifically for checking whether floats are “equal”.

            • Pelicanen@sopuli.xyz
              link
              fedilink
              English
              arrow-up
              2
              ·
              6 months ago

              Yeah, a lot of editors throw warnings for using the equals operator with floats by default, as far as I know it’s considered bad practice to do it that way.

            • Blackmist@feddit.uk
              link
              fedilink
              English
              arrow-up
              1
              ·
              6 months ago

              The issue is a lot of people use floating point numbers, but don’t even know it.

              How many programmers right now are using JS, the most popular language in the world? How many of them do you think understand floating point numbers and their theoretical levels of accuracy? How many of them are unknowingly using floating points to store currency values?

              How many of them could accurately predict the result of the following?

              • 2.99+1.52==4.51
              • 2.99+1.53==4.52
              • 2.99+1.54==4.53

              Now imagine that as code to make sure you’ve paid the right amount in an online store. I guarantee you there is code out there right now that won’t let you finish a sale if the total of the basket adds up a certain way.

          • Miaou@jlai.lu
            link
            fedilink
            English
            arrow-up
            1
            arrow-down
            1
            ·
            6 months ago

            Then most people shouldn’t be writing code, I don’t know what else to tell you, this is probably one of the first thing you learn about FP arithmetic, and any decent compiler/linter should warn you about that.

        • Womble@lemmy.world
          link
          fedilink
          English
          arrow-up
          4
          ·
          6 months ago

          But how far should that be taken should 8 == 8 return false because one is an unsigned int and the other is signed? Or 0.0 == 0.0 where they are floats and doubles? You can make a case for those due to a strong type system but it would go against most peoples idea of what equality is.

          • If bits aren’t same then i dont want it to tell me they are the same. And python just has one implementation for int and float.

            I like python cos everything’s an object i dont want different types of objects to evaluate the same they are fundamentally different objects is that not what u would expect?

            • Womble@lemmy.world
              link
              fedilink
              English
              arrow-up
              2
              ·
              6 months ago

              Even in python you can have control of what types of numbers are used under the hood with numpy arrays (and chances are if you are using floats in any quantity you want to be using numpy). I would be very surprised if array([1,2,3], dtype=uint8) == array([1,2,3], dtype=int16) gave [False, False, False]. In general I think == for numbers should give mathematical equivalence, with the understanding that comparing floats is highly likely to give false negatives unless you are extremely careful with what you are comparing.

        • jdnewmil@lemmy.ca
          link
          fedilink
          English
          arrow-up
          4
          ·
          6 months ago

          Way too late for that. Every language I know makes some kind of auto conversion for numeric comparisons… and sometimes for strings as well.

        • Sylvartas@lemmy.world
          link
          fedilink
          English
          arrow-up
          3
          ·
          6 months ago

          That makes sense, but then you’d just have people converting the int to a float manually and run into the exact same issues.

        • Miaou@jlai.lu
          link
          fedilink
          English
          arrow-up
          2
          arrow-down
          1
          ·
          6 months ago

          Idiots downvoting you (c/technology…) but this how e.g. Haskell and rust handle that, and probably most strongly typed languages