Linearer Code

Ein linearer Code ist in der Kodierungstheorie ein spezieller Blockcode, bei dem die Codewörter Elemente eines endlichdimensionalen Vektorraums F q n {\displaystyle \mathbb {F} _{q}^{n}} über einem endlichen Körper F q {\displaystyle \mathbb {F} _{q}} sind. Ein Code ist genau dann linear, wenn er ein Untervektorraum von F q n {\displaystyle \mathbb {F} _{q}^{n}} ist.

Lineare Codes haben den Vorteil, dass Methoden der Linearen Algebra verwendet werden können. Sie sind somit einfach zu kodieren und dekodieren. Die meisten wichtigen Codes sind linear: Hamming-Code, Low-Density-Parity-Check-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 C {\displaystyle C} gleich k {\displaystyle k} , so nennt man C {\displaystyle C} einen [ n , k ] {\displaystyle [n,k]} -Code oder bei einem Hamming-Abstand von d {\displaystyle d} auch [ n , k , d ] {\displaystyle [n,k,d]} -Code.

Eigenschaften

Da C {\displaystyle C} ein Untervektorraum von V {\displaystyle V} ist, existiert eine Basis g 1 , , g k {\displaystyle g_{1},\dots ,g_{k}} von C {\displaystyle C} . Fasst man diese Basis in einer Matrix

G = ( g 1 g k ) {\displaystyle G={\begin{pmatrix}g_{1}\\\vdots \\g_{k}\end{pmatrix}}}

zusammen, erhält man eine Erzeugermatrix. Des Weiteren besitzt der Code eine Kontrollmatrix H {\displaystyle H} . Für sie gilt H c T = 0 {\displaystyle Hc^{T}=0} genau dann, wenn c {\displaystyle c} ein Codewort ist. Der Rang von G {\displaystyle G} ist k {\displaystyle k} , der von H {\displaystyle H} ist n k {\displaystyle n-k} . Der Hamming-Abstand von C {\displaystyle C} ist die minimale Anzahl linear abhängiger Spalten der Kontrollmatrix.

Das Hamming-Gewicht eines Codewortes c = ( c 1 , , c n ) {\displaystyle c=(c_{1},\dots ,c_{n})} ist gleich der Anzahl der c i {\displaystyle c_{i}} , die von Null verschieden sind. Beispielsweise hat das Codewort ( 430540 ) {\displaystyle (430540)} über F 7 6 {\displaystyle \mathbb {F} _{7}^{6}} das Hamming-Gewicht 4. Der Hamming-Abstand des Codes ist gleich dem kleinsten Hamming-Gewicht 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 G = ( E k | P ) {\displaystyle G=(\mathbb {E} _{k}|P)} hat. Dabei ist E k {\displaystyle \mathbb {E} _{k}} die ( k × k ) {\displaystyle (k\times k)} -Einheitsmatrix, und P {\displaystyle P} ist eine ( k × ( n k ) ) {\displaystyle (k\times (n-k))} -Matrix. Dann heißt G {\displaystyle G} Erzeugermatrix in reduzierter Form. Die ersten k {\displaystyle k} Koordinaten können als Informationssymbole und die letzten n k {\displaystyle n-k} als Kontrollsymbole interpretiert werden. Ist G {\displaystyle G} eine Erzeugermatrix in reduzierter Form, kann eine Kontrollmatrix H {\displaystyle H} sofort gefunden werden: H = ( P T | E n k ) {\displaystyle H=(-P^{T}|\mathbb {E} _{n-k})} . Ein linearer Code ist bereits durch seine Erzeugermatrix oder seine Kontrollmatrix bestimmt.

Weil der lineare Code ein k {\displaystyle k} -dimensionaler Untervektorraum von F q n {\displaystyle \mathbb {F} _{q}^{n}} ist, ist er der Kern einer linearen Abbildung f : F q n F q n k {\displaystyle f\colon \mathbb {F} _{q}^{n}\to \mathbb {F} _{q}^{n-k}} . Die Matrix einer solchen linearen Abbildung heißt Paritätsprüfungsmatrix und wird notiert als H T {\displaystyle H^{T}} mit H F q ( n k ) × n {\displaystyle H\in \mathbb {F} _{q}^{(n-k)\times {n}}} . Der lineare Code ist definiert als Kern dieser linearen Abbildung: C := k e r ( f ) = { c F q n c H T = 0 } {\displaystyle C:=\mathrm {ker} (f)=\{c\in \mathbb {F} _{q}^{n}\mid cH^{T}=0\}} .

