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.
    • 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