用于视频编码的替代变换的方法及装置与流程

文档序号:20040084发布日期:2020-02-28 11:48阅读:102来源:国知局
用于视频编码的替代变换的方法及装置与流程
【相关申请的交叉引用】本发明主张申请于2014年11月28日,序列号为62/085,358的美国临时专利申请的优先权。将此美国临时专利申请以参考的方式并入本文中。【
技术领域
】本发明关于视频编码。特别地,本发明涉及将替代变换(alternativetransform)用于视频编码中的帧间预测编码块。
背景技术
:高效视频编码(high-efficiencyvideocoding,hevc)是由视频编码的联合协作小组(jointcollaborativeteamonvideocoding,jct-vc)开发的一种新的国际视频编码标准。hevc是以基于混合块的运动补偿的离散余弦变换(discretecosinetransform,dct)类变换编码架构为基础。用于压缩的基础单元被称为编码单元(codingunit,cu),其为2nx2n的方块。cu可以从最大cu(largestcu,lcu)开始,其在hevc中也被称为编码树单元(codedtreeunit,ctu),且每个cu可以被递归地分割为四个更小的cu,直到达到预定义的最小尺寸。当cu分层树的分割被执行,根据预测类型以及预测单元(predictionunit,pu)分区,每个cu被进一步分割为一个或多个pu单元。每个cu或每个cu的的残差被分割为变换单元(transformunit,tu)树以应用2d变换(例如:dct或离散正弦变换(discretesinetransform,dst))。类似于许多其它先前的标准,hevc采用离散余弦变换类型ii(dct-ii)作为其核心变换,因为其具有强大的“能量压缩”特性。大多数信号信息倾向于集中在dct-ii的几个低频率分量中,其近似于karhunen-loève变换(karhunen-loèvetransform,klt)。如本领域中所公知的,klt是对去相关信号(de-correlatesignal)的最佳变换,其可以通过马尔科夫过程(markovprocess)来建模。信号f[n]的n点dct-ii可以于式子(1)中定义。对于帧内预测残差,发现具有比dct-ii更有效的其它变换。于jctvc-b024(yeo,etal.,“mode-dependentfastseparablekltforblock-basedintracoding”,jointcollaborativeteamonvideocoding(jct-vc)ofitu-tsg16wp3andiso/iecjtc1/sc29/wg11,2ndmeeting:geneva,ch,21-28july,2010,document:jctvc-b024)、jctvc-c108(saxena,etal.,“jointlyoptimalintrapredictionandadaptiveprimarytransform”,jointcollaborativeteamonvideocoding(jct-vc)ofitu-tsg16wp3andiso/iecjtc1/sc29/wg11,3rdmeeting:guangzhou,cn,7-15october,2010,document:jctvc-c108)以及jctvc-e125(saxena,etal.,“ce7:mode-dependentdct/dstwithout4*4fullmatrixmultiplicationforintraprediction”,jointcollaborativeteamonvideocoding(jct-vc)ofitu-tsg16wp3andiso/iecjtc1/sc29/wg11,5thmeeting:geneva,ch,16-23march,2011,document:jctvc-e125)中,dst被引入以作为用于斜率帧内模式(obliqueintramode)的dct的替代。对于帧间预测残差,dct-ii是当前hevc中使用的唯一变换。然而,dct-ii并不是所有情况下的最佳变换。于jctvc-g281(an,etal.,“non-ce7:boundary-dependenttransformforinter-predictedresidue”,jointcollaborativeteamonvideocoding(jct-vc)ofitu-tsg16wp3andiso/iecjtc1/sc29/wg11,document:jctvc-g281)中,在一些情况下,dst类型vii(discretesinetransformtypevii,dst-vii)以及dct类型iv(discretecosinetransformtypeiv,dct-iv)被提出来以取代dct-ii。当对pu使用帧间预测时,pu边界附近的预测误差(即,预测残差或残差)通常比pu中间的预测误差更大。图1所示为用于4x4的pu的平方残差值(squaredresiduevalue)的示例。如图1所示,pu边界的残差(即,预测误差)倾向于具有较大的平方值。如图2所示,当pu被分割为多个tu时,pu边界附近的预测误差大于内部(interior)tu(非pu)边界附近的预测误差。于图2中,pu210被分割为四个tu(即,tu0、tu1、tu2、以及tu3)。块220对应于左上方tu(即,tu0)的平方残差值,其中,pu边界(由粗实线表示)附近的残差通常大于内部tu边界(由虚线表示)附近的残差。对于tu0,可以观察到平方残差值峰值(peak)大致位于左上角附近并沿着右下角减小的趋势。类似地,对于其它tu,平方残差值峰值也大致位于相应pu角附近并沿着pu的中心减小。这种效果的原因可能是因为两个相邻pu之间的不同运动向量(motionvector,mv)。为了解决这种不均匀的误差分布,可使用替代变换(例如:dst-vii以及dct-iv)。式子(2)以及式子(3)分别示出了信号f[n]的n点dst-vii以及dct-iv。基于以上观察,在jctvc-g281中公开了一种方法,如果在水平或垂直方向上的两个tu边界中的一个且仅有一个是pu边界,则使用dst-vii或dct-iv来替代dct-ii。表1示出了通过使用dst-vii从边界类型到变换类型的映射。表2示出了通过使用dct-iv从边界类型到变换类型的映射。表1表2表1中的f(dst-vii)表示dst矩阵从左到右翻转。使用f(dst-vii)的情况也可以通过先翻转输入数据再使用dst-vii来实现。f(dct-iv)的情况也是如此。于表1以及表2中,术语“非pu”以及“pu”分别表示非pu边界以及pu边界。于表1以及表2中,当水平或垂直方向的tu边界都是pu边界或非pu边界时,使用dct-ii。根据表1,图2中的四个tu将使用如表3所示的变换。表3tu水平变换垂直变换tu0f(dst-vii)f(dst-vii)tu1dst-viif(dst-vii)tu2f(dst-vii)dst-viitu3dst-viidst-vii虽然在jctvc-g281中公开的边界依从变换(boundarydependenttransform,bdt)方法可以提高编码系统的整体性能。然而,由于单个tu或pu的特性,根据jctvc-g281的bdt方法对于给定块并不是总能达到最佳性能。希望开发出一种能进一步提高性能的方法。技术实现要素:本发明公开了一种根据控制旗标于视频编码系统中进行替代变换的方法及装置。根据本发明的实施例,确定用于当前pu的控制旗标。如果控制旗标具有第一值,则在编码器侧对每个当前tu应用第一变换,或如果当前tu具有第一边界类型,则于解码器侧将第一变换的逆变换应用到每个当前tu。此外,如果当前tu具有第二边界类型,则于编码器侧将第二变换应用到每个当前tu,或于解码器侧将第二变换的逆变换应用到每个当前tu。第一变换不同于第二变换。另一方面,如果控制旗标具有第二值,无论当前tu为何边界类型,于编码器侧对每个当前tu应用选择的变换(selectedtransform),或于解码器侧对每个当前tu应用所述选择的变换的逆变换。在一个实施例中,控制旗标可被标识于tu、pu、或cu等级。在另一实施例中,可以仅对于具有第一尺寸的当前pu、tu、或cu显式地标识控制旗标。在另一实施例中,控制旗标是根据序列、图片、或条带标头等级中的其它旗标来被显式地标识。在一个实施例中,基于当前pu的边界类型隐式地确定控制旗标,且根据被显式地标识的另一旗标确定第一变换、第二变换、选择的变换、或其组合。在一个实施例中,第二变换对应于第一变换的翻转版本(flippedversion)。第一变换可对应于离散正弦变换类型v-ii(discretesinetransformtypev-ii,dst-vii)或离散余弦变换类型iv(discretecosinetransformtypeiv,dct-iv)。第一边界类型可包含左pu边界(leftpuboundary)加上右非pu边界(rightnon-puboundary)以及顶非pu边界(topnon-puboundary)加上底pu边界(bottompuboundary),且第二边界类型包含左非pu边界加上右pu边界以及顶pu边界加上底非pu边界。此外,第一边界类型还可包括左pu边界加上右pu边界、左非pu边界加上右非pu边界、顶pu边界加上底pu边界、以及顶非pu边界加上底非pu边界。第一变换、第二变换、选择的变换、或其组合可以取决于当前pu的块尺寸。例如,如果当前pu的块尺寸为4x4,则第一变换可对应于dst-vii,且如果当前pu的块尺寸为8x8或16x16,则第一变换可对应于dct-iv。选择的变换可对应于离散余弦变换类型ii(discretecosinetransformtypeii,dct-ii)。在另一方面,本发明公开了一种根据控制旗标于视频编码系统中进行替代变换的方法及装置。根据本发明的实施例,确定用于当前pu的控制旗标。如果控制旗标具有第一值,如果当前tu属于第一类型,则于编码器侧将第一变换应用到每个当前tu或于解码器侧将第一变换的逆变换应用到每个当前tu。此外,如果当前tu属于第二类型,则于编码器侧将第二变换应用到每个当前tu或于解码器侧将第二变换的逆变换应用到每个当前tu。第一变换不同于第二变换。另一方面,如果控制旗标具有第二值,无论当前tu为何边界类型,于编码器侧将选择的变换应用到每个当前tu或于解码器侧将所述选择的变换的逆变换应用到每个当前tu。在一个实施例中,当前tu是否属于第一类型或第二类型是根据边界类型、块尺寸、模式信息、或其组合来确定。【附图说明】图1所示为用于4x4pu的平方残差值的示例。图2所示为pu边界附近的预测误差大于内部tu(非pu)边界附近的预测误差的示例,其中,pu被分区为四个tu。图3所示为根据本发明实施例的基于控制旗标的结合块特性相关变换(blockcharacteristics-dependenttransform)的编码系统的示范性流程图。【具体实施方式】下文的描述是实施本发明的最佳预期模式。这种描述是为了说明本发明的一般原理,而不应被理解成对本发明的限制。本发明的范围可通过参考所附权利要求做最好的确定。如前所述,观察到pu边界附近的帧间预测误差大于pu中间的帧间预测误差。因此,一种边界依从变换(boundarydependenttransform,bdt)方法被公开于jctvc-g281中,以于单个pu中适应这种不均匀误差分布。bdt方法根据表1以及表2中总结的边界类型(即,非pu边界或pu边界)来选择变换。然而,对于给定边界类型,bdt方法总是将固定类型的变换(fixed-typetransform)应用到块(例如:dst-vii或dct-ii)。然而,块与块的预测残差的特性可能会非常不同。bdt方法可能不会总是达到最佳性能。因此,为了进一步提高bdt的性能,本发明公开了一种使用控制旗标来控制bdt操作的方法。具有显式的控制旗标,编码器可以使用模式决定方法(例如:速率失真最佳化(ratedistortionoptimization,rdo))来决定是否开启或关闭bdt。接着编码器标识此控制旗标以通知解码器。例如,控制旗标可被标识于tu、pu、或cu等级。在一个示例中,仅在当前pu、tu、或cu具有特定尺寸时,控制旗标被标识。然而,控制旗标还可被隐式地确定。例如,控制旗标的值可以取决于块尺寸,以使边界依从变换对于一些块尺寸开启且对于其它块尺寸关闭。可选地,控制旗标的值可以取决于模式信息,以使边界依从变换对于一些预测模式开启,且对于其它预测模式关闭。此外,控制旗标可根据序列、图片、或条带标头等级中的其它旗标被显式地标识。例如,其它旗标可对应于序列等级中的present_flag。如果present_flag为1,则控制旗标存在。如果present_flag为0,则控制旗标不存在且其值被推断为0。当控制旗标被隐式地确定时,另一显式的旗标可被标识以选择用于与pu相关联的tu的变换。显式的控制旗标可被使用如下。如果控制旗标等于0,则hevc中的原始dct将被用于tu。如果控制旗标等于1,则bdt将被用于tu。于另一示例中,显式的控制旗标可被使用如下。如果控制旗标等于0,则hevc中的原始dct将被用于tu。如果控制旗标等于等于1,则bdt将被用于tu。然而,此bdt是从jctvc-g281中修改得到的,以使修改后的bdt仅遵循关于是否使用变换(transform,t)的翻转或非翻转版本的决定。对于每个边界类型,修改后的bdt可使用不同于原始bdt的变换。表4所示为用于每个边界类型的变换选择的示例。变换选择可以基于当前变换单元(或当前预测单元)的块尺寸。例如,dst-vii被用于4点,且dct-iv被用于8点以及16点。于表4中,flip-t表示使用t的翻转变换矩阵的变换。于另一示例中,变换选择可以基于当前预测单元的模式信息。表4于以上示例中,特定变换(例如:dst-vii以及dct-iv)被用作为实施本发明的示范性变换。然而,本发明不限于所使用的特定变换。无论使用何种变换,控制旗标可被用于控制边界依从变换的使用。在另一实施例中,控制旗标可根据当前块的边界类型、块尺寸、或运动信息被隐式地确定,且变换选择是根据被显式标识的另一旗标被进一步确定。例如,通过从第一变换类型或基于块边界类型、块尺寸、或模式信息显式标识的类型(explicitlysignalingtype)中选择,来隐式地确定用于当前块的当前变换类型。如果显式标识的类型被选择,则当前变换类型进一步由显式标识的旗标来确定。图3所示为根据本发明实施例的基于控制旗标的结合块特性相关变换的编码系统的示范性流程图。于步骤310中,系统接收与在帧间或帧内预测模式编码的当前pu相关联的输入数据,其中,当前pu被分割为一个或多个tu。输入数据可对应于编码器侧的待编码的当前pu的残差或解码器侧的当前pu的已编码残差。当前pu可以从存储器(例如:计算机存储器或缓冲器(ram或dram))中获取。视频比特流还可从处理器(例如:处理单元或数字信号处理器)中接收。于步骤320中,确定用于当前pu的控制旗标。于步骤330中,测试控制旗标是否具有第一值(例如,开)。如果结果为“是”,则执行步骤340以及350。如果结果为“否”,则执行步骤360。于步骤340中,如果当前tu具有第一类型(即,其块特性属于第一类型),则于编码器侧将第一变换应用到每个当前tu或于解码器侧将第一变换的逆变换应用到每个当前tu。于步骤350中,如果当前tu具有第二类型(即,其块特性属于第二类型),则于编码器侧将第二变换应用到每个当前tu或于解码器侧将第二变换的逆变换应用到每个当前tu,其中,第一变换不同于第二变换。在一个实施例中,当前tu是否属于第一类型或第二类型是与当前tu的边界类型相关联的。在另一实施例中,当前tu是否属于第一类型或第二类型是根据边界类型(例如,pu边界或非pu边界)、块尺寸(例如,是否大于预定尺寸)、模式信息(例如,具体预测模式相关的信息)、或其组合来确定。于步骤360中,无论当前tu为何类型,于编码器侧将选择的变换应用到每个当前tu或于解码器侧将所述选择的变换的逆变换应用到每个当前tu。根据本发明的实施例,以上所示的流程图旨在说明帧内预测滤波的示例。本领域技术人员可以在不脱离本发明的精神实质的情况下修改每个步骤,重新排列所述步骤,分割步骤,或合并步骤来实施本发明。以上描述可使本领域的普通技术人员如特定应用及其要求的上下文提供的来实践本发明。对本领域技术人员来说,对所描述的实施例的各种修改是显而易见的,且本文定义的一般原理可被应用于其它实施例。因此,本发明并非意在限定于以上所示及所描述的特定实施例,而是要符合与此公开揭露的原理和新颖特征相一致的最宽范围。在以上详细描述中,各种具体细节被示出以便提供本发明的彻底理解。然而,本领域技术人员应知晓本发明是可被实践的。如上所述,本发明的实施例可以由各种硬件,软件代码,或两者的组合来实现。例如,本发明的实施例可以是被集成到视频压缩芯片的一个或多个电子电路,或被集成于视频压缩软件的程序代码以执行本文所描述的处理过程。本发明的实施例还可以是执行于数字信号处理器上的程序代码,以执行本文所描述的处理过程。本发明还可包含由计算机处理器,数字信号处理器,微处理器,或现场可编程门阵列执行的多个功能。根据本发明,通过执行定义本发明所体现的特定方法的机器可读软件代码或固件代码,这些处理器可被配置为执行特定任务。软件代码或固件代码可被开发为不同的编程语言以及不同的格式或风格。软件代码还可被编译以用于不同的目标平台。然而,根据本发明的不同的软件代码的代码格式、风格及语言,以及用于配置代码以执行任务的其他方式,均不会背离本发明的精神以及范围。在不脱离其精神或本质特征的情况下,本发明可以其它特定形式来体现。所描述的示例在所考虑的所有的方面都只是说明性的而不是限制性的。因此,本发明的范围是由其所附的权利要求来指示的,而不是由上文的描述来指示的。在权利要求的等效范围及含义内的所有改变均包含于本发明范围之内。当前第1页1 2 3 
当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1