Jump to content
Wikipedia The Free Encyclopedia

Korkine–Zolotarev lattice basis reduction algorithm

From Wikipedia, the free encyclopedia
Not to be confused with Kolmogorov–Zurbenko filter.

The Korkine–Zolotarev (KZ) lattice basis reduction algorithm or Hermite–Korkine–Zolotarev (HKZ) algorithm is a lattice reduction algorithm.

For lattices in R n {\displaystyle \mathbb {R} ^{n}} {\displaystyle \mathbb {R} ^{n}} it yields a lattice basis with orthogonality defect at most n n {\displaystyle n^{n}} {\displaystyle n^{n}}, unlike the 2 n 2 / 2 {\displaystyle 2^{n^{2}/2}} {\displaystyle 2^{n^{2}/2}} bound of the LLL reduction.[1] KZ has exponential complexity versus the polynomial complexity of the LLL reduction algorithm, however it may still be preferred for solving multiple closest vector problems (CVPs) in the same lattice, where it can be more efficient.

History

[edit ]

The definition of a KZ-reduced basis was given by Aleksandr Korkin and Yegor Ivanovich Zolotarev in 1877, a strengthened version of Hermite reduction. The first algorithm for constructing a KZ-reduced basis was given in 1983 by Kannan.[2]

The block Korkine-Zolotarev (BKZ) algorithm was introduced in 1987.[3]

Definition

[edit ]

A KZ-reduced basis for a lattice is defined as follows:[4]

Given a basis

B = { b 1 , b 2 , , b n } , {\displaystyle \mathbf {B} =\{\mathbf {b} _{1},\mathbf {b} _{2},\dots ,\mathbf {b} _{n}\},} {\displaystyle \mathbf {B} =\{\mathbf {b} _{1},\mathbf {b} _{2},\dots ,\mathbf {b} _{n}\},}

define its Gram–Schmidt process orthogonal basis

B = { b 1 , b 2 , , b n } , {\displaystyle \mathbf {B} ^{*}=\{\mathbf {b} _{1}^{*},\mathbf {b} _{2}^{*},\dots ,\mathbf {b} _{n}^{*}\},} {\displaystyle \mathbf {B} ^{*}=\{\mathbf {b} _{1}^{*},\mathbf {b} _{2}^{*},\dots ,\mathbf {b} _{n}^{*}\},}

and the Gram-Schmidt coefficients

μ i , j = b i , b j b j , b j {\displaystyle \mu _{i,j}={\frac {\langle \mathbf {b} _{i},\mathbf {b} _{j}^{*}\rangle }{\langle \mathbf {b} _{j}^{*},\mathbf {b} _{j}^{*}\rangle }}} {\displaystyle \mu _{i,j}={\frac {\langle \mathbf {b} _{i},\mathbf {b} _{j}^{*}\rangle }{\langle \mathbf {b} _{j}^{*},\mathbf {b} _{j}^{*}\rangle }}}, for any 1 j < i n {\displaystyle 1\leq j<i\leq n} {\displaystyle 1\leq j<i\leq n}.

Also define projection functions

π i ( x ) = j i x , b j b j , b j b j {\displaystyle \pi _{i}(\mathbf {x} )=\sum _{j\geq i}{\frac {\langle \mathbf {x} ,\mathbf {b} _{j}^{*}\rangle }{\langle \mathbf {b} _{j}^{*},\mathbf {b} _{j}^{*}\rangle }}\mathbf {b} _{j}^{*}} {\displaystyle \pi _{i}(\mathbf {x} )=\sum _{j\geq i}{\frac {\langle \mathbf {x} ,\mathbf {b} _{j}^{*}\rangle }{\langle \mathbf {b} _{j}^{*},\mathbf {b} _{j}^{*}\rangle }}\mathbf {b} _{j}^{*}}

which project x {\displaystyle \mathbf {x} } {\displaystyle \mathbf {x} } orthogonally onto the span of b i , , b n {\displaystyle \mathbf {b} _{i}^{*},\cdots ,\mathbf {b} _{n}^{*}} {\displaystyle \mathbf {b} _{i}^{*},\cdots ,\mathbf {b} _{n}^{*}}.

Then the basis B {\displaystyle B} {\displaystyle B} is KZ-reduced if the following holds:

  1. b i {\displaystyle \mathbf {b} _{i}^{*}} {\displaystyle \mathbf {b} _{i}^{*}} is the shortest nonzero vector in π i ( L ( B ) ) {\displaystyle \pi _{i}({\mathcal {L}}(\mathbf {B} ))} {\displaystyle \pi _{i}({\mathcal {L}}(\mathbf {B} ))}
  2. For all j < i {\displaystyle j<i} {\displaystyle j<i}, | μ i , j | 1 / 2 {\displaystyle \left|\mu _{i,j}\right|\leq 1/2} {\displaystyle \left|\mu _{i,j}\right|\leq 1/2}

Note that the first condition can be reformulated recursively as stating that b 1 {\displaystyle \mathbf {b} _{1}} {\displaystyle \mathbf {b} _{1}} is a shortest vector in the lattice, and { π 2 ( b 2 ) , π 2 ( b n ) } {\displaystyle \{\pi _{2}(\mathbf {b} _{2}),\cdots \pi _{2}(\mathbf {b} _{n})\}} {\displaystyle \{\pi _{2}(\mathbf {b} _{2}),\cdots \pi _{2}(\mathbf {b} _{n})\}} is a KZ-reduced basis for the lattice π 2 ( L ( B ) ) {\displaystyle \pi _{2}({\mathcal {L}}(\mathbf {B} ))} {\displaystyle \pi _{2}({\mathcal {L}}(\mathbf {B} ))}.

Also note that the second condition guarantees that the reduced basis is length-reduced (adding an integer multiple of one basis vector to another will not decrease its length); the same condition is used in the LLL reduction.

Notes

[edit ]
  1. ^ https://sites.math.washington.edu/~rothvoss/lecturenotes/IntOpt-and-Lattices.pdf, pp. 18-19
  2. ^ Zhang et al 2012, p.1
  3. ^ Yasuda, Masaya (2021). "A Survey of Solving SVP Algorithms and Recent Strategies for Solving the SVP Challenge". International Symposium on Mathematics, Quantum Theory, and Cryptography. Mathematics for Industry. Vol. 33. pp. 189–207. doi:10.1007/978-981-15-5191-8_15. ISBN 978-981-15-5190-1. S2CID 226333525.
  4. ^ Micciancio & Goldwasser, p.133, definition 7.8


References

[edit ]


Primality tests
Prime-generating
Integer factorization
Multiplication
Euclidean division
Discrete logarithm
Greatest common divisor
Modular square root
Other algorithms
  • Italics indicate that algorithm is for numbers of special forms

AltStyle によって変換されたページ (->オリジナル) /