1. 前言

在前面一片文章TIFF文件结构详解里,我们在解析TIF文件中,提到使用了LZW算法。那么LZW算法是什么呢?就让我们揭开它的神秘面纱。

2. 什么是LZW

LZW算法又叫“串表压缩算法”就是通过建立一个字符串表,用较短的代码来表示较长的字符串来实现压缩。 LZW压缩算法是Unisys的专利,有效期到2003年,所以对它的使用已经没有限制了。字符串和编码的对应关系是在压缩过程中动态生成的,并且隐含在压缩数据中,解压的时候根据表来进行恢复,算是一种无损压缩。这里涉及到对应关系表,最开始会有一个单个字符的对应关系表,当然,一般都以ACCISS码表示,这里提到的关系映射表主要是多个字符的关系映射表。

3. LZW编码算法

3.1 概述

编码器从原字符串不断地读入新的字符,并试图将单个字符或字符串编码为记号 (Symbol)。这里我们维护两个变量,一个是P (Previous),表示手头已有的,还没有被编码的字符串,一个是C (current),表示当前新读进来的字符。下图展示了其编码过程。

  1. 初始状态,字典里只有所有的默认项,例如0->a,1->b,2->c。此时P和C都是空的。
  2. 读入新的字符C,与P合并形成字符串P+C。
  3. 在字典里查找P+C,如果:
    P+C在字典里,P=P+C。
    P+C不在字典里,将P的记号输出;在字典中为P+C建立一个记号映射;更新P=C。
  4. 返回步骤2重复,直至读完原字符串中所有字符。

3.2 举例

假设现在有数据字典如下:

字符 编码
a 0
b 1
c 2

现在将ababcababac(11个字符)进行编码。具体步骤如下:

步骤 P C P+C P+C in Dict action output
1 - a a YES 更新P=a -
2 a b ab NO 添加数据字典3->ab,更新P=b 0
3 b a ba NO 添加数据字典4->ba,更新P=a 1
4 a b ab YES 更新P=ab -
5 ab c abc NO 添加数据字典5->abc,更新P=c 3
6 c a ca NO 添加数据字典6->ca,更新P=a 2
7 a b ab YES 更新P=ab -
8 ab a aba NO 添加数据字典7->aba,更新P=a 3
9 a b ab YES 更新P=ab -
10 ab a aba YES 更新P=aba -
11 aba c abac NO 添加数据字典8->abac,更新P=c 7
12 c - - - - 2

所以,最终编码为0132372(7个字符)。

4. LZW解码算法

4.1 解码概述

解码的过程比编码复杂,其核心思想在于解码需要还原出编码时的用的字典。因此要理解解码的原理,必须分析它是如何对应编码的过程的。下面首先给出算法:

解码器的输入是压缩后的数据,即记号流 (Symbol Stream)。类似于编码,我们仍然维护两个变量pW (previous word) 和cW (current word),实际上就是记号 (Symbol),或者说子串。pW表示之前刚刚解码的记号;cW表示当前新读进来的记号。

  1. 初始状态,字典里只有所有的默认项,例如0->a,1->b,2->c。此时pW和cW都是空的。

  2. 读入第一个的符号cW,解码输出。注意第一个cW肯定是能直接解码的,而且一定是单个字符。

  3. 赋值P=C,pW=cW。

  4. 读入下一个符号cW。

  5. 在字典里查找cW,如果:

    1. cW在字典里:
      (1) 解码cW的值为C,即输出C。
      (2) 令P+C的第一个字符添加到记号映射。
      (3) 更新P = C。

    2. cW不在字典里:
      (1) C=P的第一个字符
      (2) 在字典中为P+C添加新的记号映射。

      (3) 输出P+C。

      (4) 更新P = P + C

  6. 返回步骤3重复,直至读完所有记号。

4.2 举例

我们那上面编码0132372的结果进行解码。初始化字典任然为如下表:

字符 编码
a 0
b 1
c 2

首先读取第一个记号cW=0,解码为a,输出,赋值pW=cW=0。然后开始循环,依此读取后面的记号:

Step PW CW CW In Dict P C action output
1 - 0 YES - a PW=CW=0;P=C=a; a
2 0 1 YES a b PW=CW=1;P=C=b;3->ab(P+C第一个字符) b
3 1 3 YES b ab PW=CW=3;P=C=b;4->ba(P+C第一个字符) ab
4 3 2 YES ab c PW=CW=2;P=C=c;5->abc(P+C第一个字符) c
5 2 3 YES c ab PW=CW=3;P=C=ab;6->ca(P+C第一个字符) ab
6 3 7 NO ab - C=a(P第一个字母);输出aba(P+C);7->aba(P+C);PW=CW=7;P=aba aba
7 7 2 YES aba c PW=CW=2;P=C=c;3->abac(P+C第一个字符) c

