why this logical expression is wrong?
1 次查看(过去 30 天)
显示 更早的评论
Hi,
why this statment is wrong,
>> sind(30)==0.5
ans =
0
4 个评论
Walter Roberson
2019-7-18
I seem to remember seeing a sind bug in the bug reports a couple of releases ago, but I cannot find that information now.
Peter Jarosi
2019-7-18
I think it's not a bug, because it depends on the method of approximation. That's an interesting question how developers of sind() function fixed sind(30). Whether there is an if statement in the code of sind() in order to set sind(30) exactly 1/2. :-)
采纳的回答
Peter Jarosi
2019-7-18
编辑:Peter Jarosi
2019-7-18
because of the accuracy problem of a floating-point system
>> format longE
>> sind(30)
ans =
4.999999999999999e-01
Never, ever compare two floating-point numbers with == operand!
See also:
11 个评论
Peter Jarosi
2019-7-18
I voted your question. It's a million dollar question, and the problem is general, not Matlab's fault.
Walter Roberson
2019-7-18
The result of sind(30) should be exactly 1/2, but it appears that in some older releases it was not exactly that.
It is generally better to not compare for floating point equality except when you know that the exact bit-pattern occurs somewhere. For example, it is fair to test
A = min(B);
B == A
because you know that A will be a bit-for-bit copy of one of the values that is in B. (Well, except for some obscure cases involving non-default nan values... and in those cases, nan == nan is always false anyhow.)
更多回答(1 个)
Steven Lord
2019-7-19
1 个评论
Peter Jarosi
2019-7-19
How did you fix it? Did you use a better approximation method (for instance longer Taylor series) or just put an if statement in the code of function sind()? :-)
(I'm joking)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Loops and Conditional Statements 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!