- Quadratisches Sieb
-
Quadratisches Sieb ist ein Begriff aus dem Bereich Zahlentheorie der Mathematik und bezeichnet einen der schnellsten bekannten Algorithmen zur Faktorisierung großer natürlicher Zahlen. Es ist ein allgemeines Faktorisierungsverfahren, d.h. die Laufzeit hängt nur von der Größe der zu faktorisierenden Zahl ab und nicht von speziellen Eigenschaften der Zahl (bzw. ihrer Teiler). Für Zahlen mit bis ca. 100 Dezimalstellen ist es das schnellste (allgemeine) Faktorisierungsverfahren. Für größere Zahlen ist das Zahlkörpersieb schneller. Die Laufzeit zum Faktorisieren einer Zahl n mit dem quadratischen Sieb ist (unter einigen als wahrscheinlich geltenden Annahmen) in der Größenordnung von[1]
Inhaltsverzeichnis
Entstehungsgeschichte
Aufbauend auf der Kettenbruchmethode von John Brillhart und Michael Morrison sowie inspiriert durch das lineare Sieb von Richard Schroeppel erfand Carl Pomerance 1981 durch theoretische Überlegungen das Quadratische Sieb, welches schneller war als alle bis dahin bekannten Faktorisierungsverfahren.
Kurz darauf fanden James Davis und Diane Holdridge bzw. Peter Montgomery unabhängig voneinander eine Variante des Quadratischen Siebs mit mehrfachen Polynomen (genannt MPQS). Eine andere Verbesserung, das sogenannte spezielle quadratische Sieb, stammt von M. Zhang, welches aber nur auf spezielle Zahlen angewandt werden kann.
1994 gelang es, mit Hilfe des Quadratischen Siebs die 129-stellige Zahl RSA-129 zu faktorisieren.
Mehr zur Geschichte des Quadratischen Siebs findet sich im Artikel Geschichte der Faktorisierungsverfahren.
Funktionsweise
Wie die meisten modernen Faktorisierungsverfahren benutzt das Quadratische Sieb die Darstellung eines Produkts als Differenz von Quadraten. Auf Grund der 3. Binomischen Formel gilt:
Anstatt also die Teilbarkeit von Zahlen zu untersuchen, sucht man eine Darstellung der Zahl als Differenz von Quadraten. Aus einer Darstellung x2 − n = y2 erhält man die Teiler x + y sowie x − y von n.
Bei der Faktorisierungsmethode von Fermat berechnet man den Wert q(x) = x2 − n für verschiedene Zahlen x, bis man ein q(x) erhält, das eine Quadratzahl ist. Als erstes x wählt man die kleinste Zahl, die größer als die Wurzel von n ist. Anschließend zählt man x in jedem Schritt um eins hoch. Wendet man dieses Verfahren beispielsweise zur Faktorisierung der Zahl 1649 an, so erhält man für q(x) die Werte in der folgenden Tabelle.
x q(x) = x2 − n Primfaktorzerlegung von q(x) 41 32 25 42 115 5 · 23 43 200 23 · 52 ... 57 1600 402 Die Faktorisierungsmethode von Fermat gelangt nach 16 Schritten zum Ziel und kann dann anhand der Zahl x = 57 und des Quadrats q(x) = 402 die Faktorisierung von 1649 berechnen:
Wenn wir die Funktionswerte zu x = 41 und x = 43 miteinander multiplizieren, erhalten wir das Quadrat 25 · 23 · 52 = 28 · 52 = (24 · 5)2. Wir würden dieses Quadrat gerne für eine Zerlegung nutzen. Die Gleichungen können jedoch nicht ohne weiteres multipliziert werden. Maurice Kraitchik erweiterte die Darstellung von Fermat. Er betrachtete Gleichungen, in denen x2 − y2 ein Vielfaches von n ist:
Falls n | (x + y)(x − y), aber n weder x+y noch x-y teilt, dann gilt ggT (x + y,n) > 1 und ggT (x + y,n) ist ein nichttrivialer Teiler von n. Anstatt der Gleichung q(x) = x2 − n betrachten wir folgende Kongruenzen:
Diese Kongruenzen können nun multipliziert werden. Wir multiplizieren die Kongruenzen zu x=41
und x=43
- zu folgender Kongruenz
- .
Wir haben folgende quadratische Kongruenz gefunden:
- .
Mit ggT (41 · 43-80, 1649) = 17 und ggT (41 · 43+80, 1649) = 97 haben wir 1649 = 17 · 97 in seine Faktoren zerlegt. Nicht jede quadratische Kongruenz liefert echte Teiler, aber im Schnitt liefert jede zweite quadratische Kongruenz eine echte Faktorisierung. Man muss nun viel weniger Funktionswerte von q(x) betrachten, um ein Quadrat und damit eine Zerlegung zu erhalten. Wie kann man effizient bestimmen, welche Funktionswerte sich zu einem Quadrat aufmultiplizieren? Falls man die Primfaktorzerlegung der Zahlen q(x) kennt, wird die Multiplikation dieser Zahlen zur Addition der Exponenten ihrer Primfaktorzerlegung. Man betrachtet deswegen nur Zahlen q(x), deren Primfaktorzerlegung aus vorher festgelegten Faktoren bestehen. Eine Kongruenz ist genau dann ein Quadrat, wenn die Exponenten der Primfaktorzerlegung gerade sind. Unter diesen Einschränkungen kann man die Kongruenzen, die sich zu einem Quadrat multiplizieren, mittels Methoden aus der linearen Algebra bestimmen.
Im Allgemeinen sucht man in einer ersten Phase nach Kongruenzen. Hat man ausreichend viele gefunden, wird eine Teilmenge von Kongruenzen gesucht, die, miteinander multipliziert, auf beiden Seiten ein Quadrat ergeben.
Betrachten wir dazu ein weiteres Beispiel. Gesucht ist die Primfaktorzerlegung von n=87463. Wir wollen nur Zahlen x2 − n betrachten, die aus kleinen Faktoren bestehen. Sei der größte Primfaktor 29. Da für p = 5,7,11 und 23 keine Lösung hat kommen diese Zahlen niemals als Teiler von x2 − n vor. Die sogenannte Faktorbasis, in der alle möglichen Faktoren der Primfaktorzerlegung vorkommen, besteht also aus den Primzahlen 2,3,13,17,19,29. Die Matrix der Exponenten der Primfaktorzerlegung mod 2 sieht wie folgt aus:
x q(x) = x2-n Primfaktorzerlegung Primfaktorzerlegung mod 2 -1 2 3 13 17 19 29 -1 2 3 13 17 19 29 265 -1 · 2 · 3 · 132 · 17 1 1 1 2 1 0 0 1 1 1 0 1 0 0 278 -1 · 33 · 13 · 29 1 0 3 1 0 0 1 1 0 1 1 0 0 1 296 32 · 17 0 0 2 0 1 0 0 0 0 0 0 1 0 0 299 2 · 3 · 17 · 19 0 1 1 0 1 1 0 0 1 1 0 1 1 0 307 2 · 32 · 13 · 29 0 1 2 1 0 0 1 0 1 0 1 0 0 1 316 36 · 17 0 0 6 0 1 0 0 0 0 0 0 1 0 0 Gesucht ist eine Linearkombination der Zeilen, die den Nullvektor ergeben. Eine Lösung besteht aus Zeile 3 und Zeile 6.
ggT (x-y,n) = 587, ggT (x+y , n) = 149. Damit erhalten wir die Faktorisierung 87463 = 587 · 149.
Diese Grundidee wird auch in Dixons Sieb verwendet, wo man zufällige Werte für x verwendet. Im Quadratischen Sieb betrachtet man aufeinanderfolgende Werte x, von denen man die Primfaktorzerlegung schnell bestimmen kann. Das Bestimmen solcher nützlicher Kongruenzen nennt man Sieben. Der Algorithmus lässt sich in zwei Schritte aufteilen:
- der Siebschritt, bei dem Kongruenzen der Form x2 = q (mod n) gesucht werden, und
- der Auswahlschritt, bei dem aus diesen Kongruenzen geeignete ausgewählt werden, aus denen sich durch Multiplikation eine quadratische Kongruenz ergibt.
Siebschritt
Im Siebschritt werden Kongruenzen der Form
gesucht, wobei die Primfaktorzerlegung von q bekannt ist und nur aus kleinen Primzahlen besteht (in anderen Worten: q soll bezüglich einer festen Schranke glatt sein). Man wählt die Zahlen x in der Nähe der Wurzel von n, damit sind die Werte q(x): = x2 − n klein. Die Wahrscheinlichkeit, glatte Zahlen q(x) zu finden, ist damit hoch. Das Bestimmen der Primfaktorzerlegung durch Probedivision ist zeitintensiv. Um effizient zu überprüfen, ob eine Zahl glatt ist, benutzt man folgende Eigenschaft:
Wenn man also Stellen x gefunden hat, bei denen q(x) durch p teilbar ist, kann man eine ganze Sequenz von q(x + kp) bestimmen, die durch p teilbar sind. p teilt q(x) = x2 − n genau dann, wenn . Das Bestimmen der Quadratischen Wurzeln modulo einer Primzahl ist effizient lösbar (etwa mittels des Shanks-Tonelli Algorithmus). Die Sequenz der ebenfalls durch p teilbaren Zahlen wird mit einem Siebverfahren ähnlich dem des Sieb des Eratosthenes bestimmt. Das Quadratische Sieb leitet seinen Namen vom Lösen der 'Quadratischen' Gleichung und dem 'Sieben' der Teiler ab.
Im Prinzip geht man wie folgt vor:
Schritt 1: Wahl einer Faktorbasis.
Nimm alle Primzahlen p bis zu einer Schranke S, für die n quadratischer Rest ist, d.h. die Gleichung x2 = n (mod p) lösbar ist. Zahlen, für die n quadratischer Nichtrest ist, können ausgeschlossen werden, da sie nicht als Teiler von x2-n auftreten. Je größer die Schranke gewählt wird, umso größer die Wahrscheinlichkeit, dass x2-n nur aus Primfaktoren bis zu dieser Schranke besteht. Der Nachteil ist, dass wir mehr Relationen brauchen um das resultierende Gleichungssystem zu lösen. Wird die Schranke zu klein gewählt, zerfallen nur sehr wenige Zahlen wie gewünscht und wir müssen viele Zahlen betrachten.
Deshalb wählt man die Schranke S in der Größenordnung von
Schritt 2: Siebe mit den Faktoren der Faktorbasis.
Wähle ein Siebintervall in der Größenordnung von
- .
Für die Zahlen x mit |x - √n| < L fertige eine Liste mit den Werten q(x): = x2 − n an. Bestimme die (zwei) Lösungen von q(t)=0 mod p für alle Faktoren p der Faktorbasis. Teile alle Zahlen innerhalb eines gewählten Siebintervalls durch p (sowie p2, p3, ..). Die Zahlen, bei denen am Ende eine 1 übrig bleibt, sind glatt bezüglich der Faktorbasis und damit die gesuchten Werte.
Die zu untersuchenden Zahlen q(x) sind in der Größenordnung von n. Divisionen auf diesen Zahlen sind teuer (für typische n sind diese nicht mehr in hardwarenahen Formaten speicherbar). Da das Sieben laufzeitkritisch ist, modifiziert man Schritt 2. Man speichert nicht die Zahlen q(x) selbst, sondern deren auf ganze Zahlen gerundete Logarithmen (bzw. n als obere Schranke für q(x)). Diese kleinen Zahlen können mit primitiven Datentypen behandelt werden. Aus der Division durch einen Teiler p wird eine Subtraktion mit dem Logarithmus von p. Aus Geschwindigkeitsgründen verzichtet man in der Praxis auch auf das Sieben mit Potenzen der Faktoren.
Man schätzt die Rechenfehler (und das Ignorieren mehrfacher Teiler) durch eine Schranke T in der Größenordnung des Logarithmus des größten Faktors der Faktorbasis ab. Die Zahlen aus der Liste, die nach dem Sieben kleiner als T sind, sind mit hoher Wahrscheinlichkeit glatt und werden in einer Liste vermerkt. Nicht alle in der Liste vermerkten Zahlen sind notwendigerweise glatt. In einem zusätzlichen Schritt wird die Primfaktorzerlegung dieser Zahlen bestimmt und vermerkt, ob die Zahl glatt ist oder nicht.
Das Bestimmen der Primfaktorzerlegung der wahrscheinlich glatten Zahlen über der Faktorbasis kann man mit einem Faktorisierungsverfahren erledigen, das für Faktoren dieser Größe geeignet ist. Für kleine Faktoren bietet sich die Pollard-Rho-Methode an. Eine andere Methode besteht darin, ein zweites Mal zu sieben. Trifft man dabei auf eine wahrscheinlich glatte Zahl, so teilt man diese durch den Faktor, mit dem man siebt, bzw. deren Potenzen. Da die Trefferrate für große Faktoren gering ist, bietet sich dies für die größeren Faktoren der Faktorbasis an. Das Sieben kann weiter beschleunigt werden, wenn man den ggT der zu testenden Zahl mit dem Produkt der Faktoren der Faktorbasis bestimmt.
Auswahlschritt
Zu einer (glatten) Kongruenz x2 = q(mod n) besteht q nur aus Faktoren der Faktorbasis. q kann vollständig als Vektor der Exponenten seiner bekannten Primfaktorzerlegung beschrieben werden. Zu den Exponentenvektoren der Kongruenzen stellt man ein lineares Gleichungssystem über dem endlichen Körper F2 auf, bei dem jede Zeile aus dem Exponentenvektor einer Kongruenz modulo 2 besteht. Eine Zahl ist genau dann ein Quadrat, wenn alle Exponenten ihrer Primfaktorzerlegung gerade sind. Falls man also eine nichttriviale Linearkombination von Zeilen findet, die den Nullvektor ergeben, hat man auch eine quadratische Kongruenz gefunden. Diese liefert durch Berechnung von ggT(u-v,n) einen Faktor von n, der in mindestens der Hälfte aller Fälle weder 1 noch n ist.
Zur Lösung dieses Schritts verwendet man Verfahren der linearen Algebra, wie das gaußsche Eliminationsverfahren, das Verfahren der konjugierten Gradienten oder das Lanczos-Verfahren. Das Block Lanczos-Verfahren, eine Erweiterung des Lanczos-Verfahrens kann solche großen - aber sehr dünn besetzten - Matrizen in einem Bruchteil des Siebschritts Platz sparend (linear in der Anzahl der Zeilen) lösen [2].
Einsatzbereich
Das Quadratische Sieb eignet sich für große Zahlen bis etwa 110 Dezimalstellen, die keine Primpotenz sind. Für größere Zahlen ist das Zahlkörpersieb besser geeignet.
1994 wurde die Zahl RSA-129 mit dem Multiple Polynomial Quadratic Sieve unter Ausnutzung partieller Relationen faktorisiert. Diese Zahl mit 129 Dezimalstellen wurde in ihre zwei Teiler (einer mit 64, der andere mit 65 Dezimalstellen) zerlegt. Der Siebschritt wurde verteilt von 600 Freiwilligen ausgeführt. Diese sammelten 8 Monate lang Kongruenzen, die per E-Mail (oder ftp) an den zentralen Rechner übermittelt wurden. Der Auswahlschritt auf den 298 GB Daten wurde in 45 Stunden auf einem Supercomputer ausgeführt. Die Faktorbasis umfasste 524338 Primzahlen, die Matrix hatte eine Größe von 569466 Zeilen und 524338 Spalten.
Alle weiteren Faktorisierungsrekorde wurden mit dem Zahlkörpersieb aufgestellt.
Misst man die Laufzeit des Algorithmus bezüglich der Länge N = log(n) der Eingabe n, so kann man die Laufzeit des Quadratischen Siebs so schreiben:
Für α = 1 ergibt sich ein exponentielles Wachstum. Die Probedivison hat ein solches Laufzeitverhalten für c = 1 / 2. Mit α = 0 ergäbe sich ein polynomieller Algorithmus mit Laufzeit . Es handelt sich beim Quadratischen Sieb also um einen Algorithmus mit einer superpolynomialen, aber subexponentiellen Laufzeit. Beim Zahlenkörpersieb konnte die Konstante α auf 1/3 reduziert werden. Allerdings ist c, das die Laufzeit asymptotisch weniger beeinflusst als α, dort wesentlich größer. Es gibt Verbesserungen der Grundidee des Quadratischen Siebs, die die Laufzeit weiter reduzieren:
Partielle Relationen
Selbst Relationen, die nicht glatt sind, können zu (glatten) Relationen kombiniert werden, die für den Auswahlschritt brauchbar sind. Hat man zwei partielle Relationen, deren Primfaktorzerlegung einen Faktor P (außerhalb der Faktorbasis) enthalten
so ergeben diese eine Kongruenz
Durch Multiplikation mit P-2 erhält man sogar folgende glatte Relation
Bei der vorletzten Relation stammen alle Faktoren mit ungeraden Exponenten aus der Faktorbasis. Diese Relation kann somit für den Auswahlschritt verwendet werden. Wenn man den Faktor P in der Größe begrenzt, kann man ihn mit einem geringen Mehraufwand bestimmen: Man erhöht die Schranke T für die interessanten Zahlen im Siebschritt um log (P). Der Faktor P bleibt beim Bestimmen der Primfaktorzerlegung durch das Teilen mit Faktoren der Faktorbasis schließlich übrig. Durch partielle Relationen kann man die für den Auswahlschritt brauchbaren Relationen erhöhen. Die Laufzeit kann damit halbiert werden[3].
Mehrfache Polynome
Die Größe der erzeugten Zahlen beim Quadratischen Sieb steigt linear mit der Entfernung zur Nullstelle an. Beim Multiple Polynomial Quadratic Sieve (MPQS) definiert man verschiedene (möglichst disjunkte) Funktionen, die jeweils einen festen Faktor enthalten, und dasselbe Wachstum zeigen. Das Suchintervall kann auf mehrere Polynome aufgeteilt werden. Damit sind die auf Teiler zu untersuchenden Zahlen kleiner und die Wahrscheinlichkeit eine glatte Zahl zu erzeugen steigt.
Man modifiziert die Funktion q(x) = x2 − n, indem man anstelle von x nun ein Polynom ersten Grades verwendet.
Das Multiple Polynomial Quadratic Sieve betrachtet anstelle der Gleichung q(x) = x2 − n nun eine Menge von Polynomen
- qa(x) = (ax + b)2 − n = (ax)2 + 2abx + b2 − n
Dabei wird b so gewählt dass b2 − n durch a teilbar ist (b2 − n = ac). Damit gilt
und der hiermit erzeugte Wert qa(x) enthält a als Faktor.
Der Siebvorgang funktioniert ähnlich wie beim normalen Quadratischen Sieb, allerdings muss zu jedem Faktor p der Faktorbasis das multiplikative Inverse von a mod p berechnet werden. Wichtig ist dass der Wechsel zwischen zwei Polynomen (mit verschiedenen Werten für a) nicht zu viel Zeit verschlingt. Das Invertieren von a (etwa mit dem erweiterteren euklidischen Algorithmus) lässt sich in linearer Laufzeit bewerkstelligen, trotzdem benötigt dieses Wechseln des Polynoms einen großen Anteil an der Gesamtrechenzeit.
Beim Multiple Polynomial Quadratic Sieve (MPQS) wählt man a als Quadrat einer Primzahl. Damit hat die Gleichung b^2 = n mod a für b genau zwei Lösungen und ist effizient bestimmbar. Das Verfahren wurde 1983 von J.A.Davis und D.B.Holdridge entwickelt.
Beim Self Initializing Quadratic Sieve (SIQS) wird a als Produkt von Faktoren der Faktorbasis gewählt. Dadurch existieren zu einem a mehr Werte für b als beim MPQS. Um die gleiche Anzahl an zu untersuchenden Zahlen (in der gleichen Größenordnung) zu erhalten, muss man nun weniger Werte für a untersuchen. Damit müssen insgesamt weniger multiplikative Inverse berechnet werden. Somit ist das SIQS schneller als das MPQS. Dieses Verfahren wurde von René Peralta sowie W. R. Alford und Carl Pomerance 1995 entdeckt.
Implementierungen
- msieve, eine Implementierung des Multiple Polynomial Quadratic Sieve mit Unterstützung von partiellen Relationen. Geschrieben von Jason Papadopoulos.
- YAFU, von Ben Buhrow, ist wohl die schnellste Implementierung des Self Initializing Quadratic Sieve.
- Faktorisierungs Applet von Dario Alpern. Eine Java-Implementierung des SIQS.
Literatur
- Carl Pomerance: A Tale of Two Sieves, Notices of the AMS, 43 (1996) 1473-1485 (Webversion: http://www.ams.org/notices/199612/pomerance.pdf )
- Richard Crandall, Carl Pomerance: Prime Numbers, A Computational Perspective, Springer, 2001, ISBN 0-387-94777-9
- Arjen K. Lenstra, Mark S. Manasse: Factoring With Two Large Primes. EUROCRYPT 1990: 72-82
- James A. Davis, Diane B. Holdridge: Factorization Using the Quadratic Sieve Algorithm. CRYPTO 1983: 103-113
Weblinks
- http://www.mi.uni-erlangen.de/~ruppert/WS0607/Seminar/Kaiser/Faktorisierung_mit_dem_quadratischen_Sieb.pdf Seminararbeit zur Faktorisierung mit dem Quadratischen Sieb von Markus Kaiser (PDF-Datei; 142 kB)
- http://www.crypto-world.com/documents/contini_siqs.pdf - Detaillierte Beschreibung des (Self Initializing) Quadratic Sieves von Scott Patrick Contini (englisch).
- http://www.karlin.mff.cuni.cz/~krypto/mpqs/main_file.pdf Beschreibung des (Self Initializing) Quadratic Sieves von Marian Kechlibar (englisch). (PDF-Datei; 392 kB)
- http://www.alpertron.com.ar/ECM.HTM - Ein Java Applet zur Faktorisierung von Zahlen (verwendet auch das Self Initializing Quadratic Sieve)
- http://www.math.uiuc.edu/~landquis/quadsieve.pdf Überblick über das Quadratische Sieb von Eric Landquist (englisch). (PDF-Datei; 123 kB)
- http://www.informatik.tu-darmstadt.de/KP/theses/Katja_Schmidt-Samoa.diplom.pdf - Grundlagen moderner Faktorisierungsverfahren und Laufzeitanalyse von Katja Schmidt-Samoa. (PDF-Datei; 1,16 MB)
- http://www.math.colostate.edu/~hulpke/lectures/m400c/quadsievex.pdf Demonstration des Quadratische Siebs am Beispiel der Zahl 87463 (englisch). (PDF-Datei; 50 kB)
- http://www.cdc.informatik.tu-darmstadt.de/reports/reports/gross.diplom.ps.gz - Der Block Lanczos Algorithmus über GF(2) von Olaf Gross.
Einzelnachweise
- ↑ Carl Pomerance: A Tale of Two Sieves. In: Notices of the AMS. 43, Nr. 12, 1996, S. 1473–1485 (http://www.ams.org/notices/199612/pomerance.pdf). S. 1478
- ↑ Der Block Lanczos Algorithmus über GF(2) von Olaf Gross http://www.informatik.tu-darmstadt.de/ftp/pub/TI/reports/gross.diplom.ps.gz
- ↑ Arjen K. Lenstra, Mark S. Manasse: Factoring With Two Large Primes. EUROCRYPT 1990: 72-82
Wikimedia Foundation.