*When I say “I love you”, you look accordingly skeptical* – Frida Hyvönen

A few years back, Bill Callahan wrote a song about the night he dreamt the perfect song. In a fever, he woke and wrote it down before going back to sleep. The next morning, as he struggled to read his handwriting, he saw that he’d written the nonsense that forms the title of this post.

Variational inference is a lot like that song; dreams of the perfect are ruined in the harsh glow of the morning after.

(For more unnaturally tortured metaphors see my twitter. I think we can all agree setting one up was a fairly bad choice for me.)

But how can we tell if variational inference has written the perfect song or, indeed, if it has laid an egg? Unfortunately, there doesn’t seem to be a lot of literature to guide us. We (Yuling, Aki, Me, and Andrew) have a new paper to give you a bit more of an idea.

#### Palimpsest

The guiding principle of variational inference is that if it’s impossible to work with the true posterior , then near enough is surely good enough. (It seldom is.)

In particular, we try to find the member of some tractable set of distributions (commonly the family of multivariate Gaussian distributions with diagonal covariance matrices) that minimizes the *Kullback-Leibler* divergence

The Kullback-Leibler divergence in this direction (it’s asymmetric, so the order of arguments is important) can be interpreted as the the amount of information lost if we replace the approximate posterior with the true posterior . Now, if this seems like the wrong way around to you [that we should instead worry about what happens if we replace the target posterior with the approximation ], you would be very *very *correct. That Kullback-Leibler divergence is *backwards.*

*What does this mean?* Well it means that we won’t penalize approximate distributions that are much less complex than the true one as heavily as we should. *How does this translate into real life?* It means that usually we will end up with approximations that are narrower than the true posterior. Usually this manifests as distributions with lighter tails.

(*Quiet side note:* Why are those last few sentences so wishy-washy? Well it turns out that minimizing a Kullback-Leibler divergence in the wrong direction can do all kinds of things to the resulting minimizer and it’s hard to really pin down what will happen. But it’s almost everyone’s experience that the variational posterior is almost always narrower than than the true posterior. So the previous paragraph is *usually *true.)

So variational inference is mostly set up to fail. Really, we should be surprised it works at all.

#### Cold discovery

There are really two things we need to check when we’re doing variational inference. The first is that the optimization procedure that we have used to compute has actually converged to a (local) minimum. Naively, this seems fairly straightforward. After all, we don’t think of maximum likelihood estimation as being hard computationally, so we should be able to solve this optimization problem easily. But it turns out that if we want our variational inference to be *scalable* in the sense that we can apply it to big problems, we need to be more clever. For example Automatic Differentiation Variational Inference (ADVI) uses a fairly sophisticated stochastic optimization method to find .

So first we have to make sure the method actually converges. I don’t really want to talk about this, but it’s probably worth saying that it’s not trivial and stochastic methods like ADVI will occasionally terminate too soon. This leads to terrible approximations to the true posterior. It’s also well worth saying the if the true posterior is multimodal, there’s no guarantee that the minimum that is found will be a (nearly) global one. (And if the approximating family only contains unimodal distributions, we will have some problems!) There are perhaps some ways out of this (Yuling has many good ideas), but the key thing is that if you want to actually know if there is a potential problem, it’s important to run multiple optimizations beginning at a diverse set of initial values.

Anyway, let’s pretend that this isn’t a problem so that we can get onto the main point.

The second thing that we need to check is that the approximate posterior is an ok approximation to the true posterior . This is a much less standard task and we haven’t found a good method for addressing it in the literature. So we came up with two ideas.

#### Left only with love

Our first idea was based Aki, Andrew, and Jonah’s *Pareto-Smoothed Importance Sampling* (PSIS). The crux of our idea is that if is a good approximation to the true posterior, it can be used as an importance sampling proposal to compute expectations with respect to . So before we can talk about that method, we need to remember what PSIS does.

The idea is that we can approximate any posterior expectation using a self-normalized importance sampling estimator. We do this by drawing samples from the proposal distribution and computing the estimate

Here we define the *importance weights* as

We can get away with using the joint distribution instead of the posterior in the numerator because and we re-normalise the the estimator. This self-normalized importance sampling estimator is consistent with bias that goes asymptotically like . (The bias comes from the self-normalization step. Ordinary importance sampling is unbiased.)

The only problem is that if the distribution of has too heavy a tail, the self-normalized importance sampling estimator will have infinite variance. This is not a good thing. Basically, it means that the error in the posterior expectation could be any size.

The problem is that if the distribution of has a heavy tail, the importance sampling estimator will be almost entirely driven by a small number of samples with very large values. But there is a trick to get around this: somehow tamp down the extreme values of .

With PSIS, Aki, Andrew, and Jonah propose a nifty solution. They argue that you can model the tails of the distribution of the importance ratio with a *generalized Pareto distribution *

