Linearer Code

Klasse von Codes, die mit Mitteln der linearen Algebra verarbeitet werden können
Dies ist eine alte Version dieser Seite, zuletzt bearbeitet am 3. Februar 2011 um 11:07 Uhr durch 178.7.185.135 (Diskussion) (Beispiel mit unvollständiger Decodierung). Sie kann sich erheblich von der aktuellen Version unterscheiden.

Ein linearer Code ist in der Kodierungstheorie ein spezieller Blockcode, bei dem die Codeworte Elemente eines endlichdimensionalen Vektorraums über einem endlichen Körper sind. Ein Code ist genau dann ein linearer Code, falls er ein Untervektorraum von ist.

Lineare Codes haben den Vorteil, dass Methoden der Linearen Algebra verwendet werden können. Sie sind somit einfach zu codieren und decodieren. Die meisten wichtigen Codes sind linear: Hamming-Code, Reed-Muller-Code, Hadamard-Code, alle zyklischen Codes (damit auch BCH, Reed-Solomon-Codes, Golay-Codes und Goppa-Codes).

Ist die Vektorraumdimension des linearen Codes gleich , so nennt man einen -Code oder bei einem Hammingabstand von auch -Code.

Eigenschaften

Da   ein Untervektorraum von   ist, existiert eine Basis   von  . Fasst man diese Basis in einer Matrix

 

zusammen, erhält man eine Erzeugermatrix. Des Weiteren besitzt der Code eine Kontrollmatrix  . Für sie gilt   genau dann, wenn   ein Codewort ist. Der Rang von   ist  , der von   ist  . Der Hammingabstand von   ist die minimale Anzahl linear abhängiger Spalten der Kontrollmatrix.

Das Hamminggewicht eines Codewortes   ist gleich der Anzahl der  , die von Null verschieden sind. Beispielsweise hat das Codewort   über   das Hamminggewicht 4. Der Hammingabstand des Codes ist gleich dem kleinsten Hamminggewicht aller Codewörter außer dem Nullwort.

Permutiert man die einzelnen Koordinaten der Codewörter, erhält man einen sogenannten äquivalenten Code. Damit und mittels linearer Algebra kann man zu jedem linearen Code einen äquivalenten finden, der eine Erzeugermatrix der Form   hat. Dabei ist   die  -Einheitsmatrix, und   ist eine  -Matrix. Dann heißt   Erzeugermatrix in reduzierter Form. Die ersten   Koordinaten können als Informationssymbole und die letzten   als Kontrollsymbole interpretiert werden. Ist   eine Erzeugermatrix in reduzierter Form, kann eine Kontrollmatrix   sofort gefunden werden:  . Ein linearer Code ist bereits durch seine Erzeugermatrix oder seine Kontrollmatrix bestimmt.

Beispiel

Der binäre  -Hammingcode besitzt folgende Erzeugermatrix in reduzierter Form sowie die dazugehörige Kontrollmatrix:

       
       

Codierung

Ein Wort   aus dem Raum   wird codiert, indem das Produkt   gebildet wird. Die Codierung des Wortes   mit dem  -Hammingcode veranschaulicht beispielsweise die folgende Rechnung.

 

Da hier die Addition in   erfolgt, gilt  

Decodierung

Mit Decodierung bezeichnet man das Zuordnen eines empfangenen, möglicherweise fehlerhaften Eingabevektors   zu einem Codevektor  . Die Decodierung ist nicht die Umkehrfunktion der Codierung, die einem Codevektor wieder einen Vektor aus   zuordnet.

Als Decodierungsmethode wird in der Codierungstheorie meistens die Methode der größten Wahrscheinlichkeit (englisch: maximum likelihood decoding) verwendet. Dabei wird ein empfangener Vektor   zu dem Codevektor   decodiert, der mit der größten Wahrscheinlichkeit zum tatsächlich versandten Codevektor   identisch ist. Häufig wird der Vektor, bei dem die wenigsten Stellen (Fehler) korrigiert werden müssen, als der Wahrscheinlichste angenommen. Mathematisch gesprochen heißt das, man sucht den Codevektor   mit dem geringsten Hammingabstand zum empfangenen Vektor  . Dieser Fall wird auch als Methode des nächstgelegenen Nachbarn (englisch: nearest neighbor decoding) bezeichnet. Durch Kenntnis der Art der gesendeten Daten oder des verwendeten Kanals können gegebenenfalls andere Informationen verwendet werden, um die Wahrscheinlichkeit für bestimmte Codevektoren zu bestimmen.

