Misplaced Pages

Reed–Muller code

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Error-correcting codes used in wireless communication
Reed-Muller code RM(r,m)
Named afterIrving S. Reed and David E. Muller
Classification
TypeLinear block code
Block length 2 m {\displaystyle 2^{m}}
Message length k = i = 0 r ( m i ) {\displaystyle k=\sum _{i=0}^{r}{\binom {m}{i}}}
Rate k / 2 m {\displaystyle k/2^{m}}
Distance 2 m r {\displaystyle 2^{m-r}}
Alphabet size 2 {\displaystyle 2}
Notation [ 2 m , k , 2 m r ] 2 {\displaystyle _{2}} -code

Reed–Muller codes are error-correcting codes that are used in wireless communications applications, particularly in deep-space communication. Moreover, the proposed 5G standard relies on the closely related polar codes for error correction in the control channel. Due to their favorable theoretical and mathematical properties, Reed–Muller codes have also been extensively studied in theoretical computer science.

Reed–Muller codes generalize the Reed–Solomon codes and the Walsh–Hadamard code. Reed–Muller codes are linear block codes that are locally testable, locally decodable, and list decodable. These properties make them particularly useful in the design of probabilistically checkable proofs.

Traditional Reed–Muller codes are binary codes, which means that messages and codewords are binary strings. When r and m are integers with 0 ≤ rm, the Reed–Muller code with parameters r and m is denoted as RM(rm). When asked to encode a message consisting of k bits, where k = i = 0 r ( m i ) {\displaystyle \textstyle k=\sum _{i=0}^{r}{\binom {m}{i}}} holds, the RM(rm) code produces a codeword consisting of 2 bits.

Reed–Muller codes are named after David E. Muller, who discovered the codes in 1954, and Irving S. Reed, who proposed the first efficient decoding algorithm.

Description using low-degree polynomials

Reed–Muller codes can be described in several different (but ultimately equivalent) ways. The description that is based on low-degree polynomials is quite elegant and particularly suited for their application as locally testable codes and locally decodable codes.

Encoder

A block code can have one or more encoding functions C : { 0 , 1 } k { 0 , 1 } n {\textstyle C:\{0,1\}^{k}\to \{0,1\}^{n}} that map messages x { 0 , 1 } k {\textstyle x\in \{0,1\}^{k}} to codewords C ( x ) { 0 , 1 } n {\textstyle C(x)\in \{0,1\}^{n}} . The Reed–Muller code RM(r, m) has message length k = i = 0 r ( m i ) {\displaystyle \textstyle k=\sum _{i=0}^{r}{\binom {m}{i}}} and block length n = 2 m {\displaystyle \textstyle n=2^{m}} . One way to define an encoding for this code is based on the evaluation of multilinear polynomials with m variables and total degree at most r. Every multilinear polynomial over the finite field with two elements can be written as follows: p c ( Z 1 , , Z m ) = S { 1 , , m } | S | r c S i S Z i . {\displaystyle p_{c}(Z_{1},\dots ,Z_{m})=\sum _{\underset {|S|\leq r}{S\subseteq \{1,\dots ,m\}}}c_{S}\cdot \prod _{i\in S}Z_{i}\,.} The Z 1 , , Z m {\textstyle Z_{1},\dots ,Z_{m}} are the variables of the polynomial, and the values c S { 0 , 1 } {\textstyle c_{S}\in \{0,1\}} are the coefficients of the polynomial. Note that there are exactly k = i = 0 r ( m i ) {\textstyle k=\sum _{i=0}^{r}{\binom {m}{i}}} coefficients. With this in mind, an input message consists of k {\textstyle k} values x { 0 , 1 } k {\textstyle x\in \{0,1\}^{k}} which are used as these coefficients. In this way, each message x {\textstyle x} gives rise to a unique polynomial p x {\textstyle p_{x}} in m variables. To construct the codeword C ( x ) {\textstyle C(x)} , the encoder evaluates the polynomial p x {\textstyle p_{x}} at all points Z = ( Z 1 , , Z n ) { 0 , 1 } m {\textstyle Z=(Z_{1},\ldots ,Z_{n})\in \{0,1\}^{m}} , where the polynomial is taken with multiplication and addition mod 2 ( p x ( Z ) mod 2 ) { 0 , 1 } {\textstyle (p_{x}(Z){\bmod {2}})\in \{0,1\}} . That is, the encoding function is defined via C ( x ) = ( p x ( Z ) mod 2 ) Z { 0 , 1 } m . {\displaystyle C(x)=\left(p_{x}(Z){\bmod {2}}\right)_{Z\in \{0,1\}^{m}}\,.}

