一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

并置运动矢量的推导的制作方法

2022-04-27 03:26:09 来源:中国专利 TAG:

并置运动矢量的推导
1.相关申请的交叉引用
2.根据适用的《专利法》和/或《巴黎公约》的规定,本技术及时要求于2019年9月13日提交的国际专利申请号pct/cn2019/105825的优先权和利益。出于法律上的所有目的,将前述申请的全部公开以引用方式并入本文,作为本技术公开的一部分。
技术领域
3.本技术文件涉及视频和图像的编码和解码技术。


背景技术:

4.数字视频在互联网和其他数字通信网络上占据最大的带宽使用。随着能够接收和显示视频的连接用户设备数量的增加,预计数字视频使用的带宽需求将持续增长。


技术实现要素:

5.描述了与数字视频处理相关的设备、系统和方法,特别是与视频处理中并置运动矢量相关的设备、系统和方法。所描述的方法可以应用于现有的视频编解码标准(例如,高效视频编解码(hevc))和未来的视频编解码标准(例如,多功能视频编解码(vvc))或编解码器。
6.在一个示例性方面,公开了一种视频处理方法。该方法包括:进行第一确定,该第一确定关于视频的视频块的并置视频块是使用帧间编解码模式还是非帧间编解码模式编解码的;基于该第一确定进行第二确定,该第二确定关于并置视频块的运动矢量的可用性或者推导并置视频块的运动矢量的模式;以及基于该第二确定执行视频块与视频的编解码表示之间的转换。
7.在另一示例性方面,公开了一种视频处理方法。该方法包括:对于视频的视频块与视频的编解码表示之间的转换,基于该视频块的并置视频块的参考索引或者参考列表来确定一个或多个并置运动矢量;以及基于该确定执行转换。
8.在又一示例性方面,公开了一种视频处理方法。该方法包括:对于视频的当前块与该视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中,权重用来确定用于确定该预测块的两个初始预测块的加权和;以及,使用该预测块执行转换,其中,推导预测块包括:将权重应用于分别属于两个初始预测块的两个中间预测样点以推导最终预测样点;以及,对最终预测样点执行右移运算以转换该最终预测样点的比特深度,其中,右移运算是pbsample》》(shift1 3)),其中,pbsample表示最终预测样点,shift1设置为等于max(2,14-bitdepth);以及,基于该最终预测样点确定预测块。
9.在又一示例性方面,公开了一种视频处理方法。该方法包括:对于视频的当前块与视频的编解码表示之间的转换,推导根据双向编码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定该预测块的两个初始预测块的加权和;以及,使用该预
测块执行转换,其中,推导预测块包括:将权重应用于分别属于两个初始预测块的两个中间预测样点以推导最终预测样点;以及,将偏移添加到最终预测样点,其中,该偏移是1《《(shift1 2),其中,shift1设置为等于max(2,14-bitdepth);以及基于该最终预测样点确定预测块。
10.在又一示例性方面,公开了一种视频处理方法。该方法包括:对于视频的当前块与视频的编解码表示之间的转换,根据规则推导当前块的merge模式运动矢量预测器的运动矢量差;以及基于该推导执行转换,其中,规则规定是否将运动矢量差裁剪到与用于裁剪运动矢量的范围相同的范围。
11.在又一示例性方面,公开了一种视频处理方法。该方法包括:对于视频的当前块与视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定该预测块的两个初始预测块的加权和,其中,权重中的至少一个属于权重表,其中,根据规则组织权重表;以及使用预测块执行转换,其中,该规则规定权重表的条目非单调递增。
12.在又一示例性方面,公开了一种视频处理方法。该方法包括:对于视频的当前块与视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定该预测块的两个初始预测块的加权和,其中,权重中的至少一个属于权重表,并且该权重表选自多个权重表;以及使用预测块执行转换。
13.在又一示例性方面,公开了一种视频处理方法。该方法包括:对于视频的当前块与视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定预测块的两个初始预测块的加权和;以及使用预测块执行转换,其中,推导预测块包括:将中间预测样点转换为第一比特深度;将权重应用于中间预测样点以推导最终预测样点;以及将最终预测样点转换为第二比特深度。
14.在又一示例性方面,公开了一种视频处理方法。该方法包括:对于视频的当前块与视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中第一权重和第二权重用来确定用于确定预测块的两个初始预测块的加权和,其中,第一权重和第二权重中的至少一个包括在权重表中,其中根据规则组织该权重表;以及使用预测块执行转换,其中,该规则规定权重表是不对称的。
15.在又一示例方面,上述方法可以由包括处理器的视频编码器装置实施。
16.在又一示例方面,这些方法可以体现为处理器可执行指令的形式并存储在计算机可读程序介质上。
17.将在本技术文件中进一步描述这些以及其他方面。
附图说明
18.图1示出了示例编码器的框图。
19.图2示出了67种帧内预测模式的示例。
20.图3示出了水平和垂直遍历扫描的示例。
21.图4示出了用于时域merge候选的运动矢量缩放的示例。
22.图5示出了时域merge候选的候选位置。
23.图6a示出了由可选时域运动矢量预测(atmvp)使用的空域邻近块的示例。
24.图6b示出了推导子cu运动场的示例。
25.图7示出了merge运动矢量差(mmvd)模式的搜索点的示例。
26.图8是视频处理方法的示例流程图。
27.图9是视频处理方法的另一示例流程图。
28.图10是视频处理方法的又一示例流程图。
29.图11是视频处理方法的又一示例流程图。
30.图12是视频处理方法的又一示例流程图。
31.图13是视频处理方法的又一示例流程图。
32.图14a和图14b是用于实施本技术文件中描述的视觉媒体解码或视觉媒体编码技术的硬件平台的示例框图。
33.图15a-图15e是基于所公开技术的一些实施例的视频处理示例方法的流程图。
具体实施方式
34.本技术文件提供了能够由图像或视频比特流的解码器使用的各种技术,以提高解压缩或解码的数字视频或图像的质量。为了简洁起见,术语“视频”在本文中用于包括图片序列(传统上称为视频)和单个图像两者。此外,视频编码器也能够在编码过程期间实施这些技术,以便重构用于进一步编码的解码帧。
35.在本技术文件中使用章节标题以易于理解,并且不将实施例和技术限于对应章节。如此,来自一个章节的实施例能够与其他章节的实施例组合。
36.1.概要
37.本技术文件涉及视频编解码技术。具体地,其与并置运动矢量和其他编解码工具有关。其可以应用于现有的视频编解码标准,如hevc,也可以应用于待定的标准(多功能视频编解码)。其也可能适用于未来的视频编解码标准或视频编解码器。
38.2.初步讨论
39.视频编解码标准主要是通过开发公知的itu-t和iso/iec标准而发展起来的。itu-t开发了h.261和h.263,iso/iec开发了mpeg-1和mpeg-4视觉,并且两个组织联合开发了h.262/mpeg-2视频、h.264/mpeg-4高级视频编解码(avc)和h.265/hevc标准。自h.262以来,视频编解码标准基于混合视频编解码结构,其中采用了时域预测加变换编解码。为了探索hevc以外的未来视频编解码技术,vceg和mpeg于2015年联合成立了联合视频探索团队(jvet)。此后,jvet采纳了许多新方法并将其引入到名为联合探索模型(jem)的参考软件中。在2018年4月,成立了vceg(q6/16)与iso/iec jtc1 sc29/wg11(mpeg)之间的联合视频专家小组(jvet),以致力于目标在于相比hevc降低50%比特率的vvc标准。
40.2.1颜色空间和色度子采样
41.颜色空间(也称为颜色模型(或颜色系统))是抽象数学模型,其简单地将颜色范围描述为数字元组,通常为3或4个值或颜色分量(例如,rgb)。基本上来说,颜色空间是对坐标系和子空间的精细化。
42.对于视频压缩,最常用的颜色空间是ycbcr和rgb。
43.ycbcr、y

