打印本文 关闭窗口 | ||||
基于Hi3510的H.264编解码器的设计与实现来源于瑞达科技网 | ||||
作者:佚名 文章来源:不详 点击数 更新时间:2011/12/29 文章录入:瑞达 责任编辑:瑞达科技 | ||||
|
||||
随着全球音视频(AV)领域持续快速从模拟向数字转换,支持数字音频和视频处理的数字电视机、DVD播放机、数字静止图像摄像机(DSC)、数字视频刻录机(DVC)等新型消费电子设备的数量也持续快速攀升。庞大的信息流带来了人类文化的丰富,也带来了存储信息的烦恼。尤其是视频信息的庞大数据,催生了视频压缩技术的需求。视频压缩技术已成为多媒体时代最热门的技术之一,并广泛地应用在电视、电影、可视电话、视频会议、远程监控等图像传输和存储的领域。 1 H.264简介 H.264是ITU-T和ISO/IEC联合制定的最新编码标准,它最先由ITU-T于1997年提出,目标是提出一种更高性能(相对于当时的H.263)的视频编码标准。相对于其它标准,H.264具有以下特点: (1) 码率低。和MPEG-2等压缩技术相比,在同等图像质量下,采用H.264技术压缩后的数据量只有MPEG-2的1/2~1/3。显然,H.264压缩技术的采用将大大节省存储容量、信道带宽及用户的下载时间和数据流量收费。 (2) 图像质量高。H.264能提供连续、流畅的高质量图像。 (3) 应用范围广。H.264的不同Profile既可以应用于有严格时延限制的实时通信中,也可以应用于对时延要求不高的其他应用中(如视频存储、流媒体等等)。 (4) 鲁棒性。H.264在设计时,针对分组交换网如Internet中的分组丢失和无线网络中比特误码都提出了相应的工具,使得H.264在这些网络中传播时具有更强的抗误码性能。 (5) 对各种网络的友好性。H.264中增加了NAL层,负责将编码器的输出码流适配到各种类型的网络中,从而提供了友好的网络接口。 H.264之所以能够达到以上性能,是因为采用了以下一些先进的技术: 首先是帧内预测编码,充分利用图像空域相关性,来降低码率。根据像条编码类型,每个宏块可以选择几种编码类型之一。共有13种预测模式(4×4块大小9种预测模式,16×16块大小4种预测模式),这在以往标准中是没有的。 其次是采用新的快速运动估值算法UMHexagonS(中国专利),它是一种运算量相对于H.264中原有的快速全搜索算法可节约90%以上的新算法,全名叫“非对称十字型多层次六边形格点搜索算法”(unsymmetrical-cross muti-hexagon search),这是一种整像素运动估值算法。由于它在高码率大运动图像序列编码时,在保持较好失真率性能的条件下,运算量十分低,已被H.264标准正式采纳。H.264有7种块匹配模式,编码时对其逐一计算,选择最优。例如较为精细的部分采用4×4块大小,不运动的背景可以采用16×16块大小等等。以往标准只有固定的一种或者两种块大小模式。H.264采用多帧参考,最大限度地利用实域相关性。参考帧可以从1帧到15帧,以往标准都是单帧参考。还有采用1/4或1/8精度的亚象素运动估计,以往标准至多采用1/2精度亚象素搜索,而且不是必选选项。为了消除视频编码中常出现的块效应,H.264使用了去块效应滤波器。 H.264还采用了整数DCT变换,以提高变换速度,采用CAVLC,CABAC等新的熵编码方法以提高编码效果。 H264标准使运动图像压缩技术上升到了一个更高的阶段,在较低带宽上提供高质量的图像传输是H.264的应用亮点。H.264因具有较低的传输比特率且对存储的要求较低,基本系统无需使用版权,具有开放的性质,目前有望取代MPEG-2。 2 Hi3510工作原理 Hi3510是海思公司推出的一款基于H.264 BP算法的视频压缩芯片,该芯片采用 ARM+DSP+硬件加速引擎的多核高集成度的SoC构架,具备强大的视频处理功能。可实现DVD画质的实时编码,能白适应各种网络环境,确保画面的清晰度和实时性,低码率的H.264编码技术极大减少了网络存储空间,并通过集成DES/3DES加解密硬件引擎确保网络安全。 Hi3510采用0.13μm工艺、LFBGA400封装,大小为19×19mm,引脚间距为0.8mm,片内集成了包括数字视频接口、USB、ETH、I2S、I2C、GPIO、SPI、UART、SDRAM、DDR等接口,满足各种应用场景设备开发的同时能大大降低设备的BOM成本。 Hi3510的工作原理:视频输入单元通过ITU-RBT.601/656接口接收由VADC输出的数字视频信息,并通过AHB总线把接收到的原始图像写入到外存(SDR SDRAM或DDR SDRAM)中;视频编解码器器从外存中读取图像,进行运动估计(帧间预测)、帧内预测、DCT变换、 量化、熵编码(CAVLC+Exp-Golomb)、IDCT变换、反量化、运动补偿等操作,最后将符合H.264协议的裸码流和编码重构帧(作为下一帧的参考帧)写入到外存中;视频输出单元从外存中读取图像数据并通过ITU-R BT.601/656接口送给VDAC进行显示,应用的需求不同,视频输出单元从外存中读取的图像内容也不同,当需要对输入图像进行预览时,视频输出单元从外存中读取原始图像,当需要观察视频编码器的编码效果时,视频输出单元从外存中读取编码重构帧;ARM对视频编码器输出的码流进行协议栈的封装,然后送给网口发送,以实现视频点播业务。 Hi3510的H.264音视频编解码SoC逻辑框图如图1所示,该芯片由ARM+DSP+视频编解码加速器+图形引擎缩放器的核心构成,集成了丰富的外围接口,并内部集成包括如数字水印、DES/3DES算法,使得单芯片能适应几乎所有的工作,降低与其它芯片配合的开发难度,也免除厂商对算法等标准部分的内容进行重复开发,大大降低了设备厂商的投入门槛。配合海思不同应用形态的开发包,可以开发出PMP、可视电话、网络监控、PVR、可视对讲等各种产品。
|