干货 | H.265编码SAO算法优化

作者&投稿:郁符 (若有异议请与网页底部的电邮联系)
~ 一 SAO 技术介绍

  SAO 的全称是 Sample adaptiveoffset,对应的中文意思是采样自适应补偿。SAO 是H.265编码规范中一项重要的压缩技术,该技术的思想源于Samsung提案JCTVC-A124。实验测试结果显示 SAO 能够带来的压缩增益远超过Deblock和ALF。

SAO 模块在编码器的结构图一中所处的位置如下( 红色的部分 ):

  图一 SAO在编码器中的位置

SAO 在解码器的结构图二中所处的位置如下( 红色的部分 ):

  图二 SAO在解码器中的位置

  从流程图中可以看出,SAO和ALF是loop内的操作,接在Deblock的后面,输入包括原始的YUV图像和Deblock的输出,生成的参数需要进行entropy编码。参考图三:

  图三 SAO 的算法概图

二 SAO 算法介绍

  图像经过压缩和解压后,精度会损失。通过psnr计算公式可以看出,重构数据和原始数据YUV之间差值的平方和决定了psnr。SAO 通过分析原始数据和重构后的数据,对deblock之后的进行offset补偿操作,使得尽量接近原始的像素值,达到提高psnr 的目的。

  均方误差:

  峰值信噪比:

  如何具体运算来提高PSNR值呢,一个直接的想法是把deblock的重构数据和原始的YUV 中每一个相同位置的pixel做差值,把这个差值传给decoder,这样可以完全恢复YUV。实际上,这样做会导致码率非常高,达不到压缩的效果。

  为了能够提高psnr,同时只会增加极少量的码率,H.265 在码率和psnr之间做了一个tradeoff。下面看一下是怎么做的。

  H.265是基于CTB来做SAO的,通过分析原始数据和deblock后的重构数据,将pixel 分成三种SAO模式:

  SaoTypeIdx[cIdx][rx][ry]

  SAO type

  Not applied

  1

  Band Offset(BO)

  2

  Edge Offset(EO)

由上表可以看出,SAO 有三种模式:不做, BandOffset, Edge Offset , 后面两种模式分别介绍如下:

EdgeOffset Mode:(边界补偿模式)

  在这种模式下,SAO 需要为CTB 选择一种梯度模式,水平/垂直/45度角/135度角。这四个类别用sao_eo_class 语法元素表示,如图四:

  图四 edgeoffset 梯度四种模式

  为当前的CTB选择好一种梯度模式后,开始计算该CTB中每一个像素和相邻两个像素的大小关系,这个大小关系分成5类:

  EdgeIdx

  Condition

  Meaning

  P = n0 and p = n1

  Flat area

  1

  P < n0 and p < n1

  Local min

  2

  P < n0 and p = n1 or P = n0 and p < n1

  Edge

  3

  P > n0 and p = n1 or P = n0 and p > n1

  Edge

  4

  P > n0 and p > n1

  Local max

  图五 EdgeIdx 四种类型

  对CTB而言,EO(Edge Offset)的梯度模式在码流里面被包含了,但是对于每一个像素而言,EdgeIdx 是通过计算得来的,编码器和解码器所使用的计算方法一样,所以得到的结果一样,码流里面不需要编码EdgeIdx信息,这样节省了码率,付出的代价是增加了CPU 的运算量。

对于EdgeIdx 为0的flat area,可以不需要做任何操作。对于其余四类,SAO为每一类分配了一个Offset 整数补偿值,这个Offset会add到被重构的每一对应类像素中。同时 H.265规定,EdgeIdx=1,2 这两类,offset 值必须为正数,EdgeIdx=3,4必须为负数,这样符号位不需要编码,节省码率。

Band Offset Mode:

  YUV 像素值的取值范围通常是 0~255,平均分成32个band,每一个band包含的横跨的范围是8.通过一定的算法来选择连续的4个band进行补偿,当CTB的YUV 像素值处于选定的4个band中时,需要对这个sample补偿。

  图六 BandOffset 补偿模式

Band Offset 的原理是: 在编码器端,对32个band分别做像素值的直方图统计,求每一个band像素值的平均值。下面是一个例子:

