
Generate multinomially distributed random number vectors and compute multinomial probabilities.
rmultinom(n, size, prob)
dmultinom(x, size = NULL, prob, log = FALSE)
vector of length 0:size
.
number of random vectors to draw.
integer, say dmultinom
, it defaults to sum(x)
.
numeric non-negative vector of length
logical; if TRUE, log probabilities are computed.
For rmultinom()
,
an integer size
. Whereas the transposed result
would seem more natural at first, the returned matrix is more
efficient because of columnwise storage.
If x
is a dmultinom(x, prob)
is the probability
By definition, each component Bin(size, prob[j])
for
The rmultinom()
algorithm draws binomials size
),
prob
scaled to sum 1),
and for
Distributions for standard distributions, including
dbinom
which is a special case conceptually.
# NOT RUN {
rmultinom(10, size = 12, prob = c(0.1,0.2,0.8))
pr <- c(1,3,6,10) # normalization not necessary for generation
rmultinom(10, 20, prob = pr)
## all possible outcomes of Multinom(N = 3, K = 3)
X <- t(as.matrix(expand.grid(0:3, 0:3))); X <- X[, colSums(X) <= 3]
X <- rbind(X, 3:3 - colSums(X)); dimnames(X) <- list(letters[1:3], NULL)
X
round(apply(X, 2, function(x) dmultinom(x, prob = c(1,2,5))), 3)
# }
Run the code above in your browser using DataLab