This is a very sensible thing to do: the generalized Pareto is the go-to distribution that you use when you want to model the distribution of all samples from an iid population that are above a certain (high) value. The PSIS approximation argues that you should take the largest (where is chosen carefully) and fit a generalized Pareto distribution to them. You then replace those largest observed importance weights with the corresponding expected order statistics from the fitted generalized Pareto.

There are some more (critical) details in the PSIS paper but the intuition is that we are replacing the “noisy” sample importance weights with their model-based estimates. This reduces the variance of the resulting self-normalized importance sampling estimator and reduces the bias compared to other options.

It turns out that the key parameter in the generalized Pareto distribution is the shape parameter . The interpretation of this parameter is that if the generalized Pareto distribution has shape parameter , then the distribution of the sampling weights have moments.

This is particularly relevant in this context as the condition for the importance sampling estimator to have finite variance (and be asymptotically normal) is that the sampling weights have (slightly more than) two moments. This translates to .

*VERY technical side note:* What I want to say is that the self-normalized importance sampling estimator is asymptotically normal. This was nominally proved in Theorem 2 of Geweke’s 1983 paper. The proof there looks wrong. Basically, he applies a standard central limit theorem to get the result, which seems to assume the terms in the sum are iid. The only problem is that the summands

are not independent. So it looks a lot like Geweke should’ve used a central limit theorem for weakly-mixing triangular arrays instead. He did not. What he actually did was quite clever. He noticed that the bivariate random variables are independent and satisfy a central limit theorem with mean . From there you’re a second-order Taylor expansion of the function to show that the sequence

is also asymptotically normal as long as zero or infinity are never in a neighbourhood of .

*End VERY technical side note!*

The news actually gets even better! The smaller is, the faster the importance sampling estimate will converge. Even better than that, the PSIS estimator seems to be useful even if is slightly bigger than 0.5. The recommendations in the PSIS paper is that if , the PSIS estimator is reliable.

But what is ? It’s the sample estimate of the shape parameter . Once again, some really nice things happen when you use this estimator. For example, even if we know from the structure of the problem that , if (which can happen), then importance sampling will perform poorly. The value of is strongly linked to the *finite sample *behaviour of the PSIS (and other importance sampling) estimators.

The intuition for why the estimated shape parameter is more useful than the population shape parameter is that it tells you when the sample of that you’ve drawn *could have come from a heavy tailed **distribution. *If this is the case, there isn’t enough information in your sample yet to push you into the asymptotic regime and pre-asymptotic behaviour will dominate (usually leading to worse than expected behaviour).

#### Footprints

Ok, so what does all this have to do with variational inference? Well it turns out that if we draw samples from out variational posterior and use them to compute the importance weights, then we have another interpretation for the shape parameter :

where is the Rényi divergence of order . In particular, if , then the Kullback-Leibler divergence in the more natural direction even if minimizes the KL-divergence in the other direction! Once again, we have found that the estimate gives an excellent indication of the performance of the variational posterior.

So why is checking if a good heuristic to evaluate the quality of the variational posterior? There are a few reasons. Firstly, because the variational posterior minimizes the KL-divergence in the direction that penalizes approximations with heavier tails than the posterior much harder than approximations with lighter tails, it is very difficult to get a good value by simply “fattening out” the approximation. Secondly, empirical evidence suggests that the smaller the value of , the closer the variational posterior is to the true posterior. Finally, if we can automatically improve *any *expectation computed against the variational posterior using PSIS. This makes this tool both a diagnostic and a correction for the variational posterior that does not rely too heavily on asymptotic arguments. The value of has also proven useful for selecting the best parameterization of the model for the variational approximation (or equivalently, between different approximation families).

There are some downsides to this heuristic. Firstly, it really does check that the whole variational posterior is like the true posterior. This is a quite stringent requirement that variational inference methods often do not pass. In particular, as the number of dimensions increases, we’ve found that unless the approximating family is particularly well-chosen for the problem, the variational approximation will eventually become bad enough that will exceeded the threshold. Secondly, this diagnostic only considers the full posterior and cannot be modified to work on lower-dimensional subsets of the parameter space. This means that if the model has some “less important” parameters, we still require their posterior be very well captured by the variational approximation.

#### Let me see the colts

The thing about variational inference is that it’s actually often quite bad at estimating a posterior. On the other hand, the centre of the variational posterior is much more frequently a good approximation to the centre of the true posterior. This means that we can get good point estimates from variational inference even if the full posterior isn’t very good. So we need a diagnostic to reflect this.

Into the fray steps an old paper of Andrew’s (with Samantha Cook and Don Rubin) on verifying statistical software. We (mainly Stan developer Sean) have been playing with various ways of extending and refining this method for the last little while and we’re almost done on a big paper about it. (Let me tell you: god may be present in the sweeping gesture, but the devil is definitely in the details.) Thankfully for this work, we don’t need any of the new detailed work we’ve been doing. We can just use the original results as they are (with just a little bit of a twist).