cbcr或y pb/cb pr/cr(也写为ycbcr或y'cbcr)是在视频和数字摄影系统中用作颜色图像管道一部分的颜色空间族。y

是亮度分量,cb和cr是蓝差和红差色度分
量。y

(带质数)与y不同,y是光亮度(luminance),这意味着光强度是基于伽马校正的rgb原色进行非线性编码的。
44.色度子采样是利用人类视觉系统对色差的敏感度低于对于光亮度的敏感度,通过对色度信息实施比亮度信息更低分辨率来编码图像的实践。
45.2.1.1 4:4:4
46.三个y'cbcr分量中的每个具有相同的采样率,因此没有色度子采样。此方案有时用在高端胶片扫描仪和电影后期制作。
47.2.1.2 4:2:2
48.以亮度一半的采样率对两个色度分量进行采样:水平色度分辨率减半。这使得在几乎没有视觉差异的情况下将未压缩视频信号的带宽减少三分之一。
49.2.1.3 4:2:0
50.在4:2:0中,水平采样比4:1:1增加了一倍,但是由于在此方案中cb和cr通道仅在每个交替线上采样,垂直分辨率降低一半。因此数据速率是相同的。cb和cr在水平和垂直方向上均以2的因子进行子采样。4:2:0方案有三种变体,具有不同的水平和垂直选址(site)。
51.·
在mpeg-2中,cb和cr在水平上共同选址。cb和cr设置在垂直方向的像素之间(间隙选址)。
52.·
在jpeg/jfif、h.261和mpeg-1中,cb和cr是间隙设置的,位于交替亮度样点中间。
53.·
在4:2:0dv中,cb和cr在水平方向上共同选址。在垂直方向上,它们在交替线上共同选址。
54.2.2典型视频编解码器的编解码流程
55.图1示出了vvc的编码器框图的示例,其包含三个环路滤波块:去方块滤波器(df)、采样自适应偏移(sao)和alf。与使用预定义滤波器的df不同,sao和alf利用当前图片的原始样点,分别通过添加偏移和通过应用有限脉冲响应(fir)滤波器来降低原始样点与重构样点之间的均方误差,而编解码侧信息信令通知偏移和滤波器系数。alf位于每个图片的最后处理阶段,并且可以被看作是试图捕获和修复由先前阶段创建的伪像的工具。
56.2.3具有67种帧内预测模式的帧内模式编解码
57.为了捕获自然视频中出现的任意边缘方向,定向帧内模式的数目从hevc中使用的33扩展到65。在图2中用红色虚线箭头描绘附加的定向模式,并且平面模式和dc模式保持不变。这些更密集的定向帧内预测模式适用于所有块尺寸以及亮度和色度的帧内预测。
58.如图2所示,常规角度帧内预测方向在顺时针方向上定义为从45度到-135度。在vtm6中,一些常规角度帧内预测模式被自适应地替换为非正方形块的广角帧内预测模式。被替换的模式使用原始方法被信令通知,并在解析后重新映射到广角模式的索引。帧内预测模式的总数不变,即67,并且帧内模式编解码不变。
59.在hevc中,每个帧内编解码块均具有正方形形状,并且其每一侧的长度是2的幂。因此,不需要除法运算即可使用dc模式生成帧内预测器。在vvc中,块能够具有矩形形状,这通常需要对每个块使用除法运算。为了避免用于dc预测的除法运算,仅将较长的一侧用于计算非正方形块的平均值。
60.2.4帧间预测
61.对于每个帧间预测cu,运动参数包括运动矢量、参考图片索引和参考图片列表使用索引,以及用于生成帧间预测样点的vvc的新编解码特征所需的附加信息。能够显式或隐式地信令通知运动参数。当使用跳过模式编解码cu时,cu与一个pu相关联并且没有显著的残差系数、没有编解码的运动矢量增量或参考图片索引。规定了merge模式,其中从邻近cu获得当前cu的运动参数,包括空域和时域候选,以及vvc中引入的附加调度。merge模式能够应用于任何帧内预测cu,而不仅仅适用于跳过模式。merge模式的替代方案是运动参数的显式传输,其中对于每个cu,显示地信令通知运动矢量、每个参考图片列表的对应参考图片索引和参考图片列表使用标志以及其他所需信息。
62.2.5帧内块复制(ibc)
63.帧内块复制(ibc)是scc上hevc扩展中采用的工具。众所周知,它显著地提高了屏幕内容材料的编解码效率。由于ibc模式被实施为块级别的编解码模式,在编码器处执行块匹配(bm)以找到每个cu的最佳块矢量(或运动矢量)。此处,块矢量用于指示从当前块到参考块的位移,参考块已经在当前图片内重建。ibc编解码的cu的亮度块矢量是整数精度。色度块矢量也取整到整数精度。当与amvr组合时,ibc模式能够在1像素和4像素运动矢量精度之间切换。ibc编解码的cu被视为除帧内或帧间预测模式之外的第三预测模式。ibc模式适用于宽度和高度均小于或等于64个亮度样点的cu。
64.在编码器侧,针对ibc执行基于哈希(hash)的运动估计。编码器对宽度或高度不大于16个亮度样点的块执行rd检查。对于非merge模式,首先使用基于哈希的搜索来执行块矢量搜索。如果哈希搜索未返回有效候选,则执行基于块匹配的局部搜索。
65.在基于哈希的搜索中,当前块和参考块之间的哈希密钥匹配(32比特crc)被扩展到所有允许的块尺寸。当前图片中每个位置的哈希密钥计算是基于4
×
4子块。对于较大尺寸的当前块,当所有4
×
4子块的所有哈希密钥与对应参考位置中的哈希密钥匹配时,确定哈希密钥与参考块的哈希密钥匹配。如果发现多个参考块的哈希密钥与当前块的哈希密钥匹配,则计算每个匹配的参考块的块矢量成本,并选择具有最小成本的那个。
66.在块匹配搜索中,搜索范围设置为覆盖先前和当前ctu两者。
67.在cu级,以标志信令通知ibc模式,并且可以信令通知为ibc amvp模式或ibc跳过/merge模式,如下所示:
68.–
ibc跳过/merge模式:merge候选索引用于指示来自邻近候选ibc编解码块的列表中哪些块矢量用来预测当前块。merge列表包括空域、hmvp和成对候选。
69.–
ibc amvp模式:以与运动矢量差相同的方式编解码块矢量差。块矢量预测方法使用两个候选作为预测器,一个来自左邻近,另一个来自上邻近(如果ibc编解码)。当其中一个邻近不可用时,将使用默认块矢量作为预测器。信令通知标志以指示块矢量预测器索引。
70.2.6调色板模式
71.对于调色板模式信令通知,将调色板模式编解码为用于编解码单元的预测模式,即,用于编解码单元的预测模式可以是mode_intra、mode_inter、mode_ibc和mode_plt。如果使用了调色板模式,则cu中的像素值由代表性颜色值的小集合表示。该集合表示为调色板。对于具有接近调色板颜色的值的像素,信令通知调色板索引。对于具有调色板之外的值的像素,用逸出符号表示该像素,并直接信令通知量化的像素值。
72.为了解码调色板编码块,解码器需要解码调色板颜色和索引。调色板颜色由调色
板表描述,并由调色板表编解码工具进行编码。对于每个cu信令通知逸出标志以指示当前cu中是否存在逸出符号。如果存在逸出符号,则增加一个调色板表,并且将最后一个索引分配给逸出模式。cu中所有像素的调色板索引组成调色板索引映射,并由调色板索引映射编解码工具进行编码。
73.为了编解码调色板表,维护调色板预测器。在预测器重置为0的每个条带的起始,对预测器进行初始化。对于调色板预测器中的每个条目,信令通知重用标志以指示其是否是当前调色板的一部分。使用零游程长度编解码发送重用标志。此后,使用阶数为0的指数哥伦布码信令通知新调色板条目的数目。最后,信令通知新调色板条目的分量值。在对当前cu进行编码之后,将使用当前调色板来更新调色板预测器,并且先前调色板预测器中未在当前调色板中重新使用的条目将添加到新调色板预测器的末尾,直到达到允许的最大尺寸为止(调色板填充)。
74.为了编解码调色板索引映射,使用如图3所示的水平和垂直遍历扫描来编解码索引。使用palette_transpose_flag在比特流中显式地信令通知扫描顺序。
75.使用两个主要的调色板样点模式编解码调色板索引:“index”和“copy_above”。当使用水平扫描时除第一行外或者当使用垂直扫描时除第一列外,或者当前一模式是“copy_above”时,使用标志信令通知模式。在“copy_above”模式下,复制上一行中样点的调色板索引。在“index”模式下,显示地信令通知调色板索引。对于“index”和“copy_above”模式两者,均信令通知运行值,该运行值规定使用相同模式编解码的像素数目。
76.索引映射的编码顺序如下:首先,信令通知用于cu的索引值的数目。在这之后,使用截断二进制编解码来信令通知整个cu的实际索引值。索引数目和索引值均以旁路模式进行编码。这将索引相关的旁路bin成组。然后,以交错方式信令通知调色板模式(index或copy_above)和运行。最后,将对应于整个cu的逸出样点的分量逸出值成组在一起,并以旁路模式进行编解码。在信令通知索引值之后,信令通知附加语法元素last_run_type_flag。此语法元素与索引数目一起消除信令通知对应于块中最后一次运行的运行值的需要。
77.在vtm5.0中,为i条带启用了双重树,其区分了亮度和色度的编解码单元分割。因此,在此提议中,将调色板分别应用于亮度(y分量)和色度(cb和cr分量)上。如果禁用双重树,则与hevc调色板相同地将调色板联合应用于y、cb、cr分量。
78.2.7 vvc中的时域运动矢量预测(tmvp)
79.在推导此时域merge候选的过程中,基于属于并置参考图片的并置cu来推导缩放运动矢量。在条带标头中显式地信令通知用于推导并置cu的参考图片列表。如图4中的虚线所图示的获得用于时域merge候选的缩放运动矢量,该运动矢量是使用poc距离(tb和td)从并置cu的运动矢量缩放得来的,其中tb定义为当前图片的参考图片与当前图片之间的poc差,并且td定义为并置图片的参考图片与并置图片之间的poc差。将时域merge候选的参考图片索引设置为等于0。
80.如图5所描绘的,在候选c0和c1之间选择时域候选的位置。如果c0位置的cu不可用、是帧内编解码的、或者在ctu的当前行之外,则使用c1位置。否则,位置c0用于推导时域merge候选。
81.2.8 vvc中基于子块的时域运动矢量预测(sbtmvp)
82.vtm支持基于子块的时域运动矢量预测(sbtmvp)方法。类似于hevc中的时域运动
矢量预测(tmvp),sbtmvp使用并置图片中的运动场来改善当前图片中cu的运动矢量预测和merge模式。tmvp所使用的相同并置图片也用于sbtvmp。sbtmvp在以下两个主要方面不同于tmvp:
83.1.tmvp预测cu级的运动,但是sbtmvp预测子cu级的运动;
84.2.鉴于tmvp从并置图片中的并置块取得时域运动矢量(并置块是相对于当前cu的右下块或中心块),而sbtmvp在从并置图片取得时域运动信息之前应用运动位移,其中运动位移是从当前cu的空域邻近块之一的运动矢量取得的。
85.在图6中图示了sbtvmp过程。sbtmvp以两个步骤来预测当前cu内的子cu的运动矢量。在第一步骤中,检查图6a中的空域邻近a1。如果a1具有将并置图片用作其参考图片的运动矢量,则将此运动矢量选择为要应用的运动位移。如果未识别到此种运动,则将运动位移设置为(0,0)。
86.在第二步骤中,如图6b所示,应用(即,将其添加到当前块的坐标中)步骤1中标识的运动位移,以从并置图片获得子cu级运动信息(运动矢量和参考索引)。图6b中的示例假设将运动位移设置为块a1的运动。然后,对于每个子cu,将在并置图片中其对应块(覆盖中心样点的最小运动网格)的运动信息用于推导该子cu的运动信息。在标识了并置子cu的运动信息之后,以与hevc的tmvp过程类似的方式将其转换为当前子cu的运动矢量和参考索引,其中应用时域运动缩放来将时域运动示例的参考图片与当前cu的参考图片对齐。
87.在vtm6中,将包含sbtvmp候选和仿射merge候选的基于组合子块的merge列表用于信令通知基于子块的merge模式。通过序列参数集(sps)标志启用/禁用sbtvmp模式。如果启用了sbtmvp模式,则添加sbtmvp预测器作为基于子块的merge候选列表的第一条目,其后是仿射merge候选。在sps中信令通知基于子块的merge列表的尺寸,并且在vtm6中,基于子块的merge列表的最大允许尺寸是5。
88.在sbtmvp中使用的子cu尺寸固定为8
×
8,并且与仿射merge模式一样,sbtmvp模式仅适用于宽度和高度均大于或等于8的cu。
89.附加sbtmvpmerge候选的编码逻辑与其他merge候选的编码逻辑相同,即,对于p或b条带中的每个cu,执行附加rd检查以决定是否使用sbtmvp候选。
90.工作草案中tmvp和sbtmvp的描述
91.8.5.2.11时域亮度运动矢量预测的推导过程
92.此过程的输入是:
[0093]-相对于当前图片的左上亮度样点的当前亮度编解码块的左上样点的亮度位置(xcb,ycb),
[0094]-变量cbwidth,规定亮度样点中当前编解码块的宽度,
[0095]-变量cbheight,规定亮度样点中当前编解码块的高度,
[0096]-参考索引refidxlx,其中x为0或1。
[0097]
此过程的输出是:
[0098]-具有1/16的分数采样精度的运动矢量预测mvlxcol,
[0099]-可用性标志availableflaglxcol。
[0100]
变量currcb规定在亮度位置(xcb,ycb)的当前亮度编解码块。
[0101]
按照如下推导变量mvlxcol和availableflaglxcol:
[0102]-如果slice_temporal_mvp_enabled_flag等于0或(cbwidth*cbheight)小于或等于32,则将mvlxcol的两个分量设置为等于0,并将availableflaglxcol设置为等于0。
[0103]-否则,(slice_temporal_mvp_enabled_flag等于1),适用以下顺序步骤:
[0104]
1.按照如下推导右下并置运动矢量和右下边界样点位置:
[0105]
xcolbr=xcb cbwidth
ꢀꢀ
(8-421)
[0106]
ycolbr=ycb cbheight
ꢀꢀ
(8-422)
[0107]
rightboundarypos=subpic_treated_as_pic_flag[subpicidx]?
[0108]
subpicrightboundarypos:pic_width_in_luma_samples-1(8-423)
[0109]
botboundarypos=subpic_treated_as_pic_flag[subpicidx]?
[0110]
subpicbotboundarypos:pic_height_in_luma_samples-1(8-424)
[0111]

如果ycb》》ctblog2sizey等于ycolbr》》ctblog2sizey、ycolbr小于或等于botboundarypos,并且xcolbr小于或等于rightboundarypos,则适用以下:
[0112]-变量colcb规定亮度编解码块,该亮度编解码块在由colpic规定的并置图片内覆盖由((xcolbr》》3)《《3,(ycolbr》》3)《《3)指定的修改位置。
[0113]-将亮度位置(xcolcb,ycolcb)设置为等于相对于由colpic规定的并置图片的左上亮度样点的由colcb规定的并置亮度编解码块的左上样点。
[0114]-调用条款8.5.2.12中规定的并置运动矢量的推导过程,其中以设置为等于0的currcb、colcb、(xcolcb,ycolcb)、refidxlx和sbflag作为输入,并将输出分配给mvlxcol和availableflaglxcol。
[0115]-否则,将mvlxcol的两个分量设置为等于0并将availableflaglxcol设置为等于0。
[0116]
2.当availableflaglxcol等于0时,按照如下推导中心并置运动矢量:
[0117]
xcolctr=xcb (cbwidth》》1)
ꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀ
(8-425)
[0118]
ycolctr=ycb (cbheight》》1)
ꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀ
(8-426)
[0119]

变量colcb规定亮度编解码块,该亮度编解码块在由colpic规定的并置图片内覆盖由((xcolctr》》3)《《3,(ycolctr》》3)《《3)指定的修改位置。
[0120]

亮度位置(xcolcb,ycolcb)设置为等于相对于由colpic规定的并置图片的左上亮度样点的由colcb规定的并置亮度编解码块的左上样点。
[0121]

调用条款8.5.2.12中规定的并置运动矢量的推导过程,其中以设置为等于0的currcb、colcb、(xcolcb,ycolcb)、refidxlx和sbflag作为输入,并将输出分配给mvlxcol和availableflaglxcol。
[0122]
8.5.2.12并置运动矢量的推导过程
[0123]
此过程的输入是:
[0124]

变量currcb,规定当前编解码块,
[0125]

变量colcb,规定由colpic规定的并置图片内的并置编解码块,
[0126]

亮度位置(xcolcb,ycolcb),规定相对于由colpic规定的并置图片的左上亮度样点的由colcb规定的并置亮度编解码块的左上样点;
[0127]

参考索引refidxlx,其中x为0或1,
[0128]

指示子块时域merge候选的标志sbflag。
[0129]
此过程的输出是:
[0130]

具有1/16的分数样点精度的运动矢量预测mvlxcol,
[0131]

可用性标志availableflaglxcol。
[0132]
变量currpic规定当前图片。
[0133]
将阵列predflagl0col[x][y]、mvl0col[x][y]和refidxl0col[x][y]分别设置为等于由colpic规定的并置图片的predflagl0[x][y]、mvdmvrl0[x][y]和refidxl0[x][y],并且将阵列predflagl1col[x][y]、mvl1col[x][y]和refidxl1col[x][y]分别设置为等于由colpic规定的并置图片的predflagl1[x][y]、mvdmvrl1[x][y]和refidxl1[x][y]。
[0134]
按照如下推导变量mvlxcol和availableflaglxcol:
[0135][0136][0137]
2.8.1以帧间块编解码colcb时并置运动矢量的推导
[0138]

如果sbflag等于0,则将availableflaglxcol设置为等于1,并且适用以下:
[0139]-如果predflagl0col[xcolcb][ycolcb]等于0,则将mvcol、refidxcol和listcol分别设置为等于mvl1col[xcolcb][ycolcb]、refidxl1col[xcolcb][ycolcb]和l1。
[0140]-否则,如果predflagl0col[xcolcb][ycolcb]等于1并且predflagl1col[xcolcb][ycolcb]等于0,则将mvcol、refidxcol和listcol分别设置为等于mvl0col[xcolcb][ycolcb]、refidxl0col[xcolcb][ycolcb]和l0。
[0141]-否则(predflagl0col[xcolcb][ycolcb]等于1并且predflagl1col[xcolcb][ycolcb]等于1),则进行以下分配:
[0142]-如果nobackwardpredflag等于1,则将mvcol、refidxcol和listcol分别设置为等于mvlxcol[xcolcb][ycolcb]、refidxlxcol[xcolcb][ycolcb]和lx。
[0143]-否则,将mvcol、refidxcol和listcol分别设置为等于mvlncol[xcolcb][ycolcb]、refidxlncol[xcolcb][ycolcb]和ln,其中n为collocated_from_l0_flag的值。
[0144]

否则(sbflag等于1),适用以下:
[0145]-如果predflaglxcol[xcolcb][ycolcb]等于1,则将mvcol、refidxcol和listcol分别设置为等于mvlxcol[xcolcb][ycolcb]、refidxlxcol[xcolcb][ycolcb]和lx,并且将availableflaglxcol设置为等于1。
[0146]-否则(predflaglxcol[xcolcb][ycolcb]等于0),适用以下:
[0147]-如果nobackwardpredflag等于1并且predflaglycol[xcolcb][ycolcb]等于1,则将mvcol、refidxcol和listcol分别设置为mvlycol[xcolcb][ycolcb]、refidxlycol[xcolcb][ycolcb]和ly,y等于!x,其中x是调用此过程的x的值。将availableflaglxcol设置为等于1。
[0148]-否则,将mvlxcol的两个分量设置为等于0,并将availableflaglxcol设置为等于0。
[0149]

当availableflaglxcol等于真(true)时,按照以下推导mvlxcol和
availableflaglxcol:
[0150]-如果longtermrefpic(currpic,currcb,refidxlx,lx)不等于longtermrefpic(colpic,colcb,refidxcol,listcol),则将mvlxcol的两个分量设置为等于0,并将availableflaglxcol设置为等于0。
[0151]-否则,将变量availableflaglxcol设置为等于1,将refpiclist[listcol][refidxcol]设置为包含由colpic规定的并置图片中的编解码块colcb的条带的参考图片列表listcol中具有参考索引refidxcol的图片,并适用以下:
[0152]
colpocdiff=diffpicordercnt(colpic,refpiclist[listcol][refidxcol])(8-427)
[0153]
currpocdiff=diffpicordercnt(currpic,refpiclist[x][refidxlx])(8-428)
[0154]-调用条款8.5.2.15中规定的用于并置运动矢量的时域运动缓冲区压缩过程,其中以mvcol作为输入,并以修改后的mvcol作为输出。
[0155]-如果refpiclist[x][refidxlx]是长期参考图片,或者colpocdiff等于currpocdiff,则按照如下推导mvlxcol:
[0156]
mvlxcol=mvcol
ꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀ
(8-429)
[0157]-否则,按照如下将mvlxcol推导为运动矢量mvcol的缩放版本:
[0158]
tx=(16384 (abs(td)》》1))/td
ꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀ
(8-430)
[0159]
distscalefactor=clip3(-4096,4095,(tb*tx 32)》》6)
ꢀꢀꢀ
(8-431)
[0160]
mvlxcol=clip3(-131072,131071,(distscalefactor*mvcol 128-(distscalefactor*mvcol》=0))》》8))
ꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀ
(8-432)
[0161]
其中按照如下推导td和tb:
[0162]
td=clip3(-128,127,colpocdiff)
ꢀꢀ
(8-433)
[0163]
tb=clip3(-128,127,currpocdiff)
ꢀꢀ
(8-434)
[0164]
2.9 cu级加权双向预测(bcw)
[0165]
在hevc中,通过平均从两个不同的参考图片获得的两个预测信号和/或使用两个不同的运动矢量来生成双向预测信号。在vtm6中,双向预测模式被扩展到简单平均之外以允许对两个预测信号进行加权平均。
[0166]
p
bi-pred
=((8w)*p0 w*p1 4)>>3
ꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀꢀ
(3-19)
[0167]
加权平均双向预测中允许5个权重,w∈{-2,3,4,5,10}。对于每个双向预测cu,通过以下两种方式之一确定权重w:1)对于非merge cu,在运动矢量差之后信令通知权重索引;2)对于merge cu,基于merge候选索引从邻近块推断权重索引。加权平均双向预测仅适用于具有256个或更多亮度样点的cu(即,cu宽度乘以cu高度大于或等于256)。对于低延迟图片,使用所有5个权重。对于非低延迟图片,只使用3个权重(w∈{3,4,5})。
[0168]

