视频编码方法、解码方法、装置、计算机设备及存储介质与流程

文档序号:16008558发布日期:2018-11-20 20:22阅读:170来源:国知局

本申请涉及计算机处理技术领域,特别是涉及一种视频编码方法、解码方法、装置、计算机设备及存储介质。



背景技术:

随着数字媒体技术和计算机技术的发展,视频应用于各个领域,如移动通信、网络监控、网络电视等。随着硬件性能和屏幕分辨率的提高,用户对高清视频的需求日益强烈。

在带宽有限的条件下,传统的编码器对视频帧无区分地进行编码,可能出现某些场景视频质量差的问题,如在750kbps时,对于所有视频帧不加区分地进行编码时,存在部分视频帧质量差的情况,分析H.264\H.265\iOS等编码器都存在相似问题。



技术实现要素:

本发明实施例提出了一种可以自适应选择下采样信息,提高在带宽有限下的视频质量的视频编码方法、解码方法、装置、计算机设备及存储介质。

一种视频编码方法,所述方法包括:

获取输入视频帧;

当确定所述输入视频帧对应的目标处理方式为下采样处理方式时,确定与所述输入视频帧对应的下采样信息;

根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据;

根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据。

一种视频编码装置,所述装置包括:

视频帧获取模块,用于获取输入视频帧;

确定模块,用于当确定所述输入视频帧对应的目标处理方式为下采样处理方式时,确定与所述输入视频帧对应的下采样信息;

编码模块,用于根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据;

添加模块,用于根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据。

一种计算机设备,包括存储器和处理器,所述存储器存储有计算机程序,所述计算机程序被所述处理器执行时,使得所述处理器执行以下步骤:

获取输入视频帧;

当确定所述输入视频帧对应的目标处理方式为下采样处理方式时,确定与所述输入视频帧对应的下采样信息;

根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据;

根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据。

一种计算机可读存储介质,存储有计算机程序,所述计算机程序被处理器执行时,使得所述处理器执行以下步骤:

获取输入视频帧;

当确定所述输入视频帧对应的目标处理方式为下采样处理方式时,确定与所述输入视频帧对应的下采样信息;

根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据;

根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据。

上述视频编码方法、装置、计算机设备及存储介质,通过获取输入视频帧,当确定输入视频帧对应的目标处理方式为下采样处理方式时确定与输入视频帧对应的下采样信息,然后根据下采样信息对输入视频帧进行编码得到与输入视频帧对应的编码数据,根据下采样信息对应的处理范围将下采样信息添加至编码数据。上述编码方法通过将下采样信息添加至编码数据中,可以在编码过程中为每个输入视频帧灵活地自适应的选择更加适合的下采样信息,有利于提高在带宽有限下的视频质量。

一种视频解码方法,所述方法包括:

获取待解码视频帧对应的编码数据;

当确定所述待解码视频帧对应的目标处理方式为下采样处理方式时,从所述编码数据中获取与所述待解码视频帧对应的下采样信息;

根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧。

一种视频解码装置,所述装置包括:

编码数据获取模块,用于获取待解码视频帧对应的编码数据;

下采样信息获取模块,用于当确定所述待解码视频帧对应的目标处理方式为下采样处理方式时,从所述编码数据中获取与所述待解码视频帧对应的下采样信息;

解码模块,用于根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧。

一种计算机设备,包括存储器和处理器,所述存储器存储有计算机程序,所述计算机程序被所述处理器执行时,使得所述处理器执行以下步骤:

获取待解码视频帧对应的编码数据;

当确定所述待解码视频帧对应的目标处理方式为下采样处理方式时,从所述编码数据中获取与所述待解码视频帧对应的下采样信息;

根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧。

一种计算机可读存储介质,存储有计算机程序,所述计算机程序被处理器执行时,使得所述处理器执行以下步骤:

获取待解码视频帧对应的编码数据;

当确定所述待解码视频帧对应的目标处理方式为下采样处理方式时,从所述编码数据中获取与所述待解码视频帧对应的下采样信息;

根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧。

上述视频解码方法、装置、计算机设备及存储介质,通过获取待解码视频帧对应的编码数据,当确定待解码视频帧对应的目标处理方式为下采样处理方式时,从编码数据中获取与待解码视频帧对应的下采样信息,根据待解码视频帧对应的下采样信息对编码数据进行解码,得到对应的解码视频帧。通过从编码数据中获取与待解码视频帧对应的下采样信息,然后根据下采样信息进行解码,提供了对自适应的选择下采样信息进行编码得到的编码数据的解码支持。

附图说明

图1为本发明一个实施例中视频编码方法的应用环境图;

图2为本发明一个实施例中视频编码方法对应的编码框架图;

图3为本发明一个实施例中视频解码方法对应的解码框架图;

图4为本发明一个实施例中编码块对应的示意图;

图5为本发明一个实施例中视频编码方法的流程图;

图6为本发明一个实施例中头信息字段所在位置的示意图;

图7为本发明一个实施例中确定下采样信息的流程图;

图8为本发明一个实施例中视频编码方法的流程图;

图9为本发明一个实施例中编码数据的示意图;

图10为本发明一个实施例中对待编码帧进行编码得到编码数据的流程图;

图11为本发明一个实施例中根据当前参考帧进行编码得到编码数据的流程图;

图12A为本发明一个实施例中对当前参考帧进行插值的示意图;

图12B为本发明一个实施例中对当前参考帧进行插值的示意图;

图13为本发明一个实施例中当前参考帧与待编码帧的示意图;

图14为本发明一个实施例中对待编码帧进行编码得到编码数据的流程图;

图15为本发明一个实施例中视频编码方法的流程图;

图16为本发明一个实施例中视频编码框架的示意图;

图17为本发明一个实施例中视频解码方法的流程图;

图18为本发明一个实施例中视频解码方法的流程图;

图19为本发明一个实施例中得到重建视频帧的流程图;

图20为本发明一个实施例中视频编码装置的结构框图;

图21为本发明一个实施例中视频编码装置的结构框图;

图22为本发明一个实施例中视频解码装置的结构框图;

图23为本发明一个实施例中视频解码装置的结构框图;

图24为本发明一个实施例中计算机设备的内部结构图。

具体实施方式

为了使本申请的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本申请进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。

图1为一个实施例中视频编码方法、视频解码方法的应用环境图。如图1所示,该应用环境包括终端110和服务器120,其中终端110、服务器120通过网络进行通信。终端110具体可以是台式终端或移动终端,移动终端具体可以是手机、平板电脑、笔记本电脑等中的至少一种。服务器120可以用独立的服务器或者是多个服务器组成的服务器集群来实现。视频编码方法、视频解码方法可以在终端110或服务器120中完成。终端110或服务器120可以通过编码器进行视频编码,或者通过解码器进行视频解码。终端110或服务器120也可以通过处理器运行视频编码程序进行视频编码,或者通过处理器运行视频解码程序进行视频解码。服务器120通过输入接口接收到终端110发送的编码数据后,可直接传递至处理器进行解码,也可存储至数据库中等待后续解码。服务器120在通过处理器对原始视频帧编码得到编码数据后,可直接通过输出接口发送至终端110,也可将编码数据存储至数据库中等待后续传递。

图2为一个实施例中提供的视频编码方法对应的编码框架图,本发明实施例提供的视频编码方法可以获取输入视频序列的各个输入视频帧进行编码,得到对应的编码数据,并通过存储发送单元222存储或者发送编码数据,或者存储并发送编码数据。其中,在处理方式决策单元202处,可以对输入视频帧进行处理方式决策,得到输入视频帧对应的处理方式。在处理单元204处,可以根据处理方式对输入视频帧进行处理,得到待编码帧。在第一预测单元206处,可以在待编码帧的分辨率下,可以对待编码帧的各个编码块进行帧内预测或者帧间预测,并根据编码块对应的参考块的图像值得到预测值以及对应的运动矢量,将编码块实际值与预测值相减得到预测残差,运动矢量表示编码块相对于参考块的位移。在变换单元208处,将空间域中的预测残差以及矢量信息变换到频率域,并可以对变换系数进行编码。变换的方法可以为离散傅里叶变换或者离散余弦变换等等,矢量信息可以为表示位移的实际运动矢量或者运动矢量差值,运动矢量差值为实际运动矢量与预测运动矢量的差值。

在量化单元210处,将变换后的数据映射成另一个数值,例如可以通过变换后的数据除以量化步长得到一个较小的值。量化参数是量化步长对应的的序号,根据量化参数可以查找到对应的量化步长。量化参数小,则图像帧的大部分的细节都会被保留,对应的码率高。量化参数大,则对应的码率低,但图像失真较大、质量不高。量化的原理用公式表示如下:FQ=round(y/Qstep)。其中,y为量化之前视频帧对应的值,Qstep为量化步长,FQ为对y进行量化得到的量化值。Round(x)函数指将取值进行四舍五入取偶,即四舍六入五取偶。量化参数与量化步长的对应关系具体可以根据需要进行设置。例如,在一些视频编码标准中,对于亮度编码而言,量化步长共有52个值,为0~51之间的整数,对于色度编码,量化步长的取值为0~39之间的整数,且量化步长随着量化参数的增加而增加,每当量化参数增加6,量化步长便增加一倍。

熵编码单元220用于进行熵编码,熵编码为按熵原理进行编码,且不丢失任何信息的数据编码方式,能够利用较小的字符来表达一定的信息。熵编码方法例如可以为香农编码(shannon)或者哈夫曼编码(huffman)等。

第一反量化单元212、第一反变换单元214、第一重建单元216以及参考信息自适应单元218是重建路径对应的单元,利用重建路径的各个单元进行帧的重建得到参考帧,能够保持编码以及解码中参考帧的一致。其中第一反量化单元212进行的步骤是进行量化的逆过程,第一反变换单元214进行的步骤是是变换单元210进行变换的逆过程,第一重建单元216用于将反变换得到的残差数据加上预测数据得到重建参考帧。第一参考信息自适应单元218用于在待编码帧的分辨率下,对重建得到的当前参考帧、待编码帧的各个编码块对应的位置信息、当前参考帧的各个参考块对应的位置信息以及运动矢量中等参考信息中的至少一个进行自适应处理,使第一预测单元206根据自适应处理后的参考信息进行预测。

图3为一个实施例中提供的视频解码方法对应的解码框架图,本发明实施例提供的视频解码方法可以通过编码数据获取单元300获取待解码视频序列的各个待解码视频帧对应的编码数据,通过熵解码单元302进行熵解码后,得到熵解码数据,第二反量化单元304对熵解码数据进行反量化,得到反量化数据,第二反变换单元306对反量化数据进行反变换,得到反变换的数据,该反变换的数据可以与图2中第一反变换单元214进行反变换后得到的数据是一致的。分辨率信息获取单元308用于获取待解码视频帧对应的分辨率信息。第二参考信息自适应单元312用于获取第二重建单元重建得到当前参考帧,根据待解码视频帧的分辨率信息对当前参考帧、待解码视频帧的各个待解码块对应的位置信息、当前参考帧的各个参考块对应的位置信息以及运动矢量等参考信息中的至少一个进行自适应处理,根据自适应处理后的信息进行预测。第二预测单元314根据自适应后得到的参考信息获取待解码块对应的参考块,根据参考块的图像值得到与图2中的预测值一致的预测值。第二重建单元310根据预测值以及反变换的数据即预测残差进行重建,得到重建视频帧。第二处理单元316根据待解码视频帧对应的分辨率信息对重建视频帧进行处理,得到对应的解码视频帧。播放存储单元318可以对解码视频帧进行播放或者存储,或者进行播放以及存储。

可以理解,上述的编码框架图、解码框架图仅是一种示例,并不构成对本申请方案所应用于的编码方法的限定,具体的编码框架图以及解码框架图可以包括比图中所示更多或更少的单元,或者组合某些单元,或者具有不同的部件单元不知。例如,还可以对重建视频帧进行环路滤波,降低视频帧的方块效应,以提高视频质量。

可以将待编码帧划分为多个编码块,编码块的大小可以根据需要进行设置或者计算得到。例如编码块的大小可以均为8*8像素。或者可以通过计算各种编码块的划分方式对应的率失真代价,选择率失真代价小的划分方式进行编码块的划分。如图4所示为一个64*64像素图像块的划分示意图,一个方块代表一个编码块。由图4可知,编码块的大小可以包括32*32像素、16*16像素、8*8像素以及4*4像素。当然,编码块的大小也可是其他大小,例如可以是32*16像素或者是64*64像素。可以理解,在解码时,由于编码块与待解码块是一一对应的,因此待解码块的像素大小也可以包括32*32像素、16*16像素、8*8像素以及4*4像素等。

如图5所示,在一个实施例中,提供了一种视频编码方法。既可以应用于服务器,也可以用于终端,本实施例以应用于终端举例说明。该视频编码方法具体包括如下步骤:

步骤S502,获取输入视频帧。

其中,视频是由一帧帧的视频帧组成的,进行编码时,需要对每一视频帧进行编码。输入视频帧是指当前待编码的视频帧。输入视频帧可以是实时采集的视频帧,比如,用于即时通信的视频帧。也可以是存储的视频对应的视频帧。

步骤S504,当确定输入视频帧对应的目标处理方式为下采样处理方式时,确定与输入视频帧对应的下采样信息。

其中,处理方式包括:全分辨率处理方式和下采样处理方式;当确定输入视频帧对应的目标处理方式为下采样处理方式时,获取与输入视频帧对应的下采样信息。在一个实施例中,输入视频帧对应的目标处理方式是从候选的处理方式中选取的,候选的处理方式可以是全分辨率处理方式或下采样处理方式。得到输入视频帧对应的处理方式的方法可以根据实际需要设置。例如,可以是获取输入视频帧对应的处理参数,根据处理参数得到对应的处理方式。处理参数是用于确定处理方式的参数,具体采用的处理方式可以根据需要进行设置。例如处理参数可以根据输入视频帧对应的当前编码信息和/或图像特征信息得到。

在确定了处理方式后,将处理方式信息添加到编码数据中,便于后续解码端根据编码数据中处理方式信息进行解码,处理方式信息中记载了输入视频帧对应的处理方式,即全分辨率处理方式或下采样处理方式。在确定了处理方式为下采样处理方式后,还需要确定相应的下采样信息,便于后续根据下采样信息进行编码。

下采样信息包括下采样比例、下采样方法中的至少一种。下采样包括:水平(宽)下采样、垂直(高)下采样、水平和垂直下采样。下采样比例是指采样前与采样后的分辨率之间的比值,包括水平下采样比例和垂直下采样比例。采样比例可以采用采样后/采样前的分辨率比值来表示,也可以采用采样前/采样后的分辨率比值来表示。比如,在水平下采样上,水平下采样后的分辨率是采样前的二分之一,那么如果采用采样后/采样前的分辨率比值来表示,为1/2;如果采用采样前/采样后的分辨率比值来表示为2。

为了描述上的清楚,下文中的下采样比例、上采样比例是指采用采样前/采样后的分辨率比值来表示的。

下采样比例分包括垂直下采样比例(高)、水平下采样(宽)比例。比如,对输入视频帧进行水平(宽)2倍下采样,采样后的图像的宽度为原始输入视频帧的一半。如果同时对输入视频帧进行宽2倍下采样和高2倍下采样,那么采样后的宽、高都是原来的一半,采样后的分辨率为原来的1/4。为了自适应地选择下采样比例,可以预先设置多个下采样比例供选择,比如,宽2倍下采样x高2倍下采样,宽3倍下采样x高3倍下采样、宽4倍下采样x高4倍下采样、宽2倍下采样x高3倍下采样等等。

下采样方法是指具体采用的采样方法,常见的采样方法包括:抽点、直接平均、滤波器、双线性插值、双三次插值、基于CNN(卷积神经网络)的算法,基于统计特性的方法等。不同的采样方法对应的计算复杂度不同。可以根据应用环境自适应地选择下采样方法。

在一个实施例中,输入视频帧对应的下采样方法与当前环境因素有关,比如,与对当前视频的实时要求的高低有关。如果对实时要求比较高的,一般采用计算复杂度低的采样方法,如果对实时性要求不太高的,采用计算复杂度较高的采样方法。下采样方法的计算复杂度越高,相应得到的视频质量越好。在一个实施例中,当前环境因素还包括:机型、CPU占用率、CPU核数、CPU内存等中的至少一种。一般来说,如当前环境因素能够处理的计算复杂度越高,相应选择计算复杂度越高的下采样方法,反之,选择计算复杂度越低的下采样方法,这样有利于在保证视频质量的同时提高编码速度。

在一个实施例中,输入视频帧对应的下采样比例与输入视频帧对应的视频帧信息有关。视频帧信息包括帧类型、图像特征信息等。比如,如果帧类型为B帧,倾向于选择下采样比例比较高的分辨率,因为P帧可作为B帧的参考帧,P帧图像质量影响了后续B帧的图像质量,所以如果帧类型为P帧,则倾向于选择下采样比例比较低的分辨率。图像特征信息是指视频帧对应的图像本身的特征,包括运动特征和纹理复杂度特征等,一般来说,运动度越大,纹理特征越复杂,在带宽有限的情况下,越倾向于选择较高的下采样比例。

步骤S506,根据下采样信息对输入视频帧进行编码得到输入视频帧对应的编码数据。

其中,当下采样信息中包括下采样比例时,根据下采样比例对输入视频帧进行下采样得到待编码帧,然后对待编码帧进行编码得到输入视频帧对应的编码数据。编码数据是指编码后得到的数据。当下采样信息中还包括下采样方法时,终端根据下采样方法对输入视频帧进行下采样得到待编码帧,然后对待编码帧进行编码得到编码数据。当下采样信息同时包括下采样比例和下采样方法时,终端先根据下采样比例对输入视频帧进行下采样得到待编码帧,然后采用下采样方法对待编码帧进行编码得到输入视频帧对应的编码数据。

步骤S508,根据下采样信息对应的处理范围将下采样信息添加至编码数据。

其中,处理范围是下采样信息作用的范围。根据下采样信息对应的处理范围将下采样信息添加至编码数据,便于后续解码端根据编码数据中的下采样信息进行解码。下采样信息的作用范围可以只针对一个视频帧,也可以同时针对多个视频帧。如果只针对一个视频帧,即只有该视频帧采用该下采样信息,将该下采样信息添加至该视频帧对应的头信息中。如果下采样信息对应的处理范围包括多个视频帧,即该处理范围内的多个视频帧对应的是相同的下采样信息。对于包括多个视频帧的处理范围,只需要将下采样信息添加至处理范围的头信息中即可,不需要在每个视频帧的头信息中都添加下采样信息。处理范围可以根据实际需要自定义设置,比如,可以将整个视频序列作为处理范围,也可以将一个或多个图像组(GOP,Group of Picture)作为处理范围,还可以将每一视频帧作为处理范围。

