Faster Lattice Basis Computation via a Natural Generalization of the Euclidean Algorithm
Abstract
The Euclidean algorithm is the oldest algorithms known to mankind. Given two integral numbers a1 and a2, it computes the greatest common divisor (gcd) of a1 and a2 in a very elegant way. From a lattice perspective, it computes a basis of the sum of two one-dimensional lattices a1 Z and a2 Z as (a1,a2) Z = a1 Z + a2 Z. In this paper, we show that the classical Euclidean algorithm can be adapted in a very natural way to compute a basis of a general lattice L(A1, … , An) given vectors A1, … , An ∈ Zd with n> rank(a1, … ,ad). Similar to the Euclidean algorithm, our algorithm is very easy to describe and implement and can be written within 12 lines of pseudocode. As our main result, we obtain an algorithm to compute a lattice basis for given vectors A1, … , An ∈ Zd in time (counting bit operations) LS + O((n-d)d2 · (||A||), where LS is the time required to obtain the exact fractional solution of a certain system of linear equalities. The analysis of the running time of our algorithms relies on fundamental statements on the fractionality of solutions of linear systems of equations. So far, the fastest algorithm for lattice basis computation was due to Storjohann and Labhan [SL96] having a running time of O(ndω ||A||). For current upper bounds of LS, our algorithm has a running time improvement of a factor of at least d0.12 over [SL96]. Our algorithm is therefore the first general algorithmic improvement to this classical problem in nearly 30 years. At last, we present a postprocessing procedure which yields an improved size bound of d ||A|| for vectors of the resulting basis matrix.
Turn this paper into a lesson
ArcXiv compiles a structured reading guide from this paper's metadata: plain-English importance, contributions, prerequisite concepts, which sections to read first, flashcards, and a quiz. Grounded in the abstract, never invented.