在编码器处,应用快速搜索算法来查找权重索引,而不会显著增加编码器的复杂性。这些算法总结如下。有关更多详细信息,请参阅vtm软件和文档jvet-l0646。当与amvr结合使用时,如果当前图片是低延迟图片,则仅针对1像素和4像素运动矢量精度有条件地检查不等权重。
[0169]

当与仿射结合使用时,当且仅当仿射模式被选为当前最佳模式时,将对不等权重执行仿射me。
[0170]

当双向预测中的两个参考图片相同时,仅有条件地检查不等权重。
[0171]

取决于当前图片与其参考图片之间的poc距离、编解码qp以及时域级,当不满足某些条件时则不搜索不等权重。
[0172]
bcw权重索引是使用一个上下文编解码的bin和随后的旁路编解码的bin来编解码的。第一个上下文编解码的bin指示是否使用了相等权重;如果使用了不等权重,则使用旁路编解码信令通知附加bin以指示使用了哪个不等权重。
[0173]
加权预测(wp)是h.264/avc和hevc标准支持的一种编解码工具,用来有效地对具有衰减的视频内容进行编解码。对wp的支持也被添加到vvc标准中。wp允许对每个参考图片列表l0和l1中的每个参考图片信令通知加权参数(权重和偏移)。然后,在运动补偿期间,应用对应(多个)参考图片的(多个)权重和(多个)偏移。wp和bcw是为不同类型的视频内容而设计的。为了避免wp和bcw之间的会使vvc解码器的设计复杂化的相互影响,如果cu使用wp,则不信令通知bcw权重索引,并且推断w为4(即,应用相等权重)。对于merge cu,基于merge候选索引从邻近块推断权重索引。这能够应用于一般merge模式和继承仿射merge模式。对于构建的仿射merge模式,仿射运动信息是基于多达3个块的运动信息构建的。以下过程用来使用构建的仿射merge模式来推导cu的bcw索引。
[0174]
1.将bcw索引{0,1,2,3,4}的范围分为{0}、{1,2,3}和{4}三个组。如果所有控制点的bcw索引均来自于同一组,则按步骤2推导bcw索引;否则,将bcw索引设置为2。
[0175]
2.如果至少两个控制点具有相同的bcw索引,则将此bcw索引值分配给候选;否则,将当前构建的候选的bcw索引设置为2。
[0176]
2.10具有mvd的merge模式(mmvd)
[0177]
除了merge模式(其中隐式推导的运动信息被直接用于当前cu的预测样点生成)之外,在vvc中还引入了具有运动矢量差的merge模式(mmvd)。在发送跳过标志和merge标志以规定是否将mmvd模式用于cu之后,立即信令通知mmvd标志。
[0178]
在mmvd中,在选择了merge候选之后,通过信令通知mvd信息来进一步细化。进一步信息包括merge候选标志、用来规定运动幅度的索引以及用于指示运动方向的索引。在mmvd模式下,选择merge列表中前两个候选之一用作mv基础。信令通知该merge候选标志以规定使用了哪一个。
[0179]
距离索引规定运动幅度信息并指示距起始点的预定义偏移。如图7所示,将偏移添加到起始mv的水平分量或垂直分量。在表1中规定距离索引与预定义偏移的关系。
[0180]
表1:距离索引与预定义偏移的关系
[0181][0182]
方向索引表示mvd相对于起始点的方向。方向索引能够表示如表2中所示的四个方向。值得注意的是,mvd符号的含义可以根据起始mv的信息而变化。当起始mv是两个列表都指向当前图片的同一侧的非预测mv或双向预测mv(即,两个参考的poc都大于当前图片的
poc,或者都小于当前图片的poc)时,表2中的符号规定添加到起始mv的mv偏移的符号。当起始mv是两个mv指向当前图片的不同侧的双向预测mv时(即,一个参考的poc大于当前图片的poc,而另一参考的poc小于当前图片的poc),表2中的符号规定添加到起始mv的list0 mv分量的mv偏移的符号,以及具有相反值的list1 mv的符号。
[0183]
表2:由方向索引规定的mv偏移的符号
[0184]
方向idx00011011x-轴