通过将下采样信息添加至编码数据,便于后续解码端根据编码数据中的下采样信息进行解码,从而实现自适应地选择下采样信息来进行编码,不但提高了编码的速度,而且有利于保证主观质量。

上述视频编码方法,通过获取输入视频帧,确定与输入视频帧对应的下采样信息,然后根据下采样信息对输入视频帧进行编码得到与输入视频帧对应的编码数据,根据下采样信息对应的处理范围将下采样信息添加至编码数据。上述编码方法通过将下采样信息添加至编码数据中,可以在编码过程中为每个输入视频帧灵活地自适应的选择更加适合的下采样信息,在有限带宽下提高了视频质量。

在一个实施例中,根据下采样信息对应的处理范围将下采样信息添加至编码数据,包括:获取下采样信息对应的处理范围,处理范围为序列级范围或图像组级范围或帧级范围或编码块级范围;将下采样信息添加至处理范围对应的头信息中。

其中,处理范围分为序列级范围、图像组(GOP)级范围、帧级范围、编码块级范围。其中,序列级范围是指针对整个视频序列,即对视频序列中的每个视频帧都对应有相同的下采样信息。图像组(GOP)是指一组连续的画面,一个图像组是指以接收到的I帧为起始位置,以下一次接收到的I帧的位置为结束,之间包括了若干个P帧和B帧的数据段。其中,I帧是帧内编码帧,P帧是前向预测帧,B是双向预测帧。即I帧是一个完整的画面,而P帧和B帧记录的是相对于I帧的变化,没有I帧,P帧和B帧就无法解码。图像组级范围是指针对图像组的,对处理范围内的图像组中的每个视频帧采用的都是同一下采样信息。帧级范围是指针对视频帧的,即该下采样信息只针对当前视频帧,编码块级范围是针对视频帧中的编码块的。

如果下采样信息是针对序列级的,那么将下采样信息添加至视频序列的头信息中,相应的作用范围即整个视频序列。如果下采样信息是针对图像组级的,那么将下采样信息添加至图像组对应的头信息中,相应的作用范围是该图像组内的视频帧。如果下采样信息是针对帧级的,那么将下采样添加至帧级对应的头信息中,相应的作用范围是当前视频帧。如果采样方法是针对编码块级的,那么将采样方法添加至编码块对应的头信息中,相应的作用范围是当前编码块。如图6所示,为一个实施例中,序列头信息字段、图像组头信息字段、帧级头信息字段、编码块头信息字段所在位置的示意图,可以通过将相应的下采样比例的标志位Down_Sampling_Scale赋予不同的值,然后添加到处理范围对应的头信息中来进行标识相应的下采样比例,同样地,可以将相应的下采样方法的标志为Down_Sampling_Method赋予不同的值,然后添加到相应的头信息中来标识不同的下采样方法。

如图7所示,在一个实施例中,下采样信息包括:下采样比例;确定与输入视频帧对应的下采样信息,包括:

步骤S504A,获取输入视频帧对应的当前量化参数估计值。

其中,量化参数(QP)是用来衡量量化步长的参数,其能够影响图像质量,量化参数越小,相应的图像质量越好。其中,量化参数与压缩率成正相关,即量化参数越小,相应的压缩率越小,量化参数越大,相应的压缩率越高。为了确定输入视频帧对应的下采样比例,需要对输入视频帧对应的当前量化参数进行估计。在一个实施例中,根据编码器采用的编码模式确定量化参数估计值,其中,编码模式包括固定质量编码和固定码率编码,固定质量编码是指保持视频画面质量固定的编码方式,固定码率编码是指保持视频码率固定的编码方式。对于不同的编码方式,计算输入视频帧的量化参数估计值的方法不同。

在一个实施例中,当当前编码方式为固定质量编码,则直接将该固定质量编码对应的量化参数作为输入视频帧的量化参数估计值,即将编码器的外部预设值作为输入视频帧的量化参数估计值。这是因为固定质量编码方式中所有的编码单元采用的量化参数都是相同的,所以直接将预设的量化参数作为输入视频帧的量化参数估计值即可。当当前编码方式为固定码率编码时,则根据编码器已有的码率控制算法计算当前视频帧的第一个编码单元的量化参数,并将第一个编码单元的量化参数作为当前视频帧对应的量化参数估计值;对于固定码率编码,同一视频帧中的不同编码单元所对应的量化参数不同,也可以将不同编码单元的量化参数的均值作为当前视频帧对应的量化参数估计值。

在另一个实施例中,对于固定码率编码,当前视频帧的量化参数估计值是根据前向参考视频帧的平均量化参数来确定的。具体地,计算前向参考视频帧的平均量化参数,然后获取前向参考视频帧的帧类型,若前向参考视频帧与当前视频帧的帧类型相同,则直接将平均量化参数作为当前视频帧的量化参数估计值。若前向参考视频帧与当前视频帧的帧类型不同,则获取两种帧类型之间的帧量化参数偏移量(预先设置),将平均量化参数与帧量化参数偏移量之和作为当前视频帧对应的量化参数估计值。

步骤S504B,获取输入视频帧对应的量化参数阈值。

其中,量化参数阈值是用于对量化参数进行衡量的参考值。通过将输入视频帧对应的当前量化参数估计值与量化参数阈值进行比较,可以用来确定输入视频帧对应的下采样比例。不同的视频帧对应的量化参数阈值可能不同。比如,可以针对不同的帧预测类型设置不同的量化参数阈值。在另一个实施例中,量化参数阈值的设置与视频帧的图像内容复杂度有关,量化参数阈值与图像内容复杂度成正相关,图像内容复杂度越大,相应的量化参数阈值设置的越大。

步骤S504C,根据当前量化参数估计值与量化参数阈值之间的差值确定与输入视频帧对应的下采样比例。

其中,计算输入视频帧对应的当前量化参数估计值与量化参数阈值之间的差值,然后根据差值确定与输入视频帧对应的下采样比例。差值与下采样比例成正比,即差值越大,相应的下采样比例越高。通过将当前量化参数估计值与量化参数阈值进行比较,然后根据两者之间的差值选择合适的下采样比例,有利于在保证主观质量的前提下,提高视频编码的速度。

在一个实施例中,根据当前量化参数与量化参数阈值之间的差值确定与输入视频帧对应的下采样比例,包括:获取候选差值范围与候选下采样比例之间的对应关系;确定当前量化参数与量化参数阈值之间的差值对应的目标差值范围;根据目标差值范围确定与输入视频帧对应的下采样比例。

其中,预先设置候选差值范围与候选下采样比例之间的对应关系,在确定了当前量化参数与量化参数阈值之间的差值后,就可以确定该差值所在的目标差值范围,然后根据目标差值范围确定与输入视频帧对应的下采样比例。下采样比例的选择与当前量化参数估计值与量化参数阈值之间的差值成正相关,差值越大,相应的下采样比例越大。

在一个实施例中,获取输入视频帧对应的量化参数阈值,包括:获取输入视频帧对应的视频帧信息,视频帧信息包括:编码信息、图像特征信息、前序视频帧的帧内编码块与帧间编码块的比值中的至少一种;根据视频帧信息确定与输入视频帧对应的量化参数阈值。

其中,编码信息是指输入视频在之前编码时得到的视频压缩参数信息,包括帧预测类型、运动向量、量化参数、视频来源、码率、帧率、分辨率等中的至少一种。其中,帧预测类型是指视频帧的类型,分为帧内预测帧和帧间预测帧,比如,I帧为帧内预测帧,P帧、B帧属于帧间预测帧。由于I帧一般为首帧或存在画面切换的帧,I帧的质量影响了后续P帧或B帧的质量,所以帧内预测帧倾向于选择较低的下采样比例,以保证图像质量,所以对于帧间预测帧,一般设置较大的量化参数阈值。进一步的,由于P帧可以作为B帧的参考帧,P帧的图像质量影响了后续B帧的图像质量,所以相对于B帧,P帧更倾向于设置较大的量化参数阈值。图像特征信息是指与图像内容相关的信息,包括图像运动特征信息、图像纹理特征信息、图像细节丰富度、空间相关度中的至少一种。

编码信息和/或图像特征信息反映了视频帧对应的场景、细节复杂度、运动剧烈程度等,比如,通过运动向量、量化参数、预测残差、码率等可判断运动场景,量化参数越大,一般运动越剧烈,运动向量大则代表图像场景是大运动场景。在码率一定时能表达的信息量有限,所以在码率一定的条件下,对于运动场景剧烈、大运动场景的情况,倾向于选择分辨率较低(下采样比例高)的编码方式,所以相应的量化参数阈值设置的较小。

在每个视频帧中包括有多个编码块,而每个编码块都对应有预测模式,如帧内预测或帧间预测。帧内预测编码块是指根据当前帧的其他编码块对当前块进行预测的编码块,帧间预测是指根据当前帧的参考帧中的编码块对当前帧中的当前块进行预测的编码块。对于帧内预测帧,其只包含有帧内预测编码块。由于帧内预测帧往往是首帧或运动变化较大的帧,所以倾向于选择全分辨率编码或者选择下采样比例较小的编码。

而对于帧间预测帧,既可能包含帧内预测编码块,也可能包含帧间预测编码块。在一个实施例中,对于帧间预测帧,可以根据前序视频帧的帧内编码块与帧间编码块的比值来确定当前视频帧对应的量化参数阈值。前序视频帧是指前面已编码的视频帧,可以是一帧,也可以是多帧。由于当前视频帧与前序视频帧相邻,所对应的内容相似,即当前视频帧的帧内帧间比例与前序视频帧的帧内帧间比例相似,由于帧内编码块的比例越大,采用下采样也不会对视频图像的质量产生大的影响,即帧内编码块的比例越高,相应选择的下采样比例越大。那么由于是根据量化参数估计值与量化参数阈值之间的差值来确定下采样比例的,且差值越大,下采样比例越大,故,相应地可以设置较小的量化参数阈值。帧内编码块的比例越高,相应的量化参数阈值越小,即帧内编码块与帧间编码块的比值与量化参数阈值成反相关。

在一个实施例中,下采样信息包括下采样比例;确定与输入视频帧对应的下采样信息,包括:获取候选环境因素与候选下采样比例之间的对应关系;获取当前环境因素,根据候选环境因素与候选下采样比例之间的对应关系确定与当前环境因素对应的下采样比例。

其中,候选环境因素包括:当前应用环境类型、CPU占用率、CPU核数、CPU内存、主频、系统类型、机型等中的至少一个。当前应用环境类型是指对视频实时性要求高或低的类型,比如,分为对实时性要求高的类型和对实时性要求不高的类型,对实时性要求高的视频偏向于选择较高的下采样比例,因为下采样比例越高,相应的处理数据越少,处理的越快。系统类型是指当前终端所采用的操作系统类型,比如,是IOS系统,还是Android系统,或者是Windows系统等,在其他条件相同的情况下,不同系统所对应的处理能力也是不同的,所以可以将系统类型作为确定下采样比例的条件。CPU占用率、CPU核数、CPU内存、主频、机型等都是代表硬件处理能力的参数,一般来说,处理能力越强,越偏向于选择较低的下采样比例,即处理的分辨率越高。

在一个实施例中,下采样信息包括下采样方法;确定与输入视频帧对应的下采样信息,包括:获取候选环境因素和候选下采样方法之间的对应关系;获取当前环境因素,根据候选环境因素与候选下采样方法之间的对应关系确定与当前环境因素对应的下采样方法。

其中,不同的下采样方法对应的计算复杂度不同,计算复杂度越高的下采样方法,相应的效果也越好。候选环境因素包括:当前应用环境类型、CPU占用率、CPU核数、CPU内存、主频、系统类型、机型等中的至少一个。当前应用环境类型是指对视频实时性要求高低的类型,比如,分为对实时性要求高的类型和对实时性要求不高的类型,对实时性要求高的视频偏向于计算复杂度低的下采样方法。系统类型是指当前终端所采用的操作系统类型,比如,是IOS系统,还是Android系统,或者是Windows系统等,在其他条件相同的情况下,不同系统所对应的处理能力也是不同的,所以可以将系统类型作为确定下采样方法的条件。CPU占用率、CPU核数、CPU内存、主频、机型等都是代表硬件处理能力的参数,一般来说,处理能力越强,越偏向于选择计算复杂度高的下采样方法,这样有利于提高编码质量。

在一个实施例中,所述下采样信息包括:下采样方法;所述确定与所述输入视频帧对应的下采样信息,包括:计算所述输入视频帧对应的图像内容复杂度;获取候选图像内容复杂度与候选下采样方法之间的对应关系;根据所述对应关系,确定与所述图像内容复杂度对应的目标下采样方法。

其中,图像内容复杂度是视频帧图像的内容复杂度。图像内容复杂度与运动幅度、纹理复杂度、细节丰富度以及空间相关度中的至少一种有关。在一个实施例中,可以采用图像梯度值来表示图像内容复杂度。图像梯度值是根据各个像素对应的像素梯度值之和得到的。计算得到的图像梯度值越大,图像内容复杂度越大。

预先设置候选图像内容复杂度与候选下采样方法之间的对应关系。图像内容复杂度越高,在计算复杂度允许的情况下,倾向于采用更复杂高质量的下采样方法。不同的下采样方法的计算复杂度不同,计算复杂度高的下采样方法得到的处理效果也越好。

根据预先设置的候选图像内容复杂度与候选下采样方法之间的对应关系,获取与图像内容复杂度对应的目标下采样方法。在一个实施例中,可以首先根据当前硬件环境确定在当前硬件环境下所能够采用的复杂度最高的第一下采样方法,后续根据图像内容复杂度确定对应的目标下采样方法,如果目标下采样方法的计算复杂度大于第一下采样方法,则把第一下采样方法作为目标下采样方法。如果目标下采样方法的计算复杂度不大于第一下采样方法,则直接将目标下采样方法作为最终的下采样方法。

在一个实施例中,所述下采样信息包括:下采样方法;所述确定与所述输入视频帧对应的下采样信息,包括:获取所述输入视频帧的当前编码块;计算所述当前编码块对应的模块梯度值;根据所述模块梯度值将所述当前编码块分类到模块集合中的目标模块类,所述模块类集合中的各个候选模块类分别对应不同的模块梯度值范围;获取候选模块类与候选下采样方法之间的对应关系;根据所述候选模块类与候选下采样方法之间的对应关系和所述目标模块类确定所述当前编码块对应的目标下采样方法。

其中,视频帧中包括有多个编码块,对视频编码实际上就是对各个编码块进行编码。当前编码块是指当前待处理的编码块。模块梯度值是指编码块对应的平均梯度值。由于编码块的大小可能不一致,所以采用平均梯度值能够更好地反应编码块的内容复杂度。编码块的模块梯度值等于编码块中每个像素的像素梯度值之和的平均。模块梯度值反应了编码块对应的图像的复杂度,模块梯度值越大,说明该编码块包含的细节越多,比如,如果对应的图像边缘,梯度值往往比较大。在一个实施例中,可以采用拉普拉斯滤波器计算每个像素对应的像素梯度值,然后根据编码块中包含的像素计算得到模块梯度值。

预先根据模块梯度值分为多个模块类,组成模块集合。模块集合中包含有多个模块类,且每个模块类对应有相应的模块梯度值范围。不同的模块类对应不同的模块梯度值范围,且每个模块类对应的模块梯度值范围不重合,即一个模块梯度值只可能匹配到一个模块类。所以获取到模块梯度值后,就可以根据模块梯度值确定与之对应的目标模块类。

不同的模块类对应不同的采样方法,采样方法用于对编码块进行采样处理。模块类对应的模块梯度值范围中包含的模块梯度值越大,在采样比例一定的情况下,对应的采样方法得到的清晰度越高。处理效果越好的采样方法,其计算复杂度越高,相应的处理速度就会越慢。为了能够保证用户对清晰度的要求,又能满足处理速度的要求,将多个采样方法结合起来使用,对于模块梯度值比较大的编码块,其包含的细节比较多,所以采用复杂度高效果好的采样方法,而对于模块梯度值小的编码块,由于里面包含的细节比较少,采用复杂度低的采样方法。这是由于人们对细节多的内容的清晰度更敏感,所以优先采用效果好的采样方法。

根据候选模块类对应的模块梯度值范围为候选模块类设置对应的采样方法,模块梯度值越大,相应的采样方法的处理效果越好。获取到目标模块类后,根据候选模块类与候选采样方法之间的对应关系便可确定与当前编码块对应的目标采样方法。针对不同的编码块,采用不同的采样方法,即结合多种采样方法对编码块进行处理,不但能够提高视频编码的质量,而且能够提高视频编码的速度。

举个例子,假设预先将模块梯度值将编码块分为三个模块类。比如,将模块梯度值在(0,10]范围内的编码块作为第一模块类,将模块梯度值在(10,30]范围的编码块作为第二模块类,将(30,+∞)范围内的编码块作为第三模块类。其中,第一模块类对应的采样方法为双线性插值、第二模块类对应的采样方法为双三次插值、第三模块类对应的采样方法为卷积神经网络(CNN)算法。在处理效果方面,卷积神经网络算法的处理效果优于双三次插值算法,双三次插值算法优于双线性插值算法。在处理速度方面,双线性插值算法最快,双三次插值算法次之,卷积神经网络最慢。根据模块梯度值将编码块进行分类,然后分别采用不同的采样方法进行处理,能够在保证主观质量的前提下,提高视频编码的速度。

在一个实施例中,下采样信息包括下采样比例;根据下采样信息对输入视频帧进行编码得到输入视频帧对应的编码数据,包括:根据下采样信息对输入视频帧进行处理得到待编码帧;获取待编码帧对应的当前参考帧;根据当前参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据。

其中,下采样信息包括下采样比例,根据下采样比例对输入视频帧进行下采样处理得到待编码帧。帧间编码帧在编码时需要根据参考帧进行编码,所以还需要获取与待编码帧对应的当前参考帧,然后根据当前参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据。

在一个实施例中,下采样信息包括下采样比例;根据当前参考帧对输入视频帧进行编码,得到输入视频帧对应的编码数据,包括:获取待编码帧对应的下采样信息,根据下采样信息对当前参考帧进行处理得到目标参考帧;根据目标参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据。

