R: Strange trig function behavior

后端 未结 5 1208
独厮守ぢ
独厮守ぢ 2021-01-19 05:48

As a Matlab user transitioning to R, I have ran across the problem of applying trigonometric functions to degrees. In Matlab there are trig functions for both radians and de

相关标签:
5条回答
  • 2021-01-19 06:09

    This is a floating point representation error. See Chapter 1 of http://lib.stat.cmu.edu/s/Spoetry/Tutor/R_inferno.pdf

    0 讨论(0)
  • 2021-01-19 06:14

    You may also be interested in the zapsmall function for another way of showing numbers that are close to 0 as 0.

    0 讨论(0)
  • 2021-01-19 06:15

    The same reason that

    1-(1/3)-(1/3)-(1/3)
    

    doesn't equal 0. It has something to do with floating point numbers. I'm sure there will be more elaboration.

    0 讨论(0)
  • 2021-01-19 06:22

    This is floating point arithmetic:

    > all.equal(cosd(90), 0)
    [1] TRUE
    > all.equal(cosd(270), 0)
    [1] TRUE
    

    If that is what you meant by "does not work properly"?

    This is also a FAQ: http://cran.r-project.org/doc/FAQ/R-FAQ.html#Why-doesn_0027t-R-think-these-numbers-are-equal_003f

    0 讨论(0)
  • 2021-01-19 06:29

    Looks like it's working fine to me. The value for pi probably isn't precise enough, so you are getting a very close estimate. If you think about it, 6.123234e-17 and -1.836970e-16 are very very close to 0, which is what the answer should be.

    Your problem lies in the fact that while 90*pi/180 = pi/2 on paper, in computers, we use floating point numbers. I'm not sure what R/matlab use, but I'd definitely guess either a 32 bit or 64 bit floating point number. And you can only fit so much information in that limited number of bits, so you can't store every possible decimal.

    You could modify your function so that given 90 or 270, return 0.

    0 讨论(0)
提交回复
热议问题