samplesize <- c(50, 45, 40, 48)
p <- c(0.4, 0.3, 0.3)
## method 1
set.seed(0)
xx1 <- matrix(0, length(p), length(samplesize))
for(i in 1:length(samplesize)) {
xx1[, i] <- rmultinom(1, samplesize[i], p)
}
xx1
# [,1] [,2] [,3] [,4]
#[1,] 24 17 20 24
#[2,] 11 14 8 16
#[3,] 15 14 12 8
colSums(xx1)
#[1] 50 45 40 48
## method 2
set.seed(0)
xx2 <- sapply(samplesize, rmultinom, n = 1, prob = p)
xx2
# [,1] [,2] [,3] [,4]
#[1,] 24 17 20 24
#[2,] 11 14 8 16
#[3,] 15 14 12 8
colSums(xx2)
#[1] 50 45 40 48
Примечание: rmultinom
не "векторизовано", как другие функции распределения скажем rnorm
.
set.seed(0)
fail <- rmultinom(length(samplesize), samplesize, p)
# [,1] [,2] [,3] [,4]
#[1,] 24 19 25 24
#[2,] 11 16 10 17
#[3,] 15 15 15 9
colSums(fail)
#[1] 50 50 50 50
Таким образом, уровень R for
цикл или sapply
цикл или использование функции сахара Vectorize
необходим.