其中,为了能够更好地参考编码,将参考帧与待编码帧的分辨率处理为一致。在获取待编码帧对应的下采样比例后,根据下采样比例对当前参考帧进行采样处理。其中,在已知输入视频帧的原始分辨率和下采样比例的情况下,显然可以得到待编码帧的分辨率信息。当当前参考帧的分辨率小于待编码帧的分辨率时,则对当前参考帧进行上采样得到目标参考帧。当当前参考帧的分辨率大于待编码帧的分辨率时,需要对当前参考帧进行下采样得到目标参考帧,然后根据目标参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据。

如图8所示,在一个实施例中,提出了一种视频编码方法。具体可以包括以下步骤:

步骤S802,获取输入视频帧。

步骤S804,获取输入视频帧对应的目标处理方式,当目标处理方式为下采样处理方式时,进入步骤S806,若目标处理方式为全分辨率处理方式时,直接将输入视频帧作为待编码帧,进入步骤S810。

其中,输入视频帧对应的处理方式是从候选的处理方式中选取的,候选的处理方式可以是全分辨率处理方式以及下采样处理方式。得到输入视频帧对应的处理方式的方法可以根据实际需要设置。例如,可以是获取输入视频帧对应的处理参数,根据处理参数得到对应的处理方式。处理参数是用于确定处理方式的参数,具体采用的处理参数可以根据需要进行设置。例如处理参数可以包括输入视频帧对应的当前编码信息以及图像特征的至少一种。

在一个实施例中,可以根据输入视频帧对应的当前编码信息以及图像特征信息中的至少一种得到输入视频帧对应的处理方式。当前编码信息是指视频在编码时得到的视频压缩参数信息,如帧预测类型、运动向量、量化参数、视频来源、码率、帧率以及分辨率的一种或多种。图像特征信息是指与图像内容相关的信息,包括图像运动信息以及图像纹理信息的一种或多种,如边缘等。当前编码信息以及图像特征信息反映了视频帧对应的场景、细节复杂度或者运动剧烈程度等,如通过运动向量、量化参数或者码率中的一个或多个等可判断运动场景,量化参数大则一般运动剧烈,运动向量大则代表图像场景是大运动场景。还可根据已编码I帧与P帧或已编码I帧与B帧的码率比值判断,如果比值超过第一预设阈值,则判断为静止图像,如果比值小于第二预设阈值,则可判断为运动剧烈图像。或直接根据图像内容跟踪目标对象,根据目标对象的运动速度确定是否为大运动场景。码率一定时能表达的信息量一定,对于运动剧烈的场景,时间域信息量大,相应的可用于表达空间域信息的码率就少,因此采用低分辨率能达到较好的图像质量效果,更倾向于选择下采样模式进行编码。通过帧预测类型可确定画面切换场景,也可根据帧预测类型对其它帧的影响确定倾向于的编码模式。如I帧一般为首帧或存在画面切换,I帧的质量影响了后续P帧或B帧的质量,所以帧内预测帧相比于帧间预测帧更倾向于选择全分辨率处理方式,以保证图像质量。因为P帧可作为B帧的参考帧,P帧图像质量影响了后续B帧的图像质量,所以如果采用P帧编码则相比于采用B帧编码更倾向于选择全分辨率处理方式。通过图像特征信息,如图像纹理信息确定待编码视频帧的纹理复杂度,如果纹理复杂,包含的细节多,则图像空域信息多,如果进行下采样,可能由于下采样损失较多细节信息,影响视频质量,所以纹理复杂的待编码视频帧相比于纹理简单的待编码视频帧更倾向于选择全分辨率处理。

在一个实施例中,可以根据输入视频帧对应的当前量化参数以及量化参数阈值的大小关系得到输入视频帧对应的分辨率。如果当前量化参数大于量化参数阈值,则确定处理方式为下采样处理方式,否则确定处理方式为全分辨率处理方式。量化参数阈值可以根据在输入视频帧之前,已编码的前向编码视频帧的帧内编码块的比例得到,可以预先设置帧内预测块比例与量化参数阈值的对应关系,从而在确定了前向编码视频帧的帧内预测块比例后,可以根据对应关系确定与前向编码视频帧的帧内预测块比例对应的量化参数阈值。对于固定量化参数编码,当前量化参数可以是对应的固定量化参数值。对于固定码率编码,则可以根据码率控制模型计算得到输入视频帧对应的当前量化参数。或者,可以将参考帧对应的量化参数作为输入视频帧对应的当前量化参数。本发明实施例中,当前量化参数越大一般运动越剧烈,对于运动剧烈的场景更倾向于选择下采样处理方式。

在一个实施例中,帧内预测块比例与量化参数阈值的关系为正相关关系。比如,可以根据经验,预先确定帧内预测块比例Intra0与量化参数阈值QPTH的对应关系为:

步骤S806,确定与输入视频帧对应的下采样信息。

其中,下采样信息包括下采样比例、下采样方法中的至少一种。下采样包括:水平(宽)下采样、垂直(高)下采样、水平和垂直下采样。在对输入视频帧采用下采样处理方式处理时,还可按照不同的下采样方法或下采样比例进行下采样,对输入视频帧进行自适应处理的方式更为灵活步骤S808,根据下采样信息对输入视频帧进行下采样处理,得到待编码帧。

步骤S808,根据下采样信息对输入视频帧进行下采样处理得到待编码帧。

其中,待编码帧是根据处理方式对输入视频帧进行处理得到的。当处理方式包括全分辨率处理方式时,则可以将输入视频帧作为待编码帧。当处理方式包括下采样处理方式时,则可以对输入视频帧进行下采样处理,得到待编码帧。例如,当输入视频帧的分辨率为800*800像素,处理方式为水平以及垂直方向均进行2/1下采样时,下采样得到的待编码帧的分辨率为400*400像素。

步骤S810,在待编码帧的分辨率下,对待编码帧进行编码得到编码数据,当处理方式为下采样处理方式时,根据下采样信息对应的处理范围将下采样信息添加至编码数据。

其中,编码可以包括预测、变换、量化以及熵编码中的至少一个。当待编码帧为I帧时,在待编码帧的分辨率下对待编码帧进行帧内预测。当待编码帧为P帧以及B帧时,可以获取待编码帧对应的当前参考帧,根据当前参考帧进行预测得到预测残差,并对预测残差进行变换、量化以及熵编码得到输入视频帧对应的编码数据,其中,得到编码数据的过程中,根据待编码帧的分辨率对当前参考帧、待编码帧的各个编码块对应的位置信息、当前参考帧的各个参考块对应的位置信息以及运动矢量中的至少一个进行处理。例如,在计算预测残差时,可以根据待编码帧的分辨率信息对当前参考帧进行处理,得到目标参考帧,从目标参考帧中获取待编码帧中各个编码块对应的目标参考块,根据目标参考块进行预测,得到编码块对应的预测值,再根据编码块的实际值与预测值的差值得到预测残差。计算目标运动矢量时,如果当前参考帧的分辨率与待编码帧的分辨率不同,可以根据当前参考帧与待编码帧的分辨率信息对编码块的位置信息或者解码块的位置信息进行变换,使得待编码帧对应的位置信息与当前参考帧的位置信息处于同一量化尺度下,再根据变换后的位置信息得到目标运动矢量,以减少目标运动矢量的值,减少编码数据的数据量。或者,如果目标运动矢量对应的分辨率信息与待编码帧的分辨率信息不同,则在待编码帧的分辨率下,计算得到待编码帧的编码块对应的第一运动矢量时,根据待编码帧的分辨率信息以及目标运动矢量单位辨率信息对第一运动矢量进行变换,得到目标分辨率下的目标运动矢量。例如,假设待编码帧的分辨率为400*800像素,当前参考帧的分辨率为800*1600像素。则可以根据待编码帧的分辨率对当前参考帧进行2/1下采样,得到目标参考帧的分辨率为400*800像素,再根据目标参考帧进行视频编码。

通过将下采样信息添加至编码数据,便于后续解码端根据编码数据中的下采样信息进行解码,从而实现自适应地选择下采样信息来进行编码,不但提高了编码的速度,而且有利于保证主观质量。

本实施例中,在获取到处理方式为下采样处理方式时,还需要获取下采样信息,然后根据下采样信息对输入视频帧进行处理得到待编码帧,在待编码帧的分辨率下,对待编码帧进行编码得到编码数据,然后根据下采样信息对应的处理范围将下采样信息添加至编码数据。通过灵活地自适应地选择处理方式以及下采样信息,从而实现了在带宽有限的情况下,提高视频质量。

在一个实施例中,在待编码帧的分辨率下,对待编码帧进行编码得到输入视频帧对应的编码数据包括:将处理方式对应的处理方式信息添加至输入视频帧对应的编码数据中。

其中,处理方式信息用于描述输入视频帧是采用的处理方式,可以在编码数据中加入描述处理方式的标志位Frame_Resolution_Flag,即在编码数据中加入描述处理方式信息的语法元素。各个处理方式对应的标志位的值可以根据需要设置。例如,当处理方式为全分辨率处理方式时,对应的Frame_Resolution_Flag可以为0,当处理方式为下采样处理方式时,对应的Frame_Resolution_Flag可以为1。在一个实施例中,处理方式信息添加至编码数据对应的帧级头信息中,例如可以添加到帧级头信息的预设位置中,帧级头信息是输入视频帧对应的编码数据的头信息,序列级头信息是指视频序列对应的编码数据的头信息,组级头信息是指视频组(GOP,Groups of Picture)对应的编码数据的头信息。一个视频帧序列可以包括多个视频组,一个视频组可以包括多个视频帧。图9中虚线所指的方框表示各个输入视频帧对应的编码数据的帧级头信息,frame分别代表第1个、第2个以及第n个视频帧对应的编码数据。其中,图9中,第一个输入视频帧以及第二个输入视频帧对应的处理方式为全分辨率处理方式,第三个输入视频帧对应的处理方式为下采样处理方式。

在一个实施例中,还可以将对输入视频帧进行下采样的下采样处理方式信息添加至输入视频帧对应的编码数据中,以使解码端在获取到编码数据时,能够根据下采样处理方式信息获取对应的对重建视频帧进行上采样的方法以及上采样比例。下采样处理方式信息包括下采样方法信息以及下采样比例信息中的至少一种。下采样方法信息在编码数据的添加位置可以是对应的组级头信息、序列级头信息以及帧级头信息中的一个,下采样方法信息在编码数据的添加位置可以根据下采样方法对应的作用范围确定。下采样比例信息在编码数据的添加位置可以是对应的组级头信息、序列级头信息以及帧级头信息中的任一个。下采样比例信息在编码数据的添加位置可以根据下采样比例对应的作用范围确定,作用范围是指适用的范围。例如,如果下采样比例作用的范围是一个视频组,则可以将该视频组对应的下采样比例信息添加到该视频组对应的头信息中。如果下采样比例作用的范围是视频序列,将下采样比例信息添加至该视频序列对应的序列级头信息,表示该视频序列的各个视频帧采用下采样比例信息对应的下采样比例进行下采样处理。

在一个实施例中,获取输入视频帧对应的处理方式包括:获取输入视频帧对应的处理参数,根据处理参数确定输入视频帧对应的处理方式;将处理方式对应的处理方式信息添加至输入视频帧对应的编码数据中包括:当处理参数在解码过程中不能重现时,将处理方式对应的处理方式信息添加至输入视频帧对应的编码数据中。

其中,处理参数可以包括输入视频帧对应的图像编码信息以及图像特征信息中的至少一个。处理参数在解码过程中不能重现是指在解码的过程中不能得到或者不会产生该处理参数。例如,如果处理参数是与输入视频帧的图像内容对应的信息,而在编码过程中图像信息是存在损失的,则解码端的解码视频帧与输入视频帧存在差别,因此,解码过程中不会得到输入视频帧的图像内容对应的信息,即图像内容对应的信息在解码过程中不能重现。编码过程中需要计算率失真代价,而解码过程中不计算率失真代价,则当处理参数包括率失真代价时,则该处理参数不能在解码过程中重现。对于编码过程中得到的重建视频帧与输入视频帧的PSNR(Peak Signal to Noise Ratio,峰值信噪比)信息,解码过程中不能得到,因此PSNR信息在解码过程中不能重现。

在一个实施例中,当处理参数在解码端中能够重现时,可以将处理方式对应的处理方式信息添加至输入视频帧对应的编码数据中,也可以不将处理方式对应的处理方式信息添加至输入视频帧对应的编码数据中。其中,将处理方式对应的处理方式信息添加至输入视频帧对应的编码数据中时,解码端可以从编码数据中读取处理方式信息,无需再根据处理数据得到处理方式。当不将处理方式对应的处理方式信息添加至输入视频帧对应的编码数据中时,由解码设备根据处理参数确定出与编码端一致的处理方式,可以减少编码数据的数据量。

在一个实施例中,如图10所示,步骤S810即在待编码帧的分辨率下,对待编码帧进行编码得到输入视频帧对应的编码数据包括:

步骤S810A,获取待编码帧对应的当前参考帧。

其中,当前参考帧是对待编码帧进行编码时所需参考的视频帧,当前参考帧是待编码帧之前已编码得到的数据进行重建得到的视频帧。待编码帧对应的当前参考帧的个数可为一个或多个。例如当待编码帧为P帧,则对应的参考帧可以为1个。当待编码帧为B帧,则对应的参考帧可以为2个。待编码帧对应的参考帧可以是根据参考关系得到的,参考关系根据各个视频编解码标准确定。例如,对于一个视频图像组(GOP、Group Of Picture)中的第二个视频帧假设为B帧,其对应的参考帧可以是该视频组的I帧以及视频组的第3帧,也可以是第1帧和第4帧,具体可以自定义设置。

在一个实施例中,获取待编码帧对应的当前参考帧包括:获取第一参考规则,第一参考规则包括待编码帧与当前参考帧的分辨率大小关系;根据第一参考规则获取待编码帧对应的当前参考帧。

其中,第一参考规则确定了待编码帧与当前参考帧的分辨率大小限制关系,分辨率大小关系包括待编码帧与当前参考帧的分辨率相同以及不同的至少一种。当第一参考规则包括待编码帧与当前参考帧的分辨率相同时,第一参考规则还可以包括待编码帧与当前参考帧的分辨率的处理方式参考规则。例如处理方式参考规则可以包括全分辨处理方式的待编码帧可以参考全分辨率处理方式的参考帧以及下采样处理方式的待编码帧可以参考下采样处理方式的参考帧的一种或两种。当第一参考规则包括待编码帧与参考帧的分辨率不相同时,第一参考规则还可以包括待编码帧的分辨率大于参考帧的分辨率以及待编码帧的分辨率小于参考帧的分辨率的一种或两种。因此,在一个实施例中,第一参考规则具体可以包括原始分辨率待编码帧可以参考下采样分辨率参考帧、下采样分辨率待编码帧可以参考原始分辨率参考帧、原始分辨率待编码帧可以参考原始分辨率参考帧、以及下采样分辨率待编码帧可以参考下采样分辨率的参考帧中的一种或多种。其中原始分辨率待编码帧是指该待编码帧的分辨率与其对应的输入视频帧的分辨率相同,原始分辨率参考帧是指该参考帧的分辨率与其对应的输入视频帧的分辨率相同。下采样分辨率待编码帧是指该待编码帧是对应的输入视频帧进行下采样处理得到的。下采样分辨率参考帧是指该参考帧是对应的输入视频帧进行下采样处理得到的。得到第一参考规则后,根据第一参考规则获取待编码帧对应的当前参考帧,使得到的当前参考帧满足第一参考规则。

在一个实施例中,步骤S810即在待编码帧的分辨率下,对待编码帧进行编码得到输入视频帧对应的编码数据包括:将第一参考规则对应的规则信息添加至输入视频帧对应的编码数据中。

其中,规则信息用于描述采用的参考规则,可以在编码数据中加入描述参考规则的标志位Resolution_Referencer_Rules。具体的标志位的值所代表的参考规则可以根据需要设置。规则信息在编码数据的添加位置可以是组级头信息、序列级头信息以及帧级头信息中的一个或多个,规则信息在编码数据的添加位置可以根据第一处理参考规则的作用范围确定。例如,当第一参考规则为原始分辨率待编码帧可以参考下采样分辨率参考帧时,对应的Resolution_Referencer_Rules可以为1,当第一参考规则为下采样分辨率待编码帧可以参考下采样分辨率的参考帧时,对应的Resolution_Referencer_Rules可以为2。若视频序列采用相同的第一参考规则,则规则信息在编码数据的添加位置可以是序列级头信息。若第一参考规则是其中的一个视频组采用的参考规则,则规则信息在编码数据的添加位置是采用第一参考规则的视频组对应的组级头信息。

步骤S810B,在待编码帧的分辨率下,根据当前参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据。

其中,可以获取待编码帧对应的当前参考帧,根据当前参考帧进行预测得到预测残差,并对预测残差进行变换、量化以及熵编码得到输入视频帧对应的编码数据。其中,得到编码数据的过程中,根据待编码帧的分辨率对当前参考帧、待编码帧的各个编码块对应的位置信息、当前参考帧的各个参考块对应的位置信息以及运动矢量中的至少一个进行处理。得到当前参考帧后,可以从当前参考帧中获取与待编码帧的编码块对应的参考块,根据参考块对编码块进行编码。也可以根据待编码帧的分辨率对当前参考帧进行处理,得到对应的目标参考帧,从目标参考帧中获取与待编码帧的编码块对应的目标参考块,根据目标参考块对编码块进行编码,得到输入视频帧对应的编码数据。

在一个实施例中,在待编码帧的分辨率下,对待编码帧进行编码得到输入视频帧对应的编码数据包括:在待编码帧的分辨率下,获取待编码帧进行编码时对应的编码方式;将编码方式对应的编码方式信息添加至输入视频帧对应的编码数据中。

其中,编码方式是与进行编码有关的处理方式。例如可以包括编码时对参考帧进行解码重建后的视频帧采用的上采样方式、参考规则对应的规则以及对参考帧进行采样处理的采样方式以及运动矢量对应的分辨率中的一个或多个。通过将编码方式对应的编码方式信息添加至输入视频帧对应的编码数据,解码时可以根据编码方式信息对待解码视频帧对应的编码数据进行解码。