n/an/ay-轴n/an/a

[0185]
2.11可选亮度半像素插值滤波器
[0186]
在jvet-n0309中,提出了可选半象素插值滤波器。
[0187]
半像素亮度插值滤波器的切换取决于运动矢量精度。除了现有的四分之一像素、全像素和四像素amvr模式之外,还引入了新的半像素精度amvr模式。仅在半像素运动矢量精度的情况下,才能选择可选半像素亮度插值滤波器。
[0188]
2.11.1半像素amvr模式
[0189]
提出了用于非仿射非merge帧间编解码的cu的附加amvr模式,该模式允许以半像素精度信令通知运动矢量差。当前vvc草案的现有amvr方案通过以下方式直接进行扩展:直接在语法元素amvr_flag之后,如果amvr_flag==1,则存在一个新的上下文建模二值语法元素hpel_amvr_flag,如果hpel_amvr_flag==1,其指示使用新的半像素amvr模式。否则,即,如果hpel_amvr_flag==0,则如当前vvc草案中所示地,在全象素和4象素amvr模式之间的选择由语法元素amvr_precision_flag指示。
[0190]
2.11.2可选亮度半像素插值滤波器
[0191]
对于使用半像素运动矢量精度(即,半像素amvr模式)的非仿射非merge帧间编解码的cu,在hevc/vvc半像素亮度插值滤波器和一个或多个可选半像素插值之间进行切换是基于新的语法元素if_idx的值。仅在半像素amvr模式下才信令通知语法元素if_idx。在使用空域merge候选的跳过/merge模式的情况下,从邻近块继承语法元素if_idx的值。
[0192]
2.11.2.1测试1:一个可选半像素插值滤波器
[0193]
在此测试情况下,一个6抽头插值滤波器作为普通hevc/vvc半象素插值滤波器的替代。下表示出了语法元素if_idx的值与所选的半像素亮度插值滤波器之间的映射:
[0194][0195]
2.11.2.1测试2:两个可选半像素插值滤波器
[0196]
在此测试情况下,两个8抽头插值滤波器作为普通hevc/vvc半像素插值滤波器的替代。下表示出了语法元素if_idx的值与所选的半像素亮度插值过滤器之间的映射:
[0197][0198]
信令通知amvr_precision_idx以指示当前cu是采用1/2像素、1像素或4像素精度中的哪一种。需要编解码两个bin。
[0199]
信令通知hpel_if_idx以指示是使用默认半像素插值滤波器还是可选半像素插值滤波器。当使用了两个可选半像素插值滤波器时,需要编解码两个bin。
[0200]
3.现有实施方式的缺陷
[0201]
推导帧间预测中并置运动矢量的当前设计存在以下问题:
[0202]
1.tmvp和sbtmvp中并置运动矢量的推导取决于并置编解码块的预测模式。在当前vvc中,如果以帧内或ibc预测模式编解码并置编解码块,则将并置运动矢量设置为等于零运动矢量。因此,即使并置块是调色板编解码的,仍将返回未定义的并置运动矢量,因为不存在与调色板预测模式关联的运动矢量。
[0203]
2.在bcw中推导加权样点预测可能效率不高。
[0204]
3.在当前vvc中,mv被裁剪为18比特。然而,merge运动矢量差被裁剪为16比特,这可能导致精度损失。
[0205]
4.信令通知的cu_skip_flag将导致开销比特。在当前的vvc中,ibc编解码单元的最大宽度和高度为64。对于i条带中宽度或高度大于64的块,无需信令通知cu_skip_flag。
[0206]
5.即使当cu/pu/块没有半像素或更粗略的mv分量,可选亮度半像素插值滤波器标志也可以设置为真。
[0207]
4.视频编解码中并置运动矢量的示例方法
[0208]
以下详细描述发明应被视为解释一般概念的示例。对这些发明不应作狭隘的解释。此外,这些发明可以以任何方式组合。
[0209]
推导并置运动矢量
[0210]
1.与检查并置编解码块是帧内编解码还是ibc编解码不同,如何推导出并置运动矢量和/或并置运动矢量的可用性可取决于并置编解码块的预测模式是否是帧间的。在这种情况下,不需要为每个块存储四种预测模式,只需要一个1比特来判断该块是帧间的还是非帧间的。
[0211]
a.在一个示例中,对于以调色板预测模式编解码并置编解码块的情况,如何推导并置运动矢量和/或并置运动矢量的可用性可以与以帧内/ibc预测模式编解码并置编解码块的情况相同。
[0212]
b.在一个示例中,当以非帧间预测模式(例如,帧内、调色板或ibc)编解码并置编解码块时,可以将并置运动矢量设置为不可用。
[0213]
c.可选地,并置运动矢量可以被标记为可用,并且当以非帧间预测模式(例如,帧
内、调色板或ibc)编解码并置编解码块时,可以将默认运动矢量指定为并置运动矢量。
[0214]
d.可选地,当以非帧间预测模式编解码并置编解码块时,可以替代地检查其他块(例如,并置编解码块的一个邻近帧间编解码块)。
[0215]
i.在一个示例中,邻近块可以是并置编解码块在左/右/上/下最接近的帧间编解码块。
[0216]
2.并置运动矢量的确定可以取决于并置编解码块的参考列表和/或参考索引。
[0217]
a.在一个示例中,当并置编解码块的参考列表x(例如,l1)的参考索引不等于特定值(例如,0)时,可以推导并置运动矢量(例如,使用如2.8.1中所描述的现有技术)。
[0218]
b.在一个示例中,当并置编解码块的参考列表x(例如,l1)的参考索引等于特定值(例如,0)时,可以调用并置运动矢量的推导。
[0219]
c.可选地,此外,当并置编解码块是以非帧间预测模式(包括或排除ibc)编解码时,或者其参考图片不满足给定条件时,将并置mv设置为不可用。
[0220]
i.可选地,将并置mv设置为默认值。
[0221]
bcw样点预测
[0222]
3.在bcw编解码模式中应用的权重表可能是不对称的。
[0223]
a.在一个示例中,对于作为表条目的权重w,(1-w)可以不是表条目,其中,w在[a,b]的范围内,其中(a b)等于1。
[0224]
b.在一个示例中,对于作为表条目的权重w,(2
n-w)可以不是表条目,假设最终预测块由(w0
×
p0 w1
×
p1)》》n生成,其中,w0和w1是分别应用于两个预测块p0和p1的两个权重,并且(w0 w1)等于(1《《n)。
[0225]
4.在bcw编解码模式中应用的权重表中的权重可以不是单调递增的顺序。
[0226]
a.在一个示例中,表的第(i 1)条目的值可以小于表的第i条目的值。
[0227]
5.在一个示例中,bcw的加权样点预测过程可以取决于不同的权重查找表。
[0228]
a.在一个示例中,{4,5,3,10,2}/{4,3,5,10,2}/{4,5,3,10,1}/{4,3,5,10,1}/{4,5,3,10,-1}可以用作bcw的权重查找表。
[0229]
6.在一个示例中,在bcw的加权样点预测过程中,(如有必要,例如,当第一比特深度不等于中间预测样点的比特深度时)可以将每个预测方向上的中间预测样点转换为第一比特深度,然后,可以应用加权预测,并且可以将最终预测样点转换为第二比特深度。
[0230]
a.在一个示例中,第二比特深度与当前颜色分量的输入比特深度相同。
[0231]
b.在一个示例中,在不同比特深度之间的转换中,可以应用右移(例如,将样点从较高比特深度转换为较低比特深度)或左移(例如,将样点从较低比特深度转换为较高比特深度)。
[0232]
i.可选地,此外,可以在右移或左移之前添加偏移。
[0233]
c.在一个示例中,第一比特深度与中间预测样点的比特深度相同。bcw的加权样点预测可以推导为:pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(w0*predsamplesl0[x][y] w1*predsamplesl1[x][y] offset3)》》(shift1 3)),其中将shift1设置为等于max(2,14-bitdepth),将变量offset3设置为等于1《《(shift1 2),bitdepth是当前颜色分量的比特深度。
[0234]
d.在一个示例中,第一比特深度与当前颜色分量的输入比特深度相同。bcw的加权
样点预测可以推导为:pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(w0*((predsamplesl0[x][y] offset1)》》shift1) w1*((predsamplesl1[x][y] offset1)》》shift1) 4)》》3),其中将shift1设置为等于max(2,14-bitdepth),将变量offset1设置为1《《(shift1-1)。
[0235]
mmvd范围
[0236]
7.在一个示例中,可以将merge运动矢量差裁剪到与运动矢量相同的范围。
[0237]
a.在一个示例中,可以将merge运动矢量差裁剪到18比特,例如,[-2
17
,2
17

1],这与vvc中的运动矢量范围相同。
[0238]
b.在一个示例中,可以将merge运动矢量差裁剪到[-2
17
1,2
17

1]。
[0239]
c.在一个示例中,可以不裁剪merge运动矢量差。
[0240]
i.例如,在将merge运动差添加到运动矢量预测候选之后,将运动矢量的结果剪裁为18比特。
[0241]
cu_skip_flag的信令通知
[0242]
8.提出取决于编解码块的维度,可以有条件地信令通知cu/pu/块是否是以跳过模式编解码的指示(例如,cu_skip_flag)。
[0243]
a.在一个示例中,当当前条带类型为i-slice,并且sps_ibc_enabled_flag为真,以及块宽度和块高度都小于或等于n(n是整数)时,可以信令通知该指示(例如,cu_skip_flag)。例如,n=64。
[0244]
b.在一个示例中,当以ibc模式编解码当前块时,当块宽度和块高度都小于或等于n(n是整数)时,可以信令通知该指示(例如,cu_skip_flag)。例如,n=64。
[0245]
色度分量编解码工具
[0246]
9.编解码工具x(例如,x是tmvp/atmvp/bcw/mmvd/pdpc)是否可以应用于第一颜色分量的一个块是取决于其是否应用于第二颜色分量中的一个或多个对应块。
[0247]
a.在一个示例中,当编解码工具x应用于对应的第二颜色分量(例如,亮度)块时,可以禁止对第一颜色分量(例如,色度)块使用编解码工具x。
[0248]
b.在一个示例中,当编解码工具y(其中y不同于x)应用于对应的第二颜色分量(例如,亮度)块时,可以禁止对第一颜色分量(例如,色度)块使用编解码工具x。
[0249]
c.在一个示例中,可以有条件地信令通知消息(诸如,标志或索引)以指示编解码工具x是否应用于块的第一颜色分量。该条件可以定义为其是否应用于对应的第二颜色分量块。可选地,此外,如果其未应用于对应的第二颜色分量块,则在没有信令通知的情况下其并不应用于块的第一分量。
[0250]
i.在一个示例中,编解码工具x可以以不同的方式应用于不同的颜色分量。
[0251]
1)可以信令通知如何独立地对亮度分量和色度分量应用编解码工具x。
[0252]
d.在一个示例中,第一颜色分量是色度分量,第二颜色分量是亮度分量。
[0253]
e.在一个示例中,第一颜色分量是一个色度颜色分量,第二颜色分量是另一色度颜色分量。
[0254]
f.在一个示例中,第一颜色分量是亮度颜色分量,第二颜色分量是色度颜色分量。
[0255]
g.在上述讨论中,“对应的第二颜色分量块”可以表示覆盖第一颜色分量块的至少一个“对应样点”的第二颜色分量块。
[0256]
i.在一个示例中,第一颜色分量是色度分量,第二颜色分量是亮度分量。
[0257]
ii.样点位置可以按照诸如4:4:4或4:2:0等颜色格式进行缩放。假设色度块的左上位置是(x0,y0),色度块的宽度和高度是w和h,所有这些都将按照亮度样点单位进行缩放。
[0258]
iii.在一个示例中,对应样点可以在(x0,y0)处;
[0259]
iv.在一个示例中,对应样点可以在(x0 w-1,y0 h-1)处;
[0260]
v.在一个示例中,对应样点可以在(x0 w/2-1,y0 h/2-1)处;
[0261]
vi.在一个示例中,对应样点可以在(x0 w/2,y0 h/2)处;
[0262]
vii.在一个示例中,对应样点可以在(x0 w/2,y0 h/2-1)处;
[0263]
viii.在一个示例中,对应样点可以在(x0 w/2-1,y0 h/2)处;
[0264]
h.在上述讨论中,“色度分量”可以表示“一个或多个色度分量”。
[0265]
10.提出当以某些模式编解码色度块的并置亮度块时,可以对某些色度分量禁用位置相关帧内预测样点滤波过程(又称为pdpc)。
[0266]
a.在一个示例中,当以mip(基于矩阵的帧内预测)模式编解码色度块的并置亮度块时,可以禁用这样的过程。
[0267]
b.在一个示例中,当以mrl(多参考线)模式编解码色度块的并置亮度块时,可以禁用这样的过程。
[0268]
11.当cu/pu/块仅具有比半像素精度更精细精度(例如,1/4像素、1/8像素等)的mv分量时,可以将是否使用可选半像素插值滤波器的指示设置为假。也就是说,可以使用默认半像素插值滤波器而不是可选半像素插值滤波器。
[0269]
a.在一个示例中,如果重建的mv仅具有比半像素更精细精度的mv分量,则在mmvd模式中可以将这种指示设置为假。
[0270]
b.在一个示例中,对于成对merge候选,如果其仅具有比半像素更精细精度的mv分量,则可以将这种指示设置为假。
[0271]
c.在一个示例中,当重建的双向预测运动信息被转换为仅具有比半像素更精细精度的mv分量的单向预测运动信息(例如,应用于诸如4*8或/和8*4块之类的小块)时,可以将这种指示设置为假。
[0272]
12.在某些情况下,是否使用可选半像素插值滤波器的指示可以总是设置为假。也就是说,在这些情况下,可以始终使用默认半像素插值滤波器。
[0273]
a.在一个示例中,在mmvd模式中,这种指示可以总是设置为假。
[0274]
b.在一个示例中,当选择一些特定mvd时,在mmvd模式中,这种指示可以总是设置为假。
[0275]
i.例如,如果选择具有1/4像素精度的mvd,则这种指示可以设置为假。
[0276]
c.在一个示例中,对于成对merge候选,这种指示可以总是设置为假。
[0277]
d.在一个示例中,当重建的双向预测运动信息被转换为单向预测运动信息时(例如,应用于诸如4*8或/和8*4块之类的小块),这种指示可以总是设置为假。
[0278]
一般解决方案
[0279]
13.可以在序列级/图片级/条带级/片组级,诸如在序列标头/图片标头/sps/vps/dps/pps/aps/条带标头/片组标头,信令通知是否和/或如何应用上述公开的方法。
[0280]
以上描述的示例可以并入到下文所描述方法的上下文中,例如,可以在视频解码器或视频编码器处实施的方法800、900、1000、1100、1200和1300。
[0281]
图8示出了用于视频处理的示例性方法的流程图。方法800包括,在步骤810,基于相对于当前视频块的并置视频块的预测模式来确定一个或多个并置运动矢量的可用性。
[0282]
方法800包括,在步骤820,基于该一个或多个并置运动矢量执行当前块与当前块的比特流表示之间的转换,该预测模式的指示包括一个比特,该比特指示当前视频块是以帧间模式还是以非帧间模式编解码的。
[0283]
图9示出了用于视频处理的示例性方法的流程图。方法900包括,在步骤910,对于视频块的编解码表示与视频块之间的转换,确定视频块的并置视频块的类型,该类型取仅有的两个可能值中的一个。
[0284]
方法900包括,在步骤920,基于该确定执行转换。
[0285]
图10示出了用于视频处理的示例性方法的流程图。方法1000包括,在步骤1010,基于与具有编解码单元(cu)级权重过程的双向预测模式(bcw)关联的第一权重表,推导用于当前块的预测样点,其中,第一权重表是不对称的。
[0286]
方法1000包括,在步骤1020,基于预测样点执行当前块与当前块的比特流表示之间的转换。
[0287]
图11示出了用于视频处理的示例性方法的流程图。方法1100包括,在步骤1110,基于当前视频块的维度,进行关于在当前视频块的比特流表示中选择性信令通知当前视频块的跳过模式编解码的指示的决定。
[0288]
方法1100包括,在步骤1120,基于该决定,执行当前块与当前块的比特流表示之间的转换。
[0289]
图12示出了用于视频处理的示例性方法的流程图。方法1200包括,在步骤1210,基于对当前视频块的第一颜色分量中的一个或多个块应用第一编解码工具,进行关于对当前视频块的第二颜色分量的至少一个块选择性应用第二编解码工具的决定。
[0290]
方法1200包括,在步骤1220,基于该决定,执行当前块与当前块的比特流表示之间的转换。
[0291]
图13示出了用于视频处理的示例性方法的流程图。方法1300包括,在步骤1310,基于当前视频块中的运动矢量的精度,进行关于选择性信令通知使用可选半像素插值滤波器而不是默认半像素插值滤波器的指示的决定。
[0292]
方法1300包括,在步骤1320,基于该决定,执行当前块与当前块的比特流表示之间的转换。
[0293]
所公开技术的一些实施例包括进行决定或确定以启用视频处理工具或模式。在一个示例中,当启用视频处理工具或模式时,编码器将在视频块的处理中使用或实施该工具或模式,但是并非必须基于该工具或模式的使用来修改产生的比特流。也就是说,在基于决定或确定启用视频处理工具或模式时,将使用其进行从视频块到视频的比特流表示的转换。在另一示例中,当启用视频处理工具或模式时,解码器将利用已经基于该视频处理工具或模式修改比特流的知识来处理比特流。也就是说,将使用基于决定或确定而启用的视频处理工具或模式来执行从视频的比特流表示到视频块的转换。
[0294]
所公开技术的一些实施例包括作出决定或确定以禁用视频处理工具或模式。在一
示例中,当视频处理工具或模式被禁用时,在视频块到视频的比特流表示的转换中编码器将不使用该工具或模式。在另一示例中,当视频处理工具或模式被禁用时,解码器将利用并未使用基于决定或确定而禁用的视频处理工具或模式来修改比特流表示的知识,进行比特流的处理。
[0295]
在本技术文件中,术语“视频处理”可以表示视频编码、视频解码、视频压缩或视频解压缩。例如,可以在从视频的像素表示到相应的比特流表示的转换期间应用视频压缩算法,反之亦然。如语法所定义,当前视频块的比特流表示可以例如对应于在比特流内并置或分散在不同位置的比特。例如,可以根据变换和编解码的误差残差值并且还使用比特流的标头和其他字段中的比特来对宏块进行编码。
[0296]
5.公开技术的示例性实施例
[0297]
以粗体和斜体突出显示更改。删除的文本用双括号标记(例如,[[a]]表示删除字符“a”)。
[0298]
5.1实施例#1
[0299]
可以对jvet-o2001-ve中规定的工作草案进行如下更改。
[0300]
8.5.2.12并置运动矢量的推导过程
[0301]