The fact that the codeword C ( x ) {\displaystyle C(x)} suffices to uniquely reconstruct x {\displaystyle x} follows from Lagrange interpolation, which states that the coefficients of a polynomial are uniquely determined when sufficiently many evaluation points are given. Since C ( 0 ) = 0 {\displaystyle C(0)=0} and C ( x + y ) = C ( x ) + C ( y ) mod 2 {\displaystyle C(x+y)=C(x)+C(y){\bmod {2}}} holds for all messages x , y { 0 , 1 } k {\displaystyle x,y\in \{0,1\}^{k}} , the function C {\displaystyle C} is a linear map. Thus the Reed–Muller code is a linear code.

Example

For the code RM(2, 4), the parameters are as follows:

r = 2 m = 4 k = ( 4 2 ) + ( 4 1 ) + ( 4 0 ) = 6 + 4 + 1 = 11 n = 2 m = 16 {\textstyle {\begin{aligned}r&=2\\m&=4\\k&=\textstyle {\binom {4}{2}}+{\binom {4}{1}}+{\binom {4}{0}}=6+4+1=11\\n&=2^{m}=16\\\end{aligned}}}

Let C : { 0 , 1 } 11 { 0 , 1 } 16 {\textstyle C:\{0,1\}^{11}\to \{0,1\}^{16}} be the encoding function just defined. To encode the string x = 1 1010 010101 of length 11, the encoder first constructs the polynomial p x {\textstyle p_{x}} in 4 variables: p x ( Z 1 , Z 2 , Z 3 , Z 4 ) = 1 + ( 1 Z 1 + 0 Z 2 + 1 Z 3 + 0 Z 4 ) + ( 0 Z 1 Z 2 + 1 Z 1 Z 3 + 0 Z 1 Z 4 + 1 Z 2 Z 3 + 0 Z 2 Z 4 + 1 Z 3 Z 4 ) = 1 + Z 1 + Z 3 + Z 1 Z 3 + Z 2 Z 3 + Z 3 Z 4 {\displaystyle {\begin{aligned}p_{x}(Z_{1},Z_{2},Z_{3},Z_{4})&=1+(1\cdot Z_{1}+0\cdot Z_{2}+1\cdot Z_{3}+0\cdot Z_{4})+(0\cdot Z_{1}Z_{2}+1\cdot Z_{1}Z_{3}+0\cdot Z_{1}Z_{4}+1\cdot Z_{2}Z_{3}+0\cdot Z_{2}Z_{4}+1\cdot Z_{3}Z_{4})\\&=1+Z_{1}+Z_{3}+Z_{1}Z_{3}+Z_{2}Z_{3}+Z_{3}Z_{4}\end{aligned}}} Then it evaluates this polynomial at all 16 evaluation points (0101 means Z 1 = 0 , Z 2 = 1 , Z 3 = 0 , Z 4 = 1 ) {\displaystyle Z_{1}=0,Z_{2}=1,Z_{3}=0,Z_{4}=1)} : p x ( 0000 ) = 1 , p x ( 0001 ) = 1 , p x ( 0010 ) = 0 , p x ( 0011 ) = 1 , {\displaystyle p_{x}(0000)=1,\;p_{x}(0001)=1,\;p_{x}(0010)=0,\;p_{x}(0011)=1,\;}

p x ( 0100 ) = 1 , p x ( 0101 ) = 1 , p x ( 0110 ) = 1 , p x ( 0111 ) = 0 , {\displaystyle p_{x}(0100)=1,\;p_{x}(0101)=1,\;p_{x}(0110)=1,\;p_{x}(0111)=0,\;}

p x ( 1000 ) = 0 , p x ( 1001 ) = 0 , p x ( 1010 ) = 0 , p x ( 1011 ) = 1 , {\displaystyle p_{x}(1000)=0,\;p_{x}(1001)=0,\;p_{x}(1010)=0,\;p_{x}(1011)=1,\;}