在一个实施例中,也可以不将编码方式对应的编码方式信息添加到编码数据中。而是在编解码标准中预先设置编码方式,在解码端中设置与该编码方式对应的解码方式。或者编码端与解码端可以根据相同或者对应的算法计算得到匹配的编码方式以及解码方式。例如,在编解码标准中预先设置编码时对当前参考帧进行上采样方法与解码时对当前参考帧进行上采样的方法相同。

在一个实施例中,如图11所示,步骤S810B即根据当前参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据包括:

步骤S1102,根据待编码帧的分辨率信息对当前参考帧进行采样处理,得到对应的目标参考帧。

其中,目标参考帧,是对当前参考帧进行采样处理后得到的视频帧。采样处理是通过待编码帧的分辨率信息对当前参考帧进行采样,使得到的目标参考帧的分辨率信息匹配的过程。在进行采样处理时,可以先确定采样方式,采样方式包括直接分像素插值方式和采样后分像素插值方式中的一种。直接分像素插值方式直接对当前参考帧进行分像素插值处理,采样后分像素插值方式对当前参考帧进行采样处理后再分像素插值处理。

分像素插值是通过当前参考帧中整像素的参考数据插值得到分像素级别的参考数据的过程。比如,如图12A、12B所示,为一个实施例中对当前参考帧进行插值的示意图。参照图12A,A1、A2、A3、B1、B2、B3等像素点为当前参考帧中的2*2整像素点,根据这些整像素点的参考数据计算得到分像素点的参考数据,比如,可根据A1、A2、A3三个整像素点的参考数据取平均值计算得到分像素点a23的参考数据,根据A2、B2、C2三个整像素点的参考数据取平均值计算得到分像素点a21的参考数据,再根据分像素点a23、a21的参考数据计算得到分像素点a22的参考数据,实现对当前参考帧进行1/2像素精度插值。参照图12B,A1、A2、A3、B1、B2、B3等像素点为当前参考帧中的4*4整像素点,根据这些整像素点的参考数据计算得到15个分像素点参考数据,实现对当前参考帧进行1/4像素精度插值。比如,根据A2、B2整像素点的参考数据计算得到分像素点a8的参考数据,根据A2、A3整像素点的参考数据计算得到分像素点a2的参考数据,同理计算得到a1至a15共15个分像素点的参考数据,实现对整像素点A2的1/4像素精度插值。在对待编码帧进行编码的过程中,需要在当前参考帧中采用运动搜索技术找到与待编码帧中编码块相应的参考块,根据编码块相对于参考块的运动信息计算得到运动矢量,对运动矢量进行编码以告知解码端参考块对应的参考数据在当前参考帧中的位置,因而,通过对当前参考帧进行分像素插值处理得到目标参考帧,待编码帧就可以根据分辨率更高的目标参考帧进行运动估计,从而提高运动估计的准确度,提升编码质量。

在一个实施例中,编码端和解码端可在各自的编解码规则中设置根据当前参考帧进行处理得到目标参考帧时所采用的采样方式,采用的采样方式应当是一致的,在编、解码时就根据配置确定对当前参考帧进行处理所对应的采样方式。

在一个实施例中,在待编码帧的分辨率下,对待编码帧进行编码得到输入视频帧对应的编码数据包括:将对当前参考帧进行采样处理对应的采样方式信息添加至当前参考帧对应的编码数据中。当前参考帧进行采样处理对应的采样方式信息在编码数据的添加位置可以是对应的序列级头信息、组级头信息以及帧级头信息中的任一个,采样方式信息在编码数据的添加位置可以根据采样方式对应的作用范围确定。可将采样方式信息添加至输入视频帧对应的编码数据的帧级头信息中,表示输入视频帧在被编码时对应的当前参考帧采用采样方式信息对应的采样方式进行分像素插值处理。例如,当编码数据的帧级头信息中用于确定采样方式的标识位Pixel_Sourse_Interpolation为0时,表示输入视频帧对应的当前参考帧采用直接进行分像素插值处理,在Pixel_Sourse_Interpolation为1时,表示输入视频帧对应的当前参考帧采用采样处理后再分像素插值处理。解码端就可按照编码数据中标识位所表示的分像素插值方式对当前参考帧进行分像素插值处理得到目标参考帧,从而可依据目标参考帧对编码数据进行解码得到重建视频帧。

在一个实施例中,可根据待编码帧的分辨率与当前参考帧的分辨率之间的比例关系确定对当前参考帧进行采样的比例。比如,输入视频帧的分辨率均为2M*2N,通过对当前输入视频帧按照全分辨率处理方式进行处理,即直接将当前输入视频帧作为待编码帧,则待编码帧的分辨率为2M*2N,而对可作为参考帧的输入视频帧按照下采样处理方式进行处理,得到下采样后的当前待编码参考帧的分辨率为M*2N,则重建后得到的相应的当前参考帧的分辨率也为M*2N,那么就确定对当前参考帧以宽1/2、高1的采样比例进行上采样处理,得到与待编码帧分辨率相同的帧。若通过对当前输入视频帧按照下采样处理方式进行处理,下采样后得到的待编码帧的分辨率为M*N,而对可作为参考帧的输入视频帧按照全分辨率处理方式进行处理,那么重建后得到的当前参考帧的分辨率为2M*2N,则确定对当前参考帧以宽、高均为2/1的采样比例进行下采样处理,得到与待编码帧分辨率相同的帧。

在一个实施例中,由于输入视频帧的分辨率一般是相同的,可根据输入视频帧进行下采样得到待编码帧所对应的下采样比例,以及对可作为参考帧的输入视频帧进行下采样得到待编码参考帧所对应的下采样比例,确定对当前参考帧进行采样的比例。比如,通过对输入视频帧以2/1的采样比例进行下采样处理得到待编码帧,通过对可作为参考帧的输入视频帧以4/1的采样比例进行下采样处理得到待编码参考帧,那么根据待编码参考帧的编码数据重建后得到的当前参考帧对应的下采样比例也是4/1,那么,根据两者下采样比例之间的倍数关系,可确定对当前参考帧以1/2的采样比例进行上采样处理得到与待编码帧分辨率相同的帧。

在一个实施例中,对当前参考帧进行采样的采样方法与对输入视频帧进行下采样得到待编码帧的采样算法匹配,即如果需要对当前参考帧进行下采样,则下采样算法与对待编码视频帧进行下采样得到待编码帧的下采样算法相同。如果需要对当前参考帧进行上采样,则上采样算法与对输入视频帧进行下采样得到当前待编码帧的下采样算法匹配的相反的采样算法。

本实施例中,对当前参考帧进行采样的采样算法与对待编码视频帧进行下采样得到当前编码视频帧的采样算法匹配,可进一步提高当前参考帧与当前编码视频帧的图像匹配度,进一步提高帧间预测的准确度,减小预测残差,提高编码图像的质量。

步骤S1104,根据目标参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据。

其中,得到目标参考帧后,从目标参考帧中搜索得到与编码块相似的图像块作为参考块,计算编码块与参考块的像素差值得到预测残差。根据编码块与对应的目标参考块的位移得到第一运动矢量。根据第一运动矢量以及预测残差得到编码数据。

在一个实施例中,可以根据目标运动矢量分辨率单位信息对第一运动矢量进行变换,得到在目标分辨率下的目标运动矢量,根据目标运动矢量以及预测残差得生成编码数据。其中,根据目标运动矢量分辨率单位信息对第一运动矢量进行变换,得到目标运动矢量的方法在后面描述。

在一个实施例中,也可以计算目标运动矢量和对应的预测运动矢量之间的矢量差值,对矢量差值进行编码,得到编码数据,进一步减少编码数据量。计算矢量差值的步骤可以包括:获取当前编码块对应的初始预测运动矢量;根据初始预测运动矢量对应的当前运动矢量单位分辨率信息和目标运动矢量单位分辨率信息,得到第二矢量变换系数;根据初始预测运动矢量和第二矢量变换系数得到当前编码块对应的目标预测运动矢量;根据目标运动矢量和目标预测运动矢量得到运动矢量差。其中,目标预测运动矢量是在目标分辨率下的运动矢量,计算矢量差值的方法在后面描述。

在一个实施例中,步骤S1102根据待编码帧的分辨率信息对当前参考帧进行采样处理,得到对应的目标参考帧包括:根据待编码帧的分辨率信息以及运动估计像素精度对当前参考帧进行采样处理,得到对应的目标参考帧。

其中,运动估计像素精度是待编码帧中的编码块对应的运动矢量的单位长度。编码端在对待编码帧中的编码块进行编码时,可按照获取的运动估计像素精度将编码块对应的运动矢量的单位长度进行细化,这样得到的运动向量更为精细和准确,因而,需要按照获取的运动估计像素精度对当前参考帧进行采样处理得到目标参考帧,再依据目标参考帧计算待编码帧中各编码块对应的第一运动向量,基于该第一运动向量进行编码得到待编码帧对应的编码数据。

其中,可获取当前参考帧的分辨率信息,根据待编码帧采用的分像素插值方式,以及待编码帧的分辨率信息、当前参考帧的分辨率信息以及待编码帧对应的运动估计像素精度确定对当前参考帧进行何种采样处理方法、采样处理对应的采样比例以及像素插值精度。运动估计像素精度的大小可以根据需要设置,例如一般为1/2像素精度、1/4像素精度或1/8像素精度。

在一个实施例中,可根据待编码帧的图像特征信息为该待编码帧配置相应的运动估计像素精度,图像特征信息比如该待编码帧的大小、纹理信息、运动速度等,可综合多种图像特征信息确定待编码帧对应的运动估计像素精度。待编码帧所携带的图像数据越复杂,图像信息越丰富,相应的运动估计像素精度更高。比如,在对P帧进行帧间预测时,可采用较高的运动估计像素精度计算P帧中各编码块对应的运动矢量,而在对B帧进行帧间预测时,可采用较低的运动估计像素精度计算B帧中各编码块对应的运动矢量。

在一个实施例中,根据待编码帧的分辨率信息以及运动估计像素精度对当前参考帧进行采样处理,得到对应的目标参考帧包括:根据待编码帧的分辨率信息以及运动估计像素精度计算得到像素插值精度;根据像素插值精度直接对当前参考帧进行分像素插值处理,得到对应的目标参考帧。

其中,像素插值精度是对当前参考帧进行分像素插值对应的像素精度。当分像素插值方式为直接分像素插值方式,表示可对当前参考帧直接进行分像素插值处理得到目标参考帧。因此可以根据待编码帧的分辨率信息以及运动估计像素精度计算得到像素插值精度。可以计算当前参考帧的分辨率信息与待编码帧的分辨率信息的比例,根据比例以及运动估计像素精度得到像素插值精度。

在一个实施例中,当当前参考帧的分辨率大于待编码帧的分辨率时,当前参考帧中部分分像素点的数据可直接复用,可作为与运动估计像素精度相应的分像素点对应的数据。比如,待编码帧的分辨率为M*N,当前参考帧的分辨率为2M*2N,若运动估计像素精度为1/2,像素插值精度为1,那么当前参考帧可直接作为目标参考帧;若运动估计像素精度为1/4,那么计算得到像素插值精度为1/2,可对当前参考帧以1/2像素插值精度进行分像素插值处理得到目标参考帧。

在一个实施例中,当待编码帧的分辨率信息所表示的分辨率与当前参考帧的分辨率相同时,则根据运动估计像素精度直接对当前参考帧进行分像素插值处理,得到对应的目标参考帧。

其中,通过全分辨处理方式对输入视频帧进行处理得到待编码帧,且当前参考帧的分辨率也是原分辨率时,则待编码帧的分辨率和当前参考帧的分辨率相同。或者,通过下采样处理方式对输入视频帧进行处理得到待编码帧,且当前参考帧帧也是采用相同采样比例的下采样处理方式编码得到的编码数据重建得到的,则待编码帧的分辨率和当前参考帧的分辨率相同。那么,就可以直接基于运动估计像素精度直接对当前参考帧进行分像素插值处理得到目标参考帧,并且,分像素插值处理对应的像素插值精度和运动估计像素精度相同。

在一个实施例中,根据待编码帧的分辨率信息以及运动估计像素精度对当前参考帧进行采样处理,得到对应的目标参考帧包括:根据待编码帧的分辨率信息对当前参考帧进行采样处理,得到中间参考帧;根据运动估计像素精度对中间参考帧进行分像素插值处理,得到目标参考帧。

其中,当待编码帧对应的分像素插值方式为采样后分像素插值方式,表示要对当前参考帧先进行采样处理,得到与待编码帧分辨率相同的中间参考帧,再对中间参考帧进行分像素插值处理得到对应的目标参考帧。

当待编码帧的分辨率信息所表示的分辨率小于当前参考帧的分辨率时,则根据待编码帧的分辨率信息对当前参考帧进行下采样处理,得到中间参考帧,然后基于待编码帧对应的运动估计像素精度对中间参考帧进行分像素插值处理,得到目标参考帧。举例说明:通过对分辨率为2M*2N的输入视频帧按照下采样处理方式进行下采样处理得到分辨率为M*N的待编码帧,而当前参考帧的分辨率为2M*2N(全分辨率处理方式),则对当前参考帧按照2/1的采样比例进行下采样处理得到分辨率为M*N的中间参考帧,若获取的待编码帧对应的运动估计像素精度为1/2,再对中间参考帧按照与运动估计像素精度相同的像素插值精度,即1/2分像素插值精度进行分像素插值处理,得到目标参考帧;若获取的待编码帧对应的运动估计像素精度为1/4,则对中间参考帧按照1/4分像素插值精度进行分像素插值处理,得到目标参考帧。

当待编码帧的分辨率信息所表示的分辨率大于当前参考帧的分辨率时,则根据待编码帧的分辨率信息对当前参考帧进行上采样处理,得到中间参考帧,然后基于待编码帧对应的运动估计像素精度对中间参考帧进行分像素插值处理,得到目标参考帧。比如,待编码帧的分辨率为2M*2N,当前参考帧的分辨率为1/2M*1/2N,则需要按照采样比例为1/4对当前参考帧进行上采样处理得到与待编码帧分辨率相同的中间参考帧,若运动估计像素精度为1/2,则继续对得到的中间参考帧按照1/2像素插值精度进行分像素插值处理,得到目标参考帧;若运动估计像素精度为1/4,则继续对得到的中间参考帧按照1/4像素插值精度进行分像素插值处理,得到目标参考帧。

步骤S810B在待编码帧的分辨率下,根据当前参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据包括:根据待编码帧的分辨率信息和第一分辨率信息确定第一矢量变换参数,第一分辨率信息包括当前参考帧的分辨率信息或者输入视频帧对应的目标运动矢量单位分辨率信息,根据第一矢量变换参数得到待编码帧中各个编码块对应的目标运动矢量。

其中,第一矢量变换参数用于对得到运动矢量的位置信息或者运动矢量进行变换。分辨率信息是与分辨率相关的信息,例如可以是分辨率本身或者下采样比例等。第一矢量变换参数可以是待编码帧的分辨率信息和第一分辨率信息之间的比例。例如,假设当前参考帧的下采样比例为3/1,待编码帧的下采样比例为6/1。则第一矢量变换参数可以为6除以3等于2。

在一个实施例中,得到第一矢量变换参数后,根据第一矢量变换参数对得到的运动矢量或者运动矢量对应的位置信息进行变换,得到目标运动矢量。当利用第一矢量变换参数对目标运动矢量进行变换时,使得目标运动矢量是在目标运动矢量单位分辨率信息所表示的目标分辨率下的运动矢量,目标运动矢量单位分辨率信息与目标运动矢量的单位所对应的目标分辨率对应的信息,例如可以是目标分辨率本身或者下采样比例。当利用第一矢量变换参数对运动矢量对应的位置信息进行变换时,使得待编码帧对应的位置信息与当前参考帧的位置信息处于同一量化尺度下,根据变换后的位置信息得到第二运动矢量,将第二运动矢量变换为目标分辨下的目标运动矢量。

在一个实施例中,根据待编码帧的分辨率信息和第一分辨率信息确定第一矢量变换参数包括:根据待编码帧的分辨率信息和当前参考帧的分辨率信息确定第一矢量变换参数。根据第一矢量变换参数得到待编码帧中各个编码块对应的运动矢量包括:获取当前编码块对应的第一位置信息,获取当前编码块对应的目标参考块对应的第二位置信息;根据第一矢量变换参数、第一位置信息和第二位置信息计算得到当前编码块对应的目标运动矢量。

其中,当前编码块是输入视频帧中当前需要进行预测编码的编码块。目标参考块是参考帧中用于对当前编码块进行预测编码的图像块。当前编码块对应的第一位置信息可以用像素的坐标表示。当前编码块对应的第一位置信息可以包括当前编码块的全部像素对应的坐标,当前编码块对应的第一位置信息也可以是包括当前编码块的一个或多个像素的坐标。目标参考块对应的第二位置信息可以包括目标参考块的全部像素对应的坐标,目标参考块对应的第二位置信息也可以是包括目标参考块的一个或多个像素的坐标。例如,可以当前图像块的第一个像素点的坐标作为当前编码块的坐标值,以目标参考块的第一个像素点的坐标作为目标参考块的坐标值。

在一个实施例中,可以利用第一矢量变换参数对第一位置信息进行变换,得到对应的第一变换位置信息,根据第一变换位置信息与第二位置信息的差值得到目标运动矢量。或者可以利用第一矢量变换参数对第二位置信息进行变换,得到对应的第二变换位置信息,根据第一位置信息与第二位变换置信息的差值得到目标运动矢量。

在一个实施例中,第一矢量变换参数是待编码帧的分辨率与当前参考帧的分辨率信息中,大分辨率信息除以小分辨率信息得到的比例,其中,大分辨率信息对应的分辨率比小分辨率对应的分辨率大。第一矢量变换参数用于与待编码帧与当前参考帧中小分辨率信息的帧的位置信息进行变换。例如,待编码帧的分辨率为1200*1200像素,当前参考帧的分辨率为600*600像素,则大分辨率为1200*1200像素,小分辨率为600*600像素。第一矢量变换参数可以为2。假设第一位置信息为(6,8),第二位置信息为(3,3)。则目标运动矢量为(6,8)-(3*2,3*2)=(0,2)。本发明实施例中,通过对小分辨率信息的帧对应的位置信息进行变换,可以降低目标运动矢量的值,减少编码数据的数据量。