Die Informationsrate des linearen Codes C {\displaystyle C} ist R = k n log 2 ( q ) {\displaystyle R={\tfrac {k}{n}}\cdot \log _{2}(q)} .[1]

Beispiel

Der binäre [ 7 , 4 , 3 ] {\displaystyle [7,4,3]} -Hamming-Code besitzt folgende Erzeugermatrix in reduzierter Form sowie die dazugehörige Kontrollmatrix:

G = ( E k | P ) {\displaystyle G=(\mathbb {E} _{k}|P)}     H = ( P T | E n k ) {\displaystyle H=(-P^{T}|\mathbb {E} _{n-k})}
G = ( 1 0 0 0 1 1 0 0 1 0 0 1 0 1 0 0 1 0 1 1 1 0 0 0 1 0 1 1 ) {\displaystyle G={\begin{pmatrix}{\color {Brown}1}&0&0&0&1&1&0\\0&{\color {Brown}1}&0&0&1&0&1\\0&0&\color {Brown}{1}&0&1&1&1\\0&0&0&{\color {Brown}1}&0&1&1\\\end{pmatrix}}\qquad }     H = ( 1 1 1 0 1 0 0 1 0 1 1 0 1 0 0 1 1 1 0 0 1 ) {\displaystyle H={\begin{pmatrix}1&1&1&0&{\color {Brown}1}&0&0\\1&0&1&1&0&{\color {Brown}1}&0\\0&1&1&1&0&0&{\color {Brown}1}\\\end{pmatrix}}}

Kodierung

Ein Wort x = ( x 1 , , x k ) {\displaystyle x=(x_{1},\dots ,x_{k})} aus dem Raum F q k {\displaystyle \mathbb {F} _{q}^{k}} wird kodiert, indem das Produkt x G {\displaystyle xG} gebildet wird. Die Kodierung des Wortes ( 0 , 0 , 1 , 1 ) {\displaystyle (0,0,1,1)} mit dem [ 7 , 4 , 3 ] {\displaystyle [7,4,3]} -Hamming-Code veranschaulicht beispielsweise die folgende Rechnung.

x G = c ( 0 , 0 , 1 , 1 ) ( 1 0 0 0 1 1 0 0 1 0 0 1 0 1 0 0 1 0 1 1 1 0 0 0 1 0 1 1 ) = ( 0 , 0 , 1 , 1 , 1 , 0 , 0 ) {\displaystyle {\begin{aligned}x\cdot G&=c\\{\begin{pmatrix}0,0,1,1\end{pmatrix}}\cdot {\begin{pmatrix}1&0&0&0&1&1&0\\0&1&0&0&1&0&1\\0&0&1&0&1&1&1\\0&0&0&1&0&1&1\\\end{pmatrix}}&={\begin{pmatrix}0,0,1,1,1,0,0\end{pmatrix}}\end{aligned}}}

Da hier die Addition in F 2 {\displaystyle \mathbb {F} _{2}} erfolgt, gilt 1 + 1 = 0 {\displaystyle 1+1=0}

Dekodierung

