如何在R中找到循环内的最大值

时间:2016-10-04 01:07:06

标签: r loops

我有一个表达

 qbinom(0.05, n, .47) - 1 

我想创建一个循环,它在n上为n =(20,200)迭代这个表达式。对于此循环的每次迭代,此函数将生成一个数字。我想取其将产生的180个数字的最大值。所以,像。

 for (n in 20:200) {
   max(qbinom(0.05, n, .47)-1)

但我不确定如何做到这一点。

谢谢!

1 个答案:

答案 0 :(得分:6)

首先,我将向您展示如何使用循环执行此操作。

n <- 20:200
MAX = -Inf    ## initialize maximum
for (i in 1:length(n)) {
  x <- qbinom(0.05, n[i], 0.47) - 1
  if (x > MAX) MAX <- x
  }

MAX
# [1] 81

注意,我没有记录生成的所有181个值。每个值都被视为临时值,并将在下一次迭代中被覆盖。最后,我们只有一个值MAX

如果你想同时保留所有记录,我们首先需要初始化一个向量来保存它们。

n <- 20:200
MAX = -Inf    ## initialize maximum
x <- numeric(length(n))    ## vector to hold record
for (i in 1:length(n)) {
  x[i] <- qbinom(0.05, n[i], 0.47) - 1
  if (x[i] > MAX) MAX <- x[i]
  }

## check the first few values of `x`
head(x)
# [1] 5 5 6 6 6 7

MAX
# [1] 81

现在我正在展示矢量化解决方案。

max(qbinom(0.05, 20:200, 0.47) - 1)
# [1] 81

与概率分布相关的R函数以相同的方式进行矢量化。对于与二项分布相关的内容,您可以阅读?rbinom了解详细信息。

注意,矢量化是通过回收规则实现的。例如,通过指定:

qbinom(0.05, 1:4, 0.47)

R将首先进行回收:

   p: 0.05    0.05    0.05    0.05
mean:    1       2       3       4
  sd: 0.47    0.47    0.47    0.47

然后评估

qbinom(p[i], mean[i], sd[i])

通过C级循环

<强>后续

  

如何使用矢量化解决方案知道20:200中的哪一个对应于最大值?

我们可以使用

x <- qbinom(0.05, 20:200, 0.47) - 1
i <- which.max(x)
# [1] 179

注意,i是向量20:200中的位置。要获得所需的n,您需要:

(20:200)[i]
# 198

最大值是

x[i]
# [1] 81