Lasso or ‘L1’ regression
\(\,\)
Goals
- Introduce lasso regression
- As a complexity penalty
- As a tuneable hierarchy of models to be selected by cross-validation
- Show some examples comparing greedy variable selection, ridge, and lasso
Penalizing large regressors (slightly different)
Recall last
Recall that one perspective on regression is that we choose \(\betahat\) to minimize the ridge or L2 loss,
\[ \betavhat_{L2}(\lambda) := \argmin{\betav}\left( RSS(\betav) + \lambda \norm{\betav}_2^2 \right). \]
and proved that \[ \betavhat_{L2}(\lambda) = \left(\X^\trans \X + \lambda \id \right)^{-1} \X^\trans \Y. \]
One problem with this might be that the solution \(\betavhat_{L2}(\lambda)\) is still “dense”, meaning that, in general, every entry of it is nonzero, and we still have to invert a \(P\times P\) matrix.
For example, consider our highly correlated regressor example from the previous lecture. The ridge regression will still include both regressors, and their coefficient estimates will still be highly negatively correlated, but both will be shrunk towards zero. Maybe it would make more sense to select only one variable to include. Let us try to think of how we can change the penalty term to achieve this.
A “sparse” solution is an estimator \(\betavhat\) in which many of the entries are zero — that is, an estimated regression line that does not use many of the available regressors.
In a word — ridge regression estimates are not sparse. Let’s try to derive one that is by changing the penalty.
A very intuitive way to produce a sparse estimate is as follows: \[ \betavhat_{L0}(\lambda) := \argmin{\betav}\left( RSS(\betav) + \lambda \sum_{p} 1\left(\beta_p \ne 0\right) \right) \quad\textrm{(practically difficult)} \]
This finds a tradeoff between the best fit to the data, but with a penalty for using more regressors. This makes sense, but is very difficult to compute. In particular, this objective is very non-convex. Bayesian statisticians do attempt to estimate models with a similar kind of penalty (they are called “spike and slab” models), but they are extremeley computationally intensive and beyond the scope of this course.
A convex approximation to the preceding loss is the L1 or Lasso loss, leading to Lasso or L1 regression:
\[ \betavhat_{L1}(\lambda) := \argmin{\betav}\left( RSS(\betav) + \lambda \sum_{p} \abs{\beta_b} \right) = \argmin{\betav}\left( RSS(\betav) + \lambda \norm{\betav}_1 \right). \]
This loss is convex (beacuse it is the sum of two convex functions), and so is much easier to minimize. Furthermore, as \(\lambda\) grows, it does produce sparser and sparser solutions — though it may not be obvious at first.
The Lasso produces sparse solutions
One way to see that the Lasso produces sparse solutions is to start with a very large \(\lambda\) and see what happens as it is slowly decreased.
Start at \(\lambda\) very large, so that \(\betavhat_{L1}(\lambda) = \zerov\). If we take small step of size \(\varepsilon\) in a particular direction away from zero in entry \(\beta_p\), then \(\lambda \norm{\betahat}_1\) increases by \(\varepsilon \lambda\), and the RSS changes by the gradient of the squared error,
\[ \varepsilon \sumn (\y_n - \betavhat(\lambda)^\trans\xv_n) \xv_{np} = \varepsilon \sumn \reshat_n \xv_{np} = \varepsilon \sumn \y_n \xv_{np} \textrm{ (because $\betavhat(\lambda) = \zerov$)}. \]
As long as \(\abs{ \sumn \y_n \xv_{np}} < \lambda\) for all \(p\), we cannot improve the loss by moving away from \(\zerov\). Since the loss is convex, that means \(\zerov\) is the minimum.
Eventually, we decrease \(\lambda\) until \(\sumn \y_n \xv_{np} = \lambda\) for some \(p\). At that point, \(\beta_p\) moves away from zero as \(\lambda\) decreases, and the \(\reshat_n\) also change. However, until \(\sumn \reshat_n \xv_{nq} = \lambda\) for some other \(q\), only \(\beta_p\) will be nonzero. As \(\lambda\) decreases more and more variables tend to get added to the model, until \(\lambda = 0\), when of course \(\betavhat_{L1}(0) = \betahat\), the OLS solution.
Standardization
Just as with the ridge regression, you should standardize variables before appyling the Lasso.