亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

LZW數據壓縮算法的原理分析

2020-01-24 01:06:00
字體:
來源:轉載
供稿:網友

1.LZW的全稱是什么?

  Lempel-Ziv-Welch (LZW).

2. LZW的簡介和壓縮原理是什么?

  LZW壓縮算法是一種新穎的壓縮方法,由Lemple-Ziv-Welch 三人共同創造,用他們的名字命名。它采用了一種先進的串表壓縮,將每個第一次出現的串放在一個串表中,用一個數字來表示串,壓縮文件只存貯數字,則不存貯串,從而使圖象文件的壓縮效率得到較大的提高。奇妙的是,不管是在壓縮還是在解壓縮的過程中都能正確的建立這個串表,壓縮或解壓縮完成后,這個串表又被丟棄。

  LZW算法中,首先建立一個字符串表,把每一個第一次出現的字符串放入串表中,并用一個數字來表示,這個數字與此字符串在串表中的位置有關,并將這個數字存入壓縮文件中,如果這個字符串再次出現時,即可用表示它的數字來代替,并將這個數字存入文件中。壓縮完成后將串表丟棄。如"print" 字符串,如果在壓縮時用266表示,只要再次出現,均用266表示,并將"print"字符串存入串表中,在圖象解碼時遇到數字266,即可從串表中查出266所代表的字符串"print",在解壓縮時,串表可以根據壓縮數據重新生成。

3.在詳細介紹算法之前,先列出一些與該算法相關的概念和詞匯

  1)'Character': 字符,一種基礎數據元素,在普通文本文件中,它占用1個單獨的byte,而在圖像中,它卻是 一種代表給定像素顏色的索引值。
  2)'CharStream':數據文件中的字符流。
  3)'Prefix':前綴。如這個單詞的含義一樣,代表著在一個字符最直接的前一個字符。一個前綴字符長度可以為0,一個prefix和一個character可以組成一個字符串(string),
  4)'Suffix': 后綴,是一個字符,一個字符串可以由(A,B)來組成,A是前綴,B是后綴,當A長度為0的時候,代表Root,根
  5)'Code:碼,用于代表一個字符串的位置編碼
  6)'Entry',一個Code和它所代表的字符串(string)

4.壓縮算法的簡單示例,不是完全實現LZW算法,只是從最直觀的角度看lzw算法的思想

  對原始數據ABCCAABCDDAACCDB進行LZW壓縮

  原始數據中,只包括4個字符(Character),A,B,C,D,四個字符可以用一個2bit的數表示,0-A,1-B,2-C,3-D,從最直觀的角度看,原始字符串存在重復字符:ABCCAABCDDAACCDB,用4代表AB,5代表CC,上面的字符串可以替代表示為:45A4CDDAA5DB,這樣是不是就比原數據短了一些呢!

5.LZW算法的適用范圍

  為了區別代表串的值(Code)和原來的單個的數據值(String),需要使它們的數值域不重合,上面用0-3來代表A-D,那么AB就必須用大于3的數值來代替,再舉另外一個例子,原來的數值范圍可以用8bit來表示,那么就認為原始的數的范圍是0~255,壓縮程序生成的標號的范圍就不能為0~255(如果是0-255,就重復了)。只能從256開始,但是這樣一來就超過了8位的表示范圍了,所以必須要擴展數據的位數,至少擴展一位,但是這樣不是增加了1個字符占用的空間了么?但是卻可以用一個字符代表幾個字符,比如原來255是8bit,但是現在用256來表示254,255兩個數,還是劃得來的。從這個原理可以看出LZW算法的適用范圍是原始數據串最好是有大量的子串多次重復出現,重復的越多,壓縮效果越好。反之則越差,可能真的不減反增了。

6.LZW算法中特殊標記

  隨著新的串(string)不斷被發現,標號也會不斷地增長,如果原數據過大,生成的標號集(string table)會越來越大,這時候操作這個集合就會產生效率問題。如何避免這個問題呢?Gif在采用lzw算法的做法是當標號集足夠大的時候,就不能增大了,干脆從頭開始再來,在這個位置要插入一個標號,就是清除標志CLEAR,表示從這里我重新開始構造字典,以前的所有標記作廢,開始使用新的標記。
這時候又有一個問題出現,足夠大是多大?這個標號集的大小為比較合適呢?理論上是標號集大小越大,則壓縮比率就越高,但開銷也越高。 一般根據處理速度和內存空間連個因素來選定。GIF規范規定的是12位,超過12位的表達范圍就推倒重來,并且GIF為了提高壓縮率,采用的是變長的字長。比如說原始數據是8位,那么一開始,先加上一位再說,開始的字長就成了9位,然后開始加標號,當標號加到512時,也就是超過9為所能表達的最大數據時,也就意味著后面的標號要用10位字長才能表示了,那么從這里開始,后面的字長就是10位了。依此類推,到了2^12也就是4096時,在這里插一個清除標志,從后面開始,從9位再來。
GIF規定的清除標志CLEAR的數值是原始數據字長表示的最大值加1,如果原始數據字長是8,那么清除標志就是256,如果原始數據字長為4那么就是16。另外GIF還規定了一個結束標志END,它的值是清除標志CLEAR再加1。由于GIF規定的位數有1位(單色圖),4位(16色)和8位(256色),而1位的情況下如果只擴展1位,只能表示4種狀態,那么加上一個清除標志和結束標志就用完了,所以1位的情況下就必須擴充到3位。其它兩種情況初始的字長就為5位和9位。此處參照了http://blog.csdn.net/whycadi/

