JP2022541012A - ビデオコーディングにおける変換ブロック・サイズ制約 - Google Patents
ビデオコーディングにおける変換ブロック・サイズ制約 Download PDFInfo
- Publication number
- JP2022541012A JP2022541012A JP2022502208A JP2022502208A JP2022541012A JP 2022541012 A JP2022541012 A JP 2022541012A JP 2022502208 A JP2022502208 A JP 2022502208A JP 2022502208 A JP2022502208 A JP 2022502208A JP 2022541012 A JP2022541012 A JP 2022541012A
- Authority
- JP
- Japan
- Prior art keywords
- merge
- block
- candidates
- flag
- list
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 230000000007 visual effect Effects 0.000 claims abstract description 79
- 238000000034 method Methods 0.000 claims description 544
- 238000012545 processing Methods 0.000 claims description 72
- 230000001131 transforming effect Effects 0.000 claims description 12
- 238000006243 chemical reaction Methods 0.000 abstract description 48
- 238000003672 processing method Methods 0.000 abstract description 23
- 230000033001 locomotion Effects 0.000 description 595
- 241000023320 Luma <angiosperm> Species 0.000 description 475
- OSWPMRLSEDHDFF-UHFFFAOYSA-N methyl salicylate Chemical group COC(=O)C1=CC=CC=C1O OSWPMRLSEDHDFF-UHFFFAOYSA-N 0.000 description 475
- 239000013598 vector Substances 0.000 description 447
- 230000008569 process Effects 0.000 description 288
- 238000009795 derivation Methods 0.000 description 210
- 238000013138 pruning Methods 0.000 description 74
- 230000002123 temporal effect Effects 0.000 description 74
- PXFBZOLANLWPMH-UHFFFAOYSA-N 16-Epiaffinine Natural products C1C(C2=CC=CC=C2N2)=C2C(=O)CC2C(=CC)CN(C)C1C2CO PXFBZOLANLWPMH-UHFFFAOYSA-N 0.000 description 68
- 230000003044 adaptive effect Effects 0.000 description 30
- 238000005192 partition Methods 0.000 description 30
- 230000009466 transformation Effects 0.000 description 26
- 238000010276 construction Methods 0.000 description 23
- 238000004590 computer program Methods 0.000 description 18
- 238000013461 design Methods 0.000 description 18
- 230000011664 signaling Effects 0.000 description 18
- 238000003491 array Methods 0.000 description 12
- 230000015654 memory Effects 0.000 description 12
- 238000000638 solvent extraction Methods 0.000 description 11
- 238000007906 compression Methods 0.000 description 10
- 238000003780 insertion Methods 0.000 description 10
- 230000037431 insertion Effects 0.000 description 10
- 230000003287 optical effect Effects 0.000 description 10
- 238000005516 engineering process Methods 0.000 description 9
- 239000000872 buffer Substances 0.000 description 8
- 239000002131 composite material Substances 0.000 description 8
- 230000006835 compression Effects 0.000 description 8
- 238000010586 diagram Methods 0.000 description 8
- 230000006870 function Effects 0.000 description 8
- 230000007774 longterm Effects 0.000 description 8
- 230000005540 biological transmission Effects 0.000 description 6
- 238000004891 communication Methods 0.000 description 6
- 238000012360 testing method Methods 0.000 description 6
- 208000031212 Autoimmune polyendocrinopathy Diseases 0.000 description 4
- 238000007792 addition Methods 0.000 description 4
- 235000019395 ammonium persulphate Nutrition 0.000 description 4
- 238000000261 appearance potential spectroscopy Methods 0.000 description 4
- 239000011449 brick Substances 0.000 description 4
- 230000006837 decompression Effects 0.000 description 4
- 238000012986 modification Methods 0.000 description 4
- 230000004048 modification Effects 0.000 description 4
- 230000002093 peripheral effect Effects 0.000 description 4
- 238000013139 quantization Methods 0.000 description 4
- 230000009467 reduction Effects 0.000 description 4
- 238000013515 script Methods 0.000 description 4
- 238000000926 separation method Methods 0.000 description 4
- 230000008901 benefit Effects 0.000 description 3
- 241000086194 Bulbophyllum affine Species 0.000 description 2
- 230000001174 ascending effect Effects 0.000 description 2
- 230000002146 bilateral effect Effects 0.000 description 2
- 238000004422 calculation algorithm Methods 0.000 description 2
- 230000001413 cellular effect Effects 0.000 description 2
- 230000000295 complement effect Effects 0.000 description 2
- 150000001875 compounds Chemical class 0.000 description 2
- 239000013256 coordination polymer Substances 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 238000006073 displacement reaction Methods 0.000 description 2
- 230000009977 dual effect Effects 0.000 description 2
- 238000012812 general test Methods 0.000 description 2
- 230000006872 improvement Effects 0.000 description 2
- 230000001788 irregular Effects 0.000 description 2
- 238000002156 mixing Methods 0.000 description 2
- 239000000203 mixture Substances 0.000 description 2
- 230000000644 propagated effect Effects 0.000 description 2
- 230000001902 propagating effect Effects 0.000 description 2
- 230000004044 response Effects 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 239000000758 substrate Substances 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 239000011800 void material Substances 0.000 description 2
- AZFKQCNGMSSWDS-UHFFFAOYSA-N MCPA-thioethyl Chemical compound CCSC(=O)COC1=CC=C(Cl)C=C1C AZFKQCNGMSSWDS-UHFFFAOYSA-N 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/117—Filters, e.g. for pre-processing or post-processing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/12—Selection from among a plurality of transforms or standards, e.g. selection between discrete cosine transform [DCT] and sub-band transform or selection between H.263 and H.264
- H04N19/122—Selection of transform size, e.g. 8x8 or 2x4x8 DCT; Selection of sub-band transforms of varying structure or type
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/103—Selection of coding mode or of prediction mode
- H04N19/109—Selection of coding mode or of prediction mode among a plurality of temporal predictive coding modes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/119—Adaptive subdivision aspects, e.g. subdivision of a picture into rectangular or non-rectangular coding blocks
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/132—Sampling, masking or truncation of coding units, e.g. adaptive resampling, frame skipping, frame interpolation or high-frequency transform coefficient masking
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/17—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
- H04N19/174—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a slice, e.g. a line of blocks or a group of blocks
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/17—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
- H04N19/176—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a block, e.g. a macroblock
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/1883—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit relating to sub-band structure, e.g. hierarchical level, directional tree, e.g. low-high [LH], high-low [HL], high-high [HH]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/513—Processing of motion vectors
- H04N19/517—Processing of motion vectors by encoding
- H04N19/52—Processing of motion vectors by encoding by predictive encoding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/70—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by syntax aspects related to video coding, e.g. related to compression standards
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/80—Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation
- H04N19/82—Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation involving filtering within a prediction loop
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/90—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
- H04N19/96—Tree coding, e.g. quad-tree coding
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- Discrete Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
Description
パリ条約に基づく適用可能な特許法および/または規則に基づき、本願は、2019年7月14日に出願された国際特許出願第PCT/CN2019/095921号の優先権および利益を適時に主張して行われる。法に基づくすべての目的のために、前述の出願の開示全体は、本願の開示の一部として引用により援用される。
本稿は、ビデオおよび画像の符号化・復号技術に関する。
本稿は、ビデオ符号化技術に関する。具体的には、本稿は三角予測モードを含むマージ符号化に関する。これは、HEVCのような既存のビデオ符号化規格、またはこれから最終化される規格(多用途ビデオ符号化(Versatile Video Coding))に適用されることがある。これは、将来のビデオ符号化規格またはビデオ・コーデックにも適用可能でありうる。
ビデオ符号化規格は、主に、周知のITU-TおよびISO/IEC規格の開発を通じて発展してきた。ITU-TはH.261およびH.263を生み出し、ISO/IECはMPEG-1およびMPEG-4 Visualを生み出し、両機関は合同してH.262/MPEG-2 VideoおよびH.264/MPEG-4 先進ビデオ符号化(Advanced Video Coding、AVC)およびH.265/HEVC規格を生み出した。H.262以来、ビデオ符号化規格は、時間的予測と変換符号化が利用されるハイブリッドビデオ符号化構造に基づいている。HEVCを越えた将来のビデオ符号化技術を探求するため、2015年にVCEGとMPEGによって合同で、合同ビデオ探査チーム(Joint Video Exploration Team、JVET)が設立された。それ以来、JVETによって多くの新しい方法が採用され、JEM(Joint Exploration Model)と名付けられた参照ソフトウェアに入れられた。2018年4月には、VCEG(Q6/16)とISO/IEC JTC1 SC29/WG11(MPEG)の間で合同ビデオエキスパートチーム(Joint Video Expert Team、JVET)を発足し、HEVCに比べ50%のビットレート削減を目指すVVC規格に取り組んでいる。
インター符号化される符号化単位(CU)については、分割モードに応じて、1つの予測単位(PU)、2つのPUを用いて符号化されうる。各インター予測されたPUは、1つまたは2つの参照ピクチャー・リストのための動きパラメータを有する。動きパラメータは、動きベクトルおよび参照ピクチャー・インデックスを含む。2つの参照ピクチャー・リストのうちの一方の使用は、inter_pred_idcを使用して信号伝達されてもよい。動きベクトルは、予測子に対するデルタとして明示的に符号化されてもよい。
HEVCでは、インター予測という用語は、現在のデコードされたピクチャー以外の参照ピクチャーのデータ要素(たとえば、サンプル値または動きベクトル)から導出された予測を示すために使用される。H.264/AVCと同様に、ピクチャーは、複数の参照ピクチャーから予測できる。インター予測のために使用される参照ピクチャーは、一つまたは複数の参照ピクチャー・リストにおいて整理される。参照インデックスは、リスト内の参照ピクチャーのうちどれが、予測信号を生成するために使用されるべきかを同定する。
2.1.2.1 マージ・モードについての候補の導出
マージ・モードを使用してPUが予測される場合、マージ候補リスト内のエントリーを指すインデックスがビットストリームからパースされ、動き情報を取得するために使用される。このリストの構築はHEVC規格で規定されており、以下の一連のステップに従って要約することができる。
●ステップ1:初期候補の導出
○ステップ1.1:空間的候補の導出
○ステップ1.2:空間的候補についての冗長性チェック
○ステップ1.3:時間的候補の導出
●ステップ2:追加的候補の挿入
○ステップ2.1:双予測候補の生成
○ステップ2.2:ゼロ動き候補の挿入
空間的マージ候補の導出では、図22に示される位置に位置する候補の中から、最大4つのマージ候補が選択される。導出の順序はA1、B1、B0、A0、B2である。位置B2は、位置A1、B1、B0、A0のどのPUも利用可能でない(たとえば、それが別のスライスまたはタイルに属するため)またはイントラ符号化されている場合にのみ考慮される。位置A1にある候補が追加された後、残りの候補の追加は、同じ動き情報をもつ候補がリストから除外されることを保証する冗長性チェックの対象となり、符号化効率が改善される。計算複雑さを低減するために、前述の冗長性チェックでは、可能な候補ペアすべてが考慮されているわけではない。その代わりに、図3の矢印でつながれたペアのみが考慮され、冗長性チェックに使用される対応する候補が同じ動き情報を持たない場合にのみ、候補がリストに追加される。重複する動き情報の別の源は、2N×2Nとは異なるパーティションに関連付けられた「第2のPU」である。一例として、図4は、それぞれN×2Nおよび2N×Nの場合について第2のPUを示す。現在のPUがN×2Nとして分割されている場合、位置A1にある候補はリスト構築のためには考慮されない。実際、この候補を加えることによって、同じ動き情報をもつ2つの予測単位が得られる。これは、符号化単位に1つのPUをもつだけであることに対して冗長である。同様に、現在のPUが2N×Nとして分割されている場合、位置B1は考慮されない。
このステップでは、1つの候補のみがリストに追加される。具体的には、この時間的マージ候補の導出において、共位置のピクチャー内の共位置のPUに基づいて、スケーリングされた動きベクトルが導出される。時間的マージ候補のためのスケーリングされた動きベクトルは、図5の点線によって示されているように得られ、これは、POC距離、tbおよびtdを使用して、共位置のPUの動きベクトルからスケーリングされる。ここで、tbは、現在ピクチャーの参照ピクチャーと現在ピクチャーとの間のPOC差であると定義され、tdは、共位置のピクチャーの参照ピクチャーと共位置のピクチャーとの間のPOC差であると定義される。時間的マージ候補の参照ピクチャー・インデックスはゼロに設定される。スケーリング・プロセスの実際的な実現がHEVC仕様[1]に記述されている。Bスライスについては、一方は参照ピクチャー・リスト0について、他方は参照ピクチャー・リスト1についての2つの動きベクトルが得られ、組み合わされて、双予測マージ候補を作成する。
TMVPが有効にされている場合(すなわち、slice_temporal_mvp_enabled_flagが1に等しい場合)、共位置のピクチャーを表す変数ColPicは次のように導出される:
・現在のスライスがBスライスであり、信号伝達されたcollocated_from_l0_flagが0に等しい場合、ColPicはRefPicList1[collocated_ref_idx]に等しく設定される。
・それ以外の場合(slice_typeがBに等しく、collocated_from_l0_flagが1に等しい、またはslice_typeがPに等しい場合)、ColPicはRefPicList0[collocated_ref_idx]に等しく設定される。
ここで、collocated_ref_idxとcollocated_from_l0_flagは、スライスヘッダにおいて信号伝達されうる2つの構文要素である。
より具体的には、TMVP候補を導出するために、以下のステップが実行される。
1)参照ピクチャー・リストX=0と設定し、ターゲット参照ピクチャーを、リストXにおけるインデックスが0に等しい参照ピクチャー(すなわち、curr_ref)に設定する。
2)現在のスライスがBスライスである場合、参照ピクチャー・リストX=1と設定し、ターゲット参照ピクチャーを、リストXにおけるインデックスが0に等しい参照ピクチャー(すなわち、curr_ref)に設定する。共位置の諸動きベクトルについて導出プロセスを呼び出し、curr_refをポイントする、リストXについてのMVを得る。
共位置のブロックについては、単予測または双予測でイントラまたはインター符号化されてもよい。イントラ符号化される場合、TMVP候補は利用不能に設定される。
・参照ピクチャーのどれも、現在のピクチャーに比べて、より大きなPOC値をもたない場合、AはXに等しく設定される。
・そうでない場合、Aはcollocated_from_l0_flagに等しく設定される。
このプロセスへの入力は以下の通り:
・現在の予測ブロックを指定する変数currPb、
・ColPicによって指定された共位置のピクチャー内の共位置の予測ブロックを指定する変数ColPic、
・ColPbによって指定された共位置のルーマ予測ブロックの左上のサンプルを、ColPicによって指定された共位置のピクチャーの左上のルーマ・サンプルに対して指定するルーマ位置(xColPb,yColPb)、
・参照インデックスrefIdxLX、ここで、Xは0または1。
・動きベクトル予測mvLXCol、
・利用可能性フラグavailableFlagLXCol。
・colPbがイントラ予測モードで符号化されている場合、mvLXColの両方の成分が0に等しく設定され、availableFlagLXColが0に等しく設定される。
・それ以外の場合、動きベクトルmvCol、参照インデックスrefIdxCol、参照リスト識別子listColは、次のように導出される:
・predFlagL0Col[xColPb][yColPb]が0に等しい場合、mvCol,refIdxCol,listColがそれぞれmvL1Col[xColPb][yColPb],refIdxL1Col[xColPb][yColPb],L1に等しく設定される。
・それ以外の場合、predFlagL0Col[xColPb][yColPb]が1に等しく、predFlagL1Col[xColPb][yColPb]が0に等しい場合、mvCol,refIdxCol,listColはそれぞれmvL0Col[xColPb][yColPb],refIdxL0Col[xColPb][yColPb],L0に等しく設定される。
・それ以外の場合(predFlagL0Col[xColPb][yColPb]が1に等しく、predFlagL1Col[xColPb][yColPb]が1に等しい場合)、次の割り当てがされる:
・NoBackwardPredFlagが1に等しい場合、mvCol,refIdxCol,listColはそれぞれmvLXCol[xColPb][yColPb],refIdxLXCol[xColPb][yColPb],LXに等しく設定される。
・それ以外の場合、mvCol,refIdxCol,listColはそれぞれmvLNCol[xColPb][yColPb],refIdxLNCol[xColPb][yColPb]LNに等しく設定され、ここで、Nはcollocated_from_l0_flagの値である。
mvLXColおよびavailableFlagLXColは次のように導出される:
・LongTermRefPic(currPic,currPb,refIdxLX,LX)がLongTermRefPic(ColPic,colPb,refIdxCol,listCol)に等しくない場合、mvLXColの両方の成分は0に等しく設定され、availableFlagLXColは0に等しく設定される。
・それ以外の場合、変数availableFlagLXColは1に等しく設定され、refPicListCol[refIdxCol]は、ColPicによって指定された共位置ピクチャーにおける予測ブロックcolPbを含むスライスの参照ピクチャー・リストlistColにおける参照インデックスrefIdxColをもつピクチャーに設定され、以下が適用される:
colPocDiff=DiffPicOrderCnt(ColPic,refPicListCol[refIdxCol]) (2-1)
currPocDiff=DiffPicOrderCnt(currPic,RefPicListX[refIdxLX]) (2-2)
・RefPicListX[refIdxLX]が長期参照ピクチャーである、またはcolPocDiffがcurrPocDiffに等しい場合、mvLXCol次のように導出される:
mvLXCol=mvCol (2-3)
・それ以外の場合、mvLXColは以下のように動きベクトルmvColのスケーリングされたバージョンとして導出される:
・DiffPicOrderCnt(aPic,CurrPic)が現在のスライスのRefPicList0またはRefPicList1における各ピクチャーaPicについて0以下である場合、NoBackwardPredFlagは1に設定される。
・それ以外の場合、NoBackwardPredFlagは0に等しく設定される。
空間的および時間的マージ候補のほかに、2つの追加的なタイプのマージ候補がある:複合双予測マージ候補とゼロマージ候補である。複合双予測マージ候補は、空間的および時間的マージ候補を利用することによって生成される。複合双予測マージ候補は、Bスライスについてのみ使用される。複合双予測候補は、初期候補の第1の参照ピクチャー・リスト動きパラメータを、別の候補の第2の参照ピクチャー・リスト動きパラメータと組み合わせることによって生成される。これらの2つのタプルが異なる動き仮説を提供するならば、それらは新しい双予測候補をなす。一例として、図7は、mvL0およびrefIdxL0またはmvL1およびrefIdxL1を有するもとのリスト(左側)における2つの候補を使って、最終的なリスト(右側)に追加される複合双予測マージ候補を作成する場合を示している。[1]において定義されているこれらの追加的なマージ候補を生成するために考えられる組み合わせに関する多数の規則がある。
AMVPは、動きパラメータの明示的伝送に使用される、近傍のPUとの動きベクトルの時間空間的相関を利用する。各参照ピクチャー・リストについて、まず左、上の時間的に近傍のPU位置の利用可能性をチェックし、冗長な候補を除去し、ゼロ・ベクトルを追加して候補リストを一定長にすることによって、動きベクトル候補リストが構築される。次いで、エンコーダは候補リストから最良の予測子を選択し、選択された候補を示す対応するインデックスを送信することができる。同様に、マージ・インデックス信号伝達では、最良の動きベクトル候補のインデックスは、打ち切りされた単進法を用いてエンコードされる。この場合にエンコードされるべき最大値は2である(図8参照)。下記の諸節では、動きベクトル予測候補の導出プロセスの詳細を示す。
図8は、動きベクトル予測候補のための導出プロセスをまとめたものである。
空間的動きベクトル候補の導出においては、5つの潜在的候補のうちで最大2つの候補が考慮される。5つの潜在的候補は、図2に示されるような位置に位置するPUから導出され、それらの位置は、動きマージの場合と同じである。現在のPUの左側についての導出の順序は、A0、A1、およびスケーリングされたA0、スケーリングされたA1として定義される。現在のPUの上側についての導出の順序は、B0、B1、B2、スケーリングされたB0、スケーリングされたB1、スケーリングされたB2として定義される。よって、それぞれの側について、動きベクトル候補として使用できる4つの場合があり、2つの場合は空間的スケーリングを使用する必要がなく、2つの場合は空間的スケーリングが使用される。4つの異なる場合は、次のようにまとめられる。
●空間的スケーリングなし
(1)同じ参照ピクチャー・リスト、同じ参照ピクチャー・インデックス(同じPOC)
(2)異なる参照ピクチャー・リストだが、同じ参照ピクチャー(同じPOC)
●空間的スケーリング
(3)同じ参照ピクチャー・リストだが、異なる参照ピクチャー(異なるPOC)
(4)異なる参照ピクチャー・リストおよび異なる参照ピクチャー(異なるPOC)。
参照ピクチャー・インデックスの導出は別として、時間的マージ候補の導出のためのすべてのプロセスは、空間的動きベクトル候補の導出のためのものと同じである(図6を参照)。参照ピクチャー・インデックスはデコーダに信号伝達される。
インター予測改善のためのいくつかの新しい符号化ツールがある。たとえば、MVDを信号伝達するための適応動きベクトル差分解能(Adaptive Motion Vector difference Resolution、AMVR)、動きベクトル差を用いたマージ(Merge with Motion Vector Differences、MMVD)、三角予測モード(Triangular prediction mode、TPM)、復号イントラ‐インター予測(Combined intra-inter prediction、CIIP)、先進TMVP(Advanced TMVP、ATMVP、SbTMVPともいう)、アフィン予測モード、一般化双予測(Generalized Bi-Prediction、GBI)、デコーダ側動きベクトル洗練(Decoder-side Motion Vector Refinement、DMVR)、および双方向オプティカルフロー(Bi-directional Optical flow、BIO、BDOFともいう)などである。
1)サブブロック・マージ候補リスト:これは、ATMVP、アフィン・マージ候補を含む。アフィン・モードとATMVPモードの両方について、1つのマージ・リスト構築プロセスが共有される。ここで、ATMVPとアフィン・マージ候補が順次追加されてもよい。サブブロック・マージ・リストのサイズはスライスヘッダで信号伝達され、最大値は5である。
2)通常マージ・リスト:インター符号化されるブロックについて、1つのマージ・リスト構築プロセスが共有される。ここで、空間的/時間的マージ候補、HMVP、ペアワイズ・マージ候補、およびゼロ動き候補は、順に挿入されてもよい。通常マージ・リストのサイズはスライスヘッダで信号伝達され、最大値は6である。MMVD、TPM、CIIPは、通常マージ・リストに頼る。
3)IBCマージ・リスト:これは、通常マージ・リストと同様の仕方でなされる。
1)アフィンAMVP候補リスト
2)通常のAMVP候補リスト
3)IBC AMVP候補リスト:JVET-N0843の採用によるIBCマージ・リストと同じ構築プロセス
VVCでは、ピクチャーを正方形ブロックまたは長方形ブロックに分割する四分木/二分木/三分木(QT/BT/TT)構造が採用されている。
HEVCでは、並進動きモデルのみが動き補償予測(motion compensation prediction、MCP)のために適用される。現実世界では、ズームイン/アウト、回転、透視法的な動き(perspective motions)、その他の不規則な動きなど、多くの種類の動きがある。VVCでは、簡略化されたアフィン変換動き補償予測が4パラメータ・アフィン・モデルと6パラメータ・アフィン・モデルを用いて適用される。図10に示されるように、ブロックのアフィン動き場は、4パラメータ・アフィン・モデルについては2つの制御点動きベクトル(CPMV)によって、6パラメータ・アフィン・モデルについては3つのCPMVによって記述される。
2.2.3.1 並進通常マージ・モードのマージ・リスト構築
2.2.3.1.1 履歴ベースの動きベクトル予測(HMVP)
マージ・リスト設計とは異なり、VVCでは、履歴ベースの動きベクトル予測(history-based motion vector prediction、HMVP)法が用いられる。
通常マージ・リスト(並進動き用)の構築は、次の一連のステップに従って要約できる:
●ステップ1:空間的候補の導出
●ステップ2:HMVP候補の挿入
●ステップ3:ペアワイズ平均候補の挿入
●ステップ4:デフォルトの動き候補
候補は、冗長検査のために使用される対応する候補が同じ動き情報をもたない場合にのみ、リストに追加される。そのような比較プロセスは、剪定〔プルーニング〕プロセスと呼ばれる。
VVCでは、インター予測のために三角形分割モードがサポートされている。三角形分割モードは、8×8以上のCUにのみ適用され、マージ・モードでは符号化されるが、MMVDまたはCIIPモードでは適用されない。これらの条件を満たすCUについて、CUレベルのフラグが、三角形分割モードが適用されるか否かを示すために信号伝達される。
基本的には、JVET-N0340で提案されているように、通常マージ・リスト構築プロセスが適用される。しかしながら、いくつかの修正が追加される。
1)剪定プロセスをどのように行うかは、現在ブロックについてのTPMの使用に依存する。
・現在ブロックがTPMで符号化されるのでない場合は、空間的マージ候補に適用されるHEVCの5剪定が呼び出される。
・そうでない場合(現在ブロックがTPMで符号化される場合)、新しい空間的マージ候補を追加するときに、完全な剪定が適用される。すなわち、B1はA1と比較され、B0はA1およびB1と比較され、A0はA1、B1およびB0と比較され、B2はA1、B1、A0およびB0と比較される。
2)B2からの動き情報をチェックするかどうかに関する条件は、現在ブロックについてのTPMの使用に依存する。
・現在ブロックがTPMで符号化されない場合、B2をチェックする前の空間的マージ候補が4つ未満の場合にのみ、B2がアクセスされ、チェックされる。
・そうでない場合(現在ブロックがTPMで符号化される場合)、B2は、B2を追加する前に、利用可能な空間的マージ候補がいくつであるかに関係なく、常にアクセスされ、チェックされる。
各三角形予測単位を予測した後、適応重み付けプロセスが、2つの三角形予測単位の間の対角線エッジに適用され、CU全体についての最終的な予測が導出される。2つの重み付け因子群が、以下のように定義される:
・第1の重み付け因子群:{7/8、6/8、4/8、2/8、1/8}および{7/8、4/8、1/8}は、それぞれルミナンスおよびクロミナンス・サンプルのために使用される;
・第2の重み付け因子群:{7/8、6/8、5/8、4/8、3/8、2/8、1/8}および{6/8、4/8、2/8}は、それぞれルミナンスおよびクロミナンス・サンプルのために使用される。
・2つの三角形予測単位の参照ピクチャーが互いに異なっている
・2つの動きベクトルの水平方向の値の差の絶対値が16ピクセルより大きい
・2つの動きベクトルの垂直方向の値の差の絶対値が16ピクセルより大きい。
三角形予測単位の動きベクトル(図16のMv1およびMv2)は、4×4グリッドに格納される。4×4グリッドごとに、CU内の4×4グリッドの位置に依存して、単予測または双予測動きベクトルが格納される。図16に示されるように、Mv1またはMv2のいずれかの単予測動きベクトルが、重み付けされない領域に位置する(すなわち、対角線エッジに位置しない)4×4グリッドについて格納される。一方、重み付けされる領域に位置する4×4グリッドについては、双予測動きベクトルが格納される。双予測動きベクトルは、以下の規則に従ってMv1とMv2から導出される:
1)Mv1とMv2が異なる方向(L0またはL1)からの動きベクトルを有する場合、Mv1とMv2が単純に組み合わされて、双予測動きベクトルを形成する。
2)Mv1とMv2の両方が同じL0(またはL1)方向からである場合、
・Mv2の参照ピクチャーがL1(またはL0)参照ピクチャー・リスト内のあるピクチャーと同じである場合、Mv2はそのピクチャーに合わせてスケーリングされる。Mv1とスケーリングされたMv2が組み合わされて、双予測動きベクトルを形成する。
・Mv1の参照ピクチャーがL1(またはL0)参照ピクチャー・リスト内のあるピクチャーと同じである場合、Mv1はそのピクチャーに合わせてスケーリングされる。スケーリングされたMv1とMv2が組み合わされて、双予測動きベクトルを形成する。
・それ以外の場合は、重み付けされた領域について、Mv1のみが格納される。
2.2.4.4 マージ・モードについての構文テーブル、意味内容、デコード・プロセス
7.3.5.1 一般的なスライスヘッダ構文
six_minus_max_num_merge_candは、スライスにおいてサポートされるマージ動きベクトル予測(MVP)候補の最大数を6から引いたものを指定する。マージMVP候補の最大数MaxNumMergeCandは、次のように導出される:
MaxNumMergeCand=6-six_minus_max_num_merge_cand (7-57)
five_minus_max_num_subblock_merge_candは、スライスにおいてサポートされるサブブロック・ベースのマージ動きベクトル予測(MVP)候補の最大数を5から引いたものを指定する。five_minus_max_num_subblock_merge_candが存在しない場合は、5-sps_sbtmvp_enabled_flagに等しいと推定される。サブブロック・ベースのマージMVP候補の最大数MaxNumSubblockMergeCandは、次のように導出される:
MaxNumSubblockMergeCand=5-five_minus_max_num_subblock_merge_cand (7-58)
7.4.8.5 符号化単位セマンティクス
pred_mode_flagが0に等しいことは、現在の符号化単位がインター予測モードで符号化されることを指定する。pred_mode_flagが1に等しいことは、現在の符号化単位がイントラ予測モードで符号化されることを指定する。
・cbWidthが4に等しく、cbHeightが4に等しい場合、pred_mode_flagは1に等しいと推定される。
・それ以外の場合、pred_mode_flagは、Iスライスをデコードするときは1に等しく、PまたはBスライスをデコードするときはそれぞれ0に等しいと推測される。
・pred_mode_flagが0に等しい場合、CuPredMode[x][y]はMODE_INTERに等しく設定される。
・それ以外の場合(pred_mode_flagが1に等しい場合)、CuPredMode[x][y]はMODE_INTRAに等しく設定される。
pred_mode_ibc_flagが1に等しいことは、現在の符号化単位がIBC予測モードで符号化されることを指定する。pred_mode_ibc_flagが0に等しいことは、現在の符号化単位がIBC予測モードで符号化されないことを指定する。
・cu_skip_flag[x0][y0]が1に等しく、cbWidthが4に等しく、cbHeightが4に等しい場合、pred_mode_ibc_flagは1と推定される。
・それ以外の場合、cbWidthとcbHeightの両方が128に等しい場合、pred_mode_ibc_flagは0に等しいと推定される。
・それ以外の場合、pred_mode_ibc_flagは、Iスライスをデコードする場合はsps_ibc_enabled_flagの値に等しいと推定され、PまたはBスライスをデコードする場合は0に等しいと推定される。
general_merge_flag[x0][y0]は、現在の符号化単位のためのインター予測パラメータが近傍のインター予測されたパーティションから推定されるかどうかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・cu_skip_flag[x0][y0]が1に等しい場合、general_merge_flag[x0][y0]は1に等しいと推定される。
・それ以外の場合、general_merge_flag[x0][y0]は0と推定される。
mvp_l0_flag[x0][y0]は、リスト0の動きベクトル予測子インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
mvp_l1_flag[x0][y0]は、mvp_l0_flagと同じ意味内容をもち、l0とリスト0がそれぞれl1とリスト1に置き換えられる。
inter_pred_idc[x0][y0]は、テーブル7-10に従って、現在の符号化単位についてリスト0、リスト1または双予測が使用されるかどうかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
7.4.8.7 マージ・データのセマンティクス
regular_merge_flag[x0][y0]が1に等しいことは、現在の符号化単位のインター予測パラメータを生成するために、通常マージ・モードが使用されることを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・以下の条件がすべて真である場合、regular_merge_flag[x0][y0]は1に等しいと推定される:
・sps_mmvd_enabled_flagが0に等しい。
・general_merge_flag[x0][y0]が1に等しい。
・cbWidth*cbHeightが32に等しい。
・そうでない場合、regular_merge_flag[x0][y0]は0に等しいと推定される。
mmvd_merge_flag[x0][y0]が1に等しいことは、現在の符号化単位のインター予測パラメータを生成するために、動きベクトル差を用いたマージ・モードが使用されることを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・以下の条件がすべて真である場合、mmvd_merge_flag[x0][y0]は1に等しいと推定される:
・sps_mmvd_enabled_flagが1に等しい。
・general_merge_flag[x0][y0]が1に等しい。
・cbWidth*cbHeightが32に等しい。
・regular_merge_flag[x0][y0]が0に等しい。
・それ以外の場合、mmvd_merge_flag[x0][y0]は0に等しいと推定される。
mmvd_cand_flag[x0][y0]は、マージ候補リストにおける第1の候補(0)または第2の候補(1)のどちらが、mmvd_distance_idx[x0][y0]とmmvd_direction_idx[x0][y0]から導出された動きベクトル差とともに使用されるかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
MmvdOffset[x0][y0][0]=(MmvdDistance[x0][y0]<<2)*MmvdSign[x0][y0][0] (7-124)
MmvdOffset[x0][y0][1]=(MmvdDistance[x0][y0]<<2)*MmvdSign[x0][y0][1] (7-125)
merge_subblock_flag[x0][y0]は、現在の符号化単位についてのサブブロック・ベースのインター予測パラメータが近傍ブロックから推定されるかどうかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。merge_subblock_flag[x0][y0]が存在しない場合、0に等しいと推定される。
merge_subblock_idx[x0][y0]は、サブブロック・ベースのマージ候補リストのマージ候補インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
ciip_flag[x0][y0]は、現在の符号化単位について、ピクチャー間マージおよびピクチャー内予測の組み合わせが適用されるかどうかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・以下の条件がすべて満たされている場合、MergeTriangleFlag[x0][y0]は1に設定される:
・sps_triangle_enabled_flagは1に等しい。
・slice_typeはBに等しい。
・general_merge_flag[x0][y0]は1に等しい。
・MaxNumTriangleMergeCandが2以上である。
・cbWidth*cbHeightが64以上である。
・regular_merge_flag[x0][y0]が0に等しい。
・mmvd_merge_flag[x0][y0]が0に等しい。
・merge_subblock_flag[x0][y0]が0に等しい。
・cip_flag[x0][y0]が0に等しい。
・それ以外の場合、MergeTriangleFlag[x0][y0]は0に設定される。
merge_triangle_split_dir[x0][y0]は、マージ三角モードの分割方向を指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
merge_triangle_idx0[x0][y0]は、三角形形状に基づく動き補償候補リストの第1のマージ候補インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
merge_triangle_idx1[x0][y0]は、三角形形状に基づく動き補償候補リストの第2のマージ候補インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
merge_idx[x0][y0]は、マージ候補リストのマージ候補インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されている符号化ブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・mmvd_merge_flag[x0][y0]が1に等しい場合、merge_idx[x0][y0]は、mmvd_cand_flag[x0][y0]に等しいと推定される。
・それ以外の場合(mmvd_merge_flag[x0][y0]が0に等しい場合)、merge_idx[x0][y0]は0に等しいと推定される。
JVET-N0340において規定されているデコード・プロセスは、以下のように定義される。
このプロセスは、general_merge_flag[xCb][yCb]が1に等しい場合にのみ呼び出される。ここで、(xCb,yCb)は、現在のピクチャーの左上のルーマ・サンプルに対して現在のルーマ符号化ブロックの左上のサンプルを指定する。
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマ符号化ブロックの左上のサンプルのルーマ位置(xCb,yCb)、
・ルーマ・サンプル単位で現在の符号化ブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位で現在の符号化ブロックの高さを指定する変数cbHeight。
・1/16の端数サンプル精度でのルーマ動きベクトルmvL0[0][0]およびmvL1[0][0]、
・参照インデックスrefIdxL0およびrefIdxL1、
・予測リスト利用フラグpredFlagL0[0][0]およびpredFlagL1[0][0]、
・双予測重み指数bcwIdx、
・マージ候補リストmergeCandList。
1. 節8.5.2.3において指定されている近傍の符号化単位からの空間的マージ候補についての導出プロセスが、ルーマ符号化ブロック位置(xCb,yCb)、ルーマ符号化ブロック幅(cbWidth)、ルーマ符号化ブロック高さ(cbHeight)を入力として呼び出され、出力は、利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2、参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2、予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2、動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2(Xは0または1)、双予測重みインデックスbcwIdxA0、bcwIdxA1、bcwIdxB1、bcwIdxB2である。
2. 時間マージ候補Colについての参照インデックスrefIdxLXCol(Xは0または1)および双予測重みインデックスbcwIdxColが0に設定される。
3. 節8.5.2.11で指定されている時間的ルーマ動きベクトル予測のための導出プロセスが、ルーマ位置(xCb,yCb)、ルーマ符号化ブロック幅cbWidth、ルーマ符号化ブロック高さcbHeight、変数refIdxL0Colを入力として呼び出され、出力は利用可能性フラグavailableFlagL0Col、時間的動きベクトルmvL0Colである。変数availableFlagCol、predFlagL0ColおよびpredFlagL1Colは、次のように導出される:
availableFlagCol=availableFlagL0Col (8-263)
predFlagL0Col=availableFlagL0Col (8-264)
predFlagL1Col=0 (8-265)
4. slice_typeがBに等しい場合、節8.5.2.11で指定されている時間的ルーマ動きベクトル予測のための導出プロセスが、ルーマ位置(xCb,yCb)、ルーマ符号化ブロック幅cbWidth、ルーマ符号化ブロック高さcbHeight、変数refIdxL1Colを入力として呼び出され、出力は、利用可能性フラグavailableFlagL1Col、時間的動きベクトルmvL1Colである。変数availableFlagColおよびpredFlagL1Colは、次のように導出される:
availableFlagCol=availableFlagL0Col||availableFlagL1Col (8-266)
predFlagL1Col=availableFlagL1Col (8-267)
5. マージ候補リストmergeCandListは、次のように構築される:
7. numCurrMergeCandが(MaxNumMergeCand-1)より小さく、かつNumHmvpCandが0より大きい場合、次が適用される:
・節8.5.2.6において規定されている履歴ベースのマージ候補の導出プロセスが呼び出される。入力は、mergeCandListおよびnumCurrMergeCand、出力は修正されたmergeCandListおよびnumCurrMergeCand。
・numOrigMergeCandはnumCurrMergeCandと等しく設定される。
8. numCurrMergeCandがMaxNumMergeCandより小さく、かつ1より大きい場合、次が適用される:
・節8.5.2.4において指定されているペアワイズ平均マージ候補についての導出プロセスが、mergeCandList、参照インデックスrefIdxL0NおよびrefIdxL1N、予測リスト利用フラグpredFlagL0NおよびpredFlagL1N、mergeCandList内の各候補Nの動きベクトルmvL0NおよびmvL1N、およびnumCurrMergeCandを入力として呼び出され、出力は、mergeCandList、numCurrMergeCand、参照インデックスrefIdL0avgCandおよびrefIdxL1avgCand、予測リスト利用フラグpredFlagL0avgCandおよびpredFlagL1avgCand、およびmergeCandListに追加される候補avgCandの動きベクトルmvL0avgCandおよびmvL1avgCandに割り当てられる。mergeCandListに追加される候補avgCandの双予測重みインデックスbcwIdxが0に設定される。
・numOrigMergeCandはnumCurrMergeCandに等しく設定される。
9. 節8.5.2.5において指定されるゼロ動きベクトル・マージ候補の導出プロセスが、mergeCandList、参照インデックスrefIdxL0NおよびrefIdxL1N、予測リスト利用フラグpredFlagL0NおよびpredFlagL1N、mergeCandList内の各候補Nの動きベクトルmvL0NおよびmvL1NおよびnumCurrMergeCandを入力として呼び出され、出力は、mergeCandList、numCurrMergeCand、参照インデックスrefIdxL0zeroCandmおよびRefIdxL1zeroCandm、予測リスト利用フラグpredFlagL0zeroCandmおよびpredL1zeroCandm、ならびにmergeCandListに追加される各新規候補zeroCandmの動きベクトルmvL0zeroCandmおよびmvL1zeroCandmに割り当てられる。mergeCandListに追加されるすべての新しい候補zeroCandmの双予測重みインデックスbcwIdxは、0に等しく設定される。追加される候補の数numZeroMergeCandは(numCurrMergeCand-numOrigMergeCand)に等しく設定される。numZeroMergeCandが0より大きい場合、mの範囲は0からnumZeroMergeCand-1である(両端含む)。
10. 以下の割り当てがなされる。ここで、Nは、マージ候補リストmergeCandListにおける位置merge_idx[xCb][yCb]における候補であり(N=mergeCandList[merge_idx[xCb][yCb]])、Xは0または1で置き換えられる:
refIdxLX=refIdxLXN (8-269)
predFlagLX[0][0]=predFlagLXN (8-270)
mvLX[0][0][0]=mvLXN[0] (8-271)
mvLX[0][0][1]=mvLXN[1] (8-272)
bcwIdx=bcwIdxN (8-273)
11. mmvd_merge_flag[xCb][yCb]が1に等しい場合、以下が適用される:
・節8.5.2.7において指定されるマージ動きベクトル差のための導出プロセスが、ルーマ位置(xCb,yCb)、参照インデックスrefIdxL0、refIdxL1、予測リスト利用フラグpredFlagL0[0][0]、predFlagL1[0][0]を入力として呼び出される。出力は、動きベクトル差mMvdL0、mMvdL1。
・X=0、1について、動きベクトル差mMvdLXがマージ動きベクトルmvLXに、次のように加算される:
mvLX[0][0][0]+=mMvdLX[0] (8-274)
mvLX[0][0][1]+=mMvdLX[1] (8-275)
mvLX[0][0][0]=Clip3(-217,217-1,mvLX[0][0][0]) (8-276)
mvLX[0][0][1]=Clip3(-217,217-1,mvLX[0][0][1]) (8-277)
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマ符号化ブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在の符号化ブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在の符号化ブロックの高さを指定する変数cbHeight。
・近傍の符号化単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍の符号化単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍の符号化単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍の符号化単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
・availableA1がFALSEに等しい場合、availableFlagA1が0に等しく設定され、X=0または1として、mvLXA1の両成分が0に等しく設定され、refIdxLXA1が-1に等しく設定され、predFlagLXA1が0に等しく設定され、gbiIdxA1が0に等しく設定される。
・それ以外の場合、availableFlagA1は1に等しく設定され、以下の割り当てが行われる:
mvLXA1=MvLX[xNbA1][yNbA1] (8-294)
refIdxLXA1=RefIdxLX[xNbA1][yNbA1] (8-295)
predFlagLXA1=PredFlagLX[xNbA1][yNbA1] (8-296)
gbiIdxA1=GbiIdx[xNbA1][yNbA1] (8-297)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB1,yNbB1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB1に割り当てられる。
・変数availableFlagB1、refIdxLXB1、predFlagLXB1、mvLXB1は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB1が0に等しく設定され、X=0または1として、mvLXB1の両方の成分が0に等しく設定され、refIdxLXB1が-1に等しく設定され、predFlagLXB1が0に等しく設定され、gbiIdxB1が0に設定される:
・availableB1が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB1,yNbB1)は同じ動きベクトルと同じ参照インデックスをもつ。
・それ以外の場合、availableFlagB1は1に等しく設定され、以下の割り当てが行われる:
mvLXB1=MvLX[xNbB1][yNbB1] (8-298)
refIdxLXB1=RefIdxLX[xNbB1][yNbB1] (8-299)
predFlagLXB1=PredFlagLX[xNbB1][yNbB1] (8-300)
gbiIdxB1=GbiIdx[xNbB1][yNbB1] (8-301)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB0,yNbB0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB0に割り当てられる。
・変数availableFlagB0、refIdxLXB0、predFlagLXB0、mvLXB0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB0が0に等しく設定され、X=0または1として、mvLXB0の両方の成分が0に等しく設定され、refIdxLXB0が-1に等しく設定され、predFlagLXB0が0に等しく設定され、gbiIdxB0が0に設定される:
・availableB0が偽に等しい。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・それ以外の場合は、availableFlagB0が1に設定され、以下の割り当てが行われる:
mvLXB0=MvLX[xNbB0][yNbB0] (8-302)
refIdxLXB0=RefIdxLX[xNbB0][yNbB0] (8-303)
predFlagLXB0=PredFlagLX[xNbB0][yNbB0] (8-304)
gbiIdxB0=GbiIdx[xNbB0][yNbB0] (8-305)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA0,yNbA0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA0に割り当てられる。
・変数availableFlagA0、refIdxLXA0、predFlagLXA0、mvLXA0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagA0が0に等しく設定され、X=0または1として、mvLXA0の両方の成分が0に等しく設定され、refIdxLXA0が-1に等しく設定され、predFlagLXA0が0に等しく設定され、gbiIdxA0が0に設定される:
・availableA0が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもち、merge_triangle_flag[xCb][yCb]は1に等しい。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもち、merge_triangle_flag[xCb][yCb]は1に等しい。
・それ以外の場合は、availableFlagA0が1に設定され、以下の割り当てが行われる:
mvLXA0=MvLX[xNbA0][yNbA0] (8-306)
refIdxLXA0=RefIdxLX[xNbA0][yNbA0] (8-307)
predFlagLXA0=PredFlagLX[xNbA0][yNbA0] (8-308)
gbiIdxA0=GbiIdx[xNbA0][yNbA0] (8-309)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもち、merge_triangle_flag[xCb][yCb]は1に等しい。
・availableA0が真に等しく、ルーマ位置(xNbA0,yNbA0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもち、merge_triangle_flag[xCb][yCb]は1に等しい。
・availableFlagA0+availableFlagA1+availableFlagB0+availableFlagB1が4に等しく、merge_triangle_flag[xCb][yCb]が0に等しい。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
JVET-L0054では、極限動きベクトル表式(UMVE、MMVDとしても知られる)が提起されている。UMVEは、提案された動きベクトル表現法を用いて、スキップまたはマージ・モードのいずれかのために使用される。
JVET-L0100では、複数仮説予測が提案され、そこでは、イントラ予測とインター予測の組み合わせが、複数の仮説を生成するための1つの方法となる。
すべてのサブブロック関連動き候補は、非サブブロック・マージ候補のための通常のマージ・リストに追加される、別個のマージ・リストに入れられることが提案される。
a.ATMVP候補(利用可能であることも利用可能でないこともある);
b.アフィン・マージ・リスト(継承されたアフィン候補;および構築されたアフィン候補を含む);
c.ゼロMV 4パラメータ・アフィン・モデルとしてのパディング。
ATMVPの基本的なアイデアは、1ブロックについての時間的動きベクトル予測子の複数の集合を導出するというものである。各サブブロックには、1組の動き情報を割り当てられる。ATMVPマージ候補が生成されると、ブロック全体のレベルではなく、8×8レベルで動き補償が行われる。
初期化された動きベクトルをtempMvで表す。ブロックA1が利用可能であり、かつイントラ符号化されない場合(すなわち、インターまたはIBCモードで符号化される場合)、初期化された動きベクトルを導出するために、以下が適用される。
・以下の条件がすべて真である場合、tempMvは、mvL1A1で示される、リスト1のブロックA1の動きベクトルに等しく設定される:
・リスト1の参照ピクチャー・インデックスが利用可能であり(-1に等しくない)、共位置のピクチャーと同じPOC値をもつ(すなわち、DiffPicOrderCnt(ColPic,RefPicList[1][refIdxL1A1])が0に等しい)、
・すべての参照ピクチャーは現在のピクチャーと比較して、より大きなPOCを持たない(すなわち、DiffPicOrderCnt(aPic,currentPic)は、現在のスライスのすべての参照ピクチャー・リスト内のすべてのピクチャーaPicについて0以下である)、
・現在のスライスはBスライスに等しい、
・collocated_from_l0_flagが0に等しい。
・それ以外の場合、以下の条件がすべて真である場合、tempMvは、mvL0A1で示される、リスト0からのブロックA1の動きベクトルに等しく設定される:
・リスト0の参照ピクチャー・インデックスが利用可能である(-1に等しくない)、
・共位置のピクチャーと同じPOC値をもつ(すなわち、DiffPicOrderCnt(ColPic,RefPicList[0][refIdxL0A1])が0に等しい)。
・それ以外の場合、ゼロ動きベクトルが初期化されたMVとして使用される。
第2のステップは、現在のCUをサブCUに分割し、共位置のピクチャー内の各サブCUに対応するブロックから各サブCUの動作情報を取得することである。
このプロセスへの入力は以下の通りである:
・現在の符号化ブロックを指定する変数currCb、
・ColPicによって指定された共位置のピクチャー内の共位置の符号化ブロックを指定する変数colCb、
・ColPicによって指定された共位置のピクチャーの左上のルーマ・サンプルに対して、colCbによって指定された共位置のルーマ符号化ブロックの左上のサンプルを指定するルーマ位置(xColCb,yColCb)、
・参照インデックスrefIdxLX、Xは0または1、
・サブブロックの時間的マージ候補sbFlagを示すフラグ。
・1/16端数サンプル精度での動きベクトル予測mvLXCol、
・利用可能性フラグavailableFlagLXCol。
・colCbがイントラまたはIBC予測モードで符号化される場合、mvLXColの両方の成分が0に等しく設定され、availableFlagLXColが0に等しく設定される。
・それ以外の場合、動きベクトルmvCol、参照インデックスrefIdxCol、参照リスト識別子listColは以下のように導出される:
・sbFlagが0に等しい場合、availableFlagLXColは1に等しく設定され、以下が適用される:
・predFlagL0Col[xColCb][yColCb]が0に等しい場合、mvCol、refIdxCol、listColはそれぞれmvL1Col[xColCb][yColCb]、refIdxL1Col[xColCb][yColCb]、L1に等しく設定される。
・それ以外の場合、predFlagL0Col[xColCb][yColCb]が1に等しく、predFlagL1Col[xColCb][yColCb]が0に等しい場合、mvCol、refIdxCol、listColは、それぞれ、mvL0Col[xColCb][yColCb]、refIdxL0Col[xColCb][yColCb]、L0に等しく設定される。
・それ以外の場合(predFlagL0Col[xColCb][yColCb]が1に等しく、predFlagL1Col[xColCb][yColCb]が1に等しい場合)、以下の割り当てが行われる:
・NoBackwardPredFlagが1に等しい場合、mvCol、refIdxCol、listColはそれぞれmvLXCol[xColCb][yColCb]、refIdxLXCol[xColCb][yColCb]、LXに等しく設定される。
・それ以外の場合、mvCol、refIdxCol、listColはそれぞれmvLNCol[xColCb][yColCb]、refIdxLNCol[xColCb][yColCb]、LNに等しく設定され、Nはcollocated_from_l0_flagの値である。
・それ以外の場合(sbFlagが1に等しい)、以下が適用される:
・PredFlagLXCol[xColCb][yColCb]が1に等しい場合、mvCol、refIdxCol、listColはそれぞれmvLXCol[xColCb][yColCb]、refIdxLXCol[xColCb][yColCb]、LXに等しく設定され、availableFlagLXColは1に等しく設定される。
・それ以外の場合(PredFlagLXCol[xColCb][yColCb]が0に等しい場合)、以下が適用される:
・DiffPicOrderCnt(aPic,currPic)が現在のスライスのすべての参照ピクチャー・リストのすべてのピクチャーaPicについて0以下であり、PredFlagLYCol[xColCb][YColCb]が1に等しく、mvCol、refIdxCol、listColはそれぞれmvLYCol[xColCb][yColCb]、refIdxLYCol[xColCb][yColCb]、LYに設定され、Yは!Xに等しく、Xはこのプロセスが呼び出されるXの値である。availableFlagLXColが1に設定される。
・mvLXColの両方の成分が0に設定され、availableFlagLXColは0に等しく設定される。
・availableFlagLXColがTRUEに等しい場合、mvLXColおよびavailableFlagLXColは次のように導出される:
・LongTermRefPic(currPic,currCb,refIdxLX,LX)がLongTermRefPic(ColPic,colCb,refIdxCol,listCol)に等しい場合、mvLXColの両方の成分は0に等しく設定され、availableFlagLXColは0に等しく設定される。
・それ以外の場合、変数availableFlagLXColは1に等しく設定され、refPicList[listCol][refIdxCol]は、ColPicによって指定される共位置のピクチャーにおける符号化ブロックcolCbを含むスライスの参照ピクチャー・リストlistColにおける参照インデックスrefIdxColをもつピクチャーに設定され、以下が適用される:
colPocDiff=DiffPicOrderCnt(ColPic,refPicList[listCol][refIdxCol]) (8-402)
currPocDiff=DiffPicOrderCnt(currPic,RefPicList[X][refIdxLX]) (8-403)
・節8.5.2.15において指定される共位置の動きベクトルについての時間的動きバッファ圧縮プロセスが、mvColを入力、修正されたmvColを出力として呼び出される。
・RefPicList[X][refIdxLX]が長期の参照ピクチャーであるか、またはcolPocDiffがcurrPocDiffと等しい場合、mvLXColは次のように導出される:
mvLXCol=mvCol (8-404)
・それ以外の場合、mvXColは以下のように動きベクトルmvColのスケーリングされたバージョンとして導出される:
tx=(16384+(Abs(td)>>1))/td (8-405)
distScaleFactor=Clip3(-4096,4095,(tb*tx+32)>>6) (8-406)
mvLXCol=Clip3(-131072,131071,(distScaleFactor*mvCol+
128-(distScaleFactor*mvCol>=0))>>8)) (8-407)
ここで、tdとtbは次のように導出される:
td=Clip3(-128,127,colPocDiff) (8-408)
tb=Clip3(-128,127,currPocDiff) (8-409)
2.2.8.1 AMVP動き候補リスト
HEVCにおけるAMVP設計と同様に、2つまでのAMVP候補が導出されうる。しかしながら、HMVP候補はTMVP候補の後に追加されてもよい。HMVPテーブル内のHMVP候補は、インデックスの昇順で(すなわち、最も古いものである0に等しいインデックスから)たどられ、4つまでのHMVP候補が、その参照ピクチャーがターゲット参照ピクチャーと同じである(すなわち、同じPOC値)かどうかを見出すためにチェックされてもよい。
HEVCでは、スライスヘッダにおいてuse_integer_mv_flagが0に等しいとき、(PUの動きベクトルと予測された動きベクトルとの間の)動きベクトル差分(MVD)が、4分の1ルーマ・サンプルの単位で信号伝達される。VVCでは、局所的に適応的な動きベクトル分解能(adaptive motion vector resolution、AMVR)が導入される。VVCでは、MVDは、4分の1ルーマ・サンプル、整数ルーマ・サンプル、または4ルーマ・サンプル(すなわち、1/4画素、1画素、4画素)の単位で符号化できる。MVD分解能は、符号化単位(CU)レベルで制御され、MVD分解能フラグは、少なくとも1つのゼロでないMVD成分を有する各CUについて、条件付きで信号伝達される。
JVET-N1001-v2では、対称動きベクトル差分(symmetric motion vector difference、SMVD)が双予測における動き情報符号化のために適用される。
2.2.9.1 デコーダ側動きベクトル洗練(DMVR)
双予測動作では、1つのブロック領域の予測のために、それぞれlist0の動きベクトル(MV)とlist1のMVを用いて形成された2つの予測ブロックが組み合わされて、単一の予測信号を形成する。デコーダ側動きベクトル洗練(decoder-side motion vector refinement、DMVR)法では、双予測の2つの動きベクトルがさらに洗練される。
MvdX=-1;
MvdY=-1;
If(Sad(1,0)<Sad(-1,0))
MvdX=1;
If(Sad(0,1)<Sad(0,-1))
MvdY=1;
・list0とlist1の間の(0,0)位置SADが閾値より小さい場合は、早期終了。
・list0とlist1の間のSADが何らかの位置についてゼロである場合、早期終了。
・DMVRについてのブロック・サイズ:W*H>=64 && H>=8。ここで、WとHはブロックの幅と高さである。
・CUサイズ>16×16のDMVRについて、CUを16×16のサブブロックの複数に分割する。
・CUの幅または高さのみが16より大きい場合、垂直方向または水平方向にのみ分割される。
・参照ブロック・サイズ(W+7)*(H+7)(ルーマ用)。
・25点のSADベースの整数画素探索(すなわち(±)2洗練探索範囲、単一ステージ)
・双線形補間ベースのDMVR。
・「パラメトリック誤差面の式(Parametric error surface equation)」に基づくサブ画素洗練。
・この手順は、最後のMV洗練反復工程において、最小のSADコストがゼロに等しくなく、最良のMVDが(0,0)である場合にのみ、実行される。
・参照ブロック・パディングを伴う(必要な場合)、ルーマ/クロマMC。
・MCおよびTMVPのみのために使用される洗練されたMV。
以下の条件がすべて真である場合、DMVRが有効にされてもよい。
・SPSにおけるDMVR有効化フラグ(すなわちsps_dmvr_enabled_flag)が1に等しい
・TPMフラグ、インター・アフィン・フラグ、サブブロック・マージ・フラグ(ATMVPまたはアフィン・マージ)、MMVDフラグがすべて0に等しい
・マージ・フラグが1に等しい
・現在ブロックは双予測され、現在のピクチャーとリスト1内の参照ピクチャーとの間のPOC距離は、リスト0内の参照ピクチャーと現在のピクチャーとの間のPOC距離に等しい
・現在のCU高さが8以上
・ルーマ・サンプルの数(CU幅*高さ)が64以上。
本方法は、下記に要約される:
1. パラメトリック誤差面フィットは、中心位置が所与の反復工程において最良のコスト位置である場合にのみ計算される。
2. 中心位置コストと中心から(-1,0)、(0,-1)、(1,0)および(0,1)位置でのコストが、
E(x,y)=A(x-x0)2+B(y-y0)2+C
の形の二次元の放物状の誤差面の式にフィットするために使用される。ここで、(x0,y0)は最小コストの位置に対応し、Cは最小コスト値に対応する。5つの未知数の5つの方程式を解くことによって、(x0,y0)は次のように計算される:
x0=(E(-1,0)-E(1,0))/(2(E(-1,0)+E(1,0)-2E(0,0)))
y0=(E(0,-1)-E(0,1))/(2(E(0,-1)+E(0,1)-2E(0,0)))
(x0,y0)は、除算が実行される精度(すなわち、商の何ビットが計算されるか)を調整することによって、任意の必要なサブピクセル精度まで計算できる。1/16画素の精度のためには、商の絶対値の4ビットが計算されるだけでよく、これは、CUごとに必要な2つの除算の高速シフトされる減算ベースの実装に役立つ。計算された(x0,y0)は、整数距離洗練MVに加算されて、サブピクセル精度の洗練デルタMVを得る。
HEVCスクリーンコンテンツ符号化拡張(HEVC-SCC)および現在のVVCテストモデル(VTM-4.0)では、現在のピクチャー参照としても知られるイントラブロックコピー(IBC)が採用されている。IBCは、動き補償の概念をフレーム間符号化からフレーム内符号化に拡張するものである。図21に示されているように、IBCが適用されるとき、現在ブロックは、同じピクチャー内の参照ブロックによって予測される。参照ブロック内のサンプルは、現在ブロックが符号化または復号される前にすでに再構成されていなければならない。IBCは、ほとんどのカメラ捕捉されたシーケンスについてはそれほど効率的ではないが、スクリーンコンテンツについては顕著な符号化利得を示す。その理由は、スクリーンコンテンツピクチャーにはアイコンやテキスト文字などの反復パターンが多数存在することである。IBCは、これらの反復パターン間の冗長性を効果的に除去することができる。HEVC-SCCでは、インター符号化される符号化単位(CU)は、現在のピクチャーをその参照ピクチャーとして選択する場合、IBCを適用することができる。この場合、MVはブロックベクトル(BV)に名称変更され、BVは常に整数ピクセル精度をもつ。メインプロファイルHEVCとの互換性を保つために、現在のピクチャーは、デコードピクチャーバッファ(DPB)において「長期」参照ピクチャーとしてマークされる。同様に、マルチビュー/3Dビデオ符号化標準においては、ビュー間参照ピクチャーも「長期」参照ピクチャーとしてマークされることに注意すべきである。
現在のVVCテストモデル、すなわち、VTM-4.0設計では、参照ブロック全体が現在の符号化ツリー単位(CTU)と一緒であるべきであり、現在ブロックと重複しない。よって、参照ブロックまたは予測ブロックをパディングする必要はない。IBCフラグは、現在のCUの予測モードとして符号化される。よって、各CUについて、全部で3つの予測モード、MODE_INTRA、MODE_INTER、MODE_IBCがある。
IBCマージ・モードでは、IBCマージ候補リスト内のエントリーを指すインデックスがビットストリームからパースされる。IBCマージ・リストの構築は、以下の一連のステップに従って要約できる:
・ステップ1;空間的候補の導出
・ステップ2:HMVP候補の挿入
・ステップ3:ペアワイズ平均候補の挿入。
IBC AMVPモードでは、IBC AMVPリスト内のエントリーを指すAMVPインデックスがビットストリームからパースされる。IBC AMVPリストの構築は、以下の一連のステップに従って要約できる:
・ステップ1:空間的候補の導出
○利用可能な候補が見つかるまで、A0、A1をチェックする。
○利用可能な候補が見つかるまで、B0、B1、B2をチェックする。
・ステップ2:HMVP候補の挿入
・ステップ3:ゼロ候補の挿入。
現在のVVCでは、クロマIBCモードでの動き補償はサブブロック・レベルで実行される。クロマ・ブロックは、いくつかのサブブロックに分割される。各サブブロックは、対応するルーマ・ブロックがブロックベクトルをもつかどうかを、またそれが存在する場合には有効性を決定する。現在のVTMにはエンコーダ制約があり、現在のクロマCU内のすべてのサブブロックが有効なルーマ・ブロックベクトルをもつ場合に、クロマIBCモードがテストされる。たとえば、YUV 420ビデオでは、クロマ・ブロックはN×Mであり、すると、共位置のルーマ領域は2N×2Mである。クロマ・ブロックのサブブロック・サイズは2×2である。クロマmv導出、次いでブロック・コピー・プロセスを実行するためのいくつかのステップがある。
1)クロマ・ブロックがまず(N>>1)*(M>>1)サブブロックに分割される。
2)(x,y)を座標とする左上サンプルをもつ各サブブロックは、(2x,2y)を座標とする同じ左上サンプルをカバーする対応するルーマ・ブロックを取ってくる。
3)エンコーダは、取ってこられたルーマ・ブロックのブロックベクトル(bv)をチェックする。以下の条件のいずれかが満たされた場合、bvは無効とみなされる。
a. 対応するルーマ・ブロックのbvが存在しない。
b. bvによって同定された予測ブロックはまだ再構築されていない。
c. bvによって同定された予測ブロックは、現在ブロックと部分的または完全に重複している。
4)サブブロックのクロマ動きベクトルは、対応するルーマ・サブブロックの動きベクトルに設定される。
JVET-N0843がVVCに採用されている。JVET-N0843では、IBCにおける、マージ・モードおよびAMVPモードのためのBV予測子は、共通の予測子リストを共有する。これは、以下の要素から構成される:
・2つの空間的近傍位置(図2のA1、B1)
・5つのHMVPエントリー
・デフォルトのゼロ・ベクトル
マージ・モードの現在の設計には、次のような問題がありうる:
1. 通常のマージ・リスト構築プロセスは、現在ブロックについてのTPMの使用に依存する。
a. TPM符号化されるブロックについては、空間的マージ候補の間でフル剪定が適用される。
b. 非TPM符号化されるブロックについては、空間的マージ候補の間で部分的な剪定が適用される。
2. 現在の設計によれば、すべてのマージ関連ツール(IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIP、TPMを含む)は、general_merge_flagという名前の1つのフラグによって信号伝達される。しかしながら、このフラグが真である場合、すべてのマージ関連ツールが無効にされるように信号伝達される、または導出される可能性がある。この場合をどのように扱うかが不明である。また、マージ・モードをオフにすることはできない。すなわち、マージ候補の最大数は0に等しくない。しかしながら、高スループットのエンコーダ/デコーダの場合、マージ・モードの無効化を強制する必要がありうる。
3. ATMVPプロセスについての初期化されたMVの決定は、スライスタイプ、すべての参照ピクチャーのPOC値、collocated_from_10_flagなどに依存し、これはMVのスループットを遅らせる。
4. 共位置のMVの導出プロセスは、従来のTMVPプロセスまたはATMVPプロセスのようなサブブロック技術の使用に依存し、これは追加のロジックを必要とする。
5. ATMVP符号化されたブロック内のサブCUについては、その対応する共位置のブロックがインター符号化されていても、サブCUの動き情報は、対応する共位置のブロックから導出できず、他の動き情報を用いて満たされる可能性がある。そのような設計は、符号化効率とスループットの両方にとって最適ではない。
6. HEVC仕様は、現在または参照ピクチャー内の1つの近傍ブロックの利用可能性を、該ブロックが構築されているか、または異なるCTU行/スライス内にあるかなどに基づいて定義する。しかしながら、VVCでは、複数の符号化方法が導入されている。ブロックの利用可能性の異なる定義が定義される必要があるかもしれない。
7. JVET-O0545は、sps_sbt_max_size_64_flagを送信することにより、最大変換ブロック・サイズの指標を信号伝達することを提案する。
sps_sbt_max_size_64_flagが0に等しいことは、サブブロック変換を許容するための最大CU幅と高さが32ルーマ・サンプルであることを指定する。
sps_sbt_max_size_64_flagが1に等しいことは、サブブロック変換を許容するための最大CU幅と高さが64ルーマ・サンプルであることを指定する。
MaxSbtSize=sps_sbt_max_size_64_flag ? 64:32 (7 31)
64より小さい最大変換サイズ(MaxTransformSizeによって示される)をサポートするために、MaxSbtSizeの導出は以下のように修正される。
MaxSbtSize=min(MaxTransformSize,sps_sbt_max_size_64_flag ? 64:32)
8. 適応ループフィルタ(ALF)係数が固定範囲内に制約される。たとえば、AlfCoeffCによって表されるクロマALFフィルタ係数およびAlfCoeffLによって表されるルーマALFフィルタ係数は、-27から27-1の範囲でなければならない(両端含む)。そのような制約は、8ビット深さの想定に基づく。
9. ALFフィルタの予測子の指示は以下のように信号伝達される:
10. マージ関連の符号化ツールは以下のとおり:
以下の詳細なリストは、一般的な概念を説明するための例として考慮されるべきである。これらの実施形態は狭義に解釈されるべきではない。さらに、これらの技法は、任意の方法で組み合わせることができる。
1. 従来のマージとTPM符号化されたブロックについての通常マージ・リスト構築プロセスは、現在ブロックの符号化方法から切り離される。
a. 一例では、TPMが1つのブロックに適用されるとき、部分的剪定が空間的マージ候補に適用される。
i. 一例では、2つの候補が互いに比較されるかどうかは、非TPMマージ符号化ブロックについて使用されるのと同じ仕方で決定される。
ii. 一例では、B1はA1と比較され、B0はB1と比較され、A0はA1と比較され、B2はB1およびA1と比較される。
iii. あるいはまた、TPMが1つのブロックについて使用されない場合でも、フル剪定が空間的マージ候補に適用される。
iv. あるいはまた、さらに、いくつかの特定のブロック寸法にフル剪定が適用されてもよい。
1. たとえば、フル剪定は、TPMが許容されるブロック寸法に適用されてもよい。
2. たとえば、ブロック・サイズがM*Hより小さいサンプル、たとえば、16または32または64ルーマ・サンプルを含む場合、フル剪定は許容されない。
3. たとえば、ブロックの幅>th1または≧th1および/またはブロックの高さ>th2または≧th2の場合、フル剪定は許容されない。
b. 一例では、B2をチェックするかどうかは、TPMが1つのブロックに適用されるときにB2をチェックする前の利用可能なマージ候補の数に基づく。
i. あるいはまた、B2は、非TPMマージ符号化ブロックについて利用可能なマージ候補の数にかかわらず、常にチェックされる。
2. ATMVPが利用可能かどうかを決定するためにブロックを識別するために使用される初期化されたMVは、単に空間的近傍ブロック(たとえば、A1)のリストX情報に依拠してもよく、Xは、時間的な動きベクトル予測のために使用される共位置のピクチャーがそこから導かれるところ(たとえば、collocated_from_l0_flag)に設定される。
a. あるいはまた、Xは、すべての参照リスト中のすべての参照ピクチャーが、現在のピクチャーと比較して、より小さいPOC値、またはより大きくないPOC値をもつかどうかに従って決定される。
i. 一例では、それが真であれば、Xは1に設定される。それ以外の場合、Xは0に設定される。
b. あるいはまた、空間的近傍ブロック(たとえば、A1)のリストXに関連する参照ピクチャーが利用可能であり、共位置のピクチャーと同じPOC値を有する場合、初期化されたMVは、空間的近傍ブロックのリストXに関連するMVに設定される。それ以外の場合、デフォルトのMV(たとえば(0,0))が利用される。
c. あるいはまた、HMVPテーブルに格納された動き情報が、ATMVPにおいて、初期化されたMVとして使用されてもよい。
i. たとえば、HMVPテーブルに記憶された第1の利用可能な動き情報が使用されてもよい。
ii. たとえば、ある参照ピクチャー(たとえば、共位置のピクチャー)に関連付けられた、HMVPテーブルに格納された第1の利用可能な動き情報が使用されてもよい。
d. あるいはまた、Xは0または1のような固定数である。
3. サブブロック・ベースの符号化ツールおよび非サブブロック・ベースの符号化ツールのために使用される共位置のMVの導出プロセスは、整列されてもよい、すなわち、該プロセスは、特定の符号化ツールの使用から独立している。
a. 一例では、サブブロック・ベースの符号化ツールのための共位置のMVの導出プロセスの全体または一部は、TMVPのために使用されるものと整列される。
i. 一例では、それがリストYからの単予測である場合、リストYの動きベクトルは、ターゲット参照ピクチャー・リストXにスケーリングされる;
ii. 一例では、それが双予測であり、ターゲット参照ピクチャー・リストがXである場合、リストYの動きベクトルは、ターゲット参照ピクチャー・リストXにスケーリングされ、Yは以下の規則に従って決定されうる:
・現在のピクチャーに比べて、参照ピクチャーのどれも、より大きなPOC値をもたない、またはすべての参照ピクチャーが、より小さなPOC値をもつ場合は、YはXに設定される。
・それ以外の場合、Yはcollocated_from_10_flagに等しく設定される。
b. 一例では、TMVPのための共位置のMVの導出プロセスの全体または一部は、サブブロック・ベースの符号化ツールのために使用されるものと整列される。
4. 動き候補リスト構築プロセス(たとえば、通常マージ・リスト、IBCマージ/AMVPリスト)は、ブロック寸法および/またはマージ共有条件に依存してもよい。ブロックの幅をW、高さをHとする。条件Cは、WおよびH、および/またはマージ共有条件に依存してもよい。
a. 一例では、条件Cが満たされる場合、空間的マージ候補の導出はスキップされる。
b. 一例では、条件Cが満たされる場合、HMVP候補の導出はスキップされる。
c. 一例では、条件Cが満たされる場合、ペアワイズ・マージ候補の導出はスキップされる。
d. 一例では、条件Cが満たされる場合、最大剪定動作の数が減らされるか、または0に設定される。
e. 一例では、条件Cは、W*Hが閾値(たとえば、64または32)より小さいか、または大きくないときに満たされる。
f. 一例では、条件Cは、Wおよび/またはHが閾値(たとえば、4または8)より小さいか、または大きくないときに満たされる。
g. 一例では、条件Cは、現在ブロックが共有されるノードの下にある場合に満たされる。
5. 許容される通常マージ候補の最大数/許容されるIBC候補の最大数/許容されるサブブロック・マージ候補の最大数が0に設定されてもよい。よって、ある種のツールが無効にされている可能性があり、関連する構文要素は信号伝達される必要はない。
a. 一例では、許容される正規マージ候補の最大数が0に等しい場合、通常マージ・リストに依拠する符号化ツールを無効にされてもよい。符号化ツールは、通常マージ、MMVD、CIIP、TPM、DMVRなどであってもよい。
b. 一例では、許容されるIBC候補の最大数が0に等しい場合、IBC AMVPおよび/またはIBCマージが無効にされてもよい。
c. 一例では、許容されるサブブロック・ベースのマージ候補の最大数が0に等しい場合、サブブロック・ベースの技術、たとえばATMVP、アフィン・マージ・モードは無効にされてもよい。
d. 許容される候補の最大数に従ってあるツールが無効にされる場合、関連する構文要素の信号伝達はスキップされる。
i. あるいはまた、さらに、マージ関連ツールの信号伝達は、許容される候補の最大数が0と等しくないかどうかをチェックする必要があるかもしれない。
ii. あるいはまた、さらに、マージ関連ツールのためのプロセスの呼び出しは、許容される候補の最大数が0と等しくないかどうかをチェックする必要があるかもしれない。
6. general_merge_flagおよび/またはcu_skip_flagの信号伝達は、許容される通常マージ候補の最大数/許容されるIBC候補の最大数/許容されるサブブロック・マージ候補の最大数/マージ関連の符号化ツールの使用に依存してもよい。
a. 一例では、マージ関連の符号化ツールは、IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIP、TPM、DMVR等を含みうる。
b. 一例では、許容される通常マージ候補の最大数、許容されるIBCマージ/AMVP候補の最大数、許容されるサブブロック・マージ候補の最大数が0に等しい場合、general_merge_flagおよび/またはcu_skip_flagは信号伝達されない。
i. あるいはまた、さらに、general_merge_flagおよび/またはcu_skip_flagは0であると推定される。
7. 適合ビットストリームは、現在ブロックのgeneral_merge_flagまたはcu_skip_flagが真である場合、IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIP、TPM、DMVRなどを含むマージ関連ツールの少なくとも1つが有効にされるということを満足するものとする。
8. 適合ビットストリームは、現在ブロックの(general_merge_flagまたはcu_skip_flag)が真であり、1つのスライス/タイル/ブリック/ピクチャー/現在ブロックについてIBCが無効にされている場合、通常マージ、MMVD、サブブロック・マージ、CIIP、TPM、DMVRなどを含むマージ関連ツールの少なくとも1つが有効にされるということを満足するものとする。
9. 適合ビットストリームは、現在ブロックの(general_merge_flagまたはcu_skip_flag)が真であり、1つのスライス/タイル/ブリック/ピクチャー/現在ブロックについてMMVDが無効にされている場合、IBCマージ、通常マージ、サブブロック・マージ、CIIP、TPMを含むマージ関連ツールのうちの少なくとも1つが有効にされるということを満足するものとする。
10. 適合ビットストリームは、現在ブロックの(general_merge_flagまたはcu_skip_flag)が真であり、1つのスライス/タイル/ブリック/ピクチャー/現在ブロックについてCIIPが無効にされている場合、IBCマージ、通常マージ、MMVD、サブブロック・マージ、TPMを含むマージ関連ツールの少なくとも1つが有効にされるということを満足するものとする。
11. 適合ビットストリームは、現在ブロックの(general_merge_flagまたはcu_skip_flag)が真であり、1つのスライス/タイル/ブリック/ピクチャー/現在ブロックについてTPMが無効にされている場合、IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIPを含むマージ関連ツールの少なくとも1つが有効にされるということを満足するものとする。
12. 適合ビットストリームは、現在ブロックのgeneral_merge_flagまたはcu_skip_flagが真であるとき、IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIP、TPMを含む有効にされたマージ関連ツールの少なくとも1つが適用されるということを満足するものとする。第1のブロックを符号化するとき、第2のブロックの利用可能性のチェックは、第1のブロックの符号化されたモード情報に依存してもよい。たとえば、第1および第2のブロックにおいて異なるモードが使用されている場合、第2のブロックは、他の条件チェック結果(たとえば、構築された)にかかわらず、利用不能として扱われてもよい。
a. 一例では、第1のブロックがインター符号化され、第2のブロックがIBC符号である場合、第2のブロックは利用不能としてマークされる。
b. 一例では、第1のブロックがIBC符号化され、第2のブロックがインター符号である場合、第2のブロックは利用不能とマークされる。
c. 第2が利用不能とマークされている場合、関連する符号化された情報(たとえば、動き情報)は、第1のブロックを符号化するために利用されることが禁止される。
13. TPMサイド情報と無関係な構文要素の信号伝達は、許容されるTPM候補の数の条件チェックの下にあってもよい。
a. 一例では、CIIP関連の構文要素(たとえば、ciip_flag)の信号伝達は、許容されるTPM候補の数が閾値Kより大きいかどうかに依存してもよい。
b. 一例では、通常マージ・モード・フラグ(たとえば、regular_merge_flag)の信号伝達は、許容されるTPM候補の数が閾値Kより大きいかどうかに依存してもよい。
c. 一例では、Kが1に設定される。
d. あるいはまた、さらに、許容されるTPM候補の数が閾値K以下の場合、ある種の構文要素は信号伝達されなくてもよい。
14. 適合ビットストリームは、最大変換ブロック・サイズが最大CTUサイズを超えないということを満足する。
a. あるいはまた、最大変換ブロック・サイズの指示が、最大CTUサイズの下で条件付きで信号伝達されてもよいし、その逆も可能である。
i. 一例では、最大CTUサイズがM×N以下(たとえば、M=N=32)である場合、最大変換ブロック・サイズの指示を信号伝達する必要はない。
15. ALFフィルタ係数の範囲は、固定された範囲ではなく、サンプル深さ(たとえば、内部ビット深さまたは入力ビット深さ)に依存してもよい。
16. 固定フィルタに対してALF APSにおいてALFフィルタを使用するかどうかを示すために、1つのフラグが直接信号伝達されてもよい。
a. また、そのようなフラグは、利用可能なALF APSの数が0より大きいという条件の下で信号伝達されてもよい。
b. あるいはまた、さらに、APSからのALFフィルタが信号伝達される場合、ALF APSのインデックスを示すために、1つの追加的な構文がさらに信号伝達されてもよい。そのようなインデックスは、固定長符号化、単進符号化、打ち切りされた単進符号化、打ち切りされた二進符号化、指数ゴロム符号化を用いて符号化されてもよい。
最新のVVC作業原案(JVET-N1001_v7)に加える提案される変更点は以下の通りである。削除されるテキストは、[[ ]]と下線で示される。新たに追加された部分は太字でハイライトされる。
この実施形態は、非TPM符号化ブロックについての剪定プロセスを、TPM符号化されたブロックについての剪定プロセスに整列させる、すなわち、非TPM符号化ブロックについてのフル剪定操作である。
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマ符号化ブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在の符号化ブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在の符号化ブロックの高さを指定する変数cbHeight。
・近傍の符号化単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍の符号化単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍の符号化単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍の符号化単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
・availableA1がFALSEに等しい場合、availableFlagA1が0に等しく設定され、X=0または1として、mvLXA1の両成分が0に等しく設定され、refIdxLXA1が-1に等しく設定され、predFlagLXA1が0に等しく設定され、gbiIdxA1が0に等しく設定される。
・それ以外の場合、availableFlagA1は1に等しく設定され、以下の割り当てが行われる:
mvLXA1=MvLX[xNbA1][yNbA1] (8-294)
refIdxLXA1=RefIdxLX[xNbA1][yNbA1] (8-295)
predFlagLXA1=PredFlagLX[xNbA1][yNbA1] (8-296)
gbiIdxA1=GbiIdx[xNbA1][yNbA1] (8-297)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB1,yNbB1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB1に割り当てられる。
・変数availableFlagB1、refIdxLXB1、predFlagLXB1、mvLXB1は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB1が0に等しく設定され、X=0または1として、mvLXB1の両方の成分が0に等しく設定され、refIdxLXB1が-1に等しく設定され、predFlagLXB1が0に等しく設定され、gbiIdxB1が0に設定される:
・availableB1が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB1,yNbB1)は同じ動きベクトルと同じ参照インデックスをもつ。
・それ以外の場合、availableFlagB1は1に等しく設定され、以下の割り当てが行われる:
mvLXB1=MvLX[xNbB1][yNbB1] (8-298)
refIdxLXB1=RefIdxLX[xNbB1][yNbB1] (8-299)
predFlagLXB1=PredFlagLX[xNbB1][yNbB1] (8-300)
gbiIdxB1=GbiIdx[xNbB1][yNbB1] (8-301)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB0,yNbB0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB0に割り当てられる。
・変数availableFlagB0、refIdxLXB0、predFlagLXB0、mvLXB0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB0が0に等しく設定され、X=0または1として、mvLXB0の両方の成分が0に等しく設定され、refIdxLXB0が-1に等しく設定され、predFlagLXB0が0に等しく設定され、gbiIdxB0が0に設定される:
・availableB0が偽に等しい。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ[[、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・それ以外の場合は、availableFlagB0が1に設定され、以下の割り当てが行われる:
mvLXB0=MvLX[xNbB0][yNbB0] (8-302)
refIdxLXB0=RefIdxLX[xNbB0][yNbB0] (8-303)
predFlagLXB0=PredFlagLX[xNbB0][yNbB0] (8-304)
gbiIdxB0=GbiIdx[xNbB0][yNbB0] (8-305)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA0,yNbA0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA0に割り当てられる。
・変数availableFlagA0、refIdxLXA0、predFlagLXA0、mvLXA0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagA0が0に等しく設定され、X=0または1として、mvLXA0の両方の成分が0に等しく設定され、refIdxLXA0が-1に等しく設定され、predFlagLXA0が0に等しく設定され、gbiIdxA0が0に設定される:
・availableA0が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ[[、merge_triangle_flag[xCb][yCb]は1に等しい]]。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ[[、merge_triangle_flag[xCb][yCb]は1に等しい]]。
・それ以外の場合は、availableFlagA0が1に設定され、以下の割り当てが行われる:
mvLXA0=MvLX[xNbA0][yNbA0] (8-306)
refIdxLXA0=RefIdxLX[xNbA0][yNbA0] (8-307)
predFlagLXA0=PredFlagLX[xNbA0][yNbA0] (8-308)
gbiIdxA0=GbiIdx[xNbA0][yNbA0] (8-309)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ[[、merge_triangle_flag[xCb][yCb]は1に等しい]]。
・availableA0が真に等しく、ルーマ位置(xNbA0,yNbA0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ[[、merge_triangle_flag[xCb][yCb]は1に等しい]]。
・availableFlagA0+availableFlagA1+availableFlagB0+availableFlagB1が4に等しく、merge_triangle_flag[xCb][yCb]が0に等しい。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
この実施形態は、TPM符号化ブロックについての剪定プロセスを、非TPM符号化ブロックについての剪定プロセスに整列させる、すなわち、TPM符号化されるブロックについての限定的な剪定操作である。
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマ符号化ブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在の符号化ブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在の符号化ブロックの高さを指定する変数cbHeight。
・近傍の符号化単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍の符号化単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍の符号化単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍の符号化単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
・availableA1がFALSEに等しい場合、availableFlagA1が0に等しく設定され、X=0または1として、mvLXA1の両成分が0に等しく設定され、refIdxLXA1が-1に等しく設定され、predFlagLXA1が0に等しく設定され、gbiIdxA1が0に等しく設定される。
・それ以外の場合、availableFlagA1は1に等しく設定され、以下の割り当てが行われる:
mvLXA1=MvLX[xNbA1][yNbA1] (8-294)
refIdxLXA1=RefIdxLX[xNbA1][yNbA1] (8-295)
predFlagLXA1=PredFlagLX[xNbA1][yNbA1] (8-296)
gbiIdxA1=GbiIdx[xNbA1][yNbA1] (8-297)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB1,yNbB1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB1に割り当てられる。
・変数availableFlagB1、refIdxLXB1、predFlagLXB1、mvLXB1は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB1が0に等しく設定され、X=0または1として、mvLXB1の両方の成分が0に等しく設定され、refIdxLXB1が-1に等しく設定され、predFlagLXB1が0に等しく設定され、gbiIdxB1が0に設定される:
・availableB1が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB1,yNbB1)は同じ動きベクトルと同じ参照インデックスをもつ。
・それ以外の場合、availableFlagB1は1に等しく設定され、以下の割り当てが行われる:
mvLXB1=MvLX[xNbB1][yNbB1] (8-298)
refIdxLXB1=RefIdxLX[xNbB1][yNbB1] (8-299)
predFlagLXB1=PredFlagLX[xNbB1][yNbB1] (8-300)
gbiIdxB1=GbiIdx[xNbB1][yNbB1] (8-301)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB0,yNbB0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB0に割り当てられる。
・変数availableFlagB0、refIdxLXB0、predFlagLXB0、mvLXB0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB0が0に等しく設定され、X=0または1として、mvLXB0の両方の成分が0に等しく設定され、refIdxLXB0が-1に等しく設定され、predFlagLXB0が0に等しく設定され、gbiIdxB0が0に設定される:
・availableB0が偽に等しい。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ。
・[[availableA 1 が真に等しく、ルーマ位置(xNbA 1 ,yNbA 1 )と(xNbB 0 ,yNbB 0 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・それ以外の場合は、availableFlagB0が1に設定され、以下の割り当てが行われる:
mvLXB0=MvLX[xNbB0][yNbB0] (8-302)
refIdxLXB0=RefIdxLX[xNbB0][yNbB0] (8-303)
predFlagLXB0=PredFlagLX[xNbB0][yNbB0] (8-304)
gbiIdxB0=GbiIdx[xNbB0][yNbB0] (8-305)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA0,yNbA0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA0に割り当てられる。
・変数availableFlagA0、refIdxLXA0、predFlagLXA0、mvLXA0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagA0が0に等しく設定され、X=0または1として、mvLXA0の両方の成分が0に等しく設定され、refIdxLXA0が-1に等しく設定され、predFlagLXA0が0に等しく設定され、gbiIdxA0が0に設定される:
・availableA0が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ。
・[[availableB 1 が真に等しく、ルーマ位置(xNbB 1 ,yNbB 1 )と(xNbA 0 ,yNbA 0 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・[[availableB 0 が真に等しく、ルーマ位置(xNbB 0 ,yNbB 0 )と(xNbA 0 ,yNbA 0 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・それ以外の場合は、availableFlagA0が1に設定され、以下の割り当てが行われる:
mvLXA0=MvLX[xNbA0][yNbA0] (8-306)
refIdxLXA0=RefIdxLX[xNbA0][yNbA0] (8-307)
predFlagLXA0=PredFlagLX[xNbA0][yNbA0] (8-308)
gbiIdxA0=GbiIdx[xNbA0][yNbA0] (8-309)
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・[[availableB 0 が真に等しく、ルーマ位置(xNbB 0 ,yNbB 0 )と(xNbB 2 ,yNbB 2 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・[[availableA 0 が真に等しく、ルーマ位置(xNbA 0 ,yNbA 0 )と(xNbB 2 ,yNbB 2 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・availableFlagA0+availableFlagA1+availableFlagB0+availableFlagB1が4に等しく、merge_triangle_flag[xCb][yCb]が0に等しい。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
この実施形態は、B2のチェックを呼び出すための条件を揃える。
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマ符号化ブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在の符号化ブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在の符号化ブロックの高さを指定する変数cbHeight。
・近傍の符号化単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍の符号化単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍の符号化単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍の符号化単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
……
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
……
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
……
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
……
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・availableA0が真に等しく、ルーマ位置(xNbA0,yNbA0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・availableFlagA0+availableFlagA1+availableFlagB0+availableFlagB1が4に等しい[[、そしてmerge_triangle_flag[xCb][yCb]が0に等しい]]。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
この実施形態は、B2のチェックを呼び出すための条件を揃える。
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマ符号化ブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在の符号化ブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在の符号化ブロックの高さを指定する変数cbHeight。
・近傍の符号化単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍の符号化単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍の符号化単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍の符号化単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
……
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
……
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
……
・近傍のルーマ符号化ブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
……
・近傍のルーマ符号化ブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・availableA0が真に等しく、ルーマ位置(xNbA0,yNbA0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・[[availableFlagA 0 +availableFlagA 1 +availableFlagB 0 +availableFlagB 1 が4に等しい、そしてmerge_triangle_flag[xCb][yCb]が0に等しい]]。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
この実施形態は、ATMVPプロセスにおける初期化されたMVの決定を簡略化する。
このプロセスへの入力は以下の通り:
・現在の符号化ブロックを含むルーマ符号化ツリー・ブロックの左上のサンプルの位置(xCtb,yCtb)
・右下の中心サンプルをカバーする共位置のルーマ符号化ブロックの左上のサンプルの位置(xColCtrCb,yColCtrCb)、
・近傍の符号化単位の利用可能性フラグavailableFlagA1、
・近傍の符号化単位の参照インデックスrefIdxLXA1、
・近傍の符号化単位の予測リスト利用フラグpredFlagLXA1、
・近傍の符号化単位の1/16端数サンプル精度での動きベクトルmvLXA1。
・動きベクトルctrMvL0とctrMvL1、
・予測リスト利用フラグctrPredFlagL0およびctrPredFlagL1、
・時間的動きベクトルtempMv。
tempMv[0]=0 (8-529)
tempMv[1]=0 (8-530)
変数Xをcollocated_from_l0_flagに設定する。
predFlagLXA1が1に等しく、DiffPicOrderCnt(ColPic,RefPicList[X][refIdxLXA1])が0に等しいことが真である場合、tempMvはmvLXA1に等しく設定される。〕
・[[以下の条件がすべて真である場合、tempMvはmvL1A 1 に等しく設定される:
・predFlagL1A 1 が1に等しい、
・DiffPicOrderCnt(ColPic,RefPicList[1][refIdxL1A 1 ])が0に等しい、
・DiffPicOrderCnt(aPic,currPic)が、現在のスライスのすべての参照ピクチャー・リスト内のすべてのピクチャーaPicについて0以下である、
・slice_typeがBに等しい、
・collocated_from_l0_flagが0に等しい。]]
・[[それ以外の場合、以下の条件がすべて真である場合、tempMvはmvL0A 1 に等しく設定される:
・predFlagL0A 1 が1に等しい、
・DiffPicOrderCnt(ColPic,RefPicList[0][refIdxL0A1])は0に等しい。]]
xColCb=Clip3(xCtb,
Min(CurPicWidthInSamplesY-1,xCtb+(1<<CtbLog2SizeY)+3),
xColCtrCb+(tempMv[0]>>4)) (8-531)
yColCb=Clip3(yCtb,
Min(CurPicHeightInSamplesY-1,yCtb+(1<<CtbLog2SizeY)-1),
yColCtrCb+(tempMv[1]>>4)) (8-532)
……
サブブロックおよび非サブブロック・ベースの方法のための共位置のMVの導出プロセスの整列のための例。
このプロセスへの入力は以下の通りである:
・現在の符号化ブロックを指定する変数currCb、
・ColPicによって指定された共位置のピクチャー内の共位置の符号化ブロックを指定する変数colCb、
・ColPicによって指定された共位置のピクチャーの左上のルーマ・サンプルに対して、colCbによって指定された共位置のルーマ符号化ブロックの左上のサンプルを指定するルーマ位置(xColCb,yColCb)、
・参照インデックスrefIdxLX、Xは0または1、
・サブブロックの時間的マージ候補sbFlagを示すフラグ。
・1/16端数サンプル精度での動きベクトル予測mvLXCol、
・利用可能性フラグavailableFlagLXCol。
・colCbがイントラまたはIBC予測モードで符号化される場合、mvLXColの両方の成分が0に等しく設定され、availableFlagLXColが0に等しく設定される。
・それ以外の場合、動きベクトルmvCol、参照インデックスrefIdxCol、参照リスト識別子listColは以下のように導出される:
・[[sbFlagが0に等しい場合、]]availableFlagLXColは1に等しく設定され、以下が適用される:
・predFlagL0Col[xColCb][yColCb]が0に等しい場合、mvCol、refIdxCol、listColはそれぞれmvL1Col[xColCb][yColCb]、refIdxL1Col[xColCb][yColCb]、L1に等しく設定される。
・それ以外の場合、predFlagL0Col[xColCb][yColCb]が1に等しく、predFlagL1Col[xColCb][yColCb]が0に等しい場合、mvCol、refIdxCol、listColは、それぞれ、mvL0Col[xColCb][yColCb]、refIdxL0Col[xColCb][yColCb]、L0に等しく設定される。
・それ以外の場合(predFlagL0Col[xColCb][yColCb]が1に等しく、predFlagL1Col[xColCb][yColCb]が1に等しい場合)、以下の割り当てが行われる:
・NoBackwardPredFlagが1に等しい場合、mvCol、refIdxCol、listColはそれぞれmvLXCol[xColCb][yColCb]、refIdxLXCol[xColCb][yColCb]、LXに等しく設定される。
・それ以外の場合、mvCol、refIdxCol、listColはそれぞれmvLNCol[xColCb][yColCb]、refIdxLNCol[xColCb][yColCb]、LNに等しく設定され、Nはcollocated_from_l0_flagの値である。
・[[それ以外の場合(sbFlagが1に等しい)、以下が適用される:
・PredFlagLXCol[xColCb][yColCb]が1に等しい場合、mvCol、refIdxCol、listColはそれぞれmvLXCol[xColCb][yColCb]、refIdxLXCol[xColCb][yColCb]、LXに等しく設定され、availableFlagLXColは1に等しく設定される。
・それ以外の場合(PredFlagLXCol[xColCb][yColCb]が0に等しい場合)、以下が適用される:
・DiffPicOrderCnt(aPic,currPic)が現在のスライスのすべての参照ピクチャー・リストのすべてのピクチャーaPicについて0以下であり、PredFlagLYCol[xColCb][YColCb]が1に等しく、mvCol、refIdxCol、listColはそれぞれmvLYCol[xColCb][yColCb]、refIdxLYCol[xColCb][yColCb]、LYに設定され、Yは!Xに等しく、Xはそのためにこのプロセスが呼び出されるXの値である。availableFlagLXColが1に設定される。
・mvLXColの両方の成分が0に設定され、availableFlagLXColは0に等しく設定される。]]
・availableFlagLXColがTRUEに等しい場合、mvLXColおよびavailableFlagLXColは次のように導出される:
・LongTermRefPic(currPic,currCb,refIdxLX,LX)がLongTermRefPic(ColPic,colCb,refIdxCol,listCol)に等しい場合、mvLXColの両方の成分は0に等しく設定され、availableFlagLXColは0に等しく設定される。
・それ以外の場合、変数availableFlagLXColは1に等しく設定され、refPicList[listCol][refIdxCol]は、ColPicによって指定される共位置のピクチャーにおける符号化ブロックcolCbを含むスライスの参照ピクチャー・リストlistColにおける参照インデックスrefIdxColをもつピクチャーに設定され、以下が適用される:
……
視覚メディアデータの現在のビデオ・ブロックと、現在のビデオ・ブロックのビットストリーム表現との間の変換を実行するステップを含み、前記ビットストリーム表現は、符号化ツールのためのマージ候補の最大数を示す構文要素が前記ビットストリーム表現に選択的に含まれるか、除外されるかを指定し、それにより前記符号化ツールが前記変換のために有効にされるか、無効にされるかを示すことを指定するフォーマット規則に従って構成され、
前記符号化ツールのためのマージ候補の最大数は、ゼロまたは正数である、
方法。
複数のビデオ・ブロックを含む一つまたは複数のビデオ領域を含むビデオと、前記ビデオのビットストリーム表現との間で変換を実行するステップを含み、
前記ビットストリーム表現は、ビデオ領域についての許容される幾何分割モード(geometric partitioning mode、GMP)動き候補の数が前記ビデオ領域への符号化ツールの適用可能性に関する構文要素が前記ビットストリーム表現に含まれるかどうかを決定することを指定するフォーマット規則に適合し、前記符号化ツールは、GPM符号化ツールとは異なり、前記GPMは、別個に動き予測を適用するために、ビデオ・ブロックを複数の予測パーティションに分割することを含み、少なくとも1つのパーティションは非矩形形状を有する、
方法。
視覚メディアデータの現在のビデオ単位と、前記視覚メディアデータのビットストリーム表現との間で変換を実行するステップを含み、前記ビットストリーム表現は、最大変換ブロック・サイズが、前記変換のために使用される最大符号化ツリー単位(CTU)サイズと等しいかまたはそれ未満であることを指定するフォーマット規則に従って構成される、
方法。
視覚メディアデータの現在のビデオ・ブロックと、現在のビデオ・ブロックのビットストリーム表現との間の変換を実行するステップであって、前記変換は、適応ループフィルタ(ALF)を使用し、該ALFフィルタの係数は、現在のビデオ・ブロックのビデオ領域内のサンプルの深さに基づく、
方法。
視覚メディアデータの現在のビデオ・ブロックと現在のビデオ・ブロックのビットストリーム表現との間の変換を適応ループフィルタ(ALF)を用いて実行することを含み、前記ビットストリーム表現は、前記ビットストリーム表現に含まれる一つまたは複数の構文要素が、現在のビデオ・ブロックに適用されるALFフィルタが適応パラメータセット(APS)に基づいて決定されるか、または固定した諸フィルタ集合に基づいて決定されるかを示すことを指定するフォーマット規則に従って構成される、
方法。
本願は、2020年7月14日に出願された国際特許出願第PCT/CN2020/101819号に基づく。同出願は、2019年7月14日に出願された国際特許出願第PCT/CN2019/095921号の優先権および利益を適時に主張して行われる。上記のすべての特許出願は、ここに参照によりその全体において援用される。
本願は、2020年7月14日に出願された国際特許出願第PCT/CN2020/101819号に基づく。同出願は、2019年7月14日に出願された国際特許出願第PCT/CN2019/095921号の優先権および利益を適時に主張して行われる。上記のすべての特許出願は、ここに参照によりその全体において援用される。
本稿は、ビデオおよび画像のコーディング・復号技術に関する。
本稿は、ビデオコーディング技術に関する。具体的には、本稿は三角予測モードを含むマージコーディングに関する。これは、HEVCのような既存のビデオコーディング規格、またはこれから最終化される規格(多用途ビデオコーディング(Versatile Video Coding))に適用されることがある。これは、将来のビデオコーディング規格またはビデオ・コーデックにも適用可能でありうる。
ビデオコーディング規格は、主に、周知のITU-TおよびISO/IEC規格の開発を通じて発展してきた。ITU-TはH.261およびH.263を生み出し、ISO/IECはMPEG-1およびMPEG-4 Visualを生み出し、両機関は合同してH.262/MPEG-2 VideoおよびH.264/MPEG-4 先進ビデオコーディング(Advanced Video Coding、AVC)およびH.265/HEVC規格を生み出した。H.262以来、ビデオコーディング規格は、時間的予測と変換コーディングが利用されるハイブリッドビデオコーディング構造に基づいている。HEVCを越えた将来のビデオコーディング技術を探求するため、2015年にVCEGとMPEGによって合同で、合同ビデオ探査チーム(Joint Video Exploration Team、JVET)が設立された。それ以来、JVETによって多くの新しい方法が採用され、JEM(Joint Exploration Model)と名付けられた参照ソフトウェアに入れられた。2018年4月には、VCEG(Q6/16)とISO/IEC JTC1 SC29/WG11(MPEG)の間で合同ビデオエキスパートチーム(Joint Video Expert Team、JVET)を発足し、HEVCに比べ50%のビットレート削減を目指すVVC規格に取り組んでいる。
インターコーディングされるコーディング単位(CU)については、分割モードに応じて、1つの予測単位(PU)、2つのPUを用いてコーディングされうる。各インター予測されたPUは、1つまたは2つの参照ピクチャー・リストのための動きパラメータを有する。動きパラメータは、動きベクトルおよび参照ピクチャー・インデックスを含む。2つの参照ピクチャー・リストのうちの一方の使用は、inter_pred_idcを使用して信号伝達されてもよい。動きベクトルは、予測子に対するデルタとして明示的にコーディングされてもよい。
HEVCでは、インター予測という用語は、現在のデコードされたピクチャー以外の参照ピクチャーのデータ要素(たとえば、サンプル値または動きベクトル)から導出された予測を示すために使用される。H.264/AVCと同様に、ピクチャーは、複数の参照ピクチャーから予測できる。インター予測のために使用される参照ピクチャーは、一つまたは複数の参照ピクチャー・リストにおいて整理される。参照インデックスは、リスト内の参照ピクチャーのうちどれが、予測信号を生成するために使用されるべきかを同定する。
2.1.2.1 マージ・モードについての候補の導出
マージ・モードを使用してPUが予測される場合、マージ候補リスト内のエントリーを指すインデックスがビットストリームからパースされ、動き情報を取得するために使用される。このリストの構築はHEVC規格で規定されており、以下の一連のステップに従って要約することができる。
●ステップ1:初期候補の導出
○ステップ1.1:空間的候補の導出
○ステップ1.2:空間的候補についての冗長性チェック
○ステップ1.3:時間的候補の導出
●ステップ2:追加的候補の挿入
○ステップ2.1:双予測候補の生成
○ステップ2.2:ゼロ動き候補の挿入
空間的マージ候補の導出では、図22に示される位置に位置する候補の中から、最大4つのマージ候補が選択される。導出の順序はA1、B1、B0、A0、B2である。位置B2は、位置A1、B1、B0、A0のどのPUも利用可能でない(たとえば、それが別のスライスまたはタイルに属するため)またはイントラコーディングされている場合にのみ考慮される。位置A1にある候補が追加された後、残りの候補の追加は、同じ動き情報をもつ候補がリストから除外されることを保証する冗長性チェックの対象となり、コーディング効率が改善される。計算複雑さを低減するために、前述の冗長性チェックでは、可能な候補ペアすべてが考慮されているわけではない。その代わりに、図3の矢印でつながれたペアのみが考慮され、冗長性チェックに使用される対応する候補が同じ動き情報を持たない場合にのみ、候補がリストに追加される。重複する動き情報の別の源は、2N×2Nとは異なるパーティションに関連付けられた「第2のPU」である。一例として、図4は、それぞれN×2Nおよび2N×Nの場合について第2のPUを示す。現在のPUがN×2Nとして分割されている場合、位置A1にある候補はリスト構築のためには考慮されない。実際、この候補を加えることによって、同じ動き情報をもつ2つの予測単位が得られる。これは、コーディング単位に1つのPUをもつだけであることに対して冗長である。同様に、現在のPUが2N×Nとして分割されている場合、位置B1は考慮されない。
このステップでは、1つの候補のみがリストに追加される。具体的には、この時間的マージ候補の導出において、共位置のピクチャー内の共位置のPUに基づいて、スケーリングされた動きベクトルが導出される。時間的マージ候補のためのスケーリングされた動きベクトルは、図5の点線によって示されているように得られ、これは、POC距離、tbおよびtdを使用して、共位置のPUの動きベクトルからスケーリングされる。ここで、tbは、現在ピクチャーの参照ピクチャーと現在ピクチャーとの間のPOC差であると定義され、tdは、共位置のピクチャーの参照ピクチャーと共位置のピクチャーとの間のPOC差であると定義される。時間的マージ候補の参照ピクチャー・インデックスはゼロに設定される。スケーリング・プロセスの実際的な実現がHEVC仕様[1]に記述されている。Bスライスについては、一方は参照ピクチャー・リスト0について、他方は参照ピクチャー・リスト1についての2つの動きベクトルが得られ、組み合わされて、双予測マージ候補を作成する。
TMVPが有効にされている場合(すなわち、slice_temporal_mvp_enabled_flagが1に等しい場合)、共位置のピクチャーを表す変数ColPicは次のように導出される:
・現在のスライスがBスライスであり、信号伝達されたcollocated_from_l0_flagが0に等しい場合、ColPicはRefPicList1[collocated_ref_idx]に等しく設定される。
・それ以外の場合(slice_typeがBに等しく、collocated_from_l0_flagが1に等しい、またはslice_typeがPに等しい場合)、ColPicはRefPicList0[collocated_ref_idx]に等しく設定される。
ここで、collocated_ref_idxとcollocated_from_l0_flagは、スライスヘッダにおいて信号伝達されうる2つの構文要素である。
より具体的には、TMVP候補を導出するために、以下のステップが実行される。
1)参照ピクチャー・リストX=0と設定し、ターゲット参照ピクチャーを、リストXにおけるインデックスが0に等しい参照ピクチャー(すなわち、curr_ref)に設定する。
2)現在のスライスがBスライスである場合、参照ピクチャー・リストX=1と設定し、ターゲット参照ピクチャーを、リストXにおけるインデックスが0に等しい参照ピクチャー(すなわち、curr_ref)に設定する。共位置の諸動きベクトルについて導出プロセスを呼び出し、curr_refをポイントする、リストXについてのMVを得る。
共位置のブロックについては、単予測または双予測でイントラまたはインターコーディングされてもよい。イントラコーディングされる場合、TMVP候補は利用不能に設定される。
・参照ピクチャーのどれも、現在のピクチャーに比べて、より大きなPOC値をもたない場合、AはXに等しく設定される。
・そうでない場合、Aはcollocated_from_l0_flagに等しく設定される。
このプロセスへの入力は以下の通り:
・現在の予測ブロックを指定する変数currPb、
・ColPicによって指定された共位置のピクチャー内の共位置の予測ブロックを指定する変数ColPic、
・ColPbによって指定された共位置のルーマ予測ブロックの左上のサンプルを、ColPicによって指定された共位置のピクチャーの左上のルーマ・サンプルに対して指定するルーマ位置(xColPb,yColPb)、
・参照インデックスrefIdxLX、ここで、Xは0または1。
・動きベクトル予測mvLXCol、
・利用可能性フラグavailableFlagLXCol。
・colPbがイントラ予測モードでコーディングされている場合、mvLXColの両方の成分が0に等しく設定され、availableFlagLXColが0に等しく設定される。
・それ以外の場合、動きベクトルmvCol、参照インデックスrefIdxCol、参照リスト識別子listColは、次のように導出される:
・predFlagL0Col[xColPb][yColPb]が0に等しい場合、mvCol,refIdxCol,listColがそれぞれmvL1Col[xColPb][yColPb],refIdxL1Col[xColPb][yColPb],L1に等しく設定される。
・それ以外の場合、predFlagL0Col[xColPb][yColPb]が1に等しく、predFlagL1Col[xColPb][yColPb]が0に等しい場合、mvCol,refIdxCol,listColはそれぞれmvL0Col[xColPb][yColPb],refIdxL0Col[xColPb][yColPb],L0に等しく設定される。
・それ以外の場合(predFlagL0Col[xColPb][yColPb]が1に等しく、predFlagL1Col[xColPb][yColPb]が1に等しい場合)、次の割り当てがされる:
・NoBackwardPredFlagが1に等しい場合、mvCol,refIdxCol,listColはそれぞれmvLXCol[xColPb][yColPb],refIdxLXCol[xColPb][yColPb],LXに等しく設定される。
・それ以外の場合、mvCol,refIdxCol,listColはそれぞれmvLNCol[xColPb][yColPb],refIdxLNCol[xColPb][yColPb]LNに等しく設定され、ここで、Nはcollocated_from_l0_flagの値である。
mvLXColおよびavailableFlagLXColは次のように導出される:
・LongTermRefPic(currPic,currPb,refIdxLX,LX)がLongTermRefPic(ColPic,colPb,refIdxCol,listCol)に等しくない場合、mvLXColの両方の成分は0に等しく設定され、availableFlagLXColは0に等しく設定される。
・それ以外の場合、変数availableFlagLXColは1に等しく設定され、refPicListCol[refIdxCol]は、ColPicによって指定された共位置ピクチャーにおける予測ブロックcolPbを含むスライスの参照ピクチャー・リストlistColにおける参照インデックスrefIdxColをもつピクチャーに設定され、以下が適用される:
colPocDiff=DiffPicOrderCnt(ColPic,refPicListCol[refIdxCol]) (2-1)
currPocDiff=DiffPicOrderCnt(currPic,RefPicListX[refIdxLX]) (2-2)
・RefPicListX[refIdxLX]が長期参照ピクチャーである、またはcolPocDiffがcurrPocDiffに等しい場合、mvLXCol次のように導出される:
mvLXCol=mvCol (2-3)
・それ以外の場合、mvLXColは以下のように動きベクトルmvColのスケーリングされたバージョンとして導出される:
・DiffPicOrderCnt(aPic,CurrPic)が現在のスライスのRefPicList0またはRefPicList1における各ピクチャーaPicについて0以下である場合、NoBackwardPredFlagは1に設定される。
・それ以外の場合、NoBackwardPredFlagは0に等しく設定される。
空間的および時間的マージ候補のほかに、2つの追加的なタイプのマージ候補がある:複合双予測マージ候補とゼロマージ候補である。複合双予測マージ候補は、空間的および時間的マージ候補を利用することによって生成される。複合双予測マージ候補は、Bスライスについてのみ使用される。複合双予測候補は、初期候補の第1の参照ピクチャー・リスト動きパラメータを、別の候補の第2の参照ピクチャー・リスト動きパラメータと組み合わせることによって生成される。これらの2つのタプルが異なる動き仮説を提供するならば、それらは新しい双予測候補をなす。一例として、図7は、mvL0およびrefIdxL0またはmvL1およびrefIdxL1を有するもとのリスト(左側)における2つの候補を使って、最終的なリスト(右側)に追加される複合双予測マージ候補を作成する場合を示している。[1]において定義されているこれらの追加的なマージ候補を生成するために考えられる組み合わせに関する多数の規則がある。
AMVPは、動きパラメータの明示的伝送に使用される、近傍のPUとの動きベクトルの時間空間的相関を利用する。各参照ピクチャー・リストについて、まず左、上の時間的に近傍のPU位置の利用可能性をチェックし、冗長な候補を除去し、ゼロ・ベクトルを追加して候補リストを一定長にすることによって、動きベクトル候補リストが構築される。次いで、エンコーダは候補リストから最良の予測子を選択し、選択された候補を示す対応するインデックスを送信することができる。同様に、マージ・インデックス信号伝達では、最良の動きベクトル候補のインデックスは、打ち切りされた単進法を用いてエンコードされる。この場合にエンコードされるべき最大値は2である(図8参照)。下記の諸節では、動きベクトル予測候補の導出プロセスの詳細を示す。
図8は、動きベクトル予測候補のための導出プロセスをまとめたものである。
空間的動きベクトル候補の導出においては、5つの潜在的候補のうちで最大2つの候補が考慮される。5つの潜在的候補は、図2に示されるような位置に位置するPUから導出され、それらの位置は、動きマージの場合と同じである。現在のPUの左側についての導出の順序は、A0、A1、およびスケーリングされたA0、スケーリングされたA1として定義される。現在のPUの上側についての導出の順序は、B0、B1、B2、スケーリングされたB0、スケーリングされたB1、スケーリングされたB2として定義される。よって、それぞれの側について、動きベクトル候補として使用できる4つの場合があり、2つの場合は空間的スケーリングを使用する必要がなく、2つの場合は空間的スケーリングが使用される。4つの異なる場合は、次のようにまとめられる。
●空間的スケーリングなし
(1)同じ参照ピクチャー・リスト、同じ参照ピクチャー・インデックス(同じPOC)
(2)異なる参照ピクチャー・リストだが、同じ参照ピクチャー(同じPOC)
●空間的スケーリング
(3)同じ参照ピクチャー・リストだが、異なる参照ピクチャー(異なるPOC)
(4)異なる参照ピクチャー・リストおよび異なる参照ピクチャー(異なるPOC)。
参照ピクチャー・インデックスの導出は別として、時間的マージ候補の導出のためのすべてのプロセスは、空間的動きベクトル候補の導出のためのものと同じである(図6を参照)。参照ピクチャー・インデックスはデコーダに信号伝達される。
インター予測改善のためのいくつかの新しいコーディングツールがある。たとえば、MVDを信号伝達するための適応動きベクトル差分解能(Adaptive Motion Vector difference Resolution、AMVR)、動きベクトル差を用いたマージ(Merge with Motion Vector Differences、MMVD)、三角予測モード(Triangular prediction mode、TPM)、復号イントラ‐インター予測(Combined intra-inter prediction、CIIP)、先進TMVP(Advanced TMVP、ATMVP、SbTMVPともいう)、アフィン予測モード、一般化双予測(Generalized Bi-Prediction、GBI)、デコーダ側動きベクトル洗練(Decoder-side Motion Vector Refinement、DMVR)、および双方向オプティカルフロー(Bi-directional Optical flow、BIO、BDOFともいう)などである。
1)サブブロック・マージ候補リスト:これは、ATMVP、アフィン・マージ候補を含む。アフィン・モードとATMVPモードの両方について、1つのマージ・リスト構築プロセスが共有される。ここで、ATMVPとアフィン・マージ候補が順次追加されてもよい。サブブロック・マージ・リストのサイズはスライスヘッダで信号伝達され、最大値は5である。
2)通常マージ・リスト:インターコーディングされるブロックについて、1つのマージ・リスト構築プロセスが共有される。ここで、空間的/時間的マージ候補、HMVP、ペアワイズ・マージ候補、およびゼロ動き候補は、順に挿入されてもよい。通常マージ・リストのサイズはスライスヘッダで信号伝達され、最大値は6である。MMVD、TPM、CIIPは、通常マージ・リストに頼る。
3)IBCマージ・リスト:これは、通常マージ・リストと同様の仕方でなされる。
1)アフィンAMVP候補リスト
2)通常のAMVP候補リスト
3)IBC AMVP候補リスト:JVET-N0843の採用によるIBCマージ・リストと同じ構築プロセス
VVCでは、ピクチャーを正方形ブロックまたは長方形ブロックに分割する四分木/二分木/三分木(QT/BT/TT)構造が採用されている。
HEVCでは、並進動きモデルのみが動き補償予測(motion compensation prediction、MCP)のために適用される。現実世界では、ズームイン/アウト、回転、透視法的な動き(perspective motions)、その他の不規則な動きなど、多くの種類の動きがある。VVCでは、簡略化されたアフィン変換動き補償予測が4パラメータ・アフィン・モデルと6パラメータ・アフィン・モデルを用いて適用される。図10に示されるように、ブロックのアフィン動き場は、4パラメータ・アフィン・モデルについては2つの制御点動きベクトル(CPMV)によって、6パラメータ・アフィン・モデルについては3つのCPMVによって記述される。
2.2.3.1 並進通常マージ・モードのマージ・リスト構築
2.2.3.1.1 履歴ベースの動きベクトル予測(HMVP)
マージ・リスト設計とは異なり、VVCでは、履歴ベースの動きベクトル予測(history-based motion vector prediction、HMVP)法が用いられる。
通常マージ・リスト(並進動き用)の構築は、次の一連のステップに従って要約できる:
●ステップ1:空間的候補の導出
●ステップ2:HMVP候補の挿入
●ステップ3:ペアワイズ平均候補の挿入
●ステップ4:デフォルトの動き候補
候補は、冗長検査のために使用される対応する候補が同じ動き情報をもたない場合にのみ、リストに追加される。そのような比較プロセスは、剪定〔プルーニング〕プロセスと呼ばれる。
VVCでは、インター予測のために三角形分割モードがサポートされている。三角形分割モードは、8×8以上のCUにのみ適用され、マージ・モードではコーディングされるが、MMVDまたはCIIPモードでは適用されない。これらの条件を満たすCUについて、CUレベルのフラグが、三角形分割モードが適用されるか否かを示すために信号伝達される。
基本的には、JVET-N0340で提案されているように、通常マージ・リスト構築プロセスが適用される。しかしながら、いくつかの修正が追加される。
1)剪定プロセスをどのように行うかは、現在ブロックについてのTPMの使用に依存する。
・現在ブロックがTPMでコーディングされるのでない場合は、空間的マージ候補に適用されるHEVCの5剪定が呼び出される。
・そうでない場合(現在ブロックがTPMでコーディングされる場合)、新しい空間的マージ候補を追加するときに、完全な剪定が適用される。すなわち、B1はA1と比較され、B0はA1およびB1と比較され、A0はA1、B1およびB0と比較され、B2はA1、B1、A0およびB0と比較される。
2)B2からの動き情報をチェックするかどうかに関する条件は、現在ブロックについてのTPMの使用に依存する。
・現在ブロックがTPMでコーディングされない場合、B2をチェックする前の空間的マージ候補が4つ未満の場合にのみ、B2がアクセスされ、チェックされる。
・そうでない場合(現在ブロックがTPMでコーディングされる場合)、B2は、B2を追加する前に、利用可能な空間的マージ候補がいくつであるかに関係なく、常にアクセスされ、チェックされる。
各三角形予測単位を予測した後、適応重み付けプロセスが、2つの三角形予測単位の間の対角線エッジに適用され、CU全体についての最終的な予測が導出される。2つの重み付け因子群が、以下のように定義される:
・第1の重み付け因子群:{7/8、6/8、4/8、2/8、1/8}および{7/8、4/8、1/8}は、それぞれルミナンスおよびクロミナンス・サンプルのために使用される;
・第2の重み付け因子群:{7/8、6/8、5/8、4/8、3/8、2/8、1/8}および{6/8、4/8、2/8}は、それぞれルミナンスおよびクロミナンス・サンプルのために使用される。
・2つの三角形予測単位の参照ピクチャーが互いに異なっている
・2つの動きベクトルの水平方向の値の差の絶対値が16ピクセルより大きい
・2つの動きベクトルの垂直方向の値の差の絶対値が16ピクセルより大きい。
三角形予測単位の動きベクトル(図16のMv1およびMv2)は、4×4グリッドに格納される。4×4グリッドごとに、CU内の4×4グリッドの位置に依存して、単予測または双予測動きベクトルが格納される。図16に示されるように、Mv1またはMv2のいずれかの単予測動きベクトルが、重み付けされない領域に位置する(すなわち、対角線エッジに位置しない)4×4グリッドについて格納される。一方、重み付けされる領域に位置する4×4グリッドについては、双予測動きベクトルが格納される。双予測動きベクトルは、以下の規則に従ってMv1とMv2から導出される:
1)Mv1とMv2が異なる方向(L0またはL1)からの動きベクトルを有する場合、Mv1とMv2が単純に組み合わされて、双予測動きベクトルを形成する。
2)Mv1とMv2の両方が同じL0(またはL1)方向からである場合、
・Mv2の参照ピクチャーがL1(またはL0)参照ピクチャー・リスト内のあるピクチャーと同じである場合、Mv2はそのピクチャーに合わせてスケーリングされる。Mv1とスケーリングされたMv2が組み合わされて、双予測動きベクトルを形成する。
・Mv1の参照ピクチャーがL1(またはL0)参照ピクチャー・リスト内のあるピクチャーと同じである場合、Mv1はそのピクチャーに合わせてスケーリングされる。スケーリングされたMv1とMv2が組み合わされて、双予測動きベクトルを形成する。
・それ以外の場合は、重み付けされた領域について、Mv1のみが格納される。
2.2.4.4 マージ・モードについての構文テーブル、意味内容、デコード・プロセス
7.3.5.1 一般的なスライスヘッダ構文
six_minus_max_num_merge_candは、スライスにおいてサポートされるマージ動きベクトル予測(MVP)候補の最大数を6から引いたものを指定する。マージMVP候補の最大数MaxNumMergeCandは、次のように導出される:
MaxNumMergeCand=6-six_minus_max_num_merge_cand (7-57)
five_minus_max_num_subblock_merge_candは、スライスにおいてサポートされるサブブロック・ベースのマージ動きベクトル予測(MVP)候補の最大数を5から引いたものを指定する。five_minus_max_num_subblock_merge_candが存在しない場合は、5-sps_sbtmvp_enabled_flagに等しいと推定される。サブブロック・ベースのマージMVP候補の最大数MaxNumSubblockMergeCandは、次のように導出される:
MaxNumSubblockMergeCand=5-five_minus_max_num_subblock_merge_cand (7-58)
7.4.8.5 コーディング単位セマンティクス
pred_mode_flagが0に等しいことは、現在のコーディング単位がインター予測モードでコーディングされることを指定する。pred_mode_flagが1に等しいことは、現在のコーディング単位がイントラ予測モードでコーディングされることを指定する。
・cbWidthが4に等しく、cbHeightが4に等しい場合、pred_mode_flagは1に等しいと推定される。
・それ以外の場合、pred_mode_flagは、Iスライスをデコードするときは1に等しく、PまたはBスライスをデコードするときはそれぞれ0に等しいと推測される。
・pred_mode_flagが0に等しい場合、CuPredMode[x][y]はMODE_INTERに等しく設定される。
・それ以外の場合(pred_mode_flagが1に等しい場合)、CuPredMode[x][y]はMODE_INTRAに等しく設定される。
pred_mode_ibc_flagが1に等しいことは、現在のコーディング単位がIBC予測モードでコーディングされることを指定する。pred_mode_ibc_flagが0に等しいことは、現在のコーディング単位がIBC予測モードでコーディングされないことを指定する。
・cu_skip_flag[x0][y0]が1に等しく、cbWidthが4に等しく、cbHeightが4に等しい場合、pred_mode_ibc_flagは1と推定される。
・それ以外の場合、cbWidthとcbHeightの両方が128に等しい場合、pred_mode_ibc_flagは0に等しいと推定される。
・それ以外の場合、pred_mode_ibc_flagは、Iスライスをデコードする場合はsps_ibc_enabled_flagの値に等しいと推定され、PまたはBスライスをデコードする場合は0に等しいと推定される。
general_merge_flag[x0][y0]は、現在のコーディング単位のためのインター予測パラメータが近傍のインター予測されたパーティションから推定されるかどうかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・cu_skip_flag[x0][y0]が1に等しい場合、general_merge_flag[x0][y0]は1に等しいと推定される。
・それ以外の場合、general_merge_flag[x0][y0]は0と推定される。
mvp_l0_flag[x0][y0]は、リスト0の動きベクトル予測子インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
mvp_l1_flag[x0][y0]は、mvp_l0_flagと同じ意味内容をもち、l0とリスト0がそれぞれl1とリスト1に置き換えられる。
inter_pred_idc[x0][y0]は、テーブル7-10に従って、現在のコーディング単位についてリスト0、リスト1または双予測が使用されるかどうかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
7.4.8.7 マージ・データのセマンティクス
regular_merge_flag[x0][y0]が1に等しいことは、現在のコーディング単位のインター予測パラメータを生成するために、通常マージ・モードが使用されることを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・以下の条件がすべて真である場合、regular_merge_flag[x0][y0]は1に等しいと推定される:
・sps_mmvd_enabled_flagが0に等しい。
・general_merge_flag[x0][y0]が1に等しい。
・cbWidth*cbHeightが32に等しい。
・そうでない場合、regular_merge_flag[x0][y0]は0に等しいと推定される。
mmvd_merge_flag[x0][y0]が1に等しいことは、現在のコーディング単位のインター予測パラメータを生成するために、動きベクトル差を用いたマージ・モードが使用されることを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・以下の条件がすべて真である場合、mmvd_merge_flag[x0][y0]は1に等しいと推定される:
・sps_mmvd_enabled_flagが1に等しい。
・general_merge_flag[x0][y0]が1に等しい。
・cbWidth*cbHeightが32に等しい。
・regular_merge_flag[x0][y0]が0に等しい。
・それ以外の場合、mmvd_merge_flag[x0][y0]は0に等しいと推定される。
mmvd_cand_flag[x0][y0]は、マージ候補リストにおける第1の候補(0)または第2の候補(1)のどちらが、mmvd_distance_idx[x0][y0]とmmvd_direction_idx[x0][y0]から導出された動きベクトル差とともに使用されるかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
MmvdOffset[x0][y0][0]=(MmvdDistance[x0][y0]<<2)*MmvdSign[x0][y0][0] (7-124)
MmvdOffset[x0][y0][1]=(MmvdDistance[x0][y0]<<2)*MmvdSign[x0][y0][1] (7-125)
merge_subblock_flag[x0][y0]は、現在のコーディング単位についてのサブブロック・ベースのインター予測パラメータが近傍ブロックから推定されるかどうかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。merge_subblock_flag[x0][y0]が存在しない場合、0に等しいと推定される。
merge_subblock_idx[x0][y0]は、サブブロック・ベースのマージ候補リストのマージ候補インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
ciip_flag[x0][y0]は、現在のコーディング単位について、ピクチャー間マージおよびピクチャー内予測の組み合わせが適用されるかどうかを指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・以下の条件がすべて満たされている場合、MergeTriangleFlag[x0][y0]は1に設定される:
・sps_triangle_enabled_flagは1に等しい。
・slice_typeはBに等しい。
・general_merge_flag[x0][y0]は1に等しい。
・MaxNumTriangleMergeCandが2以上である。
・cbWidth*cbHeightが64以上である。
・regular_merge_flag[x0][y0]が0に等しい。
・mmvd_merge_flag[x0][y0]が0に等しい。
・merge_subblock_flag[x0][y0]が0に等しい。
・cip_flag[x0][y0]が0に等しい。
・それ以外の場合、MergeTriangleFlag[x0][y0]は0に設定される。
merge_triangle_split_dir[x0][y0]は、マージ三角モードの分割方向を指定する。配列インデックスx0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
merge_triangle_idx0[x0][y0]は、三角形形状に基づく動き補償候補リストの第1のマージ候補インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
merge_triangle_idx1[x0][y0]は、三角形形状に基づく動き補償候補リストの第2のマージ候補インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
merge_idx[x0][y0]は、マージ候補リストのマージ候補インデックスを指定する。ここで、x0、y0は、ピクチャーの左上のルーマ・サンプルに対する、考慮されているコーディングブロックの左上のルーマ・サンプルの位置(x0,y0)を指定する。
・mmvd_merge_flag[x0][y0]が1に等しい場合、merge_idx[x0][y0]は、mmvd_cand_flag[x0][y0]に等しいと推定される。
・それ以外の場合(mmvd_merge_flag[x0][y0]が0に等しい場合)、merge_idx[x0][y0]は0に等しいと推定される。
JVET-N0340において規定されているデコード・プロセスは、以下のように定義される。
このプロセスは、general_merge_flag[xCb][yCb]が1に等しい場合にのみ呼び出される。ここで、(xCb,yCb)は、現在のピクチャーの左上のルーマ・サンプルに対して現在のルーマコーディングブロックの左上のサンプルを指定する。
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマコーディングブロックの左上のサンプルのルーマ位置(xCb,yCb)、
・ルーマ・サンプル単位で現在のコーディングブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位で現在のコーディングブロックの高さを指定する変数cbHeight。
・1/16の端数サンプル精度でのルーマ動きベクトルmvL0[0][0]およびmvL1[0][0]、
・参照インデックスrefIdxL0およびrefIdxL1、
・予測リスト利用フラグpredFlagL0[0][0]およびpredFlagL1[0][0]、
・双予測重み指数bcwIdx、
・マージ候補リストmergeCandList。
1. 節8.5.2.3において指定されている近傍のコーディング単位からの空間的マージ候補についての導出プロセスが、ルーマコーディングブロック位置(xCb,yCb)、ルーマコーディングブロック幅(cbWidth)、ルーマコーディングブロック高さ(cbHeight)を入力として呼び出され、出力は、利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2、参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2、予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2、動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2(Xは0または1)、双予測重みインデックスbcwIdxA0、bcwIdxA1、bcwIdxB1、bcwIdxB2である。
2. 時間マージ候補Colについての参照インデックスrefIdxLXCol(Xは0または1)および双予測重みインデックスbcwIdxColが0に設定される。
3. 節8.5.2.11で指定されている時間的ルーマ動きベクトル予測のための導出プロセスが、ルーマ位置(xCb,yCb)、ルーマコーディングブロック幅cbWidth、ルーマコーディングブロック高さcbHeight、変数refIdxL0Colを入力として呼び出され、出力は利用可能性フラグavailableFlagL0Col、時間的動きベクトルmvL0Colである。変数availableFlagCol、predFlagL0ColおよびpredFlagL1Colは、次のように導出される:
availableFlagCol=availableFlagL0Col (8-263)
predFlagL0Col=availableFlagL0Col (8-264)
predFlagL1Col=0 (8-265)
4. slice_typeがBに等しい場合、節8.5.2.11で指定されている時間的ルーマ動きベクトル予測のための導出プロセスが、ルーマ位置(xCb,yCb)、ルーマコーディングブロック幅cbWidth、ルーマコーディングブロック高さcbHeight、変数refIdxL1Colを入力として呼び出され、出力は、利用可能性フラグavailableFlagL1Col、時間的動きベクトルmvL1Colである。変数availableFlagColおよびpredFlagL1Colは、次のように導出される:
availableFlagCol=availableFlagL0Col||availableFlagL1Col (8-266)
predFlagL1Col=availableFlagL1Col (8-267)
5. マージ候補リストmergeCandListは、次のように構築される:
7. numCurrMergeCandが(MaxNumMergeCand-1)より小さく、かつNumHmvpCandが0より大きい場合、次が適用される:
・節8.5.2.6において規定されている履歴ベースのマージ候補の導出プロセスが呼び出される。入力は、mergeCandListおよびnumCurrMergeCand、出力は修正されたmergeCandListおよびnumCurrMergeCand。
・numOrigMergeCandはnumCurrMergeCandと等しく設定される。
8. numCurrMergeCandがMaxNumMergeCandより小さく、かつ1より大きい場合、次が適用される:
・節8.5.2.4において指定されているペアワイズ平均マージ候補についての導出プロセスが、mergeCandList、参照インデックスrefIdxL0NおよびrefIdxL1N、予測リスト利用フラグpredFlagL0NおよびpredFlagL1N、mergeCandList内の各候補Nの動きベクトルmvL0NおよびmvL1N、およびnumCurrMergeCandを入力として呼び出され、出力は、mergeCandList、numCurrMergeCand、参照インデックスrefIdL0avgCandおよびrefIdxL1avgCand、予測リスト利用フラグpredFlagL0avgCandおよびpredFlagL1avgCand、およびmergeCandListに追加される候補avgCandの動きベクトルmvL0avgCandおよびmvL1avgCandに割り当てられる。mergeCandListに追加される候補avgCandの双予測重みインデックスbcwIdxが0に設定される。
・numOrigMergeCandはnumCurrMergeCandに等しく設定される。
9. 節8.5.2.5において指定されるゼロ動きベクトル・マージ候補の導出プロセスが、mergeCandList、参照インデックスrefIdxL0NおよびrefIdxL1N、予測リスト利用フラグpredFlagL0NおよびpredFlagL1N、mergeCandList内の各候補Nの動きベクトルmvL0NおよびmvL1NおよびnumCurrMergeCandを入力として呼び出され、出力は、mergeCandList、numCurrMergeCand、参照インデックスrefIdxL0zeroCandmおよびRefIdxL1zeroCandm、予測リスト利用フラグpredFlagL0zeroCandmおよびpredL1zeroCandm、ならびにmergeCandListに追加される各新規候補zeroCandmの動きベクトルmvL0zeroCandmおよびmvL1zeroCandmに割り当てられる。mergeCandListに追加されるすべての新しい候補zeroCandmの双予測重みインデックスbcwIdxは、0に等しく設定される。追加される候補の数numZeroMergeCandは(numCurrMergeCand-numOrigMergeCand)に等しく設定される。numZeroMergeCandが0より大きい場合、mの範囲は0からnumZeroMergeCand-1である(両端含む)。
10. 以下の割り当てがなされる。ここで、Nは、マージ候補リストmergeCandListにおける位置merge_idx[xCb][yCb]における候補であり(N=mergeCandList[merge_idx[xCb][yCb]])、Xは0または1で置き換えられる:
refIdxLX=refIdxLXN (8-269)
predFlagLX[0][0]=predFlagLXN (8-270)
mvLX[0][0][0]=mvLXN[0] (8-271)
mvLX[0][0][1]=mvLXN[1] (8-272)
bcwIdx=bcwIdxN (8-273)
11. mmvd_merge_flag[xCb][yCb]が1に等しい場合、以下が適用される:
・節8.5.2.7において指定されるマージ動きベクトル差のための導出プロセスが、ルーマ位置(xCb,yCb)、参照インデックスrefIdxL0、refIdxL1、予測リスト利用フラグpredFlagL0[0][0]、predFlagL1[0][0]を入力として呼び出される。出力は、動きベクトル差mMvdL0、mMvdL1。
・X=0、1について、動きベクトル差mMvdLXがマージ動きベクトルmvLXに、次のように加算される:
mvLX[0][0][0]+=mMvdLX[0] (8-274)
mvLX[0][0][1]+=mMvdLX[1] (8-275)
mvLX[0][0][0]=Clip3(-217,217-1,mvLX[0][0][0]) (8-276)
mvLX[0][0][1]=Clip3(-217,217-1,mvLX[0][0][1]) (8-277)
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマコーディングブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在のコーディングブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在のコーディングブロックの高さを指定する変数cbHeight。
・近傍のコーディング単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍のコーディング単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍のコーディング単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍のコーディング単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマコーディングブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
・availableA1がFALSEに等しい場合、availableFlagA1が0に等しく設定され、X=0または1として、mvLXA1の両成分が0に等しく設定され、refIdxLXA1が-1に等しく設定され、predFlagLXA1が0に等しく設定され、gbiIdxA1が0に等しく設定される。
・それ以外の場合、availableFlagA1は1に等しく設定され、以下の割り当てが行われる:
mvLXA1=MvLX[xNbA1][yNbA1] (8-294)
refIdxLXA1=RefIdxLX[xNbA1][yNbA1] (8-295)
predFlagLXA1=PredFlagLX[xNbA1][yNbA1] (8-296)
gbiIdxA1=GbiIdx[xNbA1][yNbA1] (8-297)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB1,yNbB1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB1に割り当てられる。
・変数availableFlagB1、refIdxLXB1、predFlagLXB1、mvLXB1は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB1が0に等しく設定され、X=0または1として、mvLXB1の両方の成分が0に等しく設定され、refIdxLXB1が-1に等しく設定され、predFlagLXB1が0に等しく設定され、gbiIdxB1が0に設定される:
・availableB1が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB1,yNbB1)は同じ動きベクトルと同じ参照インデックスをもつ。
・それ以外の場合、availableFlagB1は1に等しく設定され、以下の割り当てが行われる:
mvLXB1=MvLX[xNbB1][yNbB1] (8-298)
refIdxLXB1=RefIdxLX[xNbB1][yNbB1] (8-299)
predFlagLXB1=PredFlagLX[xNbB1][yNbB1] (8-300)
gbiIdxB1=GbiIdx[xNbB1][yNbB1] (8-301)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB0,yNbB0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB0に割り当てられる。
・変数availableFlagB0、refIdxLXB0、predFlagLXB0、mvLXB0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB0が0に等しく設定され、X=0または1として、mvLXB0の両方の成分が0に等しく設定され、refIdxLXB0が-1に等しく設定され、predFlagLXB0が0に等しく設定され、gbiIdxB0が0に設定される:
・availableB0が偽に等しい。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・それ以外の場合は、availableFlagB0が1に設定され、以下の割り当てが行われる:
mvLXB0=MvLX[xNbB0][yNbB0] (8-302)
refIdxLXB0=RefIdxLX[xNbB0][yNbB0] (8-303)
predFlagLXB0=PredFlagLX[xNbB0][yNbB0] (8-304)
gbiIdxB0=GbiIdx[xNbB0][yNbB0] (8-305)
・近傍のルーマコーディングブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA0,yNbA0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA0に割り当てられる。
・変数availableFlagA0、refIdxLXA0、predFlagLXA0、mvLXA0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagA0が0に等しく設定され、X=0または1として、mvLXA0の両方の成分が0に等しく設定され、refIdxLXA0が-1に等しく設定され、predFlagLXA0が0に等しく設定され、gbiIdxA0が0に設定される:
・availableA0が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもち、merge_triangle_flag[xCb][yCb]は1に等しい。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもち、merge_triangle_flag[xCb][yCb]は1に等しい。
・それ以外の場合は、availableFlagA0が1に設定され、以下の割り当てが行われる:
mvLXA0=MvLX[xNbA0][yNbA0] (8-306)
refIdxLXA0=RefIdxLX[xNbA0][yNbA0] (8-307)
predFlagLXA0=PredFlagLX[xNbA0][yNbA0] (8-308)
gbiIdxA0=GbiIdx[xNbA0][yNbA0] (8-309)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもち、merge_triangle_flag[xCb][yCb]は1に等しい。
・availableA0が真に等しく、ルーマ位置(xNbA0,yNbA0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもち、merge_triangle_flag[xCb][yCb]は1に等しい。
・availableFlagA0+availableFlagA1+availableFlagB0+availableFlagB1が4に等しく、merge_triangle_flag[xCb][yCb]が0に等しい。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
JVET-L0054では、極限動きベクトル表式(UMVE、MMVDとしても知られる)が提起されている。UMVEは、提案された動きベクトル表現法を用いて、スキップまたはマージ・モードのいずれかのために使用される。
JVET-L0100では、複数仮説予測が提案され、そこでは、イントラ予測とインター予測の組み合わせが、複数の仮説を生成するための1つの方法となる。
すべてのサブブロック関連動き候補は、非サブブロック・マージ候補のための通常のマージ・リストに追加される、別個のマージ・リストに入れられることが提案される。
a.ATMVP候補(利用可能であることも利用可能でないこともある);
b.アフィン・マージ・リスト(継承されたアフィン候補;および構築されたアフィン候補を含む);
c.ゼロMV 4パラメータ・アフィン・モデルとしてのパディング。
ATMVPの基本的なアイデアは、1ブロックについての時間的動きベクトル予測子の複数の集合を導出するというものである。各サブブロックには、1組の動き情報を割り当てられる。ATMVPマージ候補が生成されると、ブロック全体のレベルではなく、8×8レベルで動き補償が行われる。
初期化された動きベクトルをtempMvで表す。ブロックA1が利用可能であり、かつイントラコーディングされない場合(すなわち、インターまたはIBCモードでコーディングされる場合)、初期化された動きベクトルを導出するために、以下が適用される。
・以下の条件がすべて真である場合、tempMvは、mvL1A1で示される、リスト1のブロックA1の動きベクトルに等しく設定される:
・リスト1の参照ピクチャー・インデックスが利用可能であり(-1に等しくない)、共位置のピクチャーと同じPOC値をもつ(すなわち、DiffPicOrderCnt(ColPic,RefPicList[1][refIdxL1A1])が0に等しい)、
・すべての参照ピクチャーは現在のピクチャーと比較して、より大きなPOCを持たない(すなわち、DiffPicOrderCnt(aPic,currentPic)は、現在のスライスのすべての参照ピクチャー・リスト内のすべてのピクチャーaPicについて0以下である)、
・現在のスライスはBスライスに等しい、
・collocated_from_l0_flagが0に等しい。
・それ以外の場合、以下の条件がすべて真である場合、tempMvは、mvL0A1で示される、リスト0からのブロックA1の動きベクトルに等しく設定される:
・リスト0の参照ピクチャー・インデックスが利用可能である(-1に等しくない)、
・共位置のピクチャーと同じPOC値をもつ(すなわち、DiffPicOrderCnt(ColPic,RefPicList[0][refIdxL0A1])が0に等しい)。
・それ以外の場合、ゼロ動きベクトルが初期化されたMVとして使用される。
第2のステップは、現在のCUをサブCUに分割し、共位置のピクチャー内の各サブCUに対応するブロックから各サブCUの動作情報を取得することである。
このプロセスへの入力は以下の通りである:
・現在のコーディングブロックを指定する変数currCb、
・ColPicによって指定された共位置のピクチャー内の共位置のコーディングブロックを指定する変数colCb、
・ColPicによって指定された共位置のピクチャーの左上のルーマ・サンプルに対して、colCbによって指定された共位置のルーマコーディングブロックの左上のサンプルを指定するルーマ位置(xColCb,yColCb)、
・参照インデックスrefIdxLX、Xは0または1、
・サブブロックの時間的マージ候補sbFlagを示すフラグ。
・1/16端数サンプル精度での動きベクトル予測mvLXCol、
・利用可能性フラグavailableFlagLXCol。
・colCbがイントラまたはIBC予測モードでコーディングされる場合、mvLXColの両方の成分が0に等しく設定され、availableFlagLXColが0に等しく設定される。
・それ以外の場合、動きベクトルmvCol、参照インデックスrefIdxCol、参照リスト識別子listColは以下のように導出される:
・sbFlagが0に等しい場合、availableFlagLXColは1に等しく設定され、以下が適用される:
・predFlagL0Col[xColCb][yColCb]が0に等しい場合、mvCol、refIdxCol、listColはそれぞれmvL1Col[xColCb][yColCb]、refIdxL1Col[xColCb][yColCb]、L1に等しく設定される。
・それ以外の場合、predFlagL0Col[xColCb][yColCb]が1に等しく、predFlagL1Col[xColCb][yColCb]が0に等しい場合、mvCol、refIdxCol、listColは、それぞれ、mvL0Col[xColCb][yColCb]、refIdxL0Col[xColCb][yColCb]、L0に等しく設定される。
・それ以外の場合(predFlagL0Col[xColCb][yColCb]が1に等しく、predFlagL1Col[xColCb][yColCb]が1に等しい場合)、以下の割り当てが行われる:
・NoBackwardPredFlagが1に等しい場合、mvCol、refIdxCol、listColはそれぞれmvLXCol[xColCb][yColCb]、refIdxLXCol[xColCb][yColCb]、LXに等しく設定される。
・それ以外の場合、mvCol、refIdxCol、listColはそれぞれmvLNCol[xColCb][yColCb]、refIdxLNCol[xColCb][yColCb]、LNに等しく設定され、Nはcollocated_from_l0_flagの値である。
・それ以外の場合(sbFlagが1に等しい)、以下が適用される:
・PredFlagLXCol[xColCb][yColCb]が1に等しい場合、mvCol、refIdxCol、listColはそれぞれmvLXCol[xColCb][yColCb]、refIdxLXCol[xColCb][yColCb]、LXに等しく設定され、availableFlagLXColは1に等しく設定される。
・それ以外の場合(PredFlagLXCol[xColCb][yColCb]が0に等しい場合)、以下が適用される:
・DiffPicOrderCnt(aPic,currPic)が現在のスライスのすべての参照ピクチャー・リストのすべてのピクチャーaPicについて0以下であり、PredFlagLYCol[xColCb][YColCb]が1に等しく、mvCol、refIdxCol、listColはそれぞれmvLYCol[xColCb][yColCb]、refIdxLYCol[xColCb][yColCb]、LYに設定され、Yは!Xに等しく、Xはこのプロセスが呼び出されるXの値である。availableFlagLXColが1に設定される。
・mvLXColの両方の成分が0に設定され、availableFlagLXColは0に等しく設定される。
・availableFlagLXColがTRUEに等しい場合、mvLXColおよびavailableFlagLXColは次のように導出される:
・LongTermRefPic(currPic,currCb,refIdxLX,LX)がLongTermRefPic(ColPic,colCb,refIdxCol,listCol)に等しい場合、mvLXColの両方の成分は0に等しく設定され、availableFlagLXColは0に等しく設定される。
・それ以外の場合、変数availableFlagLXColは1に等しく設定され、refPicList[listCol][refIdxCol]は、ColPicによって指定される共位置のピクチャーにおけるコーディングブロックcolCbを含むスライスの参照ピクチャー・リストlistColにおける参照インデックスrefIdxColをもつピクチャーに設定され、以下が適用される:
colPocDiff=DiffPicOrderCnt(ColPic,refPicList[listCol][refIdxCol]) (8-402)
currPocDiff=DiffPicOrderCnt(currPic,RefPicList[X][refIdxLX]) (8-403)
・節8.5.2.15において指定される共位置の動きベクトルについての時間的動きバッファ圧縮プロセスが、mvColを入力、修正されたmvColを出力として呼び出される。
・RefPicList[X][refIdxLX]が長期の参照ピクチャーであるか、またはcolPocDiffがcurrPocDiffと等しい場合、mvLXColは次のように導出される:
mvLXCol=mvCol (8-404)
・それ以外の場合、mvXColは以下のように動きベクトルmvColのスケーリングされたバージョンとして導出される:
tx=(16384+(Abs(td)>>1))/td (8-405)
distScaleFactor=Clip3(-4096,4095,(tb*tx+32)>>6) (8-406)
mvLXCol=Clip3(-131072,131071,(distScaleFactor*mvCol+
128-(distScaleFactor*mvCol>=0))>>8)) (8-407)
ここで、tdとtbは次のように導出される:
td=Clip3(-128,127,colPocDiff) (8-408)
tb=Clip3(-128,127,currPocDiff) (8-409)
2.2.8.1 AMVP動き候補リスト
HEVCにおけるAMVP設計と同様に、2つまでのAMVP候補が導出されうる。しかしながら、HMVP候補はTMVP候補の後に追加されてもよい。HMVPテーブル内のHMVP候補は、インデックスの昇順で(すなわち、最も古いものである0に等しいインデックスから)たどられ、4つまでのHMVP候補が、その参照ピクチャーがターゲット参照ピクチャーと同じである(すなわち、同じPOC値)かどうかを見出すためにチェックされてもよい。
HEVCでは、スライスヘッダにおいてuse_integer_mv_flagが0に等しいとき、(PUの動きベクトルと予測された動きベクトルとの間の)動きベクトル差分(MVD)が、4分の1ルーマ・サンプルの単位で信号伝達される。VVCでは、局所的に適応的な動きベクトル分解能(adaptive motion vector resolution、AMVR)が導入される。VVCでは、MVDは、4分の1ルーマ・サンプル、整数ルーマ・サンプル、または4ルーマ・サンプル(すなわち、1/4画素、1画素、4画素)の単位でコーディングできる。MVD分解能は、コーディング単位(CU)レベルで制御され、MVD分解能フラグは、少なくとも1つのゼロでないMVD成分を有する各CUについて、条件付きで信号伝達される。
JVET-N1001-v2では、対称動きベクトル差分(symmetric motion vector difference、SMVD)が双予測における動き情報コーディングのために適用される。
2.2.9.1 デコーダ側動きベクトル洗練(DMVR)
双予測動作では、1つのブロック領域の予測のために、それぞれlist0の動きベクトル(MV)とlist1のMVを用いて形成された2つの予測ブロックが組み合わされて、単一の予測信号を形成する。デコーダ側動きベクトル洗練(decoder-side motion vector refinement、DMVR)法では、双予測の2つの動きベクトルがさらに洗練される。
MvdX=-1;
MvdY=-1;
If(Sad(1,0)<Sad(-1,0))
MvdX=1;
If(Sad(0,1)<Sad(0,-1))
MvdY=1;
・list0とlist1の間の(0,0)位置SADが閾値より小さい場合は、早期終了。
・list0とlist1の間のSADが何らかの位置についてゼロである場合、早期終了。
・DMVRについてのブロック・サイズ:W*H>=64 && H>=8。ここで、WとHはブロックの幅と高さである。
・CUサイズ>16×16のDMVRについて、CUを16×16のサブブロックの複数に分割する。
・CUの幅または高さのみが16より大きい場合、垂直方向または水平方向にのみ分割される。
・参照ブロック・サイズ(W+7)*(H+7)(ルーマ用)。
・25点のSADベースの整数画素探索(すなわち(±)2洗練探索範囲、単一ステージ)
・双線形補間ベースのDMVR。
・「パラメトリック誤差面の式(Parametric error surface equation)」に基づくサブ画素洗練。
・この手順は、最後のMV洗練反復工程において、最小のSADコストがゼロに等しくなく、最良のMVDが(0,0)である場合にのみ、実行される。
・参照ブロック・パディングを伴う(必要な場合)、ルーマ/クロマMC。
・MCおよびTMVPのみのために使用される洗練されたMV。
以下の条件がすべて真である場合、DMVRが有効にされてもよい。
・SPSにおけるDMVR有効化フラグ(すなわちsps_dmvr_enabled_flag)が1に等しい
・TPMフラグ、インター・アフィン・フラグ、サブブロック・マージ・フラグ(ATMVPまたはアフィン・マージ)、MMVDフラグがすべて0に等しい
・マージ・フラグが1に等しい
・現在ブロックは双予測され、現在のピクチャーとリスト1内の参照ピクチャーとの間のPOC距離は、リスト0内の参照ピクチャーと現在のピクチャーとの間のPOC距離に等しい
・現在のCU高さが8以上
・ルーマ・サンプルの数(CU幅*高さ)が64以上。
本方法は、下記に要約される:
1. パラメトリック誤差面フィットは、中心位置が所与の反復工程において最良のコスト位置である場合にのみ計算される。
2. 中心位置コストと中心から(-1,0)、(0,-1)、(1,0)および(0,1)位置でのコストが、
E(x,y)=A(x-x0)2+B(y-y0)2+C
の形の二次元の放物状の誤差面の式にフィットするために使用される。ここで、(x0,y0)は最小コストの位置に対応し、Cは最小コスト値に対応する。5つの未知数の5つの方程式を解くことによって、(x0,y0)は次のように計算される:
x0=(E(-1,0)-E(1,0))/(2(E(-1,0)+E(1,0)-2E(0,0)))
y0=(E(0,-1)-E(0,1))/(2(E(0,-1)+E(0,1)-2E(0,0)))
(x0,y0)は、除算が実行される精度(すなわち、商の何ビットが計算されるか)を調整することによって、任意の必要なサブピクセル精度まで計算できる。1/16画素の精度のためには、商の絶対値の4ビットが計算されるだけでよく、これは、CUごとに必要な2つの除算の高速シフトされる減算ベースの実装に役立つ。計算された(x0,y0)は、整数距離洗練MVに加算されて、サブピクセル精度の洗練デルタMVを得る。
HEVCスクリーンコンテンツコーディング拡張(HEVC-SCC)および現在のVVCテストモデル(VTM-4.0)では、現在のピクチャー参照としても知られるイントラブロックコピー(IBC)が採用されている。IBCは、動き補償の概念をフレーム間コーディングからフレーム内コーディングに拡張するものである。図21に示されているように、IBCが適用されるとき、現在ブロックは、同じピクチャー内の参照ブロックによって予測される。参照ブロック内のサンプルは、現在ブロックがコーディングまたは復号される前にすでに再構成されていなければならない。IBCは、ほとんどのカメラ捕捉されたシーケンスについてはそれほど効率的ではないが、スクリーンコンテンツについては顕著なコーディング利得を示す。その理由は、スクリーンコンテンツピクチャーにはアイコンやテキスト文字などの反復パターンが多数存在することである。IBCは、これらの反復パターン間の冗長性を効果的に除去することができる。HEVC-SCCでは、インターコーディングされるコーディング単位(CU)は、現在のピクチャーをその参照ピクチャーとして選択する場合、IBCを適用することができる。この場合、MVはブロックベクトル(BV)に名称変更され、BVは常に整数ピクセル精度をもつ。メインプロファイルHEVCとの互換性を保つために、現在のピクチャーは、デコードピクチャーバッファ(DPB)において「長期」参照ピクチャーとしてマークされる。同様に、マルチビュー/3Dビデオコーディング標準においては、ビュー間参照ピクチャーも「長期」参照ピクチャーとしてマークされることに注意すべきである。
現在のVVCテストモデル、すなわち、VTM-4.0設計では、参照ブロック全体が現在のコーディングツリー単位(CTU)と一緒であるべきであり、現在ブロックと重複しない。よって、参照ブロックまたは予測ブロックをパディングする必要はない。IBCフラグは、現在のCUの予測モードとしてコーディングされる。よって、各CUについて、全部で3つの予測モード、MODE_INTRA、MODE_INTER、MODE_IBCがある。
IBCマージ・モードでは、IBCマージ候補リスト内のエントリーを指すインデックスがビットストリームからパースされる。IBCマージ・リストの構築は、以下の一連のステップに従って要約できる:
・ステップ1;空間的候補の導出
・ステップ2:HMVP候補の挿入
・ステップ3:ペアワイズ平均候補の挿入。
IBC AMVPモードでは、IBC AMVPリスト内のエントリーを指すAMVPインデックスがビットストリームからパースされる。IBC AMVPリストの構築は、以下の一連のステップに従って要約できる:
・ステップ1:空間的候補の導出
○利用可能な候補が見つかるまで、A0、A1をチェックする。
○利用可能な候補が見つかるまで、B0、B1、B2をチェックする。
・ステップ2:HMVP候補の挿入
・ステップ3:ゼロ候補の挿入。
現在のVVCでは、クロマIBCモードでの動き補償はサブブロック・レベルで実行される。クロマ・ブロックは、いくつかのサブブロックに分割される。各サブブロックは、対応するルーマ・ブロックがブロックベクトルをもつかどうかを、またそれが存在する場合には有効性を決定する。現在のVTMにはエンコーダ制約があり、現在のクロマCU内のすべてのサブブロックが有効なルーマ・ブロックベクトルをもつ場合に、クロマIBCモードがテストされる。たとえば、YUV 420ビデオでは、クロマ・ブロックはN×Mであり、すると、共位置のルーマ領域は2N×2Mである。クロマ・ブロックのサブブロック・サイズは2×2である。クロマmv導出、次いでブロック・コピー・プロセスを実行するためのいくつかのステップがある。
1)クロマ・ブロックがまず(N>>1)*(M>>1)サブブロックに分割される。
2)(x,y)を座標とする左上サンプルをもつ各サブブロックは、(2x,2y)を座標とする同じ左上サンプルをカバーする対応するルーマ・ブロックを取ってくる。
3)エンコーダは、取ってこられたルーマ・ブロックのブロックベクトル(bv)をチェックする。以下の条件のいずれかが満たされた場合、bvは無効とみなされる。
a. 対応するルーマ・ブロックのbvが存在しない。
b. bvによって同定された予測ブロックはまだ再構築されていない。
c. bvによって同定された予測ブロックは、現在ブロックと部分的または完全に重複している。
4)サブブロックのクロマ動きベクトルは、対応するルーマ・サブブロックの動きベクトルに設定される。
JVET-N0843がVVCに採用されている。JVET-N0843では、IBCにおける、マージ・モードおよびAMVPモードのためのBV予測子は、共通の予測子リストを共有する。これは、以下の要素から構成される:
・2つの空間的近傍位置(図2のA1、B1)
・5つのHMVPエントリー
・デフォルトのゼロ・ベクトル
マージ・モードの現在の設計には、次のような問題がありうる:
1. 通常のマージ・リスト構築プロセスは、現在ブロックについてのTPMの使用に依存する。
a. TPMコーディングされるブロックについては、空間的マージ候補の間でフル剪定が適用される。
b. 非TPMコーディングされるブロックについては、空間的マージ候補の間で部分的な剪定が適用される。
2. 現在の設計によれば、すべてのマージ関連ツール(IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIP、TPMを含む)は、general_merge_flagという名前の1つのフラグによって信号伝達される。しかしながら、このフラグが真である場合、すべてのマージ関連ツールが無効にされるように信号伝達される、または導出される可能性がある。この場合をどのように扱うかが不明である。また、マージ・モードをオフにすることはできない。すなわち、マージ候補の最大数は0に等しくない。しかしながら、高スループットのエンコーダ/デコーダの場合、マージ・モードの無効化を強制する必要がありうる。
3. ATMVPプロセスについての初期化されたMVの決定は、スライスタイプ、すべての参照ピクチャーのPOC値、collocated_from_10_flagなどに依存し、これはMVのスループットを遅らせる。
4. 共位置のMVの導出プロセスは、従来のTMVPプロセスまたはATMVPプロセスのようなサブブロック技術の使用に依存し、これは追加のロジックを必要とする。
5. ATMVPコーディングされたブロック内のサブCUについては、その対応する共位置のブロックがインターコーディングされていても、サブCUの動き情報は、対応する共位置のブロックから導出できず、他の動き情報を用いて満たされる可能性がある。そのような設計は、コーディング効率とスループットの両方にとって最適ではない。
6. HEVC仕様は、現在または参照ピクチャー内の1つの近傍ブロックの利用可能性を、該ブロックが構築されているか、または異なるCTU行/スライス内にあるかなどに基づいて定義する。しかしながら、VVCでは、複数のコーディング方法が導入されている。ブロックの利用可能性の異なる定義が定義される必要があるかもしれない。
7. JVET-O0545は、sps_sbt_max_size_64_flagを送信することにより、最大変換ブロック・サイズの指標を信号伝達することを提案する。
sps_sbt_max_size_64_flagが0に等しいことは、サブブロック変換を許容するための最大CU幅と高さが32ルーマ・サンプルであることを指定する。
sps_sbt_max_size_64_flagが1に等しいことは、サブブロック変換を許容するための最大CU幅と高さが64ルーマ・サンプルであることを指定する。
MaxSbtSize=sps_sbt_max_size_64_flag ? 64:32 (7 31)
64より小さい最大変換サイズ(MaxTransformSizeによって示される)をサポートするために、MaxSbtSizeの導出は以下のように修正される。
MaxSbtSize=min(MaxTransformSize,sps_sbt_max_size_64_flag ? 64:32)
8. 適応ループフィルタ(ALF)係数が固定範囲内に制約される。たとえば、AlfCoeffCによって表されるクロマALFフィルタ係数およびAlfCoeffLによって表されるルーマALFフィルタ係数は、-27から27-1の範囲でなければならない(両端含む)。そのような制約は、8ビット深さの想定に基づく。
9. ALFフィルタの予測子の指示は以下のように信号伝達される:
10. マージ関連のコーディングツールは以下のとおり:
以下の詳細なリストは、一般的な概念を説明するための例として考慮されるべきである。これらの実施形態は狭義に解釈されるべきではない。さらに、これらの技法は、任意の方法で組み合わせることができる。
1. 従来のマージとTPMコーディングされたブロックについての通常マージ・リスト構築プロセスは、現在ブロックのコーディング方法から切り離される。
a. 一例では、TPMが1つのブロックに適用されるとき、部分的剪定が空間的マージ候補に適用される。
i. 一例では、2つの候補が互いに比較されるかどうかは、非TPMマージコーディングブロックについて使用されるのと同じ仕方で決定される。
ii. 一例では、B1はA1と比較され、B0はB1と比較され、A0はA1と比較され、B2はB1およびA1と比較される。
iii. あるいはまた、TPMが1つのブロックについて使用されない場合でも、フル剪定が空間的マージ候補に適用される。
iv. あるいはまた、さらに、いくつかの特定のブロック寸法にフル剪定が適用されてもよい。
1. たとえば、フル剪定は、TPMが許容されるブロック寸法に適用されてもよい。
2. たとえば、ブロック・サイズがM*Hより小さいサンプル、たとえば、16または32または64ルーマ・サンプルを含む場合、フル剪定は許容されない。
3. たとえば、ブロックの幅>th1または≧th1および/またはブロックの高さ>th2または≧th2の場合、フル剪定は許容されない。
b. 一例では、B2をチェックするかどうかは、TPMが1つのブロックに適用されるときにB2をチェックする前の利用可能なマージ候補の数に基づく。
i. あるいはまた、B2は、非TPMマージコーディングブロックについて利用可能なマージ候補の数にかかわらず、常にチェックされる。
2. ATMVPが利用可能かどうかを決定するためにブロックを識別するために使用される初期化されたMVは、単に空間的近傍ブロック(たとえば、A1)のリストX情報に依拠してもよく、Xは、時間的な動きベクトル予測のために使用される共位置のピクチャーがそこから導かれるところ(たとえば、collocated_from_l0_flag)に設定される。
a. あるいはまた、Xは、すべての参照リスト中のすべての参照ピクチャーが、現在のピクチャーと比較して、より小さいPOC値、またはより大きくないPOC値をもつかどうかに従って決定される。
i. 一例では、それが真であれば、Xは1に設定される。それ以外の場合、Xは0に設定される。
b. あるいはまた、空間的近傍ブロック(たとえば、A1)のリストXに関連する参照ピクチャーが利用可能であり、共位置のピクチャーと同じPOC値を有する場合、初期化されたMVは、空間的近傍ブロックのリストXに関連するMVに設定される。それ以外の場合、デフォルトのMV(たとえば(0,0))が利用される。
c. あるいはまた、HMVPテーブルに格納された動き情報が、ATMVPにおいて、初期化されたMVとして使用されてもよい。
i. たとえば、HMVPテーブルに記憶された第1の利用可能な動き情報が使用されてもよい。
ii. たとえば、ある参照ピクチャー(たとえば、共位置のピクチャー)に関連付けられた、HMVPテーブルに格納された第1の利用可能な動き情報が使用されてもよい。
d. あるいはまた、Xは0または1のような固定数である。
3. サブブロック・ベースのコーディングツールおよび非サブブロック・ベースのコーディングツールのために使用される共位置のMVの導出プロセスは、整列されてもよい、すなわち、該プロセスは、特定のコーディングツールの使用から独立している。
a. 一例では、サブブロック・ベースのコーディングツールのための共位置のMVの導出プロセスの全体または一部は、TMVPのために使用されるものと整列される。
i. 一例では、それがリストYからの単予測である場合、リストYの動きベクトルは、ターゲット参照ピクチャー・リストXにスケーリングされる;
ii. 一例では、それが双予測であり、ターゲット参照ピクチャー・リストがXである場合、リストYの動きベクトルは、ターゲット参照ピクチャー・リストXにスケーリングされ、Yは以下の規則に従って決定されうる:
・現在のピクチャーに比べて、参照ピクチャーのどれも、より大きなPOC値をもたない、またはすべての参照ピクチャーが、より小さなPOC値をもつ場合は、YはXに設定される。
・それ以外の場合、Yはcollocated_from_10_flagに等しく設定される。
b. 一例では、TMVPのための共位置のMVの導出プロセスの全体または一部は、サブブロック・ベースのコーディングツールのために使用されるものと整列される。
4. 動き候補リスト構築プロセス(たとえば、通常マージ・リスト、IBCマージ/AMVPリスト)は、ブロック寸法および/またはマージ共有条件に依存してもよい。ブロックの幅をW、高さをHとする。条件Cは、WおよびH、および/またはマージ共有条件に依存してもよい。
a. 一例では、条件Cが満たされる場合、空間的マージ候補の導出はスキップされる。
b. 一例では、条件Cが満たされる場合、HMVP候補の導出はスキップされる。
c. 一例では、条件Cが満たされる場合、ペアワイズ・マージ候補の導出はスキップされる。
d. 一例では、条件Cが満たされる場合、最大剪定動作の数が減らされるか、または0に設定される。
e. 一例では、条件Cは、W*Hが閾値(たとえば、64または32)より小さいか、または大きくないときに満たされる。
f. 一例では、条件Cは、Wおよび/またはHが閾値(たとえば、4または8)より小さいか、または大きくないときに満たされる。
g. 一例では、条件Cは、現在ブロックが共有されるノードの下にある場合に満たされる。
5. 許容される通常マージ候補の最大数/許容されるIBC候補の最大数/許容されるサブブロック・マージ候補の最大数が0に設定されてもよい。よって、ある種のツールが無効にされている可能性があり、関連する構文要素は信号伝達される必要はない。
a. 一例では、許容される正規マージ候補の最大数が0に等しい場合、通常マージ・リストに依拠するコーディングツールを無効にされてもよい。コーディングツールは、通常マージ、MMVD、CIIP、TPM、DMVRなどであってもよい。
b. 一例では、許容されるIBC候補の最大数が0に等しい場合、IBC AMVPおよび/またはIBCマージが無効にされてもよい。
c. 一例では、許容されるサブブロック・ベースのマージ候補の最大数が0に等しい場合、サブブロック・ベースの技術、たとえばATMVP、アフィン・マージ・モードは無効にされてもよい。
d. 許容される候補の最大数に従ってあるツールが無効にされる場合、関連する構文要素の信号伝達はスキップされる。
i. あるいはまた、さらに、マージ関連ツールの信号伝達は、許容される候補の最大数が0と等しくないかどうかをチェックする必要があるかもしれない。
ii. あるいはまた、さらに、マージ関連ツールのためのプロセスの呼び出しは、許容される候補の最大数が0と等しくないかどうかをチェックする必要があるかもしれない。
6. general_merge_flagおよび/またはcu_skip_flagの信号伝達は、許容される通常マージ候補の最大数/許容されるIBC候補の最大数/許容されるサブブロック・マージ候補の最大数/マージ関連のコーディングツールの使用に依存してもよい。
a. 一例では、マージ関連のコーディングツールは、IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIP、TPM、DMVR等を含みうる。
b. 一例では、許容される通常マージ候補の最大数、許容されるIBCマージ/AMVP候補の最大数、許容されるサブブロック・マージ候補の最大数が0に等しい場合、general_merge_flagおよび/またはcu_skip_flagは信号伝達されない。
i. あるいはまた、さらに、general_merge_flagおよび/またはcu_skip_flagは0であると推定される。
7. 適合ビットストリームは、現在ブロックのgeneral_merge_flagまたはcu_skip_flagが真である場合、IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIP、TPM、DMVRなどを含むマージ関連ツールの少なくとも1つが有効にされるということを満足するものとする。
8. 適合ビットストリームは、現在ブロックの(general_merge_flagまたはcu_skip_flag)が真であり、1つのスライス/タイル/ブリック/ピクチャー/現在ブロックについてIBCが無効にされている場合、通常マージ、MMVD、サブブロック・マージ、CIIP、TPM、DMVRなどを含むマージ関連ツールの少なくとも1つが有効にされるということを満足するものとする。
9. 適合ビットストリームは、現在ブロックの(general_merge_flagまたはcu_skip_flag)が真であり、1つのスライス/タイル/ブリック/ピクチャー/現在ブロックについてMMVDが無効にされている場合、IBCマージ、通常マージ、サブブロック・マージ、CIIP、TPMを含むマージ関連ツールのうちの少なくとも1つが有効にされるということを満足するものとする。
10. 適合ビットストリームは、現在ブロックの(general_merge_flagまたはcu_skip_flag)が真であり、1つのスライス/タイル/ブリック/ピクチャー/現在ブロックについてCIIPが無効にされている場合、IBCマージ、通常マージ、MMVD、サブブロック・マージ、TPMを含むマージ関連ツールの少なくとも1つが有効にされるということを満足するものとする。
11. 適合ビットストリームは、現在ブロックの(general_merge_flagまたはcu_skip_flag)が真であり、1つのスライス/タイル/ブリック/ピクチャー/現在ブロックについてTPMが無効にされている場合、IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIPを含むマージ関連ツールの少なくとも1つが有効にされるということを満足するものとする。
12. 適合ビットストリームは、現在ブロックのgeneral_merge_flagまたはcu_skip_flagが真であるとき、IBCマージ、通常マージ、MMVD、サブブロック・マージ、CIIP、TPMを含む有効にされたマージ関連ツールの少なくとも1つが適用されるということを満足するものとする。第1のブロックをコーディングするとき、第2のブロックの利用可能性のチェックは、第1のブロックのコーディングされたモード情報に依存してもよい。たとえば、第1および第2のブロックにおいて異なるモードが使用されている場合、第2のブロックは、他の条件チェック結果(たとえば、構築された)にかかわらず、利用不能として扱われてもよい。
a. 一例では、第1のブロックがインターコーディングされ、第2のブロックがIBC符号である場合、第2のブロックは利用不能としてマークされる。
b. 一例では、第1のブロックがIBCコーディングされ、第2のブロックがインター符号である場合、第2のブロックは利用不能とマークされる。
c. 第2が利用不能とマークされている場合、関連するコーディングされた情報(たとえば、動き情報)は、第1のブロックをコーディングするために利用されることが禁止される。
13. TPMサイド情報と無関係な構文要素の信号伝達は、許容されるTPM候補の数の条件チェックの下にあってもよい。
a. 一例では、CIIP関連の構文要素(たとえば、ciip_flag)の信号伝達は、許容されるTPM候補の数が閾値Kより大きいかどうかに依存してもよい。
b. 一例では、通常マージ・モード・フラグ(たとえば、regular_merge_flag)の信号伝達は、許容されるTPM候補の数が閾値Kより大きいかどうかに依存してもよい。
c. 一例では、Kが1に設定される。
d. あるいはまた、さらに、許容されるTPM候補の数が閾値K以下の場合、ある種の構文要素は信号伝達されなくてもよい。
14. 適合ビットストリームは、最大変換ブロック・サイズが最大CTUサイズを超えないということを満足する。
a. あるいはまた、最大変換ブロック・サイズの指示が、最大CTUサイズの下で条件付きで信号伝達されてもよいし、その逆も可能である。
i. 一例では、最大CTUサイズがM×N以下(たとえば、M=N=32)である場合、最大変換ブロック・サイズの指示を信号伝達する必要はない。
15. ALFフィルタ係数の範囲は、固定された範囲ではなく、サンプル深さ(たとえば、内部ビット深さまたは入力ビット深さ)に依存してもよい。
16. 固定フィルタに対してALF APSにおいてALFフィルタを使用するかどうかを示すために、1つのフラグが直接信号伝達されてもよい。
a. また、そのようなフラグは、利用可能なALF APSの数が0より大きいという条件の下で信号伝達されてもよい。
b. あるいはまた、さらに、APSからのALFフィルタが信号伝達される場合、ALF APSのインデックスを示すために、1つの追加的な構文がさらに信号伝達されてもよい。そのようなインデックスは、固定長コーディング、単進コーディング、打ち切りされた単進コーディング、打ち切りされた二進コーディング、指数ゴロムコーディングを用いてコーディングされてもよい。
最新のVVC作業原案(JVET-N1001_v7)に加える提案される変更点は以下の通りである。削除されるテキストは、[[ ]]と下線で示される。新たに追加された部分は太字でハイライトされる。
この実施形態は、非TPMコーディングブロックについての剪定プロセスを、TPMコーディングされたブロックについての剪定プロセスに整列させる、すなわち、非TPMコーディングブロックについてのフル剪定操作である。
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマコーディングブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在のコーディングブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在のコーディングブロックの高さを指定する変数cbHeight。
・近傍のコーディング単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍のコーディング単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍のコーディング単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍のコーディング単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマコーディングブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
・availableA1がFALSEに等しい場合、availableFlagA1が0に等しく設定され、X=0または1として、mvLXA1の両成分が0に等しく設定され、refIdxLXA1が-1に等しく設定され、predFlagLXA1が0に等しく設定され、gbiIdxA1が0に等しく設定される。
・それ以外の場合、availableFlagA1は1に等しく設定され、以下の割り当てが行われる:
mvLXA1=MvLX[xNbA1][yNbA1] (8-294)
refIdxLXA1=RefIdxLX[xNbA1][yNbA1] (8-295)
predFlagLXA1=PredFlagLX[xNbA1][yNbA1] (8-296)
gbiIdxA1=GbiIdx[xNbA1][yNbA1] (8-297)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB1,yNbB1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB1に割り当てられる。
・変数availableFlagB1、refIdxLXB1、predFlagLXB1、mvLXB1は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB1が0に等しく設定され、X=0または1として、mvLXB1の両方の成分が0に等しく設定され、refIdxLXB1が-1に等しく設定され、predFlagLXB1が0に等しく設定され、gbiIdxB1が0に設定される:
・availableB1が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB1,yNbB1)は同じ動きベクトルと同じ参照インデックスをもつ。
・それ以外の場合、availableFlagB1は1に等しく設定され、以下の割り当てが行われる:
mvLXB1=MvLX[xNbB1][yNbB1] (8-298)
refIdxLXB1=RefIdxLX[xNbB1][yNbB1] (8-299)
predFlagLXB1=PredFlagLX[xNbB1][yNbB1] (8-300)
gbiIdxB1=GbiIdx[xNbB1][yNbB1] (8-301)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB0,yNbB0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB0に割り当てられる。
・変数availableFlagB0、refIdxLXB0、predFlagLXB0、mvLXB0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB0が0に等しく設定され、X=0または1として、mvLXB0の両方の成分が0に等しく設定され、refIdxLXB0が-1に等しく設定され、predFlagLXB0が0に等しく設定され、gbiIdxB0が0に設定される:
・availableB0が偽に等しい。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ[[、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・それ以外の場合は、availableFlagB0が1に設定され、以下の割り当てが行われる:
mvLXB0=MvLX[xNbB0][yNbB0] (8-302)
refIdxLXB0=RefIdxLX[xNbB0][yNbB0] (8-303)
predFlagLXB0=PredFlagLX[xNbB0][yNbB0] (8-304)
gbiIdxB0=GbiIdx[xNbB0][yNbB0] (8-305)
・近傍のルーマコーディングブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA0,yNbA0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA0に割り当てられる。
・変数availableFlagA0、refIdxLXA0、predFlagLXA0、mvLXA0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagA0が0に等しく設定され、X=0または1として、mvLXA0の両方の成分が0に等しく設定され、refIdxLXA0が-1に等しく設定され、predFlagLXA0が0に等しく設定され、gbiIdxA0が0に設定される:
・availableA0が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ[[、merge_triangle_flag[xCb][yCb]は1に等しい]]。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ[[、merge_triangle_flag[xCb][yCb]は1に等しい]]。
・それ以外の場合は、availableFlagA0が1に設定され、以下の割り当てが行われる:
mvLXA0=MvLX[xNbA0][yNbA0] (8-306)
refIdxLXA0=RefIdxLX[xNbA0][yNbA0] (8-307)
predFlagLXA0=PredFlagLX[xNbA0][yNbA0] (8-308)
gbiIdxA0=GbiIdx[xNbA0][yNbA0] (8-309)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ[[、merge_triangle_flag[xCb][yCb]は1に等しい]]。
・availableA0が真に等しく、ルーマ位置(xNbA0,yNbA0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ[[、merge_triangle_flag[xCb][yCb]は1に等しい]]。
・availableFlagA0+availableFlagA1+availableFlagB0+availableFlagB1が4に等しく、merge_triangle_flag[xCb][yCb]が0に等しい。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
この実施形態は、TPMコーディングブロックについての剪定プロセスを、非TPMコーディングブロックについての剪定プロセスに整列させる、すなわち、TPMコーディングされるブロックについての限定的な剪定操作である。
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマコーディングブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在のコーディングブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在のコーディングブロックの高さを指定する変数cbHeight。
・近傍のコーディング単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍のコーディング単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍のコーディング単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍のコーディング単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマコーディングブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
・availableA1がFALSEに等しい場合、availableFlagA1が0に等しく設定され、X=0または1として、mvLXA1の両成分が0に等しく設定され、refIdxLXA1が-1に等しく設定され、predFlagLXA1が0に等しく設定され、gbiIdxA1が0に等しく設定される。
・それ以外の場合、availableFlagA1は1に等しく設定され、以下の割り当てが行われる:
mvLXA1=MvLX[xNbA1][yNbA1] (8-294)
refIdxLXA1=RefIdxLX[xNbA1][yNbA1] (8-295)
predFlagLXA1=PredFlagLX[xNbA1][yNbA1] (8-296)
gbiIdxA1=GbiIdx[xNbA1][yNbA1] (8-297)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB1,yNbB1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB1に割り当てられる。
・変数availableFlagB1、refIdxLXB1、predFlagLXB1、mvLXB1は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB1が0に等しく設定され、X=0または1として、mvLXB1の両方の成分が0に等しく設定され、refIdxLXB1が-1に等しく設定され、predFlagLXB1が0に等しく設定され、gbiIdxB1が0に設定される:
・availableB1が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB1,yNbB1)は同じ動きベクトルと同じ参照インデックスをもつ。
・それ以外の場合、availableFlagB1は1に等しく設定され、以下の割り当てが行われる:
mvLXB1=MvLX[xNbB1][yNbB1] (8-298)
refIdxLXB1=RefIdxLX[xNbB1][yNbB1] (8-299)
predFlagLXB1=PredFlagLX[xNbB1][yNbB1] (8-300)
gbiIdxB1=GbiIdx[xNbB1][yNbB1] (8-301)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB0,yNbB0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB0に割り当てられる。
・変数availableFlagB0、refIdxLXB0、predFlagLXB0、mvLXB0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB0が0に等しく設定され、X=0または1として、mvLXB0の両方の成分が0に等しく設定され、refIdxLXB0が-1に等しく設定され、predFlagLXB0が0に等しく設定され、gbiIdxB0が0に設定される:
・availableB0が偽に等しい。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB0,yNbB0)は同じ動きベクトルと同じ参照インデックスをもつ。
・[[availableA 1 が真に等しく、ルーマ位置(xNbA 1 ,yNbA 1 )と(xNbB 0 ,yNbB 0 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・それ以外の場合は、availableFlagB0が1に設定され、以下の割り当てが行われる:
mvLXB0=MvLX[xNbB0][yNbB0] (8-302)
refIdxLXB0=RefIdxLX[xNbB0][yNbB0] (8-303)
predFlagLXB0=PredFlagLX[xNbB0][yNbB0] (8-304)
gbiIdxB0=GbiIdx[xNbB0][yNbB0] (8-305)
・近傍のルーマコーディングブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA0,yNbA0)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA0に割り当てられる。
・変数availableFlagA0、refIdxLXA0、predFlagLXA0、mvLXA0は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagA0が0に等しく設定され、X=0または1として、mvLXA0の両方の成分が0に等しく設定され、refIdxLXA0が-1に等しく設定され、predFlagLXA0が0に等しく設定され、gbiIdxA0が0に設定される:
・availableA0が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbA0,yNbA0)は同じ動きベクトルと同じ参照インデックスをもつ。
・[[availableB 1 が真に等しく、ルーマ位置(xNbB 1 ,yNbB 1 )と(xNbA 0 ,yNbA 0 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・[[availableB 0 が真に等しく、ルーマ位置(xNbB 0 ,yNbB 0 )と(xNbA 0 ,yNbA 0 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・それ以外の場合は、availableFlagA0が1に設定され、以下の割り当てが行われる:
mvLXA0=MvLX[xNbA0][yNbA0] (8-306)
refIdxLXA0=RefIdxLX[xNbA0][yNbA0] (8-307)
predFlagLXA0=PredFlagLX[xNbA0][yNbA0] (8-308)
gbiIdxA0=GbiIdx[xNbA0][yNbA0] (8-309)
・近傍のルーマコーディングブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・[[availableB 0 が真に等しく、ルーマ位置(xNbB 0 ,yNbB 0 )と(xNbB 2 ,yNbB 2 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・[[availableA 0 が真に等しく、ルーマ位置(xNbA 0 ,yNbA 0 )と(xNbB 2 ,yNbB 2 )は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい]]。
・availableFlagA0+availableFlagA1+availableFlagB0+availableFlagB1が4に等しく、merge_triangle_flag[xCb][yCb]が0に等しい。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
この実施形態は、B2のチェックを呼び出すための条件を揃える。
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマコーディングブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在のコーディングブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在のコーディングブロックの高さを指定する変数cbHeight。
・近傍のコーディング単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍のコーディング単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍のコーディング単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍のコーディング単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマコーディングブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
……
・近傍のルーマコーディングブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
……
・近傍のルーマコーディングブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
……
・近傍のルーマコーディングブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
……
・近傍のルーマコーディングブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・availableA0が真に等しく、ルーマ位置(xNbA0,yNbA0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・availableFlagA0+availableFlagA1+availableFlagB0+availableFlagB1が4に等しい[[、そしてmerge_triangle_flag[xCb][yCb]が0に等しい]]。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
この実施形態は、B2のチェックを呼び出すための条件を揃える。
このプロセスへの入力は以下の通りである:
・現在のピクチャーの左上のルーマ・サンプルに対する現在のルーマコーディングブロックの左上のサンプルのルーマ位置(xCb,yCb)
・ルーマ・サンプル単位での現在のコーディングブロックの幅を指定する変数cbWidth、
・ルーマ・サンプル単位での現在のコーディングブロックの高さを指定する変数cbHeight。
・近傍のコーディング単位の利用可能性フラグavailableFlagA0、availableFlagA1、availableFlagB0、availableFlagB1、availableFlagB2
・近傍のコーディング単位の参照インデックスrefIdxLXA0、refIdxLXA1、refIdxLXB0、refIdxLXB1、refIdxLXB2
・近傍のコーディング単位の予測リスト利用フラグpredFlagLXA0、predFlagLXA1、predFlagLXB0、predFlagLXB1、predFlagLXB2
・近傍のコーディング単位の1/16端数サンプル精度での動きベクトルmvLXA0、mvLXA1、mvLXB0、mvLXB1、mvLXB2
・双予測重みインデックスgbiIdxA0、gbiIdxA1、gbiIdxB0、gbiIdxB1、gbiIdxB2。
・近傍のルーマコーディングブロック内のルーマ位置(xNbA1,yNbA1)は(xCb-1,yCb+cbHeight-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbA1,yNbA1)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableA1に割り当てられる。
・変数availableFlagA1、refIdxLXA1、predFlagLXA1、mvLXA1は、以下のように導出される:
……
・近傍のルーマコーディングブロック内のルーマ位置(xNbB1,yNbB1)は(xCb+cbWidth-1,yCb-1)に等しく設定される。
……
・近傍のルーマコーディングブロック内のルーマ位置(xNbB0,yNbB0)は(xCb+cbWidth,yCb-1)に等しく設定される。
……
・近傍のルーマコーディングブロック内のルーマ位置(xNbA0,yNbA0)は(xCb-1,yCb+cbWidth)に等しく設定される。
……
・近傍のルーマコーディングブロック内のルーマ位置(xNbB2,yNbB2)は(xCb-1,yCb-1)に等しく設定される。
・節6.4.X項において指定されているブロックの利用可能性導出プロセス[編注(BB):近傍ブロック利用可能性検査プロセスtbd]が、(xCb,yCb)に等しく設定された現在のルーマ位置(xCurr,yCurr)および近傍ルーマ位置(xNbB2,yNbB2)を入力として呼び出される。出力は、ブロック利用可能性フラグavailableB2に割り当てられる。
・変数availableFlagB2、refIdxLXB2、predFlagLXB2、mvLXB2は、以下のように導出される:
・以下の条件のうち一つまたは複数が真である場合、availableFlagB2が0に等しく設定され、X=0または1として、mvLXB2の両方の成分が0に等しく設定され、refIdxLXB2が-1に等しく設定され、predFlagLXB2が0に等しく設定され、gbiIdxB2が0に設定される:
・availableB2が偽に等しい。
・availableA1が真に等しく、ルーマ位置(xNbA1,yNbA1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB1が真に等しく、ルーマ位置(xNbB1,yNbB1)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ。
・availableB0が真に等しく、ルーマ位置(xNbB0,yNbB0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・availableA0が真に等しく、ルーマ位置(xNbA0,yNbA0)と(xNbB2,yNbB2)は同じ動きベクトルと同じ参照インデックスをもつ、そしてmerge_triangle_flag[xCb][yCb]は1に等しい。
・[[availableFlagA 0 +availableFlagA 1 +availableFlagB 0 +availableFlagB 1 が4に等しい、そしてmerge_triangle_flag[xCb][yCb]が0に等しい]]。
・それ以外の場合、availableFlagB2は1に設定され、以下の割り当てが行われる:
mvLXB2=MvLX[xNbB2][yNbB2] (8-310)
refIdxLXB2=RefIdxLX[xNbB2][yNbB2] (8-311)
predFlagLXB2=PredFlagLX[xNbB2][yNbB2] (8-312)
gbiIdxB2=GbiIdx[xNbB2][yNbB2] (8-313)
この実施形態は、ATMVPプロセスにおける初期化されたMVの決定を簡略化する。
このプロセスへの入力は以下の通り:
・現在のコーディングブロックを含むルーマコーディングツリー・ブロックの左上のサンプルの位置(xCtb,yCtb)
・右下の中心サンプルをカバーする共位置のルーマコーディングブロックの左上のサンプルの位置(xColCtrCb,yColCtrCb)、
・近傍のコーディング単位の利用可能性フラグavailableFlagA1、
・近傍のコーディング単位の参照インデックスrefIdxLXA1、
・近傍のコーディング単位の予測リスト利用フラグpredFlagLXA1、
・近傍のコーディング単位の1/16端数サンプル精度での動きベクトルmvLXA1。
・動きベクトルctrMvL0とctrMvL1、
・予測リスト利用フラグctrPredFlagL0およびctrPredFlagL1、
・時間的動きベクトルtempMv。
tempMv[0]=0 (8-529)
tempMv[1]=0 (8-530)
変数Xをcollocated_from_l0_flagに設定する。
predFlagLXA1が1に等しく、DiffPicOrderCnt(ColPic,RefPicList[X][refIdxLXA1])が0に等しいことが真である場合、tempMvはmvLXA1に等しく設定される。〕
・[[以下の条件がすべて真である場合、tempMvはmvL1A 1 に等しく設定される:
・predFlagL1A 1 が1に等しい、
・DiffPicOrderCnt(ColPic,RefPicList[1][refIdxL1A 1 ])が0に等しい、
・DiffPicOrderCnt(aPic,currPic)が、現在のスライスのすべての参照ピクチャー・リスト内のすべてのピクチャーaPicについて0以下である、
・slice_typeがBに等しい、
・collocated_from_l0_flagが0に等しい。]]
・[[それ以外の場合、以下の条件がすべて真である場合、tempMvはmvL0A 1 に等しく設定される:
・predFlagL0A 1 が1に等しい、
・DiffPicOrderCnt(ColPic,RefPicList[0][refIdxL0A1])は0に等しい。]]
xColCb=Clip3(xCtb,
Min(CurPicWidthInSamplesY-1,xCtb+(1<<CtbLog2SizeY)+3),
xColCtrCb+(tempMv[0]>>4)) (8-531)
yColCb=Clip3(yCtb,
Min(CurPicHeightInSamplesY-1,yCtb+(1<<CtbLog2SizeY)-1),
yColCtrCb+(tempMv[1]>>4)) (8-532)
……
サブブロックおよび非サブブロック・ベースの方法のための共位置のMVの導出プロセスの整列のための例。
このプロセスへの入力は以下の通りである:
・現在のコーディングブロックを指定する変数currCb、
・ColPicによって指定された共位置のピクチャー内の共位置のコーディングブロックを指定する変数colCb、
・ColPicによって指定された共位置のピクチャーの左上のルーマ・サンプルに対して、colCbによって指定された共位置のルーマコーディングブロックの左上のサンプルを指定するルーマ位置(xColCb,yColCb)、
・参照インデックスrefIdxLX、Xは0または1、
・サブブロックの時間的マージ候補sbFlagを示すフラグ。
・1/16端数サンプル精度での動きベクトル予測mvLXCol、
・利用可能性フラグavailableFlagLXCol。
・colCbがイントラまたはIBC予測モードでコーディングされる場合、mvLXColの両方の成分が0に等しく設定され、availableFlagLXColが0に等しく設定される。
・それ以外の場合、動きベクトルmvCol、参照インデックスrefIdxCol、参照リスト識別子listColは以下のように導出される:
・[[sbFlagが0に等しい場合、]]availableFlagLXColは1に等しく設定され、以下が適用される:
・predFlagL0Col[xColCb][yColCb]が0に等しい場合、mvCol、refIdxCol、listColはそれぞれmvL1Col[xColCb][yColCb]、refIdxL1Col[xColCb][yColCb]、L1に等しく設定される。
・それ以外の場合、predFlagL0Col[xColCb][yColCb]が1に等しく、predFlagL1Col[xColCb][yColCb]が0に等しい場合、mvCol、refIdxCol、listColは、それぞれ、mvL0Col[xColCb][yColCb]、refIdxL0Col[xColCb][yColCb]、L0に等しく設定される。
・それ以外の場合(predFlagL0Col[xColCb][yColCb]が1に等しく、predFlagL1Col[xColCb][yColCb]が1に等しい場合)、以下の割り当てが行われる:
・NoBackwardPredFlagが1に等しい場合、mvCol、refIdxCol、listColはそれぞれmvLXCol[xColCb][yColCb]、refIdxLXCol[xColCb][yColCb]、LXに等しく設定される。
・それ以外の場合、mvCol、refIdxCol、listColはそれぞれmvLNCol[xColCb][yColCb]、refIdxLNCol[xColCb][yColCb]、LNに等しく設定され、Nはcollocated_from_l0_flagの値である。
・[[それ以外の場合(sbFlagが1に等しい)、以下が適用される:
・PredFlagLXCol[xColCb][yColCb]が1に等しい場合、mvCol、refIdxCol、listColはそれぞれmvLXCol[xColCb][yColCb]、refIdxLXCol[xColCb][yColCb]、LXに等しく設定され、availableFlagLXColは1に等しく設定される。
・それ以外の場合(PredFlagLXCol[xColCb][yColCb]が0に等しい場合)、以下が適用される:
・DiffPicOrderCnt(aPic,currPic)が現在のスライスのすべての参照ピクチャー・リストのすべてのピクチャーaPicについて0以下であり、PredFlagLYCol[xColCb][YColCb]が1に等しく、mvCol、refIdxCol、listColはそれぞれmvLYCol[xColCb][yColCb]、refIdxLYCol[xColCb][yColCb]、LYに設定され、Yは!Xに等しく、Xはそのためにこのプロセスが呼び出されるXの値である。availableFlagLXColが1に設定される。
・mvLXColの両方の成分が0に設定され、availableFlagLXColは0に等しく設定される。]]
・availableFlagLXColがTRUEに等しい場合、mvLXColおよびavailableFlagLXColは次のように導出される:
・LongTermRefPic(currPic,currCb,refIdxLX,LX)がLongTermRefPic(ColPic,colCb,refIdxCol,listCol)に等しい場合、mvLXColの両方の成分は0に等しく設定され、availableFlagLXColは0に等しく設定される。
・それ以外の場合、変数availableFlagLXColは1に等しく設定され、refPicList[listCol][refIdxCol]は、ColPicによって指定される共位置のピクチャーにおけるコーディングブロックcolCbを含むスライスの参照ピクチャー・リストlistColにおける参照インデックスrefIdxColをもつピクチャーに設定され、以下が適用される:
……
視覚メディアデータの現在のビデオ・ブロックと、現在のビデオ・ブロックのビットストリーム表現との間の変換を実行するステップを含み、前記ビットストリーム表現は、コーディングツールのためのマージ候補の最大数を示す構文要素が前記ビットストリーム表現に選択的に含まれるか、除外されるかを指定し、それにより前記コーディングツールが前記変換のために有効にされるか、無効にされるかを示すことを指定するフォーマット規則に従って構成され、
前記コーディングツールのためのマージ候補の最大数は、ゼロまたは正数である、
方法。
複数のビデオ・ブロックを含む一つまたは複数のビデオ領域を含むビデオと、前記ビデオのビットストリーム表現との間で変換を実行するステップを含み、
前記ビットストリーム表現は、ビデオ領域についての許容される幾何分割モード(geometric partitioning mode、GMP)動き候補の数が前記ビデオ領域へのコーディングツールの適用可能性に関する構文要素が前記ビットストリーム表現に含まれるかどうかを決定することを指定するフォーマット規則に適合し、前記コーディングツールは、GPMコーディングツールとは異なり、前記GPMは、別個に動き予測を適用するために、ビデオ・ブロックを複数の予測パーティションに分割することを含み、少なくとも1つのパーティションは非矩形形状を有する、
方法。
視覚メディアデータの現在のビデオ単位と、前記視覚メディアデータのビットストリーム表現との間で変換を実行するステップを含み、前記ビットストリーム表現は、最大変換ブロック・サイズが、前記変換のために使用される最大コーディングツリー単位(CTU)サイズと等しいかまたはそれ未満であることを指定するフォーマット規則に従って構成される、
方法。
視覚メディアデータの現在のビデオ・ブロックと、現在のビデオ・ブロックのビットストリーム表現との間の変換を実行するステップであって、前記変換は、適応ループフィルタ(ALF)を使用し、該ALFフィルタの係数は、現在のビデオ・ブロックのビデオ領域内のサンプルの深さに基づく、
方法。
視覚メディアデータの現在のビデオ・ブロックと現在のビデオ・ブロックのビットストリーム表現との間の変換を適応ループフィルタ(ALF)を用いて実行することを含み、前記ビットストリーム表現は、前記ビットストリーム表現に含まれる一つまたは複数の構文要素が、現在のビデオ・ブロックに適用されるALFフィルタが適応パラメータセット(APS)に基づいて決定されるか、または固定した諸フィルタ集合に基づいて決定されるかを示すことを指定するフォーマット規則に従って構成される、
方法。
Claims (8)
- 視覚メディア処理の方法であって:
視覚メディアデータの現在のビデオ単位と、前記視覚メディアデータのビットストリーム表現との間で変換を実行するステップを含み、前記ビットストリーム表現は、最大変換ブロック・サイズが、前記変換のために使用される最大符号化ツリー単位(CTU)サイズと等しいかまたはそれ未満であることを指定するフォーマット規則に従って構成される、
方法。 - 前記フォーマット規則が、前記最大CTUサイズに基づいて、前記最大変換ブロック・サイズを示す構文要素を前記ビットストリーム表現に選択的に含めることを指定する、請求項1に記載の方法。
- 前記フォーマット規則が、前記最大CTUサイズが、定義されたM×Nブロック・サイズより小さいまたはそれに等しいという判定に基づいて、前記ビットストリーム表現において前記最大変換ブロック・サイズを示す構文要素を除外することを指定する、請求項2に記載の方法。
- M=32およびN=32である、請求項3に記載の方法。
- 前記変換は、現在のビデオ・ブロックから前記ビットストリーム表現を生成することを含む、請求項1ないし4のうちいずれか一つまたは複数に記載の方法。
- 前記変換は、前記ビットストリーム表現から現在のビデオ・ブロックのサンプルを生成することを含む、請求項1ないし4のうちいずれか一つまたは複数に記載の方法。
- 請求項1ないし4のうちいずれか一つまたは複数に記載の方法を実装するように構成されたプロセッサを有するビデオ処理装置。
- コードが記憶されているコンピュータ読み取り可能媒体であって、前記コードは、実行時に、プロセッサに、請求項1ないし4のうちいずれか一つまたは複数に記載の方法を実装させる、媒体。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2023117437A JP7568352B2 (ja) | 2019-07-14 | 2023-07-19 | ビデオコーディングにおける変換ブロック・サイズ制約 |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CNPCT/CN2019/095921 | 2019-07-14 | ||
CN2019095921 | 2019-07-14 | ||
PCT/CN2020/101819 WO2021008513A1 (en) | 2019-07-14 | 2020-07-14 | Transform block size restriction in video coding |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2023117437A Division JP7568352B2 (ja) | 2019-07-14 | 2023-07-19 | ビデオコーディングにおける変換ブロック・サイズ制約 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2022541012A true JP2022541012A (ja) | 2022-09-21 |
JP7318099B2 JP7318099B2 (ja) | 2023-07-31 |
Family
ID=74210199
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2022502208A Active JP7318099B2 (ja) | 2019-07-14 | 2020-07-14 | ビデオコーディングにおける変換ブロック・サイズ制約 |
JP2023117437A Active JP7568352B2 (ja) | 2019-07-14 | 2023-07-19 | ビデオコーディングにおける変換ブロック・サイズ制約 |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2023117437A Active JP7568352B2 (ja) | 2019-07-14 | 2023-07-19 | ビデオコーディングにおける変換ブロック・サイズ制約 |
Country Status (6)
Country | Link |
---|---|
US (3) | US11647186B2 (ja) |
EP (1) | EP3984215A4 (ja) |
JP (2) | JP7318099B2 (ja) |
KR (1) | KR20220030995A (ja) |
CN (4) | CN114128295B (ja) |
WO (3) | WO2021008511A1 (ja) |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112840654B (zh) * | 2018-10-12 | 2024-04-16 | 韦勒斯标准与技术协会公司 | 使用多假设预测的视频信号处理方法和装置 |
JP7446339B2 (ja) | 2019-06-04 | 2024-03-08 | 北京字節跳動網絡技術有限公司 | 幾何学的分割モードコーディングを用いた動き候補リスト |
EP3963890A4 (en) | 2019-06-04 | 2022-11-02 | Beijing Bytedance Network Technology Co., Ltd. | BUILDING A LIST OF MOVEMENT CANDIDATES USING NEIGHBOR BLOCK INFORMATION |
KR20220030995A (ko) | 2019-07-14 | 2022-03-11 | 베이징 바이트댄스 네트워크 테크놀로지 컴퍼니, 리미티드 | 비디오 코딩에서 변환 블록 크기 제한 |
JP2022543207A (ja) | 2019-07-25 | 2022-10-11 | ウィルス インスティテュート オブ スタンダーズ アンド テクノロジー インコーポレイティド | ビデオ信号処理方法及び装置 |
CN117596389A (zh) | 2019-09-28 | 2024-02-23 | 北京字节跳动网络技术有限公司 | 视频编解码中的几何分割模式 |
US20230101542A1 (en) * | 2021-09-29 | 2023-03-30 | Tencent America LLC | Techniques for constraint flag signaling for range extension with coding for last significant coefficient |
EP4412216A1 (en) * | 2021-10-01 | 2024-08-07 | LG Electronics Inc. | Gpm-based image coding method and device |
WO2023200237A1 (ko) * | 2022-04-12 | 2023-10-19 | 엘지전자 주식회사 | 기하 분할된 블록에 대한 영상 부호화/복호화 방법, 비트스트림을 전송하는 방법 및 비트스트림을 저장한 기록 매체 |
WO2024227180A1 (en) * | 2023-04-27 | 2024-10-31 | Beijing Dajia Internet Information Technology Co., Ltd | Methods and devices for intra block copy and intra template matching |
Family Cites Families (162)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050111545A1 (en) | 2003-11-25 | 2005-05-26 | Ram Prabhakar | Dynamic packet size control for MPEG-4 data partition mode |
JP2009545919A (ja) * | 2006-08-02 | 2009-12-24 | トムソン ライセンシング | ビデオ復号処理のためにアダブティブなジオメトリック分割を行う方法および装置 |
CN101415121B (zh) | 2007-10-15 | 2010-09-29 | 华为技术有限公司 | 一种自适应的帧预测的方法及装置 |
EP2173100A3 (en) * | 2008-10-06 | 2010-08-11 | LG Electronics Inc. | A method and an apparatus for decoding a video signal |
TWI428023B (zh) * | 2008-11-18 | 2014-02-21 | Ind Tech Res Inst | 解碼方法及裝置 |
KR101098739B1 (ko) * | 2008-11-24 | 2011-12-23 | 한국전자통신연구원 | 비디오 신호의 부호화/복호화 장치 및 방법 |
US9036692B2 (en) | 2010-01-18 | 2015-05-19 | Mediatek Inc. | Motion prediction method |
US8879632B2 (en) | 2010-02-18 | 2014-11-04 | Qualcomm Incorporated | Fixed point implementation for geometric motion partitioning |
CN108462874B (zh) | 2010-04-09 | 2022-06-07 | 三菱电机株式会社 | 运动图像编码装置以及运动图像解码装置 |
US9819966B2 (en) * | 2010-09-01 | 2017-11-14 | Qualcomm Incorporated | Filter description signaling for multi-filter adaptive filtering |
US9071851B2 (en) | 2011-01-10 | 2015-06-30 | Qualcomm Incorporated | Adaptively performing smoothing operations |
CN102611880B (zh) * | 2011-01-19 | 2015-02-04 | 华为技术有限公司 | 标识图像块几何划分模式的编解码方法和设备 |
US9001883B2 (en) * | 2011-02-16 | 2015-04-07 | Mediatek Inc | Method and apparatus for slice common information sharing |
US9826238B2 (en) * | 2011-06-30 | 2017-11-21 | Qualcomm Incorporated | Signaling syntax elements for transform coefficients for sub-sets of a leaf-level coding unit |
JP5884697B2 (ja) | 2011-09-28 | 2016-03-15 | 株式会社Jvcケンウッド | 動画像符号化装置、動画像符号化方法、動画像符号化プログラム、送信装置、送信方法及び送信プログラム |
US20130107973A1 (en) | 2011-10-28 | 2013-05-02 | Qualcomm Incorporated | Loop filtering control over tile boundaries |
US20130114717A1 (en) | 2011-11-07 | 2013-05-09 | Qualcomm Incorporated | Generating additional merge candidates |
US9538200B2 (en) * | 2012-01-19 | 2017-01-03 | Qualcomm Incorporated | Signaling of deblocking filter parameters in video coding |
US9451277B2 (en) | 2012-02-08 | 2016-09-20 | Qualcomm Incorporated | Restriction of prediction units in B slices to uni-directional inter prediction |
US9549180B2 (en) | 2012-04-20 | 2017-01-17 | Qualcomm Incorporated | Disparity vector generation for inter-view prediction for video coding |
US20130294513A1 (en) | 2012-05-07 | 2013-11-07 | Qualcomm Incorporated | Inter layer merge list construction for video coding |
US20130329007A1 (en) | 2012-06-06 | 2013-12-12 | Qualcomm Incorporated | Redundancy removal for advanced motion vector prediction (amvp) in three-dimensional (3d) video coding |
US20130336406A1 (en) | 2012-06-14 | 2013-12-19 | Qualcomm Incorporated | Redundancy removal for merge/skip mode motion information candidate list construction |
US9749645B2 (en) | 2012-06-22 | 2017-08-29 | Microsoft Technology Licensing, Llc | Coded-block-flag coding and derivation |
US9088770B2 (en) | 2012-08-15 | 2015-07-21 | Intel Corporation | Size based transform unit context derivation |
US20140071235A1 (en) | 2012-09-13 | 2014-03-13 | Qualcomm Incorporated | Inter-view motion prediction for 3d video |
US9491461B2 (en) | 2012-09-27 | 2016-11-08 | Qualcomm Incorporated | Scalable extensions to HEVC and temporal motion vector prediction |
US9699450B2 (en) | 2012-10-04 | 2017-07-04 | Qualcomm Incorporated | Inter-view predicted motion vector for 3D video |
EP2904800A4 (en) | 2012-10-05 | 2016-05-04 | Mediatek Singapore Pte Ltd | METHOD AND DEVICE FOR MOTION VECTOR REMOVAL FOR 3D VIDEO CODING |
US10136143B2 (en) | 2012-12-07 | 2018-11-20 | Qualcomm Incorporated | Advanced residual prediction in scalable and multi-view video coding |
US9357214B2 (en) | 2012-12-07 | 2016-05-31 | Qualcomm Incorporated | Advanced merge/skip mode and advanced motion vector prediction (AMVP) mode for 3D video |
US9538180B2 (en) | 2012-12-17 | 2017-01-03 | Qualcomm Incorporated | Motion vector prediction in video coding |
JP6149151B2 (ja) | 2013-04-02 | 2017-06-14 | ヴィド スケール インコーポレイテッド | スケーラブルビデオコーディングのための拡張時間的動きベクトル予測 |
US9609347B2 (en) | 2013-04-04 | 2017-03-28 | Qualcomm Incorporated | Advanced merge mode for three-dimensional (3D) video coding |
WO2014170547A1 (en) * | 2013-04-17 | 2014-10-23 | Nokia Corporation | An apparatus, a method and a computer program for video coding and decoding |
US9225991B2 (en) * | 2013-05-30 | 2015-12-29 | Apple Inc. | Adaptive color space transform coding |
US9288507B2 (en) | 2013-06-21 | 2016-03-15 | Qualcomm Incorporated | More accurate advanced residual prediction (ARP) for texture coding |
US9800895B2 (en) | 2013-06-27 | 2017-10-24 | Qualcomm Incorporated | Depth oriented inter-view motion vector prediction |
WO2015003383A1 (en) | 2013-07-12 | 2015-01-15 | Mediatek Singapore Pte. Ltd. | Methods for inter-view motion prediction |
WO2015007159A1 (en) | 2013-07-15 | 2015-01-22 | Mediatek Singapore Pte. Ltd. | Method of disparity derived depth coding in 3d video coding |
JP2016528810A (ja) | 2013-07-24 | 2016-09-15 | マイクロソフト テクノロジー ライセンシング,エルエルシー | 非変換符号化のためのスキャン順序 |
US20150078457A1 (en) * | 2013-09-13 | 2015-03-19 | Qualcomm Incorporated | Representation format signaling in multi-layer video coding |
US9762927B2 (en) * | 2013-09-26 | 2017-09-12 | Qualcomm Incorporated | Sub-prediction unit (PU) based temporal motion vector prediction in HEVC and sub-PU design in 3D-HEVC |
WO2015053697A1 (en) * | 2013-10-11 | 2015-04-16 | Telefonaktiebolaget L M Ericsson (Publ) | Method and arrangement for transcoding a video bitstream |
WO2015070739A1 (en) | 2013-11-15 | 2015-05-21 | Mediatek Inc. | Method of block-based adaptive loop filtering |
US9432685B2 (en) | 2013-12-06 | 2016-08-30 | Qualcomm Incorporated | Scalable implementation for parallel motion estimation regions |
KR101847899B1 (ko) * | 2014-02-12 | 2018-04-12 | 주식회사 칩스앤미디어 | 동영상 처리 방법 및 장치 |
WO2015131387A1 (en) | 2014-03-07 | 2015-09-11 | Qualcomm Incorporated | Simplified sub-prediction unit (sub-pu) motion parameter inheritence (mpi) |
WO2015135169A1 (en) | 2014-03-13 | 2015-09-17 | Qualcomm Incorporated | Constrained depth intra mode coding for 3d video coding |
CN103942793B (zh) | 2014-04-16 | 2016-11-16 | 上海交通大学 | 基于热扩散的视频一致运动区域检测方法 |
KR102298599B1 (ko) * | 2014-04-29 | 2021-09-03 | 마이크로소프트 테크놀로지 라이센싱, 엘엘씨 | 샘플 적응 오프셋 필터링에 대한 인코더측 결정 |
US10567789B2 (en) | 2014-06-16 | 2020-02-18 | Qualcomm Incorporated | Simplified shifting merge candidate and merge list derivation in 3D-HEVC |
US10327001B2 (en) * | 2014-06-19 | 2019-06-18 | Qualcomm Incorporated | Systems and methods for intra-block copy |
EP3158754B1 (en) | 2014-06-19 | 2021-10-20 | VID SCALE, Inc. | Methods and systems for intra block copy search enhancement |
US10027981B2 (en) * | 2014-09-01 | 2018-07-17 | Hfi Innovation Inc. | Method of intra picture block copy for screen content and video coding |
US10469847B2 (en) | 2014-09-12 | 2019-11-05 | Vid Scale, Inc. | Inter-component de-correlation for video coding |
JP2017532885A (ja) | 2014-09-26 | 2017-11-02 | ヴィド スケール インコーポレイテッド | 時間ブロックベクトル予測を用いたイントラブロックコピー符号化 |
GB2531003A (en) | 2014-10-06 | 2016-04-13 | Canon Kk | Method and apparatus for vector encoding in video coding and decoding |
US9918105B2 (en) * | 2014-10-07 | 2018-03-13 | Qualcomm Incorporated | Intra BC and inter unification |
US9854237B2 (en) | 2014-10-14 | 2017-12-26 | Qualcomm Incorporated | AMVP and merge candidate list derivation for intra BC and inter prediction unification |
US11477477B2 (en) | 2015-01-26 | 2022-10-18 | Qualcomm Incorporated | Sub-prediction unit based advanced temporal motion vector prediction |
US10484686B2 (en) | 2015-01-29 | 2019-11-19 | Vid Scale, Inc. | Palette coding modes and palette flipping |
US10057574B2 (en) * | 2015-02-11 | 2018-08-21 | Qualcomm Incorporated | Coding tree unit (CTU) level adaptive loop filter (ALF) |
SG11201706978TA (en) * | 2015-03-02 | 2017-09-28 | Hfi Innovation Inc | Method and apparatus for intrabc mode with fractional-pel block vector resolution in video coding |
US10356416B2 (en) | 2015-06-09 | 2019-07-16 | Qualcomm Incorporated | Systems and methods of determining illumination compensation status for video coding |
CN105141957B (zh) * | 2015-07-31 | 2019-03-15 | 广东中星电子有限公司 | 图像和视频数据编解码的方法和设备 |
MX2018002477A (es) | 2015-09-02 | 2018-06-15 | Mediatek Inc | Metodo y aparato de derivacion de movimiento de lado de decodificador para codificacion de video. |
US10218975B2 (en) | 2015-09-29 | 2019-02-26 | Qualcomm Incorporated | Transform precision manipulation in video coding |
US10462439B2 (en) | 2015-10-02 | 2019-10-29 | Vid Scale, Inc. | Color correction with a lookup table |
US10812822B2 (en) | 2015-10-02 | 2020-10-20 | Qualcomm Incorporated | Intra block copy merge mode and padding of unavailable IBC reference region |
US20170150156A1 (en) | 2015-11-25 | 2017-05-25 | Qualcomm Incorporated | Illumination compensation with non-square predictive blocks in video coding |
US11405611B2 (en) | 2016-02-15 | 2022-08-02 | Qualcomm Incorporated | Predicting filter coefficients from fixed filters for video coding |
MX2018011198A (es) * | 2016-03-16 | 2019-05-20 | Mediatek Inc | Metodo y aparato de procesamiento de datos de video con tamaño restringido de bloque en codificacion de video. |
JP2019519972A (ja) | 2016-05-05 | 2019-07-11 | ヴィド スケール インコーポレイテッド | イントラコーディングのための制御点ベースのイントラ方向表現 |
US10560718B2 (en) | 2016-05-13 | 2020-02-11 | Qualcomm Incorporated | Merge candidates for motion vector prediction for video coding |
US10419755B2 (en) * | 2016-05-16 | 2019-09-17 | Qualcomm Incorporated | Confusion of multiple filters in adaptive loop filtering in video coding |
US11095922B2 (en) | 2016-08-02 | 2021-08-17 | Qualcomm Incorporated | Geometry transformation-based adaptive loop filtering |
US10326986B2 (en) | 2016-08-15 | 2019-06-18 | Qualcomm Incorporated | Intra video coding using a decoupled tree structure |
US10271069B2 (en) * | 2016-08-31 | 2019-04-23 | Microsoft Technology Licensing, Llc | Selective use of start code emulation prevention |
US10721489B2 (en) | 2016-09-06 | 2020-07-21 | Qualcomm Incorporated | Geometry-based priority for the construction of candidate lists |
US10448010B2 (en) | 2016-10-05 | 2019-10-15 | Qualcomm Incorporated | Motion vector prediction for affine motion models in video coding |
WO2018099269A1 (en) | 2016-11-29 | 2018-06-07 | Mediatek Inc. | Method and apparatus of merge mode derivation for video coding |
US20180184127A1 (en) | 2016-12-22 | 2018-06-28 | Qualcomm Incorporated | Determining neighboring samples for bilateral filtering in video coding |
US10506230B2 (en) | 2017-01-04 | 2019-12-10 | Qualcomm Incorporated | Modified adaptive loop filter temporal prediction for temporal scalability support |
US11025903B2 (en) | 2017-01-13 | 2021-06-01 | Qualcomm Incorporated | Coding video data using derived chroma mode |
CN106961606B (zh) * | 2017-01-26 | 2020-04-07 | 浙江工业大学 | 基于纹理划分特征的hevc帧内编码模式选择方法 |
US20180242024A1 (en) * | 2017-02-21 | 2018-08-23 | Mediatek Inc. | Methods and Apparatuses of Candidate Set Determination for Quad-tree Plus Binary-tree Splitting Blocks |
KR102559063B1 (ko) * | 2017-02-24 | 2023-07-24 | 주식회사 케이티 | 비디오 신호 처리 방법 및 장치 |
CN110393011B (zh) * | 2017-03-10 | 2022-02-18 | 联发科技股份有限公司 | 用于视频编解码中具有帧内方向预测模式的内含帧内编解码工具设定的方法和装置 |
US10778974B2 (en) | 2017-07-05 | 2020-09-15 | Qualcomm Incorporated | Adaptive loop filter with enhanced classification methods |
US11172203B2 (en) | 2017-08-08 | 2021-11-09 | Mediatek Inc. | Intra merge prediction |
CN116761001A (zh) | 2017-08-29 | 2023-09-15 | Sk电信有限公司 | 视频编码装置、视频解码装置和存储比特流的方法 |
CN111567045A (zh) | 2017-10-10 | 2020-08-21 | 韩国电子通信研究院 | 使用帧间预测信息的方法和装置 |
US10785494B2 (en) | 2017-10-11 | 2020-09-22 | Qualcomm Incorporated | Low-complexity design for FRUC |
WO2019078581A1 (ko) | 2017-10-16 | 2019-04-25 | 디지털인사이트주식회사 | 영상 부호화/복호화 방법, 장치 및 비트스트림을 저장한 기록 매체 |
US20190116374A1 (en) | 2017-10-17 | 2019-04-18 | Qualcomm Incorporated | Coding motion information of video data using coding structure-based candidate list construction |
WO2019079611A1 (en) | 2017-10-18 | 2019-04-25 | Huawei Technologies Co., Ltd. | GENERATION OF MOVEMENT VECTOR CANDIDATES LIST DEPENDING ON THE AVAILABILITY OF A NEIGHBORING BLOCK |
JP2021016016A (ja) | 2017-10-20 | 2021-02-12 | シャープ株式会社 | 動画像符号化装置及び動画像復号装置 |
JP7390300B2 (ja) | 2017-11-01 | 2023-12-01 | ヴィド スケール インコーポレイテッド | ビデオコーディングにおける適応ループフィルタを簡略化する方法 |
US11503333B2 (en) | 2017-11-14 | 2022-11-15 | Qualcomm Incorporated | Unified merge candidate list usage |
US10721469B2 (en) | 2017-11-28 | 2020-07-21 | Qualcomm Incorporated | Line buffer reduction for adaptive loop filtering in video coding |
US20190208225A1 (en) * | 2018-01-02 | 2019-07-04 | Qualcomm Incorporated | Sign prediction in video coding |
US11388398B2 (en) | 2018-01-11 | 2022-07-12 | Qualcomm Incorporated | Video coding using local illumination compensation |
US20190238845A1 (en) | 2018-01-26 | 2019-08-01 | Qualcomm Incorporated | Adaptive loop filtering on deblocking filter results in video coding |
WO2019164031A1 (ko) | 2018-02-22 | 2019-08-29 | 엘지전자 주식회사 | 영상 코딩 시스템에서 블록 분할 구조에 따른 영상 디코딩 방법 및 장치 |
WO2019191890A1 (zh) | 2018-04-02 | 2019-10-10 | 深圳市大疆创新科技有限公司 | 用于图像处理的方法和图像处理装置 |
US20190306502A1 (en) | 2018-04-02 | 2019-10-03 | Qualcomm Incorporated | System and method for improved adaptive loop filtering |
US10397603B1 (en) | 2018-05-08 | 2019-08-27 | Tencent America LLC | Method and apparatus for video coding |
US10506251B2 (en) | 2018-05-08 | 2019-12-10 | Tencent America LLC | Method and apparatus for video coding |
CN110662036B (zh) | 2018-06-29 | 2022-09-02 | 北京字节跳动网络技术有限公司 | 运动信息共享的限制 |
SG11202011714RA (en) | 2018-06-29 | 2020-12-30 | Beijing Bytedance Network Technology Co Ltd | Partial/full pruning when adding a hmvp candidate to merge/amvp |
JP7137008B2 (ja) | 2018-06-29 | 2022-09-13 | 北京字節跳動網絡技術有限公司 | 1つまたは複数のルックアップテーブルを使用して、以前コーディングされた動き情報を順に記憶させてそれらを後続のブロックのコーディングに使用する概念 |
TWI725463B (zh) | 2018-07-01 | 2021-04-21 | 大陸商北京字節跳動網絡技術有限公司 | 空間運動壓縮 |
TWI731366B (zh) | 2018-07-02 | 2021-06-21 | 大陸商北京字節跳動網絡技術有限公司 | 查找表的使用 |
US10531090B1 (en) | 2018-07-02 | 2020-01-07 | Tencent America LLC | Method and apparatus for video coding |
US11051010B2 (en) | 2018-07-18 | 2021-06-29 | Mediatek Inc. | Merge candidates with multiple hypothesis |
US10523963B1 (en) | 2018-07-30 | 2019-12-31 | Tencent America LLC | Method and apparatus for merge mode in video coding |
US10362330B1 (en) | 2018-07-30 | 2019-07-23 | Tencent America LLC | Combining history-based motion vector prediction and non-adjacent merge prediction |
CN110858905B (zh) | 2018-08-26 | 2023-04-07 | 北京字节跳动网络技术有限公司 | 基于多运动模型的跳过和直接模式编解码的视频块中的修剪方法及装置 |
CN111064959B (zh) | 2018-09-12 | 2023-09-01 | 北京字节跳动网络技术有限公司 | 要检查多少个hmvp候选 |
US11445185B2 (en) * | 2018-09-19 | 2022-09-13 | Electronics And Telecommunications Research Institute | Image encoding/decoding method and device, and recording medium in which bitstream is stored |
WO2020058952A1 (en) | 2018-09-23 | 2020-03-26 | Beijing Bytedance Network Technology Co., Ltd. | 8-parameter affine mode |
TWI822863B (zh) | 2018-09-27 | 2023-11-21 | 美商Vid衡器股份有限公司 | 360度視訊寫碼樣本導出 |
WO2020084553A1 (en) | 2018-10-24 | 2020-04-30 | Beijing Bytedance Network Technology Co., Ltd. | Motion candidate derivation based on multiple information in sub-block motion vector prediction |
CN111147855B (zh) | 2018-11-02 | 2024-10-29 | 北京字节跳动网络技术有限公司 | 几何分割预测模式与其他工具之间的协调 |
CN112997489B (zh) | 2018-11-06 | 2024-02-06 | 北京字节跳动网络技术有限公司 | 具有几何分割的帧间预测的边信息信令 |
WO2020094079A1 (en) | 2018-11-06 | 2020-05-14 | Beijing Bytedance Network Technology Co., Ltd. | Block size dependent storage of motion information |
CN112997495B (zh) | 2018-11-10 | 2024-02-20 | 北京字节跳动网络技术有限公司 | 当前图片参考中的取整 |
CN112970253B (zh) | 2018-11-13 | 2024-05-07 | 北京字节跳动网络技术有限公司 | 用于预测的运动候选列表构建 |
CN112997493B (zh) | 2018-11-13 | 2024-01-05 | 北京字节跳动网络技术有限公司 | 用于单一类型运动候选列表的构建方法 |
CN113039796B (zh) | 2018-11-17 | 2023-09-19 | 北京字节跳动网络技术有限公司 | 视频处理中的广义双向预测模式 |
CN113170112B (zh) | 2018-11-22 | 2024-05-10 | 北京字节跳动网络技术有限公司 | 用于具有几何分割的帧间预测的构建方法 |
CN113170106A (zh) | 2018-11-28 | 2021-07-23 | 北京字节跳动网络技术有限公司 | 帧内块复制模式中运动参考的扩展方法 |
WO2020114404A1 (en) | 2018-12-03 | 2020-06-11 | Beijing Bytedance Network Technology Co., Ltd. | Pruning method in different prediction mode |
WO2020135465A1 (en) | 2018-12-28 | 2020-07-02 | Beijing Bytedance Network Technology Co., Ltd. | Modified history based motion prediction |
CN113905239A (zh) | 2018-12-29 | 2022-01-07 | 深圳市大疆创新科技有限公司 | 视频处理方法和设备 |
CN116866605A (zh) | 2019-01-03 | 2023-10-10 | 北京大学 | 视频处理方法和装置 |
CN113273186A (zh) | 2019-01-10 | 2021-08-17 | 北京字节跳动网络技术有限公司 | Lut更新的调用 |
CN113383554B (zh) | 2019-01-13 | 2022-12-16 | 北京字节跳动网络技术有限公司 | LUT和共享Merge列表之间的交互 |
CN113302919A (zh) | 2019-01-17 | 2021-08-24 | 北京字节跳动网络技术有限公司 | 在视频处理中使用虚拟候选预测和加权预测 |
US10904557B2 (en) | 2019-01-22 | 2021-01-26 | Tencent America LLC | Method and apparatus for video coding |
CN113647109B (zh) | 2019-02-17 | 2024-07-05 | 北京字节跳动网络技术有限公司 | 帧内块复制(ibc)模式和非ibc帧间模式的运动候选列表构建 |
SG11202109287PA (en) | 2019-02-27 | 2021-09-29 | Huawei Tech Co Ltd | Adaptation parameter set identifier value spaces in video coding |
AU2020229608B2 (en) | 2019-02-28 | 2023-09-14 | Lg Electronics, Inc. | APS signaling-based video or image coding |
JP2022524627A (ja) | 2019-03-11 | 2022-05-09 | 華為技術有限公司 | エンコーダ、デコーダ及び対応する方法 |
EP3926956A4 (en) | 2019-03-13 | 2022-11-09 | SZ DJI Technology Co., Ltd. | VIDEO PROCESSING METHOD AND DEVICE |
CN117499644A (zh) | 2019-03-14 | 2024-02-02 | 北京字节跳动网络技术有限公司 | 环路整形信息的信令和语法 |
CN115767107A (zh) | 2019-03-24 | 2023-03-07 | 北京字节跳动网络技术有限公司 | 视频处理中的非线性自适应环路滤波 |
WO2020200236A1 (en) | 2019-04-01 | 2020-10-08 | Beijing Bytedance Network Technology Co., Ltd. | Using interpolation filters for history based motion vector prediction |
CN113678464B (zh) | 2019-04-15 | 2022-12-02 | 北京字节跳动网络技术有限公司 | 非线性自适应环路滤波器中的参数的时域预测 |
EP3928516A4 (en) | 2019-04-16 | 2022-06-15 | Beijing Bytedance Network Technology Co., Ltd. | ADAPTIVE LOOP FILTERING FOR VIDEO PROCESSING |
US11284114B2 (en) | 2019-04-23 | 2022-03-22 | Qualcomm Incorporated | Adaptive loop filter set index signaling |
KR20210135337A (ko) | 2019-05-14 | 2021-11-12 | 엘지전자 주식회사 | 적응적 루프 필터 기반 비디오 또는 영상 코딩 |
US11019334B2 (en) * | 2019-05-17 | 2021-05-25 | Qualcomm Incorporated | Multiple adaptive loop filter sets for video coding |
JP7446339B2 (ja) | 2019-06-04 | 2024-03-08 | 北京字節跳動網絡技術有限公司 | 幾何学的分割モードコーディングを用いた動き候補リスト |
EP3963890A4 (en) | 2019-06-04 | 2022-11-02 | Beijing Bytedance Network Technology Co., Ltd. | BUILDING A LIST OF MOVEMENT CANDIDATES USING NEIGHBOR BLOCK INFORMATION |
US11166033B2 (en) * | 2019-06-06 | 2021-11-02 | Qualcomm Incorporated | Adaptation parameter set in access unit in video coding |
US11736688B2 (en) | 2019-06-21 | 2023-08-22 | Qualcomm Incorporated | Adaptive loop filter signalling |
KR20220030995A (ko) | 2019-07-14 | 2022-03-11 | 베이징 바이트댄스 네트워크 테크놀로지 컴퍼니, 리미티드 | 비디오 코딩에서 변환 블록 크기 제한 |
CN117596389A (zh) | 2019-09-28 | 2024-02-23 | 北京字节跳动网络技术有限公司 | 视频编解码中的几何分割模式 |
US11432016B2 (en) | 2019-12-05 | 2022-08-30 | Hfi Innovation Inc. | Methods and apparatuses of syntax signaling constraint for cross-component adaptive loop filter in video coding system |
US11563980B2 (en) * | 2020-04-02 | 2023-01-24 | Qualcomm Incorporated | General constraint information syntax in video coding |
-
2020
- 2020-07-14 KR KR1020227000455A patent/KR20220030995A/ko active IP Right Grant
- 2020-07-14 WO PCT/CN2020/101805 patent/WO2021008511A1/en active Application Filing
- 2020-07-14 CN CN202080051086.4A patent/CN114128295B/zh active Active
- 2020-07-14 CN CN202311469061.8A patent/CN117354547A/zh active Pending
- 2020-07-14 CN CN202080051103.4A patent/CN114175636B/zh active Active
- 2020-07-14 JP JP2022502208A patent/JP7318099B2/ja active Active
- 2020-07-14 CN CN202080051112.3A patent/CN114128258B/zh active Active
- 2020-07-14 WO PCT/CN2020/101819 patent/WO2021008513A1/en unknown
- 2020-07-14 WO PCT/CN2020/101820 patent/WO2021008514A1/en active Application Filing
- 2020-07-14 EP EP20840562.1A patent/EP3984215A4/en active Pending
-
2022
- 2022-01-11 US US17/572,833 patent/US11647186B2/en active Active
- 2022-01-11 US US17/572,785 patent/US11509893B2/en active Active
-
2023
- 2023-02-23 US US18/173,306 patent/US20230231997A1/en active Pending
- 2023-07-19 JP JP2023117437A patent/JP7568352B2/ja active Active
Non-Patent Citations (4)
Title |
---|
BENJAMIN BROSS, JIANLE CHEN, AND SHAN LIU: "Versatile Video Coding (Draft 5)", JOINT VIDEO EXPERTS TEAM (JVET) OF ITU-T SG 16 WP 3 AND ISO/IEC JTC 1/SC 29/WG 11, vol. JVET-N1001 (version 10), JPN6023008211, 2 July 2019 (2019-07-02), pages 51, ISSN: 0005008625 * |
MOHAMMED GOLAM SARWER, YAN YE, JIANCONG LUO, AND JIE CHEN: "AHG9:Transform and transform-skip related HLS clean-up", JOINT VIDEO EXPERTS TEAM (JVET) OF ITU-T SG 16 WP 3 AND ISO/IEC JTC 1/SC 29/WG 11, vol. JVET-R0097-v2, JPN6023008210, April 2020 (2020-04-01), pages 1 - 3, ISSN: 0005008627 * |
XIN ZHAO, XIANG LI, AND SHAN LIU: "Non-CE6: Configurable max transform size in VVC", JOINT VIDEO EXPERTS TEAM (JVET) OF ITU-T SG 16 WP 3 AND ISO/IEC JTC 1/SC 29/WG 11, vol. JVET-N0362-v2, JPN6023008214, March 2019 (2019-03-01), pages 1 - 8, ISSN: 0005008624 * |
ZHIPIN DENG, ET AL.: "Non-CE6: Cleanups of maximum transform size related syntax elements", JOINT VIDEO EXPERTS TEAM (JVET) OF ITU-T SG 16 WP 3 AND ISO/IEC JTC 1/SC 29/WG 11, vol. JVET-P0405, JPN6023008217, September 2019 (2019-09-01), pages 1 - 3, ISSN: 0005008626 * |
Also Published As
Publication number | Publication date |
---|---|
US11647186B2 (en) | 2023-05-09 |
US11509893B2 (en) | 2022-11-22 |
JP2023126565A (ja) | 2023-09-07 |
CN114128258A (zh) | 2022-03-01 |
US20220132119A1 (en) | 2022-04-28 |
EP3984215A4 (en) | 2022-08-24 |
WO2021008513A1 (en) | 2021-01-21 |
US20230231997A1 (en) | 2023-07-20 |
WO2021008511A1 (en) | 2021-01-21 |
CN114128258B (zh) | 2023-12-22 |
CN114175636B (zh) | 2024-01-12 |
CN114128295B (zh) | 2024-04-12 |
WO2021008514A1 (en) | 2021-01-21 |
JP7318099B2 (ja) | 2023-07-31 |
CN114128295A (zh) | 2022-03-01 |
EP3984215A1 (en) | 2022-04-20 |
CN114175636A (zh) | 2022-03-11 |
JP7568352B2 (ja) | 2024-10-16 |
KR20220030995A (ko) | 2022-03-11 |
US20220132118A1 (en) | 2022-04-28 |
CN117354547A (zh) | 2024-01-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP7318099B2 (ja) | ビデオコーディングにおける変換ブロック・サイズ制約 | |
JP7556090B2 (ja) | デコーダ側精緻化ツールのサイズ選択アプリケーション | |
JP7425808B2 (ja) | 動き候補リスト構築プロセスの条件付き実行 | |
US20220086441A1 (en) | Intra block copy with triangular partitions | |
CN114450959A (zh) | 视频编解码中的几何分割模式 | |
KR102627821B1 (ko) | 이웃 블록 정보를 사용한 모션 후보 리스트 구성 | |
JP2022535903A (ja) | 映像符号化のための動き候補リストの構成 | |
WO2020248925A1 (en) | History-based motion vector prediction with default parameters | |
WO2020164544A1 (en) | Updating of history based motion vector prediction tables | |
WO2021000883A1 (en) | Storage of motion information in history-based motion vector prediction table |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20220113 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20220113 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20220614 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20230224 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20230307 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20230602 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20230620 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20230719 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 7318099 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |