APP下载

基于四叉树的嵌入式平台Huffman解码优化

2012-09-07鲁云飞何明华

关键词:四叉树码流二值

鲁云飞,何明华

(1.福州大学电气工程与自动化学院,福建福州350108;2.福州大学物理与信息工程学院,福建福州350108)

基于四叉树的嵌入式平台Huffman解码优化

鲁云飞1,何明华2

(1.福州大学电气工程与自动化学院,福建福州350108;2.福州大学物理与信息工程学院,福建福州350108)

考虑到嵌入式设备资源的有限性,提出一种基于四叉树的Huffman解码优化算法.解码过程中,先将Huffman码表表示成四叉树结构,据此重建为一维数组,并充分利用数值计算代替判断与跳转操作.为测试本算法解码性能,将其应用于嵌入式MP3实时解码中,结果表明本算法内存损耗小,解码速率快,算法复杂度低,相比于其他优化算法,更适合应用于嵌入式设备中.

嵌入式;四叉树;Huffman解码;解码优化;MP3音频

Huffman编码是一种高效的无失真信源熵编码,作为无损信源压缩的重要方法,该编码算法在文本、音频、图像、视频等多种多媒体数据压缩中得到广泛应用[1-2].Huffman解码的实现分硬件实现和软件实现.其中,硬件实现需采用专用集成电路或芯片,解码效率虽高,但解码成本也高,系统硬件依赖性强,解码灵活度小;而软件实现则依靠处理器采用软件编程为手段,虽效率较前者稍低,但系统开发成本小,灵活度大.传统的Huffman解码软件实现算法主要有顺序搜索法、二值树法、查表法等[1-5].但这些算法分别存在搜索时间长、解码速率低及内存损耗大等问题,因此,不少学者以此为基础,提出了一系列的改进算法.Hashemian及董培良等(以下简称Hashemian等算法)提出每次从码流中读取r比特码元,减少了解码效率对码长的依赖[2-4];Aggarwal等[5]基于特征分类方法提出解码思想,解决了解码效率对码长的依赖问题;Lee等[6]提出了改进二值解码算法(以下简称Lee算法),用数值计算代替每步解码时的判断与跳转操作,其解码效率在一定程度上得到提高.然而,随着生活质量的提高与生活节奏的加快,人们对娱乐设备的要求也越来越高,即要求设备便携的同时还能提供高质量与多功能的服务[6-8].这就需要在不影响功能效果的前提下尽量减小单个功能模块的内存损耗,充分利用嵌入式设备的有限存储空间和能源供给.基于此,本文结合Hashemian等算法中的多位操作及Lee算法中的数值计算等优点,提出了基于四叉树的Huffman解码优化算法.

1 基于四叉树的Huffman解码算法

1.1 Huffman码表四叉树形结构的建立

常规的多媒体数据解码时,其Huffman码多采用二值Huffman树表示.图1为二值Huffman树,即将表1中的Huffman码字用二值树表示时的树形图.为方便算法阐述,表1所示的码表来源于MPEG1音频数据layer 3的部分标准Huffman码表[9].如图1所示,从根节点出发,每次从码流中读取1 bit的码元,根据这个数据的数值进行跳转,若为1则跳转到右节点,反之则跳转到左节点;以此类推,直到跳转至二叉树的叶节点,即可得到码字所代表的字符[10].

从图1可看到:二值Huffman树对码流一位一位进行操作,其码字的搜索次数多,搜索深度广,因而解码效率低.为提高Huffman解码过程中对码字的搜索速度,采用Hashemian等算法中的多位操作思想,以缩短解码过程中对码字的搜素深度.然而,由于Huffman码为单义码,且为前缀码,码中无任何码字为其他码字的前缀,所以会出现相同前缀的码字解出相同结果的情况.为尽量减小这种情况所带来的大量内存冗余,提高嵌入式设备内存使用效率,本算法一次性对码流的2位码元进行操作,将标准Huffman码表重建成四叉树结构,如图2所示.图2中:根节点表示Huffman树的开始;叶子节点表示某个码字的结束,其处存储着该码字所代表的字符;中间节点对应码字的码元;空节点表示该节点为无意义节点.

表1 MP3部分标准Huffman码表Tab.1 Part of the MP3 Huffman code table

图1 二值Huffman树Fig.1 Binary Huffman tree

从图2可看出:该四叉码树同样由父节点及子节点组成,每个节点对应2个码元,且每个节点下面最多有4个子节点,从左到右分别代表读入的码字为“00”~“11”的搜索路径.因而解码时,每经过四叉Huffman树一个节点,相当于从码流中读取2个比特码元进行Huffman码字匹配,故理论上对每个Huffman码字解码的搜索深度及搜索时间最多可减少为原二叉树的1/2.

