电子科技大学通信学院附录1.PPT

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
电子科技大学通信学院附录1

霍夫曼编码综合设计 综合实验设计 霍夫曼信源编码综合设计 实验目的 通过本专题设计,掌握熵编码的原理和方法,并熟悉C语言的使用。 实验原理 数字通信系统的组成 实验原理 信源编码是通过压缩编码来去掉信号源中的冗余成分,以达到压缩码率和带宽,实现信号有效传输的目的,因此压缩编码的技术与标准成为信源编码的核心。 信道编码是通过按一定规则重新排列信号码元或加入辅助码的办法来防止码元在传输过程中出错,并进行检错和纠错,以保证信号的可靠传输。 信道编码后的基带信号经过调制,可送入各类通 信信道中进行传输。 从信息论的分析可知,减少或消除各信源符号间的关联,并使各符号的出现趋于等概分布,将使离散信源达到最大熵,从而以最少的符号数传送最大的信息量。 Huffman编码算法需要的两个基本概念 Entropy(熵)的概念 熵是信息量的度量方法,它表示某一事件事件发生的可能性越小,数学上就是概率越小,该事件携带的信息就越多。 某个事件的信息量用 表示,其中 为第i个事件的概率, 信源S的熵的定义 [例1] 有一幅40个象素组成的灰度图像,灰度共有5级,分别用符号A、B、C、D和E表示,40个象素中出现灰度A的象素数有15个,出现灰度B的象素数有7个,出现灰度C的象素数有7个等等,如表1所示。如果用3个位表示5个等级的灰度值,也就是每个象素用3位表示,编码这幅图像总共需要120位。 表1 符号在图像中出现的数目 按照仙农理论,这幅图像的熵为 霍夫曼编码步骤 1.初始化,根据符号概率的大小按由大到小顺序对符号进行排序,如表3和图2所示。 2.把概率最小的两个符号组成一个节点,如图2中的D和E组成节点P1。 3.重复步骤2,得到节点P2、P3和P4,形成一棵“树”,其中的P4称为根节点。 4. 从根节点P4开始到相应于每个符号的“树叶”,从上到下标上“0”(上枝)或者“1”(下枝),至于哪个为“1”哪个为“0”则无关紧要,最后的结果仅仅是分配的代码不同,而代码的平均长度是相同的。(注意:为了便于对设计的程序进行检验,在标“0”“1”时,一律按从下到上标上“0”(下枝)和“1”(上枝),如图2所示) 。 5.从根节点P4开始顺着树枝到每个叶子分别写出每个符号的代码,如表3所示。 图2 霍夫曼编码方法 表3 霍夫曼编码 这副图的压缩比1.3333:1(120:90)。与仙农-范诺编码相比,这两种方法都自含同步码,在编码之后的码串中都不须要另外添加标记符号,即在译码时分割符号的特殊代码。此外,霍夫曼编码方法的编码效率比仙农-范诺编码效率高一些。 实验要求及成绩说明 用C语言设计一个类似于压缩软件的程序,要求能够对任意文件进行Huffman编码,最后生成一个压缩文件,格式为*.hfm(具体格式《霍夫曼信源编码综合设计》实验教材的附录1)。 在本课程结束时应交上实验设计报告和程序。 实验成绩 = 实验程序(30%) +实验报告(50%)+考勤(20%,共四次,5分/次) 实验报告要求 实验报告中需包含问题分析、算法分析、程序的流程图等设计细节以及个人对霍夫曼编码不足之处的思考与解决办法,以及个人在本课程设计中的心得体会,在设计中遇到了什么问题,怎么解决的问题,学到了什么等等,并完成思考题。(参见《霍夫曼信源编码综合设计》实验教材的附录2 ) 附录1:霍夫曼编码格式 1.? 文件扩展名:*.hfm 2.? 文件结构(三部分) HUFFMAN压缩文件结构 文件头HUFFMANFILEHEADER typedefstructtagHUFFMANFILEHEADER{ WORD hfType;//指定文件类型,必须是0x4846,即字符串HF DWORD hfSize;//指定文件大小,包括这12个字节 WORD FileNameLength;//指定被压缩文件名称的字节数 BYTE SourceSignalNum; //指定信源符号的个数,也是 //HUFFMAN码表的项数。 WORD hfOffBits; //从文件头到实际数据的偏移字节数,即前 //两个部分(文件头和码表)的长度之和。 BYTE ValidDataBitsNum; //(数据部分中)最后一个字 //节中有效的比特位数 } HUFFMANFILEHEADER; 霍夫曼码表HUFFMANTABLE typedefstructtagHUFFMANTABLE{ BYTE SourceSig

您可能关注的文档

文档评论(0)

fengruiling + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档