Contents
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_.
- This chapter based on the "BEC model" ("Binary Erasure Channel"), which marks an uncertain bit as "erasure" E.
- In contrast to the "BSC model" ("Binary Symmetric Channel") and "AWGN model" ("Additive White Gaussian Noise"), bit errors (yi≠ci) 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, ... ,uk−1),c_=(c0,c1, ... ,ci, ... ,cn−1).
- For the individual symbols of information block and code word, Reed–Solomon coding applies:
- ui∈GF(q),ci∈GF(q)withq=n+1=2m⇒n=2m−1.
- Each code symbol ci is thus represented by m≥2 binary symbols. For comparison: For the binary block codes hold q=2, m=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 λm≈m⋅λ a code symbol ci is erased (yi=E) and it holds Pr(yi=ci)=1−λm.
- For more details on the conversion of the two models, see "Exercise 2.11Z".
- For more details on the conversion of the two models, see "Exercise 2.11Z".
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 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.
- 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_=enc−1(z_).
- With the generator matrix G can also be written for this:
- c_=u_⋅G⇒z_=υ_⋅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=7, k=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,ci∈GF(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,z5∈GF(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:
- H⋅z_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 z2, z3 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 H⋅z_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 n−k=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:
- HE⋅z_TE+HK⋅z_TK=0_T⇒HE⋅z_TE=−HK⋅z_TK.
- Since for all elements zi∈GF(2m) the "additive inverse" InvA(zi)=(−zi)=zi holds in the same way
- HE⋅z_TE=HK⋅z_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=α5⇒z_=(α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