Treść książki

Przejdź do opcji czytnikaPrzejdź do nawigacjiPrzejdź do informacjiPrzejdź do stopki
16
20Informacjaikodowanie
WalgorytmieVitteryzaostrzonoostatniezałożenieotrzymujesięrównież
ciągliczbnierosnących,leczwobrębiepodciągówotychsamychwartościachna
początkutepochodzącezwęzłówwewnętrznych,anakońcuzliści.
Gdylicznikwliściuzwiększysię,algorytmymodyfikująniewielkifragment
drzewa(przemieszczającniektórewęzły),zachowującpodanewyżejwłasności.
BardziejzłożonyalgorytmVitterydajekrótszekodyniżalgorytmFGK.
2.2.3.KodyLempela-Ziva
AlgorytmbezstratnejkompresjidanychopracowanyprzezLempelaiZiva
wytwarzakodopartynasłownikuadaptacyjnym[85]0Kompresjapolegatuna
zastępowaniupowtarzającychsięciągówbitów,bajtów,albosłówliczbami
wskazującymirozmiarilokalizacjętakiegociągu.Takiewykrytepowiązania
tworząsłownikorozmiarzekilkudziesięciukilobajtówdanych.Jeśliciągsię
powtórzy,tojestzastąpionyprzezliczbypodającejegopozycjęwsłowniku
idługośćciągu.Zawartośćsłownikajestnabieżącoodtwarzanaprzezdekoder.
AlgorytmkompresjiLempela-Ziva
Buforwejściowyzawierasłownik,przechowującykostatnioprzetwarzanych
symboli(indeksowanyod0dok1)orazbuforkodowania,przechowującyn
symbolidozakodowaniaindeksowanychodkdok+N–1
słownikjestwypełnianypierwszymsymbolemwejściowymitensymbol
jestzapisywanynawyjście,
dobuforawejściowegowstawianejestnpierwszychsymbolizwejścia.
Dopókiwbuforzewejściowymjakieśdane:
wsłownikuwyszukiwanyjestnajdłuższypodciągrównypoczątkowi
buforakodowania(najdłuższyprefiks);nadawanyjestmuindeksP<k-1
początkuwyszukanegopodciąguijegodługośćCŚn-1;jeślipodciągunie
udasięznaleźć,toC=0zaśPjestdowolne,
nawyjściewyprowadzanajesttrójka(P,C,S),gdzieStosymbolzbufora
wejściowegonastępującypodopasowanympodciągu,
okno(słownik+buforwejściowy)przesuwanejestwlewooC+1pozycji
iuzupełnianekolejnymisymbolamizwejścia(oilejeszczejakieś).
Algorytmdekompresji
Takjakpodczaskompresji,buforwejściowyzawierak-pozycyjnysłownik,który
jestwypełnianypoczątkowymsymbolem,orazn-pozycyjnybuforkodowania0
Dekompresjajestwykonywanadlakażdejtrójki(PiCiS)wgprocedury:
kopiujzesłownikadobuforawyjściowegosymbolezzakresuPłP+C-1,
doklejnakoniecbuforawyjściowegosymbolS,
wyprowadźC+1początkowychsymbolizbuforawyjściowego,
przesuńzawartośćbuforaoC+1pozycjiwlewo0
Opisanapodstawowawersjaalgorytmumawielemodyfikacji,którychcelem
jestpoprawieniestopniakompresji[32]0