Reed-Solomon Code

Kokeneet kirjoittajat eivät ole vielä tarkistaneet sivun nykyistä versiota, ja se voi poiketa merkittävästi 27. joulukuuta 2021 tarkistetusta versiosta . tarkastukset vaativat 3 muokkausta .
Reed-Solomon Code
Nimetty Irving Reed [d] ja Gustav Solomon [d]
Tyyppi
Lohkon pituus
Viestin pituus
Etäisyys
Aakkosten koko yksinkertaiselle , usein
Nimitys
 Mediatiedostot Wikimedia Commonsissa

Reed -Solomon -koodit ( eng.  Reed-Solomon -koodit ) ovat ei-binaarisia syklisiä koodeja , joiden avulla voit korjata virheitä tietolohkoissa. Koodivektorin elementit eivät ole bittejä, vaan bittiryhmiä (lohkoja). Reed-Solomon-koodit ovat hyvin yleisiä, ja ne toimivat tavujen (oktettien) kanssa.

Reed-Solomon-koodi on BCH-koodin erikoistapaus .

Sitä käytetään tällä hetkellä laajalti tietojen palautusjärjestelmissä CD- levyiltä , ​​kun luodaan arkistoja, joissa on tietoja palautusta varten vaurioiden varalta, kohinaa korjaavassa koodauksessa .

Historia

Solomon-koodin keksivät vuonna 1960 Reid ja Gustav Solomon Massachusetts Institute laboratoriosta Ajatus tämän koodin käytöstä esiteltiin artikkelissa "Polynomikoodit tiettyjen rajallisten kenttien yli". Tehokkaita dekoodausalgoritmeja ehdottivat vuonna 1969 Alvin Berlekamp ja James Massey ( Berlekamp-Massey-algoritmi ) ja vuonna 1977 David Mandelbaum (menetelmä Euclid-algoritmilla [1] ). Reed-Solomon-koodia käytettiin ensimmäisen kerran vuonna 1982 CD-levyjen sarjatuotannossa.

Muodollinen kuvaus

Reed-Solomon-koodit ovat tärkeä erikoistapaus BCH-koodista , jonka generaattoripolynomijuuret ovat samassa kentässä , jonka päälle koodi on rakennettu ( ). Antaa olla  osa järjestyskentän . Jos  on primitiivinen elementti, niin sen järjestys on , eli . Sitten normalisoitu minimiasteen polynomi kentän yli, jonka juuret ovat elementin peräkkäiset potenssit , on Reed-Solomon-koodin generoiva polynomi kentän yli :

jossa  on jokin kokonaisluku (mukaan lukien 0 ja 1), jonka avulla on joskus mahdollista yksinkertaistaa kooderia. Yleensä oletetaan . Polynomin aste on .

Tuloksena olevan koodin pituus , minimietäisyys (on kaikkien koodisanaparien kaikkien Hamming-etäisyyksien minimi , katso rivikoodi ). Koodi sisältää tarkistussymbolit, joissa ilmaisee polynomin astetta; tietosymbolien määrä . Siten Reed-Solomon-koodi on myös erotettavissa oleva koodi, jolla on maksimietäisyys (se on optimaalinen Singletonin rajoituksen merkityksessä ).

Koodipolynomi saadaan tietopolynomista , kertomalla ja :

Ominaisuudet

Reed-Solomon-koodi over , joka korjaa virheet, vaatii pariteettisymboleja ja sitä voidaan käyttää mielivaltaisten tai pienempien virhepakettien korjaamiseen. Reiger-rajalauseen mukaan Reed-Solomon-koodit ovat optimaalisia paketin pituuden suhteen ja virheenkorjausmahdollisuuden suhteen - ylimääräisiä tarkistussymboleja käyttämällä virheet korjataan (ja vähemmän).

Lause (Reiger-sidottu) . Jokaisen lineaarisen lohkokoodin, joka korjaa kaikki enintään pituiset purskeet, on sisällettävä vähintään pariteettisymbolit.

Reed-Solomon-koodin kaksoiskoodi on myös Reed-Solomon-koodi. Syklisen koodin kaksoiskoodi on sen tarkistuspolynomin luoma koodi.

