gaussbary1d | R Documentation |
\mathbf{R}
Given a collection of Gaussian distributions \mathcal{N}(\mu_i, \sigma_i^2)
for i=1,\ldots,n
,
compute the Wasserstein barycenter of order 2. For the barycenter computation of
variance components, we use a fixed-point algorithm by \insertCiteAlvarezEsteban;textualT4transport.
gaussbary1d(means, vars, weights = NULL, ...)
means |
a length- |
vars |
a length- |
weights |
a weight of each image; if |
... |
extra parameters including
|
a named list containing
mean of the estimated barycenter distribution.
variance of the estimated barycenter distribution.
gaussbarypd()
for multivariate case.
#----------------------------------------------------------------------
# Two Gaussians
#
# Two Gaussian distributions are parametrized as follows.
# Type 1 : (mean, var) = (-4, 1/4)
# Type 2 : (mean, var) = (+4, 1/4)
#----------------------------------------------------------------------
# GENERATE PARAMETERS
par_mean = c(-4, 4)
par_vars = c(0.25, 0.25)
# COMPUTE THE BARYCENTER OF EQUAL WEIGHTS
gmean = gaussbary1d(par_mean, par_vars)
# QUANTITIES FOR PLOTTING
x_grid = seq(from=-6, to=6, length.out=200)
y_dist1 = stats::dnorm(x_grid, mean=-4, sd=0.5)
y_dist2 = stats::dnorm(x_grid, mean=+4, sd=0.5)
y_gmean = stats::dnorm(x_grid, mean=gmean$mean, sd=sqrt(gmean$var))
# VISUALIZE
opar <- par(no.readonly=TRUE)
plot(x_grid, y_gmean, lwd=2, col="red", type="l",
main="Barycenter", xlab="x", ylab="density")
lines(x_grid, y_dist1)
lines(x_grid, y_dist2)
par(opar)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.