The Basics of Product Codes

From LNTwww
< Channel Coding
Revision as of 17:15, 17 January 2017 by Ayush (talk | contribs) (Die Seite wurde neu angelegt: „ {{Header |Untermenü=Iterative Decodierverfahren |Vorherige Seite=Soft–in Soft–out Decoder |Nächste Seite=Grundlegendes zu den Turbocodes }} == Grundst…“)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Grundstruktur eines Produktcodes


Die Grafik zeigt den prinzipiellen Aufbau von Produktcodes, die bereits 1954 von Peter Elias eingeführt wurden. Der nachfolgend dargestellte zweidimensionale Produktcode C = C1 × C2 basiert auf den beiden linearen und binären Blockcodes mit den Parametern (n1, k1) bzw. (n2, k2).

Grundstruktur eines Produktcodes

Die Codewortlänge ist n = n1 · n2. Diese n Codebits lassen sich wie folgt gruppieren:

  • Die k = k1 · k2 Informationsbits sind in der k2×k1–Matrix U angeordnet. Die Coderate ist gleich dem Produkt der Coderaten der beiden Basiscodes: R = k/n = (k1/n1) · (k2/n2) = R1 · R2.
  • Die rechte obere Matrix P(1) mit der Dimension k2×m1 beinhaltet die Prüfbits (englisch: Parity) hinsichtlich des Codes C1. In jeder der k2 Zeilen werden zu den k1 Informationsbits m1 = n1k1 Prüfbits hinzugefügt, wie in Kapitel 1.3 am Beispiel der Hamming–Codes beschrieben wurde.
  • Die linke untere Matrix P(2) der Dimension m2×k1 beinhaltet die Prüfbits hinsichtlich des zweiten Komponentencodes C2. Hier erfolgt die Codierung (und auch die Decodierung) zeilenweise: In jeder der k1 Spalten werden die k2 Informationsbits noch um m2 = n2k2 Prüfbits ergänzt.
  • Die m2×m1–Matrix P(12) rechts unten bezeichnet man als Checks–on–Checks. Hier werden die vorher erzeugten Parity–Matrizen P(1) und P(2) entsprechend den Prüfgleichungen verknüpft.

Alle Produktcodes entsprechend obiger Grafik weisen folgende Eigenschaften auf:

  • Bei linearen Komponentencodes C1 und C2 ist auch der Produktcode C = C1 × C2 linear.
  • Jede Zeile von C gibt ein Codewort von C1 wieder und jede Spalte ein Codewort von C2.
  • Die Summe zweier Zeilen ergibt aufgrund der Linearität wieder ein Codewort von C1.
  • Ebenso ergibt die Summe zweier Spalten ein gültiges Codewort von C2.
  • Jeder Produktcodes beinhaltet auch das Nullwort 0 (ein Vektor mit n Nullen).
  • Die minimale Distanz von C ist dmin = d1 · d2, wobei di die minimale Distanz von Ci angibt.

Iterative Syndromdecodierung von Produktcodes (1)


Wir betrachten nun den Fall, dass ein Produktcode mit Matrix X über einen Binärkanal übertragen wird. Die Empfangsmatrix sei Y = X + E, wobei E die Fehlermatrix bezeichnet. Alle Elemente der Matrizen X, E und Y seien binär, also 0 oder 1.

Für die Decodierung der beiden Komponentencodes bietet sich die Syndromdecodierung entsprechend dem Kapitel 1.5 an. Im zweidimensionalen Fall bedeutet dies:

  • Man decodiert zunächst die n2 Zeilen der Empfangsmatrix Y, basierend auf der Prüfmatrix H1 des Komponentencodes C1. Man verwendet hierzu die Syndromdecodierung.
  • Dazu bildet man jeweils das sogenannte Syndrom s = y · H1T, wobei der Vektor y der Länge n1 die aktuelle Zeile von Y angibt und „T” für „transponiert” steht.
  • Entsprechend dem berechneten sμ (mit 0 ≤ μ < 2n1k1) findet man dann in einer vorbereiteten Syndromtabelle das wahrscheinliche Fehlermuster e = eμ.
  • Bei nur wenigen Fehlern innerhalb der Zeile stimmt dann y + e mit dem gesendeten Zeilenvektor x überein. Sind zu viele Fehler aufgetreten, so kommt es allerdings zu Fehlkorrekturen.
  • Anschließend syndromdecodiert man die n1 Spalten der (korrigierten) Empfangsmatrix Y', diesmal basierend auf der (transponierten) Prüfmatrix H2T des Komponentencodes C2.
  • Hierzu bildet man das Syndrom s = y' · H2T, wobei der Vektor y' der Länge n2 die betrachtete Spalte von Y' bezeichnet.
  • Aus einer zweiten Syndromtabelle (gültig für den Code C2) findet man für das berechnete sμ (mit 0 ≤ μ < 2n2k2) das wahrscheinliche Fehlermuster e = eμ der bearbeiteten Spalte.
  • Nach Korrektur aller Spalten liegt die Marix Y vor. Nun kann man wieder eine Zeilen– und anschließend eine Spaltendecodierung vornehmen  ⇒  zweite Iteration, und so weiter, und so fort.

Auf der nächsten Seite wird dieser Decodieralgorithmus an einem Beispiel verdeutlicht. Dazu betrachten wir wieder den (42, 12) Produktcode, basierend auf

  • dem Hammingcode (7, 4, 3)  ⇒  Code C1,
  • dem verkürzten Hammingcode (6, 3, 3)  ⇒  Code C2.

