The Concrete distribution is a really powerful tool for modern machine learning. We use it to learn the parameters of discrete distributions, but it's actually a continuous distribution on the probability simplex. The temperature parameter controls the sparsity of samples, and although I've been using the Concrete distribution for a while, I've never been certain that I'm using the right temperature value.
So that's what I've tried to figure out for this post. I'll start by explaining the role of the temperature parameter through the Concrete's relationship with other random variables (namely, the Gumbel and Generalized Inverse Gamma), and then I'll run some simulations that provide practical guidance on how to set it in your models.
Before saying what the Concrete distribution is, here's why it's so famous. Starting in 2013, a technique known as the reparameterization trick (explained here) became popular for learning distributions of random variables inside neural networks [1, 2]. Learning distributional parameters can be tricky, but these papers showed how to get an unbiased, low-variance gradient estimator using a clever sampling trick. There were other techniques before it, but the reparameterization trick's low variance made it work much better, especially for VAEs. But unfortunately, although it worked for a variety of distributions (Gaussian, Gamma, Weibull, etc.), it didn't work out-of-the-box for discrete random variables.
Then, the Concrete distribution showed how to make it work. The distribution, introduced by two papers in 2016, is a continuous relaxation for discrete random variables (hence the name con-crete) [3, 4]. When you think about discrete random variables, you probably think of a random variable with the possible values , but that set is equivalent to the set of one-hot vectors in . And the Concrete distribution is basically a relaxed version of a distribution over one-hot vectors. Its support is on the simplex
whereas one-hot vectors lie at the vertices
The Concrete distribution over indices has parameters. There are unnormalized probabilities that control how likely each index is to dominate the others, and there's a temperature parameter that controls the sparsity of samples.
Formally, the distribution is defined by its density function , which for can be written as
for [3]. That may not seem very intuitive, but we'll see a couple simpler ways to understand the Concrete distribution below.
First, here's what the samples look like for different sets of parameters.
As you can see, the samples get more discrete/sparse as the temperature is set to lower values. And since we usually want discrete samples, the ability to set the temperature is an essential feature of the Concrete distribution.
To see why the temperature has this effect, we need to consider how the Concrete relates to other random variables.
In terms of independent uniform samples , the random variable has dimensions equal to
This is how we typically sample from the Concrete distribution in practice. But the expression above isn't very intuitive.
In terms of independent Gumbel samples , the random variable has dimensions equal to
or . This is what gives the Concrete distribution its other name, the Gumbel-softmax distribution [4]. And you can see that a low temperature would amplify the differences between the softmax arguments and lead to a one-hot vector.
An interpretation that I find even simpler is that has dimensions equal to
where . So each dimension of the Concrete represents the proportion of the sum of independent Generalized Inverse Gamma random variables.
That last part about the Generalized Inverse Gamma variables makes the Concrete look a bit like the Dirichlet distribution (another distribution on the probability simplex), because the random variable has dimensions equal to
where , or equivalently . So the Concrete and Dirichlet distributions are actually pretty similar: they're both proportions of independent non-negative random variables, and both depend on the Gamma distribution. Table 1 provides a comparison between the Concrete and Dirichlet distributions, and it highlights how both can be understood in terms of other distributions.
Concrete | Dirichlet | |
---|---|---|
Parameters | ||
Support | for for |
|
Proportion of | ||
Softmax of | ||
Primary Uses | Learning discrete distributions | Conjugate prior Topic modeling |
The Concrete and Dirichlet distributions have some similarities, but their differences are significant. The Gamma distribution used by the Dirichlet is well-behaved: has finite mean, and all of its moments exist. By contrast, the Generalized Inverse Gamma is heavy-tailed: for low temperatures , the mean, variance, and higher moments of are all undefined [5]. Intuitively, that means that empirical estimators for these quantities would never converge because the occasional massive samples would throw them off. So at low temperatures , the Concrete distribution is much more likely to have individual samples that make up a large proportion of the total , which leads to values of near .
This perspective gives some intuition for why low temperatures have the effect of increasing the sparsity of Concrete samples. If you're interested, check out the derivation of these results below.
Consider the sequence of operations that we use to produe a Concrete sample using the Gumbel-softmax trick. For convenience, we'll use to denote the sequence of random variables.
where . And if you're wondering about the relationships between all these different probability distributions, here's where you can learn more about them: Exponential, Gumbel, Gamma, Generalized Gamma, Generalized Inverse Gamma, Dirichlet.
Now, let's talk about the tradeoff we face when choosing a temperature value. What happens when we choose a high temperature or a low temperature?
High temperature
In the limit , samples from the Concrete distribution aren't like one-hot vectors at all. In fact, they're deterministically equal to , with the mass spread evenly between the indices [4]. Formally, we would say that for we have
This seems intuitive when you think about the Gumbel-softmax sampling trick, because a large temperature wipes out any differences between the arguments to the softmax.
Low temperature
In the limit , the samples start to actually look like one-hot vectors. This was proved in Proposition 1c of [3], where the authors showed that
Again, the increasing sparsity of the samples seems obvious when you consider the role of the temperature in the softmax. The fact that the probability of dominating the other indices is equal to is the magic of the Gumbel-max trick (which predates the Gumbel-softmax trick by several decades). Ryan Adams has a simple proof of this fact here.
An easy choice?
Given what we've just seen, this seems like an easy choice—we should just use to get more discrete samples, right? Unfortunately, there's a tradeoff: the original paper explains that low is necessary for discrete samples, but high is necessary for getting large gradients [3]. And we need large gradients to learn the parameters .
To deal with the tradeoff, some papers have used a carefully chosen fixed value of [6], while others have annealed from a high value to a low value [7]. I like the idea of annealing, because you can pass through a region of high that's suitable for learning while eventually ending up with discrete samples. Learning will get harder as gets closer to zero, but you should end up with a good solution for if you pre-solve the problem for a slightly larger .
So annealing seems like a good idea, but to do it, we still need to figure out a range of values that makes sense.
What does it mean to choose the right temperature value? We want a large enough temperature to enable learning, but we also want a low enough temperature to get discrete samples. That's why annealing from a high value to a low value is a nice idea, because we can get the best of both worlds. We know how the Concrete distribution behaves when or , and we want to pass between these two regimes when we anneal . The question is where the transition occurs.
To figure this out, I tried to derive a mathematical function to describe the sparsity of Concrete samples as a function of and . Sadly, this turned out to be very hard. My plan was to quantify the sparsity of single samples though their entropy, or the value of the maximum index, and then figure out what that quantity was in expectation. It turns out that the inverse of the maximum index is a bit easier to characterize, but figuring out was still too hairy. Maybe someone else will figure it out one day.
Until then, we can fall back on a simulation study. The idea is to consider different values of and to see how the sparsity of Concrete samples changes. Of course we should also look at different values of , but it seems obvious that letting will lead to the most spread out samples, so we'll just look at this "balanced" setting, plus one "imbalanced" setting where and the rest are .
We'll use two quantities to measure sparsity. First, we'll look at the average entropy of samples, , by which I mean the entropy in the discrete random variable . And second, we'll look at the expected value of the max index, .
I estimated each of these quantities for 100 different temperature values using a million samples, and the results demonstrate exactly what we want to see. The transition between perfect spread and perfect sparsity happens between and for a wide range of numbers of indices .
Figure 3 shows that the mean entropy starts out high and then goes to zero, and we start getting sparse samples without having to resort to extremely low temperatures. Even for large values of and balanced parameters, the samples have almost no entropy with . And when the parameters are imbalanced, we can get sparse samples with even higher temperatures.
Figure 4 shows the expected value of the max index , and these simulations tell the same story. According to these results, it would be safer to set the temperature to to get truly discrete samples when is balanced, but for imbalanced parameters we can get near exact sparsity with .
These results show that if you want to start with a high temperature to make learning easier, then there's no point in going higher than . And if you want to reduce the temperature to get truly discrete samples, then should be sufficient. Even for reasonably large values of , annealing the temperature between and allows you to transition between the two regimes, so you can get the best of both worlds by taking advantage of larger gradients for learning while still ending up with discrete samples.
The Concrete distribution is a powerful tool because it lets us learn the parameters of discrete distributions with the reparameterization trick, but the low temperatures that are necessary for truly discrete samples can make learning harder. These simulations gave us a good idea of the right range of values to use during training by showing where the transition occurs between perfect spread and perfect sparsity.
According to the results in these simulations, multiplicatively annealing the temperature from to (as in the Concrete Autoencoders paper [7]) or even just setting (the fixed value used by L2X [6]) should be effective both for learning, and for ultimately getting discrete samples. That's what I'll be doing from now on.