Prezentace se nahrává, počkejte prosím

Prezentace se nahrává, počkejte prosím

Kódování Radim Farana Podklady pro výuku. Obsah Základy pojmy z diskrétních kódů. Druhy kódů. Nejkratší kódy. Detekce chyb, Hammingova vzdálenost. Kontrolní.

Podobné prezentace


Prezentace na téma: "Kódování Radim Farana Podklady pro výuku. Obsah Základy pojmy z diskrétních kódů. Druhy kódů. Nejkratší kódy. Detekce chyb, Hammingova vzdálenost. Kontrolní."— Transkript prezentace:

1 Kódování Radim Farana Podklady pro výuku

2 Obsah Základy pojmy z diskrétních kódů. Druhy kódů. Nejkratší kódy. Detekce chyb, Hammingova vzdálenost. Kontrolní a samoopravné kódy.  Lineární kódy.  Hammingovy kódy.  Opakovací kódy.

3 Kód Popis přiřazení kódových slov jednotlivým zprávám (kódová kniha). Kódové slovo je posloupnost znaků použité abecedy. Abeceda je množina znaků (binární abeceda Z 2 = {0, 1}) Minimální délka kódového slova: N * (x) = - log 2 (P(x)) [bit]

4 Vlastnosti kódu prosté kódování: různým zprávám odpovídají různá kódová slova, jednoznačná dekódovatelnost: ze znalosti zakódované zprávy lze jednoznačně určit zprávu zdrojovou, Kód K : A → B musí být prostým zobrazením.

5 Problém dekódování Kód A001 Zpráva Posloupnost zpráv (kódových slov): nelze jednoznačně dekódovat Kód B Posloupnost zpráv (kódových slov): lze jednoznačně dekódovat? Ano, ale jen „odzadu“, po přijetí celé posloupnosti zpráv. Kód C Posloupnost zpráv (kódových slov): můžeme dekódovat on-line. Důvod? Žádné kódové slovo není začátkem jiného kódového slova (prefixem).

6 Druhy kódů Prefixový kód je prosté kódování u kterého žádné kódové slovo není začátkem jiného kódového slova. Blokový kód je prosté kódování u kterého mají všechna kódová slova stejnou délku (počet znaků). Protože musí být prostým zobrazením, je nutně také prefixovým kódem.

7 Použití kódů Nejkratší (optimální) kódy R → 0, L → min, Bezpečnostní kódy  detekční kódy (odhalují chyby),  samoopravné kódy (opravují chyby), Speciální kódy  kódy konstantní změny (Grayův kód),  čárové kódy,  alfanumerické kódy,  číselné kódy (datové formáty), …

8 Nejkratší kódy Pokud má R → 0, neboli L → min, pak N(i) → N * (i) pro i = 1, 2, … n. Hledáme vhodný algoritmus konstrukce takového kódu:  Huffmanův kód (1952),  Shannonův kód. Algoritmy se liší, stejně tak i dosažené výsledky, Huffmanův kód se snáze algoritmizuje a tedy také realizuje Huffman, David A. * 1925, USA California, USA

9 Huffmanův kód Triviální případ ZprávaP(i)P(i) 1> 2< kódkód 0 1 Redukovaná abeceda ZprávaP(i)P(i) 1» 2> redukce 3< 1 2,3 kódkód 0 1 expanze Postup: seřazení podle pravděpodobnosti, postupná redukce a oprava pořadí, přiřazení znaků 0, 1 a zpětná expanze. Příklad A P(i)P(i) 0,4 0,30,1 BCDEZpráva 0,1 1.redukce 0,4 0,30,20,1 2.redukce 0,4 0,3 3.redukce 0,6 0,4 znaky kód Problémy: definice pořadí zpráv pro stejnou P(i), zařazení skupin se stejnou P(i), pořadí přiřazení znaků 0, 1.

10 Shannon-Fanova konstrukce kódu Postup: seřazení podle pořadí pravděpodobnosti, rozdělení na skupiny s co nejbližší pravděpodobností, přiřazení znaků 0, 1. Zpráva A, BC, D, E ABC D, E DE 1 bit Fano, Robert Mario 1917 Turin, Italy jpg Příklad A P(i)P(i) 0,4 0,30,1 BCDEZpráva 0, kód

11 Množinu všech slov rozdělíme na slova kódová a slova nekódová. t-násobná chyba změní kódové slovo na nekódové, pokud se dvě kódová slova liší ve více než t znacích. Hammingova vzdálenost je počet znaků ve kterých se dvě kódová slova liší. Hammingova vzdálenost kódu d je nejmenší z nich. Detekce chyb

12 011 d = 1 Hammingova vzdálenost d = 1 nekódová slova kódové slovo Hamming, Richard Wesley * Chicago, Il. USA Monterey, Cal. USA Kód odhaluje t-násobné chyby, pokud je Hammingova vzdálenost kódu d > t. Označení kódů (blokových): (n, k)-kód počet informačních znakůpočet znaků (4, 3)-kód má jeden kontrolní znak, je schopen mít d = 2.

13 Opravování chyb 111 d = d = 1 kódové slovo 011 nekódová slova 110 d = 2 d = 3 Kód opravuje t-násobné chyby, pokud je Hammingova vzdálenost kódu d > 2.t.

14 Kód dvourozměrné kontroly parity Informační znaky zapíšeme do matice typu (p, q). Každému řádku přidáme jeden symbol kontroly parity řádku, podobně každému sloupci kontrolu parity sloupce. Paritě sloupce parit řádků pak znak „kontrola kontrol“, volený tak, aby i parita výsledné matice byla sudá. Např. pro p = 7 a q = 3 obdržíme ASCII (32, 21)-kód. Tento kód opravuje jednoduché chyby. Příklad

15 Lineární kódy (maticové kódy) Kódové slovo chápeme jako řádkový vektor v = [ 0 0 1]. Lineární kombinací libovolného počtu kódových slov vznikne opět kódové slovo. Kód je možno popsat pomocí generující matice (kterou tvoří báze kódu) G = v = z.G

16 Systematické kódy Informační slovo tvoří začátek kódového slova. Určení informačního slova (dekódování) je triviální. Je možno snadno určit kontrolní matici kódu A syndrom přijatého slova Nenulový syndrom indikuje chybu. G =EB H =-BE’E’ T s = H.v T

17 Hammingovy kódy Opravují jednoduché chyby a jsou perfektní = při daných vlastnostech mají minimální možnou redundanci. Kód s m kontrolními znaky (m = 2, 3, …) má délku n = 2 m – 1. Sloupce kontrolní matice tvoří binární rozvoj čísel 1, 2, …, 2 m - 1 Nenulový syndrom je binárním rozvojem pozice chyby.

18 Opakovací kódy Velmi jednoduše se generují kódová slova i vyhodnocují přijatá slova. Jsou perfektní. Opakovací (3, 1)-kód se shoduje s Hammingovým (3, 1)-kódem.


Stáhnout ppt "Kódování Radim Farana Podklady pro výuku. Obsah Základy pojmy z diskrétních kódů. Druhy kódů. Nejkratší kódy. Detekce chyb, Hammingova vzdálenost. Kontrolní."

Podobné prezentace


Reklamy Google