Es sei   der tatsächlich versendete (Code-)Vektor und   der empfangene Vektor. Die Decodierung sucht aus allen   Codevektoren den oder die Codevektoren  , die mit der größten Wahrscheinlichkeit versendet wurden.

 

Bei der Nearest-Neighbor-Dekodierung also:

 

Man sollte dabei beachten, dass diese Zuordnung bei den meisten Codes nicht für alle Fehlervektoren eindeutig ist. Es gibt dann einige Fehlervektoren, die nicht zugeordnet werden können, da sie mehr als einen nächstgelegenen Nachbarn haben.

Syndromdecodierung

Eine effizientere Methode für die Decodierung stellt die sogenannte Syndrom-Decodierung dar. Das Syndrom   eines Vektors   erhält man durch Multiplikation der Kontrollmatrix   mit  .

 

Es sei   der Fehlervektor von  . In   sind genau die Koordinaten ungleich Null, bei denen während der Übertragung Fehler aufgetreten sind.

Für das Syndrom von   gilt wegen der Linearität des Codes:

 

Da das Syndrom von Codevektoren immer Null ist, folgt:

 

Alle (fehlerhaften) Wörter mit dem gleichen Fehlervektor sind im gleichen affinen Unterraum, das heißt für solche Wörter ist das Syndrom   konstant.

Alle Vektoren, die aus einem beliebigen, festen Vektor durch Subtraktion eines beliebigen Codevektors hervorgegangen sind, bilden eine Nebenklasse der Untergruppe   von  . Der Vektor mit minimalem Gewicht in dieser Klasse heißt Führer der Nebenklasse (englisch: coset leader). Daher ist auch der Begriff „coset leader decoding” verbreitet.

Um   zu   zu decodieren, sucht man also den Fehlervektor  , dessen Syndrom identisch zum Syndrom von   ist und dessen Hamminggewicht minimal ist. Mit diesem Fehlervektor berechnet man   den nächstgelegenen Codevektor  .

Man kann also eine Tabelle mit bis zu   Zeilen aufstellen, die für jedes Syndrom eines empfangenen Vektors den entsprechenden Fehlervektor mit minimalem Hamminggewicht beinhaltet. Ist das Syndrom gleich 0, dann muss nichts korrigiert werden ansonsten beschränkt sich Decodierung auf das Nachschlagen des Fehlervektors in dieser Tabelle und Korrigieren der so detektierten Fehler.

Die Decodierung von linearen Codes ist im Allgemeinen NP-vollständig, das heißt, es sind keine Algorithmen mit polynomieller Laufzeit bekannt.[1] Die bekannten linearen Codes, beispielsweise Hamming-Codes, zeichnen sich dadurch aus, dass für sie effiziente Decodierungs-Algorithmen bekannt sind. Die Komplexität der linearen Decodierung ist Grundlage für das McEliece-Kryptosystem, das als sicher gilt, aber aufgrund seiner vergleichsweise langen Schlüssel bisher selten eingesetzt wird.

Beispiel

Will man den  -Hammingcode (von oben) decodieren, trifft man zuerst die Annahme, dass nur  -Bit Fehler auftreten. (Falls mehr Fehler auftreten, ist keine Fehlerkorrektur, sondern nur noch eine Fehlererkennung möglich.) Die möglichen Fehlervektoren   sind dann

 
 
 
 
 
 
 

Für jeden dieser Fehlervektoren wird nun das Syndrom   berechnet. Damit ergibt sich

   
   
   
   
   
   
   
   

Wird dann das fehlerhafte Wort   empfangen, ergibt dann  . Damit ergibt sich der Fehlervektor  , und   wird somit nach   decodiert. Das Klartextwort ist dann  .