p x ( 1100 ) = 0 , p x ( 1101 ) = 0 , p x ( 1110 ) = 1 , p x ( 1111 ) = 0 . {\displaystyle p_{x}(1100)=0,\;p_{x}(1101)=0,\;p_{x}(1110)=1,\;p_{x}(1111)=0\,.} As a result, C(1 1010 010101) = 1101 1110 0001 0010 holds.

Decoder

As was already mentioned, Lagrange interpolation can be used to efficiently retrieve the message from a codeword. However, a decoder needs to work even if the codeword has been corrupted in a few positions, that is, when the received word is different from any codeword. In this case, a local decoding procedure can help.

The algorithm from Reed is based on the following property: you start from the code word, that is a sequence of evaluation points from an unknown polynomial p x {\textstyle p_{x}} of F 2 [ X 1 , X 2 , . . . , X m ] {\textstyle {\mathbb {F} }_{2}} of degree at most r {\textstyle r} that you want to find. The sequence may contains any number of errors up to 2 m r 1 1 {\textstyle 2^{m-r-1}-1} included.

If you consider a monomial μ {\textstyle \mu } of the highest degree d {\textstyle d} in p x {\textstyle p_{x}} and sum all the evaluation points of the polynomial where all variables in μ {\textstyle \mu } have the values 0 or 1, and all the other variables have value 0, you get the value of the coefficient (0 or 1) of μ {\textstyle \mu } in p x {\textstyle p_{x}} (There are 2 d {\textstyle 2^{d}} such points). This is due to the fact that all lower monomial divisors of μ {\textstyle \mu } appears an even number of time in the sum, and only μ {\textstyle \mu } appears once.

To take into account the possibility of errors, you can also remark that you can fix the value of other variables to any value. So instead of doing the sum only once for other variables not in μ {\textstyle \mu } with 0 value, you do it 2 m d {\textstyle 2^{m-d}} times for each fixed valuations of the other variables. If there is no error, all those sums should be equals to the value of the coefficient searched. The algorithm consists here to take the majority of the answers as the value searched. If the minority is larger than the maximum number of errors possible, the decoding step fails knowing there are too many errors in the input code.

Once a coefficient is computed, if it's 1, update the code to remove the monomial μ {\textstyle \mu } from the input code and continue to next monomial, in reverse order of their degree.

Example

Let's consider the previous example and start from the code. With r = 2 , m = 4 {\textstyle r=2,m=4} we can fix at most 1 error in the code. Consider the input code as 1101 1110 0001 0110 (this is the previous code with one error).

We know the degree of the polynomial p x {\textstyle p_{x}} is at most r = 2 {\textstyle r=2} , we start by searching for monomial of degree 2.

  • μ = X 3 X 4 {\textstyle \mu =X_{3}X_{4}}
    • we start by looking for evaluation points with X 1 = 0 , X 2 = 0 , X 3 { 0 , 1 } , X 4 { 0 , 1 } {\textstyle X_{1}=0,X_{2}=0,X_{3}\in \{0,1\},X_{4}\in \{0,1\}} . In the code this is: 1101 1110 0001 0110. The first sum is 1 (odd number of 1).
    • we look for evaluation points with X 1 = 0 , X 2 = 1 , X 3 { 0 , 1 } , X 4 { 0 , 1 } {\textstyle X_{1}=0,X_{2}=1,X_{3}\in \{0,1\},X_{4}\in \{0,1\}} . In the code this is: 1101 1110 0001 0110. The second sum is 1.
    • we look for evaluation points with X 1 = 1 , X 2 = 0 , X 3 { 0 , 1 } , X 4 { 0 , 1 } {\textstyle X_{1}=1,X_{2}=0,X_{3}\in \{0,1\},X_{4}\in \{0,1\}} . In the code this is: 1101 1110 0001 0110. The third sum is 1.
    • we look for evaluation points with X 1 = 1 , X 2 = 1 , X 3 { 0 , 1 } , X 4 { 0 , 1 } {\textstyle X_{1}=1,X_{2}=1,X_{3}\in \{0,1\},X_{4}\in \{0,1\}} . In the code this is: 1101 1110 0001 0110. The third sum is 0 (even number of 1).

The four sums don't agree (so we know there is an error), but the minority report is not larger than the maximum number of error allowed (1), so we take the majority and the coefficient of μ {\textstyle \mu } is 1.

