 for
 for 
 , the Gramm-Schmidt
orthogonalization process produces an orthogonal basis
, the Gramm-Schmidt
orthogonalization process produces an orthogonal basis 
 for
 for 
 as follows.  Define inductively
 as follows.  Define inductively
 
 
sage: A = matrix(ZZ, 2, [1,2, 3,4]); A [1 2] [3 4] sage: Bstar, mu = A.gramm_schmidt()
The rows of the matrix  are obtained
from the rows of
 are obtained
from the rows of  by the Gramm-Schmidt procedure.
 by the Gramm-Schmidt procedure. 
sage: Bstar [ 1 2] [ 4/5 -2/5] sage: mu [ 0 0] [11/5 0]
A lattice 
 is a subgroup that
is free of rank
 is a subgroup that
is free of rank  such that
 such that 
 .
. 
 for a lattice
 for a lattice 
 is LLL reduced if for all
is LLL reduced if for all  ,
, 
 
 ,
, 
 
For example, the basis 
 ,
, 
 for a lattice
 for a lattice  is not
LLL reduced because
 is not
LLL reduced because  and
 and 
 
 ,
, 
 for
 for  is
LLL reduced, since
 is
LLL reduced, since
 
 
sage: A = matrix(ZZ, 2, [1,2, 3,4]) sage: A.LLL() [1 0] [0 2]
William Stein 2012-09-24