Пређи на садржај

Kod za ispravljanje grešaka

С Википедије, слободне енциклопедије
(преусмерено са Error correction code)

U računarstvu, telekomunikacijama, teoriji informacija i teoriji kodiranja, kod za ispravljanje grešaka, ili kod korigovanja grešaka (engl. error correcting code - ECC) koristi se za kontrolu grešaka u podacima preko nepouzdanih ili bučnih komunikacionih kanala.[1][2] Centralna ideja je da pošiljalac kodira poruku izlišnim informacijama u obliku ECC-a. Prekomernost omogućava primaocu da otkrije ograničeni broj grešaka koje se mogu pojaviti bilo gde u poruci i često da ih ispravi bez ponovnog prenosa. Američki matematičar Ričard Haming je bio pionir ovog polja tokom 1940-ih i izumeo je prvi kod za ispravljanje grešaka 1950: Hemingov (7,4) kod.[2]

ECC se razlikuje od otkrivanja grešaka jer se greške koje se nađu mogu ispraviti, a ne jednostavno otkriti. Prednost je u tome što sistem koji koristi ECC ne zahteva reverzni kanal da zahteva ponovni prenos podataka kada dođe do greške. Loša strana je što se fiksni trasnmisioni troškovi dodaju u poruku, što zahteva veću propusnu širinu kanala unapred. ECC se stoga primenjuje u situacijama kada su ponovni prenosi skupi ili nemogući, kao što su jednosmerne komunikacione veze i prilikom prenosa na više prijemnika u multikastu. Od ovakvog pristupa takođe imaju koristi i veze sa dugim kašnjenjem; u slučaju da satelit kruži oko Urana, ponovni prenos zbog grešaka može stvoriti kašnjenje od pet sati.

Korekcija grešaka unapred

[уреди | уреди извор]

U telekomunikacijama, teoriji informacija i teoriji kodiranja, ispravljanje grešaka unapred (engl. forward error correction - FEC) ili kodiranje kanala[3][4] je tehnika koja se koristi za kontrolu grešaka u prenosu podataka preko nepouzdanih ili bučnih komunikacionih kanala. Centralna ideja je da pošiljalac kodira poruku na redundantan način, najčešće koristeći ECC.

Izlišnost omogućava primaocu da otkrije ograničeni broj grešaka koje se mogu pojaviti bilo gde u poruci i često da ih ispravi bez ponovnog prenosa. FEC daje primaocu mogućnost ispravljanja grešaka bez potrebe za reverznim kanalom da bi se zahtevao ponovni prenos podataka, ali po ceni fiksnog, većeg propusnog opsega unapred. FEC se stoga primenjuje u situacijama kada su ponovni prenosi skupi ili nemogući, kao što su jednosmerne komunikacione veze i prilikom prenosa na više prijemnika u multikastu. FEC informacije se obično dodaju u uređaje za masovno skladištenje (magnetni, optički i SSD/fleš) kako bi se omogućio oporavak oštećenih podataka, široko se koristi u modemima, koristi se u sistemima u kojima je primarna memorija ECC memorija i u situacijama emitovanja gde prijemnik nema mogućnost da zahteva ponovni prenos ili gde bi to izazvalo značajno kašnjenje. Na primer, u slučaju da satelit kruži oko Urana, ponovni prenos zbog grešaka u dekodiranju može stvoriti kašnjenje od najmanje 5 sati.

FEC obrada u prijemniku može se primeniti na digitalni tok bita ili u demodulaciji digitalno modulisanog nosača. Za ovo drugo, FEC je sastavni deo početne analogno-digitalne konverzije u prijemniku. Viterbi dekoder primenjuje algoritam meke odluke za demodulaciju digitalnih podataka iz analognog signala oštećenog bukom. Mnogi FEC koderi takođe mogu da generišu signal stope greške u bitovima (engl. bit-error rate - BER) koji se može koristiti kao povratna informacija za fino podešavanje analogne prijemne elektronike.

Maksimalni udeo grešaka ili nedostajućih bitova koji se mogu ispraviti određen je dizajnom ECC-a, tako da su različiti kodovi za ispravljanje grešaka unapred pogodni za različite uslove. Generalno, jači kod indukuje veću suvišnost koju treba preneti koristeći raspoloživu propusnu širinu, što smanjuje efektivnu brzinu protoka, istovremeno poboljšavajući primljeni efektivni odnos signala i šuma. Teorema kodiranja bučnog kanala Kloda Šenona odgovara na pitanje koliko je propusnog opsega preostalo za komunikaciju podataka, pri čemu se koristi najefikasniji kod koji verovatnoću greške u dekodiranju svodi na nulu. Ovo uspostavlja granice teoretske maksimalne brzine prenosa informacija kanala sa određenim osnovnim nivoom šuma. Njegov dokaz nije konstruktivan, i stoga ne daje uvid u to kako da se izgradi kod za postizanje kapaciteta. Međutim, nakon više godina istraživanja, neki napredni FEC sistemi poput polarnog koda[4] postižu kapacitet Šenonovog kanala pod hipotezom o beskonačnoj dužini okvira.

ECC se ostvaruje dodavanjem izlišnosti u transmitovane informacije koristeći algoritam. Izlišni bit može biti složena funkcija mnogih originalnih informacionih bitova. Originalne informacije mogu se ili ne moraju pojaviti doslovno u kodiranom izlazu; kodovi koji uključuju nemodifikovani ulaz u izlaz su sistematski, dok su oni koji to nisu nesistematski.

Pojednostavljeni primer ECC-a je prenos svakog bita podataka 3 puta, što je poznato kao (3,1) kod ponavljanja. Kroz bučni kanal, prijemnik može videti 8 verzija izlaza, pogledajte donju tabelu.

Triplet primljen Protumačen kao
000 0 (bez greške)
001 0
010 0
100 0
111 1 (bez greške)
110 1
101 1
011 1

Ovo omogućava ispravljanje greške u bilo kom od tri uzorka „većinskim glasanjem” ili „demokratskim glasanjem”. Sposobnost ispravljanja ovog ECC je:

  • Do 1 bita tripleta pri greški, ili
  • Do 2 bita iz tripleta izostavljena (slučajevi nisu prikazani u tabeli).

Iako je jednostavan za primenu i široko se koristi, ova trostruka modularna izlišnost je relativno neefikasan ECC. Bolji ECC kodovi obično ispituju poslednjih nekoliko desetina ili čak poslednjih nekoliko stotina prethodno primljenih bitova kako bi se utvrdilo kako da se dekodira trenutni mali set bitova (obično u grupama od 2 do 8 bitova).

Usrednjavanje buke za redukciju grešaka

[уреди | уреди извор]

Moglo bi se reći da ECC radi tako što „usrednjava šum“; pošto svaki bit podataka utiče na mnoge prenete simbole, oštećenje nekih simbola šumom obično omogućava da se originalni korisnički podaci ekstrahuju iz drugih, neoštećenih primljenih simbola koji takođe zavise od istih korisničkih podataka.

  • Zbog ovog efekta „udruženja rizika“, digitalni komunikacioni sistemi koji koriste ECC imaju tendenciju da rade znatno iznad određenog minimalnog odnosa signal-šum, a ne ispod njega.
  • Ova tendencija sve ili ništaefekat litice – postaje sve izraženija kako se koriste jači kodovi koji se bliže približavaju teorijskoj Šenonovoj granici.
  • Preplitanje ECC kodiranih podataka može redukovat svojstva „sve ili ništa” prenetih ECC kodova kada se greške kanala obično javljaju u rafalima. Međutim, ovaj metod ima ograničenja; najbolje se koristi na uskopojasnim podacima.

Većina telekomunikacionih sistema koristi fiksni kanalski kod dizajniran da toleriše očekivanu stopu bitne greške u najgorem slučaju, a zatim uopšte ne funkcionišu ako je stopa grešaka u bitovima još gora. Međutim, neki sistemi se prilagođavaju datim uslovima greške kanala: neki slučajevi hibridnog automatskog zahteva za ponavljanje koriste fiksni ECC metod sve dok ECC može da obradi stopu greške, a zatim se prebacuje na ARQ kada stopa greške postane previsoka; adaptivna modulacija i kodiranje koristi različite ECC brzine, dodajući više bitova za ispravljanje grešaka po paketu kada postoje veće stope grešaka u kanalu, ili ih uklanjaju kada nisu potrebne.

Block kod (posebno Hamingov kod) gde se redundantni bitovi dodaju kao blok na kraj početne poruke
Kontinualni konvolucioni kod gde se redundantni bitovi kontinuirano dodaju u strukturu kodne reči

