Zum Inhalt springen

Rabin-Fingerprint

aus Wikipedia, der freien Enzyklopädie
Dies ist die aktuelle Version dieser Seite, zuletzt bearbeitet am 20. Juli 2021 um 06:09 Uhr durch imported>회기-로 (Methode).
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)

Der Rabin-Fingerprint ist ein Verfahren zur Berechnung eines Fingerprints. Es wurde von Michael O. Rabin vorgeschlagen.<ref name="rabin1981" />

Motivation

Fingerprints sind kurze Etiketten für große Objekte. Unterschiedliche Fingerprints sollen unterschiedlichen Objekten entsprechen und unterschiedliche Objekte sollen nur mit geringer Wahrscheinlichkeit denselben Fingerprint haben.

Der Rabin-Fingerprint ist ein spezielles Verfahren, das auf der Arithmetik in <math>\Z_2\left[x\right]</math> modulo eines irreduziblen Polynoms mit Koeffizienten in <math>\Z_2</math> beruht.

Methode

Verschlüsselt werden soll ein String <math>(a_1,\ldots,a_m)</math> aus Nullen und Einsen mit <math>a_1=1</math>. Dieser wird als Polynom <math>a_1t^{m-1}+\ldots+a_2t^{m-2}+\ldots+a_m</math> mit Koeffizienten in <math>\Z_2</math> aufgefasst, das Eingabe-Polynom <math>A(x)</math>.

Für die Berechnung wird ein Schlüssel <math>P(x)</math>, ebenfalls aus <math>\mathbb{Z}_2[x]</math>, benötigt. Bei <math>P(x)</math> soll es sich um ein irreduzibles Polynom handeln.

Die Rabin-Fingerprintfunktion <math>f</math> ist als

<math>f(A)(x) = A(x) \mod P(x)</math>

definiert.

Verwendung

Besonders geeignet ist der Rabin-Fingerprint beim Einsatz zur Erkennung von identischen oder ähnlichen Abschnitten in unterschiedlichen Dateien, d. h. zur Erkennung von Redundanz. Diese kann dann zum Beispiel zur Optimierung von Dateitransferprozessen oder bei der Archivierung von Daten genutzt werden. So benutzt etwa das am Massachusetts Institute of Technology entwickelte Dateisystem LBFS (Low-Bandwidth File System) den Rabin-Fingerprint.<ref name="kulkarni:usenix2004" />

Weblinks

Einzelnachweise

<references> <ref name="rabin1981"> </ref> <ref name="kulkarni:usenix2004"> Purushottam Kulkarni, Fred Douglis, Jason D. LaVoie, John M. Tracey: Redundancy Elimination Within Large Collections of Files. In: USENIX Annual Technical Conference, General Track. 12. Mai 2004, S. 59–72, abgerufen am 21. Februar 2015 (Lua-Fehler in Modul:Multilingual, Zeile 153: attempt to index field 'data' (a nil value)). </ref> </references>