




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
采用FPGA技术高速实现无链表SPIHT图像压缩算法的设计1、引言基于变换的图像压缩方法当前应用最为广泛。小波变换以其优秀的能量集中能力而被JPEG2000标准所采用。而当前诸如countourlet、directionlets等具有多方向性的变换由于具有非常高的非线性逼近能力很可能使图像压缩性能得到较大提高。然而非线性逼近能力强并不能直接使图像压缩性能得以提高,因为重要系数的位置还需要进行有效的熵编码。SPIHT和EBCOT是熵编码器中最具代表性的编码方案。它们都具有编码效率高,生成的码流具有嵌入式的特点。EBCOT是JPEG200中的核心编码器。它采用的是块编码技术,根据信源的特性对信源进行分类,然后进行MQ算术编码,利用压缩后率失真优化(PCRD)策略产生嵌入式码流。SPIHT则是基于子带之间的自相似的特点通过零树结构进行重要性信息的编码。算法对集合进行重要性测试并按照一定的规则分裂.如果集合中所有元素的幅值小于某阈值(即该集合是不重要的),则使用一个比特即可表示,这样就大大简化了集合的表示.由于变换系数在空间定位树结构中的相似性,使这种算法具有极高的效率,即使不使用算术编码也能达到较高的压缩效率。SPIHT与EBCOT相比,虽然没有EBCOT码流极其灵活的特点,但由于算法复杂度相对较低并且可以省去自适应算术编码过程,适用于对编码实时性要求较高的场合.因此研究SPIHT算法的FPGA实现具有重要意义。但是,原始的SPIHT算法是通过3个有序的链表存储重要性信息实现对图像的编码.链表操作包括动态分配链表、添加和删除结点等,这非常不适于FPGA的有效实现。F.W.Wheeler和W.A.Pearlman随后提出了无链表SPIHT,并称之为NLS。NLS则可以用FPGA加以实现。本文在深入研究无链表SPIHT图像压缩算法的基础上,设计了该算法的FPGA实现结构。2、无链表SPIHT图像压缩算法为了使SPIHT算法适应硬件的实现,无链表SPIHT算法对原算法进行了一些改进。在改进算法中采用了宽度优先的搜索策略。这是由于相对应深度优先的搜索策略,宽度优先的搜索策略会使重要系数更可能先被扫描到,从而能够提高压缩性能。在无链表SPIHT算法中,采用特定的标志符来代替原SPIHT算法中的链表。当新的不重要集合生成时,这些稀疏的标志符就会被相应更新。通过稀疏的标志符标识,图像中的大部分不重要块被跳过,从而使编码时间大大减少。为了能够高效实现图像中不重要块被跳过,无链表SPIHT算法采用一维线性索引的寻址方式代替二维的寻址方式。对于无链表SPIHT算法,集合结构、分割规则和SPIHT相同。每个位平面有三个过程,不重要系数过程、重要集合过程、精细化过程。在编码过程中为了避免重复扫描系数,使用最大值表存储器来解决这个问题。在开始编码前,首先要计算出两个后代集合的最大值表。这两个最大值表分别存储后代集合最大值(记为DMax)和除了儿子外的后代集合最大值(记为GMax)。这两个最大值表可由下面两个公式求出。在求的过程中,按照从后向前的顺序扫描系数。其中在求DMax时,当GMax超出图像边界后应把它算作零。最大值函数max实际上可以用按位或运算来代替,这也非常利于硬件实现。当完成最大值表求取完成后,接着对标志符存储器进行初始化。最后就可以进行正式编码了。编码的算法主流程请参考[3]。3、FPGA算法实现结构根据无链表SPIHT算法,设计了具体的FPGA实现结构。图2所示为系统的总体框图。整个系统以NLSEncoder为中心实现对小波系数的扫描编码。Coefficients存储了经过小波变换后的系数,而且按照线性索引的顺序已排列好。DMax用于存储所有结点的后代最大系数。GMax用于存储所有结点的除了儿子外的所有后代的最大系数。Marker存储了各个系数的当前状态标志,且在编码过程中相应的更新。图2无链表SPIHT算法FPGA实现总体框图算法实现中,使用一个有限状态机实现对编码过程的有效控制。图3所示为NLS编码器状态机的状态转换图。系统复位后进入Idle状态,当start信号有效后开始对图像系数进行编码处理进入Initial状态。在Initial状态里对标志符存储器进行初始化设置,设置完成后进入GetMax状态。在GetMax状态里对图像系数进行扫描,求出DMax和GMax并把他们存储到对应的存储器里,全部求完后进入SortingPixel状态。在SortingPixel状态里,完成对不重要系数的扫描编码并把编码结果输出,扫描完成后进入SortingSet状态。在SortingSet状态里,对不重要集合进行扫描测试,按照算法的规则输出相应的编码,完成相应扫描后,进入Refinement状态。在Refinement状态里对重要系数进行精细化过程,完成相应扫描后进入NextBitPlane状态。在NextBitPlane里把位平面测试变量切换到下一个位平面,并回到SortingPixel状态。其中在SortingPixel、SortingSet和Refinement状态里,都要判断输出的压缩码流是否达到了目标码率,如果达到则都直接返回到Idle状态,完成这幅图像的压缩编码,等待下一幅图像压缩的开始。图3NLS编码器状态机状态转换图4、实验结果为了验证该算法FPGA实现的正确性和高效性,采用了Altera公司的FPGA开发板。板上FPGA为StratixII系列,具体型号为EP2S60F672C5。首先,使用MATLAB对图像进行小波变换,然后把经过小波变换的系数以存储器初始化文件(*.mif格式)存储到Coefficients存储器中[4]。系统工作后,通过按键产生start信号启动一次压缩过程。为了观察压缩结果,把压缩后的码流仍然存储到片内存储器中,且把该存储器中的“AllowIn-SystemMemoryContentEditortocaptureandupdatecontentindependentlyofthesystemclock”选项设置为有效。那么当压缩完成后,就可以通过JTAG下载电缆,把该存储器的数据通过QuartusII软件的In-SystemMemoryContentEditor功能读回到计算机,并同样可以存储为*.mif格式文件。这样利用MATLAB读取该*.mif格式文件,进行解码操作,并进行小波逆变换,即可恢复解压缩的图像。使用FPGA实现该算法时,完全使用FPGA片内存储器。对于256x256大小的图像,表1列出了FPGA片内存储器的使用情况,总计需要200K字节的存储器即可。如果把图像的压缩比设为8:1,则压缩码流存储器需要的存储容量为8K字节。表1FPGA片内存储器使用情况5、结论SPIHT算法是公认的高性能的图像压缩算法。为了能采用FPGA进行有效的高速实现,本文深入分析了其改进算法:无链表SPIHT算法(NLS)。由于无链表SPIHT算法采用状态标示符取代动态链表操作来记录集合分割信息,进而把
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- Unit 3 Sports Lesson1:School sports day(教学设计)-2024-2025学年北师大版(三起)英语六年级上册
- 12坐井观天教学设计-2024-2025学年二年级上册语文统编版
- 粤教版 信息技术 必修 3.2 表格信息的加工与表达教学设计
- 全国电子工业版初中信息技术第一册第1单元1.3活动1《了解常用的无线网络技术》教学设计
- 国际海运合同法律适用问题
- 2025年度公共设施装修合同违约赔偿标准及执行
- 2025年真纺织品行业深度研究分析报告
- 二零二五年度社区消毒灭菌服务合作协议
- 2025年度仓储用地使用权转让协议书
- 4S店装修管理协议样本
- (正式版)JBT 10437-2024 电线电缆用可交联聚乙烯绝缘料
- 【S城投公司偿债能力存在的问题及优化建议探析8000字(论文)】
- 品质部质量目标
- 2024届广东省深圳市中考物理模拟试卷(一模)(附答案)
- 前庭功能锻炼科普知识讲座
- 信永中和线上测评题库
- 供应链战略布局与区域拓展案例
- 上海话培训课件
- 注塑车间绩效考核方案
- 初中英语阅读理解专项练习26篇(含答案)
- LS/T 1234-2023植物油储存品质判定规则
评论
0/150
提交评论