Dve glavne kategorije ECC kodova su blok kodovi i konvolucijski kodovi.

  • Blok kodovi rade na blokovima (paketima) fiksne veličine bitova ili simbola unapred-određene veličine. Praktični blok kodovi se generalno mogu teško dekodirati u polinomskom vremenu do njihove dužine bloka.
  • Konvolucijski kodovi rade na tokovima bitova ili simbola proizvoljne dužine. Oni se najčešće meko dekodiraju Viterbijevim algoritmom, mada se ponekad koriste i drugi algoritmi. Viterbijevo dekodiranje omogućava asimptotski optimalnu efikasnost dekodiranja sa povećanjem dužine ograničenja konvolucionog koda, ali na račun eksponencijalno rastuće složenosti. Konvolucijski kod koji je prekinut je takođe 'blok kod' po tome što kodira blok ulaznih podataka, ali je veličina bloka konvolucionog koda generalno proizvoljna, dok kodovi bloka imaju fiksnu veličinu koju diktiraju njihove algebarske karakteristike. Tipovi završetka za konvolucione kodove uključuju „odgrizanje repa” i „ispiranje bita”.

Postoji mnogo tipova blok kodova; Rid–Solomonovo kodiranje je vredno pažnje zbog svoje široke upotrebe na kompakt diskovima, DVD-ovima i hard diskovima. Drugi primeri klasičnih blok kodova uključuju Golay, BCH, višedimenzionalni paritet i Hamingove kodove.

Hamingov ECC se obično koristi za ispravljanje grešaka NAND fleš memorije.[5] Ovo obezbeđuje jednobitnu korekciju greške i detekciju 2-bitne greške. Hamingovi kodovi su pogodni samo za pouzdanije NAND ćelije sa jednim nivoom (SLC). NAND gušćih ćelija na više nivoa (MLC) može da koristi više-bitni ispravljajući ECC kao što je BCH ili Rid-Solomon.[6][7] NOR Flaš obično ne koristi nikakvu ispravku grešaka.[6]

Klasični blok kodovi se obično dekodiraju korišćenjem algoritama tvrdog odlučivanja,[8] što znači da se za svaki ulazni i izlazni signal donosi teška odluka da li odgovara jediničnom ili nultom bitu. Nasuprot tome, konvolucijski kodovi se obično dekodiraju korišćenjem algoritama meke odluke kao što su Viterbi, MAP ili BCJR algoritmi, koji obrađuju (diskretizovane) analogne signale i koji omogućavaju mnogo više performanse ispravljanja grešaka od dekodiranja sa tvrdom odlukom.

Skoro svi klasični blok kodovi primenjuju algebarska svojstva konačnih polja. Stoga se klasični blok kodovi često nazivaju algebarskim kodovima.

Za razliku od klasičnih blok kodova koji često specificiraju sposobnost otkrivanja ili ispravljanja grešaka, mnogim modernim blok kodovima kao što su LDPC kodovi nedostaju takve garancije. Umesto toga, savremeni kodovi se procenjuju u smislu njihove stope bitnih grešaka.

Većina kodova za ispravljanje grešaka unapred ispravlja samo preokret bitova, ali ne i umetanja ili brisanja bitova. U ovoj postavci, Hemingova udaljenost je odgovarajući način za merenje stope bitne greške. Nekoliko kodova za ispravljanje grešaka unapred je dizajnirano da ispravljaju umetanje i brisanje bitova, kao što su kodovi markera i kodovi vodenih žigova. Levenštajnova udaljenost je prikladniji način za merenje stope bitne greške kada se koriste takvi kodovi.[9]

Brzina koda i kompromis između pouzdanosti i brzine prenosa podataka

[уреди | уреди извор]

Osnovni princip ECC-a je dodavanje redundantnih bitova kako bi se pomoglo dekoderu da sazna pravu poruku koju je kodirao predajnik. Brzina koda datog ECC sistema je definisana kao odnos između broja bitova informacija i ukupnog broja bitova (tj. informacija plus bitova redundancije) u datom komunikacionom paketu. Otuda je brzina koda realan broj. Niska brzina koda blizu nule implicira jak kod koji koristi mnogo redundantnih bitova za postizanje dobrih performansi, dok velika brzina koda blizu 1 implicira slab kod.

Redundantni bitovi koji štite informacije moraju se preneti koristeći iste komunikacione resurse koje pokušavaju da zaštite. Ovo uzrokuje fundamentalni kompromis između pouzdanosti i brzine prenosa podataka.[10] U jednom ekstremu, jak kod (sa niskom brzinom koda) može da izazove značajno povećanje SNR prijemnika (odnos signal-šum) smanjujući stopu greške u bitu, po cenu smanjenja efektivne brzine prenosa podataka. Sa druge strane, nekorišćenje bilo kakvog ECC-a (tj. brzina koda jednaka 1) koristi ceo kanal za potrebe prenosa informacija, po cenu ostavljanja bitova bez ikakve dodatne zaštite.

