图像压缩编码是专门研究图像数据压缩的技术,就是尽量减少表示数据图像所需要的数据量。
本章主要介绍图像压缩编码的基础知识,重点讲解常用的图像压缩编码方法,如霍夫曼编码、香农编码、算术编码、行程编码和预测编码及编码方法的MATLAB实现,最后介绍了静态图像压缩标准JPEG标准。
数字图像通常需要很大的比特数,这给图像的传输和存储带来相当大的困难。例如用8bit存储一幅512512的灰度图像的比特数为256K。而一部60分钟的彩色电影,如果每秒放映24帧,数字化后每帧包含512512像素,每像素的R、G、B分量分别占8bit,则这样一部电影的总比特数为64800M,若用一张600M的CD存储则需要100多张CD光盘来存储。由此可见对图像数据进行压缩显得非常必要。减少存储空间、缩短传输时间这成为促进图像压缩编码技术发展的主导因素。图像压缩是通过编码来实现的,所以通常将压缩与编码统称为图像的压缩编码。图像压缩编码从本质上来说就是对要处理的图像数据按照一定的规则进行变换和组合,从而达到以尽可能少的数据来表示尽可能多的数据信息。

1 霍夫曼编码

霍夫曼在1952年提出了一种构造最佳码的方法,称之为霍夫曼编码(Huffman)。霍夫曼编码是一种无损的统计编码方法,利用信息符号概率分布特性的改变字长进行编码。霍夫曼编码适用于多远独立信源,对于多元独立信源来说它是最佳码。
霍夫曼编码是一种利用信息符号概率分布特性的变字长的编码方法,即对于出现概率大的信息符号编以短字长的码,对于出现概率小的信息符号编以长字长的码。如果码字长度严格按照所对应符号出现概率大小逆序排列,则编码结果的平均码字长度一定小于任何其他排列形式。霍夫曼编码则是严格按照信源符号出现的概率大小来构造码字,因此这种编码方式形成的平均码字长度最短。
霍夫曼编码系统主要分为压缩对象输入、概率统计、构造Huffman树、生成Huffman树、压缩编码环节组成,如图所示霍夫曼编解码系统构成。编程思路依据霍夫曼的编程步骤进行,实现对数据的压缩及其压缩参数的计算。

1.1编码参数

一副大小为m*n的图像灰度级为K,图像中第k级灰度出现的概率为Pk,每个像素用d比特表示,每两帧图像间隔为△t,则相关参数为:
数字图像的熵H :
表示图像信源的平均信息量。
图像平均码子长度R:
描述图像压缩后的平均码子长度。
编码效率:
描述图像编码效率
信息冗余度:
描述图像被压缩的程度,冗余度越小则图像可以被压缩的程度越小。
每秒所需的传输比特数为:
反映的数据的容量。
压缩比: r = d/R

1.2 霍夫曼编码的步骤如下:

1.将信源符号按出现概率从大到小排成一列,然后把最末两个符号的概率相加,合成一个概率。
2.把这个符号的概率与其余符号的概率按从大到小排列,然后再把最末两个符号的概率加起来,合成一个概率。
3.重复上述做法,直到最后剩下两个概率为止。
4.从最后一步剩下的两个概率开始逐步反向进行编码。每步只需对两个分支各赋予一个二进制码,如对概率大的赋予码1,对概率小的赋予码O。

1.3 霍夫曼编码的源代码

1.3.1 fliplr 左右翻转矩阵函数,sort排序函数,find返回非零元素函数

