I am delighted to share that my paper Randomized Kaczmarz with tail averaging, joint with Gil Goldshlager and Rob Webber, has been posted to arXiv. This paper in particular really benefited from a lot of feedback from discussions with friends, colleagues, and experts, and I’d like to thank everyone who gave us feedback on this paper.
In this post, I want to provide a different and complementary perspective on the results of this paper, and provide some more elementary results and derivations that didn’t make the main paper.
The randomized Kaczmarz (RK) method is an iterative method for solving systems of linear equations , whose dimensions will be
throughout this post. Beginning from a trivial initial solution
, the method works by repeating the following two steps for
:
- Randomly sample a row
of
with probability
denotes the
th row of
.
- Orthogonally project
onto the solution space of the equation
, obtaining
.
The main selling point of RK is that it only interacts with the matrix through row accesses, which makes the method ideal for very large problems where only a few rows of
can fit in memory at a time.
When applied to a consistent system of linear equations (i.e., a system possessing a solution satisfying
), RK is geometrically convergent:
(1)
(2)
data:image/s3,"s3://crabby-images/7d6e7/7d6e77645d551325b9bded911b038487d7f3097c" alt="Rendered by QuickLaTeX.com \sigma_i(A)"
data:image/s3,"s3://crabby-images/c1217/c12179b93ac1291850be714789a02a34bdcd4ea5" alt="Rendered by QuickLaTeX.com A"
data:image/s3,"s3://crabby-images/24505/245054ffa73c9648fdad08a8cb77d3ad84e7e792" alt="Rendered by QuickLaTeX.com \kappa_{\rm dem} = \kappa \cdot \sqrt{\operatorname{srank}(A)}"
data:image/s3,"s3://crabby-images/3e791/3e7913d009b214674ce6cf6064be1d7159fc46c5" alt="Rendered by QuickLaTeX.com \kappa = \sigma_{\rm max}(A) / \sigma_{\rm min}(A)"
data:image/s3,"s3://crabby-images/cab4b/cab4bca725b81c3dc2d84a0042b2f2797e132752" alt="Rendered by QuickLaTeX.com \operatorname{srank}(A) = \norm{A}_{\rm F}^2/\sigma_{\rm max}^2(A)"
data:image/s3,"s3://crabby-images/c1217/c12179b93ac1291850be714789a02a34bdcd4ea5" alt="Rendered by QuickLaTeX.com A"
data:image/s3,"s3://crabby-images/c1217/c12179b93ac1291850be714789a02a34bdcd4ea5" alt="Rendered by QuickLaTeX.com A"
data:image/s3,"s3://crabby-images/1d40a/1d40a63cd4eab6064476feed4c5f2fc3130721a5" alt="Rendered by QuickLaTeX.com \e^{-t / (\kappa^2 \operatorname{srank}(A))}"
data:image/s3,"s3://crabby-images/914df/914dfe580dbfb45822a05fa3e875e882b8bbca22" alt="Rendered by QuickLaTeX.com \kappa^2 \operatorname{srank}(A)"
data:image/s3,"s3://crabby-images/24db5/24db5d07c27960d55a82e7c41f0130b91b9ab8b9" alt="Rendered by QuickLaTeX.com \kappa^2 n"
data:image/s3,"s3://crabby-images/ded43/ded4347863bc6b9bc34aadc9218d9888df76d200" alt="Rendered by QuickLaTeX.com x_t"
data:image/s3,"s3://crabby-images/cf54d/cf54d2027017038167d3b2787aa237484797ae19" alt="Rendered by QuickLaTeX.com a_{i_t}^\top x = b_{i_t}"
data:image/s3,"s3://crabby-images/43899/43899f38d0024f69ee592f5bb7bba18df6023c16" alt="Rendered by QuickLaTeX.com x_\star"
However, while the RK iterates continue to randomly fluctuate when applied to an inconsistent system, their expected value does converge. In fact, it converges to the least-squares solution2If the matrix is rank-deficient, then we define
to be the minimum-norm least-squares solution
, which can be expressed using the Moore–Penrose pseudoinverse
.
to the system, defined as
data:image/s3,"s3://crabby-images/ded43/ded4347863bc6b9bc34aadc9218d9888df76d200" alt="Rendered by QuickLaTeX.com x_t"
data:image/s3,"s3://crabby-images/43899/43899f38d0024f69ee592f5bb7bba18df6023c16" alt="Rendered by QuickLaTeX.com x_\star"
Theorem 1 (Exponentially Decreasing Bias): The RK iterates
have an exponentially decreasing bias
(3)
Observe that the rate of convergence (3) for the bias is twice as fast as the rate of convergence for the error in (1). This factor of two was previously observed by Gower and Richtarik in the context of consistent systems of equations.
The proof of Theorem 1 is straightforward, and we will present it at the bottom of this post. First, we will discuss a couple of implications. First, we develop convergent versions of the RK algorithm using tail averaging. Second, we explore what happens when we implement RK with different sampling probabilities .
Tail Averaging
It may seem like Theorem 1 has little implication for practice. After all, just because the expected value of becomes closer and closer to
, it need not be the case that
is close to
. However, we can improve the quality of the approximate solution
by averaging.
There are multiple different possible ways we could use averaging. A first idea would be to run RK multiple times, obtaining multiple solutions which could then be averaged together. This approach is inefficient as each solution
is computed separately.
A better strategy is tail averaging. Fix a burn-in time , chosen so that the bias
is small. For each
,
is a nearly unbiased approximation to the least-squares solution
. To reduce variance, we can average these estimators together
data:image/s3,"s3://crabby-images/85912/85912127019619fbd5f26b1783dcae6f2d991f1d" alt="Rendered by QuickLaTeX.com \overline{x}_t"
data:image/s3,"s3://crabby-images/a8e13/a8e1338343bea05445130fbcf9b3c2b9b7357125" alt="Rendered by QuickLaTeX.com t_{\rm b}"
data:image/s3,"s3://crabby-images/0c088/0c0889abbbeb5b759745a771741769727a366880" alt="Rendered by QuickLaTeX.com t"
data:image/s3,"s3://crabby-images/ed70d/ed70db57eb5e14ea674775e97c458c4d636de428" alt="Rendered by QuickLaTeX.com (a_i,b_i)"
Tail averaging can be an effective method for squeezing a bit more accuracy out of the RK method for least-squares problems. The figure below shows the error of different RK methods applied to a random least-squares problem, including plain RK, RK with thread averaging (RKA), and RK with underrelaxation (RKU);3The number of threads is set to 10, and the underrelaxation parameter is . We found this underrelaxation parameter to lead to a smaller error than the other popular underrelaxation parameter schedule
. see the paper’s Github for code. For this problem, tail-averaged randomized Kaczmarz achieves the lowest error of all of the methods considered, being 6× smaller than RKA, 22× smaller than RK, and 10⁶× smaller than RKU.
data:image/s3,"s3://crabby-images/26055/260559579d0bbeeed95abaddd8892f6cd31d618a" alt="Error versus iteration for different randomized Kaczmarz methods. Tail-averaged randomized Kaczmarz shows the lowest error"
What Least-Squares Solution Are We Converging To?
A second implication of Theorem 1 comes from reanalyzing the RK algorithm if we change the sampling probabilities. Recall that the standard RK algorithm draws random row indices using squared row norm sampling:
data:image/s3,"s3://crabby-images/f63d4/f63d4ed67ec7e984ecadfdfd6cefef8f973d9362" alt="Rendered by QuickLaTeX.com j"
data:image/s3,"s3://crabby-images/02bd1/02bd102b4802690008c5e3f4095f126b60b6214a" alt="Rendered by QuickLaTeX.com p_j^{\rm RK}"
Using the standard RK sampling procedure can sometimes be difficult. To implement it directly, we must make a full pass through the matrix to compute the sampling probabilities.4If we have an upper bound on the squared row norms, there is an alternative procedure based on rejection sampling that avoids this precomputation step. It can be much more convenient to sample rows uniformly at random
.
To do the following analysis in generality, consider performing RK using general sampling probabilities :
Define a diagonal matrix
data:image/s3,"s3://crabby-images/5555d/5555de03f62a7b93bbe0e9c2ebcdf3bf75b75f0f" alt="Rendered by QuickLaTeX.com \{p_j\}"
data:image/s3,"s3://crabby-images/85912/85912127019619fbd5f26b1783dcae6f2d991f1d" alt="Rendered by QuickLaTeX.com \overline{x}_t"
data:image/s3,"s3://crabby-images/c9ca1/c9ca182b2adfeb1521628ae755182bcbdf62e9e8" alt="Rendered by QuickLaTeX.com x_{\rm weighted}"
data:image/s3,"s3://crabby-images/43899/43899f38d0024f69ee592f5bb7bba18df6023c16" alt="Rendered by QuickLaTeX.com x_\star"
I find this very interesting. In the standard RK method, the squared row norm sampling distribution is chosen to ensure rapid convergence of the RK iterates to the solution of a consistent system of linear equations. However, for a consistent system, the RK method will always converge to the same solution no matter what row sampling strategy is chosen (as long as every non-zero row has a positive probability of being picked). In the least-squares context, however, the conclusion is very different: the choice of row sampling distribution not only affects the rate of convergence, but also which solution is being converged to!
As the plot below demonstrates, the original least-squares solution and re-weighted least-squares solution can sometimes be quite different from each other. This plot shows the results of fitting a function with many kinks (show as a black dashed curve) using a polynomial function [mfn}Note that, for this experiment we represent the polynomial
using its monomial coefficients
, which has issues with numerical stability. It’s better to use a representation using Chebyshev polynomials. We use this example only to illustrate the difference between the weighted and original least-squares solution.[/mfn} at
equispaced points. We compare the unweighted least-squares solution (orange solid curve) to the weighted least-squares solution using uniform RK weights
(blue dash-dotted curve). These two curves differ meaningfully, with the weighted least-squares solution having higher error at the ends of the interval but more accuracy in the middle. These differences can be explained looking at the weights (diagonal entries of
, grey dotted curve), which are lower at the ends of the interval than in the center.
data:image/s3,"s3://crabby-images/05c8f/05c8f0e0fc51ec5fcda8c47f5d9966cb6ba83422" alt="Weighted and un-weighted least-squares solution to polynomial regression problem. (Tail averaged) randomized Kaczmarz method with uniform sampling converges to the weighted least-squares solution, which is more accurate on the middle of the interval (where the weights are high) than the edges of the interval (where the weights are smaller)"
Does this diagonal rescaling issue matter? Sometimes not. In many applications, the weighted and un-weighted least squares solutions will both be fine. Indeed, in the above example, neither the weighted nor un-weighted solutions are the “right” one; the weighted solution is more accurate in the interior of the domain and less accurate at the boundary. However, sometimes getting the true least-squares solution matters, or the amount of reweighting done by uniform sampling is too aggressive for a problem. In these cases, using the classical RK sampling probabilities may be necessary. Fortunately, rejection sampling can often be used to perform squared row norm sampling; see this blog post of mine for details.
Proof of Theorem 1
Let us now prove Theorem 1, the asymptotic unbiasedness of randomized Kaczmarz. We will assume throughout that is full-rank; the rank-deficient case is similar but requires a bit more care.
Begin by rewriting the update rule in the following way
data:image/s3,"s3://crabby-images/5282e/5282e707477e8b04f35423358478d4dcc444c9b9" alt="Rendered by QuickLaTeX.com \expect_{i_t}"
data:image/s3,"s3://crabby-images/53d28/53d282ffd111ec2a5eb3bf6f18dd20a9404e8194" alt="Rendered by QuickLaTeX.com i_t"
We can evaluate the sums and
directly. Therefore, we obtain
data:image/s3,"s3://crabby-images/0611a/0611a2eac72bf439b42876fb42389952ef74d3fc" alt="Rendered by QuickLaTeX.com x_0 = 0"
(4)
The equation (4) expresses the expected RK iterate
![Rendered by QuickLaTeX.com \expect[x_t]](https://www.ethanepperly.com/wp-content/ql-cache/quicklatex.com-41d92b12c75d466d126bae8b5af9c2a5_l3.png)
data:image/s3,"s3://crabby-images/d2b51/d2b51687fda4659e80fee16697327ca1869e50f9" alt="Rendered by QuickLaTeX.com |y|<1"
data:image/s3,"s3://crabby-images/a13d7/a13d7b9c766e30125fc68ba43bbbf17ed5b77d14" alt="Rendered by QuickLaTeX.com x=1-y"
data:image/s3,"s3://crabby-images/ce45a/ce45aacc4b57dc1f500c755dcfde8bd68a9ea771" alt="Rendered by QuickLaTeX.com 0 < x < 2"
data:image/s3,"s3://crabby-images/2c177/2c17753e2f969f32cbf515113454922bea4c25da" alt="Rendered by QuickLaTeX.com X"
data:image/s3,"s3://crabby-images/4b24b/4b24be36ccc0d2ce7fffeb1965ee411841ef1022" alt="Rendered by QuickLaTeX.com 0 < \sigma_{\rm min}(X) \le \norm{X} < 2"
data:image/s3,"s3://crabby-images/d83e8/d83e8295abfb73591509b915c425ef209617a01a" alt="Rendered by QuickLaTeX.com X = A^\top A / \norm{A}_{\rm F}^2"
data:image/s3,"s3://crabby-images/c1217/c12179b93ac1291850be714789a02a34bdcd4ea5" alt="Rendered by QuickLaTeX.com A"
(5)
(6)
We are at the home stretch. Plugging (6) into (4) and using the normal equations , we obtain
(7)
To complete the proof we must evaluate the norm of the matrix . Let
be a (thin) singular value decomposition, where
. Then
data:image/s3,"s3://crabby-images/4a9f2/4a9f29dbe3d47545603b7131c82d846a690ce2b6" alt="Rendered by QuickLaTeX.com V"
data:image/s3,"s3://crabby-images/584dc/584dc49919c458cc5e482dba6061775769990e54" alt="Rendered by QuickLaTeX.com 1 - \sigma_{\rm min}^2(A)/\norm{A}_{\rm F}^2 = 1 - \kappa_{\rm dem}^{-2}"