Reed-Muller-code

Een Reed-Muller-code is een lineaire foutcorrigerende code, die gebruikt wordt bij draadloze communicatie, in het bijzonder in communicatie in de ruimte.[1] Bovendien steunt 5G op de nauw verwante polaire codes.[2]

Reed-Mullercodes zijn een generalisatie van Reed-Solomoncodes en Walsh-Hadamardcodes. Traditioneel gebruikt met Reed-Mullercodes als binaire codes, wat betekent dat de boodschappen en codewoorden binaire tekenreeksen zijn. De codes zijn vernoemd naar David E. Muller, een Amerikaanse wiskundige en computerwetenschapper, die de codes in 1954 ontdekte[3] en naar Irving S. Reed, een Amerikaanse wiskundige, die het eerste efficiënte decodeeralgoritme voor de codes voorstelde.[4]

Constructie

Er bestaan verschillende equivalente manieren om Reed-Mullercodes te beschrijven. Hier wordt gebruik gemaakt van de methode met generatormatrix. Een andere manier is via veeltermen. De generator-matrix van een Reed-Muller-code met lengte n = 2 d {\displaystyle n=2^{d}} wordt opgebouwd als volgt. Beschouw eerst de vectorruimte met dimensie d over het eindig lichaam F 2 = G F ( 2 ) {\displaystyle \mathbb {F} _{2}=GF(2)} . Deze vectorruimte bevat 2 d {\displaystyle 2^{d}} elementen.

F 2 d = { x 1 , , x 2 d } {\displaystyle \mathbb {F} _{2}^{d}=\{x_{1},\ldots ,x_{2^{d}}\}}

We definiëren nu in de n-dimensionale ruimte over F 2 {\displaystyle \mathbb {F} _{2}} de 'indicator-vectoren':

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

op deelverzamelingen A F 2 d {\displaystyle A\subset \mathbb {F} _{2}^{d}} door:

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

en we definiëren in ( F 2 ) n {\displaystyle (\mathbb {F} _{2})^{n}} de volgende binaire bewerking 'puntproduct':

w z = ( w 1 × z 1 , , w n × z n ) {\displaystyle w\wedge z=(w_{1}\times z_{1},\ldots ,w_{n}\times z_{n})}


F 2 d {\displaystyle \mathbb {F} _{2}^{d}} is een d {\displaystyle d} -dimensionale vectorruimte over F 2 {\displaystyle \mathbb {F} _{2}} , en is dus te schrijven als

( F 2 ) d = { ( y 1 , , y d ) | y i F 2 } {\displaystyle (\mathbb {F} _{2})^{d}=\{(y_{1},\ldots ,y_{d})|y_{i}\in \mathbb {F} _{2}\}}

We definiëren nu de volgende vectoren ter lengte n : v 0 = ( 1 , 1 , 1 , 1 , 1 , 1 , 1 , 1 ) {\displaystyle n:v_{0}=(1,1,1,1,1,1,1,1)} en

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

waarbij H i {\displaystyle H_{i}} hypervlakken in ( F 2 ) d {\displaystyle (\mathbb {F} _{2})^{d}} zijn (van dimensie 2 d 1 {\displaystyle 2^{d}-1} ):

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

De Reed-Muller RM(d,r)-code van de orde r {\displaystyle r} en lengte n = 2 d {\displaystyle n=2^{d}} is de lineaire code die wordt gegenereerd door v 0 {\displaystyle v_{0}} en de puntproducten tot en met r {\displaystyle r} van de vectoren v i , 1 i m {\displaystyle v_{i},1\leq i\leq m} .

Voorbeeld 1

Zij d = 3 {\displaystyle d=3} . Dan is derhalve n = 8 {\displaystyle n=8} en

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

en

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{matrix}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{matrix}}}

De RM(3,1)-code wordt gegenereerd door de verzameling

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

of, meer expliciet geformuleerd, door de rijen van de 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}}}

De dimensie van de code is 4, dus de code bestaat uit 16 codewoorden.

Voorbeeld 2

De RM(3,2)-code wordt gegenereerd door de verzameling

{ 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}\}}

ofwel door de volgende 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}}}

Eigenschappen

Volgende eigenschappen gelden voor Reed-Mullercodes:

  1. De verzameling van alle mogelijke puntproducten tot en met d {\displaystyle d} van de vectoren v i {\displaystyle v_{i}} vormt een basis van F 2 n {\displaystyle \mathbb {F} _{2}^{n}} .
  2. De RM(d,r)-code heeft dimensie s = 0 r ( d s ) {\displaystyle \sum _{s=0}^{r}{d \choose s}} .
  3. Er geldt RM(d,r) = RM(d-1,r) | RM(d-1,r-1) waarbij '|' voor twee lineaire codes C 2 C 1 {\displaystyle C_{2}\subset C_{1}} is gedefinieerd als C 1 | C 2 = { ( c 1 | c 1 + c 2 ) c 1 C 1 , c 2 C 2 } {\displaystyle C_{1}|C_{2}=\{(c_{1}|c_{1}+c_{2})\mid c_{1}\in C_{1},c_{2}\in C_{2}\}} .
  4. RM(d,r) heeft minimale Hammingafstand 2 d r {\displaystyle 2^{d-r}} .
Bronnen, noten en/of referenties
  1. (en) James L. Massey (september 1992). Advanced Methods for Satellite and Deep Space Communications. Proceedings of an International Seminar Organized by Deutsche Forschungsanstalt für Luft- und Raumfahrt (DLR) (Springer). DOI: 10.1007/BFb0036046. Geraadpleegd op 13 september 2019.
  2. (en) Erdal Arikan (19 juni 2009). Channel Polarization: A Method for Constructing Capacity-Achieving Codes for Symmetric Binary-Input Memoryless Channels. IEEE Transactions on Information Theory 55 (7): 3051–3073 (IEEE). ISSN: 0018-9448. DOI: 10.1109/TIT.2009.2021379. Geraadpleegd op 13 september 2019.
  3. (en) David E. Muller (september 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 (IEEE). ISSN: 2168–1740. DOI: 10.1109/IREPGELC.1954.6499441. Geraadpleegd op 13 september 2019.
  4. (en) Irving S. Reed (september 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 (IEEE). ISSN: 2168-2690. DOI: 10.1109/TIT.1954.1057465. Geraadpleegd op 13 september 2019.