Goppa Codes
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 gebruikgemaakt van Binaire Goppa Codes. Een Binaire Goppa Code is iets anders dan een algebraïsche Goppa Code.
Inhoud |
Voorwaardes [bewerken]
Er zijn verschillende definities te geven voor een Goppa Code. 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 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 woord
, met maximaal t fouten. Dat betekent dat er een coodewoord
is zodat 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ëfficiënt van de hoogste macht van x, 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
|
met
.
. Noem de rij afzonderlijke elementen uit dat lichaam,
lexicografisch geordend.
. Voor
zijn bijvoorbeeld t = 32, t = 70, of t = 100.
als een
.
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.
over het lichaam
. De graad van s is kleiner dan t.
en
genereren een
.
van een vector
is per definitie gelijk aan de norm van het polynoom
.
.
van minimale lengte. Deze zal kleiner of gelijk zijn aan
.
monisch wordt.
. Dit zullen t factoren zijn.
.