BCH-code (coderingstheorie)

In de coderingstheorie is een BCH-code een cyclische foutcorrigerende code die gegenereerd wordt door een polynoom over een eindig lichaam. BCH-codes zijn in 1959 bedacht door Hocquenghem en onafhankelijk van deze in 1960 door Bose en Ray-Chaudhuri. De afkorting BCH is opgebouwd uit hun initialen.

Een groot voordeel van BCH-codes is dat ze worden gedecodeerd door middel van een algebraïsche methode die bekendstaat als syndroom decoderen. Hierdoor kan de benodigde elektronische hardware eenvoudig zijn, en is het energieverbruik beperkt. Daarnaast zijn ze als een klasse codes flexibel, met instelbaarheid van bloklengte en inzetbaarheid bij in de praktijk voorkomende bitfoutkansen. Dus bij een specificatie kan een code worden ontworpen (vanzelfsprekend wel binnen de wiskundige grenzen).

Technisch uitgedrukt is een BCH-code een multiniveau, cyclische, fout-corrigerende, variabele lengte digitale code, die gebruikt wordt voor het corrigeren van foutpatronen met meer dan één bitfout per blok. BCH-codes kunnen ook worden gebruikt met multiniveau phase-shift keying, mits het aantal niveaus een priemgetal is, of een macht van een priemgetal. Een BCH-code met 11 niveaus is gebruikt voor het representeren van 10 decimale digits plus een teken.

Constructie

Een BCH-code wordt gegenereerd door een polynoom over een eindig lichaam G F ( q ) {\displaystyle \mathbb {GF} (q)} , waarin q {\displaystyle q} een macht van een priemgetal is.

Een eenvoudige klasse BCH-codes

Definitie

Voor positieve gehele getallen q , m , n , {\displaystyle q,\,m,\,n,} en d {\displaystyle d} met q {\displaystyle q} een priemgetal, n = q m 1 {\displaystyle n=q^{m}-1} en 2 d n {\displaystyle 2\leq d\leq n} , wordt een polynoomcode met bloklengte n {\displaystyle n} en een minimum hammingafstand van minstens d {\displaystyle d} bepaald door de genererende polynoom die het kleinste gemeenschappelijke veelvoud g ( x ) = k g v ( m 1 ( x ) , , m d 1 ( x ) ) {\displaystyle g(x)={\rm {kgv}}(m_{1}(x),\ldots ,m_{d-1}(x))} is. Daarin is m i ( x ) {\displaystyle m_{i}(x)} de minimale polynoom van α i {\displaystyle \alpha ^{i}} over G F ( q ) {\displaystyle \mathbb {GF} (q)} , met α {\displaystyle \alpha } een primitief element in G F ( q m ) {\displaystyle \mathbb {GF} (q^{m})} .

Voorbeeld

In het voorbeeld is q = 2 {\displaystyle q=2} en m = 4 {\displaystyle m=4} , dus n = 15 {\displaystyle n=15} .

Volgens de theorie bestaat er een primitieve wortel α G F ( 16 ) {\displaystyle \alpha \in \mathbb {GF} (16)} met een minimale polynoom van graad m {\displaystyle m} die voldoet aan:

α 4 + α + 1 = 0 {\displaystyle \alpha ^{4}+\alpha +1=0}

De bijbehorende minimale polynoom over G F ( 2 ) {\displaystyle \mathbb {GF} (2)} is:

m 1 ( x ) = x 4 + x + 1 {\displaystyle m_{1}(x)=x^{4}+x+1}

In G F ( 2 ) {\displaystyle \mathbb {GF} (2)} geldt ( a + b ) 2 = a 2 + 2 a b + b 2 = a 2 + b 2 {\displaystyle (a+b)^{2}=a^{2}+2ab+b^{2}=a^{2}+b^{2}} , zodat:

m 1 ( α 2 ) = α 8 + α 2 + 1 = ( m 1 ( α ) ) 2 = 0 {\displaystyle m_{1}(\alpha ^{2})=\alpha ^{8}+\alpha ^{2}+1=(m_{1}(\alpha ))^{2}=0}

