Gebruiker:Thijsjanlard

Uit Wikipedia, de vrije encyclopedie
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 | brontekst 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 | brontekst 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 | brontekst 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 | brontekst bewerken]

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

Bij rationale functies geldt . Bijvoorbeeld .

Algoritme[bewerken | brontekst 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 | brontekst bewerken]

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