Matriisi generoi Reed-Solomon-koodin, jos ja vain jos mikä tahansa matriisin sivuarvo on nollasta poikkeava.

Reed-Solomon-koodia pilkkottaessa tai lyhennettäessä saadaan Reed-Solomon-koodi uudelleen. Lävistys  on toimenpide, joka poistaa yhden tarkistusmerkin. Koodin pituus pienenee yhdellä, mitta säilyy. Koodietäisyyden on pienennettävä yhdellä, muuten poistettu merkki olisi hyödytön. Lyhennys  - korjaamme mielivaltaisen koodisarakkeen ja valitsemme vain ne vektorit, jotka sisältävät tässä sarakkeessa 0. Tämä vektorijoukko muodostaa aliavaruuden .

Useita virheenkorjauksia

Reed-Solomon-koodi on yksi tehokkaimmista koodeista useiden virhepurskeiden korjaamiseen. Sitä käytetään kanavilla, joissa virhepurskeita voi esiintyä niin usein, että niitä ei voida enää korjata yksittäisiä virheitä korjaavilla koodeilla.

Reed-Solomonin ylikenttäkoodia , jolla on koodietäisyys , voidaan ajatella -kentän päälle -koodina , joka voi korjata minkä tahansa virheyhdistelmän, joka keskittyy enintään m merkin lohkoihin. Suurin määrä lohkoja, joihin pituuspaketti voi vaikuttaa , missä , ei ylitä , joten virhelohkoja korjaava koodi voi aina korjata minkä tahansa kokonaispituisten pakettien yhdistelmän, jos .

Käytännön toteutus

Reed-Solomon-koodaus voidaan toteuttaa kahdella tavalla: systemaattisesti ja ei-systeemisesti (katso [1] kooderin kuvaus).

Ei-systeemisessä koodauksessa informaatiosana kerrotaan jollakin redusoitumattomalla polynomilla Galois'n kentässä. Tuloksena oleva koodattu sana on täysin erilainen kuin alkuperäinen, ja tietosanan purkamiseksi sinun on suoritettava dekoodaustoiminto ja vasta sitten voit tarkistaa datan virheiden varalta. Tällainen koodaus vaatii paljon resursseja vain informaatiodatan poimimiseen, vaikka se voi olla virheetöntä.

Systemaattisessa koodauksessa tarkistussymbolit kohdistetaan symbolien tietolohkoon, jokaista tarkistussymbolia laskettaessa käytetään kaikkia alkuperäisen lohkon symboleja. Tässä tapauksessa alkuperäisen lohkon purkamisesta ei aiheudu lisäkustannuksia, jos informaatiosana ei sisällä virheitä, mutta kooderin/dekooderin on suoritettava yhteen- ja kertolaskuoperaatiot pariteettisymbolien muodostamiseksi. Lisäksi, koska kaikki toiminnot suoritetaan Galois-kentällä, itse koodaus/dekoodaustoiminnot vaativat paljon resursseja ja aikaa. Nopeaan Fourier-muunnokseen perustuva nopea dekoodausalgoritmi toimii luokkaa .

Koodaus

Koodauksen aikana informaatiopolynomi kerrotaan generoivalla polynomilla. Alkuperäisen pituuden sanan kertominen redusoitumattomalla polynomilla systemaattisessa koodauksessa voidaan tehdä seuraavasti:

Enkooderi on rakennettu siirtorekistereistä, summaimista ja kertoimista. Siirtorekisteri koostuu muistisoluista, joista jokainen sisältää yhden Galois-kentän elementin.

On olemassa toinen koodausmenettely (käytännöllisempi ja yksinkertaisempi) . Olkoon  kentän primitiivinen elementti ja olkoon  informaatiosymbolien vektori ja siten  informaatiopolynomi. Tällöin vektori on informaatiovektoria vastaava Reed-Solomon-koodivektori . Tämä koodausmenetelmä osoittaa, että PC-koodille ei tarvitse tietää generoivaa polynomia ja koodin generoivaa matriisia ollenkaan, riittää, että tietää kentän laajeneminen primitiivisen elementin ja koodin dimensioiden suhteen. (koodin pituus on tässä tapauksessa määritelty ). Asia on siinä, että generoiva polynomi ja koodietäisyys ovat täysin piilossa eron takana.

