Rabin-Fingerprint
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>