We remove μ {\textstyle \mu } from the code before continue : code : 1101 1110 0001 0110, valuation of μ {\textstyle \mu } is 0001000100010001, the new code is 1100 1111 0000 0111

  • μ = X 2 X 4 {\textstyle \mu =X_{2}X_{4}}
    • 1100 1111 0000 0111. Sum is 0
    • 1100 1111 0000 0111. Sum is 0
    • 1100 1111 0000 0111. Sum is 1
    • 1100 1111 0000 0111. Sum is 0

One error detected, coefficient is 0, no change to current code.

  • μ = X 1 X 4 {\textstyle \mu =X_{1}X_{4}}
    • 1100 1111 0000 0111. Sum is 0
    • 1100 1111 0000 0111. Sum is 0
    • 1100 1111 0000 0111. Sum is 1
    • 1100 1111 0000 0111. Sum is 0

One error detected, coefficient is 0, no change to current code.

  • μ = X 2 X 3 {\textstyle \mu =X_{2}X_{3}}
    • 1100 1111 0000 0111. Sum is 1
    • 1100 1111 0000 0111. Sum is 1
    • 1100 1111 0000 0111. Sum is 1
    • 1100 1111 0000 0111. Sum is 0

One error detected, coefficient is 1, valuation of μ {\textstyle \mu } is 0000 0011 0000 0011, current code is now 1100 1100 0000 0100.

  • μ = X 1 X 3 {\textstyle \mu =X_{1}X_{3}}
    • 1100 1100 0000 0100. Sum is 1
    • 1100 1100 0000 0100. Sum is 1
    • 1100 1100 0000 0100. Sum is 1
    • 1100 1100 0000 0100. Sum is 0

One error detected, coefficient is 1, valuation of μ {\textstyle \mu } is 0000 0000 0011 0011, current code is now 1100 1100 0011 0111.

  • μ = X 1 X 2 {\textstyle \mu =X_{1}X_{2}}
    • 1100 1100 0011 0111. Sum is 0
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 0
    • 1100 1100 0011 0111. Sum is 0

One error detected, coefficient is 0, no change to current code. We know now all coefficient of degree 2 for the polynomial, we can start mononials of degree 1. Notice that for each next degree, there are twice as much sums, and each sums is half smaller.

  • μ = X 4 {\textstyle \mu =X_{4}}
    • 1100 1100 0011 0111. Sum is 0
    • 1100 1100 0011 0111. Sum is 0
    • 1100 1100 0011 0111. Sum is 0
    • 1100 1100 0011 0111. Sum is 0
    • 1100 1100 0011 0111. Sum is 0
    • 1100 1100 0011 0111. Sum is 0
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 0

One error detected, coefficient is 0, no change to current code.

  • μ = X 3 {\textstyle \mu =X_{3}}
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 1
    • 1100 1100 0011 0111. Sum is 0

One error detected, coefficient is 1, valuation of μ {\textstyle \mu } is 0011 0011 0011 0011, current code is now 1111 1111 0000 0100.

Then we'll find 0 for μ = X 2 {\textstyle \mu =X_{2}} , 1 for μ = X 1 {\textstyle \mu =X_{1}} and the current code become 1111 1111 1111 1011.

For the degree 0, we have 16 sums of only 1 bit. The minority is still of size 1, and we found p x = 1 + X 1 + X 3 + X 1 X 3 + X 2 X 3 + X 3 X 4 {\textstyle p_{x}=1+X_{1}+X_{3}+X_{1}X_{3}+X_{2}X_{3}+X_{3}X_{4}} and the corresponding initial word 1 1010 010101

Generalization to larger alphabets via low-degree polynomials

Using low-degree polynomials over a finite field F {\displaystyle \mathbb {F} } of size q {\displaystyle q} , it is possible to extend the definition of Reed–Muller codes to alphabets of size q {\displaystyle q} . Let m {\displaystyle m} and d {\displaystyle d} be positive integers, where m {\displaystyle m} should be thought of as larger than d {\displaystyle d} . To encode a message x F k {\textstyle x\in \mathbb {F} ^{k}} of width k = ( m + d m ) {\displaystyle k=\textstyle {\binom {m+d}{m}}} , the message is again interpreted as an m {\displaystyle m} -variate polynomial p x {\displaystyle p_{x}} of total degree at most d {\displaystyle d} and with coefficient from F {\displaystyle \mathbb {F} } . Such a polynomial indeed has ( m + d m ) {\displaystyle \textstyle {\binom {m+d}{m}}} coefficients. The Reed–Muller encoding of x {\displaystyle x} is the list of all evaluations of p x ( a ) {\displaystyle p_{x}(a)} over all a F m {\displaystyle a\in \mathbb {F} ^{m}} . Thus the block length is n = q m {\displaystyle n=q^{m}} .