在一个实施例中,第一矢量变换参数是待编码帧的分辨率与当前参考帧的分辨率信息中,小分辨率信息除以大分辨率信息得到的比例,第一矢量变换参数用于对待编码帧与当前参考帧中,大分辨率信息的帧的位置信息进行变换。例如,待编码帧的分辨率为1200*1200像素,当前参考帧的分辨率为600*600像素,第一矢量变换参数可以为1/2。假设第一位置信息为(6,8),第二位置信息为(3,3)。则目标运动矢量为(6*1/2,8*1/2)-(3,3)=(0,1)。

本发明实施例中,通过第一矢量变换参数对位置信息进行变换,使得得到的位置信息处于同一量化尺度下,可以降低目标运动矢量的值,减少编码数据的数据量。例如,如图13所示,当前参考帧的分辨率为待编码帧的分辨率的2倍,当前编码块为像素(1、1)、(1、2)、(2、1)以及(2、2)组成的,对应的目标参考块为像素(4、2)、(4、3)、(5、2)以及(5、3)组成的,如果不进行变换,则目标运动矢量为(-3,-1),而如果在计算目标运动矢量时,将待编码帧中对应的位置信息乘以2,再计算目标运动矢量,则目标运动矢量为(-2,0),比(-3,-1)小。

在一个实施例中,根据待编码帧的分辨率信息和第一分辨率信息确定第一矢量变换参数包括:获取目标运动矢量单位分辨率信息;根据待编码帧的分辨率信息和目标运动矢量单位分辨率信息确定第一矢量变换参数。根据第一矢量变换参数得到待编码帧中各个编码块对应的目标运动矢量包括:根据当前编码块与对应的目标参考块的位移得到第一运动矢量;根据第一矢量变换参数以及第一运动矢量得到当前编码块对应的目标运动矢量。

其中,目标运动矢量单位分辨率信息是指与目标运动矢量的单位对应的目标分辨率对应的信息,例如可以是目标分辨率或者对应的下采样比例。目标运动矢量是以该分辨率下的矢量单位为标准计算的。由于输入视频序列的对应的各个待编码帧可能有一些分辨率与输入视频帧的原始分辨率相同,而另一些待编码帧的分辨率比输入视频帧的原始分辨率小,即视频序列中待编码帧的分辨率有多种,因此需要确定目标运动矢量的单位对应的分辨率。目标运动矢量的单位对应的分辨率可以是在编码前已经设定或者根据编码过程的参数得到,具体可以根据需要进行设置。

第一运动矢量是根据当前编码块与对应的目标参考块的位移得到的,目标参考块可以是从当前参考帧中获取的,也可以从对当前参考帧进行处理后得到的目标参考帧中获取的,当得到第一运动矢量后,可以将第一矢量变换参数以及第一运动矢量相乘,将得到的乘积作为目标运动矢量。比如,假设目标运动矢量单位对应的分辨率是原始分辨率,而待编码帧对应的下采样比例为2/1。由于目标运动矢量单位是原始分辨率,而第一运动矢量是在待编码帧的分辨率下计算得到的,因此需要对第一运动矢量进行变换,第一矢量变换参数等于2,当得到的第一运动矢量为(2,2,),则目标运动矢量为(4,4)。得到目标运动矢量后,可以根据目标运动矢量进行编码,例如可以对目标运动矢量以及当前编码块对应的预测残差进行编码,得到编码数据。

在一个实施例中,当目标参考块是从当前参考帧中获取的,可以理解,对于同一编码块,第一运动矢量可等于第二运动矢量。

在一个实施例中,目标运动矢量的单位对应的分辨率可以是输入视频帧对应的分辨率,即原始分辨率,或者目标运动矢量的单位对应的分辨率可以是待编码帧对应的分辨率。第一矢量变换参数可以是目标运动矢量单位对应的分辨率信息与待编码帧的分辨率信息的比例。例如,假设目标运动矢量单位对应的分辨率是原始分辨率,目标运动矢量单位对应的采样比例为1,待编码帧的分辨率的采样比例为2/1,则,第一矢量变换参数可以为2除以1等于2。或者,假设目标运动矢量单位对应的分辨率是原始分辨率,为900*900像素,目待编码帧的分辨率的采样比例为450*600像素,第一矢量变换参数可以包括两个,水平方向的第一矢量变换参数以及垂直方向的第一矢量变换参数。则水平方向的第一矢量变换参数为900/450=2,垂直方向的第一矢量变换参数为900/600=1.5。

在一个实施例中,可以根据进行编码的设备的计算能力得到目标运动矢量单位分辨率信息,例如,当进行编码的设备只能对整数进行运算或者当数值为小数时运算耗时长,则目标运动矢量单位对应的分辨率可以为输入视频帧对应的原始分辨率,当进行编码的设备能够快速进行小数的运算,目标运动矢量单位对应的分辨率可以为待编码帧对应的分辨率。

在一个实施例中,当待编码帧的分辨率信息和目标运动矢量单位分辨率信息一致时,第一矢量变换参数为1,第一运动矢量与目标运动矢量相同,因此,可以跳过步骤S802,将第一运动矢量作为目标运动矢量。当待编码帧的分辨率信息和目标运动矢量单位分辨率信息不一致时,则执行步骤S802。

本发明实施例中,当目标运动矢量的单位对应的分辨率为输入视频帧对应的分辨率,即原始分辨率,对于分辨率统一的视频序列,各个输入视频帧对应目标分辨率是一致的,可以保持目标运动矢量的统一性。当目标运动矢量的单位对应的分辨率为待编码视频帧对应的分辨率时,由于待编码帧的分辨率信息和目标运动矢量单位分辨率信息一致,因此不需要需对第一运动矢量进行变换,可以减少计算时间。

在一个实施例中,可以将表示目标运动矢量单位分辨率信息的标识信息添加至编码数据中,使解码端可以获取得到目标运动矢量对应的目标分辨率。如果不携带标识信息,则编码端与解码端可以约定目标运动矢量对应的目标分辨率。该标识信息用于表示目标运动矢量所对应的分辨率信息。标识信息在编码数据的添加位置可以是组级头信息、序列级头信息帧级头信息以及块级头信息中的一个或多个,其中块级头信息是指编码块对应的编码数据的头信息。标识信息在编码数据的添加位置可以根据目标运动矢量单位分辨率信息的作用范围确定。例如,若视频序列中矢量单位对应的分辨率一致,则添加位置可以是序列级头信息。具体的标志位的值所代表的分辨率信息可以根据需要设置。例如,当目标运动矢量单位分辨率信息对应的分辨率为原始分辨率时,对应的标志位MV_Scale_Adaptive为0,当目标运动矢量单位分辨率信息对应的分辨率为待编码帧对应的分辨率时,对应的标志位MV_Scale_Adaptive为1。

在一个实施例,如图14所示,步骤S808即根据当前参考帧对待编码帧进行编码,得到输入视频帧对应的编码数据包括:

步骤S1402,获取当前编码块对应的初始预测运动矢量。

其中,为了降低用于编码数据的比特数,可以对当前编码块的运动矢量进行预测,得到预测值,计算目标运动矢量与预测值的差值,得到运动矢量差值,对运动矢量差值进行编码。初始预测运动矢量用于对当前编码块的运动矢量进行预测。初始预测运动矢量的数量可以为一个或多个,具体可以根据需要进行设置。初始预测运动矢量的获取规则可以根据需要进行设置,由于当前编码块与其相邻编码块的往往具有空间相关性,因此可以将当前编码块对应的一个或多个相邻已编码块的对应的目标运动矢量值作为初始预测运动矢量。例如,可以将当前编码块中右上角以及左上角的相邻已编码块对应的第一运动矢量值作为初始预测运动矢量。或者,可以将当前编码块对应的目标参考块所对应的目标参考块的运动矢量值作为初始预测运动矢量。

步骤S1404,根据初始预测运动矢量对应的当前运动矢量单位分辨率信息和目标运动矢量单位分辨率信息,得到第二矢量变换系数。

其中,当前运动矢量单位分辨率信息是指与初始预测运动矢量的单位对应的当前分辨率对应的信息,例如可以是当前分辨率或者下采样比例。初始预测运动矢量的单位对应的分辨率是指该初始预测运动矢量的单位是以当前分辨率下的矢量单位为标准计算的,即是当前分辨率下的运动矢量。当初始预测运动矢量对应的当前运动矢量单位分辨率信息和目标运动矢量单位分辨率信息不同,则需要根据初始预测运动矢量对应的当前运动矢量单位分辨率信息和目标运动矢量单位分辨率信息得到第二矢量变换系数。第二矢量变换参数用于将初始预测运动矢量变换为目标分辨率下的运动矢量,第二矢量变换参数可以是目标运动矢量单位对应的分辨率信息与当前运动矢量单位分辨率信息的比例。例如,假设目标运动矢量单位对应的分辨率是200*200像素,当前运动矢量单位分辨率信息是100*100像素,则第一矢量变换参数可以是2。

步骤S1406,根据初始预测运动矢量和第二矢量变换系数得到当前编码块对应的目标预测运动矢量。

其中,得到第二矢量变换参数后,根据初始预测运动矢量与第二矢量变换系数进行运算,得到目标预测运动矢量,目标预测运动矢量是目标分辨率下的预测运动矢量。例如,当初始预测运动矢量为一个时,可以将初始预测运动矢量与第二矢量变换系数的乘积作为目标预测运动矢量。当初始预测运动矢量为多个时,可以对初始预测运动矢量进行计算,得到计算结果,根据计算结果与第二矢量变换系数得到目标运动矢量。计算结果可以是初始预测运动矢量中的最小值、平均值以及中位数值中的一种或多种。可以理解,根据初始预测运动矢量和第二矢量变换系数得到目标预测运动矢量的算法可以自定义,在解码端可以利用一致的自定义的算法计算得到相同的目标预测运动矢量。

步骤S1408,根据目标运动矢量和目标预测运动矢量得到运动矢量差。

其中,将运动目标矢量与目标预测运动矢量的差值作为运动矢量差,以根据运动矢量差进行编码,得到编码数据,减少编码数据的数据量。

本发明实施例中,通过对初始预测运动矢量进行变换,得到在目标分辨率下的目标预测运动矢量,使目标预测运动矢量以及目标运动矢量的单位是在匹配的量化尺度下的,因此得到的运动矢量差值小,减少了编码数据的数据量。

在一个实施例中,步骤S804即获取输入视频帧对应的处理方式包括:计算目标预测类型编码块在输入视频帧对应的前向编码视频帧中的比例;根据比例确定输入视频帧对应的处理方式。

其中,预测类型编码块是帧预测类型对应的编码块。目标预测类型的比例可以是帧内编码块对应的比例以及帧间编码块对应的比例中的一种或两种。目标预测类型编码块在输入视频帧对应的前向编码视频帧中的比例可以是该目标预测类型编码块与其他预测类型编码块的比例,也可以是该类型编码块与总编码块数量的比例。具体可以根据需要进行设置。例如可以获取前向编码视频帧中帧内编码块的第一数量,前向编码视频帧中帧间编码块的第二数量。根据第一数量和第二数量计算得到帧内编码块与帧间编码块的比例,或者统计前向编码视频帧的全部编码块的第三数量,根据第一数量和第三数量计算得到帧内编码块与第三数据量的比例。还可根据第二数量和第三数量计算得到帧间编码块与第三数据量的比例。

前向编码视频帧是指对输入视频帧进行编码之前已经编码的视频帧,获取的前向编码视频帧的具体数量可自定义,例如,前向编码视频帧可以是输入视频帧的前一个已编码的编码视频帧,前向编码视频帧也可以是输入视频帧的前3个已编码的编码视频帧。在计算得到目标预测类型编码块对应的在前向编码视频帧中的比例后,根据计算得到的比例确定输入视频帧对应的处理方式。若获取到的前向编码视频帧的数量为多个时,可以计算得到不同类型编码块对应的在每一个前向编码视频帧中的比例,根据各个比例进行加权计算得到总比例,再根据总比例和预设阈值确定输入视频帧对应的目标处理方式。其中,前向视频帧对应的权重可以与前向编码视频帧与输入视频帧的编码距离成负相关关系。

在一个实施例中,可以计算前向编码视频帧中帧内编码块在前向编码视频帧中的比例,当比例大于目标阈值时,确定处理方式为下采样处理方式。

对于帧内编码块对应的比例,可以是当该比例大于目标阈值时,确定输入视频帧对应的目标处理方式为下采样处理方式,否则确定视频帧对应的目标处理方式为全分辨率处理方式。如,当比例大于目标阈值时,确定输入视频帧对应的处理方式为下采样处理方式,否则确定视频帧对应的目标处理方式为全分辨率处理方式。

本发明实施例中,如果帧内编码块的比例大,则说明视频会相对比较复杂或者视频帧之间的相关度比较低,因此得到的预测残差比较大,因此更倾向于采用下采样处理方式进行编码,减少编码数据量。

其中目标阈值可根据输入视频帧对应的参考帧的处理方式进行确定。当输入视频帧对应的参考帧的处理方式为下采样处理方式时,获取第一预设阈值T1,将第一预设阈值T1作为目标阈值。同样地,当输入视频帧对应的参考帧的处理方式为全分辨率处理方式时,获取第二预设阈值T2,将第二预设阈值T2作为目标阈值。进一步地,在根据输入视频帧对应的参考帧的分辨率信息获取到目标阈值后,根据目标阈值和前向编码视频帧中帧内编码块在前向编码视频帧中的比例确定输入视频帧的处理方式。其中,当前向编码视频帧中帧内编码块在前向编码视频帧中的比例大于目标阈值时,确定输入视频帧对应的处理方式为下采样处理方式。

在一个实施例中,第二预设阈值大于第一预设阈值,这样,当当前参考帧对应的处理方式全分辨率处理方式时,输入视频帧更倾向于采用全分辨率处理方式,当当前参考帧为下采样处理方式时,输入视频帧更倾向于采用下采样处理方式。

在一个实施例中,如图15所示,获取输入视频帧之前,视频编码方法还包括:

步骤S1502,获取输入视频帧对应的输入视频序列,获取输入视频序列对应的目标视频序列编码模式,其中,目标视频序列编码模式包括恒定分辨率编码模式或者混合分辨率编码模式。

其中,输入视频序列可以包括多个输入视频帧。当目标视频序列编码模式为恒定分辨率编码模式时,输入视频序列的各个输入视频帧是在相同的分辨率例如全分辨率下进行编码的,当目标视频序列编码模式为混合分辨率编码模式时,则获取各个输入视频帧对应的处理方式,根据处理方式对输入视频帧进行处理,得到待编码帧,根据待编码帧进行编码,待编码帧的分辨率可以与输入视频帧的分辨率相同,也可以与输入视频帧的分辨率小,输入视频序列存在不同分辨率的待编码帧。因此当视频序列编码模式为混合分辨率编码模式时,执行上述实施例中提供的视频编码方法。

在一个实施例中,获取待编码视频序列对应的视频序列编码模式包括:获取当前环境信息,当前环境信息包括当前编码环境信息、当前解码环境信息中的至少一种信息;根据当前环境信息确定输入视频序列对应的目标视频序列编码模式。

其中,环境信息可以包括执行视频编码方法的设备的处理能力、执行视频解码方法的设备的处理能力以及当前应用场景信息中的一种或多种。处理能力可以用处理速度进行表示。例如,对于处理能力强的设备,由于处理速度快,对应的目标视频序列编码模式为全分辨率编码方式,当当前应用场景信息对应的当前应用场景为实时应用场景时,视频序列编码模式为混合分辨率编码模式。当当前应用场景信息对应的当前应用场景非实时应用场景时,视频序列编码模式为恒定分辨率编码模式。可以设置当前环境信息与视频序列编码模式对应的关系,当得到当前环境信息后,根据当前环境信息与视频序列编码模式的对应关系得到输入视频序列对应的目标视频序列编码模式。例如,可以设置视频编码方法的设备的处理速度与执行视频解码方法的设备的处理速度的平均值与视频序列编码模式的对应关系,当得到视频编码方法的设备的处理速度与执行视频解码方法的设备的处理速度后,计算平均值,根据平均值得到目标视频序列编码模式。当前应用场景是否为实时应用场景可以根据需要进行设置。例如,视频通话应用场景、游戏应用场景为实时应用场景,视频网站上的视频编码,离线视频的编码对应的应用场景可以为非实时应用场景。

步骤S1504,判断目标视频序列编码模式是否为混合分辨率编码模式。

如果是,进入步骤S802,如果否,进入步骤S1506。

步骤S1506,对输入视频序列的各个输入视频帧进行恒定分辨率编码。

其中,当视频序列编码模式为恒定分辨率编码模式时,对输入视频序列的各个输入视频帧进行恒定分辨率编码。

在一个实施例中,在待编码帧的分辨率下,对待编码帧进行编码得到所述输入视频帧对应的编码数据:将目标视频序列编码模式对应的视频序列编码模式信息添加至编码数据中。

其中,视频序列编码模式信息用于描述输入视频序列采用的编码模式,可以在编码数据中加入描述视频序列编码模式的标志位Sequence_Mix_Resolution_Flag,具体的标志位的值可以根据需要设置。视频序列编码模式信息在编码数据的添加位置可以是序列级头信息。例如,当Sequence_Mix_Resolution_Flag为1时,对应的目标视频序列编码模式可以为混合分辨率编码模式。当Sequence_Mix_Resolution_Flag为0时,对应的目标视频序列编码模式可以为恒定分辨率编码模式。

在一个实施例中,视频编码框架如图16所示。视频编码框架包括恒定分辨率编码框架以及混合分辨率编码框架,混合分辨率编码框架可以与图2中的编码框架对应。当得到输入视频序列后,在视频序列编码模式获取模块处对视频序列编码模式进行决策,当目标视频序列编码模式为混合分辨率编码模式,则采用混合分辨率编码框架进行编码,当目标视频序列编码模式为恒定分辨率编码模式时,利用图16的恒定分辨率编码框架进行恒定分辨率编码。其中恒定分辨率编码框架可以是目前的HEVC编码框架或者H.265编码框架等。

以下假设视频序列A包括三个输入视频帧:a、b以及c,对视频编码方法进行说明。

1、获取视频序列A对应的目标视频序列编码模式,由于当前环境是视频通话环境,目标视频序列编码模式为混合分辨率编码模式。

2、利用混合分辨率编码框架中的处理决策单元对第一个输入视频帧a进行决策,得到处理方式为下采样处理方式,下采样比例为2/1对a进行下采样处理,得到下采样后的视频帧a1,对a1进行帧内编码,得到a1对应的编码数据d1,并将a1对应的编码数据进行重建,得到对应的重建视频帧a2。