Dus α 2 {\displaystyle \alpha ^{2}} is een wortel van m 1 ( x ) {\displaystyle m_{1}(x)} , en blijkbaar is:

m 2 ( x ) = m 1 ( x ) = x 4 + x + 1 {\displaystyle m_{2}(x)=m_{1}(x)=x^{4}+x+1}

De minimale polynoom m 3 ( x ) {\displaystyle m_{3}(x)} van α 3 {\displaystyle \alpha ^{3}} is ook van de graad 4:

Nu is:

α 4 + α + 1 = 0 {\displaystyle \alpha ^{4}+\alpha +1=0} ,

dus

α 4 = α + 1 {\displaystyle \alpha ^{4}=\alpha +1} ,

zodat

α 6 = α 4 α 2 = ( α + 1 ) α 2 = α 3 + α 2 {\displaystyle \alpha ^{6}=\alpha ^{4}\alpha ^{2}=(\alpha +1)\alpha ^{2}=\alpha ^{3}+\alpha ^{2}}
α 9 = ( α 4 ) 2 α = ( α 2 + 1 ) α = α 3 + α {\displaystyle \alpha ^{9}=(\alpha ^{4})^{2}\alpha =(\alpha ^{2}+1)\alpha =\alpha ^{3}+\alpha }
α 12 = ( α 4 ) 3 = ( α + 1 ) 3 = ( α 2 + 1 ) ( α + 1 ) = α 3 + α 2 + α + 1 {\displaystyle \alpha ^{12}=(\alpha ^{4})^{3}=(\alpha +1)^{3}=(\alpha ^{2}+1)(\alpha +1)=\alpha ^{3}+\alpha ^{2}+\alpha +1}

Het blijkt dat

( α 3 ) 4 + ( α 3 ) 3 + ( α 3 ) 2 + α 3 + 1 = α 12 + α 9 + α 6 + α 3 + 1 = {\displaystyle (\alpha ^{3})^{4}+(\alpha ^{3})^{3}+(\alpha ^{3})^{2}+\alpha ^{3}+1=\alpha ^{12}+\alpha ^{9}+\alpha ^{6}+\alpha ^{3}+1=}
= α 3 + α 2 + α + 1 + α 3 + α + α 3 + α 2 + α 3 + 1 = 0 {\displaystyle =\alpha ^{3}+\alpha ^{2}+\alpha +1+\alpha ^{3}+\alpha +\alpha ^{3}+\alpha ^{2}+\alpha ^{3}+1=0}

De minimale polynoom van α 3 {\displaystyle \alpha ^{3}} is de polynoom

m 3 ( x ) = x 4 + x 3 + x 2 + x + 1 {\displaystyle m_{3}(x)=x^{4}+x^{3}+x^{2}+x+1} .

Op vergelijkbare wijze vindt men:

m 4 ( x ) = m 2 ( x ) = x 4 + x + 1 {\displaystyle m_{4}(x)=m_{2}(x)=x^{4}+x+1}
m 5 ( x ) = x 2 + x + 1 {\displaystyle m_{5}(x)=x^{2}+x+1}
m 6 ( x ) = m 3 ( x ) = x 4 + x 3 + x 2 + x + 1 {\displaystyle m_{6}(x)=m_{3}(x)=x^{4}+x^{3}+x^{2}+x+1}
m 7 ( x ) = x 4 + x 3 + 1 {\displaystyle m_{7}(x)=x^{4}+x^{3}+1}

Deze polynomen zijn juist de vier irreducibele polynomen.

De BCH-code met d = 1 , 2 , 3 {\displaystyle d=1,\,2,\,3} heeft als genererende polynoom

d ( x ) = m 1 ( x ) = x 4 + x + 1 {\displaystyle d(x)=m_{1}(x)=x^{4}+x+1}