fliplr(A)
将矩阵A的列绕垂直轴进行左右翻转 matabc
如果A是一个行向量,fliplr(A)将A中元素的顺序进行翻转。
如果A是一个列向量,fliplr(A)还等于A。
sort排序函数
sort(A):对一维或二维矩阵进行升序排序,并返回排序后的矩阵;当A为二维矩阵时,对矩阵的每一列分别进行排序。
sort(A,dim):对矩阵按指定的方向进行升序排序,并返回排序后的矩阵。当dim=1时,对矩阵的每一列排序(即将第一维行数打乱重排);当dim=2时,对矩阵的每一行排序(即将第二维列数打乱重排)。
sort(A,dim,mode):mode为’ascend’时,进行升序排序;mode为’descend’时,进行降序排序。相比于sort(A)可见默认升序,默认dim=1。
find返回非零元素函数

返回前N个非零元素的位置,find(A,X)
返回最后一个非零值的位置find(A,1,‘last’)
返回最后一个非零值的行列位置或者A中非零元素位置
[a,b,v] = find(A),找出A中非零元素所在的行和列,分别存储在a和b中,并将结果放在v中。

%【例10-2】霍夫曼编码
close all; clear all; clc;              %关闭所有图形窗口,清除工作空间所有变量,清空命令行
A=[0.5,0.19,0.19,0.12];                    %信源消息的概率序列
A=fliplr(sort(A));                     %按降序排列
T=A;
[m,n]=size(A);
B=zeros(n,n-1);                            %空的编码表(矩阵)
for i=1:nB(i,1)=T(i);                         %生成编码表的第一列
end
r=B(i,1)+B(i-1,1);                        %最后两个元素相加
T(n-1)=r;
T(n)=0;
T=fliplr(sort(T));
t=n-1;
for j=2:n-1                                %生成编码表的其他各列for i=1:tB(i,j)=T(i);endK=find(T==r);B(n,j)=K(end);                    %从第二列开始,每列的最后一个元素记录特征元素在该列的位置r=(B(t-1,j)+B(t,j));                  %最后两个元素相加T(t-1)=r;T(t)=0;T=fliplr(sort(T)); t=t-1;
end
B;                                  %输出编码表
END1=str2sym('[0 ,1]');                      %给最后一列的元素编码
END=END1;
t=3;
d=1;
for j=n-2:-1:1                         %从倒数第二列开始依次对各列元素编码for i=1:t-2if i>1 & B(i,j)==B(i-1,j)d=d+1;elsed=1;endB(B(n,j+1),j+1)=-1;temp=B(:,j+1);x=find(temp==B(i,j));END(i)=END1(x(d));endy=B(n,j+1);END(t-1)=[char(END1(y)),'0'];END(t)=[char(END1(y)),'1'];t=t+1;END1=END;
end
disp('排序后的原概率序列A:');
disp(A)                             %排序后的原概率序列
disp('编码结果END:')
disp(END)   ;                           %编码结果
for i=1:n[a,b]=size(char(END(i)));L(i)=b;
end
disp('平均码字长度')
avlen=sum(L.*A);disp(avlen);                   %平均码长
H1=log2(A);
disp('信息熵')
H=-A*(H1');disp(H)                            %熵
disp('编码效率')
P=H/avlen;disp(P)                          %编码效率


图像处理—霍夫曼编码相关推荐

  1. 可逼近信道容量编码技术之霍夫曼编码的实现

    可逼近信道容量编码技术之霍夫曼编码的实现 简介 在当今信息爆炸时代,如何采用有效的数据压缩技术来节省数据文件的存储空间和计算机网络的传送时间已越来越引起人们的重视.哈夫曼编码正是一种应用广泛且非常有效 ...

  2. 【数据结构】图解霍夫曼编码,看了就能懂

    今天来给大家普及一下霍夫曼编码(Huffman Coding),一种用于无损数据压缩的熵编码算法,由美国计算机科学家大卫·霍夫曼在 1952 年提出--这么专业的解释,不用问,来自维基百科了. 说实话 ...

  3. 信息论4—无失真信源编码(非延长码,霍夫曼编码)

    无失真信源编码 单义可译码 码字非奇异,码字序列非奇异. 单义可译定理--克拉夫不等式 非延长码(即时码,在无失真信源编码中,常采用此码) 延长码:部分码字是其它码字的前缀.100是10的延长码,01 ...

  4. 数据结构与算法 / 霍夫曼树、霍夫曼编码和解码

    一. 诞生原因 找出存放一串字符所需的最少的二进制编码. 二. 构造方法 首先统计出每种字符出现的频率,即:概率.权值. 例如:频率表 A:60,    B:45,   C:13   D:69   E ...

  5. 哈夫曼编码压缩率计算_程序员的算法课(8)-贪心算法:理解霍夫曼编码

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/m0_37609579/article/ ...

  6. C语言Huffman Encode霍夫曼编码的算法(附完整源码)

    C语言Huffman Encode霍夫曼编码的算法 C语言Huffman Encode霍夫曼编码的算法完整源码(定义,实现,main函数测试) C语言Huffman Encode霍夫曼编码的算法完整源 ...

  7. 灵光一现的创造——霍夫曼编码

    点击上方"LiveVideoStack"关注我们 作者 | Alex 技术审校 | 赵军 霍夫曼 声影传奇 #004# 作为一名科学家和老师,我真的非常执着.如果我觉得自己还没有找 ...

  8. 贪心算法之最小堆实现霍夫曼编码

    贪心算法之最小堆实现霍夫曼编码 实现之前需要学习的地方: 如果你不了解堆.堆的插入.堆的删除,可以先看下我前面几篇博客 http://blog.csdn.net/u011068702/article/ ...

  9. 贪心算法(Greedy Algorithm)之霍夫曼编码

    文章目录 1. 贪心算法 2. 应用 2.1 找零钱 2.2 区间覆盖 2.3 霍夫曼编码 霍夫曼编码完整代码 1. 贪心算法 我们希望在一定的限制条件下,获得一个最优解 每次都在当前的标准下做出当下 ...

最新文章

  1. Grunt插件之LiveReload 实现页面自动刷新,所见即所得编辑
  2. 【批处理学习笔记】第二十四课:直接传递
  3. 在visualstudio中使用Qt
  4. 网络安全比赛理论答题(二)
  5. U-Boot 之二 详解使用 eclipse + J-Link 进行编译及在线调试
  6. Linux MySQL5.5的安装
  7. 牛客 - A Simple Game(尼姆博弈变形)
  8. C# ConcurrentBag的实现原理
  9. html中写meta会乱码,BeautifulSoup+Unicode,该死的html乱码,尽管在meta标记中指定了字符集...
  10. linux源码acl,Linux自主访问控制机制模块详细分析之posix_acl.c核心代码注释与acl.c文件介绍...
  11. matlab2c使用c++实现matlab函数系列教程-expstat函数
  12. 05-python中的异常
  13. 即时获取最新全国省市区县地图json数据(亲测可用)以及echarts中使用中国地图
  14. jenkins恢复删除的文件
  15. 成年人夜生活的自救! 华熙LIVE·五棵松放大招
  16. Python采集淘宝1585个商家车厘子数据,看看到底有多贵
  17. Linux从入门到放弃 docker
  18. anemometer mysql5.6_Anemometer|Anemometer(mysql慢查询日志分析工具)下载免费版 - 欧普软件下载...
  19. python 英语分词_NLTK(一):英文分词分句
  20. 啊,CET6 2020年12月

热门文章

  1. VScode无法跳转函数/no definition found for xxx
  2. P3393 逃离僵尸岛
  3. 【源码】ThingSpeak支撑工具箱:与物联网数据平台交互的工具
  4. 利用pycharm简单实现多进程
  5. 高达1万欧元!AI所绘制的画作出现在佳士出场
  6. 手机html5测试苹果八,怎么检测iPhone8的真假 查这些步骤确保真机
  7. 读写access数据(简单版)
  8. 这20个机械键盘,敲代码贼爽!送了
  9. 小红书爆文怎么打造?今天让我们一起来看看吧
  10. 惠普奥德赛计划:谁的掘墓人?