首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用蒙特卡罗方法求R中二重积分的近似值

用蒙特卡罗方法求R中二重积分的近似值
EN

Stack Overflow用户
提问于 2013-12-02 07:34:44
回答 1查看 2.9K关注 0票数 0

我正在尝试在R中实现蒙特卡罗方法,以求出以下二重积分的近似值:

我有以下代码:

代码语言:javascript
复制
mean.estimated <- function(nvals) {
    X <- runif(nvals)
    Y <- runif(nvals)
    sum(exp((2*X + 3*Y)^5))/ nvals
}


monte.carlo <- function(nreps,nvals) {
    estimates <- NULL
    for (i in 1:nreps){
        estimates[i] <- mean.estimated(nvals)
    }
    estimates
}

simvalues <- monte.carlo(200,2000)

但它只生成Inf值。我做错了什么?

EN

回答 1

Stack Overflow用户

发布于 2013-12-02 08:01:13

由于XY在0和1之间有界,因此2*X + 3*Y的取值范围在0到5之间。

2*X + 3*Y超过约3.72时,我们得到exp((2*X + 3*Y)^5)是无限的:

代码语言:javascript
复制
> exp((3.72)^5)
[1] Inf

如果和中的任何一个值是无限的,则和是无限的。我不打算在这里计算概率,但在2000个样本中,每个样本的2*X + 3*Y都不会超过~3.72,这是不太可能的。所以你不太可能对每个样本都得到Inf

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20318626

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档