R:可以' mu'或者' Sigma'在生成双变量正态样本时,在MASS :: mvrnorm()中进行矢量化?

时间:2017-04-07 04:19:42

标签: r random vectorization normal-distribution

考虑以下数据,

n <- 3
phi0 <- 1
phi1 <- 0.1
phi2 <- 0.2
W2 <- runif(n,0,1)
W3 <- runif(n,0,1)
W <- cbind(W2,W3)
phi <- rbind(phi0,phi1,phi2)
rho <- 0.4
sigma1 <- exp(as.numeric(model.matrix(~W) %*% phi))
sigma2<- 1

library(MASS)
#Sigma <- ???
mu <- rep(0,2)
v <- mvrnorm(n, mu, Sigma)

sigma1是我的方差向量。

我想要生成长度为v=(v1,v2)的双变量矢量n,并且具有正常的双变量分布。以这种方式,v的第i行具有平均mu=(0,0)的双变量正态分布,rho=0.4sigma=(sigma1, 1)接收的sigma1的边际方差sigma1第i行rnorm的值。我该怎么办?

编辑的澄清

在1D案例中,mu接受矢量化sigmarnorm(3, 0, sqrt(sigma1)) ,以便

N(0, sqrt(sigma1[i]))

提供mvrnorm的样本。基本上OP要求list($msec, $sec) = explode(' ', microtime()); $time_milli = $sec.substr($msec, 2, 3); // '1491536422147' $time_micro = $sec.substr($msec, 2, 6); // '1491536422147300' 具有相同的功能。

1 个答案:

答案 0 :(得分:1)

基本解决方案

不,它无法进行矢量化。写一个for循环。

v <- matrix(0, n, 2)
for (i in 1:n) {
  sig11 <- sigma1[i]
  sig21 <- rho * sqrt(sig11)
  Sigma <- matrix(c(sig11, sig21, sig21, 1), 2)
  v[i, ] <- mvrnorm(1, c(0,0), Sigma)
  }

高级解决方案

给出协方差Sigma

sig11 ^ 2                rho * sig11 * sig22
rho * sig11 * sig22      sig22 ^ 2

它的下三角Cholesky因子L

sig11          0
rho * sig22    sqrt(1 - rho ^ 2) * sig22

如果x <- rnorm(2),那么mu + L %*% x就是来自N(mu, Sigma)的样本。

这提供了完全矢量化的解决方案

# mu1, mu2, sig11, sig22, rho can be
## length-n vectors
## scalars
## vectors than can be recycled to be length-n
birnorm <- function (n, mu1, mu2, sig11, sig22, rho) {
  x1 <- rnorm(n)
  x2 <- rnorm(n)
  z1 <- sig11 * x1 + mu1
  z2 <- rho * sig22 * x1 + sqrt(1 - rho ^ 2) * sig22 * x2 + mu2
  cbind(z1, z2)
  }

对于您的数据,您可以使用

v <- birnorm(3, 0, 0, sqrt(sigma1), 1, 0.4)

为双变量情况

重建mvrnorm

请注意,此函数可用于为双变量情况重建mvrnorm

mvrnorm2 <- function (n, mu, Sigma) {
  sig11 <- sqrt(Sigma[1])
  sig22 <- sqrt(Sigma[4])
  rho <- Sigma[2] / (sig11 * sig22)
  birnorm(n, mu[1], mu[2], sig11, sig22, rho)
  }

它更快

mu <- c(0,0)
Sigma <- matrix(c(1,0.5,0.5,1),2)
library(microbenchmark)
microbenchmark(mvrnorm(1000, mu, Sigma), mvrnorm2(1000, mu, Sigma))