3、利用混合分辨率编码框架中的处理决策单元对第二个输入视频帧b进行决策,得到处理方式为下采样处理方式,采样比例为4/1。对b进行下采样,得到b1,对b1进行编码,得到b对应的编码数据,并在编码数据中携带下采样比例对应的采样比例信息以及处理方式对应的处理方式信息。

其中编码过程包括:由于b为帧间预测帧,因此需要将a2作为当前参考帧,由于b1与a2的分辨率不同,故需要对a2进行采样处理。确定a2的采样方式为直接分像素插值,运动估计精度为1/4,故像素插值精度为1/4*2=1/2,根据像素插值精度对a2进行1/2分像素插值,得到目标参考帧a3。计算b1中的当前编码块与目标参考帧中的目标参考块的第一运动矢量MV1,预测残差为p1。并获取得到目标分辨率为原始分辨率,因此,目标运动矢量为4MV1。计算得到初始预测矢量为MV2,初始预测矢量是在4/1下采样比例对应的分辨率下计算得到,因此,目标预测矢量为4MV2,故当前编码块对应的运动矢量差MVD1等于4MV1-4MV2。对MVD1以及p1进行变换、量化以及熵编码,得到编码数据。

4、利用混合分辨率编码框架中的处理决策单元对第三个输入视频帧c进行决策,得到处理方式为下采样处理方式,采样比例为8/1。对c进行下采样,得到c1,对c1进行编码,得到c对应的编码数据d2。

其中编码过程包括:由于c为帧间预测帧,对应的当前参考帧为对b的编码数据重建得到的重建视频帧b2,由于c1与b2的分辨率不同,故需要对b2进行采样处理。确定b2的采样方式为直接分像素插值,运动估计精度为1/4,故像素插值精度为1/4*2=1/2,根据像素插值精度对b2进行1/2分像素插值,得到目标参考帧b3。计算c1中的当前编码块与目标参考帧中的目标参考块的第一运动矢量MV3,预测残差为p2。并获取得到目标分辨率为原始分辨率,因此,目标运动矢量为8MV3。获取初始预测矢量为MV4,初始预测矢量是在4/1下采样比例对应的分辨率下计算得到,因此,目标预测矢量为4MV4,故当前编码块对应的运动矢量差MVD2等于8MV3-4MV4。对MVD2以及p2进行变换、量化以及熵编码,得到编码数据d3。

5、将d1、d2以及d3组成编码数据包,作为视频序列对应的编码数据,发送到接收终端,其中,视频序列对应的编码数据中携带了描述目标视频序列编码模式为混合分辨率编码模式的标志位。

如图17所示,在一个实施例中,提出了一种视频解码方法,该方法包括:

步骤S1702,获取待解码视频帧对应的编码数据。

其中,编码数据是指编码后得到的数据。解码端获取待解码视频帧对应的编码数据,通过对编码数据进行解码得到解码视频帧。

步骤S1704,当确定待解码视频帧对应的目标处理方式为下采样处理方式时,从编码数据中获取与待解码视频帧对应的下采样信息。

其中,通过获取编码数据中预设位置对应的处理方式标志位,当处理方式标志为下采样处理方式时,继续读取编码数据中下采样信息的标志位,通过下采样信息的标志位得到待解码视频帧对应的下采样信息。下采样信息包括下采样比例、下采样方法中的至少一种。

步骤S1706,根据待解码视频帧对应的下采样信息对编码数据进行解码,得到对应的解码视频帧。

其中,获取到下采样信息后,根据下采样信息对编码数据进行解码,得到对应的解码视频帧。如果下采样信息中包括有下采样比例,那么采用与下采样比例对应的上采样比例对编码数据进行解码得到对应的解码视频帧。如果下采样信息中包括下采样方法,则采用与下采样方法对应的上采样方法对编码数据进行解码得到对应的解码视频帧。其中,上采样方法和下采样方法采用的采样方法可以相同,也可以不同,比如,可以都采用双线性插值的采样方法,也可以一个采用双线性插值的采样方法,一个采用CNN的采样方法。

上述视频解码方法,通过获取待解码视频帧对应的编码数据,然后从编码数据中获取与待解码视频帧对应的下采样信息,根据待解码视频帧对应的下采样信息对编码数据进行解码,得到对应的解码视频帧。通过从编码数据中获取与待解码视频帧对应的下采样信息,然后根据下采样信息进行解码,提供了对自适应的选择下采样信息进行编码得到的编码数据的解码支持。

在一个实施例中,从编码数据中获取与待解码视频帧对应的下采样信息,包括:从编码数据中读取下采样信息,根据下采样信息在编码数据中的位置确定下采样信息对应的处理范围,处理范围为序列级范围或图像组级范围或帧级范围或编码块级范围;根据处理范围确定与待解码视频帧对应的下采样信息。

其中,下采样信息所在的位置决定了下采样信息所作用的处理范围。根据下采样信息的处理范围就可以确定待解码视频帧对应的下采样信息。如果下采样信息在序列头信息中,则下采样信息的处理范围为序列级范围,即该视频序列中所有视频帧对应的是同一个下采样信息。如果下采样信息在图像组的头信息中,那么下采样信息的处理范围为图像组级范围,该图像组内的视频帧对应的是同一个下采样信息。如果下采样信息在当前视频帧的头信息中,那么只有当前视频帧对应该下采样信息,如果下采样信息在视频帧中编码块的头信息中,那么只有当前编码块对应该下采样信息。

在一个实施例中,下采样信息包括:下采样比例;根据待解码视频帧对应的下采样信息对编码数据进行解码,得到对应的解码视频帧,包括:根据待解码视频帧对应的下采样比例对编码数据进行解码,得到待解码视频帧对应的重建视频帧;根据下采样比例对应的上采样比例对重建视频帧进行上采样处理得到解码视频帧。

其中,下采样信息中包括下采样比例。对重建视频帧进行上采样所选择的上采样比例与编码端的下采样比例互为倒数。首先,根据下采样比例对编码数据进行解码得到重建视频帧,由于重建视频帧的分辨率比较低,需要对重建视频帧进行上采样得到最终的解码视频帧。

在一个实施例中,根根据待解码视频帧对应的下采样比例对编码数据进行解码,得到待解码视频帧对应的重建视频帧,包括:获取待解码视频帧对应的当前参考帧;根据待解码视频帧对应的下采样比例以及当前参考帧对编码数据进行解码,得到待解码视频帧对应的重建视频帧。

其中,在进行编码时,需要根据参考帧进行编码,同样地,在解码时,也需要依据参考帧进行解码。获取待解码视频帧对应的当前参考帧,根据下采样比例确定当前参考帧所对应的分辨率信息,然后根据分辨率信息对当前参考帧进行采样(上采样或下采样)得到与待解码视频帧具有相同分辨率信息的目标参考帧,然后根据目标参考帧对编码数据进行解码得到重建视频帧,继而根据重建视频帧进行上采样得到解码视频帧。

在一个实施例中,根据待解码视频帧对应的下采样比例以及当前参考帧对编码数据进行解码,得到待解码视频帧对应的重建视频帧,包括:根据待解码视频帧对应的下采样比例确定与待解码视频帧对应的分辨率信息;根据分辨率信息对当前参考帧进行处理得到目标参考帧;根据目标参考帧对编码数据进行解码,得到待解码视频帧对应的重建视频帧。

其中,待解码视频帧的分辨率信息可以根据下采样比例确定的,由于下采样比例是相对于原始分辨率而言的,所以在已知原始分辨率的情况下,根据下采样比例就可以确定待解码视频帧的分辨率信息。由于待解码视频帧的当前参考帧需要与待解码视频帧的分辨率保持一致才能进行解码,所以需要根据分辨率信息对当前参考帧进行处理得到目标参考帧,目标参考帧即得到的与分辨率信息一致的参考帧,然后根据目标参考帧对编码数据进行解码,然后得到相应的重建视频帧,后续对重建视频帧根据下采样比例对应的上采样比例进行上采样处理即可得到解码视频帧。

在一个实施例中,下采样信息包括下采样方法;根据待解码视频帧对应的下采样信息对待解码视频帧进行解码,得到对应的解码视频帧,包括:对编码数据进行解码,得到待解码视频帧对应的重建视频帧;根据下采样方法对应的上采样方法对重建视频帧进行处理得到解码视频帧。

其中,下采样信息中包括下采样方法。对编码数据对解码得到重建视频帧后,根据获取到的下采样方法获取与之匹配的上采样方法,然后根据上采样方法对重建视频帧进行上采样处理得到解码视频帧。

如图18所示,在一个实施例中,提出了一种视频解码方法,具体可以包括以下步骤:

步骤S1802,获取待解码视频帧对应的编码数据。

其中,待解码视频帧是需要进行解码的视频帧。一个待解码视频序列可以包括多个待解码视频帧。待解码视频帧可以是实时获取的视频帧,也可以是预先存储的待解码视频序列中获取的视频帧。

步骤S1804,确定待编码视频帧对应的目标处理方式,当目标处理方式为下采样处理方式时,进入步骤S1805,若目标处理方式为全分辨率处理方式时,则进入步骤S1810。

其中,目标处理方式包括全分辨率处理方式和下采样处理方式。通过获取编码数据中预设位置对应的处理方式标志位来读取得到目标处理方式,当处理方式标志为下采样处理方式时,继续读取编码数据中下采样信息的标志位,通过下采样信息的标志位得到待解码视频帧对应的下采样信息。下采样信息包括下采样比例、下采样方法中的至少一种。当处理方式标志位为全分辨率处理方式时,则直接根据待编码视频帧的原始分辨率进行解码得到解码视频帧。

步骤S1805,从编码数据中获取与待解码视频帧对应的下采样信息,下采样信息包括:下采样比例,根据下采样比例确定与待解码视频帧对应的分辨率信息。

其中,分辨率信息是与分辨率相关的信息,可以是分辨率本身也可以下采样比例。待解码视频帧对应的分辨率信息可以是从编码数据中携带的,也可以是解码设备经过计算得到的。

在一个实施例中,编码数据中可以携带待解码视频帧对应的分辨率信息,例如可以携带待解码视频帧对应的分辨率或者下采样比例。

在一个实施例中,编码数据中可以携带处理方式信息,解码设备从编码数据中获取处理方式信息,根据处理方式信息得到待解码视频帧对应的分辨率信息。例如,编码数据中可以携带处理方式信息对应的处理方式为下采样处理方式,编码标准以及解码标准中确定了下采样比例均为2/1或者编码数据中携带对应的下采样比例,则获取得到的分辨率信息为下采样比例为2/1。

步骤S1806,根据待解码视频帧对应的分辨率信息对编码数据进行解码,得到待解码视频帧对应的重建视频帧。

其中,重建视频帧是解码重建得到的视频帧。可以理解,该重建视频帧对应的分辨率信息与编码过程中的待编码帧的分辨率信息是对应的。如果在编码的过程中图像信息不存在损失,则重建视频帧与待编码帧是相同的,如果在编码的过程中图像信息存在损失,则重建视频帧与待编码帧的差异与损失值对应。对编码数据进行解码是在待解码视频帧对应的分辨率信息进行的。解码可以包括预测、反变换、反量化以及熵解码中的至少一个,具体根据编码的过程确定。在解码时,根据待解码视频帧的分辨率信息对当前参考帧、待解码视频帧的各个待解码块对应的位置信息、当前参考帧的各个参考块对应的位置信息以及运动矢量中的至少一个进行处理,其中的处理方法与编码端进行编码时的处理方法是匹配的。例如可以获取待解码视频帧对应的当前参考帧,根据待解码视频帧对应的分辨率信息对当前参考帧进行处理,得到目标参考帧,根据携带的运动矢量信息获取目标参考块,根据目标参考块得到待解码块对应的预测值,并根据编码数据中的预测残差与预测值得到重建视频帧。

在一个实施例中,当编码端对位置信息进行了变换时,则在解码过程中获取得到相应的位置信息时,需要对该位置信息进行相应的变换,以保持编码端与解码端得到的目标参考块的一致性。

在一个实施例中,当编码数据中携带的运动矢量信息是目标运动矢量时,可以根据目标运动矢量单位分辨率信息与待解码视频帧对应的分辨率信息将目标运动矢量进行变换,得到在待解码视频帧对应的分辨率信息下的第一运动矢量,根据第一运动矢量得到待解码块对应的目标参考块。

在一个实施例中,当编码数据中携带的运动矢量信息是运动矢量差值时,获取当前待解码块对应的初始预测运动矢量,对各待解码块对应的运动矢量差值和初始预测运动矢量在相同分辨率下进行处理,得到相应待解码块所对应的、且在待解码视频帧的分辨率下的第一运动矢量,根据第一运动矢量得到待解码块对应的目标参考块。

其中,将运动矢量差值和初始预测运动矢量都变换到相同分辨率下对应的运动矢量。例如可以将初始预测运动矢量变换为目标分辨率下的目标预测运动矢量,根据目标预测运动矢量以及运动矢量差值得到目标运动矢量,再将目标运动矢量变换到待解码视频帧的分辨率下的第一运动矢量。也可以将初始预测运动矢量变换为待解码视频帧的分辨率下的预测运动矢量,将运动矢量差值变换到待解码视频帧的分辨率下的运动矢量差值,根据待解码视频帧的分辨率下的运动矢量差值以及待解码视频帧的分辨率下的预测运动矢量得到第一运动矢量。

步骤S1808,根据待解码视频帧对应的下采样信息对重建视频帧进行处理,得到对应的解码视频帧。

其中,对重建视频帧进行处理可以是采样处理,例如为上采样处理。对重建视频帧进行处理的方法与编码中对输入视频帧的处理方法可以是相对应的。例如,当输入视频帧的处理方式是下采样处理方式时,且下采样比例是2/1,则对重建视频帧进行上采样处理,上采样比例可以是1/2。

下采样信息包括:下采样比例和下采样方法。根据下采样比例对应的上采样比例,采用与下采样方法对应的上采样方法对重建视频帧进行上采样处理得到解码视频帧。

在一个实施例中,当解码端从编码数据的头信息中确定编码数据是通过下采样处理方式进行编码得到的,则解码端还可从头信息中获取所采用的下采样比例信息或下采样方法信息,并采用与下采样比例信息或下采样方法信息匹配的上采样比例、上采样方法对得到的重建视频帧进行上采样处理,得到解码视频帧。比如,下采样比例信息对应的采样比例为2/1,则解码端需要按照采样比例为1/2以及下采样方法信息匹配的上采样方法对重建视频帧进行上采样处理,得到解码视频帧。解码端可以从序列级头信息、组级头信息以及帧级头信息中的任一个获取到当前编码数据对应的下采样比例信息或下采样方法信息。

步骤S1810,获取待编码视频帧的原始分辨率信息,根据待解码视频帧的原始分辨率信息进行解码,得到对应的解码视频帧。

其中,当目标处理方式为全分辨率处理方式时,直接根据待解码视频帧的原始分辨率信息进行解码,得到解码视频帧。上述视频解码方法,获取待解码视频帧对应的编码数据,获取待解码视频帧对应的下采样信息,下采样信息包括下采样比例,根据待解码视频帧对应的下采样信息对编码数据进行解码,得到待解码视频帧对应的重建视频帧,根据待解码视频帧对应的下采样信息对重建视频帧进行处理,得到对应的解码视频帧。因此进行解码时,可以灵活地根据待解码视频帧对应的下采样信息进行解码,得到解码视频帧,在带宽有限的条件下,提高了视频解码得到的视频质量。

在一个实施例中,将待解码视频序列的待解码视频帧对应的重建视频帧都处理成相同的分辨率,例如将重建视频帧处理成与输入视频帧的原始分辨率相同的解码视频帧。

在一个实施例中,步骤S1806即根据待解码视频帧对应的分辨率信息对编码数据进行解码,得到待解码视频帧对应的重建视频帧包括:获取待解码视频帧对应的当前参考帧;根据待解码视频帧对应的分辨率信息以及当前参考帧对编码数据进行解码,得到待解码视频帧对应的重建视频帧。

其中,待解码视频帧对应的参考帧的个数可为一个或多个。例如当待解码视频帧为P帧,则对应的参考帧可以为1个。当待解码视频帧为B帧,则对应的参考帧可以为2个。待编码帧对应的参考帧可以是根据参考关系得到的,参考关系根据各个视频编解码标准可以不同。例如,对于一个视频图像组(GOP)中的第二个视频帧,为B帧,对应的待解码视频帧可以是该视频组的I帧以及视频组的第4帧。或者待解码视频帧对应的当前参考帧可以是其前向的已编码帧中的前一个或者两个。可以理解,当前参考帧与编码过程的当前参考帧是一致的。

在一个实施例中,获取待解码视频帧对应的当前参考帧包括:获取第二参考规则,第二参考规则包括待解码视频帧与当前参考帧的分辨率大小关系;根据第二参考规则获取待解码视频帧对应的当前参考帧。

其中,第二参考规则确定了待解码视频帧与当前参考帧的分辨率大小的限制关系,可以理解,为了保证编码过程中获取得到的当前参考帧与解码过程中获取得到的参考帧的一致性,第一参考规则与第二参考规则是一致的。第一参考规则、第二参考规则可以是在编解码标准中预先设置的。或者,在进行编码时,可以根据编码的应用场景、实时性要求等选择第一参考规则,并在编码数据中携带参考规则信息,解码器根据编码数据中的参考规则信息得到第二参考规则。分辨率大小关系包括待解码视频帧与参考帧相同以及不同的至少一种。当第二参考规则包括待解码视频帧与参考帧的分辨率相同时,第二参考规则还可以包括待解码视频帧与当前参考帧的分辨率的处理方式参考规则。例如处理方式参考规则可以包括全分辨处理方式的待解码视频帧可以参考全分辨率处理方式的当前参考帧以及下采样处理方式的待解码视频帧可以参考下采样处理方式的当前参考帧的一种或两种。当第二参考规则包括待解码视频帧与参考帧的分辨率不相同时,第二参考规则还可以包括待解码视频帧的分辨率大于当前参考帧的分辨率以及待解码视频帧的分辨率小于当前参考帧的分辨率的一种或两种。因此,第二参考规则可以包括原始分辨率待解码视频帧可以参考下采样分辨率参考帧、下采样分辨率待解码视频帧可以参考原始分辨率参考帧、原始分辨率待解码视频帧可以参考原始分辨率参考帧以及下采样分辨率待解码视频帧可以参考下采样分辨率的参考帧中的一种或多种。其中原始分辨率待解码视频帧是指该待解码视频帧的分辨率与对应的输入视频帧的分辨率相同,原始分辨率参考帧是指该参考帧的分辨率与其对应的输入视频帧的分辨率相同。下采样分辨率待解码视频帧是指该待解码视频帧对应的分辨率信息为下采样。下采样分辨率参考帧是指该参考帧对应的分辨率信息为下采样。得到第二参考规则后,根据第二参考规则待解码视频帧对应的当前参考帧,使得到的当前参考帧满足第二参考规则。

