• scratchee@feddit.uk
    link
    fedilink
    English
    arrow-up
    5
    ·
    16 days ago

    In game dev it’s pretty common. Lots of stuff is built on floating point and balancing quality and performance, so we can’t just switch to double when things start getting janky as we can’t afford the cost, so instead we actually have to think and work out the limits of 32 bit floats.

    • Cyborganism@lemmy.ca
      link
      fedilink
      English
      arrow-up
      1
      ·
      16 days ago

      So you have to remember how it’s represented in the system with how the bits are used? Or you just have to remember some general rules that “if you do that, it’ll fuck up.”

      • scratchee@feddit.uk
        link
        fedilink
        English
        arrow-up
        2
        ·
        16 days ago

        Well, rules like “all integers can be represented up to 2^24” and “10^-38 is where denormalisation happens” are helpful, but I often have to figure out why I got a dodgy value from first principles, floating point is too complicated to solve every problem with 3 general rules.

        I wrote a float from string function once which obviously requires the details (intentionally low quality and limited but faster variant since the standard version was way too slow).