第2章 数据无损压缩.pptVIP

  1. 1、本文档共70页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第2章 数据无损压缩

2.4 词典编码 2.4.4 LZ78算法 【例2.7】待编码字符串(字符流)如下表,进行LZ78编码。 位置 1 2 3 4 5 6 7 8 9 字符 A B B C B C A B A 编码位置 当前字符Ch := A。 Pr :=B。 Pr+Ch(即BA)不在词典中,则 (1) 输出(Pr对应的码字,Ch), 即(2,A); (2) 把Pr+Ch,即BA添加到词典中; (3) 令Pr := 空值。 结束编码。 步骤 编码位置 词典 输出 1 1 A (0,A) 2 2 B (0,B) 3 3 BC (2,C) 4 5 BCA (3,A) 5 8 BA (2,A) 步骤 词典 步骤 词典 1 A 3 BC 2 B 4 BCA 2.4 词典编码 2.4.4 LZ78算法 【例2.7】待编码字符串(字符流)如下表,进行LZ78编码。 LZ78的编码思想:不断地从字符流中提取新的缀-符串(新“词条”),然后用“代号”也就是码字表示这个“词条”。这样一来,对字符流的编码就变成了用码字去替换字符流,生成码字流,从而达到压缩数据的目的。 步骤 编码位置 词典 输出 1 1 A (0,A) 2 2 B (0,B) 3 3 BC (2,C) 4 5 BCA (3,A) 5 8 BA (2,A) 位置 1 2 3 4 5 6 7 8 9 字符 A B B C B C A B A 编码过程 2.4 词典编码 2.4.4 LZ78算法 与LZ77相比,LZ78的最大优点是在每个编码步骤中减少了缀-符串比较的次数,而压缩率与LZ77类似。 LZ78译码算法如下: 【步骤1】 在开始时词典是空的。 【步骤2】 当前码字W :=码字流中的下一个码字。 【步骤3】 当前字符C := 紧随码字之后的字符。 【步骤4】把当前码字的缀-符串(string.W)输出到字符流,然后输出字符C。 【步骤5】 把string.W+C添加到词典中。 【步骤6】判断码字流中是否还有码字要译  (1) 如果“是”,就返回到步骤2。  (2) 如果“否”,则结束。 2.4 词典编码 2.4.5 LZW算法 LZW编码算法是围绕称为词典的转换表来完成的,如下表“LZW词典” 码字 前缀 1 … … 193 A 194 B … … 码字 前缀 255 … … 1305 abcdefxyF01234 … … 上表实际扩充了8位ACSII字符集,增加的符号用来表示在文本或图像中出现的可变长度ASCII字符。 Welch论文中采用12位代码,共4096个表项,256个表项存放已定义字符,3840个表项存放前缀。 2.4 词典编码 2.4.5 LZW算法 在LZW算法中使用的术语与LZ78使用的相同,仅增加了一个术语—前缀根(Root),它是由单个字符串组成的缀-符串。 在编码原理上,LZW与LZ78相比有如下差别: (1) LZW只输出代表词典中的缀-符串的码字(code word)。则词典初始不能为空,它必须包含前缀根。 (2) 由于所有可能出现的单个字符都事先包含在词典中,每个编码步骤开始时都使用一字符前缀(one-character prefix)。 (3) 重构词典时不需要在码字流中加入额外的符号。 LZW编码器使用了贪婪分析算法(greedy parsing algorithm),即每一次分析都要串行地检查来自字符流的字符串,从中分解出已经识别的最长的字符串(即已在词典中出现的最长前缀)。 2.4 词典编码 2.4.5 LZW算法 Dictionary[j] ← all n single-character, j=1, 2, …,n j ← n+1 Prefix ← read first Character in Charstream while((C ← next Character)!=NULL) Begin If Prefix.C is in Dictionary Prefix ← Prefix.C else Codestream ← cW for Prefix Dictionary[j] ← Prefix.C j ← n+1 Prefix ← C end Codestream ← cW for Prefix LZW编码算法伪代码 2.4 词典编码 2.4.5 LZW算法 LZW算法得到普遍采用,它的速度比LZ77算法快,因为它不需要执行那么多的缀-符串比较操作。 对LZW算法进一步的改进是增加可变的码字长度,以及在词典中删除老的缀-符串

文档评论(0)

wyjy + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档