DCN - Fehlererkennung und -korrektur
Es gibt viele Gründe wie Rauschen, Übersprechen usw., die dazu beitragen können, dass Daten während der Übertragung beschädigt werden. Die oberen Schichten arbeiten mit einer verallgemeinerten Ansicht der Netzwerkarchitektur und sind sich der tatsächlichen Hardware-Datenverarbeitung nicht bewusst. Daher erwarten die oberen Schichten eine fehlerfreie Übertragung zwischen den Systemen. Die meisten Anwendungen würden nicht erwartungsgemäß funktionieren, wenn sie fehlerhafte Daten empfangen. Anwendungen wie Sprache und Video sind möglicherweise nicht so betroffen, und mit einigen Fehlern funktionieren sie möglicherweise immer noch gut.
Die Datenverbindungsschicht verwendet einen Fehlerkontrollmechanismus, um sicherzustellen, dass Rahmen (Datenbitströme) mit einer bestimmten Genauigkeit übertragen werden. Um zu verstehen, wie Fehler kontrolliert werden, ist es wichtig zu wissen, welche Arten von Fehlern auftreten können.
Arten von Fehlern
Es kann drei Arten von Fehlern geben:
Single bit error
In einem Frame gibt es jedoch überall nur ein Bit, das beschädigt ist.
Multiple bits error
Der Rahmen wird mit mehr als einem Bit im beschädigten Zustand empfangen.
Burst error
Der Frame enthält mehr als 1 aufeinanderfolgende beschädigte Bits.
Der Fehlerkontrollmechanismus kann zwei Möglichkeiten umfassen:
Fehlererkennung
Fehler Korrektur
Fehlererkennung
Fehler in den empfangenen Frames werden mittels Parity Check und Cyclic Redundancy Check (CRC) erkannt. In beiden Fällen werden nur wenige zusätzliche Bits zusammen mit den tatsächlichen Daten gesendet, um zu bestätigen, dass die am anderen Ende empfangenen Bits dieselben sind, wie sie gesendet wurden. Wenn die Gegenprüfung am Ende des Empfängers fehlschlägt, werden die Bits als beschädigt betrachtet.
Paritätsprüfung
Ein zusätzliches Bit wird zusammen mit den Originalbits gesendet, um die Anzahl der Einsen entweder gerade bei gerader Parität oder ungerade bei ungerader Parität zu machen.
Der Absender zählt beim Erstellen eines Frames die Anzahl der Einsen. Wenn beispielsweise eine gerade Parität verwendet wird und die Anzahl der Einsen gerade ist, wird ein Bit mit dem Wert 0 hinzugefügt. Auf diese Weise bleibt die Anzahl der Einsen gerade. Wenn die Anzahl der Einsen ungerade ist, wird ein gerades Bit mit dem Wert 1 hinzugefügt.
Der Empfänger zählt einfach die Anzahl der Einsen in einem Rahmen. Wenn die Anzahl von 1s gerade ist und eine gerade Parität verwendet wird, gilt der Frame als nicht beschädigt und wird akzeptiert. Wenn die Anzahl von 1s ungerade ist und eine ungerade Parität verwendet wird, ist der Frame immer noch nicht beschädigt.
Wenn ein einzelnes Bit während der Übertragung umgedreht wird, kann der Empfänger es durch Zählen der Anzahl von 1s erkennen. Wenn jedoch mehr als ein Bit fehlerhaft ist, ist es für den Empfänger sehr schwierig, den Fehler zu erkennen.
Cyclic Redundancy Check (CRC)
CRC ist ein anderer Ansatz, um festzustellen, ob der empfangene Frame gültige Daten enthält. Diese Technik beinhaltet eine binäre Division der gesendeten Datenbits. Der Divisor wird unter Verwendung von Polynomen erzeugt. Der Absender führt eine Teilungsoperation für die gesendeten Bits durch und berechnet den Rest. Vor dem Senden der tatsächlichen Bits fügt der Absender den Rest am Ende der tatsächlichen Bits hinzu. Die tatsächlichen Datenbits plus der Rest werden als Codewort bezeichnet. Der Absender überträgt Datenbits als Codewörter.
Am anderen Ende führt der Empfänger eine Teilungsoperation an Codewörtern unter Verwendung desselben CRC-Teilers durch. Wenn der Rest alle Nullen enthält, werden die Datenbits akzeptiert, andernfalls wird davon ausgegangen, dass während der Übertragung eine Datenbeschädigung aufgetreten ist.
Fehler Korrektur
In der digitalen Welt kann die Fehlerkorrektur auf zwei Arten erfolgen:
Backward Error Correction Wenn der Empfänger einen Fehler in den empfangenen Daten feststellt, fordert er den Absender auf, die Dateneinheit erneut zu übertragen.
Forward Error Correction Wenn der Empfänger einen Fehler in den empfangenen Daten feststellt, führt er einen Fehlerkorrekturcode aus, der ihm hilft, einige Arten von Fehlern automatisch wiederherzustellen und zu korrigieren.
Die erste, die Rückwärtsfehlerkorrektur, ist einfach und kann nur dann effizient eingesetzt werden, wenn eine erneute Übertragung nicht teuer ist. Zum Beispiel Glasfaser. Im Falle einer drahtlosen Übertragung kann eine erneute Übertragung jedoch zu viel kosten. Im letzteren Fall wird die Vorwärtsfehlerkorrektur verwendet.
Um den Fehler im Datenrahmen zu korrigieren, muss der Empfänger genau wissen, welches Bit im Rahmen beschädigt ist. Um das fehlerhafte Bit zu lokalisieren, werden redundante Bits als Paritätsbits für die Fehlererkennung verwendet. Wenn wir beispielsweise ASCII-Wörter (7-Bit-Daten) verwenden, benötigen wir möglicherweise 8 Arten von Informationen: Die ersten sieben Bits geben an, welches Bit vorhanden ist ist ein Fehler und noch ein Bit, um zu sagen, dass es keinen Fehler gibt.
Für m Datenbits werden r redundante Bits verwendet. r Bits können 2r Kombinationen von Informationen liefern. Im m + r-Bit-Codewort besteht die Möglichkeit, dass die r-Bits selbst beschädigt werden. Die Anzahl der verwendeten r Bits muss also über m + r Bitpositionen plus fehlerfreie Informationen, dh m + r + 1, informieren.