Loading [MathJax]/jax/output/HTML-CSS/fonts/TeX/fontdata.js

Reed-Solomon Decoding for the Erasure Channel

From LNTwww
< Channel Coding
Revision as of 14:32, 20 October 2022 by Guenter (talk | contribs)

Block diagram and requirements for Reed-Solomon error detection


In the  "Decoding at the Binary Erasure Channel"  chapter we showed for the binary block codes,  which calculations the decoder has to perform to decode from an incomplete received word  y_  the transmitted code word  x_  in the best possible way.  In the Reed–Solomon chapter we renamed  x_  to  c_.

Transmission system with Reed-Solomon coding/decoding and erasure channel
  1. This chapter based on the  "BEC model"  ("Binary Erasure Channel"),  which marks an uncertain bit as  "erasure"  E
  2. In contrast to the  "BSC model"  ("Binary Symmetric Channel") and   "AWGN model"  ("Additive White Gaussian Noise"),   bit errors  (yici)  are excluded here.


Each bit of a received word

  • thus matches the corresponding bit of the code word  (yi=ci),  or
  • is already marked as a cancellation  (yi=E).


The graphic shows the block diagram,  which is slightly different from the model in chapter  "Decoding oflinear block codes":

  • Since Reed–Solomon codes are linear block codes,  the information word  u_  and the code word  c_  are also related via the generator matrix  G  and following equation:
c_=enc(u_)=u_Gwithu_=(u0,u1, ... ,ui, ... ,uk1),c_=(c0,c1, ... ,ci, ... ,cn1).
  • For the individual symbols of information block and code word,  Reed–Solomon coding applies:
uiGF(q),ciGF(q)withq=n+1=2mn=2m1.
  • Each code symbol  ci  is thus represented by  m2  binary symbols.  For comparison:   For the binary block codes hold  q=2m=1  and the code word length  n  is freely selectable.
  • When encoding at symbol level,  the BEC model must be extended to the  "m-BEC model": 
  • With probability  λmmλ  a code symbol  ci  is erased  (yi=E)  and it holds  Pr(yi=ci)=1λm.


In the following, we deal only with the block  "code word finder"  (CWF),  which extracts from the received vector  y_  the vector  z_CRS:

  • If the number  e  of erasures in the vector   y_   is sufficiently small,  the entire code word can be found with certainty:   (z_=c_) .
  • If too many symbols of the received word  y_  are erased,  the decoder reports that this word cannot be decoded.  It may then be necessary to send this sequence again.

In the case of the erasure channel  (m BEC)  unlike the  m BSC, which is described in the chapter  "Error correction after Reed-Solomon coding"  applies, an error decision  (z_c_)  is excluded   ⇒   Block error probability  Pr(z_c_)=0   ⇒   Pr(v_u_)=0.

  • The reconstructed information word results according to the block diagram (yellow background) to  v_=enc1(z_).
  • With the generator matrix  G  can also be written for this:
c_=u_Gz_=υ_Gυ_=z_GT.

Procedure using the RSC as an example (7, 3, 5)8


In order to be able to represent the Reed–Solomon decoding at the extinction channel as simply as possible, we start from a concrete task:

A Reed–Solomon code with parameters  n=7k=3  and  q=23=8 is used.

Thus, for the information word  u_  and the code word  c_:

u_=(u0,u1,u2),c_=(c0,c1,c2,c3,c4,c5,c6),ui,ciGF(23)={0,1,α,α2,...,α6},

and the parity-check matrix  H  is:

H=(1α1α2α3α4α5α61α2α4α6α1α3α51α3α6α2α5α1α41α4α1α5α2α6α3).

For example, the received vector  y_=(α,1,E,E,α2,E,α5)  is assumed here. Then holds:

  • Since the erasure channel produces no errors, four of the code symbols are known to the decoder:
c0=α1,c1=1,c4=α2,c6=α5.
  • It is obvious that the block "code word finder" – in the block diagram is denoted by  CWF'  a vector of the form  z_=(c0,c1,z2,z3,c4,z5,c6)  is to be supplied with  z2,z3,z5GF(23).
  • But since the codeword  z_  found by the decoder is also supposed to be a valid Reed–Solomon code word   ⇒   z_CRS, must hold as well:
Hz_T=0_T(1α1α2α3α4α5α61α2α4α6α1α3α51α3α6α2α5α1α41α4α1α5α2α6α3)(c0c1z2z3c4z5c6)=(0000).
  • This gives four equations for the unknowns  z2z3  and  z5. With unique solution – and only with such – the decoding is successful and one can then say with certainty that indeed  c_=z_  was sent.


Solution of the matrix equations using the example of the RSC (7, 3, 5)8


Thus, it is necessary to find the admissible codeword  z_ that satisfies the determination equation  Hz_T  satisfies. For convenience, we split the vector  z_  into two partial vectors, viz.

  • the vector  z_E=(z2,z3,z5)  of the erased symbols  (index "E" for erasures ),
  • the vector  z_K=(c0,c1,c4,c6)  of known symbols  (index "K" for correct ).

With the associated partial matrices (each with  nk=4  rows)

HE=(α2α3α5α4α6α3α6α2α1α1α5α6),HK(1α1α4α61α2α1α51α3α5α41α4α2α3)

the equation of determination is thus:

HEz_TE+HKz_TK=0_THEz_TE=HKz_TK.
  • Since for all elements  ziGF(2m)  the  "additive inverse"  InvA(zi)=(zi)=zi  holds in the same way
HEz_TE=HKz_TK=(1α1α4α61α2α1α51α3α5α41α4α2α3)(α11α2α6)=...=(α3α4α20).
  • The right-hand side of the equation results for the considered example   ⇒   z_K=(c0,c1,c4,c6)  and is based on the polynomial  p(x)=x3+x+1, which leads to the following powers (in   α) :
α3=α+1,α4=α2+α,α5=α2+α+1,α6=α2+1,α7=1,α8=α1,α9=α2,α10=α3=α+1,...
  • Thus, the matrix equation for determining the vector we are looking for  z_E:
(α2α3α5α4α6α3α6α2α1α1α5α6)(z2z3z5)!=(α3α4α20).
  • Solving this matrix equation (most easily by program), we get
z2=α2,z3=α1,z5=α5z_=(α1,1,α2,α1,α2,α5,α5).
  • The result is correct, as the following control calculations show:
α2α2+α3α1+α5α5=α4+α4+α10=α10=α3,
α4α2+α6α1+α3α5=(α2+1)+(1)+(α)=α2+α=α4,
α6α2+α2α1+α1α5=(α)+(α+1)+(α2+1)=α2,
α1α2+α5α1+α6α5=(α+1)+(α2+1)+(α2+α)=0.
  • The corresponding information word is obtained with the  "Generator Matrix"  G  to  v_=z_GT=(α1,1,α3).

Exercises for the chapter


Exercise 2.11: Reed-Solomon Decoding according to "Erasures"

Exercise 2.11Z: Erasure Channel for Symbols