7.用lzw算法壓縮原始數據的示例分析

  輸入流,也就是原始的數據為:255,24,54,255,24,255,255,24,5,123,45,255,24,5,24,54..................
  這個正好可以看到是gif文件中像素數組的一部分,如何對它進行壓縮
  因為原始數據可以用8bit來表示,故清除標志Clear=255+1 =256,結束標志為End=256+1=257,目前標號集為
  0 1 2 3 .................................................................................255 CLEAR END
  第一步,讀取第一個字符為255,在標記表里面查找,255已經存在,我們已經認識255了,不做處理
  第二步,取第二個字符,此時前綴為A,形成當前的Entry為(255,24),在標記集合不存在,我們并不認識255,24好,這次你小子來了,我就記住你,把它在標記集合中標記為258,然后輸出前綴A,保留后綴24,并作為下一次的前綴(后綴變前綴)
  第三步,取第三個字符為54,當前Entry(24,54),不認識,記錄(24,54)為標號259,并輸出24,后綴變前綴
  第四部:取第四個字符255,Entry=(54,255),不認識,記錄(54,255)為標號260,輸出54,后綴變前綴
  第五步   取第5個字符24,entry=(255,24),啊,認識你,這不是老258么,于是把字符串規約為258,并作為前綴
  第六步  取第六個字符255,entry=(258,255),不認識,記錄(258,255)為261,輸出258,后綴變前綴
  .......
  一直處理到最后一個字符,
  用一個表記錄處理過程
  CLEAR=256,END=257

第幾步 前綴 后綴 Entry 認識(Y/N) 輸出 標號
1 255 (,255)
2 255 24   (255,24)       N 255 258
3 24 54   (24,54)       N 24 259
4 54 255   (54,255)       N 54 260
5 255 24   (255,24)       Y
6 258 255   (258,255)       N 258 261
7 255 255   (255,255)       N 255 262

.....

上面這個示例有些不能完整體現,另外一個例子是
原輸入數據為:A B A B A B A B B B A B A B A A C D A C D A D C A B A A A B A B .....
采用LZW算法對其進行壓縮,壓縮過程用一個表來表述為:
注意原數據中只包含4個character,A,B,C,D
用兩bit即可表述,根據lzw算法,首先擴展一位變為3為,Clear=2的2次方+1=4; End=4+1=5;
初始標號集因該為

0 1 2 3 4 5
A B C D Clear End

而壓縮過程為:

第幾步 前綴 后綴 Entry 認識(Y/N) 輸出 標號
1 A (,A)
2 A B   (A,B)       N A 6
3 B A   (B,A)       N B 7
4 A B   (A,B)       Y
5 6 A   (6,A)       N 6 8
6 A B   (A,B)       Y
7 6 A   (6,A)       Y
8 8 B   (8,B)       N 8 9
9 B B   (B,B)       N B 10
10 B B   (B,B)       Y
11 10 A   (10,A)       N 10 11
12 A B   (A,B)       Y

.....
當進行到第12步的時候,標號集應該為

0 1 2 3 4 5 6 7 8 9 10 11
A B C D Clear End AB BA 6A 8B BB 10A

8.LZW算法的偽代碼實現

STRING = get input characterWHILE there are still input characters DO CHARACTER = get input character IF STRING+CHARACTER is in the string table then  STRING = STRING+character ELSE  output the code for STRING  add STRING+CHARACTER to the string table  STRING = CHARACTER END of IFEND of WHILEoutput the code for STRING 

9.LZW算法的流程圖

沒有安visio,畫了一個,比較難看,

http://files.VeVB.COm/file_images/article/201606/2016061611295847.jpg