[0302]
按照如下推导变量mvlxcol和availableflaglxcol:
[0303]

如果以帧内或ibc预测模式编解码colcb,则将mvlxcol的两个分量设置为等于0,并且将availableflaglxcol设置为等于0。
[0304]

否则,按照如下推导运动矢量mvcol、参考索引refidxcol和参考列表标识符listcol:
[0305]

[0306]
可选地,适用以下:
[0307]
按照如下推导变量mvlxcol和availableflaglxcol:
[0308]

如果以[[帧内或ibc]]预测模式编解码colcb,则将mvlxcol的两个分量设置为等于0,并且将availableflaglxcol设置为等于0。
[0309]

否则,按照如下推导运动矢量mvcol、参考索引refidxcol和参考列表标识符listcol:
[0310]

[0311]
5.2实施例#2
[0312]
可以对jvet-o2001-ve中规定的工作草案进行如下更改。
[0313]
8.5.1对于以帧间预测模式编解码的编解码单元的一般解码过程
[0314]

[0315]
3.对于xsbidx=0..numsbx

1、ysbidx=0..numsby

1,按照如下推导在解码器侧运动矢量细化之后的亮度和色度运动矢量阵列refmvlx[xsbidx][ysbidx]和refmvclx[xsbidx][ysbidx],其中,x是0和1:
[0316]

如果dmvrflag等于1,调用条款8.5.2.13中用于色度运动矢量的推导过程,其中以refmvlx[xsbidx][ysbidx]和refidxlx作为输入,并以refmvclx[xsbidx][ysbidx]作为
输出,并且按照如下推导输入refmvlx[xsbidx][ysbidx]:
[0317]
refmvlx[xsbidx][ysbidx]=mvlx[xsbidx][ysbidx] dmvlx[xsbidx][ysbidx](8-287)
[0318]
refmvlx[xsbidx][ysbidx][0]=clip3(-2
17
,2
17-1,refmvlx[xsbidx][ysbidx][0])(8-288)
[0319]
refmvlx[xsbidx][ysbidx][1]=clip3(-2
17
,2
17-1,refmvlx[xsbidx][ysbidx][1])(8-289)
[0320]

否则(dmvrflag等于0),适用以下:
[0321]
refmvlx[xsbidx][ysbidx]=mvlx[xsbidx][ysbidx]
ꢀꢀꢀ
(8-290)
[0322]
refmvclx[xsbidx][ysbidx]=mvclx[xsbidx][ysbidx]
ꢀꢀ
(8-291)
[0323][0324]
注意-阵列refmvlx存储在mvdmvrlx中,并且用于条款8.5.2.12中并置运动矢量的推导过程。在解码条带之后,当以ibc预测模式对编解码块cb[xsbidx][ysbidx]进行编解码时,将mvdmvrlx[xsbidx][ysbidx]和对应参考索引均设置为等于-1。在空域运动矢量预测和去方块边界强度推导过程中使用非细化亮度运动矢量mvlx的阵列。
[0325]