The resulting heuristic, which we call *Variational Simulation-Based Calibration* (VSBC), complements the PSIS diagnostic by assessing the average performance of the implied variational approximation to *univariate* posterior marginals. One of the things that this method can do particularly well is indicate if the centre of the variational posterior will be, on average, biased. If it’s not biased, we can apply clever second-order corrections (like the one proposed by Ryan Giordano, Tamara Broderick, and Michael Jordan).

I keep saying “on average”, so what do I mean by that? Basically, VSBC looks at how well the variational posterior is calibrated by computing the distribution of where is simulated from the model with parameter that is itself drawn from the prior distribution. If the variational inference method is *calibrated*, then Cook *et al.* showed that the histogram of should be uniform.

This observation can be generalized using insight from the forecast validation community: *if the histogram of is asymmetric, then the variational posterior will be (on average over data drawn from the model) biased.* In the paper, we have a specific result, which shows that this insight is exactly correct if the true posterior is symmetric, and approximately true if it’s fairly symmetric.

There’s also the small problem that if the model is badly mis-specified, then it may fit the observed data much worse or better than the average of data drawn from the model. Again, this contrasts with the PSIS diagnostic that only assesses the fit for the particular data set you’ve observed.

In light of this, we recommend interpreting both of our heuristics the same way: conservatively. If either heuristic fails, then we can say the variational posterior is poorly behaved in one of two specific ways. If either or both heuristics pass, then we can have some confidence that the variational posterior will be a good approximation to the true distribution (especially after a PSIS or second-order correction), but this is still not guaranteed.

#### Faith/Void

To close this post out symmetrically (because symmetry indicates a lack of bias), let’s go back to a different Bill Callahan song to remind us that even if it’s not the perfect song, you can construct something beautiful by leveraging formal structure:

*If*

*If you*

*If you could*

*If you could only*

*If you could only stop*

*If you could only stop your*

*If you could only stop your heart*

*If you could only stop your heart beat*

*If you could only stop your heart beat for*

*If you could only stop your heart beat for one heart*

*If you could only stop your heart beat for one heart beat*

Andrew, Andrew, Andrew You just gave me a theme for my dance routine.

Soooooo not Andrew :p

LOL

The ‘missing’ line “If you could only stop your heart beat for one” makes me nervous for some reason.

It works surprisingly well in the song (which is beautiful and not at al stressful)

It happens to me from time to time when I sleep. Waking up thinking that you are dead because your heart has stopped beating is stressful because it takes a few seconds for your oxygen-deprived brain to update its posterior probability that you are dead given that you are awake.

Indeed, these are called “ectopic heart beats”. They are quite normal, mostly self-limiting, and usually benign.

Anybody knows what happened to Bill Callahan recently? No real new album since about 2013. (Sorry if that’s a question for another blog).

No idea generally, but he is playing a show in Austin tonight :p

LOL You know I wonder whether in today’s internet age, romanticism is even feasible. When one is out and about, couples are on their cellphones cruising Facebook, Snapchat, and Twitter

Or on Scruff while literally standing inside the Eagle. Girl…

Maybe they’re just there for the cheap drinks… :p

idk, last time I was at the NYC Eagle it was like $9 for the wateriest of macrobrews… but I concede the general point that there are other reasons to go there :)

There’s a typo right before equation 1 in your paper; it should say “maximizing the evidence lower bound”.

Thanks. Fixed in tex.

FYI: I am trying to run the code and found some typos:

Figure_2_linear_reg.R line 57 `I=length(tel_vec)` –> `I=length(tol_vec)`

Thanks. Fixed (but fix not yet in public version)

> this is still not guaranteed.

But somewhat more assurance than say feeling financially secure given two lottery tickets in separate lotteries ;-)

On the other hand, one could speculate that if sampling from posteriors in wide generality became direct, then future statisticians would not need to learn (much) more than high school math.

You’d still need to know enough to understand mis-specification, which is still hard. But there would definitely be a stronger split between the more mathematical and more applied parts of the field.

Actually to get an adequate understanding of specification itself likely requires more than high school math.

Why not use the Jensen–Shannon divergence instead, wouldn’t this fix the direction problem?

KL(q||p) is used because it’s easier to take the expectation over q than p. Jensen–Shannon divergence requires taking the expectation over p. If it would be easy to compute Jensen–Shannon divergence, then we could as well use KL(p||q)^*.

^*Footnote: In ideal case we would like to use KL(p||q) as it measures the information lost by approximating p with q, but we may use other divergences either because they are easier to compute or because they may be less sensitive to misspecifications.