-1

可能重复:
在 R 中,这两者有什么区别?
R中的浮点问题?

这是我创建的代码的一部分。当我终于意识到应该为 TRUE 的比较被 R 计算为 FALSE 时,我花了几天时间寻找问题。我在 Windows 上使用 R 2.14.2 64 位。这是重现问题的代码。

concList= c(1.15, 1.15, 1.15 ,1.15 ,1.15 ,1.15 )
concList=concList-0.4
a=sum(concList)
b=length(concList)*0.75
str(a)
str(b)
print(a==b)

即使它们显示为完全相同的数字,最后一次打印也会导致 FALSE。我认为这可能是 R 的浮点数值表示上的一些问题,所以我添加了下面的代码来解决这个问题。

a=round(a,1)
b=round(b,1)
print(a==b)

我的问题是,有没有更优雅的解决方案?这是一个应该报告的错误吗?

谢谢你的时间。

4

1 回答 1

5

因为它们不是完全相同的数字。由于计算机对数字的表示,它们的差异很小,也称为浮点错误

> a - b
[1] -8.881784e-16

Jon Skeet 有一篇关于这个问题的优秀博客文章,它 定期出现在 Stack Overflow 上。

正如@mrdwab 在评论中建议的那样,您应该使用它all.equal(a, b)来测试近似相等。

于 2012-08-08T17:16:50.290 回答