A Randomized Algorithm for Preconditioner Selection
Conner DiPaolo, Weiqing Gu

TL;DR
This paper introduces a fast, sketching-based randomized algorithm for selecting the best preconditioner from a set, significantly improving efficiency and enabling practical preconditioner choice in iterative linear solvers.
Contribution
It presents a novel estimator for preconditioner stability that can be computed efficiently, allowing provable selection of optimal preconditioners among multiple candidates.
Findings
Estimator computes preconditioner stability in constant CG iterations
Method provably selects minimal stability preconditioner in near-linear time
First reported preconditioned kernel regression method with no iteration increase
Abstract
The task of choosing a preconditioner to use when solving a linear system with iterative methods is difficult. For instance, even if one has access to a collection of candidate preconditioners, it is currently unclear how to practically choose the which minimizes the number of iterations of an iterative algorithm to achieve a suitable approximation to . This paper makes progress on this sub-problem by showing that the preconditioner stability , known to forecast preconditioner quality, can be computed in the time it takes to run a constant number of iterations of conjugate gradients through use of sketching methods. This is in spite of folklore which suggests the quantity is…
| Matrix | Conjugate Gradients Iterations With Various Preconditioners | ||||||||
|---|---|---|---|---|---|---|---|---|---|
| apache1 | 3,538 | 3,513 | 3,286 | 3,283 | 3,270 | 3,265 | 3,269 | 3,710 | 3,693 |
| crystm01 | 122 | 54 | 39 | 34 | 30 | 27 | 27 | 24 | 21 |
| crystm02 | 138 | 54 | 38 | 35 | 34 | 29 | 30 | 24 | 24 |
| crystm03 | 143 | 54 | 38 | 34 | 33 | 30 | 29 | 25 | 24 |
| cvxbqp1 | 16,424 | 11,337 | 11,338 | 11,332 | 11,331 | 11,330 | 11,328 | 10,148 | 10,353 |
| gridgena | 3,658 | 3,542 | 2,659 | 2,572 | 2,504 | 2,504 | 2,479 | 2,892 | 2,863 |
| jnlbrng1 | 139 | 131 | 126 | 126 | 125 | 125 | 125 | 130 | 130 |
| minsurfo | 94 | 88 | 64 | 63 | 63 | 62 | 62 | 88 | 88 |
| msc10848 | — | 5,659 | 3,791 | 3,028 | 2,793 | 2,656 | 2,628 | 2,192 | 2,092 |
| obstclae | 66 | 65 | 49 | 48 | 47 | 47 | 47 | 65 | 65 |
| oilpan | 48,291 | 28,065 | 12,804 | 8,167 | 5,476 | 4,992 | 4,127 | 4,757 | 4,433 |
| torsion1 | 66 | 65 | 49 | 48 | 47 | 47 | 47 | 65 | 65 |
| wathen100 | 327 | 45 | 44 | 44 | 44 | 44 | 44 | 42 | 42 |
| wathen120 | 378 | 45 | 45 | 45 | 44 | 44 | 44 | 43 | 43 |
| Matrix | Worst-Case | Random | Algorithm 2 Approximation Ratio | |||||
|---|---|---|---|---|---|---|---|---|
| Min | Mean | Max | Min | Mean | Max | |||
| apache1 | 1.14 | 1.05 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| crystm01 | 5.81 | 2.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| crystm02 | 5.75 | 1.88 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| crystm03 | 5.96 | 1.90 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| cvxbqp1 | 1.62 | 1.15 | 1.12 | 1.12 | 1.12 | 1.12 | 1.12 | 1.12 |
| gridgena | 1.48 | 1.15 | 1.00 | 1.00 | 1.01 | 1.00 | 1.00 | 1.00 |
| jnlbrng1 | 1.11 | 1.03 | 1.04 | 1.04 | 1.04 | 1.04 | 1.04 | 1.04 |
| minsurfo | 1.52 | 1.20 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| msc10848 | 223.90 | 3.97 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| obstclae | 1.40 | 1.18 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| oilpan | 211.70 | 3.26 | 1.00 | 1.09 | 1.15 | 1.07 | 1.08 | 1.15 |
| torsion1 | 1.40 | 1.18 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| wathen100 | 7.79 | 1.79 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
| wathen120 | 8.79 | 1.89 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 | 1.00 |
Peer Reviews
No public reviews on file for this paper yet. If you reviewed it on a platform where reviews are public (OpenReview, ICLR, NeurIPS, ICML), you can paste yours below so the community can read it here.
Videos
No videos yet. Explain this paper in a talk, walkthrough, or lecture? Add one.
Taxonomy
TopicsStochastic Gradient Optimization Techniques · Matrix Theory and Algorithms · Complexity and Algorithms in Graphs
\headers
A Randomized Algorithm for Preconditioner SelectionConner DiPaolo and Weiqing Gu
A Randomized Algorithm for
Preconditioner Selection
Conner DiPaolo Author was with the Department of Mathematics, Harvey Mudd College during the progress of this research. He is now with Yelp Inc., San Francisco, California ([email protected]).
Weiqing Gu Department of Mathematics, Harvey Mudd College, Claremont, California ([email protected]).
Abstract
The task of choosing a preconditioner to use when solving a linear system with iterative methods is difficult. For instance, even if one has access to a collection of candidate preconditioners, it is currently unclear how to practically choose the which minimizes the number of iterations of an iterative algorithm to achieve a suitable approximation to . This paper makes progress on this sub-problem by showing that the preconditioner stability , known to forecast preconditioner quality, can be computed in the time it takes to run a constant number of iterations of conjugate gradients through use of sketching methods. This is in spite of folklore which suggests the quantity is impractical to compute, and a proof we give that ensures the quantity could not possibly be approximated in a useful amount of time by a deterministic algorithm. Using our estimator, we provide a method which can provably select the minimal stability preconditioner among candidates using floating point operations commensurate with running on the order of steps of the conjugate gradients algorithm. Our method can also advise the practitioner to use no preconditioner at all if none of the candidates appears useful. The algorithm is extremely easy to implement and trivially parallelizable. In one of our experiments, we use our preconditioner selection algorithm to create to the best of our knowledge the first preconditioned method for kernel regression reported to never use more iterations than the non-preconditioned analog in standard tests.
keywords:
Preconditioning, Randomized Algorithms, Sketching Methods
{AMS}
65F08, 68W20, 68Q17, 62G08
1 Introduction
A preconditioner is helpful for solving a linear system via iterative methods if it reduces the number of iterations enough to offset the cost of constructing the preconditioner plus the additional cost of taking the iterations (typically an extra computation of the form per iteration.) Ignoring the latter component of this trade-off, this corresponds to having a small condition number for the conjugate gradient method [29, 14]; a precise objective is unclear in the indefinite or unsymmetric case with general Krylov methods besides the general desire that the spectrum of be clustered [8]. For instance, even if we have a small number of candidate preconditioners for our problem ready to use and assume that they add the same amount of time to compute each iteration, it is unclear how one would go about estimating which preconditioner would reduce the iteration count the most without actually solving a system with each preconditioner or doing a comparable amount of work. This preconditioner selection task is the focus of the present work.
1.1 Contributions
The core contribution of this work is the realization that randomized sketching methods make completely practical the computation of a helpful forecaster of preconditioner quality previously thought to be infeasible to compute.
In addition to this primary method for computing preconditioner stability, we provide a number of other results:
- •
We prove that no practical deterministic algorithm, in a meaningful sense, could possibly be used to estimate the preconditioner stability .
- •
We confirm the conjecture of [5] regarding the true asymptotic sample complexity of the Gaussian trace estimator using a substantially more direct proof than the general result provided in [33], at the same time confirming the tightness of our stability estimation algorithm convergence bound.
- •
We provide a randomized algorithm which can provably select a preconditioner of approximately minimal stability among candidate preconditioners using computational resources equivalent to computing on the order of steps of the conjugate gradients algorithm.
- •
We give a theoretical speedup to the initial preconditioner selection method which largely decouples the runtime dependence between the number of preconditioners and the desired accuracy in the situation that the input preconditioner stabilities satisfy an anti-concentration assumption.
- •
Using our initial preconditioner selection algorithm, we create the first (to the best of our knowledge) method for preconditioning in kernel regression which is reported to never give a worse number of iterations than using no preconditioner in standard tests.
It is important to point out that while our experiments consider positive definite systems and preconditioners, our algorithms and runtime bounds hold as-is for arbitrary matrices and preconditioners .
1.2 Prior Art
Current approaches to forecasting preconditioner quality are not robust in the sense that they can fail to select a highly performant preconditioner in favor of a poorly performing one in many realistic scenarios. This lack of robustness, even in the case of positive definite , results in part from the fact that the research community does not have robust methods for estimating condition numbers of large sparse matrices, which makes proxies for preconditioner quality necessary. For instance, Avron et al. [4] recently produced a condition number estimator in this setting which appears to perform admirably in many situations but does not always converge and at this point does not have rigorous theoretical backing.
The simplest forecasting criterion is that a preconditioner ought to be an ‘accurate’ approximation, in the sense that the Frobenius norm distance is small. This preconditioner accuracy criterion can be efficiently computed so long as one has access to the preconditioning matrix in memory as well as the standard matrix-vector product access to . Moreover, for symmetric -matrices this accuracy criterion is a useful proxy for the number of conjugate gradient iterations necessary to solve the preconditioned system in . This point was theoretically confirmed by Axelsson and Eijkhout [6], who showed that the condition number can be bounded in terms of . The accuracy criterion for forecasting preconditioner quality was heavily tested on an empirical level in [15].
Even in this setting, though, there exist accurate real-world preconditioners that give a poor iteration count because is very large [8]. Unfortunately, to detect this issue one presumably needs to compute the entire matrix in memory solely from matrix-vector product access to . The natural method for this, computing each of the columns from products with the standard basis vectors , takes the same leading-order floating point cost as solving the system via conjugate-gradients, at least when matrix-vector multiply access to is comparable to the matrix-vector multiply cost of multiplying by . Perhaps as a result of this intuition, computing , or rather its close cousin the -norm , was deemed impractical [8, 7]. In practice, Chow and Saad [10] suggested using the lower bound for where is the vector of all ones. This has proved helpful for detecting preconditioner instability in some situations, and especially indefinite systems [8].
The quantity known as ‘preconditioner stability,’ , is empirically the most reliable indicator of preconditioner performance from this class of forecasts. This is especially true among many non-symmetric problems or problems which are far from diagonally dominant [8]. Unfortunately, prior work has suggested that computing preconditioner stability is ‘impractical’ [7] for effectively the same reason as why was considered impractical to compute.
In spite of this, Tyrtyshnikov’s influential paper [30] gave a fast algorithm to solve the harder problem considered in this paper of determining the minimal-stability preconditioner over the special class of circulant matrices. This algorithm relied heavily on properties of these matrices.
Our results in this paper will suggest that even for generic and , one can get an arbitrarily accurate estimate of most of these quantities previously thought to be unusable for preconditioner selection. That said, it is crucial to note that the prior impracticality assessment is completely valid in a certain regard: no deterministic algorithms, as we also show, could possibly even approximate the preconditioner stability, for example. Thus an algorithm must fail at some of these tasks with some nonzero probability.
1.3 Overview
Section 2 motivates the need for a randomized algorithm for stability estimation with theory, responds with a sketching-based solution, and uses it to create and analyze a method for preconditioner selection. This theory is empirically confirmed in Section 3 where we apply the primary preconditioner selection algorithm from Section 2 to solving generic real-world systems (Section 3.1) and creating more robust preconditioned solvers for kernel regression (Section 3.2.) After this we conclude in Section 4 and discuss open problems that could provide an avenue for future work.
1.3.1 Notation
Boldface letters like denote vectors while their upper-case analogues such as denote matrices. Such matrices and vectors can be either random or deterministic. The underlying scalar field is either the real numbers or the complex numbers unless otherwise specified. The adjoint of a matrix is denoted by . The inner product of two vectors and is denoted as . The expectation of a random variable will be denoted with , and the probability of an event is written . The norms and represent the Frobenius and Euclidean norms, respectively. The condition number is the condition number. The notation represents . and are normal and circularly-symmetric complex normal random variables, respectively.
2 Algorithms
This section contains all of our core theoretical results and algorithms. In Section 2.1 we show that the only algorithms which can possibly estimate preconditioner stability must be randomized. The follow-up question of whether randomization can indeed work is answered in the affirmative in Section 2.2, where we show that a slight adaptation of a well-known sketching-based algorithm for computing Schatten norms perfectly fits our realistic access model to our preconditioner and matrix . Once we have a good estimator of preconditioner stability, a natural method for selecting the candidate preconditioner with minimal stability criterion presents itself in Section 2.3. It turns our that our algorithm can be trivially parallelized, and a testament to this fact is given in Section 2.3.1. In Section 2.4 we take advantage of highly informative results from the literature on trace estimation to provide useful approximation guarantees and runtime bounds for the previously presented algorithms. Section 2.4.1 returns the focus to Theorem 2.3 of Section 2.4, showing that the leading constant is tight and providing a more concise resolution of a conjecture from [5] than the more generalized result from [33]. In that section, we also comment that no randomized algorithm for estimating preconditioner stability which has access to matrix-vector products of the form could possibly do better asymptotically than Algorithm 1 by relying on this result [33, Thm. 3] from the trace estimation literature. Finally, this conversation is wrapped up in Section 2.4.2, where our bounds from Section 2.4 are utilized to provide a theoretical improvement to Algorithm 2.
2.1 Randomization is Necessary to Compute Preconditioner Stability
This paper provides a simple randomized algorithm which can accurately estimate the preconditioner stability in time faster than running a constant number of iterations of preconditioned conjugate gradients with the matrix and preconditioner . Through incorporating randomness, however, we must accept that the algorithm fails with some probability. This failure probability can be made arbitrarily small, but it would still be advantageous (for example, in mission-critical applications) to provide a deterministic algorithm for the same task with a comparable approximation guarantee. The purpose of this section is to crush that latter hope, and the following theorem does just that.
Theorem 2.1**.**
Fix some . Suppose we have a deterministic algorithm which takes as input an arbitrary positive semi-definite matrix and positive definite matrix , and returns an estimate satisfying
[TABLE]
*after sequentially querying and observing matrix vector multiplies of the form
for where is a constant depending only on and . Then . *
Proof 2.2**.**
Fix for the remainder of the proof. Suppose to the contrary that suffices to compute . Let be the query vectors used by the algorithm in the case that always returns . Write for the orthogonal projection onto . Both of the positive semi-definite matrices and will return uniformly over , and thus since the algorithm is deterministic the estimated stabilities are equal. But since was an orthogonal projection onto a subspace of dimension strictly less than , and hence
[TABLE]
*by our approximation guarantee. This contradiction ensures that we must take . Since , matrix-vector multiply access to is equivalent via a bijection to matrix-vector multiply access to and , hence our strengthened statement of the result. *
Of course, using queries suffices to achieve no error at all, and so the above lower bound is tight:
[TABLE]
where is any orthonormal basis for . Also, note that the condition that and be positive semi-definite gives a stronger result than if they were allowed to be arbitrary matrices.
In order to put Theorem 2.1 into better context, recall that the dominant cost of an iteration of preconditioned conjugate gradients [16, Alg. 11.5.1] is (a) computing for a vector , and (b) computing for a vector . Thus Theorem 2.1 says roughly that in the time it takes to even approximate deterministically, one can solve a system exactly (in exact arithmetic) by running the conjugate gradients algorithm for iterations. Since our whole goal of computing is to forecast how well would do as a preconditioner for solving the system , this means that any deterministic algorithm for this task is, in general, impractical for this task.
2.2 Computing Preconditioner Stability via Randomization
Now we will demonstrate that, unlike the deterministic case, randomization makes it entirely practical to compute preconditioner stability. To see why this is intuitive, let be a standard (real or complex) Gaussian vector. Then
[TABLE]
by the linearity of expectation, the cyclic property of the trace, and the fact that . Thus, if are independent standard normal vectors for all , the Monte-Carlo squared stability estimate
[TABLE]
almost surely as by the strong law of large numbers. We can rewrite the above estimator as where is a matrix with independent and identically distributed elements . This stability estimation algorithm for is given as Algorithm 1. In Algorithm 1, we adjust whether is real or complex depending on for analysis reasons that will be apparent later in Section 2.4.
It is important to note that the mathematical foundations of the above algorithm are not novel. It is equivalent in exact arithmetic to applying the trace estimators in [25] to the matrix and then taking the square root. It is also a simplification of the Schatten- norm estimator in [34, Thm. 69] (relayed from [22]) applied to . The reason we include Algorithm 1 is not because of its mathematical novelty but because of its observational novelty: sketching algorithms using the matrix-vector multiply access model are a perfect fit for interrogating the matrices and in the context of iterative methods for solving linear systems, since this kind of access to and are precisely what make that kind of access practical.
Of course, the presentation thus far does not help us choose how large the accuracy parameter should be. To that end, Theorem 2.3 in Section 2.4 presents a tight upper bound on the necessary to achieve a given error bound with high probability, although in practice just setting appears sufficient in many situations of interest – see Section 3.
2.3 Randomized Algorithm for Selecting the ‘Best’ Preconditioner
Once we have a practical way to compute preconditioner stability, a trivial algorithm for picking the preconditioner among candidates becomes natural. Namely, we can compute estimates for and then just return the preconditioner for which is minimized. This is presented as Algorithm 2. As we mentioned in the previous section, theoretical advice on how to pick will be given in Section 2.4. An improvement to this algorithm in the case there is a clear winner, relying on those analytical bounds, is included in Section 2.4.2.
We note that the sketching matrix can be re-used when computing the stability estimates in Algorithm 1. This is done in all our computational experiments in Section 3, and reduces the number of normal variates one needs to simulate from to . Reuse does not affect our theoretical upper bound presented as Theorem 2.5.
2.3.1 Parallelization
A convenient aspect of sketching based algorithms like Algorithm 2 is that they can be parallelized extremely easily. For instance, suppose we are trying to pick the minimal stability preconditioner among candidates , and have processors , , which have access to and , respectively. Then we can compute each stability estimate in parallel at processor . Ignoring communication costs (which are a genuine concern in practice,) this would bring the runtime of the algorithm down to computing steps of preconditioned conjugate gradients with and the most computation-intensive (in terms of matrix-vector multiply access to ) preconditioner .
Taken to the extreme, one could similarly parallelize Algorithm 2 over processors , and , assuming each had access to and the candidate preconditioner . Each processor would need to compute and return where is an independently sampled standard normal vector. Then in parallel for all processor could compute , at which point we could use processor to compute such that is minimal and return the corresponding . Ignoring communication costs again, this algorithm take fewer floating point operations than running one iteration of preconditioned conjugate gradients with and the most computation-intensive preconditioner , plus flops that were used to turn the into the estimate .
2.4 Approximation Guarantees and Runtime Bounds
This section details runtime bounds and approximation guarantees for Algorithms 1 and 2, as well as using those bounds to derive a theoretical improvement to Algorithm 2.
To start, we will give the following theorem, which says that to estimate preconditioner stability up to a multiplicative factor with failure probability at most , one may take in Algorithm 1. This is (in contrast to the deterministic case) completely independent of the underlying dimension. Theorem 2.3 result sharpens an analogous bound for trace estimators given in [25, Thm. 3], largely following the proof structure of Theorem 1 from that work. We bring the leading constant from a to as and allow for complex matrices. This Theorem is included as a result in its own right primarily since we can even show that the leading constant is tight; see Section 2.4.1.
Theorem 2.3**.**
Let and be arbitrary matrices in where is invertible. If and are positive and less than one, taking ensures that in exact arithmetic the estimate of Algorithm 1 satisfies
[TABLE]
*with probability at least . In particular, if , then the simpler condition ensures this same approximation guarantee. *
Proof 2.4**.**
Unitarily diagonalize as for some unitary and non-negative diagonal matrix . By the rotation invariance of the Gaussian and the fact that is orthogonal when , is equal in distribution to in both the real and complex cases. This implies is equal in distribution to and we can focus on the latter, simpler quantity. By Markov’s inequality, for any ,
[TABLE]
Jensen’s inequality reduces
[TABLE]
so long as . Note that the last inequality covers both real and complex , and results from the moment generating function being bounded above uniformly by the real case for this range of . Taking in Equation 9 gives
[TABLE]
via the scalar inequality for all . The same argument for the lower tail, instead taking , gives
[TABLE]
*as well. A union bound provides the desired result. *
Using Theorem 2.3 we are able to prove an approximation guarantee for Algorithm 2 via a union bound. In particular, to achieve an -multiplicative approximation to the best of candidate preconditioners with probability at least we can take , again independent of the underlying dimension. This dependence on is quite weak, especially since in realistic applications we would only expect to have at most, say, fifty candidate preconditioners.
Theorem 2.5**.**
Let be an arbitrary matrix, and be invertible candidate preconditioners for . If and are positive and less than one, taking ensures that the preconditioner returned by Algorithm 2 satisfies
[TABLE]
with probability at least . In particular, if the simpler condition ensures
[TABLE]
*with probability at least . *
Proof 2.6**.**
Start by fixing any . If we take , Theorem 2.3 ensures that
[TABLE]
except with probability at most . In particular, if we unfix the probability at least one of the does not satisfy Equation 13 is at most by a union bound. (Note that we did not need independence of the estimates here; this is why reusing the sketching matrix is valid.) Thus with probability at least all estimates satisfy Equation 13 simultaneously.
Write for the candidate preconditioner returned by Algorithm 2, and write for a candidate preconditioner which satisfies
[TABLE]
Then since the estimate of the stability of was at most that of by minimality, the simultaneous bounds of Equation 13 give
[TABLE]
except with probability at most . Rearranging the inequality gives the desired result after substituting Equation 14.
*The final simplified bound results from the scalar inequality when and simple algebraic manipulation. *
2.4.1 The Constant in Theorem 2.3 is Tight
Most of the theory presented in this paper relies on Theorem 2.3 to create more sophisticated bounds. Since Algorithm 1 is at its core a repurposing of a trace estimator using only matrix vector products, the work [33] applies and ensures that no randomized, adaptive algorithm for estimating the stability could possibly use asymptotically fewer matrix-vector multiplies so long as the algorithm only has access to for query vectors . In this sense, Algorithm 1 is optimal.
The theoretically-inclined practitioner, however, also cares about knowing the optimality of our analysis in Theorem 2.3. The following Theorem says that our analysis in Theorem 2.3 is asymptotically tight even up to the leading effective constant which tends to for small . In the proof, as is the Lambert- function [19].
Theorem 2.7**.**
Fix some . For any underlying dimension , there exists a positive semi-definite matrix , positive definite matrix , and some so that for any , taking guarantees the stability estimate returned by Algorithm 1 fails to satisfy the equation
[TABLE]
*with probability at least . *
Proof 2.8**.**
If is a standard normal random variable then
[TABLE]
by [17] for all . Setting the right hand side of Inequality 15 to and solving gives
[TABLE]
whenever , which is satisfied when .
Now let and , where is the first standard basis vector. We can observe that
[TABLE]
if is a standard Gaussian vector. In particular, the standard deviation of is . Thus since is a sample average of independent copies of these random variables, fixing ensures
[TABLE]
by the Central Limit Theorem [31, Thm. 1.3.2] and Equation 16 as . This implies the existence of an so that ensures the relation
[TABLE]
*fails with probability at least under our relation defining . The simpler condition on given in the statement of this result follows from the bound for all from [19, Thm. 2]. *
We point out that the above proof gives another confirmation of the conjecture in [5] regarding the true asymptotics of the Gaussian trace estimator. The work in [33] confirmed this conjecture to be true, but did so as a corollary of a general result regarding lower bounds for trace estimation algorithms. Our result above is much more direct.
2.4.2 An Improvement in the Presence of a Clear Winner
Algorithm 2 is simple to implement and works well for selecting preconditioners of minimal stability, as we shall see in Section 3. Nevertheless, if we are selecting between preconditioners where some are clearly worse than the optimal preconditioner in terms of stability, our method seems excessive. Intuitively, we should be able to tell that terrible preconditioners will not be optimal with very rudimentary information. Algorithm 3 presents such a revision to Algorithm 2, iteratively refining the stability estimates we have and filtering out any preconditioners as soon as we can be confident they will not be optimal. Note that the algorithm crucially relies on the bounds from Section 2.4.
We can prove that Algorithm 3 is actually an improvement over Algorithm 2 by making an anti-concentration assumption about the input stabilities.
Theorem 2.9**.**
Let be an arbitrary matrix, be invertible candidate preconditioners for , , and . Denoting , we will write
[TABLE]
for the (shifted) cumulative distribution function of the input relative stabilities. If uniformly over for some positive constant , then Algorithm 3 returns a preconditioner satisfying
[TABLE]
*with probability at least using strictly fewer floating point operations than running iterations of the preconditioned conjugate gradients algorithm in with the most expensive preconditioner in terms of the number of floating point operations required to compute for input vectors . *
Proof 2.10**.**
The same Bonferroni-correction argument from the proof of Theorem 2.5 ensures that
[TABLE]
simultaneously for all over the course of the algorithm, except with probability at most . The rest of the proof will only rely on property 23, so everything we say will hold with this same probability.
If is the set in step of the algorithm and is in before the filtering at the end of step , Equation 23 implies
[TABLE]
Thus, since initially, we know by induction that throughout the process of the entire algorithm. Now consider in the final step of Algorithm 3. Since ,
[TABLE]
Rearranging and realizing that at gives our desired approximation guarantee.
Now we will exhibit the runtime bound by bounding at each step of Algorithm 3. We claim that for all . To see this, note that if a candidate preconditioner is retained after filtering in any step of the algorithm,
[TABLE]
Thus the number of elements in just after step in the algorithm is at most since for . Our runtime bound follows from the sum
[TABLE]
*where is the set during iteration of the algorithm. This gives the number of matrix-vector multiplies of the form used by the algorithm after the first step. To see the final form, add on the multiplies done during the first iteration and plug in . *
The anti-concentration condition in Theorem 2.9 intuitively asserts that the stabilities of the preconditioners do not cluster around the minimal stability. This is satisfied, for example, if at most some number of the candidate preconditioners have stability within a multiplicative factor of the optimal stability. The resulting constant gives an asymptotic runtime bound for Algorithm 3 of , decoupling the linear dependence in with the polynomial accuracy dependence on . Such an improvement is serious when is moderately large; while this example is contrived many other distributions on input data satisfy the assumptions of Theorem 2.9 with the same constant .
Of course, one would hope that Algorithm 3 does not perform poorly when the input data assumptions made in Theorem 2.9 are not satisfied. For example, this would happen when all preconditioners have extremely similar performance, to the point that even our target accuracy cannot distinguish their stabilities. Luckily, a constant always works in Theorem 2.9, so Algorithm 3 never suffers more than a multiplicative increase over Algorithm 2 in number of floating point operations needed to select a preconditioner.
3 Experiments
The present section will jointly test the hypothesis that preconditioner stability is a good forecast for preconditioner quality along with the performance of our algorithms. This is done by evaluating how well Algorithm 2 can select a candidate preconditioner which minimizes the number of conjugate gradients iterations required to achieve some fixed approximation quality in various situations. In Section 3.1, we detail one experiment of this type for generic real-world systems from the SuiteSparse Matrix Collection [13]. Section 3.2 details our other numerical experiment, where we use Algorithm 2 to contribute improvements to the growing literature on preconditioned solvers for kernel regression problems.
3.1 Experiments with Sparse Systems
First we attempt a generic experiment on a collection of real-world sparse linear systems and simple preconditioners, testing how well the preconditioner chosen a-priori by Algorithm 2 compares to the minimal-iterations preconditioner. For the target system , we fix a sampled for the entire experiment. The positive definite matrices are taken from the SuiteSparse/University of Florida Sparse Matrix Collection [13]. We include all matrices from the Boeing and GHS_psdef groups which have between 100,000 and 2,250,000 non-zero entries and are strictly positive definite.
We provide nine candidate preconditioners for Algorithm 2 to select between, using block diagonal preconditioners in order to avoid existence issues of other common preconditioning methods [7]:
- •
The first candidate preconditioner is the trivial preconditioner , which is equivalent to using no preconditioner at all.
- •
The preconditioner denotes a block-diagonal pinching/truncation of the matrix with block size .
- •
The preconditioner is the same block-diagonal pinching, but performed after a Reverse Cuthill-McKee ordering of the matrix [12].
To ensure uniqueness and clarity, blocking is performed by taking the matrix and constructing a block diagonal matrix with blocks of the form for . Since is positive definite, the resulting preconditioners are also positive definite [9, Ex. 2.2.1.(viii)].
In Table 1 we present the number of iterations the preconditioned conjugate gradients algorithm took for each test matrix and preconditioner pair. The algorithm was run until the approximate solution satisfied . The number of iterations was limited to 50,000. Entries in Table 1 achieving this iteration limit are overwritten with ‘—’. The conjugate gradients algorithm applied to the matrices bcsstk36, bcsstk38, msc23052, and vanbody did not converge with any candidate preconditioner, so they are omitted in Table 1.
Even though larger block sizes ought to create better approximations of the original matrix, there are situations when smaller block sizes result in fewer conjugate gradients iterations. Similarly, there are some situations when the original ordering of the data is preferable over the Reverse Cuthill-McKee ordering, and vice-versa. As a result, it is unclear a-priori which preconditioner one should choose to solve the linear system, and this is why someone might wish to use Algorithm 2 to automate that choice.
We test this use of Algorithm 2 under two parameter settings and . Algorithm 2 is run for 1,000 independent trials for each matrix-preconditioner- pairing. After the fact, we compare the number of iterations of preconditioned conjugate gradients would be necessary when using the recommendation of Algorithm 2 relative to the minimal number of iterations possible if we knew in advance how many iterations each preconditioner would use.
3.1.1 Results
The results of our generic real-world-use experiment are presented in Table 2. Every cell is an approximation ratio, i.e. the number of iterations an algorithm for selecting preconditioners took divided by the minimal number of iterations possible using our set of candidate preconditioners. As such, an entry of 1.00 is optimal and represents the minimal-number-of-iterations preconditioner being correctly selected. The column ‘Worst-Case’ reports the approximation ratio if one deterministically selected the maximal-number-of-iterations preconditioner in each setting. The column ‘Random’ reports the expected approximation ratio if one were to select a candidate preconditioner from Table 1 uniformly at random. The columns corresponding to Algorithm 2 gives statistics of the empirical distribution of approximation ratios seen over the 1,000 independent trial runs of the method.
For 10 of the 14 test matrices reported, setting always picks the optimal preconditioner for the problem across every one of the 1,000 trials. If we take , this happens for 11 of the 14 test matrices. Moreover, even when the accuracy parameter , the returned preconditioner never needs more than 15% iterations over than the optimal choice.
One might wonder if taking to be even larger would result in approximation ratios concentrating more uniformly at the ideal 1.00 mark. This will not happen in general, and is where the good-proxy hypothesis is put to the test. For the oilpan matrix, increasing from to raises the best-seen approximation ratio given by Algorithm 2 from 1.00 to 1.07. Increasing causes the preconditioner returned by Algorithm 2 to concentrate further around the true minimal-stability preconditioner (see Theorem 2.5,) and so this implies that the preconditioner stability criterion itself is not perfect and will not in general forecast the exact preconditioner resulting in the minimal number of conjugate gradients iterations.
3.2 Experiments with Kernel Regression Preconditioners
This section will show that Algorithm 2 can turn two simple preconditioners for the standard kernel regression problem into a robust, state-of-the-art preconditioning method. As a corollary of this investigation, we exhibit how Algorithm 2 performs well in situations when the ‘minimal accuracy’ criterion for selecting preconditioners fails, something left unanswered in the previous experiment.
3.2.1 A Quick Review
Kernel regression is a common statistical technique for nonlinear regression. In this setting, we have a dataset consisting of mappings from Euclidean space to the real line . We wish to find coefficients so that the functional mapping
[TABLE]
faithfully represents the empirical mapping in the sense that . In general, is just required to be a positive definite kernel, but in our experiment, we will only use the squared exponential kernel , parametrized by the length-scale which controls the derivative of the model . The coefficients are found by solving the system
[TABLE]
where the positive definite Gram matrix , the output vector , and the noise standarad deviation is used for regularization so that the model fits well on out-of-sample data. In almost all kernel regression problems, and hence are dense. See [32] for more background on this model and associated inference procedure.
3.2.2 Related Work
This experiment will test a preconditioning procedure for solving the linear system via conjugate gradients. There has been a recent interest in this general iterative framework for kernel regression, which largely focuses on creating quality preconditioners for the Gram matrices [3, 11, 18, 27, 26]. This is necessary since for reasonable parameter settings even is often ill-conditioned.
Cutajar et al. [11] performed some initial leg-work in this area, proposing eight candidate preconditioners. These preconditioners include a block-diagonal approximation of , adding a larger regularizer and solving recursively, a Nyström approximation of the Gram matrix using data points as inducing points chosen uniformly at random, a coupling of the Nyström approximation with a block-diagonal approximation, or replacing with an optimal low-rank factorization which can be computed via a randomized SVD [18] or the Lanczos method [16, Sec. 10.1]. Both [11] and the work [3] of Avron et al. use the Fourier features method of Rahimi and Recht [24] to create a preconditioner which replaces with a sketched version . The latter paper [3] also proposes using the TensorSketch method of [23] for creating a sketched preconditioner when using the polynomial kernel , though the necessary sketching dimension in their upper bounds is exponential in . The work of Rudi et al. [27] also uses the Nyström-based preconditioner like [11], combining it with other computational tricks. This Nyström-based approach was refined with approximate leverage score sampling in more recent work by Rudi et al. [26].
An empirical issue within many of the above methods is illustrated perfectly in Figure 1 of [11]. For every preconditioner presented therein, there exist parameter settings for which using no preconditioner results in fewer iterations than using the preconditioner when solving for via conjugate gradients. As such, it is unclear how one would choose a preconditioner in practice which makes these solvers work well in practice.
3.2.3 Two Simple Geometrically Driven Preconditioners
Here we detail the two candidate preconditioners which we will use in our experiments. They both utilize a geometrically-motivated reordering of the data to empirically achieve superior performance to the preconditioners of [11] for many settings of the kernel parameters and .
The first preconditioner is a simple block diagonal pinching of a reordering of the data. The kernel regression model under the squared exponential kernel effectively asserts that points nearby in ought to have similar outputs . If the input data is highly clustered in , our model then ought to largely ignore points from different clusters when considering a point in some cluster. The first preconditioning algorithm turns this ‘ought to’ statement directly into an approximation of the Gram matrix . We first cluster the data in via the k-means or k-means++ [1] algorithm with clusters, constructing a permutation matrix that places points in the same cluster next to each other on the Gram matrix. At this point, we precondition the re-ordered system by creating a block-diagonal pinching of the re-ordered matrix where each block corresponds to the points within a cluster. The resulting preconditioner is that pinching plus the true noise term .
The second preconditioner is a slightly more complex version of the first. After computing the permuted matrix , we compute a truncated rank- approximation of where is diagonal and has orthonormal columns. At this point we compute the same block diagonal pinching of the error in approximation . The resulting preconditioner is then .
To show that these are feasible to use as preconditioners, it suffices to consider the latter since it reduces to the former when . If is a constant, we can solve systems in this preconditioner using the Woodbury identity [16, Sec. 2.1.4] in floating point operations under the assumption that the cluster sizes are all within a constant factor of each other. This is after computing a one-time Cholesky decomposition of the block-diagonal pinching in floating point operations. Similarly, computing the low-rank factorization takes floating point operations using either the Implicitly-Restarted Lanczos method [28] or a Randomized SVD [18], though for higher ranks the latter method is preferable. Since matrix-vector multiplies with take floating point operations, these preconditioners do not raise the per-iteration complexity of the conjugate gradients method.
Moreover, if we fix the resulting sparsity pattern of the preconditioner, the former preconditioner exactly minimizes the accuracy over all matrices with the same sparsity pattern. Since the identity matrix also has this sparsity pattern, we would always choose the preconditioner over the identity matrix if using the accuracy criterion, and a similar logic shows the same holds for the latter preconditioner.
The work of Cutajar et al. [11] already suggests that block-diagonal approximations to kernel matrices can be faithful for small length-scales , and that low-rank approximations can be faithful for large length-scales . Following this helpful research, the main insight in our proposed preconditioners is that permutating the data in a way that points close together in Euclidean space are close on the matrix ensures a block-diagonal approximation is even more faithful. The permutation we use relies on the Euclidean geometry of our kernel, and other permutations would need to be used for kernels other than the squared exponential kernel.
3.2.4 Experimental Design
We consider three datasets along with various parameter settings, aiming to see how many iterations the conjugate gradients algorithm takes with each of our proposed preconditioners, as well as using Algorithm 2, in comparison to using no preconditioner at all. This experiment is identical to one from [11] except with different preconditioners, and ideally our preconditioned solvers significantly reduce the number of iterations used by the standard conjugate gradients algorithm.
The datasets have names Concrete, Power, and Protein, and are identically the same as the data in [11] pulled from the UCI Machine Learning Repository [2]. The Concrete dataset consists of 1,029 data points in . The Power dataset consists of 9,567 data points in . The Protein dataset consists of 45,729 data points in .
For each of these datasets, and each pair of parameters chosen from and , we construct a kernel system . This system is solved using conjugate gradients with no preconditioner, the geometric preconditioner with no low-rank approximation, and the geometric preconditioner with a rank low-rank approximation. We also solve the system using the preconditioner chosen by one run of Algorithm 2 among no preconditioner, the purely block-diagonal geometric preconditioner, and the rank low-rank approximation-based geometric preconditioner, using an accuracy parameter . We also attempt using Algorithm 2 with the same if we restrict the choice to the two geometric preconditioners, ruling out the use of no preconditioner. In solving these systems, we record the number of conjugate gradients iterations needed to achieve a residual norm less than as in [11]; a relative tolerance of is also specified, though this is vacuous in comparison to the absolute tolerance. The solver is stopped after 10,000 iterations if the residual has not converged to within tolerance by then. The low-rank approximations are computed via ARPACK [21] with a tolerance parameter of .
3.2.5 Results
Figure 1 illustrates the relative improvement different preconditioning schemes have over using no preconditioner for each dataset and parameter combination. Each cell gives the logarithm of the ratio of the preconditioned conjugate gradients iterations to the non-preconditioned conjugate gradients iterations, i.e. the order of magnitude of the improvement granted by using the preconditioner. Accordingly, negative values (blue or ‘–’) represent improvement through using the preconditioner, while positive values (red or ‘+’) correspond to the preconditioned system requiring more iterations than using no preconditioner at all. Five of the cells for the Protein dataset with the purely block diagonal geometric preconditioner have relative improvements of more than two orders of magnitude. Another three preconditioners using a low-rank approximation with the Protein dataset have this property. In spite of this, we restrict the visual range of the plot from to to allow Figure 1 to be compared easily to the identical presentation in Figure 1 of [11]. No cell values exceed .
First we comment purely on the performance of the two geometrically motivated preconditioners. The main take-away is that the geometric permutation based on the k-means algorithm appears to truly help in creating a faithful preconditioner. As evidence, we can point to the fact that the simple geometric block-diagonal preconditioner gives, for five different parameter settings with the Protein dataset, a relative improvement better than every single preconditioner-parameters-dataset pair in [11]. Phrased differently, at these parameter settings the number of iterations drops from 189, 111, 2,345, 618, and 10,000 (did not converge) to 1, 1, 3, 3, and 94 iterations, respectively. Moreover, the geometric preconditioner using a low-rank approximation for the Concrete dataset always outperforms using no preconditioner, something no preconditioner proposed in [11] can do. These improvements are genuine and stark, and again achieved by an extremely simple method just by relying on geometry.
Of course, one can rightfully point out that the block diagonal pinching is not robust as a preconditioner, just like many methods from [11]. This is true; the block diagonal approximation works well for small length scales , as in these circumstances dependencies between far away data points and are shrunk, resulting in a genuine clustering of the underlying data where the intuition we used in justifying the preconditioner carries through. For large , the block diagonal preconditioner performs poorly because the matrix looks more uniform and doesn’t have a genuine clustered structure. Luckily, the more sophisticated preconditioners with added rank-25 terms perform well in precisely this regime, as the low-rank term can capture uniform structure in the Gram matrix . While this complicated preconditioner is not perfect, it is more robust to parameter changes than the analogous SVD-based preconditioner from [11]. Between our two candidate preconditioners, at least one provides a performance boost over non-preconditioned conjugate gradients for every dataset and parameter setting chosen. Such a claim cannot be said about any pair of preconditioners in [11].
Since we have two quality preconditioners, each performing admirably in opposing parameter regimes, we might hope to get the best of both worlds by forecasting via Algorithm 2 which one will perform better than using no preconditioner and solving the system with that resulting preconditioner. This approach does quite well, as we can see in Figure 1. While Algorithm 2 does not always pick the best preconditioner in terms of minimizing the number of conjugate gradients iterations, it never selects a preconditioner which performs worse than using no preconditioner. That said, a preconditioner resulting in an exactly minimal number of iterations is chosen over 80% of the time if the ‘use no preconditioner’ option is included, and over 40% of the time the preconditioner ranking induced by our stability estimates exactly corresponds to the ranking induced by the true iteration count. If we exclude the ‘use no preconditioner’ option, which corresponds to an a-priori understanding that at least one of the geometric preconditioners works well, the former statistic jumps from 80% to an impressive 98.1%. This ‘all blue’ plot which represents a robust preconditioner regime can not be found using the techniques of [11]. Moreover, the algorithm was able to return the advice ‘use no preconditioner’ in the face of uncertainty instead of suggesting the use of a poor preconditioner. This fact alone is highly desirable for the practitioner.
To confirm the importance of this paper, it is necessary to show that our method performs well when the computationally simple accuracy method does not. As mentioned when detailing the construction of these preconditioners, the accuracy criterion would never choose the ‘use no preconditioner’ option over one of the geometric preconditioner. If we were just looking at the purely block-diagonal geometric preconditioner versus the ‘use no preconditioner option’, the accuracy criterion would result in a poor preconditioner (higher number of iterations than possible) exactly a third of the time with the Concrete dataset. Of these times that the accuracy method fails, the estimated stability criterion succeeds exactly half of the time. For the Power dataset, the accuracy method fails 44.4% of the time, but our estimated stability criterion succeeds in a quarter of these cases. While this behavior is not universal, it indicates that our method can be a crucial help when standard tools fail.
Finally, it is important to point out that in this setting, Algorithm 2 performed computation commensurate with taking 30 steps of conjugate gradients. Since in over half of the parameter-dataset pairs the non-preconditioned conjugate gradients algorithm took more than five times this number of iterations, and our method can in most situations reduce that full-solution cost significantly, this initial cost is acceptable.
4 Conclusions
We have created a method to make the conjugate gradients algorithm friendlier to the practitioner. In particular, we took a quality forecast of preconditioner quality previously thought of as unusable in this arena, preconditioner stability, and presented a randomized algorithm which can quickly compute this quantity and use it to select a quality preconditioner. Our methods are motivated and justified heavily by theory and backed up by empirical evidence which suggests its applicability in the real world. In particular, Algorithm 2 allowed us to create the first practical preconditioning system for kernel regression which is reported to never run fewer iterations than using no preconditioner at all in standard experiments; this is accomplished with surprisingly little leg-work.
Our work raises some important theoretical questions which would be ripe for future work. Most notably, it would be helpful to determine the fundamental limits of using preconditioner stability as a proxy for preconditioner quality with regard to different iterative methods. For example, it would be interesting to know if there are arbitrarily long sequences of preconditioners for some fixed positive definite matrix for which the order induced by the preconditioner-stability criterion is the opposite of the order induced by the condition number.
Finally, we note that our framing in Section 2.2 allows us to interpret the problem of finding a good preconditioner as a multi-armed bandit problem. Algorithms and lower bounds from this research area – see [20] for example – would then be informative to our problem of interest. As before, this investigation is left for future work.
Acknowledgments
We would like to thank Nicholas Pippenger for fruitful discussions early in the process of this research, as well as Karl Wimmer for helping us understand the main result in [33]. We also appreciate the support of Harvey Mudd College in the form of computational resources used during this work.
The reference list from the paper itself. Each links out to its DOI / PubMed record.
- 1[1] D. Arthur and S. Vassilvitskii , k-means++: The advantages of careful seeding , in Proceedings of the eighteenth annual ACM-SIAM symposium on Discrete algorithms, Society for Industrial and Applied Mathematics, 2007, pp. 1027–1035.
- 2[2] A. Asuncion and D. Newman , Uci machine learning repository , 2007.
- 3[3] H. Avron, K. L. Clarkson, and D. P. Woodruff , Faster kernel ridge regression using sketching and preconditioning , SIAM Journal on Matrix Analysis and Applications, 38 (2017), pp. 1116–1138.
- 4[4] H. Avron, A. Druinsky, and S. Toledo , Spectral condition-number estimation of large sparse matrices , Numerical Linear Algebra with Applications, 26 (2019), p. e 2235.
- 5[5] H. Avron and S. Toledo , Randomized algorithms for estimating the trace of an implicit symmetric positive semi-definite matrix , Journal of the ACM (JACM), 58 (2011), p. 8.
- 6[6] O. Axelsson and V. Eijkhout , Vectorizable preconditioners for elliptic difference equations in three space dimensions , in Advances in Parallel Computing, vol. 1, Elsevier, 1990, pp. 299–321.
- 7[7] M. Benzi , Preconditioning techniques for large linear systems: a survey , Journal of computational Physics, 182 (2002), pp. 418–477.
- 8[8] M. Benzi, D. B. Szyld, and A. Van Duin , Orderings for incomplete factorization preconditioning of nonsymmetric problems , SIAM Journal on Scientific Computing, 20 (1999), pp. 1652–1670.