Die Prüfmatrizen dieser beiden systematischen Komponentencodes lauten in transponierter Form:

\[{ \boldsymbol{\rm H}}_1^{\rm T} = \begin{pmatrix} 1 &0 &1 \\ 1 &1 &0 \\ 0 &1 &1 \\ 1 &1 &1 \\ 1 &0 &0 \\ 0 &1 &0 \\ 0 &0 &1 \end{pmatrix} \hspace{0.05cm}, \hspace{0.5cm} { \boldsymbol{\rm H}}_2^{\rm T} = \begin{pmatrix} 1 &1 &0 \\ 1 &0 &1 \\ 0 &1 &1 \\ 1 &0 &0 \\ 0 &1 &0 \\ 0 &0 &1 \end{pmatrix}\hspace{0.05cm}.\]

Iterative Syndromdecodierung von Produktcodes (2)


Die linke Grafik zeigt die Empfangsmatrix Y, Aus Darstellungsgründen wurde die Codermatrix X zu einer 6 × 7–Nullmatrix gewählt, so dass die neun Einsen in Y gleichzeitig Übertragungsfehler darstellen.

Zur Syndromdecodierung des (42, 12)–Produktcodes

Hinweis: Für die folgenden Berechnungen ist der Link zu den transponierten Prüfmatrizen nützlich.

Die zeilenweise Syndromdecodierung geschieht über das Syndrom s = y · H1T. Im Einzelnen:

  • Zeile 1  ⇒  Einzelfehlerkorrektur ist erfolgreich (ebenso in den Zeilen 3, 4 und 6): Syndromtabelle für den Code C1
\[\underline{s} = \left ( 0, \hspace{0.02cm} 0, \hspace{0.02cm}1, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}0 \right ) \hspace{-0.03cm}\cdot \hspace{-0.03cm}{ \boldsymbol{\rm H}}_1^{\rm T} \hspace{-0.05cm}= \left ( 0, \hspace{0.03cm} 1, \hspace{0.03cm}1 \right ) = \underline{s}_3\]
\[\Rightarrow \hspace{0.3cm} \underline{y} + \underline{e}_3 = \left ( 0, \hspace{0.02cm} 0, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}0 \right ) \hspace{0.05cm}.\]
  • Zeile 2  ⇒  Fehlkorrektur bezüglich Bit 5:
\[\underline{s} = \left ( 1, \hspace{0.02cm} 0, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}1 \right ) \hspace{-0.03cm}\cdot \hspace{-0.03cm}{ \boldsymbol{\rm H}}_1^{\rm T} \hspace{-0.05cm}= \left ( 1, \hspace{0.03cm} 0, \hspace{0.03cm}0 \right ) = \underline{s}_4\]
\[\Rightarrow \hspace{0.3cm} \underline{y} + \underline{e}_4 = \left ( 1, \hspace{0.02cm} 0, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}1, \hspace{0.02cm}0, \hspace{0.02cm}1 \right ) \hspace{0.05cm}.\]
  • Zeile 5  ⇒  Fehlkorrektur bezüglich Bit 3:
\[\underline{s} = \left ( 0, \hspace{0.02cm} 0, \hspace{0.02cm}0, \hspace{0.02cm}1, \hspace{0.02cm}1, \hspace{0.02cm}0, \hspace{0.02cm}0 \right ) \hspace{-0.03cm}\cdot \hspace{-0.03cm}{ \boldsymbol{\rm H}}_1^{\rm T} \hspace{-0.05cm}= \left ( 0, \hspace{0.03cm} 1, \hspace{0.03cm}1 \right ) = \underline{s}_3\]
\[\Rightarrow \hspace{0.3cm} \underline{y} + \underline{e}_3 = \left ( 0, \hspace{0.02cm} 0, \hspace{0.02cm}1, \hspace{0.02cm}1, \hspace{0.02cm}1, \hspace{0.02cm}0, \hspace{0.02cm}0 \right ) \hspace{0.05cm}.\]

Die spaltenweisen Syndromdecodierung entfernt alle Einzelfehler in den Spalten 1, 2, 3, 4, 6 und 7. Syndromtabelle für den Code C2

  • Spalte 5  ⇒  Fehlkorrektur bezüglich Bit 4:
\[\underline{s} = \left ( 0, \hspace{0.02cm} 1, \hspace{0.02cm}0, \hspace{0.02cm}0, \hspace{0.02cm}1, \hspace{0.02cm}0 \right ) \hspace{-0.03cm}\cdot \hspace{-0.03cm}{ \boldsymbol{\rm H}}_1^{\rm T} \hspace{-0.05cm}= \left ( 1, \hspace{0.03cm} 0, \hspace{0.03cm}0 \right ) = \underline{s}_4\]
\[\Rightarrow \hspace{0.3cm} \underline{y} + \underline{e}_4 = \left ( 0, \hspace{0.02cm} 1, \hspace{0.02cm}0, \hspace{0.02cm}1, \hspace{0.02cm}1, \hspace{0.02cm}0 \right ) \hspace{0.05cm}.\]

Die verbliebenen drei Fehler werden durch zeilenweise Decodierung der zweiten Iterationsschleife korrigiert.

Ob alle Fehler eines Blockes korrigierbar sind, hängt vom Fehlermuster ab. Hier verweisen wir auf Aufgabe A4.7.