“And then there was Yodeling Elaine, the Queen of the Air. She had a dollar sign medallion about as big as a dinner plate around her neck and a tiny bubble of spittle around her nostril and a little rusty tear, for she had lassoed and lost another tipsy sailor“– Tom Waits
It turns out I turned thirty two and became unbearable. Some of you may feel, with an increasing sense of temporal dissonance, that I was already unbearable. (Fair point) Others will wonder how I can look so good at my age. (Answer: Black Metal) None of that matters to me because all I want to do is talk about the evils of marketing like the 90s were a vaguely good idea. (Narrator: “They were not. The concept of authenticity is just another way for the dominant culture to suppress more interesting ones.”)
The thing is, I worry that the real problem in academic statistics in 2017 is not a reproducibility crisis, so much as that so many of our methods just don’t work. And to be honest, I don’t really know what to do about that, other than suggest that we tighten our standards and insist that people proposing new methods, models, and algorithms work harder to sketch out the boundaries of their creations. (What a suggestion. Really. Concrete proposals for concrete change. But it’s a blog. If ever there was a medium to be half-arsed in it’s this one. It’s like twitter for people who aren’t pithy.)
Berätta för mig om det är sant att din hud är doppad i honung
So what is the object of my impotent ire today. Well nothing less storied than the Bayesian Lasso.
It should be the least controversial thing in this, the year of our lord two thousand and seventeen, to point out that this method bears no practical resemblance to the Lasso. Or, in the words of Law and Order: SVU, “The [Bayesian Lasso] is fictional and does not depict any actual person or event”.
Who do you think you are?
The Bayesian Lasso is a good example of what’s commonly known as the Lupita Nyong’o fallacy, which goes something like this: Lupita Nyong’o had a break out role in Twelve Years a Slave, she also had a heavily disguised role in one of the Star Wars films (the specific Star Wars film is not important. I haven’t seen it and I don’t care). Hence Twelve Years a Slave exists in the extended Star Wars universe.
The key point is that the (classical) Lasso plays a small part within the Bayesian Lasso (it’s the MAP estimate) in the same way that Lupita Nyong’o played a small role in that Star Wars film. But just as the presence of Ms Nyong’o does not turn Star Wars into Twelve Years a Slave, the fact that the classical Lasso can be recovered as the MAP estimate of the Bayesian Lasso does not make the Bayesian Lasso useful.
And yet people still ask if they can be fit in Stan. In that case, Andrew answered the question that was asked, which is typically the best way to deal with software enquiries. (It’s usually a fool’s game to try to guess why people are asking particular questions. It probably wouldn’t be hard for someone to catalogue the number of times I’ve not followed my advice on this, but in life as in statistics, consistency is really only a concern if everything else is going well.) But I am brave and was not asked for my opinion, so I’m going to talk about why the Bayesian Lasso doesn’t work.
Hiding all away
So why would anyone not know that the Bayesian Lasso doesn’t work? Well, I don’t really know. But I will point out that all of the results that I’ve seen in this directions (not that I’ve been looking hard) have been published in the prestigious but obtuse places like Annals of Statistics, the journal we publish in when we either don’t want people without a graduate degree in mathematical statistics to understand us or when we want to get tenure.
By contrast, the original paper is very readable and published in JASA, where we put papers when we are ok with people who do not have a graduate degree in mathematical statistics being able to read them, or when we want to get tenure.
To be fair to Park and Casella, they never really say that the Baysian Lasso should be used for sparsity. Except for one sentence in the introduction where they say the median gives approximately sparse estimators and the title which links it to the most prominent and popular method for estimating a sparse signal. Marketing eh. (See, I’m Canadian now).
The devil has designed my death and is waiting to be sure
So what is the Bayesian LASSO (and why did I spend 600 words harping on about something before defining it? The answer will shock you. Actually the answer will not shock you, it’s because it’s kinda hard to do equations on this thing.)
For data observed with Gaussian error, the Bayesian Lasso takes the form
where, instead of putting a Normal prior on we put independent Laplace priors
Here the tuning parameter where
is the number of covariates,
is the number of observations,
is the number of “true” non-zero elements of
,
is known, and
is an unknown scaling parameter that should be
.
Important Side note: This isn’t the exact same model as Park and Castella used as they didn’t use the transformation
but rather just dealt with as the parameter. From a Bayesian viewpoint, it’s a much better idea to put a prior on
than on
directly. Why? Because a prior on
needs to depend on n, p,
, and X and hence needs to be changed for each problem, while a prior on
can be used for many problems. One possible option is
, which is a rate optimal parameter for the (non-Bayesian) Lasso. Later, we’ll do a back-of-the-envelope calculation that suggests we probably don’t need the square root around the logarithmic term.
Edit: I’ve had some questions about this scaling, so I’m going to try to explain it a little better. The idea here is that the Bayesian Lasso uses the i.i.d. Laplace priors with scaling parameter on
to express the substantive belief that the signal is approximately sparse. The reason for scaling the prior is that not every value of
is consistent with this belief. For example,
will not give an approximately sparse signal. While we could just use a prior for
that has a very heavy right tail (something like an inverse gamma), this is at odds with a good practice principle of making sure all of thee parameters in your models are properly scaled to make them order 1. Why do we do this? Because it makes it much much easier to set sensible priors.
Other important side note: Some of you may have noticed that the scaling can depend on the unknown sparsity
. This seems like cheating. People who do asymptotic theory call this sort of value for
an oracle value, mainly because people studying Bayesian asymptotics are really really into databasing software. The idea is that this is the value of
that gives the model the best chance of working. When maths-ing, you work out the properties of the posterior with the oracle value of
and then you use some sort of smoothness argument to show that the actual method that is being used to select (or average over) the parameter gives almost the same answer.
Only once in Sheboygan. Only once.
So what’s wrong with the Bayesian Lasso? Well the short version is that the Laplace prior doesn’t have enough mass near zero relative to the mass in the tails to allow for a posterior that has a lot of entries that are almost zero and some entries that are emphatically not zero. Because the Bayesian Lasso prior does not have a spike at zero, none of the entries will be a priori exactly zero, so we need some sort of rule to separate the “zero” entries from the “non-zero” entries. The way that we’re going to do this is to choose a cutoff where we assume that if
, then
.
So how do we know that the Lasso prior doesn’t put enough mass in important parts of the parameter space? Well there are two ways. I learnt it during the exciting process of writing a paper that the reviewers insisted should have an extended section about sparsity (although this was at best tangential to the rest of the paper), so I suddenly needed to know about Bayesian models of sparsity. So I read those Annals of Stats papers. (That’s why I know I should be scaling !).
What are the key references? Well all the knowledge that you seek is here and here.
But a much easier way to work out that the Bayesian Lasso is bad is to do some simple maths. Because the are a priori independent, we get a prior on the effective sparsity
For the Bayesian Lasso, that probability can be computed as
.
Ideally, the distribution of this effective sparsity would be centred on the true sparsity. That is, we’d like to choose so that
.
A quick re-arrangement suggests that
.
Now, we are interested in signals with , i.e. where only a very small number of the
are non-zero. This suggests we can safely ignore the second term. Some other theory suggests that we need to take
to depend on
in such a way that it goes to zero faster than
as
gets large. (Edit: Oops – this paper used
and
. For the general case, their reasoning leads to
.)
This means that we need to take in order to ensure that we have our prior centred on sparse vectors (in the sense that the prior mean for the number of non-zero components is always much less than
).
Show some emotion
So for the Bayesian Lasso, a sensible parameter is , which will usually have a large number of components less than the threshold
and a small number that are larger. But this is still not any good. To see this, let’s consider the prior probability of seeing a
larger than one:
.
This is the problem with the Bayesian Lasso: in order to have a lot of zeros in the signal, you are also forcing the non-zero elements to be very small. A plot of this function is above, and it’s clear that even for very small values of this probability is infinitesimally small.
Basically, the Bayesian Lasso can’t give enough mass to both small and large signals simultaneously. Other Bayesian models (such as the horseshoe and the Finnish horseshoe) can support both simultaneously and this type of calculation can show that (although it’s harder. See Theorem 6 here).
Side note: The scaling that I derived in the previous section is a little different to the standard Lasso scaling of , but the same result holds: for large
the probability of seeing a large signal is vanishingly small.
Maybe I was mean, but I really don’t think so
Now, obviously this is not what we see with real data when we fit the Bayesian Lasso in Stan with an unknown . What happens is the model tries to strike a balance between the big signals and the small signals, shrinking the former too much, and letting the latter be too far from zero. You will see this in the event that you try to fit the Bayesian Lasso in Stan.
Update: I’ve put some extra notes in the above text to make it hopefully a little clearer in one case and a little more correct in the other. Please accept this version of the title track as way of an apology
(Also this stunning version, done wearing even more makeup)
The post The king must die appeared first on Statistical Modeling, Causal Inference, and Social Science.