霍夫曼信源编码实验报告

霍夫曼信源编码实验报告

ID:35239226

大小:132.36 KB

页数:7页

时间:2019-03-22

霍夫曼信源编码实验报告_第1页
霍夫曼信源编码实验报告_第2页
霍夫曼信源编码实验报告_第3页
霍夫曼信源编码实验报告_第4页
霍夫曼信源编码实验报告_第5页
资源描述:

《霍夫曼信源编码实验报告》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、实验1:霍夫曼信源编码综合设计【实验目的】通过本专题设计,掌握霍夫曼编码的原理和实现方法,并熟悉利用C语言进行程序设计,对典型的文本数据和图像数据进行霍夫曼编解码。【预备知识】1、熵的概念,霍夫曼编码原则2、数据结构和算法设计3、C(或C++)编程语言【实验环境】1、设备:计算机一台2、软件:C程序编译器【设计要求】根据霍夫曼编码原则,利用C语言设计并实现霍夫曼编码和解码程序,要求能够对给出的典型文本数据和图像数据进行霍夫曼编解码,并计算相应的熵和压缩比。【实验原理】Huffman编码属于熵编码的方法之一,是根据信源符号出现概率的分布特性而进行的压缩编码。Huffman编码的主要思想是

2、:出现概率大的符号用长的码字表示;反之,出现概率小的符号用短的码字表示。Huffman编码过程描述:1.初始化:将信源符号按出现频率进行递增顺序排列,输入集合L;2.重复如下操作直至L中只有1个节点:(a)从L中取得两个具有最低频率的节点,为它们创建一个父节点;(b)将它们的频率和赋给父结点,并将其插入L;3.进行编码:从根节点开始,左子节点赋予1,右节点赋予0,直到叶子节点。【基本定义】71.熵和平均编码符号长度熵是信息量的度量方法,它表示某一事件出现的概率越小,则该事件包含的信息就越多。根据Shannon理论,信源S的熵定义为,其中是符号在S中出现的概率;表示包含在中的信息量,也就

3、是编码所需要的位数假设符号编码后长度为li(i=1,…,n),则平均编码符号长度L为:2.压缩比设原始字符串的总长度为Lorig位,编码后的总长度为Lcoded位,则压缩比R为R=(Lorig-Lcoded)/Lorig【例子】有一幅40个象素组成的灰度图像,灰度共有5级,分别用符号A、B、C、D和E表示,40个象素中出现灰度A的象素数有15个,出现灰度B的象素数有7个,出现灰度C的象素数有7个等等,如表1所示。如果用3个位表示5个等级的灰度值,也就是每个象素用3位表示,编码这幅图像总共需要120位。表1符号在图像中出现的数目符号ABCDE出现的次数157765根据Shannon理论,

4、这幅图像的熵为H(S)=(15/40)´(40/15)+(7/40)´(40/7)++(5/40)´(40/5)=2.196平均编码符号长度L为(15/40)*1+(7/40)*3+(7/40)*3+(6/40)*3+(5/40)*3=2.25根据霍夫曼编码原则可以得到如下的霍夫曼编码表。表2霍夫曼编码举例符号出现的次数log2(1/pi)分配的代码所需位数A15(0.375)1.4150115B7(0.175)2.514501121C7(0.175)2.514501021D6(0.150)2.736900118E5(0.125)3.000000015因而,这副图采用霍夫曼编码的压缩比

5、R为1.3333:1(120:90)。霍夫曼码的码长虽然是可变的,但却不需要另外附加同步代码。例如,码串中的第1位为0,那末肯定是符号A,因为表示其他符号的代码没有一个是以0开始的,因此下一位就表示下一个符号代码的第1位。同样,如果出现“110”,那么它就代表符号D。如果事先编写出一本解释各种代码意义的“词典”,即码簿,那么就可以根据码簿一个码一个码地依次进行译码。7【实验步骤】(16学时)根据提供的示例Huffman编译码器源程序,利用VC++6.0进行编译生成可执行文件,阅读并运行程序。1、用MicrosoftOfficeVision分别画出Huffman编码和译码程序流程图,写出

6、用到的主要数据结构并加以说明。2、在Huffman编码器合适位置加入4个函数:calcProbability,calcEntropy,calcAvgSymbolLength,calcCompressionRatio,分别计算信源各符号出现的概率、信源的熵、平均编码符号长度以及压缩比。(自定义函数的参数)3、分析霍夫曼编译码码的计算复杂度,定量说明Huffman编码和译码哪种操作更耗时?4、设计中遇到的问题,怎样解决问题的。在设计过程中的心得体会。思考题:1、霍夫曼编码是否具有唯一性?2、个人对霍夫曼编码方式的不足之处的思考以及怎么样在进行压缩时避免这些问题。3、分析霍夫曼编码对文本数据

7、以及图象数据的编码效率,观察与对应信源概率分布的关系。4、参考静止图像压缩编码国际标准JPEG,为了提高对图像编码的效率,通常要在霍夫曼编码之前进行什么操作?5、。【实验结果】一.译码与编码流程图如下所示:1.译码流程图图像显示指令?接收到有效指令?主程序程序初始化7否返回主程序调用字符库数据显示字符字符显示指令?是调用图像库数据是图像像素数据?否是否否显示图像JPEG格式图像解码是2.编码流程图图像显示指令?接收到有效指令?主程序程序初始化7

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。