Mee bezig Mee bezig
Aan deze pagina of deze sectie wordt de komende uren of dagen nog druk gewerkt.
Klik op geschiedenis voor de laatste ontwikkelingen.

Een binaire Goppa Code, doorgaans alleen Goppa Code genoemd, is een foutencorrigerende code. De code is vernoemd naar de Russische wiskundige Velerii Denisovich Goppa. In McEliece-cryptografie wordt bijvoorbeeld gebruik gemaakt van Binaire Goppa Codes. Een Binaire Goppa Code is iets anders dan een algebraïsche Goppa Code.

Voorwaardes

bewerken

Er zijn verschillende definities te geven voor een Goppa Code, en hier wordt toegewerkt naar een polynomiale definitie. Voordat we dat kunnen doen zijn er enkele parameters nodig. De volgende gegevens zijn gebruikelijk voor een Goppa Code:

  • Kies   met  .
  • De code is gedefinieerd over het lichaam  . Noem de rij afzonderlijke elementen uit dat lichaam,   lexicografisch geordend.
  • Voor het aantal fouten dat gecorrigeerd kan worden door de code, t, kiezen we  . Voor   zijn bijvoorbeeld t = 32, t = 70, of t = 100.
  • Neem nu   als een irreducibel monisch polynoom van graad t.
  • Laat  .

In dit geval geldt dat  .

Definitie

bewerken

Een definitie van de Goppa Code  , is nu

 

De polynomen   , kunnen gezien worden als vectoren over  .
Ze vormen een pariteitscontrole-matrix voor de code  .

Algoritme van Patterson

bewerken

In 1975 heeft Patterson(link) een algoritme ontwikkeld om in polynomiale tijd t fouten te kunnen corrigeren uit de Goppa Code.
Voordat het algoritme weergegeven kan worden, is de definitie nodig van de norm van een polynoom.

Norm van een polynoom

bewerken

Voor een polynoom   geldt dat de norm  , met   de graad van  .

Bij rationale functies geldt  . Bijvoorbeeld  .

Algoritme

bewerken

Het doel is om maximaal t fouten te verbeteren uit een Goppa Code  . We starten met een codewoord  , met maximaal t fouten. Dat betekent dat er in het codewoord hoogstens t maal een 1 met een 0 verwisseld is, of andersom.

  • Bereken   over het lichaam  . Als deze som nul is in het lichaam, dan zijn er blijkbaar geen fouten in de code. Het algoritme geeft dan output w.
  • Bereken de wortel van   over het lichaam  .
  • Noem deze berekende wortel s en bekijk deze in het lichaam  . De graad van s is kleiner dan t.
  • De vectoren   en   genereren een rooster  .
De norm   van een vector   is per definitie gelijk aan de norm van het polynoom  .
Zo is de lengte van de vector   gelijk aan  .
  • Vind met behulp van basisreductie een basis   van minimale lengte. Deze zal kleiner of gelijk zijn aan  .
  • Bereken  
  • Deel door de coëfficient van de eerste term, zodat   monisch wordt.
  • Ontbindt   in lineaire factoren van de vorm  . Dit zullen t factoren zijn.
  • Output c, is de gecorrigeerd code w, met een correctie op de plaatsen i, waar  .

Voor een uitgebreid voorbeeld van dit algoritme wordt verwezen naar het artikel van Bernstein. [1]




Referenties en bronvermelding

bewerken

[[Categorie:Discrete wiskunde]] [[Categorie:Algebraïsche getaltheorie]]