[0326]
8.5.2.12并置运动矢量的推导过程
[0327]

[0328]
按照如下推导变量mvlxcol和availableflaglxcol:
[0329]

如果以帧内或ibc预测模式编解码colcb,则将mvlxcol的两个分量设置为等于0,并且将availableflaglxcol设置为等于0。
[0330]

否则,按照如下推导运动矢量mvcol、参考索引refidxcol和参考列表标识符listcol:
[0331]
如果predflagl0col[xcolcb][ycolcb]等于0并且predflagl1col[xcolcb][ycolcb]等于0,则将mvlxcol的两个分量设置为等于0并将availableflaglxcol设置为等于0。
[0332]
否则,适用以下:
[0333]-如果sbflag等于0,则将availableflaglxcol设置为1,并且适用以下:
[0334]-如果predflagl0col[xcolcb][ycolcb]等于0,则将mvcol、refidxcol和listcol分别设置为等于mvl1col[xcolcb][ycolcb]、refidxl1col[xcolcb][ycolcb]和l1。
[0335]-否则,如果predflagl0col[xcolcb][ycolcb]等于1并且predflagl1col[xcolcb][ycolcb]等于0,则将mvcol、refidxcol和listcol分别设置为等于mvl0col[xcolcb][ycolcb]、refidxl0col[xcolcb][ycolcb]和l0。
[0336]-否则(predflagl0col[xcolcb][ycolcb]等于1并且predflagl1col[xcolcb][ycolcb]等于1),则进行以下分配:
[0337]-如果nobackwardpredflag等于1,则将mvcol、refidxcol和listcol分别设置为等于mvlxcol[xcolcb][ycolcb]、refidxlxcol[xcolcb][ycolcb]和lx。
[0338]-否则,将mvcol、refidxcol和listcol分别设置为等于mvlncol[xcolcb][ycolcb]、refidxlncol[xcolcb][ycolcb]和ln,其中n为collocated_from_l0_flag的值。
[0339]

否则(sbflag等于1),适用以下:
[0340]-如果predflaglxcol[xcolcb][ycolcb]等于1,则将mvcol、refidxcol和listcol分别设置为等于mvlxcol[xcolcb][ycolcb]、refidxlxcol[xcolcb][ycolcb]和lx,并且将availableflaglxcol设置为1。
[0341]-否则(predflaglxcol[xcolcb][ycolcb]等于0),适用以下:
[0342]-如果nobackwardpredflag等于1并且predflaglycol[xcolcb][ycolcb]等于1,则mvcol、refidxcol和listcol分别设置为mvlycol[xcolcb][ycolcb]、refidxlycol[xcolcb][ycolcb]和ly,y等于!x,其中x是调用此过程的x的值。将availableflaglxcol设置为等于1。
[0343]-否则,将mvlxcol的两个分量设置为等于0,并将availableflaglxcol设置为等于0。
[0344]

[0345]
5.3实施例#3
[0346]
可以对jvet-o2001-ve中规定的工作草案进行如下更改。
[0347]
8.5.6.6.2默认加权样点预测过程
[0348]

[0349]
按照如下推导变量shift1、shift2、offset1、offset2和offset3:
[0350]

将变量shift1设置为等于max(2,14-bitdepth),将变量shift2设置为等于max(3,15-bitdepth)。
[0351]

将变量offset1设置为等于1《《(shift1-1)。
[0352]

将变量offset2设置为等于1《《(shift2-1)。
[0353]

将变量offset3设置为等于1《《(shift2 1[[2]])。
[0354]

[0355]

否则(predflagl0等于1并且predflagl1等于1),适用以下:
[0356]-如果bcwidx等于0或者ciip_flag[xcb][ycb]等于1,按照如下推导预测样点值:
[0357]
pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(8-823)
[0358]
(predsamplesl0[x][y] predsamplesl1[x][y] offset2)》》shift2)
[0359]-否则(bcwidx不等于0并且ciip_flag[xcb][ycb]等于0),适用以下:
[0360]-将变量w1设置为等于bcwwlut[bcwidx],其中bcwwlut[k]={4,5,3,10,-2}。
[0361]-将变量w0设置为等于(8-w1)。
[0362]-按照如下推导预测样点值:
[0363]
pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(8-824)(w0*predsamplesl0[x][y] w1*predsamplesl1[x][y] offset3)》》(shift2 [[3]]2))
[0364]

[0365]
可选地,适用以下:
[0366]

[0367]
按照如下推导变量shift1、shift2、offset1、offset2和offset3:
[0368]

将变量shift1设置为等于max(2,14-bitdepth)[[并将变量shift2设置为等于max(3,15-bitdepth)]]。
[0369]

将变量offset1设置为等于1《《(shift1-1)。
[0370]

将变量offset2设置为等于1《《(shift1 [[2-]]1)。
[0371]
将变量offset3设置为等于1《《(shift[[2]]1 2)]]。
[0372]

[0373]

否则(predflagl0等于1并且predflagl1等于1),适用以下:
[0374]-如果bcwidx等于0或者ciip_flag[xcb][ycb]等于1,按照如下推导预测样点值:
[0375]
pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,
ꢀꢀꢀꢀ
(8-823)
[0376]
(predsamplesl0[x][y] predsamplesl1[x][y] offset2)》》(shift1 1)[[2]])
[0377]-否则(bcwidx不等于0并且ciip_flag[xcb][ycb]等于0),适用以下:
[0378]-将变量w1设置为等于bcwwlut[bcwidx],其中bcwwlut[k]={4,5,3,10,-2}。
[0379]-将变量w0设置为等于(8-w1)。
[0380]-按照如下推导预测样点值:
[0381]
pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(8-824)(w0*predsamplesl0[x][y] w1*predsamplesl1[x][y] offset3)》》(shift1 3[[2 3]]))
[0382]

[0383]
可选地,适用以下:
[0384]

[0385]
按照如下推导变量shift1、shift2、offset1、offset2和offset3:
[0386]

将变量shift1设置为等于max(2,14-bitdepth),将变量shift2设置为等于max(3,15-bitdepth)。
[0387]

将变量offset1设置为等于1《《(shift1-1)。
[0388]

将变量offset2设置为等于1《《(shift2-1)。
[0389]

[[将变量offset3设置为等于1《《(shift2 2)]]。
[0390]

[0391]

否则(predflagl0等于1并且predflagl1等于1),适用以下:
[0392]-如果bcwidx等于0或者ciip_flag[xcb][ycb]等于1,按照如下推导预测样点值:
[0393]
pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(8-823)
[0394]
(predsamplesl0[x][y] predsamplesl1[x][y] offset2)》》shift2)
[0395]-否则(bcwidx不等于0并且ciip_flag[xcb][ycb]等于0),适用以下:
[0396]-将变量w1设置为等于bcwwlut[bcwidx],其中bcwwlut[k]={4,5,3,10,-2}。
[0397]-将变量w0设置为等于(8-w1)。
[0398]-按照如下推导预测样点值:
[0399]
pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(8-824)(w0*((predsamplesl0[x][y] offset1)》》shift1) w1*((predsamplesl1[x][y] offset1)》》shift1) 4)》》(8[[shift2 3)]])
[0400]

[0401]
5.4实施例#4
[0402]
可以对jvet-o2001-ve中规定的工作草案进行如下更改。
[0403]
8.5.6.6.2默认加权样点预测过程
[0404]

[0405]-否则(bcwidx不等于0并且ciip_flag[xcb][ycb]等于0),适用以下:
[0406]
将变量w1设置为等于bcwwlut[bcwidx],其中,bcwwlut[k]={4,5,3,10,2[[-2]]}/{4,5,3,10,1}/{4,3,5,10,2}/{4,3,5,10,1}/{4,5,3,10,-1}.
[0407]

[0408]
5.5实施例#5
[0409]
可以对jvet-o2001-ve中规定的工作草案进行如下更改。
[0410]
8.5.2.7merge运动矢量差的推导过程
[0411]

[0412]
mmvdl1[0]=clip3(-2
[[15]]17
,2
[[15]]17-1,(distscalefactor*mmvdl0[0] (8-394)
[0413]
128-(distscalefactor*mmvdl0[0]》=0))》》8)
[0414]
mmvdl1[1]=clip3(-2
[[15]]17
,2
[[15]]17-1,(distscalefactor*mmvdl0[1] (8-395)
[0415]
128-(distscalefactor*mmvdl0[1]》=0))》》8)
[0416]

[0417]
mmvdl0[0]=clip3(-2
[[15]]17
,2
[[15]]17-1,(distscalefactor*mmvdl1[0] (8-404)
[0418]
128-(distscalefactor*mmvdl1[0]》=0))》》8)
[0419]
mmvdl0[1]=clip3(-2
[[15]]17
,2
[[15]]17-1,,(distscalefactor*mmvdl1[1] (8-405)
[0420]
128-(distscalefactor*mmvdl1[1]》=0))》》8))
[0421]

