随机数彼此太相似了吗?

Random Numbers Are Too Similar To Each Other?

我正在使用此代码生成 3 个随机数,这些数字加起来是 72:

# 
rand_vect <- function(N, M, sd = 1, pos.only = TRUE) {
    vec <- rnorm(N, M/N, sd)
    if (abs(sum(vec)) < 0.01) vec <- vec + 1
    vec <- round(vec / sum(vec) * M)
    deviation <- M - sum(vec)
    for (. in seq_len(abs(deviation))) {
        vec[i] <- vec[i <- sample(N, 1)] + sign(deviation)
    }
    if (pos.only) while (any(vec < 0)) {
        negs <- vec < 0
        pos  <- vec > 0
        vec[negs][i] <- vec[negs][i <- sample(sum(negs), 1)] + 1
        vec[pos][i]  <- vec[pos ][i <- sample(sum(pos ), 1)] - 1
    }
    vec
}

如果我运行这个代码100次:

results <- list()

for (i in 1:100)

{

r_i = rand_vect(3,72)

results[[i]] <- r_i


}

当我查看得出的数字时:

[[1]]
[1] 23 24 25

[[2]]
[1] 25 24 23

[[3]]
[1] 24 25 23

[[4]]
[1] 23 24 25

[[5]]
[1] 25 24 23

[[6]]
[1] 24 24 24

[[7]]
[1] 24 25 23

[[8]]
[1] 24 25 23

[[9]]
[1] 24 25 23

[[10]]
[1] 24 23 25

在每次迭代中,所有数字都按预期加起来为 72 - 但数字并不是真的“看起来那么随机”。它们似乎都“聚集”在“24、23、25”周围。我希望在这些数字中看到更多的“随机性”。例如:

[[11]] [1] 5 50 17

[[12]] [1] 12 40 20

谢谢!

如果你只想要三个总和为 72 的随机整数,你可以这样做

diff(c(0, sort(sample(72, 2)), 72))