假设对于原始的CTB,其中有一个band,位于[28,35], 有三个 pixel ,像素值分别是: 32,35, 35 ,这样可以知道该band 的像素平均值是 (32 + 35+35)/3 = 34 ; 而对应的deblock之后的band,包含三个像素,分别是 30,32,34 ,平均值是 (30 + 32 + 34) / 3 = 32 , 可见,在该band上,原始的像素值 平均值比重构的大 34-32=2 ,因此,可以分配offset=+2给这个band, 在decoder 端为这个band 的每一个像素值加2. 这样保证在该band上出现的重构pixel和原始的平均值相等。对32个都做这种处理,最后选择连续的4个。

对于 Band OffsetMode 和 Edge Offset Mode 而言, 如果当前的CTB的SAO 参数与左边或上边CTB的SAO 参数相同,这时不需要为当前的CTB传输SAO参数,而是直接使用左边或上边CTB的SAO 参数。

三 SAO 算法的优化

1. 优化之前的常用算法:

  对于CTB 内的每一个像素而言,需要计算:

  1. 先要计算出原始像素值和重构像素值的差值,每个像素的差值用变量offset_value 表示;

  2. 需要根据重构的像素值,分别计算每个像素BO,EO0, EO1, EO2, EO3 这五种类型内的每一种子类型值,这个类型之命名为 sao_class,这样 64*64的CTB 方阵,要遍历5次,访问次数大约为:5*64*64

  3. 然后对CTB的64*64的方阵,一共4096个像素统计每一个类型的offset_value之和,以及每个类型像素个数 cnt_of_class。

2. 优化后的算法:

  该算法的特点是,把每个像素的 offset_value 向左偏移 12位,一个32位的整数,高20位放offset_value 值,低12位放像素个数. 对于每一个像素而言,低12位初始化为1. 64*64 的CTB 块,同一个SAO 的子类型,最多只有 2^12 个像素,所以用低12位保存子类型个数刚刚好不会溢出,如下图:

  12 ~ 31 bit (offset_value)

  0 ~ 11 (cnt_of_class)

  图七 复合数据格式

  这样把offset_value 和 cnt_of_class 合并到一个 32 位整型数内,可以让两个数据同时累加运行,运算量减少一半。

  假设 64*64的CTB 块,offset值定义为下面的数组:

Offset_value[64][64] = { … …} ; 其中的每个数据格式都是符合数据格式

Rec_pixel_value[64][64] = { … …} ; 重构像素值 0 ~ 255

BO_class[64][64] = { … …} ; 取值范围 0 ~ 31

EO0_class[64][64] = { … …} ; 取值范围 0 ~ 4

EO1_class[64][64] = { … …} ; 取值范围 0 ~ 4

EO2_class[64][64] = { … …} ; 取值范围 0 ~ 4

EO3_class[64][64] = { … …} ; 取值范围 0 ~ 4

  定义一个数组:

Int BO_Class[32] = {0} ;

For(int i = 0; i < 64; i++)

For(intj = 0; j < 64; j++)

{

Int Rec_pixel_value[i][j] >> 3;

BO_Class[class]+= Offset_value[i][j];

}

  上面运算完成后,可以从BO_Class中分离出每一个子类的:

For(int i = 0; i < 32; i++)

{

offset_value = BO_Class[i] >> 12;

cnt_of_ BO_Class[i] & 0xFFF;

}

  Edge Offset Mode:

  1. 把 EO0, EO1 和并到一个数组中:EO0, EO1 都包含了 5个子类 0 ~ 4, 需要3bit,为了把两个子类合并起来,需要建立一个二维数组,两个下标分别代表两个类型的子类索引。假设左边的下标代表 EO1 的子类索引,右边的下标代表 EO0 的子类索引:

EO_01[8][8]

  2. 按照上面的方法把 EO2, EO3合并到一个数组中:

EO_23[8][8]

  3. 完成下面的运算:

{

Intclass_0 = EO0_class[i][j];

Int class_1 = EO1_class[i][j];

Int offset = Offset_value[i][j];

EO_01[class_1][class_0] += offset

EO_23[class_3][class_2] += offset;

  4. 分离出 EO0, EO1, EO2, EO3:

Int EO0[5] = {0};

Int EO1[5] = {0};

Int EO2[5] = {0};

Int EO3[5] = {0};

For(int i = 0; i < 5; i++)

For(int J =0; J < 5; J++)

EO0[j] += EO_01[i][j];

EO1[i]+= EO_01[i][j];

EO2[j]+= EO_23[i][j];

  最后把每一类的 offset 和 count 分离出来。

四 总结

  优化后,SAO 中 offset 统计部分的计算量减少到原来的 25%左右。整个 SAO 模块 90%的运算时间被统计部分消耗掉,所以这个算法的优化在C 层面比较明显。在汇编层面,有一定效果,但不太明显,因为在运算的中间加了一个 8*8的数组,这个数组不利于用多媒体指令集并行方式来实现。


壤塘县15040554293: H.265里的算法是怎样的 -
濯申利胆: H.265是新的视频编码标准. H.265标准围绕着现有的视频编码标准H.264,保留原来的某些技术,同时对一些相关的技术加以改进.新技术使用先进的技术用以改善码流、编码质量、延时和算法复杂度之间的关系,达到最优化设置.具体的研究内容包括

壤塘县15040554293: H.265+是什么意思 -
濯申利胆: H265是新的视频编码标准.是在H264的基础上,保留原来的某些技术,同时对一些相关的技术加以改进.新技术使用先进的技术用以改善码流、编码质量、延时和算法复杂度之间的关系,达到最优化设置.具体的研究内容包括:提高压缩效率、提高鲁棒性和错误恢复能力、减少实时的时延、减少信道获取时间和随机接入时延、降低复杂度等. 目前,正在广泛推广和使用的音视频传输技术.

壤塘县15040554293: H.265解码是什么? -
濯申利胆: H.265硬解:利用独立显卡或者CPU核显进行H.265编码的解码方式; H.265软解:利用CPU进行H.265编码的解码方式. 由于H.265的解码对CPU要求较高,所以大部分CPU解码H.265都比较吃力,包括I7. 所以一般都倾向于显卡硬解.现在显卡对H.265 8bit和10 bit解码的支持,还不是很完善.所以在选择购买显卡时,要搞清楚是否支持H.265的解码.

壤塘县15040554293: 海康录像机h265+什么意思? -
濯申利胆: 海康录像机h265意思, 海康威视摄像头h.265编码, 是把摄像机每天的原始数据压缩比h.264压缩更好. H.265技术能给我们降低非常多的成本.

壤塘县15040554293: 监控系统改如何选择?怎么样的监控系统好 -
濯申利胆: 、方案选择: 1)当前的监控系统主流是网络高清监控,特点是清晰度高、扩展性更好,所以新安装的监控系统应该尽量采用网络监控; 2)如果是老的监控系统(模拟监控)需要升级,则采用同轴高清监控系统的性价比比较高. 3)模拟监控...

壤塘县15040554293: h265与mp4,mkv,tc分别指的是什么 -
濯申利胆: h265是指h.265,又名hevc,是抄一种视袭频编码格式.mp4和mkv都是封装格式.tc可能指timecodes,是mkv中用于记2113录每一帧按什么速度放(或每帧在什么时间点放的东5261西),一般只4102在压制vfr(可变帧率)视频时会碰到.tc也可能指traditional chinese,即1653繁体/正体中文

壤塘县15040554293: 什么是H.265?什么是H264?两者有什么区别? -
濯申利胆: H.264和H.265都是视频编码的格式.相比H.264,H.265能在有限带宽下传输更高质量的网络视频,也就是说只需原先H.264编码的一半带宽即可传输相同质量的视频.1. 视频编码,是指通过特定的压缩技术,将某个视频格式的文件转换成另一种...

壤塘县15040554293: h.265编码和h.264 编码之间都有哪些区别? 在相同的画面质量下,h.265会比h.264节约多少码流? -
濯申利胆: 区别,h.265编码在h.264基础上在宏区块上增加了四叉树结构,滤波器的精度增加一倍.动作预测多达32个角度.计算量多至少20倍. 想想2003年的电脑看h.264的性能水平,就等于2013年的电脑看h.265的水平 比h.264节约<40%的带宽,节约约一半以内.

壤塘县15040554293: 什么是H265格式,哪个安卓智能盒子支持这种格式 -
濯申利胆: 相对于H.264, H.265最大的优势是就拥有更高的压缩率.这一点从H.265命名就可以看出端倪,H.265又名HEVC(High Efficiency Video Coding,高效率视频编码),其最主要的用途就是要进一步降低影片所需的流量,以降低储存与传输的成本.目前唯一支持这个先进格式的方案是瑞芯微的RK3188四核处理器,快播盒子就是这个配置

壤塘县15040554293: h265相比h264解码方式新增了哪些特性? -
濯申利胆: 最大的特性就是,在码率相同条件下,265比264拥有更高的压缩比,但画质却更细腻.

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网