[0422]
5.6实施例#6
[0423]
可以对jvet-o2001-ve中规定的工作草案进行如下更改。
[0424]
7.3.8.5编解码单元语法
[0425]
[0426][0427]
图14a是视频处理装置1400的框图。装置1400可以用于实现本文描述的一种或多种方法。装置1400可以实施在智能手机、平板电脑、计算机、物联网(iot)接收器等之中。装置1400可以包括一个或多个处理器1402、一个或多个存储器1404和视频处理硬件1406。(多个)处理器1402可以配置成实现本技术文件中描述的一种或多种方法(包括但不限于方法800、900、1000、1100、1200和1300)。(多个)存储器1404可以用于存储用于实现本文描述的方法和技术的数据和代码。视频处理硬件1406可以用于使用硬件电路实现本技术文件中描述的一些技术。在一些实施例中,硬件1406可以完全或部分地在处理器1402中实现,例如图形协处理器。
[0428]
图14b是示出示例视频处理系统1410的框图,其中可以实施本文所公开的各种技术。各种实施方式可以包括系统1410的一些或全部组件。系统1410可以包括用于接收视频内容的输入1412。视频内容可以原始或未压缩格式接收,例如8比特或10比特多分量像素值,或者可以压缩或编码格式接收。输入1412可以表示网络接口、外围总线接口或存储接口。网络接口的示例包括诸如以太网、无源光网络(pon)等的有线接口以及诸如wi-fi或蜂窝接口的无线接口。
[0429]
系统1410可以包括编解码组件1414,其可实现本技术文件中所描述的各种编解码或编码方法。编解码组件1414可以降低从编解码组件1414的输入1412到编解码组件1414的输出的视频的平均比特率,以产生视频的编解码表示。因此,编解码技术有时被称为视频压缩或视频转码技术。编解码组件1414的输出可以被存储,也可以通过连接的通信(如组件1416所示)进行传输。输入1412处接收的视频的存储或传输的比特流(或编解码)表示可由组件1418用于生成像素值或发送到显示接口1410的可显示视频。从比特流表示生成用户可观看视频的过程有时称为视频解压缩。此外,尽管某些视频处理操作被称为“编解码”操作或工具,但应当理解的是,编解码工具或操作被用于编码器处,并且逆向编解码结果的对应的解码工具或操作将由解码器执行。
[0430]
外围总线接口或显示接口的示例可以包括通用串行总线(usb)或高清晰度多媒体接口(hdmi)或显示端口等。存储接口的示例包括sata(串行高级技术附件)、pci、ide接口等。本文中所述的技术可实施在各种电子设备中,例如移动电话、笔记本电脑、智能手机或其他能够执行数字数据处理和/或视频显示的设备。
[0431]
在一些实施例中,视频编解码方法可以使用如图14a或14b所示的在硬件平台上实现的装置来实现。
[0432]
以下列表提供能够解决本技术文件中描述的技术问题以及其他问题的实施例。第一组条款描述在先前章节中所公开技术的某些特征和方面。
[0433]
1.一种用于处理视频的方法,包括:基于相对于当前视频块的并置视频块的预测模式,确定一个或多个并置运动矢量的可用性;以及基于一个或多个并置运动矢量,执行当前块与当前块的比特流表示之间的转换,其中,预测模式的指示包括一个比特,该比特指示当前视频块是使用帧间模式还是非帧间模式编解码。
[0434]
2.一种用于处理视频的方法,包括:对于视频块的编解码表示与视频块之间的转换,确定视频块的并置视频块的类型,其中,该类型仅取两个可能值中的一个;以及基于该确定执行转换。
[0435]
3.根据条款2所述的方法,其中,两个可能值包括:指示并置视频块是帧间编解码的第一值;以及指示并置视频块是使用除帧间编解码之外的模式编解码的第二值。
[0436]
4.根据条款1-3中任一项所述的方法,其中,当当前视频块是以调色板预测模式编解码时与当当前视频块是以帧内或帧内块复制(ibc)预测模式编解码时,该确定相同。
[0437]
5.根据条款1-3中任一项所述的方法,其中,当以非帧间预测模式编解码并置视频块时,将一个或多个并置运动矢量确定为不可用。
[0438]
6.根据条款1-3中任一项所述的方法,其中,当以非帧间预测模式编解码并置视频块时,将一个或多个并置运动矢量确定为可用并且包括默认运动矢量。
[0439]
7.根据条款5或6所述的方法,其中,非帧间预测模式是帧内预测模式、调色板预测模式或帧内块复制(ibc)预测模式。
[0440]
8.根据条款1-3中任一项所述的方法,其中,该确定是基于并置视频块的参考索引或参考列表。
[0441]
9.根据条款8所述的方法,其中,参考索引是预定值。
[0442]
10.根据条款8所述的方法,其中,参考索引排除预定值。
[0443]
11.根据条款9或10所述的方法,其中,预定值是0。
[0444]
12.一种视频处理方法,包括:基于与具有编解码单元(cu)级加权过程的双向预测(bcw)模式关联的第一权重表,推导当前块的预测样点,其中,第一权重表是不对称的;以及基于预测样点,执行当前块与当前块的比特流表示之间的转换。
[0445]
13.根据条款12所述的方法,其中,第一权重表中的条目是非单调递增。
[0446]
14.根据条款12所述的方法,其中,bcw过程还基于不同于第一权重表的第二权重表。
[0447]
15.根据条款12所述的方法,其中,推导预测样点包括:将中间预测样点转换为第一比特深度;以及将第一权重表的权重应用于中间预测样点以推导预测样点;以及将预测样点转换为第二比特深度。
[0448]
16.根据条款15所述的方法,其中,第二比特深度是当前视频块的颜色分量的比特深度。
[0449]
17.一种视频处理方法,包括:基于当前视频块的维度,进行关于在当前视频块的比特流表示中选择性信令通知当前视频块的跳过编解码模式的指示的决定;以及基于该决
定,执行当前块与当前块的比特流表示之间的转换。
[0450]
18.根据条款17所述的方法,其中,在确定包括当前视频块的条带的条带类型是i-slice、sps_ibc_enabled_flag设置为真以及当前视频块的宽度和高度小于或等于n的情况下,信令通知该指示。
[0451]
19.根据条款17所述的方法,其中,在确定以帧内块复制(ibc)模式编解码当前视频块以及当前视频块的高度和宽度小于或等于n的情况下,信令通知该指示。
[0452]
20.根据条款18或19所述的方法,其中,n=64。
[0453]
21.一种视频处理方法,包括:基于对当前视频块的第一颜色分量中的一个或多个块应用第一编解码工具,进行关于对当前视频块的第二颜色分量的至少一个块选择性应用第二编解码工具的决定;以及基于该决定,执行当前块与当前块的比特流表示之间的转换。
[0454]
22.根据条款21所述的方法,其中,在确定第二编解码工具与第一编解码工具相同的情况下,应用第二编解码工具。
[0455]
23.根据条款21所述的方法,其中,在确定第二编解码工具不同于第一编解码工具的情况下,不应用第二编解码工具。
[0456]
24.根据条款21所述的方法,其中,该决定还基于比特流表示中的指示。
[0457]
25.根据条款21-24中任一项所述的方法,其中,第一颜色分量是亮度分量,第二颜色分量是色度分量。
[0458]
26.根据条款21-24中任一项所述的方法,其中,第一颜色分量是第一色度颜色分量,第二颜色分量是第二色度颜色分量。
[0459]
27.根据条款21-26中任一项所述的方法,其中,第一编解码工具和第二编解码工具是以下之一:时域运动矢量预测(tmvp)、可选时域运动矢量预测(atmvp)、具有编解码单元(cu)级加权过程的双向预测(bcw)、具有运动矢量差的merge(mmvd)模式或位置相关的预测组合(pdpc)过程。
[0460]
28.一种视频处理方法,包括:基于当前视频块的运动矢量精度,进行关于选择性信令通知使用可选半像素插值滤波器而不是默认半像素插值滤波器的指示的决定;以及基于该决定,执行当前块和当前块的比特流表示之间的转换。
[0461]
29.根据条款28所述的方法,其中,在确定以具有运动矢量差的merge(mmvd)模式编解码当前视频块以及重建运动矢量的精度低于半像素的情况下,使用默认半像素插值滤波器。
[0462]
30.根据条款1-29中任一项所述的方法,其中,执行转换还基于解码器参数集(dps)、序列参数集(sps)、图片参数集(pps)、自适应参数集(aps)、视频参数集(vps)、序列标头、图片标头、条带标头或片组标头中的信令通知。
[0463]
31.根据条款1-30中任一项所述的方法,其中,执行转换包括从当前视频块生成比特流表示。
[0464]
32.根据条款1-30中任一项所述的方法,其中,执行转换包括从比特流表示生成当前视频块。
[0465]
33.一种视频解码装置,包括处理器,处理器被配置成实现根据条款1-32中任一项所述的方法。
[0466]
34.一种存储在非暂时性计算机可读介质上的计算机程序产品,计算机程序产品
包括程序代码,该程序代码用于运行根据条款1-32中任一项所述的方法。
[0467]
第二组条款描述在先前章节中所公开技术的某些特征和方面(例如,第1项和第2项)。
[0468]
1.一种视频处理方法,包括:进行第一确定,该第一确定关于视频的视频块的并置视频块是使用帧间编解码模式还是非帧间编解码模式编解码的;基于该第一确定进行第二确定,该第二确定关于并置视频块的运动矢量的可用性或者推导并置视频块的运动矢量的模式;以及基于该第二确定执行视频块与视频的编解码表示之间的转换。
[0469]
2.根据条款1所述的方法,其中,非帧间编解码模式是帧内模式、调色板模式或帧内块复制(ibc)模式。
[0470]
3.根据条款1所述的方法,其中,执行第二确定,使得对于以调色板模式编解码的并置视频块和以帧内模式编解码的并置视频块,该第二确定是相同的。
[0471]
4.根据条款1所述的方法,其中,执行第二确定,使得对于以调色板模式编解码的并置视频块和以帧内块复制模式编解码的并置视频块,该第二确定是相同的。
[0472]
5.根据条款1所述的方法,其中,执行第二确定,使得对于以帧内模式编解码的并置视频块和以帧内块复制模式编解码的并置视频块,该第二确定是相同的。
[0473]
6.根据条款1所述的方法,其中,进行第一确定包括:生成一个比特以指示并置视频块是使用帧间编解码模式还是非帧间编解码模式编解码的。
[0474]
7.根据条款1所述的方法,其中,基于并置视频块是使用非帧间编解码模式编解码的第一确定,第二确定确定并置视频块的运动矢量不可用。
[0475]
8.根据条款1所述的方法,其中,基于并置视频块是使用非帧间编解码模式编解码的第一确定,第二确定确定并置视频块的运动矢量可用,其中,将默认运动矢量分配为并置视频块的运动矢量。
[0476]
9.根据条款1所述的方法,其中,在使用非帧间编解码模式编解码并置视频块的情况下,检查除并置视频块之外的另一视频块。
[0477]
10.根据条款9所述的方法,其中,另一视频块是邻近块,该邻近块是在并置视频块的左、右、上或下方的最近帧间编解码块。
[0478]
11.一种视频处理方法,包括:对于视频的视频块与视频的编解码表示之间的转换,基于视频块的并置视频块的参考索引或者参考列表确定一个或多个并置运动矢量;以及基于该确定执行转换。
[0479]
12.根据条款11所述的方法,其中,在并置视频块的参考列表的参考索引不等于预定值的情况下,推导一个或多个并置运动矢量。
[0480]
13.根据条款11所述的方法,其中,在并置视频块的参考列表的参考索引等于预定值的情况下,推导一个或多个并置运动矢量。
[0481]
14.根据条款12或13所述的方法,其中,预定值是0。
[0482]
15.根据条款11所述的方法,其中,在并置视频块是以非帧间编解码模式编解码的或者并置视频块的参考图片不满足给定条件的情况下,将一个或多个并置运动矢量设置为不可用。
[0483]
16.根据条款11所述的方法,其中,在并置视频块是以非帧间编解码模式编解码的或者并置视频块的参考图片不满足给定条件的情况下,将一个或多个并置运动矢量设置为
默认值。
[0484]
17.根据条款1-16中任一项所述的方法,其中,转换包括将视频编码为编解码表示。
[0485]
18.根据条款1-16中任一项的方法,其中,转换包括对编解码表示进行解码以生成视频。
[0486]
19.一种视频处理装置,包括:处理器,该处理器被配置成实现条款1-16中任意一项或多项所述的方法。
[0487]
20.一种计算机可读介质,存储程序代码,该程序代码在被执行时促使处理器实现条款1-16中任意一项或多项所述的方法。
[0488]
21.一种计算机可读介质,存储根据上述方法中的任意一项生成的编解码表示或比特流表示。
[0489]
第三组条款描述了先前章节中所公开的技术的某些特征和方面(例如,3-7项)。
[0490]
1.一种视频处理方法(例如,图15c中示出的方法1530),包括:对于视频的当前块与视频的编解码表示之间的转换,推导(1532)根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定预测块的两个初始预测块的加权和;以及,使用预测块执行(1534)转换,其中,推导预测块包括:将权重应用于分别属于两个初始预测块的两个中间预测样点以推导最终预测样点;以及对最终预测样点进行右移运算以转换最终预测样点的比特深度,其中,右移运算是pbsample》》(shift1 3),其中,pbsample表示最终预测样点,shift1设置为等于max(2,14-bitdepth);基于最终预测样点确定预测块。
[0491]
2.根据条款1所述的方法,其中,在执行右移操作之前,将偏移添加到最终预测样点。
[0492]
3.根据条款1所述的方法,其中,偏移是1《《(shift1 2)。
[0493]
4.根据条款3所述的方法,其中,推导最终预测样点pbsamples[x][y]使得pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(w0*predsamplesl0[x][y] w1*predsamplesl1[x][y] offset3)》》(shift1 3)),其中,w0和w1是权重,predsamplesl0[x][y]和predsamplesl1[x][y]是两个中间预测样点。
[0494]
5.根据条款1所述的方法,其中,权重中的至少一个属于权重表,其中,权重表的条目非单调递增。
[0495]
6.一种视频处理方法,包括:对于视频的当前块与视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定预测块的两个初始预测块的加权和;使用预测块执行转换,其中,推导预测块包括:将权重应用于分别属于两个初始预测块的两个中间预测样点以推导最终预测样点;以及将偏移添加到最终预测样点,该偏移为1《《(shift1 2),其中,shift1设置为等于max(2,14-bitdepth);基于最终预测样点确定预测块。
[0496]
7.根据条款6所述的方法,其中,基于最终预测样点确定预测块包括:对最终预测样点执行右移操作以转换最终预测样点的比特深度。
[0497]
8.根据条款1或7所述的方法,其中,右移操作是pbsample》》(shift1 3),其中,pbsample表示最终预测样点。
[0498]
9.根据条款8所述的方法,其中,推导最终预测样点pbsamples[x][y]以使得
pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(w0*predsamplesl0[x][y] w1*predsamplesl1[x][y] offset3)》》(shift1 3)),其中w0和w1是权重,predsamplesl0[x][y]和predsamplesl1[x][y]是两个中间预测样点。
[0499]
10.根据条款6所述的方法,其中,权重中的至少一个属于权重表,其中,权重表的条目非单调递增。
[0500]
11.一种视频处理方法(例如,图15d中所示出的方法1540),包括:对于视频的当前块与视频的编解码表示之间的转换,根据规则推导(1542)当前块的merge模式运动矢量预测器的运动矢量差;基于该推导执行(1544)转换,其中,规则规定是否将运动矢量差裁剪到与用于裁剪运动矢量的范围相同的范围。
[0501]
12.根据条款11所述的方法,其中,规则规定将运动矢量差裁剪到与用于裁剪运动矢量的范围相同的范围。
[0502]
13.根据条款11所述的方法,其中,用于裁剪运动矢量的范围是18比特。
[0503]
14.根据条款13所述的方法,其中,用于裁剪运动矢量的范围是[-2
17
,2
17

1]。
[0504]
15.根据条款11所述的方法,其中,该规规定将运动矢量差裁剪到[-2
17
1,2
17

1]。
[0505]
16.根据条款11所述的方法,其中,规则规定不裁剪运动矢量差。
[0506]
17.根据条款16所述的方法,其中,规则规定将通过将运动矢量差添加到运动矢量预测候选而获得的结果裁剪为18比特。
[0507]
18.一种视频处理方法,包括:对于视频的当前块和视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定预测块的两个初始预测块的加权和,其中权重中的至少一个属于权重表,根据规则组织权重表;使用预测块执行转换,其中,该规则规定权重表的条目非单调递增。
[0508]
19.根据条款18所述的方法,其中,权重表包括第(i 1)个条目,其值小于第i个条目的值。
[0509]
20.一种视频处理方法,包括:对于视频的当前块与视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定预测块的两个初始预测块的加权和,其中,权重中的至少一个属于权重表,并且权重表选自多个权重表;以及使用预测块执行转换。
[0510]
21.根据条款20所述的方法,其中,多个权重表包括{4,5,3,10,2}、{4,3,5,10,2}、{4,5,3,10,1}、{4,3,5,10,1}或{4,5,3,10,-1}。
[0511]
22.一种视频处理方法,包括:对于视频的当前块与视频的编解码表示之间的转换,推导根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中权重用来确定用于确定预测块的两个初始预测块的加权和;使用预测块执行转换,其中,推导预测块包括:将中间预测样点转换为第一比特深度;将权重应用于中间预测样点以推导最终预测样点;将最终预测样点转换为第二比特深度。
[0512]
23.根据条款22所述的方法,其中,第二比特深度是当前块的颜色分量的比特深度。
[0513]
24.根据条款22所述的方法,其中,第一比特深度不等于所述中间预测样点的比特深度。
[0514]
25.根据条款22所述的方法,其中,推导预测块包括:将样点从较高比特深度转换
为较低比特深度的右移运算或将样点从较低比特深度转换为较高比特深度的左移操作。
[0515]
26.根据条款25所述的方法,其中,在右移操作或左移操作之前添加偏移。
[0516]
27.根据条款22所述的方法,其中,推导最终预测样点pbsamples[x][y]以使得pbsamples[x][y]=clip3(0,(1《《bitdepth)-1,(w0*((predsamplesl0[x][y] offset1)》》shift1) w1*((predsamplesl1[x][y] offset1)》》shift1) 4)》》3),其中w0和w1是权重,shift1设置为等于max(2,14-bitdepth),offset1设置为等于1《《(shift1-1)。
[0517]
28.一种视频处理方法(图15e中所示出的方法1550),包括:对于视频的当前块与视频的编解码表示之间的转换,推导(1552)根据双向编解码单元级加权(bcw)工具确定的当前块的预测块,其中第一权重和第二权重用来确定用于确定预测块的两个初始预测块的加权和,第一权重和第二权重中的至少一个包括在权重表中,其中,根据规则组织该权重表;使用预测块执行转换,其中,规则规定权重表是不对称的。
[0518]
29.根据条款28所述的方法,其中,权重表包括其值对应于第一权重w的条目,并且不包括其值对应于第二权重(1-w)的任何条目,由此w在[a,b]的范围内,并且a和b的总和(a b)等于1。
[0519]
30.根据条款28所述的方法,其中,在通过(w0*p0 w1*p1)》》n生成预测样点情况下,权重表包括其值对应于第一权重w的条目,并且不包括其值对应于第二权重(2
n-w)的任何条目,其中,w0和w1是分别应用于两个初始预测块p0和p1的第一权重和第二权重;(w0 w1)等于(1《《n)。
[0520]
31.根据条款1-30中任一项所述的方法,其中,执行转换包括从当前视频块生成编解码表示。
[0521]
32.根据条款1-30中任一项所述的方法,其中,执行转换包括从编解码表示生成当前视频块。
[0522]
33.一种视频处理设备,包括视频处理器,该处理器被配置为实现条款1-32中任意一项或多项所述的方法。
[0523]
34.一种计算机可读介质,存储程序代码,该程序代码在被执行时促使处理器实现条款1-32中任意一项或多项所述的方法。
[0524]
35.一种计算机可读介质,其存储根据上述方法中的任意一项生成的编解码表示或比特流表示。
[0525]
根据前述内容,可以理解的是,出于说明的目的,本文中已经描述了当前公开的技术的特定实施例,但是在不脱离本发明的范围的情况下可以进行各种修改。因此,除了所附权利要求书外,当前公开的技术不受限制。
[0526]
本文中描述的主题的实例和功能操作可以在各种系统、数字电子电路、或计算机软件、固件或硬件中实现,包括本说明书中所公开的结构及其结构等效体,或其中一个或多个的组合。本说明说中描述的主题的实例可以实现为一个或多个计算机程序产品,即一个或多个编码在有形的且非易失的计算机可读介质上的计算机程序指令的模块,以供数据处理装置执行或控制数据处理装置的操作。计算机可读介质可以是机器可读存储设备、机器可读存储基板、存储设备、影响机器可读传播信号的物质组成或其中一个或其中多个的组合。术语“数据处理单元”或“数据处理装置”包括用于处理数据的所有装置、设备和机器,包括例如可编程处理器、计算机或多处理器或计算机组。除硬件外,该装置还可以包括为计算
机程序创建执行环境的代码,例如,构成处理器固件的代码、协议栈、数据库管理系统、操作系统或其中一个或多个的组合。
[0527]
计算机程序(也称为程序、软件、软件应用、脚本或代码)可以用任何形式的编程语言(包括编译语言或解释语言)编写,并且可以以任何形式部署,包括作为独立程序或作为模块、组件、子程序或其他适合在计算环境中使用的单元。计算机程序不一定与文件系统中的文件对应。程序可以存储在保存其他程序或数据的文件的部分中(例如,存储在标记语言文档中的一个或多个脚本)、专用于该程序的单个文件中、或多个协调文件(例如,存储一个或多个模块、子程序或部分代码的文件)中。计算机程序可以部署在一台或多台计算机上来执行,这些计算机位于一个站点上或分布在多个站点上,并通过通信网络互连。
[0528]
本说明书中描述的处理和逻辑流可以通过一个或多个可编程处理器执行,该处理器执行一个或多个计算机程序,通过在输入数据上操作并生成输出来执行功能。处理和逻辑流也可以通过特殊用途的逻辑电路来执行,并且装置也可以实现为特殊用途的逻辑电路,例如,fpga(现场可编程门阵列)或asic(专用集成电路)。
[0529]
例如,适于执行计算机程序的处理器包括通用和专用微处理器,以及任何类型数字计算机的任何一个或多个。通常,处理器将从只读存储器或随机存取存储器或两者接收指令和数据。计算机的基本元件是执行指令的处理器和存储指令和数据的一个或多个存储设备。通常,计算机还将包括一个或多个用于存储数据的大容量存储设备,例如,磁盘、磁光盘或光盘,或通过操作耦合到一个或多个大容量存储设备来从其接收数据或将数据传输到一个或多个大容量存储设备,或两者兼有。然而,计算机不一定具有这样的设备。适用于存储计算机程序指令和数据的计算机可读介质包括所有形式的非易失性存储器、介质和存储器设备,包括例如半导体存储器设备,例如eprom、eeprom和闪存设备。处理器和存储器可以由专用逻辑电路来补充,或合并到专用逻辑电路中。
[0530]
说明书与附图一起旨在仅视为示例性的,其中示例性意味着示例。如本文所使用的,单数形式“一”、“一个”和“该”也旨在包括复数形式,除非上下文另外明确指出。另外,“或”的使用旨在包括“和/或”,除非上下文另外明确指出。
[0531]
虽然本专利文件包含许多细节,但不应将其解释为对任何发明或权利要求范围的限制,而应解释为对特定发明的特定实施例的特征的描述。本专利文件在单独实施例的上下文描述的某些特征也可以在单个实施例中组合实施。相反,在单个实施例的上下文中描述的各种功能也可以在多个实施例中单独实施,或在任何合适的子组合中实施。此外,尽管上述特征可以描述为在某些组合中起作用,甚至最初要求是这样,但在某些情况下,可以从组合中移除权利要求组合中的一个或多个特征,并且权利要求的组合可以指向子组合或子组合的变体。
[0532]
同样,尽管附图中以特定顺序描述了操作,但这不应理解为要获得想要的结果必须按照所示的特定顺序或顺序执行此类操作,或执行所有说明的操作。此外,本专利文件所述实施例中各种系统组件的分离不应理解为在所有实施例中都需要这样的分离。
[0533]
仅描述了一些实例和示例,可以基于本专利文件中描述和说明的内容做出其他实例、增强和变体。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献