由于一次性只对码流的2位码元进行操作,当码长为2的整数倍时,最后一组剩余的码元个数为2,因而该组码元即与四叉树中节点是一一对应关系,如图2中的S2~S5;当码长不是2的整数倍时,最后一组剩余的码元个数为1,此时该组码元对应两个具有相同前缀的节点,即如待解的Huffman码字长度为L,M=L mod N(N为单次处理码元的位数),则需要填补(2M-1)个节点,各节点数值大小从左到右,从上到下依次递增“01”,如图2中的S1,S6及S7.从图2可知:本四叉Huffman树的冗余度较小.

1.2 四叉Huffman码树信息的存储

四叉Huffman树重建完后,还需根据其结构将所带数据信息存储起来.为进一步提高解码速度,减少二值Huffman解码算法中大量“比较跳转”操作所消耗的时间,可采用Lee等数值运算的方法,将图2所示的四叉树信息存储成一维数组形式以供解码时使用,所建一维数组Array[]如表2所示.

图2 四叉Huffman树Fig.2 Quad Huffman tree

表2 所建一维数组Tab.2 Single dimensional array constructed

在重建数组时,将四叉树中的节点按照从上到下、从左到右的顺序排列后,依次分配给数组中的元素,因而,数组元素的索引值index随着节点数目的增加而增加.除此之外,数组Array[]中的每个节点包含3个变量:F,el,rv.其中:F用以表示该节点是否为叶节点,若F为0,则该节点为中间节点,否则为叶子节点;el用于表示中间节点中的有效码元个数,且el的取值为1~2;rv用于表示中间节点到其子节点0的偏移距离.如表2所示,数组中的每个元素代表1个节点,且第1行的数据表明了节点在四叉树中所属的层数,表中前4个元素对应树的第1层节点,后5个对应树的第2层,最后4个则对应树的第3层.以四叉树中第2层左起第3个节点为例,其对应表2中索引Index值为6的元素,且其为中间元素,有效码元个数为2,到其0子节点的偏移距离为6,即索引值为12处的元素.

1.3 码流的Huffman解码

利用重建好的Huffman码四叉树型结构及其对应的一维数组,对读入的码流进行相应Huffman解码,其流程如图3所示.具体解码过程如下:

1)先初始化查找表的基地址;

2)从输入的码流中读取2 bit码元,并将新读入码元值new_2digit与初始基地址(即初始索引值Index)之和作为新索引地址值Index,从而得到当前查找节点的地址;

3)从数组中该节点的F值判断该节点是否为叶子节点,若是,则终止本次搜索,并将该节点数组中存储的码字Array[].rv读取出来;否则,将该节点数组中存储的偏移值rv读出来,并与过程2)所得新索引值Index相加,再转到步骤2)继续搜索,直至遇到叶子节点,则该分支码字搜索结束;

4)依次递推搜索直至将输入码流解码完毕;

5)将搜索出来的码字依次排列起来,即为输入Huffman码流所对应解码后的码字.

当对一输入Huffman码流解码连续出现多个中间节点时,可将图3所示流程中计算下一分支地址索引值的过程直观地归纳为:index∶=index+Array[index].rv+new_2digit.以防止索引值多次叠加时出错,以输入Huffman码流“010100101”解码为例,其解码结果为“S3S7”,在码字“S7”所对应的码元解码时就连续出现对3个中间节点操作的情况.

图3 基于四叉树结构的Huffman解码流程Fig.3 Huffman decode flow base on quad-tree

2 实验结果及算法性能分析

根据以上四叉树Huffman解码优化算法原理,以软件编程方式实现其解码过程,并将其应用到嵌入式MP3解码中,以测试该算法解码性能.为便于各算法性能的比较,分别以W1,W2,W3表示Lee算法(改进二值法)、Hashemian等算法(以一次性操作3位即八叉树来代替)和本文提出的基于四叉树的Huffman解码算法.以5个不同码率的MP3文件作为测试文件,测试表明算法W1,W2,W3消耗的内存分别为0.62,1.23,0.75 KB,而所需解码时间以及解码指令数情况如表3所示.

由测试结果可知:若以W1算法的Huffman解码算法为基准,W3算法内存损耗增加少,约为W1算法的21%,而W2算法所耗内存增量大,约为W1算法的98%,换而言之,W2算法带来了很大的内存冗余.根据表3数据可知:当对不同码率的文件进行测试时,所需的Huffman解码时间及指令数都各有不同.就解码时间而言,相比于W1算法,W3算法节省了约为47.5%,而W2算法节省的略多于W3算法,即约为W1算法的62.6%,也即W2算法的解码速度略快于W3算法;就解码所需指令数而言,相比于W1算法,W3算法总指令数约为W1算法的57%,而W2算法约为W1算法的44%,即W3算法的指令数略多于W2算法.