Mit Dekodierung bezeichnet man das Zuordnen eines empfangenen, möglicherweise fehlerhaften Eingabevektors  x {\displaystyle x} zu einem Codevektor  c {\displaystyle c'} . Die Dekodierung ist nicht die Umkehrfunktion der Kodierung, die einem Codevektor wieder einen Vektor aus F q k {\displaystyle \mathbb {F} _{q}^{k}} zuordnet.

Als Dekodierungsmethode wird in der Kodierungstheorie meistens die Methode der größten Wahrscheinlichkeit (englisch: maximum likelihood decoding) verwendet. Dabei wird ein empfangener Vektor  x {\displaystyle x} zu dem Codevektor  c {\displaystyle c'} dekodiert, der mit der größten Wahrscheinlichkeit zum tatsächlich versandten Codevektor  c {\displaystyle c} 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  c {\displaystyle c'} mit dem geringsten Hamming-Abstand zum empfangenen Vektor  x {\displaystyle x} . 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 c {\displaystyle c} der tatsächlich versendete (Code-)Vektor und x {\displaystyle x} der empfangene Vektor. Die Dekodierung sucht aus allen q n {\displaystyle q^{n}} Codevektoren den oder die Codevektoren c {\displaystyle c'} , die mit der größten Wahrscheinlichkeit versendet wurden.

c = argmax y C { P [ y = c ] } {\displaystyle c'=\operatorname {argmax} _{y\in C}\left\{\operatorname {P} \left[y=c\right]\right\}}

Bei der Nearest-Neighbor-Dekodierung also:

c = argmin y C { w t ( x y ) } {\displaystyle c'=\operatorname {argmin} _{y\in C}\left\{wt(x-y)\right\}}

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. Ist für jeden Fehlervektor eine eindeutige Dekodierung möglich, so heißt der Code perfekt.

Syndromdekodierung

Eine effizientere Methode für die Dekodierung stellt die sogenannte Syndrom-Dekodierung dar. Das Syndrom s x {\displaystyle s_{x}} eines Vektors x {\displaystyle x} erhält man durch Multiplikation der Kontrollmatrix  H {\displaystyle H} mit x T {\displaystyle x^{T}} .

s x T = H x T {\displaystyle s_{x}^{T}=Hx^{T}}

Es sei e = x c {\displaystyle e=x-c} der Fehlervektor von x {\displaystyle x} . In e {\displaystyle e} sind genau die Koordinaten ungleich Null, bei denen während der Übertragung Fehler aufgetreten sind.

Für das Syndrom von x {\displaystyle x} gilt wegen der Linearität des Codes:

s x T = H x T = H c T + H e T {\displaystyle s_{x}^{T}=Hx^{T}=Hc^{T}+He^{T}}

Da das Syndrom von fehlerfreien Codevektoren immer Null ist, folgt:

s x T = H e T = s e T {\displaystyle s_{x}^{T}=He^{T}=s_{e}^{T}}

Alle (fehlerhaften) Wörter mit dem gleichen Fehlervektor sind im gleichen affinen Unterraum, das heißt für solche Wörter ist das Syndrom s e T = H e T {\displaystyle s_{e}^{T}=He^{T}} konstant.

Alle Vektoren, die aus einem beliebigen, festen Vektor durch Subtraktion eines beliebigen Codevektors hervorgegangen sind, bilden eine Nebenklasse der Untergruppe C {\displaystyle C} von F q n {\displaystyle \mathbb {F} _{q}^{n}} . 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 x {\displaystyle x} zu c {\displaystyle c'} zu dekodieren, sucht man also den Fehlervektor  e {\displaystyle e'} , dessen Syndrom identisch zum Syndrom von x {\displaystyle x} ist und dessen Hamming-Gewicht minimal ist. Mit diesem Fehlervektor berechnet man c = x e {\displaystyle c'=x-e'} den nächstgelegenen Codevektor  c {\displaystyle c'} . Man kann also eine Tabelle mit bis zu q n k {\displaystyle q^{n-k}} Zeilen aufstellen, die für jedes Syndrom eines empfangenen Vektors den entsprechenden Fehlervektor mit minimalem Hamming-Gewicht beinhaltet. Ist das Syndrom gleich 0, dann muss nichts korrigiert werden ansonsten beschränkt sich Dekodierung auf das Nachschlagen des Fehlervektors in dieser Tabelle und Korrigieren der so detektierten Fehler.

Anders interpretiert sind die Nebenklassen gerade die Äquivalenzklassen der Äquivalenzrelation x y s x T = s y T {\displaystyle x\equiv y\Leftrightarrow s_{x}^{T}=s_{y}^{T}} Die Führer sind gerade Vertreter der Äquivalenzklassen, man wählt einen mit minimalem Hamming-Gewicht. Perfekte Codes zeichnen sich dadurch aus, dass die Führer eindeutig festgelegt sind.

Die Dekodierung von linearen Codes ist im Allgemeinen NP-vollständig, das heißt, es sind keine Algorithmen mit polynomieller Laufzeit bekannt.[2] Die bekannten linearen Codes, beispielsweise Hamming-Codes, zeichnen sich dadurch aus, dass für sie effiziente Dekodierungs-Algorithmen bekannt sind. Die Komplexität der linearen Dekodierung 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 [ 7 , 4 , 3 ] {\displaystyle [7,4,3]} -Hamming-Code (von oben) dekodieren, trifft man zuerst die Annahme, dass nur 1 {\displaystyle 1} -Bit Fehler auftreten. Die möglichen Fehlervektoren e {\displaystyle e} sind dann

( 1 , 0 , 0 , 0 , 0 , 0 , 0 ) {\displaystyle (1,0,0,0,0,0,0)}
( 0 , 1 , 0 , 0 , 0 , 0 , 0 ) {\displaystyle (0,1,0,0,0,0,0)}
( 0 , 0 , 1 , 0 , 0 , 0 , 0 ) {\displaystyle (0,0,1,0,0,0,0)}
( 0 , 0 , 0 , 1 , 0 , 0 , 0 ) {\displaystyle (0,0,0,1,0,0,0)}
( 0 , 0 , 0 , 0 , 1 , 0 , 0 ) {\displaystyle (0,0,0,0,1,0,0)}
( 0 , 0 , 0 , 0 , 0 , 1 , 0 ) {\displaystyle (0,0,0,0,0,1,0)}
( 0 , 0 , 0 , 0 , 0 , 0 , 1 ) {\displaystyle (0,0,0,0,0,0,1)}

Für jeden dieser Fehlervektoren wird nun das Syndrom s T = H e T {\displaystyle s^{T}=He^{T}} berechnet. Damit ergibt sich

e {\displaystyle e} s {\displaystyle s}
( 1 , 0 , 0 , 0 , 0 , 0 , 0 ) {\displaystyle (1,0,0,0,0,0,0)} ( 1 , 1 , 0 ) {\displaystyle (1,1,0)}
( 0 , 1 , 0 , 0 , 0 , 0 , 0 ) {\displaystyle (0,1,0,0,0,0,0)} ( 1 , 0 , 1 ) {\displaystyle (1,0,1)}
( 0 , 0 , 1 , 0 , 0 , 0 , 0 ) {\displaystyle (0,0,1,0,0,0,0)} ( 1 , 1 , 1 ) {\displaystyle (1,1,1)}
( 0 , 0 , 0 , 1 , 0 , 0 , 0 ) {\displaystyle (0,0,0,1,0,0,0)} ( 0 , 1 , 1 ) {\displaystyle (0,1,1)}
( 0 , 0 , 0 , 0 , 1 , 0 , 0 ) {\displaystyle (0,0,0,0,1,0,0)} ( 1 , 0 , 0 ) {\displaystyle (1,0,0)}
( 0 , 0 , 0 , 0 , 0 , 1 , 0 ) {\displaystyle (0,0,0,0,0,1,0)} ( 0 , 1 , 0 ) {\displaystyle (0,1,0)}
( 0 , 0 , 0 , 0 , 0 , 0 , 1 ) {\displaystyle (0,0,0,0,0,0,1)} ( 0 , 0 , 1 ) {\displaystyle (0,0,1)}

Wird dann das fehlerhafte Wort x = ( 0 , 1 , 1 , 1 , 1 , 0 , 0 ) {\displaystyle x=(0,1,1,1,1,0,0)} empfangen, ergibt dann s T = H x T = ( 1 , 0 , 1 ) T {\displaystyle s^{T}=Hx^{T}=(1,0,1)^{T}} . Damit ergibt sich der Fehlervektor e = e ( ( 1 , 0 , 1 ) ) = ( 0 , 1 , 0 , 0 , 0 , 0 , 0 ) {\displaystyle e=e((1,0,1))=(0,1,0,0,0,0,0)} , und x {\displaystyle x} wird somit nach c ( x ) = ( 0 , 1 , 1 , 1 , 1 , 0 , 0 ) ( 0 , 1 , 0 , 0 , 0 , 0 , 0 ) = ( 0 , 0 , 1 , 1 , 1 , 0 , 0 ) {\displaystyle c(x)=(0,1,1,1,1,0,0)-(0,1,0,0,0,0,0)=(0,0,1,1,1,0,0)} dekodiert. Das Klartextwort ist dann ( 0 , 0 , 1 , 1 ) {\displaystyle (0,0,1,1)} .

Beispiel mit unvollständiger Dekodierung

Gegeben sei der ternäre ( q = 3 {\displaystyle q=3} ) Wiederholungscode der Länge 3:

G = ( 1 1 1 ) {\displaystyle G={\begin{pmatrix}1&1&1\end{pmatrix}}\qquad }     H = ( 2 1 0 2 0 1 ) {\displaystyle H={\begin{pmatrix}2&1&0\\2&0&1\\\end{pmatrix}}}

Jeweils zwei Spalten von H {\displaystyle H} sind linear unabhängig, alle drei dagegen linear abhängig. Der minimale Hamming-Abstand des Codes berechnet sich als minimale Anzahl linear abhängiger Spalten in H {\displaystyle H} also zu 3. Es kann damit höchstens ein Zeichenfehler korrigiert werden. Die Syndromtabelle sieht folgendermaßen aus:

e {\displaystyle e} s {\displaystyle s}
( 1 , 0 , 0 ) {\displaystyle (1,0,0)} ( 2 , 2 ) {\displaystyle (2,2)}
( 2 , 0 , 0 ) {\displaystyle (2,0,0)} ( 1 , 1 ) {\displaystyle (1,1)}
( 0 , 1 , 0 ) {\displaystyle (0,1,0)} ( 1 , 0 ) {\displaystyle (1,0)}
( 0 , 2 , 0 ) {\displaystyle (0,2,0)} ( 2 , 0 ) {\displaystyle (2,0)}
( 0 , 0 , 1 ) {\displaystyle (0,0,1)} ( 0 , 1 ) {\displaystyle (0,1)}
( 0 , 0 , 2 ) {\displaystyle (0,0,2)} ( 0 , 2 ) {\displaystyle (0,2)}

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 x = ( 1 , 1 , 0 ) {\displaystyle x=(1,1,0)} , y = ( 1 , 2 , 0 ) {\displaystyle y=(1,2,0)} . Bei x {\displaystyle x} ist das Syndrom H x t = ( 0 , 2 ) t {\displaystyle Hx^{t}=(0,2)^{t}} , die Korrektur lautet: ( 1 , 1 , 0 ) ( 0 , 0 , 2 ) = ( 1 , 1 , 1 ) {\displaystyle (1,1,0)-(0,0,2)=(1,1,1)} . Die Berechnung des Syndroms von y {\displaystyle y} ergibt: H y t = ( 1 , 2 ) t {\displaystyle Hy^{t}=(1,2)^{t}} . Dieser Wert ist nicht in der Syndromtabelle enthalten, das Wort kann also nicht korrigiert werden.

Anwendung

Die Kodierung und Dekodierung ist, so wie sie oben beschrieben ist, relativ aufwendig. Bei der Kodierung muss die Erzeugermatrix im Speicher gehalten werden, was bei Systemen mit begrenzten Ressourcen (zum Beispiel mobile Endgeräte oder Weltraumsonden) problematisch ist. Bei der Dekodierung 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 kodieren und dekodieren. Binäre zyklische Codes lassen sich beispielsweise sehr einfach mittels Schieberegister und Exklusiv-Oder-Gatter realisieren.

Dualer Code

Zu jedem (linearen) Code C {\displaystyle C} gibt es einen dualen Code (oder auch Dualcode) C {\displaystyle C^{\perp }} , der selbst ein linearer Code ist. Die Codewörter des dualen Codes sind alle Wörter aus F q n {\displaystyle \mathbb {F} _{q}^{n}} , die zu den Codewörtern aus C {\displaystyle C} dual sind:

Man definiert hierzu ein inneres Produkt:

; : F q n × F q n F q {\displaystyle \langle \cdot ;\cdot \rangle \,:\;\mathbb {F} _{q}^{n}\times \mathbb {F} _{q}^{n}\to \mathbb {F} _{q}}

das die Vektoren x = ( x 1 , x 2 , , x n ) , y = ( y 1 , y 2 , , y n ) {\displaystyle x=(x_{1},x_{2},\dots ,x_{n}),y=(y_{1},y_{2},\dots ,y_{n})} folgendermaßen abbildet:

x ; y = i = 1 n x i y i {\displaystyle \langle x;y\rangle =\sum _{i=1}^{n}x_{i}y_{i}}

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 an den binären Vektor ( 1 , 1 ) {\displaystyle (1,1)} .

Mit Hilfe dieser Definition ergibt sich der Duale Code als:

C = { x F q n x , c = 0 f u ¨ r a l l e c C } {\displaystyle C^{\perp }=\{x\in \mathbb {F} _{q}^{n}\mid \langle x,c\rangle =0\;\mathrm {f{\ddot {u}}r\;alle} \;c\in C\}}

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 k = n / 2 {\displaystyle k=n/2} . Das wichtigste Beispiel für einen selbstdualen Code ist der erweiterte Hamming-Code, bei dem der binäre [7,4,3]-Hamming-Code um ein Paritätsbit auf gerade Parität erweitert wird:

G = H = ( 1 0 0 0 1 1 0 1 0 1 0 0 1 0 1 1 0 0 1 0 1 1 1 0 0 0 0 1 0 1 1 1 ) {\displaystyle G=H={\begin{pmatrix}1&0&0&0&1&1&0&1\\0&1&0&0&1&0&1&1\\0&0&1&0&1&1&1&0\\0&0&0&1&0&1&1&1\\\end{pmatrix}}}

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).

Einzelnachweise

  1. Technische Universität Berlin: Linear Codes
  2. 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.