因此,最终解码的字符为:ababcababac

LZW编码与解码的那点事相关推荐

  1. MATLAB实现LZW编码与解码

    clear all clc str = input('请输入一串字符:','s'); disp("编码开始..."); %% 编码 N = length(str); % 获得输入字 ...

  2. C语言实现LZW编码

    LZW编码 算法思想 首先我们有一个0到255的ASCII码表,然后得到若干字符串对其进行编码,再对编码后的码流进行解码以验证. 编码: 初始化:前缀P为空,第一个字符进入后缀C 判断:P+C(P为a ...

  3. Python的编码与解码

    转自: http://www.cnblogs.com/huxi/archive/2010/12/05/1897271.html 一. 字符编码简介 1.1. ASCII ASCII(American  ...

  4. 计算机编码与解码编码表

    目录 一.编码与解码 1.什么是编码与解码 二.常见的编码表 1.ASCII 2.ISO-8859-1 3.Windows-1252 4.GB2312 5.GBK 6.GB18030 7.Big5 乱 ...

  5. Python实现英文文本的LZW编码压缩

    LZW编码采用隐字典码的形式完成压缩. 文本中符号并不是独立存在的,前一个符号对后一个符号的出现有着很大影响. LZW算法利用文本开头部分的特征,作为整个文本的特征,即利用文本开头部分的内容,生成固定 ...

  6. 【数据压缩】C++实现LZW算法编解码

    一.实验目的 掌握词典编码的基本原理,用C/C++/Python等语言编程实现LZW解码器并分析编解码算法. 选择十种不同格式类型的文件,使用LZW编码器进行压缩得到输出的压缩比特流文件.对各种不同格 ...

  7. Python 对图像进行base64编码及解码读取为numpy、opencv、matplot需要的格式

    Python 对图像进行base64编码及解码读取为numpy.opencv.matplot需要的格式 1. 效果图 2. 源码 参考 这篇博客将介绍Python如何对图像进行base64编解码及读取 ...

  8. 二叉树:二叉搜索树的编码和解码

    二叉搜索树的编码和解码描述: 编码:即将一个二叉搜索树编码,节点数值转换为字符串 解码:即将一个字符串解码,数值转换为对应的二叉搜索树的节点 过程导图如下: 针对性编码实现如下: /*数字转字符串*/ ...

  9. js php base64,JavaScript实现Base64编码与解码的代码详解

    本篇文章给大家分享的是jJavaScript实现Base64编码与解码的代码详解,内容挺不错的,希望可以帮助到有需要的朋友 一.加密解密方法使用//1.加密 var str = '124中文内容'; ...

最新文章

  1. 工业界AI项目落地血泪教训总结
  2. 新建html带参数,本地html加载时带参数的问题
  3. 【主机】vnc 介绍以及安装时注意的问题
  4. java.util.List学习笔记
  5. c# 标准正太分布函数_数据标准化处理中的min-max和zscore
  6. android适配性报告,关于Android的多种屏幕适配
  7. C语言中指针和数组的区别
  8. Mybatis 的日志管理
  9. html——windows.onload()与$(document).ready()区别
  10. Dos window下运行java程序
  11. 【转】让VB6.0集成环境支持鼠标滑轮
  12. 全自动电音基调查询助手软件下载完美支持32_64bit系统所有电音插件。
  13. 写给2018考研的你
  14. 基于STM32设计的宠物投喂器
  15. 使用D3渲染中国地图
  16. Nature Reviews Microbiology | 土壤微生物组与同一健康
  17. cad无法安装_CAD软件下载好了,为什么安装不上?有两个原因,解决方法在这
  18. 如何在小视频源码里实现边下边播
  19. 机器学习实战-54: 集成学习分类算法(ada-boost)
  20. sed: -e expression #1, char 0: no previous regular expression

热门文章

  1. 单片机执行指令过程详解
  2. 计算机专业英语博士就业情况,北京外国语大学博士就业前景怎么样
  3. C语言输出4*5的矩阵
  4. 【工作】论文格式详细要求
  5. 2021年十大最有前途的编程语言,第1名实至名归or名不副实?
  6. 数据标准化的原因和方法
  7. spring源码系列一--BeanDefinition
  8. Hander创建消息
  9. 激光导引头电子舱测试系统软件的研究与开发
  10. jmeter非GUI输出性能测试报告报WARNING: Could not open/create prefs root node Software\JavaSoft\Prefs at root 0x