sketchucation logo sketchucation
    • Login
    Oops, your profile's looking a bit empty! To help us tailor your experience, please fill in key details like your SketchUp version, skill level, operating system, and more. Update and save your info on your profile page today!
    🛣️ Road Profile Builder | Generate roads, curbs and pavements easily Download

    Strange result of a substraction

    Scheduled Pinned Locked Moved Developers' Forum
    14 Posts 5 Posters 276 Views 5 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • J Offline
      Jim
      last edited by

      Much has been written about floating point errors.

      Basically, floating point numbers can not be accurately represented in binary.

      Hi

      1 Reply Last reply Reply Quote 0
      • Dan RathbunD Offline
        Dan Rathbun
        last edited by

        @macgile said:

        i have tested with a = a + b the result is same

        That is because the Ruby interpreter converts
        a += b
        to
        a = a + b
        before the expression is evaluated.

        I'm not here much anymore.

        1 Reply Last reply Reply Quote 0
        • voljankoV Offline
          voljanko
          last edited by

          @unknownuser said:

          i dont compare anything !!!
          i have tested with a = a + b the result is same

          I just meant that is always good to avoid considering floats as exact numbers.

          SuSolid.com - solid check - solid repair- solid intersection check - weight plugin

          1 Reply Last reply Reply Quote 0
          • M Offline
            macgile
            last edited by

            @dan rathbun said:

            @macgile said:

            i have tested with a = a + b the result is same

            That is because the Ruby interpreter converts
            a += b
            to
            a = a + b
            before the expression is evaluated.

            i dont understand your explanation Dan !!!!

            1 Reply Last reply Reply Quote 0
            • M Offline
              macgile
              last edited by

              @voljanko said:

              @unknownuser said:

              i dont compare anything !!!
              i have tested with a = a + b the result is same

              I just meant that is always good to avoid considering floats as exact numbers.

              oh yes 😄

              I thought the result would be near to 0 and not of 4.

              1 Reply Last reply Reply Quote 0
              • voljankoV Offline
                voljanko
                last edited by

                Try to add some number,you will see that is zero and not 4.

                SuSolid.com - solid check - solid repair- solid intersection check - weight plugin

                1 Reply Last reply Reply Quote 0
                • Dan RathbunD Offline
                  Dan Rathbun
                  last edited by

                  A singleton method to increment a float a, by an argument arg, to dec number of decimal places. (It defaults to 1 decimal place.)

                  a = 9.0
                  def a.incr( arg = 1.0, dec = 1 )
                    dec = dec.to_i
                    arg = round( arg.to_f * 10**dec  )
                    # self is object a
                    temp =( round( self * 10**dec ) + arg ).to_f
                    self =( temp / 10**dec )
                  end
                  

                  use it like:
                  a = 9.0 b = -1.8 a.incr(b)

                  I'm not here much anymore.

                  1 Reply Last reply Reply Quote 0
                  • J Offline
                    Jim
                    last edited by

                    @macgile said:

                    I thought the result would be near to 0 and not of 4.

                    macguile,

                    4.44089209850063e-016

                    The e-016 at the end of the number means to move the decimal place 16 places to the left - making the actual number:

                    0.0000000000000000444089209850063

                    or very nearly zero. The reason the result is not exactly zero is due to floating point errors as linked above.

                    Hi

                    1 Reply Last reply Reply Quote 0
                    • M Offline
                      macgile
                      last edited by

                      @dan rathbun said:

                      A singleton method to increment a float a, by an argument arg, to dec number of decimal places. (It defaults to 1 decimal place.)

                      a = 9.0
                      > def a.incr( arg = 1.0, dec = 1 )
                      >   dec = dec.to_i
                      >   arg = round( arg.to_f * 10**dec  )
                      >   # self is object a
                      >   temp =( round( self * 10**dec ) + arg ).to_f
                      >   self =( temp / 10**dec )
                      > end
                      

                      use it like:
                      a = 9.0 b = -1.8 a.incr(b)

                      THANK for this solution Dan

                      Best Regard 😄

                      1 Reply Last reply Reply Quote 0
                      • M Offline
                        macgile
                        last edited by

                        @jim said:

                        @macgile said:

                        I thought the result would be near to 0 and not of 4.

                        macguile,

                        4.44089209850063e-016

                        The e-016 at the end of the number means to move the decimal place 16 places to the left - making the actual number:

                        0.0000000000000000444089209850063

                        or very nearly zero. The reason the result is not exactly zero is due to floating point errors as linked above.

                        thank i nderstand now 😄

                        regard

                        1 Reply Last reply Reply Quote 0
                        • thomthomT Offline
                          thomthom
                          last edited by

                          Link Preview Image
                          The Floating-Point Guide - What Every Programmer Should Know About Floating-Point Arithmetic

                          Aims to provide both short and simple answers to the common recurring questions of novice programmers about floating-point numbers not 'adding up' correctly, and more in-depth information about how IEEE 754 floats work, when and how to use them correctly, and what to use instead when they are not appropriate.

                          favicon

                          (floating-point-gui.de)

                          Thomas Thomassen — SketchUp Monkey & Coding addict
                          List of my plugins and link to the CookieWare fund

                          1 Reply Last reply Reply Quote 0
                          • 1 / 1
                          • First post
                            Last post
                          Buy SketchPlus
                          Buy SUbD
                          Buy WrapR
                          Buy eBook
                          Buy Modelur
                          Buy Vertex Tools
                          Buy SketchCuisine
                          Buy FormFonts

                          Advertisement