Dekoodaus

Dekooderi, joka toimii autoregressiivisen spektrin dekoodausmenetelmän mukaisesti, suorittaa peräkkäin seuraavat toiminnot:

Virheoireyhtymän laskeminen

Virheoireyhtymän laskennan suorittaa oireyhtymän dekooderi, joka jakaa koodisanan generaattoripolynomiksi. Jos jaon aikana on jäännös, sanassa on virhe. Jaon loppuosa on virheoireyhtymä.

Virhepolynomin rakentaminen

Laskettu virhesyndrooma ei osoita virheiden sijaintia. Syndroomapolynomin aste on , joka on paljon pienempi kuin koodisanan aste . Virheen ja sen viestin välisen vastaavuuden saamiseksi muodostetaan virhepolynomi. Virhepolynomi toteutetaan Berlekamp-Massey- algoritmilla tai Euclid-algoritmilla. Euklidesin algoritmilla on yksinkertainen toteutus, mutta se vaatii resursseja. Siksi useammin käytetään monimutkaisempaa, mutta halvempaa Berlekamp-Massey-algoritmia. Löydetyn polynomin kertoimet vastaavat suoraan koodisanan virheellisten symbolien kertoimia.

Juurien etsiminen

Tässä vaiheessa etsitään virhepolynomin juuret, jotka määrittävät vääristyneiden symbolien sijainnin koodisanassa. Se toteutetaan Chenin menetelmällä, joka vastaa tyhjentävää luettelointia. Kaikki mahdolliset arvot sijoitetaan peräkkäin virhepolynomiin, kun polynomi katoaa, juuret löydetään.

Virheen luonteen määrittäminen ja sen korjaaminen

Virheoireyhtymän ja löydettyjen polynomijuurien perusteella määritetään virheen luonne Forney-algoritmilla ja rakennetaan vääristyneiden symbolien maski. RS-koodien kohdalla on kuitenkin helpompi tapa löytää virheiden luonne. Kuten kohdassa [2] näkyy RS-koodeille, joissa on mielivaltainen joukko peräkkäisiä nollia :

missä on formaalinen derivaatta suhteessa virheenpaikannuspolynomiin , ja

Lisäksi, kun maski on löydetty, se asetetaan koodisanan päälle käyttämällä XOR -toimintoa ja vääristyneet merkit palautetaan. Tämän jälkeen tarkistusmerkit hylätään ja palautettu tietosana saadaan.

Sudanin algoritmi

Tällä hetkellä on sovellettu täysin uusia dekoodausmenetelmiä, esimerkiksi Madhu Sudanin vuonna 1997 ehdottama algoritmi [3] .

RS-koodien laajentaminen

RS-koodin pidennys on prosessi, jossa koodin pituus ja etäisyys kasvavat (kun koodi on edelleen Singletonin rajalla ja koodiaakkoset eivät muutu), eikä koodin tietosymbolien määrä muutu [4] . Tämä menettely lisää koodin korjauskykyä . Harkitse RS-koodin pidentämistä yhdellä symbolilla. Antaa olla  RS-koodivektori, jonka generoiva polynomi on . Anna nyt . Osoitetaan, että symbolin lisääminen vektoriin kasvattaa sen painoa arvoon , jos . Koodivektoria vastaava polynomi voidaan kirjoittaa muodossa , mutta silloin saadaan lauseke huomioon ottaen . , koska 1 ei kuulu generoivan polynomin juuriluetteloon. Mutta myös , koska tässä tapauksessa , mikä lisäisi koodin etäisyyttä ehdon vastaisesti, tämä tarkoittaa, että koodin paino on kasvanut uuden merkin lisäämisen vuoksi . Uudet koodiparametrit , pidennetty vektori . Ei-venytetyn koodin tarkistusmatriisilla on muoto

Tällöin tarkistusmatriisi, jota on jatkettu yhdellä PC-koodin symbolilla, on

Sovellus