De minimale hammingafstand is minstens 3 en hij corrigeert 1 bitfout. Omdat de genererende polynoom van de graad 4 is, heeft deze code 11 data-bits en 4 checkbits.

De BCH-code met d = 4 , 5 {\displaystyle d=4,\,5} heeft als genererende polynoom

d ( x ) = k g v ( m 1 ( x ) , m 3 ( x ) ) = ( x 4 + x + 1 ) ( 1 + x + x 2 + x 3 + x 4 ) = x 8 + x 7 + x 6 + x 4 + 1 {\displaystyle {\begin{aligned}d(x)&{}={\rm {kgv}}(m_{1}(x),m_{3}(x))=(x^{4}+x+1)(1+x+x^{2}+x^{3}+x^{4})\\&{}=x^{8}+x^{7}+x^{6}+x^{4}+1\end{aligned}}}

De minimale hammingafstand is minstens 5 en de code corrigeert 2 bitfouten. Omdat het genererende polynoom de graad 8 heeft, bevat deze code 7 data-bits en 8 checkbits.

De BCH-code met d = 6 , 7 {\displaystyle d=6,\,7} heeft als genererende polynoom

d ( x ) = k g v ( m 1 ( x ) , m 3 ( x ) , m 5 ( x ) ) = ( x 4 + x + 1 ) ( 1 + x + x 2 + x 3 + x 4 ) ( x 2 + x + 1 ) = x 10 + x 8 + x 5 + x 4 + x 2 + x + 1 {\displaystyle {\begin{aligned}d(x)&{}={\rm {kgv}}(m_{1}(x),m_{3}(x),m_{5}(x))\\&{}=(x^{4}+x+1)(1+x+x^{2}+x^{3}+x^{4})(x^{2}+x+1)\\&{}=x^{10}+x^{8}+x^{5}+x^{4}+x^{2}+x+1\end{aligned}}}

De minimale hammingafstand is minstens 7 en de code corrigeert 3 bitfouten. Deze code heeft 5 data-bits en 10 checkbits.

De BCH-code met d = 8 {\displaystyle d=8} en hoger heeft als genererende polynoom

d ( x ) = k g v ( m 1 ( x ) , m 3 ( x ) , m 5 ( x ) , m 7 ( x ) ) = ( x 4 + x + 1 ) ( 1 + x + x 2 + x 3 + x 4 ) ( x 2 + x + 1 ) ( x 4 + x 3 + 1 ) = x 14 + x 13 + x 12 + + x 2 + x + 1 {\displaystyle {\begin{aligned}d(x)&{}={\rm {kgv}}(m_{1}(x),m_{3}(x),m_{5}(x),m_{7}(x))\\&{}=(x^{4}+x+1)(1+x+x^{2}+x^{3}+x^{4})(x^{2}+x+1)(x^{4}+x^{3}+1)\\&{}=x^{14}+x^{13}+x^{12}+\cdots +x^{2}+x+1\end{aligned}}}

Deze code heeft minstens hammingafstand 15 en corrigeert 7 bitfouten. De code heeft 1 data-bit en 14 checkbits. Feitelijk bestaat deze code uit de volgende twee codewoorden: 000000000000000 and 111111111111111.

Algemene BCH-codes

Algemene BCH-codes wijken op twee punten af van de hierboven behandelde eenvoudige BCH-codes. Ten eerste is de eis dat n = q m 1 {\displaystyle n=q^{m}-1} vervangen door een meer algemene eis. Ten tweede is het zo dat de opeenvolgende wortels van de generatorpolynoom niet bij α 1 {\displaystyle \alpha ^{1}} hoeven te beginnen; voldoende is dus als de rij eruitziet als volgt: α c , , α c + d 2 {\displaystyle \alpha ^{c},\ldots ,\alpha ^{c+d-2}} (in plaats van α , , α d 1 {\displaystyle \alpha ,\ldots ,\alpha ^{d-1}} ).

Definitie