Beispiel mit unvollständiger Decodierung

Gegeben sei der ternäre Wiederholungscode der Länge 3:

       

Die drei Spalten von   sind paarweise linear unabhängig. Der minimale Hammingabstand des Codes ist 3. Es können also höchstents ein Zeichenfehler korrigiert werden. Die Syndromtabelle sieht damit folgendermaßen aus:

   
   
   
   
   
   
   

(Durch Ausnützen von Linearitäten könnte die Anzahl der Zeilen halbiert werden, man muss dann aber testen, ob ein linear abhängiges Syndrom in der Tabelle ist.)

Man betrachte nun  ,  . Bei   ist das Syndrom  , die Korrektur lautet:  . Die Berechnung des Syndroms von   ergibt:  . Dieser Wert ist nicht in der Syntromtabelle enthalten, das Wort kann also nicht korrigiert werden.

Anwendung

Die Codierung und Decodierung ist, so wie sie oben beschrieben ist, relativ aufwendig. Bei der Codierung muss die Erzeugermatrix im Speicher gehalten werden, was bei Systemen mit begrenzten Ressourcen (zum Beispiel mobile Endgeräte oder Weltraumsonden) problematisch ist. Bei der Decodierung wird eine – je nach Korrekturrate – große Tabelle benötigt; der Speicherverbrauch ist dementsprechend groß. Aus diesem Grund werden in der Regel zusätzliche Eigenschaften der Codes benutzt, um diese effizient zu codieren und decodieren. Binäre zyklische Codes lassen sich beispielsweise sehr einfach mittels Schieberegister und XOR-Gatter realisieren.

Dualer Code

Zu jedem (linearen) Code   gibt es einen dualen Code (oder auch Dualcode)  , der selbst ein linearer Code ist. Die Codewörter des dualen Codes sind alle Wörter aus  , die zu den Codewörter aus   dual sind:

Man definiert hierzu ein inneres Produkt:

 

das die Vektoren   folgendermaßen abbildet:

 

Trotz der ähnlichen Definition handelt es sich hierbei nicht um ein Skalarprodukt, da diese Bilinearform nicht positiv definit ist. Es gibt nämlich aufgrund der Eigenschaften von Endlichen Körpern meistens Vektoren, die ungleich dem Nullvektor sind und bei denen das innere Produkt 0 ergibt. Man denke beispielsweise im an den binären Vektor  .

Mit Hilfe dieser Definition ergibt sich der Duale Code als:

 

Eine Erzeugermatrix des dualen Codes ist eine Kontrollmatrix des Ursprungscodes und umgekehrt.

Der duale Code spielt bei der Analyse der Eigenschaften von Codes eine wichtige Rolle.

Ein Spezialfall sind die sogenannten selbstdualen Codes. Dies sind Codes, die mit ihrem Dualcode identisch sind. Aus Dimensiongründen haben diese immer die Dimension  . Das wichtigste Beispiel für einen selbstdualen Code ist der erweiterte Hammingcode, bei dem der binäre [7,4,3]-Hammingcode um ein Paritätsbit auf gerade Parität erweitert wird:

 

Quellen

  1. E. R. Berlekamp, R. J. McEliece, H. C. A. von Tilburg: On the inherent intractability of certain coding problems. In: IEEE Transactions on Information Theory 24. 1978.

Literatur

  • Werner Lütkebohmert: Codierungstheorie. Algebraisch-geometrische Grundlagen und Algorithmen. Vieweg Verlag, Braunschweig u. a. 2003, ISBN 3-528-03197-2 (Vieweg-Studium – Aufbaukurs Mathematik).
  • J. H. van Lint: Introduction to Coding Theory. 3. revised and expanded edition. Springer Verlag, Heidelberg u. a. 1999, ISBN 3-540-64133-5 (Graduate texts in mathematics 86).
  • Florence J. MacWilliams, Neil J. Sloane: The Theory of Error-Correcting Codes. 2. Printing. North-Holland publishing company, Amsterdam 1978, ISBN 0-444-85009-0 (North Holland mathematical library 16).