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 278 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.
    • voljankoV Offline
      voljanko
      last edited by

      This is almost zero 😄
      It is always a risk when you use floats, in all languages.You should never compare float == float if you don't want problems.

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

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

        @voljanko said:

        This is almost zero 😄
        It is always a risk when you use floats, in all languages.You should never compare float == float if you don't want problems.

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

        1 Reply Last reply Reply Quote 0
        • 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