You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This issue proposes switching the Gaussian parameters from (info_vec, precision) to (info_vec, prec_sqrt), following @fehiepsi's work in pyro-ppl/pyro#2019.
Motivation
Our original motivation for representing Gaussians as (info_vec, precision) was to support operations on rank-deficient precision matrices, which occur in conditional probability distributions. This design choice allows us to uniformly handle priors, conditional distributions, and likelihoods by treating all three agnostically as mere factors in a factor graph.
However while the (info_vec, precision) representation is numerically stable, it is computationally inefficient when making low-dimensional observations of a high-dimensional variable. For example to store a conditional distribution of a 1-dimensional variable given a 1000-dimensional variable, the precision matrix has 1001**2 elements, but since it has rank 1 its square root would cost only 1001 elements. Indeed we recognized this pyro-ppl/pyro#2005 and #217 and created a special AffineNormal pattern to avoid materializing rank-1 precision matrices.
An alternative representation is the classic square root information filter (SRIF), explored by @fehiepsi in pyro-ppl/pyro#2019. This represents a Gaussian as a pair (info_vec, prec_sqrt), of shapes batch_shape + (dim,) and batch_shape + (dim, rank) respectively, so that
precision=prec_sqrt @ prec_sqrt.transpose(-2, -1)
Advantages of the square root information representation include:
space storage cost is O(dim * rank) which can be much smaller than O(dim ** 2)
ops.add can be implemented by mere concatenation (optionally followed by compression if rank > dim or maybe rank > 1.5 * dim)
I believe all Pyro & NumPyro code uses to_funsor(), so will be unaffected
How should we make this change? Possibilities include:
👍 Simply replace the existing Gaussian.
Build a separate GaussianS.
Create a new ConditionalGaussian as the basic thing and make Gaussian a mere alias
(but how do we unify priors, conditionals, and likelihoods?)
Create an abstraction for structured precision matrices as in GPyTorch.
(or is it cleaner to allow structured square root matrices, since they have natural block structure?)
The text was updated successfully, but these errors were encountered:
Addresses #559
This issue proposes switching the
Gaussian
parameters from(info_vec, precision)
to(info_vec, prec_sqrt)
, following @fehiepsi's work in pyro-ppl/pyro#2019.Motivation
Our original motivation for representing Gaussians as
(info_vec, precision)
was to support operations on rank-deficient precision matrices, which occur in conditional probability distributions. This design choice allows us to uniformly handle priors, conditional distributions, and likelihoods by treating all three agnostically as mere factors in a factor graph.However while the
(info_vec, precision)
representation is numerically stable, it is computationally inefficient when making low-dimensional observations of a high-dimensional variable. For example to store a conditional distribution of a 1-dimensional variable given a 1000-dimensional variable, the precision matrix has 1001**2 elements, but since it has rank 1 its square root would cost only 1001 elements. Indeed we recognized this pyro-ppl/pyro#2005 and #217 and created a specialAffineNormal
pattern to avoid materializing rank-1 precision matrices.An alternative representation is the classic square root information filter (SRIF), explored by @fehiepsi in pyro-ppl/pyro#2019. This represents a Gaussian as a pair
(info_vec, prec_sqrt)
, of shapesbatch_shape + (dim,)
andbatch_shape + (dim, rank)
respectively, so thatAdvantages of the square root information representation include:
O(dim * rank)
which can be much smaller thanO(dim ** 2)
rank > dim
or mayberank > 1.5 * dim
)AffineNormal
Design questions
Gaussian
interface what will break?to_funsor()
, so will be unaffectedGaussian
.Build a separateGaussianS
.Create a newConditionalGaussian
as the basic thing and makeGaussian
a mere alias(but how do we unify priors, conditionals, and likelihoods?)
Create an abstraction for structured precision matrices as in GPyTorch.(or is it cleaner to allow structured square root matrices, since they have natural block structure?)
The text was updated successfully, but these errors were encountered: