Lenstra–Lenstra–Lovász lattice basis reduction algorithm Information & Lenstra–Lenstra–Lovász lattice basis reduction algorithm Links at HealthHaven.com
advertise
add site
services
publishers
database
health videos
Bookmark and Share

search wiki for    ?
web dir firms image gallery news pdf wiki shop video 
about
toolbar
stats
live show
health store
more stuff
JOIN/LOGIN
Featured Results:
Degeneration: What to do for lattice or retinal atrophy...
Degeneration: What to do for lattice or retinal atrophy...
naturaleyecare.com
 Breast Reduction New York City, New York Breast Reduction , Breast...
Breast Reduction New York City, New York Breast Reduction, Breast...
antell-md.com
 Breast Reduction Virginia, Breast Reduction Washington DC, Breast
Breast Reduction Virginia, Breast Reduction Washington DC, Breast
drmarefat.com
 Male Breast Reduction - Male Breast Reduction Surgery, Gynecomastia Surger
Male Breast Reduction - Male Breast Reduction Surgery, Gynecomastia Surger
peoriacosmeticsurgery.com
 

The Lenstra–Lenstra–Lovász lattice basis reduction (LLL) is a polynomial time lattice reduction algorithm invented by Arjen Lenstra, Hendrik Lenstra and László Lovász in 1982.[1] Given as input d lattice basis vectors with n-dimensional integer coordinates and norms lesser than B, the LLL algorithm outputs an LLL-reduced (short, nearly orthogonal) lattice basis in time

O(d^5n\log^3 B).\,

The original applications were to give polynomial time algorithms for factorizing polynomials with rational coefficients into irreducible polynomials, for finding simultaneous rational approximations to real numbers, and for solving the integer linear programming problem in fixed dimensions.

Contents

[edit] LLL reduction

The precise definition of LLL-reduced is as follows: the basis

\mathbf{B}=\{ \mathbf{b}_1,\mathbf{b}_2, \dots, \mathbf{b}_n \},

with its Gram–Schmidt process orthogonal basis,

\mathbf{B}^*=\{ \mathbf{b}^*_1, \mathbf{b}^*_2, \dots, \mathbf{b}^*_n \}

is LLL-reduced if there exists a parameter δ in (0.25,1] such that

  1. (size-reduced)  \forall i \leq n, j < i\colon \left|\mu_{i,j}\right|\leq 0.5,
  2. (Lovász condition)  \forall i < n \colon \delta \Vert \mathbf{b}^*_i\Vert^2  \leq \left \Vert  \mu_{i+1,i} \mathbf{b}^*_i+\mathbf{b}^*_{i+1}\right \Vert^2,

where

\mu_{i,j}=\frac{\langle\mathbf{b}_i,\mathbf{b}^*_j\rangle}{\langle\mathbf{b}^*_j,\mathbf{b}^*_j\rangle}, for any i>j.

Note that although LLL-reduction is well-defined for δ = 1, the polynomial-time complexity is guaranteed only for δ in (0.25,1).

The LLL algorithm computes LLL-reduced bases. A reduced basis is one in which the basis vectors are as short as possible. There is no known efficient algorithm to compute such a basis except for lattices of dimensions up to 4. A basis which is nearly reduced, in the sense that there are absolute bounds ci > 1 such that the first basis vector is no more than c1 times as long as a shortest vector in the lattice, the second basis vector is likewise within c2 of the second successive minimum, and so on, is computed by the LLL algorithm.

[edit] Applications

The LLL algorithm has found numerous other applications in MIMO detection algorithms and cryptanalysis of public-key encryption schemes: knapsack cryptosystems, RSA with particular settings, NTRUEncrypt, and so forth. The algorithm can be used to find integer solutions to many problems.[2]

In particular, the LLL algorithm forms a core of one of the integer relation algorithms. For example, if it is believed that r=1.618034 is a (slightly rounded) root to a quadratic equation with integer coefficients, one may apply the LLL reduction to the lattice in R4 spanned by [1,0,0,10000r2],[0,1,0,10000r], and [0,0,1,10000]. The first vector in the reduced basis will be an integer linear combination of these three, thus necessarily of the form [a,b,c,10000(ar2 + br + c)]; but such a vector is "short" only if a, b, c are small and ar2 + br + c is even smaller. Thus the first three entries of this short vector are likely to be the coefficients of the integral quadratic polynomial which has r as a root. In this example the LLL algorithm finds the shortest vector to be [1, -1, -1, 0.00025] and indeed x2x − 1 has a root equal to 1.6180339887…

[edit] Implementations

LLL is implemented in

  • Arageli as the function lll_reduction_int
  • fpLLL as a stand-alone implementation
  • GAP as the function LLLReducedBasis
  • LiDIA as the function/method lll in the LT package
  • Macaulay2 as the function LLL in the package LLLBases
  • Magma as the functions LLL and LLLGram (taking a gram matrix)
  • Maple as the function IntegerRelations[LLL]
  • Mathematica as the function LatticeReduce
  • Number Theory Library (NTL) as the function LLL
  • PARI/GP as the function qflll
  • SAGE as the method LLL driven by fpLLL and NTL

[edit] Notes

[edit] References




Product Results (view all...)

search wiki for    ?
web dir firms image gallery news pdf wiki shop video 



↑ top of page ↑about thumbshots