Välittömästi ilmestymisen jälkeen (XX vuosisadan 60-luku) Reed-Solomon-koodeja alettiin käyttää ulkoisina koodeina satelliittiviestinnässä käytetyissä kaskadirakenteissa. Tällaisissa rakenteissa -: nnet PC-symbolit (niitä voi olla useita) koodataan sisäisillä konvoluutiokoodeilla . Vastaanottopäässä nämä symbolit dekoodataan pehmeällä Viterbi-algoritmilla (voimassa AWGN -kanavilla ). Tällainen dekooderi korjaa yksittäiset virheet q-symboleissa, mutta kun purskevirheitä tapahtuu ja jotkut q-symbolien paketit dekoodataan väärin, ulkoinen Reed-Solomon-dekooderi korjaa näiden virheiden purskeet. Siten saavutetaan vaadittu tiedonsiirron luotettavuus ( [5] ).

Tällä hetkellä Reed-Solomon-koodeilla on erittäin laaja soveltamisala, koska ne pystyvät löytämään ja korjaamaan useita virhepurskeita.

Tiedon tallennus ja tallennus

Reed-Solomon-koodia käytetään kirjoitettaessa ja luettaessa RAM-ohjaimissa, arkistoitaessa tietoja, kirjoitettaessa tietoja kiintolevyille ( ECC ), kirjoitettaessa CD / DVD-levyille. Vaikka huomattava määrä tietoa on vaurioitunut, useat levytietovälineen sektorit vaurioituvat, Reed-Solomon-koodien avulla voit palauttaa suurimman osan kadonneista tiedoista. Käytetään myös kirjoitettaessa medialle, kuten magneettinauhoille ja viivakoodeille.

Polttaminen CD-ROM-levylle

Mahdolliset virheet levyltä luettaessa ilmenevät jo levyn tuotantovaiheessa, koska nykyaikaisilla tekniikoilla on mahdotonta tehdä ihanteellista levyä. Virheet voivat johtua myös levyn pinnan naarmuista, pölystä jne. Tästä syystä luettavaa CD-levyä valmistettaessa käytetään CIRC (Cross Interleaved Reed Solomon Code) -korjausjärjestelmää. Tämä korjaus toteutetaan kaikissa laitteissa, jotka mahdollistavat tietojen lukemisen CD-levyiltä laiteohjelmistolla varustetun sirun muodossa. Virheiden havaitseminen ja korjaaminen perustuu redundanssiin ja lomitteluun . Redundanssi - noin 25 % alkuperäisestä tiedosta.

Äänitys CD - levyille käyttää Red Book - standardia . Virheenkorjaus tapahtuu kahdella tasolla, C1 ja C2. Ensimmäisessä vaiheessa koodattaessa alkuperäiseen dataan lisätään tarkistussymbolit, toisessa vaiheessa tiedot koodataan uudelleen. Koodauksen lisäksi tavuja lomitetaan ( interleaved ) niin, että korjauksen aikana virhelohkot hajoavat erillisiksi biteiksi, jotka on helpompi korjata. Ensimmäisellä tasolla tunnistetaan ja korjataan virheelliset yhden ja kahden tavun lohkot (vastaavasti yksi ja kaksi virheellistä merkkiä). Kolmen tavun virhelohkot tunnistetaan ja siirretään seuraavalle tasolle. Toisella tasolla tunnistetaan ja korjataan 1- ja 2-tavuiset virhelohkot, jotka ovat peräisin C2:sta. Kolmen virheellisen merkin havaitseminen on kohtalokas virhe, eikä sitä voida korjata.

Langaton ja matkaviestintä _

Tätä koodausalgoritmia käytetään tiedonsiirrossa WiMAX -verkkojen kautta , optisissa viestintälinjoissa , satelliitti- ja radioreleiden tiedonsiirrossa . Forward Error Correction (FEC) -menetelmä perustuu Reed-Solomon -koodeihin.

Koodausesimerkkejä

Heksadesimaali (15,11) Reed-Solomon koodi

Anna . Sitten

Tutkinto on 4 ja . Jokainen kenttäelementti voidaan kuvata 4 bitiksi. Tietopolynomi on 11 merkin sekvenssi alkaen , mikä vastaa 44 bittiä, ja koko koodisana on 60 bitin sarja.

8-ar (7,3) Reed-Solomon koodi

Anna . Sitten

Olkoon tietopolynomin muoto:

Ei-systeemisen koodin koodisana kirjoitetaan seuraavasti:

joka on seitsemän oktaalimerkin sarja.

Vaihtoehtoinen koodausmenetelmä 9-ary (8,4) Reed-Solomon -koodille

Muodostetaan Galois'n kenttä modulo polynomi . Olkoon sitten juurensa kenttätaulukko näyttää tältä:

Olkoon tietopolynomi ja tehden sitten vastaavat laskelmat konstruoidusta kentästä, saamme:

Tuloksena rakennettiin RS-koodivektori parametreineen . Tämä päättää koodauksen. Huomaa, että tällä menetelmällä emme tarvinneet generoivaa koodipolynomia [4] .

Dekoodausesimerkkejä

Olkoon kenttä generoitu primitiivisellä alkiolla, jonka redusoitumaton polynomi on . Sitten . Anna . Tällöin PC-koodin generoiva polynomi on yhtä suuri kuin . Hyväksytään nyt polynomi . Sitten . Sitten avainyhtälöjärjestelmä saadaan muodossa:

Tarkastellaan nyt euklidistä algoritmia tämän yhtälöjärjestelmän ratkaisemiseksi.

  • Alkuehdot :

Algoritmi pysähtyy, koska , joten se seuraa sitä

Lisäksi täydellinen haku Cheney-algoritmilla antaa meille virheiden sijainnit, tämä on . Sitten kaavalla saamme sen

Siten dekoodattu vektori . Dekoodaus valmis, kaksi virhettä korjattu [6] .

Sovellus

  • Reed-Solomon -koodia käytetään joissakin tallennussovelluksissa, kuten RAID 6 ;

Katso myös

Muistiinpanot

  1. Morelos-Zaragoza R. Virheenkorjauskoodauksen taito. Menetelmät, algoritmit, sovellus / per. englannista. V. B. Afanasjev . - M . : Technosfera, 2006. - S. 92-93. — (Viestintämaailma). - 2000 kappaletta.  — ISBN 5-94836-035-0 .
  2. Morelos-Zaragoza R. Virheenkorjauskoodauksen taito. Menetelmät, algoritmit, sovellus / per. englannista. V. B. Afanasjev . - M . : Technosfera, 2006. - 320 s. — (Viestintämaailma). - 2000 kappaletta.  — ISBN 5-94836-035-0 .
  3. Sudan-algoritmi . Haettu 24. joulukuuta 2018. Arkistoitu alkuperäisestä 24. joulukuuta 2018.
  4. 1 2 Sagalovich, 2007 , s. 212-213.
  5. M. Werner. Koodauksen perusteet. - Technosphere, 2004. - S. 268-269. ISBN 5-94836-019-9 .
  6. Morelos-Zaragoza R. Virheenkorjauskoodauksen taito. Menetelmät, algoritmit, sovellus / per. englannista. V. B. Afanasjev . - M . : Technosfera, 2006. - S. 116-119. — (Viestintämaailma). - 2000 kappaletta.  — ISBN 5-94836-035-0 .

Kirjallisuus

  • Peterson W, Weldon E. Virheenkorjauskoodit . - M .: Mir, 1976. - S.  596 .
  • Blahut R. Virheenhallintakoodien teoria ja käytäntö. — M .: Mir , 1986. — 576 s.
  • Berlekamp E. Algebrallinen koodausteoria = Algebrallinen koodausteoria. - M .: Mir, 1971. - S.  478 .
  • Egorov S.I. Virheenkorjaus tietokoneiden oheislaitteiden tietokanavissa. - Kursk: KurskGTU, 2008. - S. 252.
  • Sagalovich Yu. L. Johdatus algebrallisiin koodeihin - M .: MIPT , 2007. - 262 s. — ISBN 978-5-7417-0191-1
  • Morelos-Zaragoza R. Virheenkorjauskoodauksen taito. Menetelmät, algoritmit, sovellus / per. englannista. V. B. Afanasjev . - M . : Technosfera, 2006. - 320 s. — (Viestintämaailma). - 2000 kappaletta.  — ISBN 5-94836-035-0 .
  • M. Werner. Koodauksen perusteet. - Technosphere, 2004. - 288 s. — ISBN 5-94836-019-9 .

Linkit