Neem een eindig lichaam G F ( q ) {\displaystyle \mathbb {GF} (q)} , waarbij q {\displaystyle q} een macht is van een priemgetal. Kies positieve gehele getallen m , n , d , c {\displaystyle m,n,d,c} zodat 2 d n {\displaystyle 2\leq d\leq n} , g g d ( n , q ) = 1 {\displaystyle {\rm {ggd}}(n,q)=1} , en m {\displaystyle m} is de multiplicatieve orde van q {\displaystyle q} modulo n {\displaystyle n} (dat wil zeggen m {\displaystyle m} is de kleinste macht met de eigenschap dat q m = 1 {\displaystyle q^{m}=1} modulo n {\displaystyle n} ).

Zoals hierboven is α {\displaystyle \alpha } een primitieve n {\displaystyle n} -de machts eenheidswortel in G F ( q m ) {\displaystyle \mathbb {GF} (q^{m})} , en is (voor alle i) m i ( x ) {\displaystyle m_{i}(x)} de minimale polynoom over G F ( q ) {\displaystyle \mathbb {GF} (q)} van α i {\displaystyle \alpha ^{i}} . De generatorpolynoom van de BCH-code is nu gedefinieerd als het kleinste gemeenschappelijke veelvoud g ( x ) = k g v ( m c ( x ) , , m c + d 2 ( x ) ) {\displaystyle g(x)={\rm {kgv}}(m_{c}(x),\ldots ,m_{c+d-2}(x))} .

NB

Als n = q m 1 {\displaystyle n=q^{m}-1} , zoals in het eenvoudige geval, is g g d ( n , q ) {\displaystyle {\rm {ggd}}(n,q)} gelijk aan 1, en is de orde van q mod n {\displaystyle q\mod n} automatisch gelijk aan m {\displaystyle m} . De 'eenvoudige' BCH-code is dus inderdaad een specifiek voorbeeld binnen de algemene BCH-codes.

Eigenschappen

1. De generatorpolynoom van een BCH-code heeft als graad ten hoogste ( d 1 ) m {\displaystyle (d-1)m} . En als q = 2 {\displaystyle q=2} en c = 1 {\displaystyle c=1} , dan is de graad van de generatorpolynoom ten hoogste d m / 2 {\displaystyle dm/2} .

Bewijs: elke minimale polynoom m i ( x ) {\displaystyle m_{i}(x)} heeft als graad ten hoogste m {\displaystyle m} . Het kleinste gemeenschappelijke veelvoud van d 1 {\displaystyle d-1} minimale polynomen heeft dus ten hoogste de graad ( d 1 ) m {\displaystyle (d-1)m} . En als q = 2 {\displaystyle q=2} , is m i ( x ) = m 2 i ( x ) {\displaystyle m_{i}(x)=m_{2i}(x)} voor alle i {\displaystyle i} . Dus g ( x ) {\displaystyle g(x)} is het kleinste gemeenschappelijke veelvoud van ten hoogste d / 2 {\displaystyle d/2} minimale polynomen m i ( x ) {\displaystyle m_{i}(x)} voor oneven indices i {\displaystyle i} , die elk ten hoogste de graad m {\displaystyle m} hebben.

2. Een BCH-code heeft als minimale hammingafstand ten minste d {\displaystyle d} . Bewijs in het eenvoudige geval (het bewijs voor het algemene geval is vergelijkbaar). Neem aan dat p ( x ) {\displaystyle p(x)} een codewoord is met minder dan d {\displaystyle d} digits ongelijk aan nul. Dan is

p ( x ) = b 1 x j 1 + + b d 1 x j d 1 ,  waarbij  j 1 < j 2 < < j d 1 {\displaystyle p(x)=b_{1}x^{j_{1}}+\ldots +b_{d-1}x^{j_{d-1}},{\text{ waarbij }}j_{1}<j_{2}<\ldots <j_{d-1}}

