Multivariate normal random draws.
Syntax: @rmvnorm(S[, n])
@rmvnormc(S[, n])
@rmvnormi(S[, n])
@rmvnormic(S[, n])
m: (optional) vector
S: sym, matrix
n: (optional) integer,
data:image/s3,"s3://crabby-images/98516/98516a00d27bc1dda916d6f76ebf412577ca515b" alt=""
Return: vector, matrix
Draw random multivariate normals using the
data:image/s3,"s3://crabby-images/bee75/bee75e7ca479cc8368bdd1f1bc082f4f3976b7d0" alt=""
density function.
The multivariate normal density is given by
There are four different forms of the function, corresponding to different ways of specifying
data:image/s3,"s3://crabby-images/6c85a/6c85af3a7aaf105d89071210d0bd237c4ecff0bd" alt=""
. The forms are distinguished by different suffixes that are applied to the base “@rmvnorm” command and how they change the interpretation of the
S matrix argument:
@rmvnorm | “” | Supply data:image/s3,"s3://crabby-images/c5a71/c5a71d56e38d5ab334b22d35934eab9da51d4902" alt="" . |
@rmvnormc | “c” | Supply the Cholesky decomposition of data:image/s3,"s3://crabby-images/21ac4/21ac4e396ae98f6aa8fdd816da9d0a5020d2ad46" alt="" . This form is more efficient when performing multiple draws from the same distribution (compute the Cholesky once, but sample many times). |
@rmvnormi | “i” | Supply data:image/s3,"s3://crabby-images/bc120/bc120c79385047c3e37fb13d80f9a09448630b6f" alt="" . This form is more efficient than explicitly inverting data:image/s3,"s3://crabby-images/4c333/4c333a0dcf8816be31b40a689242669d3b2d5242" alt="" to supply data:image/s3,"s3://crabby-images/26ed8/26ed882d10ad50c32c360b9fb8e624aaf6ab36a7" alt="" . |
@rmvnormic | “ic” | Supply the Cholesky decomposition of data:image/s3,"s3://crabby-images/3ca6e/3ca6ee973bf9aa57eee61c5b2a0715904bda8137" alt="" . This form combines the efficiencies of the Cholesky and inverse forms. |
If the optional argument n is omitted, the function returns a vector containing a single draw from the distribution. If n is provided, n is the number of rows of the returned matrix, with each row representing a draw from the distribution.
Examples
= @dmvnorm(@identity(3))
returns a random draw from a trivariate normal distribution.
Cross-references