以上就是本文的全部內容,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
一区二区欧美激情| 欧美性xxxx在线播放| 国产69精品久久久久99| 久久精品国产精品亚洲| 久久视频国产精品免费视频在线| 欧美超级免费视 在线| 日韩在线www| 欧美视频国产精品| 久久久精品国产网站| 欧美二区在线播放| 亚洲偷熟乱区亚洲香蕉av| 久久亚洲成人精品| 欧美精品videos另类日本| 国产精品久久久久久久久久久久| 成人av电影天堂| 国内精品久久久久久| 一本色道久久综合亚洲精品小说| 91精品啪在线观看麻豆免费| 92福利视频午夜1000合集在线观看| 亚洲欧美激情在线视频| 97久久精品视频| 欧美激情视频三区| 中文字幕亚洲图片| 成人欧美在线观看| 久久精品99国产精品酒店日本| 国产一区二区在线免费视频| 国产亚洲在线播放| 国产午夜精品免费一区二区三区| 欧洲亚洲免费在线| 成人在线一区二区| 国产精品444| 亚洲精品少妇网址| 91久久精品视频| 亚洲人成在线观看网站高清| 亚洲欧美色婷婷| 91精品视频免费观看| 国产成人福利夜色影视| 日韩一区在线视频| 中文字幕亚洲字幕| 超碰精品一区二区三区乱码| 亚洲福利视频网| 欧美在线视频一区二区| 日韩在线视频导航| 亚洲男人天堂古典| 国产在线日韩在线| 91高潮精品免费porn| 日韩激情片免费| 国产视频精品一区二区三区| 亚洲天堂av网| 国产精品美女www爽爽爽视频| 亚洲jizzjizz日本少妇| 日韩有码视频在线| 国产美女91呻吟求| 国内伊人久久久久久网站视频| 性视频1819p久久| 国产成人精品在线播放| 日韩精品视频观看| 亚洲影院高清在线| 久久久精品国产| 欧美巨乳美女视频| 日韩欧美国产成人| 亚洲日韩中文字幕| 国产精品久久久久久久久久久新郎| 欧美精品第一页在线播放| 91久久精品美女| 国产精品自产拍高潮在线观看| 国产成人精品在线视频| 欧美日韩加勒比精品一区| 亚洲综合色av| 欧美日韩国产精品专区| 97精品国产97久久久久久春色| 国产99久久精品一区二区永久免费| 91影视免费在线观看| 欧美日韩人人澡狠狠躁视频| 91精品国产综合久久久久久久久| 国产日韩欧美在线视频观看| 免费91麻豆精品国产自产在线观看| 国产精品一区二区三区久久| 亚洲全黄一级网站| 中文字幕久热精品视频在线| 久久久久久久久国产精品| 久久久欧美精品| 国产视频精品在线| 日韩在线视频免费观看高清中文| 91精品国产综合久久久久久蜜臀| 日韩成人在线观看| 亚洲国产小视频在线观看| 亚洲激情在线观看| 欧美理论电影网| 精品国产鲁一鲁一区二区张丽| 欧美最猛性xxxxx免费| 中文字幕视频在线免费欧美日韩综合在线看| 久久大大胆人体| 91国产精品电影| 精品国产欧美成人夜夜嗨| www.日本久久久久com.| 亚洲无限乱码一二三四麻| 国产精品久久久av久久久| 欧美理论在线观看| 91精品国产自产在线观看永久| 91国在线精品国内播放| 亚洲桃花岛网站| 精品久久久久久久久久久| 欧美极品第一页| 亚洲3p在线观看| 欧美激情免费在线| 成人精品久久av网站| 国内精久久久久久久久久人| 色综合久久中文字幕综合网小说| 91成人免费观看网站| 国产精品久久久久久久午夜| 国产+成+人+亚洲欧洲| 日韩黄色av网站| 国产精品揄拍500视频| 亚洲三级av在线| 欧美性生交大片免网| 欧美精品www在线观看| 国产精品亚洲视频在线观看| 日韩在线观看免费高清完整版| 在线日韩欧美视频| 国产剧情久久久久久| 久久综合伊人77777尤物| 亚洲欧美另类在线观看| 成人日韩av在线| 国产精品免费福利| 26uuu日韩精品一区二区| 日韩中文字幕欧美| 亚洲精品中文字幕女同| 国产一区二区三区视频在线观看| 国产精品99久久久久久www| 亚洲成成品网站| 久久久精品视频在线观看| 日韩在线观看免费| 日韩电影在线观看免费| 欧美野外wwwxxx| 日韩精品在线观看网站| 日韩大片免费观看视频播放| 国产欧美一区二区白浆黑人| 成人黄色片网站| 国产欧美va欧美va香蕉在线| 51视频国产精品一区二区| 91久久精品视频| 国产欧美精品一区二区三区介绍| 欧美一级大片在线免费观看| 久久夜色精品国产欧美乱| 欧美性资源免费| 在线视频日韩精品| 精品久久久久久电影| 国内精品视频一区| 92国产精品久久久久首页| 国产精品国产三级国产专播精品人| www.日韩.com| 久久久久999| 欧美日韩国产激情| 97人洗澡人人免费公开视频碰碰碰| 亚洲天堂av在线免费观看| 久久久久久有精品国产| 精品日韩美女的视频高清| 国产精品美女无圣光视频| 97在线观看免费高清| 久久精品中文字幕一区| 亚洲国产另类久久精品| 亚洲色图国产精品| 精品视频在线观看日韩|