We wisten dat α 1 , , α d 1 {\displaystyle \alpha ^{1},\ldots ,\alpha ^{d-1}} wortels zijn van g ( x ) {\displaystyle g(x)} , en dus ook van p ( x ) {\displaystyle p(x)} . Hieruit volgt dat b 1 , , b d 1 {\displaystyle b_{1},\ldots ,b_{d-1}} aan de volgende vergelijkingen voldoen voor i = 1 , , d 1 {\displaystyle i=1,\ldots ,d-1} :

p ( α i ) = b 1 α i j 1 + b 2 α i j 2 + + b d 1 α i j d 1 = 0 {\displaystyle p(\alpha ^{i})=b_{1}\alpha ^{ij_{1}}+b_{2}\alpha ^{ij_{2}}+\ldots +b_{d-1}\alpha ^{ij_{d-1}}=0}

Dit delen we nu door α i j 1 {\displaystyle \alpha ^{ij_{1}}} , en we definiëren k l = j l j 1 {\displaystyle k_{l}=j_{l}-j_{1}} , om als resultaat te verkrijgen

b 1 + b 2 α i k 2 + + b d 1 α i k d 1 = 0 {\displaystyle b_{1}+b_{2}\alpha ^{ik_{2}}+\ldots +b_{d-1}\alpha ^{ik_{d-1}}=0}

voor alle i {\displaystyle i} , hetgeen equivalent is met

[ 1 α k 2 α k d 1 1 α 2 k 2 α 2 k d 1 1 α ( d 1 ) k 2 α ( d 1 ) k d 1 ] [ b 1 b 2 b d 1 ] = [ 0 0 0 ] {\displaystyle {\begin{bmatrix}1&\alpha ^{k_{2}}&\ldots &\alpha ^{k_{d-1}}\\1&\alpha ^{2k_{2}}&\ldots &\alpha ^{2k_{d-1}}\\\vdots &\vdots &&\vdots \\1&\alpha ^{(d-1)k_{2}}&\ldots &\alpha ^{(d-1)k_{d-1}}\\\end{bmatrix}}{\begin{bmatrix}b_{1}\\b_{2}\\\vdots \\b_{d-1}\end{bmatrix}}={\begin{bmatrix}0\\0\\\vdots \\0\end{bmatrix}}}

Deze matrix is een vandermonde-matrix, en heeft als determinant

det ( V ) = 1 i < j d 1 ( α k j α k i ) {\displaystyle \det(V)=\prod _{1\leq i<j\leq d-1}(\alpha ^{k_{j}}-\alpha ^{k_{i}})} ,

hetgeen ongelijk aan nul is. Hieruit volgt dat b 1 , , b d 1 = 0 {\displaystyle b_{1},\ldots ,b_{d-1}=0} , en dus p ( x ) = 0 {\displaystyle p(x)=0} .

3. Een BCH-code is cyclisch.

Bewijs: een polynoomcode met bloklengte n {\displaystyle n} is dan en slechts dan cyclisch als zijn generatorpolynoom een deler is van x n 1 {\displaystyle x^{n}-1} . Omdat g ( x ) {\displaystyle g(x)} de minimale polynoom is met wortels α c , , α c + d 2 {\displaystyle \alpha ^{c},\ldots ,\alpha ^{c+d-2}} , behoeft slechts te worden gecontroleerd dat alle α c , , α c + d 2 {\displaystyle \alpha ^{c},\ldots ,\alpha ^{c+d-2}} wortel zijn van x n 1 {\displaystyle x^{n}-1} . Echter, dit volgt direct uit het feit dat α {\displaystyle \alpha } per definitie een n {\displaystyle n} de machts eenheidswortel is.

Speciale gevallen

  • Een BCH-code met c = 1 {\displaystyle c=1} wordt een BCH-code in engere zin genoemd.
  • Een BCH-code met n = q m 1 {\displaystyle n=q^{m}-1} wordt primitief genoemd.

De hierboven beschouwde "eenvoudige" BCH-codes vormen precies de primitieve BCH-codes in engere zin.

  • Een BCH-code in engere zin met n = q 1 {\displaystyle n=q-1} wordt een Reed-Solomon code genoemd.