Jedno interesantno pitanje je: koliko efikasan u smislu prenosa informacija može biti ECC koji ima zanemarljivu stopu grešaka u dekodiranju? Na ovo pitanje je odgovorio Klod Šenon svojom drugom teoremom, koja kaže da je kapacitet kanala maksimalna brzina bitova koju može postići bilo koji ECC čija stopa grešaka teži nuli.[11] Njegov dokaz se oslanja na Gausovo nasumično kodiranje, koje nije pogodno za aplikacije u stvarnom svetu. Gornja granica koju je dao Šenonov rad inspirisala je dugo putovanje u dizajniranju ECC-a koji se mogu približiti krajnjoj granici performansi. Različiti kodovi danas mogu dostići skoro Šenonovu granicu. Međutim, ECC-i za postizanje kapaciteta su obično izuzetno složeni za implementaciju.

Najpopularniji ECC-ovi imaju kompromis između performansi i računarske složenosti. Obično njihovi parametri daju raspon mogućih brzina koda, koji se može optimizovati u zavisnosti od scenarija. Obično se ova optimizacija radi kako bi se postigla niska verovatnoća greške u dekodiranju uz minimiziranje uticaja na brzinu prenosa podataka. Drugi kriterijum za optimizaciju brzine koda je balansiranje niske stope greške i broja retransmisija kako bi se postigla energetska cena komunikacije.[12]

  1. ^ Glover, Neal; Dudley, Trent (1990). Practical Error Correction Design For Engineers (Revision 1.1, 2nd изд.). CO, USA: Cirrus Logic. ISBN 0-927239-00-0. ISBN 978-0-927239-00-4. 
  2. ^ а б Hamming, R. W. (април 1950). „Error Detecting and Error Correcting Codes”. Bell System Technical Journal. USA: AT&T. 29 (2): 147—160. doi:10.1002/j.1538-7305.1950.tb00463.x. 
  3. ^ Charles Wang; Dean Sklar; Diana Johnson (2001). „Forward Error-Correction Coding”. Crosslink. The Aerospace Corporation. 3 (1). Архивирано из оригинала 25. 2. 2012. г. Приступљено 5. 3. 2006. „How Forward Error-Correcting Codes Work 
  4. ^ а б Maunder, Robert (2016). „Overview of Channel Coding”. 
  5. ^ "Hamming codes for NAND flash memory devices" Архивирано 21 август 2016 на сајту Wayback Machine. EE Times-Asia. Apparently based on "Micron Technical Note TN-29-08: Hamming Codes for NAND Flash Memory Devices" Архивирано 29 август 2017 на сајту Wayback Machine. 2005. Both say: "The Hamming algorithm is an industry-accepted method for error detection and correction in many SLC NAND flash-based applications."
  6. ^ а б „What Types of ECC Should Be Used on Flash Memory?” (Application note). Spansion. 2011. „Both Reed–Solomon algorithm and BCH algorithm are common ECC choices for MLC NAND flash. ... Hamming based block codes are the most commonly used ECC for SLC.... both Reed–Solomon and BCH are able to handle multiple errors and are widely used on MLC flash. 
  7. ^ Jim Cooke (август 2007). „The Inconvenient Truths of NAND Flash Memory” (PDF). стр. 28. „For SLC, a code with a correction threshold of 1 is sufficient. t=4 required ... for MLC. 
  8. ^ Baldi, M.; Chiaraluce, F. (2008). „A Simple Scheme for Belief Propagation Decoding of BCH and RS Codes in Multimedia Transmissions”. International Journal of Digital Multimedia Broadcasting. 2008: 1—12. doi:10.1155/2008/957846Слободан приступ. 
  9. ^ Shah, Gaurav; Molina, Andres; Blaze, Matt (2006). „Keyboards and covert channels”. USENIX. Приступљено 20. 12. 2018. 
  10. ^ Tse, David; Viswanath, Pramod (2005), Fundamentals of Wireless Communication, Cambridge University Press, UK 
  11. ^ Shannon, C. E. (1948). „A mathematical theory of communication” (PDF). Bell System Technical Journal. 27 (3–4): 379—423 & 623—656. doi:10.1002/j.1538-7305.1948.tb01338.x. hdl:11858/00-001M-0000-002C-4314-2Слободан приступ. 
  12. ^ Rosas, F.; Brante, G.; Souza, R. D.; Oberli, C. (2014). „Optimizing the code rate for achieving energy-efficient wireless communications”. Proceedings of the IEEE Wireless Communications and Networking Conference (WCNC). стр. 775—780. ISBN 978-1-4799-3083-8. doi:10.1109/WCNC.2014.6952166. 

Spoljašnje veze

[уреди | уреди извор]