- Berlekamp-Algorithmus
-
In der Computeralgebra, einem Teilgebiet der Mathematik, ist der Berlekamp-Algorithmus eine Methode zur Faktorisierung von Polynomen über einem endlichen Körper, die 1967 von Elwyn Berlekamp entwickelt wurde. Er ist in den meisten Computeralgebrasystemen implementiert und war der führende Faktorisierungsalgorithmus bis zur Entwicklung des Cantor-Zassenhaus-Algorithmus, einer probabilistischen Variante des Berlekamp-Algorithmus aus dem Jahre 1981.
Inhaltsverzeichnis
Hintergrund
Gesucht ist eine Faktorisierung von
mit deg P(x) = n in irreduzible Faktoren
wobei die Größe r unbekannt ist und auch eins sein kann, wenn P(x) irreduzibel ist. Dabei kann man ohne Beschränkung der Allgemeinheit annehmen, dass P(x) quadratfrei ist, weil quadratfreie Polynome P(x) die Eigenschaft
erfüllen und bei nicht quadratfreien Polynomen auf diese Weise bereits ein echter Teiler gefunden wird. (P'(x) bezeichnet hier die formale Ableitung nach x und
den größten gemeinsamen Teiler.)Um die pi zu bestimmen, bedient man sich eines leichter zu faktorisierenden Polynoms
, das von P(x) geteilt wird, denn dann giltDa
ein endlicher Körper ist, kann man in der Identität
X durch b(x) ersetzen und erhält
.Weil G(x) durch P(x) teilbar ist, sucht man also b(x), die die Kongruenz
erfüllen.Man kann nun beweisen, dass alle diese b(x) Eigenvektoren einer
Matrix
zum Eigenwert 1 sind, wobei die qk,l gegeben sind durch die Kongruenzen:
.
Denn dann gilt:
.Man bestimmt also alle Eigenvektoren b(j) von
und erhält dann die pi(x), indem man für alle
und für alle Eigenvektoren b(j)
berechnet. Dabei kann man zum einen den trivialen Eigenvektor
auslassen und zum anderen die Berechnungen beenden, wenn man
verschiedene Faktoren gefunden hat.Algorithmus
Der Algorithmus kann also wie folgt zusammengefasst werden:
- Man berechnet
, indem man für
jeweils
reduziert. - Man bestimmt die Eigenvektoren b(j) von
. - Solange noch nicht alle
Faktoren von P(x) bestimmt sind, berechne für alle
und für alle 
.
Anwendung
Eine wichtige Anwendung des Berlekamp-Algorithmus ist die Berechnung des diskreten Logarithmus über einem endlichen Körper
mit Primzahl p und
, was eine große Bedeutung in der Public Key Cryptography hat. In einem endlichen Körper ist die schnellste Methode zur Berechnung des diskreten Logarithmus der Index-Calculus-Algorithmus, bei dem Körperelemente faktorisiert werden. Da
isomorph ist zu einem Polynomring über
, faktorisiert nach einem irreduziblen Polynom vom Grad n, entspricht die Faktorisierung der Körperelemente in
der Faktorisierung von Polynomen in einem Polynomring über
, faktorisiert nach einem irreduziblen Polynom vom Grad n. Diese kann dann mit dem Berlekamp-Algorithmus durchgeführt werden.Siehe auch
- Faktorisierung von Polynomen
- Cantor-Zassenhaus-Algorithmus
Quellen
- Atilla Pethö; Michael Pohst (Hrsg.): Algebraische Algorithmen. Vieweg, 1999, ISBN 9783528065980, S. 183.
- Michael Kaplan: Computeralgebra. Springer, 2005, ISBN 3540213791, S. 239.
- Elwyn R. Berlekamp: Factoring Polynomials Over Finite Fields. Bell System Technical Journal, Band 46, 1967, Seiten 1853-1859 bzw. in: Elwyn R. Berlekamp: Algebraic Coding Theory. Mc-Graw Hill, 1968.
Wikimedia Foundation.
