Rabin-Fingerprint

Verfahren zur Berechnung eines Hashwerts

Der Rabin-Fingerprint ist ein Verfahren zur Berechnung eines Fingerprints. Es wurde von Michael O. Rabin vorgeschlagen.[1]

Motivation

Bearbeiten

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   modulo eines irreduziblen Polynoms mit Koeffizienten in   beruht.

Verschlüsselt werden soll ein String   aus Nullen und Einsen mit  . Dieser wird als Polynom   mit Koeffizienten in   aufgefasst, das Eingabe-Polynom  .

Für die Berechnung wird ein Schlüssel  , ebenfalls aus  , benötigt. Bei   soll es sich um ein irreduzibles Polynom handeln.

Die Rabin-Fingerprintfunktion   ist als

 

definiert.

Verwendung

Bearbeiten

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.[2]

Bearbeiten

Einzelnachweise

Bearbeiten
  1. Michael O. Rabin: Fingerprinting by Random Polynomials. Center for Research in Computing Technology, Harvard University, 1981 (englisch, xmailserver.org [PDF; 465 kB; abgerufen am 9. Dezember 2014]).
  2. 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 (englisch).