Description using a generator matrix

This section may be confusing or unclear to readers. In particular, this section uses dense notation that is not explained well for most readers. Please help clarify the section. There might be a discussion about this on the talk page. (March 2011) (Learn how and when to remove this message)

A generator matrix for a Reed–Muller code RM(r, m) of length N = 2 can be constructed as follows. Let us write the set of all m-dimensional binary vectors as:

X = F 2 m = { x 1 , , x N } . {\displaystyle X=\mathbb {F} _{2}^{m}=\{x_{1},\ldots ,x_{N}\}.}

We define in N-dimensional space F 2 N {\displaystyle \mathbb {F} _{2}^{N}} the indicator vectors

I A F 2 N {\displaystyle \mathbb {I} _{A}\in \mathbb {F} _{2}^{N}}

on subsets A X {\displaystyle A\subset X} by:

( I A ) i = { 1  if  x i A 0  otherwise {\displaystyle \left(\mathbb {I} _{A}\right)_{i}={\begin{cases}1&{\mbox{ if }}x_{i}\in A\\0&{\mbox{ otherwise}}\\\end{cases}}}

together with, also in F 2 N {\displaystyle \mathbb {F} _{2}^{N}} , the binary operation

w z = ( w 1 z 1 , , w N z N ) , {\displaystyle w\wedge z=(w_{1}\cdot z_{1},\ldots ,w_{N}\cdot z_{N}),}

referred to as the wedge product (not to be confused with the wedge product defined in exterior algebra). Here, w = ( w 1 , w 2 , , w N ) {\displaystyle w=(w_{1},w_{2},\ldots ,w_{N})} and z = ( z 1 , z 2 , , z N ) {\displaystyle z=(z_{1},z_{2},\ldots ,z_{N})} are points in F 2 N {\displaystyle \mathbb {F} _{2}^{N}} (N-dimensional binary vectors), and the operation {\displaystyle \cdot } is the usual multiplication in the field F 2 {\displaystyle \mathbb {F} _{2}} .

F 2 m {\displaystyle \mathbb {F} _{2}^{m}} is an m-dimensional vector space over the field F 2 {\displaystyle \mathbb {F} _{2}} , so it is possible to write

( F 2 ) m = { ( y m , , y 1 ) y i F 2 } . {\displaystyle (\mathbb {F} _{2})^{m}=\{(y_{m},\ldots ,y_{1})\mid y_{i}\in \mathbb {F} _{2}\}.}

We define in N-dimensional space F 2 N {\displaystyle \mathbb {F} _{2}^{N}} the following vectors with length N : v 0 = ( 1 , 1 , , 1 ) {\displaystyle N:v_{0}=(1,1,\ldots ,1)} and

v i = I H i , {\displaystyle v_{i}=\mathbb {I} _{H_{i}},}

where 1 ≤ i ≤ m and the Hi are hyperplanes in ( F 2 ) m {\displaystyle (\mathbb {F} _{2})^{m}} (with dimension m − 1):

H i = { y ( F 2 ) m y i = 0 } . {\displaystyle H_{i}=\{y\in (\mathbb {F} _{2})^{m}\mid y_{i}=0\}.}

The generator matrix

The Reed–Muller RM(r, m) code of order r and length N = 2 is the code generated by v0 and the wedge products of up to r of the vi, 1 ≤ im (where by convention a wedge product of fewer than one vector is the identity for the operation). In other words, we can build a generator matrix for the RM(r, m) code, using vectors and their wedge product permutations up to r at a time v 0 , v 1 , , v n , , ( v i 1 v i 2 ) , ( v i 1 v i 2 v i r ) {\displaystyle {v_{0},v_{1},\ldots ,v_{n},\ldots ,(v_{i_{1}}\wedge v_{i_{2}}),\ldots (v_{i_{1}}\wedge v_{i_{2}}\ldots \wedge v_{i_{r}})}} , as the rows of the generator matrix, where 1 ≤ ikm.

Example 1

Let m = 3. Then N = 8, and

X = F 2 3 = { ( 0 , 0 , 0 ) , ( 0 , 0 , 1 ) , ( 0 , 1 , 0 ) , ( 1 , 1 , 1 ) } , {\displaystyle X=\mathbb {F} _{2}^{3}=\{(0,0,0),(0,0,1),(0,1,0)\ldots ,(1,1,1)\},}

and

v 0 = ( 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 ) v 1 = ( 1 , 0 , 1 , 0 , 1 , 0 , 1 , 0 ) v 2 = ( 1 , 1 , 0 , 0 , 1 , 1 , 0 , 0 ) v 3 = ( 1 , 1 , 1 , 1 , 0 , 0 , 0 , 0 ) . {\displaystyle {\begin{aligned}v_{0}&=(1,1,1,1,1,1,1,1)\\v_{1}&=(1,0,1,0,1,0,1,0)\\v_{2}&=(1,1,0,0,1,1,0,0)\\v_{3}&=(1,1,1,1,0,0,0,0).\end{aligned}}}

The RM(1,3) code is generated by the set

{ v 0 , v 1 , v 2 , v 3 } , {\displaystyle \{v_{0},v_{1},v_{2},v_{3}\},\,}

or more explicitly by the rows of the matrix:

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

Example 2

The RM(2,3) code is generated by the set:

{ v 0 , v 1 , v 2 , v 3 , v 1 v 2 , v 1 v 3 , v 2 v 3 } {\displaystyle \{v_{0},v_{1},v_{2},v_{3},v_{1}\wedge v_{2},v_{1}\wedge v_{3},v_{2}\wedge v_{3}\}}

or more explicitly by the rows of the matrix:

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

Properties

The following properties hold:

  1. The set of all possible wedge products of up to m of the vi form a basis for F 2 N {\displaystyle \mathbb {F} _{2}^{N}} .
  2. The RM (r, m) code has rank
    s = 0 r ( m s ) . {\displaystyle \sum _{s=0}^{r}{m \choose s}.}
  3. RM (r, m) = RM (r, m − 1) | RM (r − 1, m − 1) where '|' denotes the bar product of two codes.
  4. RM (r, m) has minimum Hamming weight 2.

Proof

  1. There are
    s = 0 m ( m s ) = 2 m = N {\displaystyle \sum _{s=0}^{m}{m \choose s}=2^{m}=N}

    such vectors and F 2 N {\displaystyle \mathbb {F} _{2}^{N}} have dimension N so it is sufficient to check that the N vectors span; equivalently it is sufficient to check that R M ( m , m ) = F 2 N {\displaystyle \mathrm {RM} (m,m)=\mathbb {F} _{2}^{N}} .

    Let x be a binary vector of length m, an element of X. Let (x)i denote the i element of x. Define

    y i = { v i  if  ( x ) i = 0 v 0 + v i  if  ( x ) i = 1 {\displaystyle y_{i}={\begin{cases}v_{i}&{\text{ if }}(x)_{i}=0\\v_{0}+v_{i}&{\text{ if }}(x)_{i}=1\\\end{cases}}}

    where 1 ≤ im.

    Then I { x } = y 1 y m {\displaystyle \mathbb {I} _{\{x\}}=y_{1}\wedge \cdots \wedge y_{m}}

    Expansion via the distributivity of the wedge product gives I { x } R M ( m , m ) {\displaystyle \mathbb {I} _{\{x\}}\in \mathrm {RM} (m,m)} . Then since the vectors { I { x } x X } {\displaystyle \{\mathbb {I} _{\{x\}}\mid x\in X\}} span F 2 N {\displaystyle \mathbb {F} _{2}^{N}} we have R M ( m , n ) = F 2 N {\displaystyle \mathrm {RM} (m,n)=\mathbb {F} _{2}^{N}} .
  2. By 1, all such wedge products must be linearly independent, so the rank of RM(r, m) must simply be the number of such vectors.
  3. Omitted.
  4. By induction.
    The RM(0, m) code is the repetition code of length N =2 and weight N = 2 = 2. By 1 R M ( m , n ) = F 2 n {\displaystyle \mathrm {RM} (m,n)=\mathbb {F} _{2}^{n}} and has weight 1 = 2 = 2.
    The article bar product (coding theory) gives a proof that the weight of the bar product of two codes C1 , C2 is given by
    min { 2 w ( C 1 ) , w ( C 2 ) } {\displaystyle \min\{2w(C_{1}),w(C_{2})\}}
    If 0 < r < m and if
    1. RM(r,m − 1) has weight 2
    2. RM(r − 1,m − 1) has weight 2 = 2
    then the bar product has weight
    min { 2 × 2 m 1 r , 2 m r } = 2 m r . {\displaystyle \min\{2\times 2^{m-1-r},2^{m-r}\}=2^{m-r}.}

Decoding RM codes

RM(r, m) codes can be decoded using majority logic decoding. The basic idea of majority logic decoding is to build several checksums for each received code word element. Since each of the different checksums must all have the same value (i.e. the value of the message word element weight), we can use a majority logic decoding to decipher the value of the message word element. Once each order of the polynomial is decoded, the received word is modified accordingly by removing the corresponding codewords weighted by the decoded message contributions, up to the present stage. So for a rth order RM code, we have to decode iteratively r+1, times before we arrive at the final received code-word. Also, the values of the message bits are calculated through this scheme; finally we can calculate the codeword by multiplying the message word (just decoded) with the generator matrix.

One clue if the decoding succeeded, is to have an all-zero modified received word, at the end of (r + 1)-stage decoding through the majority logic decoding. This technique was proposed by Irving S. Reed, and is more general when applied to other finite geometry codes.

Description using a recursive construction

A Reed–Muller code RM(r,m) exists for any integers m 0 {\displaystyle m\geq 0} and 0 r m {\displaystyle 0\leq r\leq m} . RM(m, m) is defined as the universe ( 2 m , 2 m , 1 {\displaystyle 2^{m},2^{m},1} ) code. RM(−1,m) is defined as the trivial code ( 2 m , 0 , {\displaystyle 2^{m},0,\infty } ). The remaining RM codes may be constructed from these elementary codes using the length-doubling construction

R M ( r , m ) = { ( u , u + v ) u R M ( r , m 1 ) , v R M ( r 1 , m 1 ) } . {\displaystyle \mathrm {RM} (r,m)=\{(\mathbf {u} ,\mathbf {u} +\mathbf {v} )\mid \mathbf {u} \in \mathrm {RM} (r,m-1),\mathbf {v} \in \mathrm {RM} (r-1,m-1)\}.}

From this construction, RM(r,m) is a binary linear block code (n, k, d) with length n = 2, dimension k ( r , m ) = k ( r , m 1 ) + k ( r 1 , m 1 ) {\displaystyle k(r,m)=k(r,m-1)+k(r-1,m-1)} and minimum distance d = 2 m r {\displaystyle d=2^{m-r}} for r 0 {\displaystyle r\geq 0} . The dual code to RM(r,m) is RM(m-r-1,m). This shows that repetition and SPC codes are duals, biorthogonal and extended Hamming codes are duals and that codes with k = n/2 are self-dual.

Special cases of Reed–Muller codes

Table of all RM(r,m) codes for m≤5

All RM(rm) codes with 0 m 5 {\displaystyle 0\leq m\leq 5} and alphabet size 2 are displayed here, annotated with the standard coding theory notation for block codes. The code RM(rm) is a [ 2 m , k , 2 m r ] 2 {\displaystyle \textstyle _{2}} -code, that is, it is a linear code over a binary alphabet, has block length 2 m {\displaystyle \textstyle 2^{m}} , message length (or dimension) k, and minimum distance 2 m r {\displaystyle \textstyle 2^{m-r}} .

0 1 2 3 4 5 m
RM(m,m)
(2, 2, 1)
universe codes
RM(5,5)
(32,32,1)
RM(4,4)
(16,16,1)
RM(m − 1, m)
(2, 2−1, 2)
SPC codes
RM(3,3)
(8,8,1)
RM(4,5)
(32,31,2)
RM(2,2)
(4,4,1)
RM(3,4)
(16,15,2)
RM(m − 2, m)
(2, 2−m−1, 4)
extended Hamming codes
RM(1,1)
(2,2,1)
RM(2,3)
(8,7,2)
RM(3,5)
(32,26,4)
RM(0,0)
(1,1,1)
RM(1,2)
(4,3,2)
RM(2,4)
(16,11,4)
RM(0,1)
(2,1,2)
RM(1,3)
(8,4,4)
RM(2,5)
(32,16,8)
RM(r, m=2r+1)
(2, 2, 2)
self-dual codes
RM(−1,0)
(1,0, {\displaystyle \infty } )
RM(0,2)
(4,1,4)
RM(1,4)
(16,5,8)
RM(−1,1)
(2,0, {\displaystyle \infty } )
RM(0,3)
(8,1,8)
RM(1,5)
(32,6,16)
RM(−1,2)
(4,0, {\displaystyle \infty } )
RM(0,4)
(16,1,16)
RM(1,m)
(2, m+1, 2)
punctured Hadamard codes
RM(−1,3)
(8,0, {\displaystyle \infty } )
RM(0,5)
(32,1,32)
RM(−1,4)
(16,0, {\displaystyle \infty } )
RM(0,m)
(2, 1, 2)
repetition codes
RM(−1,5)
(32,0, {\displaystyle \infty } )
RM(−1,m)
(2, 0, ∞)
trivial codes

Properties of RM(r,m) codes for r≤1 or r≥m-1

  • RM(0, m) codes are repetition codes of length N = 2, rate R = 1 N {\displaystyle {R={\tfrac {1}{N}}}} and minimum distance d min = N {\displaystyle d_{\min }=N} .
  • RM(1, m) codes are parity check codes of length N = 2, rate R = m + 1 N {\displaystyle R={\tfrac {m+1}{N}}} and minimum distance d min = N 2 {\displaystyle d_{\min }={\tfrac {N}{2}}} .
  • RM(m − 1, m) codes are single parity check codes of length N = 2, rate R = N 1 N {\displaystyle R={\tfrac {N-1}{N}}} and minimum distance d min = 2 {\displaystyle d_{\min }=2} .
  • RM(m − 2, m) codes are the family of extended Hamming codes of length N = 2 with minimum distance d min = 4 {\displaystyle d_{\min }=4} .

References

  1. Massey, James L. (1992), "Deep-space communications and coding: A marriage made in heaven", Advanced Methods for Satellite and Deep Space Communications, Lecture Notes in Control and Information Sciences, vol. 182, Springer-Verlag, pp. 1–17, CiteSeerX 10.1.1.36.4265, doi:10.1007/bfb0036046, ISBN 978-3540558514pdf
  2. "3GPP RAN1 meeting #87 final report". 3GPP. Retrieved 31 August 2017.
  3. Arikan, Erdal (2009). "Channel Polarization: A Method for Constructing Capacity-Achieving Codes for Symmetric Binary-Input Memoryless Channels - IEEE Journals & Magazine". IEEE Transactions on Information Theory. 55 (7): 3051–3073. arXiv:0807.3917. doi:10.1109/TIT.2009.2021379. hdl:11693/11695. S2CID 889822.
  4. Muller, David E. (1954). "Application of Boolean algebra to switching circuit design and to error detection". Transactions of the I.R.E. Professional Group on Electronic Computers. EC-3 (3): 6–12. doi:10.1109/irepgelc.1954.6499441. ISSN 2168-1740.
  5. Reed, Irving S. (1954). "A class of multiple-error-correcting codes and the decoding scheme". Transactions of the IRE Professional Group on Information Theory. 4 (4): 38–49. doi:10.1109/tit.1954.1057465. hdl:10338.dmlcz/143797. ISSN 2168-2690.
  6. Prahladh Harsha et al., Limits of Approximation Algorithms: PCPs and Unique Games (DIMACS Tutorial Lecture Notes), Section 5.2.1.
  7. Trellis and Turbo Coding, C. Schlegel & L. Perez, Wiley Interscience, 2004, p149.

Further reading

External links

Consultative Committee for Space Data Systems
Data compression
Error Correction
Current
Binary Golay code
Concatenated codes
Turbo codes
Proposed
LDPC codes
Telemetry command uplink
Telemetry downlink
Telemetry general
Telemetry modulation systems
Current
BPSK
QPSK
OQPSK
Proposed
GMSK
Frequencies
Networking, interoperability and monitoring
Categories:
Reed–Muller code Add topic