加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

如何在R中使用大数?

发布时间:2020-12-14 05:17:30 所属栏目:大数据 来源:网络整理
导读:我想在R的计算中改变精度.例如,我想用x = c(-2.5e 59,-5.6e 60)计算x ^ 6.为了计算它我应该改变R的精度,否则结果是Inf,我不知道怎么做. 解决方法 正如Livius在他的评论中指出的那样,这是R(实际上是大多数编程语言)的问题,数字用二进制表示. 要使用极大/小浮
我想在R的计算中改变精度.例如,我想用x = c(-2.5e 59,-5.6e 60)计算x ^ 6.为了计算它我应该改变R的精度,否则结果是Inf,我不知道怎么做.

解决方法

正如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 decimal places you want
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)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读