1.本发明涉及数字信号处理技术领域,特别涉及一种运动矢量预测方法、装置、存储介质及终端。
背景技术:2.随着电子和通信技术的发展,数字视频已经深入日常生活,人们对视频的需求不断高涨。其中数字视频压缩技术被广泛应用于通信、个人计算机、广播电视、消费电子等领域,堪称数字媒体产业的最核心技术。以mpeg
‑
2为代表的信源编码标准获得了巨大的成功。目前,以h.264/avc和avs为代表的新一代信源编码标准出现了。avs标准是中国具有自主知识产权的信源编码标准。2006年2月,avs视频标准已经正式被批准为国家标准,进入了产业化推广的阶段。主流视频编码的核心算法是帧间预测。帧间预测的主要目的是去除视频序列中的时序冗余,它是混合视频编码框架中对性能影响最为重要的一个环节。其中运动矢量预测,是实现视频帧间预测高效率的关键技术。
3.当前的运动矢量预测具有较高的数据依赖性。首先,从最大编码单元的级别上来说,对于一个需要进行编码的最大编码单元来说,需要用到位于其左边的最大编码单元最右一列区域的最优模式信息,这就需要等待前一个最大编码单元的模式决策过程完成,当前的最大编码单元才能开始进行运动矢量预测。其次,在编码单元的级别上,对于一个最大编码单元内的多个编码单元来说,任何一个编码单元的运动矢量预测过程都需要等待邻近编码单元的模式决策完成才能进行。这两种数据依赖性都会导致硬件上常用的流水策略和并行计算策略无法使用,从而造成较大的时延,降低了编码效率。
技术实现要素:4.本技术实施例提供了一种运动矢量预测方法、装置、存储介质及终端。为了对披露的实施例的一些方面有一个基本的理解,下面给出了简单的概括。该概括部分不是泛泛评述,也不是要确定关键/重要组成元素或描绘这些实施例的保护范围。其唯一目的是用简单的形式呈现一些概念,以此作为后面的详细说明的序言。
5.第一方面,本技术实施例提供了一种运动矢量预测方法,方法包括:
6.划分最大编码单元生成多个编码单元;
7.根据最大编码单元得到左边最优模式信息与上边最优模式信息;
8.从多个编码单元中获取目标编码单元,确定目标编码单元中待代替的第一位置与第二位置集合;其中,第一位置位于目标编码单元的左侧,第二位置集合位于目标编码单元的正上方;
9.从左边最优模式信息中获取第一位置的水平位置上的模式信息,并将水平位置上的模式信息代替第一位置上的模式信息;
10.从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息,并将各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息;
11.根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量;
12.将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。
13.可选的,根据最大编码单元得到左边最优模式信息与上边最优模式信息,包括:
14.识别与最大编码单元相邻的左侧最大编码单元内最右方的信息;
15.获取左侧最大编码单元的前一帧编码单元,并从前一帧编码单元中获取与最右方的信息对应位置处的最优模式信息;
16.将最优模式信息代替左侧最大编码单元内最右方的信息,得到左边最优模式信息;
17.获取与最大编码单元相邻的正上方最大编码单元内最下方区域的信息,得到上边最优模式信息。
18.可选的,方法还包括:
19.继续执行从多个编码单元中获取目标编码单元的步骤,直到多个编码单元中各编码单元都进行了运动矢量预测时,停止遍历。
20.可选的,将预测运动矢量输入预先训练的线性模型中进行调整的公式为:
21.|pmvp
ver
|=|pmv’ver
|
×
k
ver
+b
ver
22.|pmvp
hor
|=|pmv’hor
|
×
k
hor
+b
hor
23.其中,|pmvp
ver
|为调整后的预测运动矢量的垂直分量的大小,
24.|pmvp’ver
|则为预测运动矢量的垂直分量的大小,k
ver
和b
ver
为预先训练的线性模型中微调垂直分量的参数;|pmvp
hor
|为调整后的预测运动矢量的水平分量的大小,|pmvp’hor
|则为预测运动矢量的水平分量的大小,k
hor
和b
hor
为预先训练的线性模型中微调水平分量的参数。
25.可选的,按照以下方式生成预先训练的线性模型,包括:
26.随机选择的多个不同量化步长;
27.在多个不同量化步长下编码多帧各个avs标准测试条件序列;
28.分别记录编码中各编码单元通过预设标准方法生成的预测运动矢量和上述任意一项方法产生的最终预测运动矢量,生成训练数据集;
29.创建线性模型;
30.采用训练数据集估计线性模型中的参数;
31.当参数估计结束后,生成预先训练的线性模型。
32.第二方面,本技术实施例提供了一种运动估计方法,其特征在于,方法包括:
33.获取根据上述任意一项的方法输出的目标编码单元的最终预测运动矢量;
34.根据目标编码单元的最终预测运动矢量生成搜索窗;
35.基于预设率失真优化公式从搜索窗中选取最优运动矢量;
36.计算最终预测运动矢量与最优运动矢量的差值,生成运动矢量差;
37.将运动矢量差写入当前码流。
38.可选的,预设率失真优化公式为:
39.j=sad+λr(mvd)
40.其中,sad为当前编码块与匹配块的像素绝对差值和,r(mvd)则为表示当前mvd所
需要的字节数,λ则为拉格朗日乘子。
41.第三方面,本技术实施例提供了一种运动矢量预测装置,装置包括:
42.编码单元划分模块,用于划分最大编码单元生成多个编码单元;
43.模式信息生成模块,用于根据最大编码单元得到左边最优模式信息与上边最优模式信息;
44.位置确定模块,用于从多个编码单元中获取目标编码单元,确定目标编码单元中待代替的第一位置与第二位置集合;其中,第一位置位于目标编码单元的左侧,第二位置集合位于目标编码单元的正上方;
45.第一模式信息代替模块,用于从左边最优模式信息中获取第一位置的水平位置上的模式信息,并将水平位置上的模式信息代替第一位置上的模式信息;
46.第二模式信息代替模块,用于从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息,并将各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息;
47.预测运动矢量计算模块,用于根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量;
48.最终预测运动矢量输出模块,用于将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。
49.第四方面,本技术实施例提供一种计算机存储介质,计算机存储介质存储有多条指令,指令适于由处理器加载并执行上述的方法步骤。
50.第五方面,本技术实施例提供一种终端,可包括:处理器和存储器;其中,存储器存储有计算机程序,计算机程序适于由处理器加载并执行上述的方法步骤。
51.本技术实施例提供的技术方案可以包括以下有益效果:
52.在本技术实施例中,运动矢量预测装置首先划分最大编码单元生成多个编码单元,再根据最大编码单元得到左边最优模式信息与上边最优模式信息,再从多个编码单元中获取目标编码单元,并确定目标编码单元中待代替的第一位置与第二位置集合,然后从左边最优模式信息中获取第一位置的水平位置上的模式信息代替第一位置的模式信息,再从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息,其次根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量,最后将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。由于本技术通过模式信息代替,使得当前编码单元不需要等待临近编码单元决策结束后才进行运动矢量预测,从而降低了当前编码单元对临近编码单元的依赖性,从而降低了编码时延,提升编码效率。
53.应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本发明。
附图说明
54.此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。
55.图1是本技术实施例提供的一种运动矢量预测方法的流程示意图;
56.图2是本技术实施例提供的一种时域最优模式信息替换示意图;
57.图3是本技术实施例提供的一种任意编码单元的邻近块模式信息替换方式示意图;
58.图4是本技术实施例提供的一种运动估计方法的流程示意图;
59.图5是本技术实施例提供的一种运动矢量预测装置的装置示意图;
60.图6是本技术实施例提供的一种终端的结构示意图。
具体实施方式
61.以下描述和附图充分地示出本发明的具体实施方案,以使本领域的技术人员能够实践它们。
62.应当明确,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其它实施例,都属于本发明保护的范围。
63.下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本发明相一致的所有实施方式。相反,它们仅是如所附权利要求书中所详述的、本发明的一些方面相一致的装置和方法的例子。
64.在本发明的描述中,需要理解的是,术语“第一”、“第二”等仅用于描述目的,而不能理解为指示或暗示相对重要性。对于本领域的普通技术人员而言,可以具体情况理解上述术语在本发明中的具体含义。此外,在本发明的描述中,除非另有说明,“多个”是指两个或两个以上。“和/或”,描述关联对象的关联关系,表示可以存在三种关系,例如,a和/或b,可以表示:单独存在a,同时存在a和b,单独存在b这三种情况。字符“/”一般表示前后关联对象是一种“或”的关系。
65.本技术提供了一种运动矢量预测方法、装置、存储介质及终端,以解决上述相关技术问题中存在的问题。本技术提供的技术方案中,由于本技术通过模式信息代替,使得当前编码单元不需要等待临近编码单元决策结束后才进行运动矢量预测,从而降低了当前编码单元对临近编码单元的依赖性,从而降低了编码时延,提升编码效率,下面采用示例性的实施例进行详细说明。
66.下面将结合附图1
‑
附图4,对本技术实施例提供的运动矢量预测方法进行详细介绍。该方法可依赖于计算机程序实现,可运行于基于冯诺依曼体系的运动矢量预测装置上。该计算机程序可集成在应用中,也可作为独立的工具类应用运行。其中,本技术实施例中的运动矢量预测装置可以为用户终端,包括但不限于:个人电脑、平板电脑、手持设备、车载设备、可穿戴设备、计算设备或连接到无线调制解调器的其它处理设备等。在不同的网络中用户终端可以叫做不同的名称,例如:用户设备、接入终端、用户单元、用户站、移动站、移动台、远方站、远程终端、移动设备、用户终端、终端、无线通信设备、用户代理或用户装置、蜂窝电话、无绳电话、个人数字处理(personal digital assistant,pda)、5g网络或未来演进网络中的终端设备等。
67.请参见图1,为本技术实施例提供了一种运动矢量预测方法的流程示意图。
68.如图1所示,本技术实施例的方法可以包括以下步骤:
69.s101,划分最大编码单元生成多个编码单元;
70.其中,lcu(largest coding unit,最大编码单元)可以看作是视频图像数据中的h.265/高效率视讯编码的处理单元,该处理单元类似h.264/高阶视讯编码中的宏区块(macroblock)。cu(coding unit,编码单元)是从lcu中分割出来的。
71.通常,一个最大编码单元按照多种划分方式可划分出多个编码单元。
72.在一种可能的实现方式中,在划分最大编码单元时,首先获取原始视频中的图像,然后对原始图像进行缩小化生成缩小的图像,再判断缩小的图像中最大编码单元对应的最佳分割方式,最后根据最佳分割方式将最大编码单元lcu进行分割,生成多个编码单元cu。
73.s102,根据最大编码单元得到左边最优模式信息与上边最优模式信息;
74.其中,左边最优模式信息是最大编码单元左侧相邻的lcu内最右侧区域中代替后的模式信息。上边最优模式信息是最大编码单元上方相邻的lcu内最下方区域中代替后的模式信息。
75.在本技术实施例中,生成左边最优模式信息与上边最优模式信息时,首先识别与最大编码单元相邻的左侧最大编码单元内最右方的信息,然后获取左侧最大编码单元的前一帧编码单元,并从前一帧编码单元中获取与最右方的信息对应位置处的最优模式信息,再将最优模式信息代替左侧最大编码单元内最右方的信息,得到左边最优模式信息,最后获取与最大编码单元相邻的正上方最大编码单元内最下方区域的信息,得到上边最优模式信息。
76.例如图2所示,图2是本技术提供的一种时域最优模式信息替换示意图,在运动矢量预测中图2中左侧最大编码单元最右方的信息是不可得到的,此时则利用左侧最大编码单元的前一帧中对应位置处lcu的最优模式信息代替左侧最大编码单元的最右方的信息,从而得到左边最优模式信息。与此同时,当前最大编码单元的相邻上方有正上方编码单元,正上方编码单元已经经过模式决策过程,最下方区域的信息(即模式信息)是可得到的,则直接获取后可得到上边最优模式信息。
77.s103,从多个编码单元中获取目标编码单元,确定目标编码单元中待代替的第一位置与第二位置集合;其中,第一位置位于目标编码单元的左侧,第二位置集合位于目标编码单元的正上方;
78.通常,基于步骤s102对当前最大编码单元进行时域信息替换后,可针对最大编码单元中划分出的每个编码单元进行运动矢量预测,以及每个编码单元进行运动矢量预测过程所需的邻近编码单元模式信息进行替换。
79.在一种可能的实现方式中,在完成时域信息替换后,需要从多个编码单元中获取某一个编码单元作为目标编码单元,该目标编码单元上包含了用于模式信息替代的多个位置,可分为第一位置与第二位置集合;其中,第一位置位于目标编码单元的左侧,第二位置集合位于目标编码单元的正上方,例如图3所示,当前最大编码单元中的目标编码单元上有模式信息替换的多个位置,包括位置b、位置d、位置a、位置c,位置b在目标编码单元的左侧,位置d、位置a、位置c在目标编码单元的正上方。
80.s104,从左边最优模式信息中获取第一位置的水平位置上的模式信息,并将水平位置上的模式信息代替第一位置上的模式信息;
81.例如图3所示,图3是任意编码单元的邻近块模式信息替换方式示意图,针对目标
编码单元中的位置b,采用相同水平位置上的时域替换模式信息进行相同位置的替换(箭头指向的位置b),并用模式信息中的运动矢量进行预测运动矢量的计算。
82.s105,从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息,并将各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息;
83.例如,针对目标编码单元中的位置d、位置a、位置c,用当前最大编码单元正上方最大编码单元中最下方位置的模式信息对所需的位置信息进行相同垂直位置的替换,并用该模式信息中的运动矢量进行预测运动矢量的计算。
84.s106,根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量;
85.s107,将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。
86.在本技术实施例中,在得到目标编码单元的预测运动矢量pmv后,记为pmv’,通过一个线性模型对pmv’的垂直和水平方向两个分量的大小进行一定的微调,让其更加接近于avs3标准计算方法中的pmv,微调后的pmv记为pmvp,则被运用于cu的me过程中。为微调的方式如下:
87.|pmvp
ver
|=|pmv’ver
|
×
k
ver
+b
ver
;
88.|pmvp
hor
|=|pmv’hor
|
×
k
hor
+b
hor
;
89.其中,|pmvp
ver
|为调整后的预测运动矢量的垂直分量的大小,
90.|pmvp’ver
|则为预测运动矢量的垂直分量的大小,k
ver
和b
ver
为预先训练的线性模型中微调垂直分量的参数;|pmvp
hor
|为调整后的预测运动矢量的水平分量的大小,|pmvp’hor
|则为预测运动矢量的水平分量的大小,k
hor
和b
hor
为预先训练的线性模型中微调水平分量的参数。
91.具体的,在生成预先训练的线性模型时,首先随机选择的多个不同量化步长,并在多个不同量化步长下编码多帧各个avs标准测试条件序列,然后分别记录编码中各编码单元通过预设标准方法生成的预测运动矢量和图1方法步骤产生的最终预测运动矢量,生成训练数据集,其次创建线性模型,再采用训练数据集估计线性模型中的参数,最后当参数估计结束后,生成预先训练的线性模型。
92.进一步地,继续执行从多个编码单元中获取目标编码单元的步骤,直到多个编码单元中各编码单元都进行了运动矢量预测时,停止遍历。
93.在本技术实施例中,运动矢量预测装置首先划分最大编码单元生成多个编码单元,再根据最大编码单元得到左边最优模式信息与上边最优模式信息,再从多个编码单元中获取目标编码单元,并确定目标编码单元中待代替的第一位置与第二位置集合,然后从左边最优模式信息中获取第一位置的水平位置上的模式信息代替第一位置的模式信息,再从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息,其次根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量,最后将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。由于本技术通过模式信息代替,使得当前编码单元不需要等待临近编码单元决策结束后才进行运动矢量预测,从而降低了当前编码单元对临近编码单元的依赖性,从而降低了编码时延,提升编码效率。
94.请参见图4,为本技术实施例提供了一种运动估计方法的流程示意图。如图4所示,
本技术实施例的方法可以包括以下步骤:
95.s201,获取图1中方法步骤输出的目标编码单元的最终预测运动矢量;
96.s202,根据目标编码单元的最终预测运动矢量生成搜索窗;
97.s203,基于预设率失真优化公式从搜索窗中选取最优运动矢量;
98.s204,计算最终预测运动矢量与最优运动矢量的差值,生成运动矢量差;
99.s205,将运动矢量差写入当前码流。
100.预设率失真优化公式为:
101.j=sad+λr(mvd)
102.其中,sad为当前编码块与匹配块的像素绝对差值和,r(mvd)则为表示当前mvd所需要的字节数,λ则为拉格朗日乘子。
103.在本技术实施例中,运动矢量预测装置首先划分最大编码单元生成多个编码单元,再根据最大编码单元得到左边最优模式信息与上边最优模式信息,再从多个编码单元中获取目标编码单元,并确定目标编码单元中待代替的第一位置与第二位置集合,然后从左边最优模式信息中获取第一位置的水平位置上的模式信息代替第一位置的模式信息,再从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息,其次根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量,最后将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。由于本技术通过模式信息代替,使得当前编码单元不需要等待临近编码单元决策结束后才进行运动矢量预测,从而降低了当前编码单元对临近编码单元的依赖性,从而降低了编码时延,提升编码效率。
104.下述为本发明装置实施例,可以用于执行本发明方法实施例。对于本发明装置实施例中未披露的细节,请参照本发明方法实施例。
105.请参见图5,其示出了本发明一个示例性实施例提供的运动矢量预测装置的结构示意图。该运动矢量预测装置可以通过软件、硬件或者两者的结合实现成为终端的全部或一部分。该装置1包括编码单元划分模块10、模式信息生成模块20、位置确定模块30、第一模式信息代替模块40、第二模式信息代替模块50、预测运动矢量计算模块60、最终预测运动矢量输出模块70。
106.编码单元划分模块10,用于划分最大编码单元生成多个编码单元;
107.模式信息生成模块20,用于根据最大编码单元得到左边最优模式信息与上边最优模式信息;
108.位置确定模块30,用于从多个编码单元中获取目标编码单元,确定目标编码单元中待代替的第一位置与第二位置集合;其中,第一位置位于目标编码单元的左侧,第二位置集合位于目标编码单元的正上方;
109.第一模式信息代替模块40,用于从左边最优模式信息中获取第一位置的水平位置上的模式信息,并将水平位置上的模式信息代替第一位置上的模式信息;
110.第二模式信息代替模块50,用于从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息,并将各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息;
111.预测运动矢量计算模块60,用于根据代替后的模式信息中运动矢量计算目标编码
单元的预测运动矢量;
112.最终预测运动矢量输出模块70,用于将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。
113.需要说明的是,上述实施例提供的运动矢量预测装置在执行运动矢量预测方法时,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将设备的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。另外,上述实施例提供的运动矢量预测装置与运动矢量预测方法实施例属于同一构思,其体现实现过程详见方法实施例,这里不再赘述。
114.上述本技术实施例序号仅仅为了描述,不代表实施例的优劣。
115.在本技术实施例中,运动矢量预测装置首先划分最大编码单元生成多个编码单元,再根据最大编码单元得到左边最优模式信息与上边最优模式信息,再从多个编码单元中获取目标编码单元,并确定目标编码单元中待代替的第一位置与第二位置集合,然后从左边最优模式信息中获取第一位置的水平位置上的模式信息代替第一位置的模式信息,再从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息,其次根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量,最后将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。由于本技术通过模式信息代替,使得当前编码单元不需要等待临近编码单元决策结束后才进行运动矢量预测,从而降低了当前编码单元对临近编码单元的依赖性,从而降低了编码时延,提升编码效率。
116.本发明还提供一种计算机可读介质,其上存储有程序指令,该程序指令被处理器执行时实现上述各个方法实施例提供的运动矢量预测方法。
117.本发明还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行上述各个方法实施例的运动矢量预测方法。
118.请参见图6,为本技术实施例提供了一种终端的结构示意图。如图6所示,终端1000可以包括:至少一个处理器1001,至少一个网络接口1004,用户接口1003,存储器1005,至少一个通信总线1002。
119.其中,通信总线1002用于实现这些组件之间的连接通信。
120.其中,用户接口1003可以包括显示屏(display)、摄像头(camera),可选用户接口1003还可以包括标准的有线接口、无线接口。
121.其中,网络接口1004可选的可以包括标准的有线接口、无线接口(如wi
‑
fi接口)。
122.其中,处理器1001可以包括一个或者多个处理核心。处理器1001利用各种借口和线路连接整个电子设备1000内的各个部分,通过运行或执行存储在存储器1005内的指令、程序、代码集或指令集,以及调用存储在存储器1005内的数据,执行电子设备1000的各种功能和处理数据。可选的,处理器1001可以采用数字信号处理(digital signal processing,dsp)、现场可编程门阵列(field
‑
programmable gate array,fpga)、可编程逻辑阵列(programmable logic array,pla)中的至少一种硬件形式来实现。处理器1001可集成中央处理器(central processing unit,cpu)、图像处理器(graphics processing unit,gpu)和调制解调器等中的一种或几种的组合。其中,cpu主要处理操作系统、用户界面和应用程序等;gpu用于负责显示屏所需要显示的内容的渲染和绘制;调制解调器用于处理无线通
信。可以理解的是,上述调制解调器也可以不集成到处理器1001中,单独通过一块芯片进行实现。
123.其中,存储器1005可以包括随机存储器(random access memory,ram),也可以包括只读存储器(read
‑
only memory)。可选的,该存储器1005包括非瞬时性计算机可读介质(non
‑
transitory computer
‑
readable storage medium)。存储器1005可用于存储指令、程序、代码、代码集或指令集。存储器1005可包括存储程序区和存储数据区,其中,存储程序区可存储用于实现操作系统的指令、用于至少一个功能的指令(比如触控功能、声音播放功能、图像播放功能等)、用于实现上述各个方法实施例的指令等;存储数据区可存储上面各个方法实施例中涉及到的数据等。存储器1005可选的还可以是至少一个位于远离前述处理器1001的存储装置。如图6所示,作为一种计算机存储介质的存储器1005中可以包括操作系统、网络通信模块、用户接口模块以及运动矢量预测应用程序。
124.在图6所示的终端1000中,用户接口1003主要用于为用户提供输入的接口,获取用户输入的数据;而处理器1001可以用于调用存储器1005中存储的运动矢量预测应用程序,并具体执行以下操作:
125.划分最大编码单元生成多个编码单元;
126.根据最大编码单元得到左边最优模式信息与上边最优模式信息;
127.从多个编码单元中获取目标编码单元,确定目标编码单元中待代替的第一位置与第二位置集合;其中,第一位置位于目标编码单元的左侧,第二位置集合位于目标编码单元的正上方;
128.从左边最优模式信息中获取第一位置的水平位置上的模式信息,并将水平位置上的模式信息代替第一位置上的模式信息;
129.从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息,并将各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息;
130.根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量;
131.将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。
132.在一个实施例中,处理器1001在执行根据最大编码单元得到左边最优模式信息与上边最优模式信息时,具体执行以下操作:
133.识别与最大编码单元相邻的左侧最大编码单元内最右方的信息;
134.获取左侧最大编码单元的前一帧编码单元,并从前一帧编码单元中获取与最右方的信息对应位置处的最优模式信息;
135.将最优模式信息代替左侧最大编码单元内最右方的信息,得到左边最优模式信息;
136.获取与最大编码单元相邻的正上方最大编码单元内最下方区域的信息,得到上边最优模式信息。
137.在本技术实施例中,运动矢量预测装置首先划分最大编码单元生成多个编码单元,再根据最大编码单元得到左边最优模式信息与上边最优模式信息,再从多个编码单元中获取目标编码单元,并确定目标编码单元中待代替的第一位置与第二位置集合,然后从左边最优模式信息中获取第一位置的水平位置上的模式信息代替第一位置的模式信息,再
从上边最优模式信息中获取第二位置集合中各第二位置的垂直位置上的模式信息代替各第二位置上的模式信息,其次根据代替后的模式信息中运动矢量计算目标编码单元的预测运动矢量,最后将预测运动矢量输入预先训练的线性模型中进行调整,输出目标编码单元的最终预测运动矢量。由于本技术通过模式信息代替,使得当前编码单元不需要等待临近编码单元决策结束后才进行运动矢量预测,从而降低了当前编码单元对临近编码单元的依赖性,从而降低了编码时延,提升编码效率。
138.本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,的程序可存储于计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,的存储介质可为磁碟、光盘、只读存储记忆体或随机存储记忆体等。
139.以上所揭露的仅为本技术较佳实施例而已,当然不能以此来限定本技术之权利范围,因此依本技术权利要求所作的等同变化,仍属本技术所涵盖的范围。