表3 3种Huffman解码算法解码时间及算法指令数Tab.3 Three different Huffman decode algorithm decoding time and instruction number

3 结论

Lee的改进二值法虽内存损耗小,但解码所耗时间长,算法复杂度高,因而算法的解码实时性较差,不适合应用于嵌入式设备多媒体应用程序开发当中.Hashemian等算法的Huffman解码效率较好,实时性较高,但其内存损耗大,因而对于内存有限的嵌入式开发并不合适.所提出的基于四叉树的Huffman解码算法综合了以上两类算法的优点.相比于Lee的改进二值法,在内存损耗增加不明显的情况下,显著提高了Huffman的解码性能;相比于Hashemian等算法,其解码性能虽有所降低,但却能明显改善系统的内存冗余,提高内存的利用率,符合嵌入式开发的实时性与内存低损耗性要求.因此,可更灵活地移植到嵌入式环境下多种多媒体数据解码中,具有一定的普适性.

[1] 倪昕,王维东,刘鹏,等.媒体处理器视频哈夫曼解码快速算法[J].浙江大学学报:工学版,2007,41(12):2036-2039.

[2] 董培良,俞日龙,廖天康,等.一种快速霍夫曼解码算法及其软硬件实现[J].复旦学报:自然科学版,2002,41(2):165-169.

[3] HASHEMIAN R.Memory efficient and high speed search Huffman coding[J].IEEE Trans on Communications,1995,43(10):2576-2581.

[4] HASHEMIAN R.Condensed table of Huffman coding,a new approach to efficient decoding[J].IEEE Transactions on Communications,2004,52(1):6-8.

[5] AGGARWAL M,NARAYAN A.Efficient huffman decoding[C]∥International Conference on Image Processing.Vancouver:[s.n.],2000:936-939.

[6] LEE J S,JEONG J H,CHANG T G.An efficient method of Huffman decoding for MPEG-2 AAC and its performance analysis[J].IEEE Trans on Speech and Audio Processing,2005,13(6):1206-1209.

[7] WANG Sung-wen,WU Ja-ling,CHUANG Shang-chih.Memory efficient hierarchical lookup tables for mass arbitrary-side growing huffman trees decoding[J].IEEE Trans on Circuits and Systems for Video Technology,2008,18(10):1335-1346.

[8] PHAM H A,BUI V H,DINH-DUC A V.An adaptive huffman decoding algorithm for MP3 decoder[C]∥Fifth IEEE International Symposium on Electronic Design,Test &Applications.Washington D C:IEEE Computer Society,2010:153-157.

[9] ISO/IEC.ISO/IEC 11172-3-1994 Information technology:Coding of moving pictures and associated audio for digital storage media at up to about 1.5 Mbit/s:Part 3:Audio[S].Geneva:ISO/IEC,1994.

[10] 朱坤旺,傅文渊,凌朝东.低功耗H.264 Baseline解码IP核设计[J].华侨大学学报:自然科学版,2011,32(3):280-283.

Embedded Platform Huffman Optimization Decoding Algorithm Base on Quad-Tree

LU Yun-fei1,HE Ming-hua2
(1.College of Electric Engineering and Automation,Fuzhou University,Fuzhou 350108,China;2.College of Physics and Telecommunication Engineering,Fuzhou University,Fuzhou 350108,China)

Considering the limitation of embedded system resources,a Huffman decoding optimization algorithm based on the quad tree is proposed in this paper.In this process,the Huffman code table is expressed as quad tree structure at first,and according to which a one-dimensional array is reconstructed,then make full use of numerical calculation instead of judgment and jump operation.In order to test the decoding performance,the method is applied to the embedded realtime MP3 decoding.The results show that the algorithm memory loss is small,decoding speed is rapid and its complexity is low,compared to other optimization algorithms,this algorithm is more suitable for application in embedded devices.

embedded;quad-tree;Huffman decoding;decoding optimization;MP3 audio

TP 391

A

(责任编辑:黄晓楠 英文审校:吴逢铁)

1000-5013(2012)05-0499-04

2012-01-22

何明华(1971-),男,教授,博士生导师,主要从事嵌入式系统与系统级芯片设计的研究.E-mail:mhhe@fzu.edu.cn.

福建省科技重大专项(2009HZ0007 1)

猜你喜欢

四叉树码流二值
数字电视TS码流协议简要分析
基于二值形态学算子的轨道图像分割新算法
面向网络边缘应用的新一代神经网络
基于稀疏表示的二值图像超分辨率重建算法
基于WebGL的三维点云可视化研究
基于四叉树的高效梯度域图像融合
基于四叉树的高效梯度域图像融合
基于曲率局部二值模式的深度图像手势特征提取
一种比较ASN.1码流差异的方法
基于内容的图像检索(CBIR)中图像颜色特征提取方法的研究和改进