Datenstromalgorithmus
In der Informatik ist ein Datenstromalgorithmus ein Algorithmus, der die Daten eines oder mehrerer Datenströme sequenziell liest und dabei direkt („online“) verarbeitet.
Anwendung
[Bearbeiten | Quelltext bearbeiten]Viele heutige Anwendungen in der Informatik machen auf Grund der extrem großen, kontinuierlich angelieferten Datenmenge, die Verarbeitung eines Datenstroms erforderlich. Dies ist beispielsweise bei der Erfassung von Routingdaten in Netzwerken, bei Aufzeichnungen von Telekommunikationsdaten, bei Banktransaktionen oder bei Börsentickern der Fall.
Mathematische Sichtweise und Effizienzanforderungen
[Bearbeiten | Quelltext bearbeiten]Man modelliert die kontinuierlich anfallenden Daten als Strom – eine Folge von Eingabezeichen, deren Länge häufig unbekannt ist, aber als sehr groß angenommen wird.
Ein den Strom verarbeitender Algorithmus darf nur Zeichen für Zeichen des Stromes lesen, wahlfreier Zugriff (random access), d. h. ein „Springen“ auf den Eingabezeichen, ist nicht erlaubt.
Im Datenstromszenario werden wegen der Menge der anfallenden Daten im Wesentlichen zwei Effizienzforderungen gestellt: Die Speicherplatzkomplexität des Datenstromalgorithmus soll sublinear, idealerweise logarithmisch oder polylogarithmisch sein, ebenso wie die Rechenzeit pro Eingabezeichen.
Gewisse Probleme lassen sich also mit Datenstromalgorithmen exakt lösen, da die gesamte Eingabe gelesen werden darf. Trotzdem sind sublinearer Speicherplatz und sublineare Rechenzeit pro Eingabezeichen Effizienzanforderungen, die häufig dazu führen, dass dies eben nicht möglich ist und nur approximative Lösungen gegeben werden können und Randomisierung eingesetzt werden muss.
Denn ein Datenstromalgorithmus darf wegen des nur sublinearen Speicherplatzes nicht die gesamte Eingabe speichern, sondern nur eine Zusammenfassung des bisher Gesehenen. Man sagt, der Algorithmus speichert eine Skizze (Sketch) der bisher gesehenen Eingabe.
Im folgenden Beispiel wird ein Algorithmus vorgestellt, der das gegebene Problem exakt lösen kann.
Beispiele
[Bearbeiten | Quelltext bearbeiten]Anzahl der Elemente
[Bearbeiten | Quelltext bearbeiten]Die Anzahl der Elemente in einem Datenstrom kann einfach mit einem Zähler ermittelt werden. Mit randomisierten Algorithmen lässt sich der Speicherbedarf dabei weiter verringern.
Fehlende Zahl
[Bearbeiten | Quelltext bearbeiten]Sei eine Permutation der Zahlenmenge mit einem fehlenden Element .
Eine einfache Methode zur Bestimmung der fehlenden Zahl wäre, alle Zahlen zu sammeln, zu sortieren und diese geordnete Menge dann der Reihe nach auf das fehlende Element zu durchsuchen. Dazu müssten aber wie beschrieben alle Zahlen gespeichert werden. Der Speicherverbrauch dieses Algorithmus beträgt dann Bytes, wenn angenommen wird, dass jede Zahl als 32-Bit Integer gespeichert wird. So müsste man bspw. für ca. 3,7 GB speichern. Um eine angemessene Performanz zu erreichen, müssten dabei diese Daten im Arbeitsspeicher abgelegt werden, doch dies ist aufgrund des großen Datenvolumens bei den meisten PCs nicht möglich. Somit müsste auf die Festplatte zurückgegriffen werden, was jedoch diesen Algorithmus extrem verlangsamt.
Wären alle Zahlen im Datenstrom enthalten, so wäre die Summe der Elemente des Stromes gemäß der Gaußschen Summenformel
- .
Bildet man daher die Summe der im Strom enthaltenen Elemente in , so kann man nach Lesen der gesamten Eingabe die gesuchte Zahl mit
bestimmen. Dieser Algorithmus muss zur Berechnung der Summe und zur anschließenden Bestimmung von nur eine Zahl speichern und der Speicherplatz beträgt damit nur . Er ist damit ganz offensichtlich effizienter.