在一个实施例中,可以从当前参考帧中获取与待解码视频帧的待解码块对应的参考块,根据参考块对待解码块进行解码。也可以根据待解码视频帧的分辨率信息对当前参考帧进行处理,得到对应的目标参考帧,从目标参考帧中获取与待解码视频帧的待解码块对应的目标参考块,根据目标参考块对编码块进行解码,待解码视频帧对应的重建视频帧。

在一个实施例中,根据待解码视频帧对应的分辨率信息以及当前参考帧对编码数据进行解码,得到待解码视频帧对应的重建视频帧包括:根据待解码视频帧对应的分辨率信息对当前参考帧进行采样处理,得到对应的目标参考帧;根据目标参考帧对待解码视频帧进行解码,得到待解码视频帧对应的重建视频帧。

其中,根据携带的运动矢量信息从目标参考帧中获取目标参考块,根据目标参考块得到待解码块对应的预测值,并根据编码数据中的预测残差与预测值得到重建视频帧。

在一个实施例中,根据待解码视频帧对应的分辨率信息对当前参考帧进行采样处理,得到对应的目标参考帧包括:根据待解码视频帧的分辨率信息以及运动估计像素精度对当前参考帧进行处理,得到对应的目标参考帧。

在一个实施例中,根据待解码视频帧的分辨率信息以及运动估计像素精度对当前参考帧进行采样处理,得到对应的目标参考帧包括:根据待解码视频帧的分辨率信息以及运动估计像素精度计算得到像素插值精度;根据像素插值精度直接对当前参考帧进行分像素插值处理,得到对应的目标参考帧。

在一个实施例中,根据待解码视频帧的分辨率信息以及运动估计像素精度对当前参考帧进行采样处理,得到对应的目标参考帧包括:根据待解码视频帧的分辨率信息对当前参考帧进行采样处理,得到中间参考帧;根据进行运动估计的像素精度对中间参考帧进行分像素插值处理,得到目标参考帧。

其中,待解码视频帧与待编码视频帧的分辨率是一致的,得到的目标参考帧也是一致的,因此,根据待解码视频帧对应的分辨率信息对当前参考帧进行采样处理,得到对应的目标参考帧的方法与编码端中根据待编码帧的分辨率信息对当前参考帧进行采样处理,得到对应的目标参考帧是一致的,本发明实施例在此不再赘述。

在一个实施例中,解码端还可从编码数据的头信息中获取待解码视频帧对应的采样方式信息。具体可以从序列级头信息、组级头信息以及帧级头信息中的任一个获取到待解码视频帧对应的分像素插值方式信息。例如,当编码数据的帧级头信息中用于确定采样方式的标识位Pixel_Sourse_Interpolation为0时,表示输入视频帧对应的当前参考帧采用直接进行分像素插值处理,在Pixel_Sourse_Interpolation为1时,表示输入视频帧对应的当前参考帧采用采样处理后再分像素插值处理。解码端就可按照与编码数据中标识位所表示的分像素插值方式相同的方式对当前参考帧进行分像素插值处理得到目标参考帧,从而可依据目标参考帧对编码数据进行解码得到重建视频帧。

如图19所示,在一个实施例中,步骤S1806B即根据待解码视频帧对应的分辨率信息以及当前参考帧对编码数据进行解码,得到待解码视频帧对应的重建视频帧包括:

步骤S1902,根据待解码视频帧对应的分辨率信息以及第一分辨率信息确定第三矢量变换参数,第一分辨率信息包括目标运动矢量单位分辨率信息或者当前参考帧的分辨率信息。

其中,第三矢量变换参数用于对得到运动矢量的位置信息或者运动矢量进行变换。第三矢量参数可以是第一分辨率信息与待解码视频帧的分辨率信息之间的比例,第三矢量参数与第一矢量变换参数是对应的。当利用第三矢量变换参数对目标运动矢量进行变换时,可以将目标运动矢量变换到待解码视频帧对应的分辨率下,所对应的运动矢量,则第三矢量参数可以是第一矢量变换参数的倒数。当利用第三矢量变换参数对运动矢量对应的位置信息进行变换时,如果编码端中第一矢量变换参数用于对第一位置信息进行变换,则由于待解码块与编码块的位置信息相同,因此第三矢量变换参数与第一矢量变换参数相同。如果编码端中第一矢量变换参数用于对第二位置信息进行变换,由于根据目标运动矢量以及第一位置信息计算得到的位置值,是编码端中对根据第一矢量变换参数对第二位置信息进行变换后的位置值,因此第三矢量变换参数为第一矢量变换参数的倒数。

步骤S1904,根据编码数据获取待解码视频帧中各个待解码块对应的目标运动矢量。

其中,当编码数据中携带目标运动矢量时,从编码数据中读取目标运动矢量。当编码数据中携带的是运动矢量差时,则可以计算得到目标预测运动矢量,根据运动矢量差以及目标预测运动矢量得到目标运动矢量。

步骤S1906,根据第三矢量变换参数以及目标运动矢量得到待解码视频帧中各个待解码块对应的目标参考块。

其中,得到第三矢量变换参数后,根据第三矢量变换参数对得到的运动矢量或者运动矢量对应的位置信息进行变换,得到目标参考块对应的位置信息,从而得到目标参考块。

步骤S1908,根据目标参考块对编码数据进行解码,得到待解码视频帧对应的重建视频帧。

其中,得到目标参考块后,根据目标参考块的像素值以及编码数据中携带待解码块的预测残差,得到重建视频帧各个图像块的像素值,得到重建视频帧。

在一个实施例中,步骤S1902即根据待解码视频帧对应的分辨率信息以及第一分辨率信息确定第三矢量变换参数包括:根据待解码视频帧对应的分辨率信息和当前参考帧的分辨率信息确定第三矢量变换参数;步骤S1906即根据第三矢量变换参数以及目标运动矢量得到待解码视频帧中各个待解码块对应的目标参考块包括:获取当前待解码块对应的第一位置信息;根据第一位置信息、第三矢量变换参数以及目标运动矢量得到当前待解码块对应的目标参考块。

其中,可以根据第一位置信息、第三矢量变换参数以及目标运动矢量得到目标参考块对应的第二位置信息,根据第二位置信息得到目标参考块。由于编码与解码的对应性,如果编码端中第一矢量变换参数用于对第一位置信息进行变换,则由于待解码块与编码块的位置信息相同,因此第三矢量变换参数与第一矢量变换参数相同。如果编码端中第一矢量变换参数用于对第二位置信息进行变换,由于根据目标运动矢量以及第一位置信息计算得到的位置值,是编码端中根据第一矢量变换参数对第二位置信息进行变换后的位置值,因此第三矢量变换参数为第一矢量变换参数的倒数。

例如,待解码视频帧的分辨率为1200*1200像素,当前参考帧的分辨率为600*600像素。第一矢量变换参数用于对第二位置信息进行变换,第一矢量变换参数为2,则第三矢量变换参数为1/2。假设第一位置信息为(6,8),目标运动矢量为(0,2),则中间位置信息为(6,8)-(0,2)=(6,6),目标参考块对应的第二位置信息为(6*1/2,6*1/2)=(3,3)。

例如,待解码视频帧的分辨率为1200*1200像素,当前参考帧的分辨率为600*600像素,第一矢量变换参数用于对第一位置信息进行变换,第一矢量变换参数为1/2,则第三矢量变换参数为1/2。假设第一位置信息为(6,8),则目标运动矢量为(0,1),则第二位置信息为(6*1/2,8*1/2)-(0,1)=(3,3)。

在一个实施例中,步骤S1902即根据待解码视频帧对应的分辨率信息以及第一分辨率信息确定第三矢量变换参数包括:根据待解码视频帧对应的分辨率信息和目标运动矢量单位分辨率信息确定第三矢量变换参数;步骤S1906即根据第三矢量变换参数以及目标运动矢量得到待解码视频帧中各个待解码块对应的目标参考块包括:根据目标运动矢量以及第三矢量变换参数得到第一运动矢量;根据第一运动矢量获取当前待解码块对应的目标参考块。

其中,第三矢量变换参数是根据待解码视频帧对应的分辨率信息和目标运动矢量单位分辨率信息确定的,用于将目标运动矢量变换到带解码帧对应的分辨率下对应的第一运动矢量。当得到第三矢量变换参数后,可以将第三矢量变换参数以及目标运动矢量相乘,将得到的乘积作为第一运动矢量。可以理解,根据第三矢量变换参数以及目标运动矢量得到第一运动矢量这一过程与根据第一矢量变换参数以及第一运动矢量得到当前编码块对应的目标运动矢量是逆过程。例如如果编码端中,该待解码块对应的编码块第一矢量变换参数等于2。得到的第一运动矢量为(2,2),根据第一矢量变换参数与第一运动矢量为(2,2,)的乘积得到目标运动矢量为(4,4)。那么解码过程中,第三矢量变换参数为1/2,得到的目标运动矢量为(4,4),根据第三矢量变换参数1/2与目标运动矢量(4,4)的乘积得到第一运动矢量为(2,2)。

在一个实施例中,当编码数据中携带的是运动矢量差时,则根据编码数据获取待解码视频帧中各个待解码块对应的目标运动矢量包括:根据编码数据获取待解码视频帧中的当前待解码块对应的运动矢量差;

获取当前待解码块对应的初始预测运动矢量;根据初始预测运动矢量对应的当前运动矢量单位分辨率信息和目标运动矢量单位分辨率信息,得到第二矢量变换系数;根据初始预测运动矢量和第二矢量变换系数得到当前解码块对应的目标预测运动矢量;根据目标预测运动矢量以及运动矢量差得到目标运动矢量。

其中,由于解码与编码过程中待解码块与待编码块是对应的,初始预测运动矢量获取规则相同,因此当前待解码块对应的初始运动预测矢量与当前待编码块对应的初始预测运动矢量是一致的,得到目标预测运动矢量的方法可以参照编码过程中的方法,具体不再赘述。目标运动矢量是目标预测运动矢量以及运动矢量差的和。

在一个实施例中,还可以计算目标预测类型解码块在待解码视频帧对应的前向解码视频帧中的比例;根据比例确定待解码视频帧对应的处理方式;根据处理方式得到待解码视频帧对应的分辨率信息。

其中,目标预测类型解码块与目标预测类型编码块是对应的。前向解码视频帧是在待解码视频帧解码的视频帧,前向解码视频帧与前向编码视频帧也是对应的,因此编码端得到的目标预测类型编码块的比例与解码端得到的目标预测类型解码块的比例的计算方法以及结果也是一致的,得到目标预测类型解码块的比例的方法可以参照目标预测类型编码块的比例的方法,在此不再赘述。得到处理方式后,当处理方式为全分辨率处理方式,则对应的分辨率信息为原始分辨率。当处理方式为下采样处理方式,获取预设的下采样比例或者从编码数据中的头信息中获取下采样比例。

在一个实施例中,可以计算前向解码视频帧中帧内解码块在前向解码视频帧中的比例,当比例大于目标阈值时,确定处理方式为下采样处理方式。

对于帧内解码块对应的比例,可以是当该比例大于目标阈值时,确定待解码视频帧对应的目标处理方式为下采样处理方式,否则确定视频帧对应的目标处理方式为全分辨率处理方式。如,当比例大于目标阈值时,确定待解码视频帧对应的处理方式为下采样处理方式,否则确定视频帧对应的目标处理方式为全分辨率处理方式。

其中目标阈值可根据待解码视频帧对应的参考帧的处理方式进行确定。当待解码视频帧对应的参考帧的处理方式为下采样处理方式时,获取第一预设阈值T1,将第一预设阈值T1作为目标阈值。同样地,当待解码视频帧对应的参考帧的处理方式为全分辨率处理方式时,获取第二预设阈值T2,将第二预设阈值T2作为目标阈值。进一步地,在根据待解码视频帧对应的参考帧的分辨率信息获取到目标阈值后,根据目标阈值和前向解码视频帧中帧内解码块在前向解码视频帧中的比例确定待解码视频帧的处理方式。其中,当前向解码视频帧中帧内解码块在前向解码视频帧中的比例大于目标阈值时,确定待解码视频帧对应的处理方式为下采样处理方式。

在一个实施例中,获取待解码视频帧对应的编码数据之前,还包括:获取待解码视频帧对应的待解码视频序列,获取待解码视频序列对应的视频序列解码模式,其中,视频序列解码模式包括恒定分辨率编码模式或者混合分辨率编码模式;当视频序列解码模式为混合分辨率编码模式时,对待解码视频序列的各个待解码视频帧执行混合分辨率解码方法;当视频序列解码模式为恒定分辨率编码模式时,对待解码视频序列进行恒定分辨率解码。

其中,可以从编码数据中获取视频序列编码模式信息,根据视频序列编码模式信息得到视频序列解码模式。例如,当视频序列编码模式信息对应的视频序列编码模式为恒定分辨率编码模式时,对应的视频序列解码模式为恒定分辨率解码模式,在恒定分辨率解码模式中,视频序列的各个待解码视频帧的分辨率是一致的。当视频序列编码模式信息对应的视频序列编码模式为混合分辨率编码模式时,对应的视频序列解码模式为混合分辨率解码模式,

在一个实施例中,可从编码数据的头信息中确定待解码视频帧对应的解码框架。其中,解码端可以从编码数据对应的序列级头信息中,获取当前编码数据对应的输入视频帧序列中每个输入视频帧在被编码时所采用的编码框架,从而确定与之匹配的待解码视频帧的解码框架。比如,当编码数据的序列级头信息中用于确定所采用编码框架的标识位Sequence_Mix_Flag为0时,表示输入视频帧序列中各个输入视频帧在被编码时均采用恒定分辨率的编码框架,则解码端可采用恒定分辨率的解码框架对编码数据进行解码得到待解码视频帧对应的重建视频帧;在Sequence_Mix_Flag为1时,表示输入视频帧序列中各个输入视频帧在被编码时均采用混合分辨率的编码框架,解码端就可采用混合适应分辨率的解码框架对编码数据进行解码得到重建视频帧序列。

在一个实施例中,获取待解码视频序列对应的视频序列解码模式可以包括:获取当前环境信息,当前环境信息包括当前编码环境信息、当前解码环境信息中的至少一种信息;根据当前环境信息确定待解码视频序列对应的目标视频序列解码模式。

其中,解码端也可以根据与编码端计算视频序列编码模式的方法得到对应的目标视频序列解码模式,因此本发明实施例中根据当前环境信息确定目标视频序列解码模式与根据当前环境信息确定目标视频序列编码模式是一致的,在此不再赘述。

在一个实施例中,当前环境信息包括待解码视频序列对应的应用场景,可以根据应用场景获取待解码视频序列对应的视频序列解码模式。

以下以对视频序列A对应的编码数据进行解码为例,对视频解码方法进行说明。其中,假设输入视频帧a、b、c在解码端对应的待解码视频帧的名称分别为e、f以及g。

1、接收终端获取视频序列A对应的编码数据,从编码数据对应的序列头信息中获取得到目标视频序列编码模式为混合分辨率编码模式,因此,利用混合分辨率解码框架对编码数据进行解码。

2、混合分辨率解码框架的分辨率信息获取单元获取第一个待解码视频帧e对应的分辨率信息,可以理解,e对应的编码数据为对a1进行编码得到的数据。对e进行帧内解码,得到重建视频帧e1,由于e对应的分辨率信息为1/2,因此,可以对重建视频帧e1进行采样比例为1/2的上采样处理,得到解码视频帧e2。

3、混合分辨率解码框架的分辨率信息获取单元获取第二个待解码视频帧f对应的分辨率信息,可以理解,f对应的编码数据为对b1进行编码得到的数据。对f进行帧间解码,得到重建视频帧f1,由于f对应的分辨率信息为下采样比例为4/1,因此,可以对重建视频帧f1进行采样比例为1/4的上采样处理,得到解码视频帧f2。

解码过程如下:由于f为帧间预测帧,因此需要将重建视频帧e1作为当前参考帧,可以理解,e1与a2是相同的,对e1进行与a2相同的采样处理,得到e3,这里的e3与a3是相同的,为目标参考帧。从编码数据中获取得到当前待解码块对应的运动矢量差为MVD1,由于MVD1是目标分辨率即原始分辨率下的,因此需要将MVD1转换为f对应的分辨率下,因此可以得到MVD3为MVD1/4。获取初始预测矢量为MV2,由于初始预测矢量是在4/1下采样比例对应的分辨率下计算得到,与f对应的分辨率相同,故可以得到第一运动矢量为MV1等于MVD1/4+MV2。根据MV1获取得到目标参考块。根据目标参考块得到待解码块对应的预测值,将预测残差p1加上预测值重建得到重建视频帧f1对应的重建块。

4、混合分辨率解码框架的分辨率信息获取单元获取第三个待解码视频帧g对应的编码数据,可以理解,g对应的编码数据为对c1进行编码得到的数据。对g进行帧间解码,得到重建视频帧g1,由于g对应的分辨率信息为1/8,因此,可以对重建视频帧f1进行采样比例为1/8的上采样处理,得到解码视频帧g2。

解码过程如下:由于g为帧间预测帧,因此需要将重建视频帧f1作为当前参考帧,可以理解,f1与b2是相同的,对f1进行与b2相同的采样处理,得到f3,这里的f3与b3是相同的,为目标参考帧。从编码数据中获取得到当前待解码块对应的运动矢量差为MVD2,由于MVD2是目标分辨率即原始分辨率下的,因此需要将MVD2转换为g对应的分辨率下,因此可以得到MVD2为MVD1/8。获取初始预测矢量为MV4,由于初始预测矢量是在4/1下采样比例对应的分辨率下计算得到,需要变换为f对应的分辨率下,f对应的下采样比例为8/1,故可以得到第一运动矢量为MV3等于MVD2/8+MV4/2。根据MV3获取得到目标参考块。根据目标参考块得到待解码块对应的预测值,将预测残差p2加上预测值重建得到重建视频帧g1对应的重建块。

