x = c(-2.5e+59, -5.6e+60)
计算x^6
。为了计算它,我需要更改R语言的精度,否则结果将为Inf
,但我不知道如何操作。请注意保留原文中的HTML标签。x = c(-2.5e+59, -5.6e+60)
计算x^6
。为了计算它,我需要更改R语言的精度,否则结果将为Inf
,但我不知道如何操作。请注意保留原文中的HTML标签。正如Livius在评论中指出的那样,这是R(事实上,大多数编程语言)中用二进制表示数字的问题。
为了处理非常大/小的浮点数,可以使用Rmpfr
库:
install.packages("Rmpfr")
library("Rmpfr")
x <- c(-2.5e+59, -5.6e+60)
y <- mpfr(x, 6) # the second number is how many precision **bits** you want - NB: not decimal places!
y^6
# 2 'mpfr' numbers of precision 6 bits
# [1] 2.50e356 3.14e364
如果要处理比R能够处理的更大的数字(例如exp(1800)
),您可以使用“Brobdingnag”包:
install.packages("Brobdingnag")
library("Brobdingnag")
## An example of a single number too large for R:
10^1000.7
# [1] Inf
## Now using the Brobdingnag package:
10^as.brob(1000.7)
# [1] +exp(2304.2)
exp()
)与重复乘法不同的浮点运算之一,在接近精度边缘时,这可能会产生重要后果。 - Livius