5、接收终端播放e2、f2以及g2。

如图20所示,在一个实施例中,提出了一种视频编码装置,该装置包括:

视频帧获取模块2002,用于获取输入视频帧;

确定模块2004,用于当确定输入视频帧对应的目标处理方式为下采样处理方式时,确定与所述输入视频帧对应的下采样信息;

编码模块2006,用于根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据;

添加模块2008,用于根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据。

在一个实施例中,所述添加模块还用于获取所述下采样信息对应的处理范围,所述处理范围为序列级范围或图像组级范围或帧级范围;将所述下采样信息添加至所述处理范围对应的头信息中。

在一个实施例中,所述下采样信息包括:下采样比例;所述确定模块还用于获取所述输入视频帧对应的当前量化参数估计值;获取所述输入视频帧对应的量化参数阈值;根据所述当前量化参数与所述量化参数阈值之间的差值确定与所述输入视频帧对应的下采样比例。

在一个实施例中,所述确定模块还用于获取候选差值范围与候选下采样比例之间的对应关系;确定所述当前量化参数与所述量化参数阈值之间的差值对应的目标差值范围;根据所述目标差值范围确定与所述输入视频帧对应的下采样比例。

在一个实施例中,所述确定模块还用于获取所述输入视频帧对应的视频帧信息,所述视频帧信息包括:编码信息、图像特征信息、前序视频帧的帧内编码块与帧间编码块的比值中的至少一种;根据所述视频帧信息确定与所述输入视频帧对应的量化参数阈值。

如图21所示,在一个实施例中,上述视频编码装置还包括:

处理方式获取模块2003,用于获取所述输入视频帧对应的处理方式,当所述处理方式为下采样处理方式时,通知确定模块确定与所述输入视频帧对应的下采样信息。

在一个实施例中,所述下采样信息包括下采样比例;所述确定模块还用于获取候选环境因素与候选下采样比例之间的对应关系;获取当前环境因素,根据所述候选环境因素与候选下采样比例之间的对应关系确定与当前环境因素对应的下采样比例。

在一个实施例中,所述下采样信息包括下采样方法;所述确定模块还用于所述确定与所述输入视频帧对应的下采样信息,包括:获取候选环境因素和候选下采样方法之间的对应关系;获取当前环境因素,根据所述候选环境因素与候选下采样方法之间的对应关系确定与当前环境因素对应的下采样方法。

在一个实施例中,所述下采样信息包括下采样比例;所述编码模块还用于根据所述下采样比例对所述输入视频帧进行处理得到待编码帧;获取所述待编码帧对应的当前参考帧;根据所述当前参考帧对所述待编码帧进行编码,得到输入视频帧对应的编码数据。

在一个实施例中,所述编码模块还用于获取待编码帧对应的下采样比例,根据所述下采样比例对所述当前参考帧进行处理得到目标参考帧;根据所述目标参考帧对所述待编码帧进行编码,得到所述输入视频帧对应的编码数据。

如图22所示,在一个实施例中,提出了一种视频解码装置,该装置包括:

编码数据获取模块2202,用于获取待解码视频帧对应的编码数据;

下采样信息获取模块2204,用于当确定待解码视频帧对应的目标处理方式为下采样处理方式时,从所述编码数据中获取与所述待解码视频帧对应的下采样信息;

解码模块2206,用于根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧。

在一个实施例中,所述下采样信息获取模块还用于从所述编码数据中读取所述下采样信息,根据所述下采样信息在所述编码数据中的位置确定所述下采样信息对应的处理范围,所述处理范围为序列级范围或图像组级范围或帧级范围;根据所述处理范围确定与所述待解码视频帧对应的下采样信息。

在一个实施例中,所述下采样信息包括:下采样比例;所述解码模块还用于根据所述待解码视频帧对应的下采样比例对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧;根据所述下采样比例对应的上采样比例对所述重建视频帧进行上采样处理得到解码视频帧。

在一个实施例中,所述解码模块还用于获取所述待解码视频帧对应的当前参考帧;根据所述待解码视频帧对应的下采样比例以及所述当前参考帧对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧。

在一个实施例中,所述解码模块还用于根据所述待解码视频帧对应的下采样比例确定与所述待解码视频帧对应的分辨率信息;根据所述分辨率信息对所述当前参考帧进行处理得到目标参考帧;根据所述目标参考帧对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧。

如图23所示,在一个实施例中,上述视频解码装置还包括:

读取模块2203,用于从所述编码数据中读取处理方式,当所述处理方式为下采样处理方式时,通知下采样信息获取模块从编码数据中获取与所述待解码视频帧对应的下采样信息的。

在一个实施例中,所述下采样信息包括下采样方法;所述解码模块还用于对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧;根据所述下采样方法对应的上采样方法对所述重建视频帧进行处理得到解码视频帧。

图24示出了一个实施例中计算机设备的内部结构图。该计算机设备具体可以是终端,也可以是服务器。如图24所示,该计算机设备包括通过系统总线连接的处理器、存储器和网络接口。其中,存储器包括非易失性存储介质和内存储器。该计算机设备的非易失性存储介质存储有操作系统,还可存储有计算机程序,该计算机程序被处理器执行时,可使得处理器实现视频编码方法及视频解码方法的至少一种方法。该内存储器中也可储存有计算机程序,该计算机程序被处理器执行时,可使得处理器执行视频编码方法及视频解码方法的至少一种方法。本领域技术人员可以理解,图24中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的计算机设备的限定,具体的计算机设备可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。

在一个实施例中,本申请提供的视频解码装置可以实现为一种计算机程序的形式,计算机程序可在如图24所示的计算机设备上运行。计算机设备的存储器中可存储组成该视频解码装置的各个程序模块,比如,图20所示的视频帧获取模块2002、确定模块2004、编码模块2006及添加模块2008。各个程序模块构成的计算机程序使得处理器执行本说明书中描述的本申请各个实施例的视频编码方法中的步骤。例如,图24所示的计算机设备可以通过如图20所示的视频编码装置中的视频帧获取模块2002获取输入视频帧;通过确定模块2004确定与所述输入视频帧对应的下采样信息;通过编码模块2006根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据;通过添加模块2008根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据。

在一个实施例中,本申请提供的视频解码装置可以实现为一种计算机程序的形式,计算机程序可在如图24所示的计算机设备上运行。计算机设备的存储器中可存储组成该视频解码装置的各个程序模块,比如,图22所示的编码数据获取模块2202、下采样信息获取模块2204和解码模块2206。各个程序模块构成的计算机程序使得处理器执行本说明书中描述的本申请各个实施例的视频解码方法中的步骤。例如,图24所示的计算机设备可以通过如图22所示的视频解码装置中的编码数据获取模块2202获取待解码视频帧对应的编码数据;通过下采样信息获取模块2204从所述编码数据中获取与所述待解码视频帧对应的下采样信息;通过解码模块2206根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧。

在一个实施例中,提出了一种计算机设备,包括存储器和处理器,所述存储器存储有计算机程序,所述计算机程序被所述处理器执行时,使得所述处理器执行以下步骤:获取输入视频帧;当确定输入视频帧对应的目标处理方式为下采样处理方式时确定与所述输入视频帧对应的下采样信息;根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据;根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据。

在一个实施例中,所述根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据,包括:获取所述下采样信息对应的处理范围,所述处理范围为序列级范围或图像组级范围或帧级范围;将所述下采样信息添加至所述处理范围对应的头信息中。

在一个实施例中,所述下采样信息包括:下采样比例;所述确定与所述输入视频帧对应的下采样信息,包括:获取所述输入视频帧对应的当前量化参数估计值;获取所述输入视频帧对应的量化参数阈值;根据所述当前量化参数与所述量化参数阈值之间的差值确定与所述输入视频帧对应的下采样比例。

在一个实施例中,所述根据所述当前量化参数与所述量化参数阈值之间的差值确定与所述输入视频帧对应的下采样比例,包括:获取候选差值范围与候选下采样比例之间的对应关系;确定所述当前量化参数与所述量化参数阈值之间的差值对应的目标差值范围;根据所述目标差值范围确定与所述输入视频帧对应的下采样比例。

在一个实施例中,所述获取所述输入视频帧对应的量化参数阈值,包括:获取所述输入视频帧对应的视频帧信息,所述视频帧信息包括:编码信息、图像特征信息、前序视频帧的帧内编码块与帧间编码块的比值中的至少一种;根据所述视频帧信息确定与所述输入视频帧对应的量化参数阈值。

在一个实施例中,在所述获取输入视频帧之后,所述计算机程序还使得所述处理器执行如下步骤:获取所述输入视频帧对应的处理方式,当所述处理方式为下采样处理方式时,进入确定与所述输入视频帧对应的下采样信息的步骤。

在一个实施例中,所述下采样信息包括下采样比例;所述确定与所述输入视频帧对应的下采样信息,包括:获取候选环境因素与候选下采样比例之间的对应关系;获取当前环境因素,根据所述候选环境因素与候选下采样比例之间的对应关系确定与当前环境因素对应的下采样比例。

在一个实施例中,所述下采样信息包括下采样方法;所述确定与所述输入视频帧对应的下采样信息,包括:获取候选环境因素和候选下采样方法之间的对应关系;获取当前环境因素,根据所述候选环境因素与候选下采样方法之间的对应关系确定与当前环境因素对应的下采样方法。

在一个实施例中,所述下采样信息包括下采样比例;所述根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据,包括:根据所述下采样比例对所述输入视频帧进行处理得到待编码帧;获取所述待编码帧对应的当前参考帧;根据所述当前参考帧对所述待编码帧进行编码,得到输入视频帧对应的编码数据。

在一个实施例中,所述根据所述当前参考帧对所述待编码帧进行编码,得到输入视频帧对应的编码数据,包括:获取待编码帧对应的下采样比例,根据所述下采样比例对所述当前参考帧进行处理得到目标参考帧;根据所述目标参考帧对所述待编码帧进行编码,得到所述输入视频帧对应的编码数据。

在一个实施例中,提出了一种计算机设备,包括存储器和处理器,所述存储器存储有计算机程序,所述计算机程序被所述处理器执行时,使得所述处理器执行以下步骤:获取待解码视频帧对应的编码数据;当确定待解码视频帧对应的目标处理方式为下采样处理方式时从所述编码数据中获取与所述待解码视频帧对应的下采样信息;根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧。

在一个实施例中,所述从所述编码数据中获取与所述待解码视频帧对应的下采样信息,包括:从所述编码数据中读取所述下采样信息,根据所述下采样信息在所述编码数据中的位置确定所述下采样信息对应的处理范围,所述处理范围为序列级范围或图像组级范围或帧级范围;根据所述处理范围确定与所述待解码视频帧对应的下采样信息。

在一个实施例中,所述下采样信息包括:下采样比例;所述根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧,包括:根据所述待解码视频帧对应的下采样比例对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧;根据所述下采样比例对应的上采样比例对所述重建视频帧进行上采样处理得到解码视频帧。

在一个实施例中,所述根根据所述待解码视频帧对应的下采样比例对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧,包括:获取所述待解码视频帧对应的当前参考帧;根据所述待解码视频帧对应的下采样比例以及所述当前参考帧对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧。

在一个实施例中,所述根据所述待解码视频帧对应的下采样比例以及所述当前参考帧对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧,包括:根据所述待解码视频帧对应的下采样比例确定与所述待解码视频帧对应的分辨率信息;根据所述分辨率信息对所述当前参考帧进行处理得到目标参考帧;根据所述目标参考帧对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧。

在一个实施例中,在所述从所述编码数据中获取与所述待解码视频帧对应的下采样信息之前,所述计算机程序还使得所述处理器执行如下步骤:从所述编码数据中读取处理方式,当所述处理方式为下采样处理方式时,进入从编码数据中获取与所述待解码视频帧对应的下采样信息的步骤。

在一个实施例中,所述下采样信息包括下采样方法;所述根据所述待解码视频帧对应的下采样信息对所述待解码视频帧进行解码,得到对应的解码视频帧,包括:对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧;根据所述下采样方法对应的上采样方法对所述重建视频帧进行处理得到解码视频帧。

在一个实施例中,提出了一种计算机可读存储介质,存储有计算机程序,所述计算机程序被处理器执行时,使得所述处理器执行以下步骤:获取输入视频帧;确定与所述输入视频帧对应的下采样信息;根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据;根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据。

在一个实施例中,所述根据所述下采样信息对应的处理范围将所述下采样信息添加至所述编码数据,包括:获取所述下采样信息对应的处理范围,所述处理范围为序列级范围或图像组级范围或帧级范围;将所述下采样信息添加至所述处理范围对应的头信息中。

在一个实施例中,所述下采样信息包括:下采样比例;所述确定与所述输入视频帧对应的下采样信息,包括:获取所述输入视频帧对应的当前量化参数估计值;获取所述输入视频帧对应的量化参数阈值;根据所述当前量化参数与所述量化参数阈值之间的差值确定与所述输入视频帧对应的下采样比例。

在一个实施例中,所述根据所述当前量化参数与所述量化参数阈值之间的差值确定与所述输入视频帧对应的下采样比例,包括:获取候选差值范围与候选下采样比例之间的对应关系;确定所述当前量化参数与所述量化参数阈值之间的差值对应的目标差值范围;根据所述目标差值范围确定与所述输入视频帧对应的下采样比例。

在一个实施例中,所述获取所述输入视频帧对应的量化参数阈值,包括:获取所述输入视频帧对应的视频帧信息,所述视频帧信息包括:编码信息、图像特征信息、前序视频帧的帧内编码块与帧间编码块的比值中的至少一种;根据所述视频帧信息确定与所述输入视频帧对应的量化参数阈值。

在一个实施例中,在所述获取输入视频帧之后,所述计算机程序还使得所述处理器执行如下步骤:获取所述输入视频帧对应的处理方式,当所述处理方式为下采样处理方式时,进入确定与所述输入视频帧对应的下采样信息的步骤。

在一个实施例中,所述下采样信息包括下采样比例;所述确定与所述输入视频帧对应的下采样信息,包括:获取候选环境因素与候选下采样比例之间的对应关系;获取当前环境因素,根据所述候选环境因素与候选下采样比例之间的对应关系确定与当前环境因素对应的下采样比例。

在一个实施例中,所述下采样信息包括下采样方法;所述确定与所述输入视频帧对应的下采样信息,包括:获取候选环境因素和候选下采样方法之间的对应关系;获取当前环境因素,根据所述候选环境因素与候选下采样方法之间的对应关系确定与当前环境因素对应的下采样方法。

在一个实施例中,所述下采样信息包括下采样比例;所述根据所述下采样信息对所述输入视频帧进行编码得到所述输入视频帧对应的编码数据,包括:根据所述下采样比例对所述输入视频帧进行处理得到待编码帧;获取所述待编码帧对应的当前参考帧;根据所述当前参考帧对所述待编码帧进行编码,得到输入视频帧对应的编码数据。

在一个实施例中,所述根据所述当前参考帧对所述待编码帧进行编码,得到输入视频帧对应的编码数据,包括:获取待编码帧对应的下采样比例,根据所述下采样比例对所述当前参考帧进行处理得到目标参考帧;根据所述目标参考帧对所述待编码帧进行编码,得到所述输入视频帧对应的编码数据。

在一个实施例中,提出了一种计算机可读存储介质,存储有计算机程序,所述计算机程序被处理器执行时,使得所述处理器执行以下步骤:获取待解码视频帧对应的编码数据;从所述编码数据中获取与所述待解码视频帧对应的下采样信息;根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧。

在一个实施例中,所述从所述编码数据中获取与所述待解码视频帧对应的下采样信息,包括:从所述编码数据中读取所述下采样信息,根据所述下采样信息在所述编码数据中的位置确定所述下采样信息对应的处理范围,所述处理范围为序列级范围或图像组级范围或帧级范围;根据所述处理范围确定与所述待解码视频帧对应的下采样信息。

在一个实施例中,所述下采样信息包括:下采样比例;所述根据所述待解码视频帧对应的下采样信息对所述编码数据进行解码,得到对应的解码视频帧,包括:根据所述待解码视频帧对应的下采样比例对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧;根据所述下采样比例对应的上采样比例对所述重建视频帧进行上采样处理得到解码视频帧。

在一个实施例中,所述根根据所述待解码视频帧对应的下采样比例对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧,包括:获取所述待解码视频帧对应的当前参考帧;根据所述待解码视频帧对应的下采样比例以及所述当前参考帧对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧。

在一个实施例中,所述根据所述待解码视频帧对应的下采样比例以及所述当前参考帧对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧,包括:根据所述待解码视频帧对应的下采样比例确定与所述待解码视频帧对应的分辨率信息;根据所述分辨率信息对所述当前参考帧进行处理得到目标参考帧;根据所述目标参考帧对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧。

在一个实施例中,在所述从所述编码数据中获取与所述待解码视频帧对应的下采样信息之前,所述计算机程序还使得所述处理器执行如下步骤:从所述编码数据中读取处理方式,当所述处理方式为下采样处理方式时,进入从编码数据中获取与所述待解码视频帧对应的下采样信息的步骤。

在一个实施例中,所述下采样信息包括下采样方法;所述根据所述待解码视频帧对应的下采样信息对所述待解码视频帧进行解码,得到对应的解码视频帧,包括:对所述编码数据进行解码,得到所述待解码视频帧对应的重建视频帧;根据所述下采样方法对应的上采样方法对所述重建视频帧进行处理得到解码视频帧。

本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,所述的程序可存储于一非易失性计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,本申请所提供的各实施例中所使用的对存储器、存储、数据库或其它介质的任何引用,均可包括非易失性和/或易失性存储器。非易失性存储器可包括只读存储器(ROM)、可编程ROM(PROM)、电可编程ROM(EPROM)、电可擦除可编程ROM(EEPROM)或闪存。易失性存储器可包括随机存取存储器(RAM)或者外部高速缓冲存储器。作为说明而非局限,RAM以多种形式可得,诸如静态RAM(SRAM)、动态RAM(DRAM)、同步DRAM(SDRAM)、双数据率SDRAM(DDRSDRAM)、增强型SDRAM(ESDRAM)、同步链路(Synchlink)DRAM(SLDRAM)、存储器总线(Rambus)直接RAM(RDRAM)、直接存储器总线动态RAM(DRDRAM)、以及存储器总线动态RAM(RDRAM)等。

以上实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。

以上所述实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对本申请专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。因此,本申请专利的保护范围应以所附权利要求为准。

当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1