(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2024010175
(43)【公開日】2024-01-23
(54)【発明の名称】カラーフォーマットに基づいたサイズ制限
(51)【国際特許分類】
H04N 19/105 20140101AFI20240116BHJP
H04N 19/186 20140101ALI20240116BHJP
H04N 19/70 20140101ALI20240116BHJP
H04N 19/136 20140101ALI20240116BHJP
【FI】
H04N19/105
H04N19/186
H04N19/70
H04N19/136
【審査請求】有
【請求項の数】20
【出願形態】OL
【外国語出願】
(21)【出願番号】P 2023189742
(22)【出願日】2023-11-07
(62)【分割の表示】P 2022506732の分割
【原出願日】2020-08-06
(31)【優先権主張番号】PCT/CN2019/099447
(32)【優先日】2019-08-06
(33)【優先権主張国・地域又は機関】CN
(71)【出願人】
【識別番号】520476341
【氏名又は名称】北京字節跳動網絡技術有限公司
【氏名又は名称原語表記】Beijing Bytedance Network Technology Co., Ltd.
【住所又は居所原語表記】Room B-0035, 2/F, No.3 Building, No.30, Shixing Road, Shijingshan District Beijing 100041 China
(71)【出願人】
【識別番号】520477474
【氏名又は名称】バイトダンス インコーポレイテッド
【氏名又は名称原語表記】BYTEDANCE INC.
【住所又は居所原語表記】12655 West Jefferson Boulevard, Sixth Floor, Suite No. 137 Los Angeles, California 90066 United States of America
(74)【代理人】
【識別番号】100107766
【弁理士】
【氏名又は名称】伊東 忠重
(74)【代理人】
【識別番号】100070150
【弁理士】
【氏名又は名称】伊東 忠彦
(74)【代理人】
【識別番号】100135079
【弁理士】
【氏名又は名称】宮崎 修
(72)【発明者】
【氏名】シュイ,ジィジォン
(72)【発明者】
【氏名】デン,ジピン
(72)【発明者】
【氏名】ザン,リー
(72)【発明者】
【氏名】リュウ,ホンビン
(57)【要約】
【課題】ビデオ処理の方法を提供する。
【解決手段】方法は、1つ以上のルーマブロック及び1つ以上のクロマブロックを有する1つ以上のビデオ領域を有するビデオと、ビデオの符号化表現との間の変換を、ルールに従って実行するステップを含む。ルールは、サイズM×Nを有している1つ以上のクロマブロックの中のクロマブロックが、イントラモード又はイントラブロックコピーモードを用いてコーディングされた表現で表されることを許可されないことを定め、M及びNは、夫々、クロマブロックの幅及び高さを示す整数である。イントラモードは、前に符号化又は再構成されたビデオブロックに基づきクロマブロックを符号化することを含み、イントラブロックコピーモードは、ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いてクロマブロックを符号化することを含む。
【選択図】
図18
【特許請求の範囲】
【請求項1】
ビデオデータを処理する方法であって、
ビデオのコーディングツリーノードと前記ビデオのビットストリームとの間の変換のために、前記コーディングツリーノードのルーマペアレントブロック及び前記コーディングツリーノードのクロマペアレントブロックを分割し、前記ルーマペアレントブロックからの1つ以上のルーマブロック及び前記クロマペアレントブロックからの1つ以上のクロマブロックを予測するためのルールに従ったスキームを決定するステップと、
前記変換を前記スキームに基づき実行するステップと
を有し、
前記ルールは、4サンプルに等しい幅を有する前記1つ以上のルーマブロックのうちのルーマブロックに対して第1予測モードが適用可能であることを定め、
前記第1予測モードで、予測サンプルは、ブロックベクトルによって決定されたのと同じピクチャのサンプル値のブロックから導出される、
方法。
【請求項2】
前記第1予測モードは、イントラブロックコピー(IBC)モードである、
請求項1に記載の方法。
【請求項3】
前記ルールは、N以下である高さを有するルーマブロックに対して前記第1予測モードが適用可能であることを定め、Nは正の整数であり、Nは64であると予め決定される、
請求項1又は2に記載の方法。
【請求項4】
前記ルーマペアレントブロック及び前記クロマペアレントブロックを分割するために異なる分割スキームが使用されることに応答して、前記ルールは、前記1つ以上のクロマブロックに対して前記第1予測モードが利用可能でないことを定め、
前記1つ以上のクロマブロックのツリータイプはデュアルツリーである、
請求項1乃至3のうちいずれか一項に記載の方法。
【請求項5】
前記ルールは、MODE_TYPE_INTRAに等しいモードタイプを有するブロックに対して前記第1予測モードが利用可能であることを定め、
前記ルールは更に、MODE_TYPE_INTRAに等しいモードタイプを有するブロックに対して前記第1予測モードが利用可能であり、当該ブロックがスキップされないことを定め、
前記ルールは、前記ブロックがスキップされないことを示すよう前記ビットストリームに第1シンタックス要素cu_skip_flagが含まれることを定める、
請求項1乃至4のうちいずれか一項に記載の方法。
【請求項6】
前記第1予測モードが有効であるかどうかを示すよう前記ビットストリームに第2シンタックス要素が含められ、
前記ルールは、前記第2シンタックス要素が存在しない場合に、コーディングブロックの幅及び高さが4に等しくかつブロックがスキップされるという条件で、当該ブロックに対して前記第1予測モードが使用されると推測されることを定め、あるいは、
前記ルールは、前記第2シンタックス要素が存在しない場合に、MODE_TYPE_INTRAに等しいモードタイプをブロックが有しかつ該ブロックがスキップされるという条件で、当該ブロックに対して前記第1予測モードが使用されると推測されることを定める、
請求項1乃至5のうちいずれか一項に記載の方法。
【請求項7】
前記ルールは更に、第1カラーフォーマットについては前記コーディングツリーノードに第1スキームが適用されることを定め、
前記コーディングツリーノードが前記ルーマペアレントブロックのサイズに関する所定の条件を満足する場合に、前記第1カラーフォーマットとは異なる第2カラーフォーマットについては前記コーディングツリーノードに前記第1スキームとは異なる第2スキームが適用される、
請求項1乃至6のうちいずれか一項に記載の方法。
【請求項8】
前記第1カラーフォーマットは、4:0:0カラーフォーマット又は4:4:4カラーフォーマットであり、前記第2カラーフォーマットは、4:2:0カラーフォーマット又は4:2:2カラーフォーマットであり、
前記第1スキーム及び前記第2スキームは、前記1つ以上のルーマブロック及び前記1つ以上のクロマブロックのモードタイプに対する異なる制約を有し、
前記第1スキームでは、前記1つ以上のルーマブロック及び前記1つ以上のクロマブロックの前記モードタイプは、MODE_TYPE_ALLであり、
前記第2スキームでは、前記1つ以上のルーマブロック及び前記1つ以上のクロマブロックの前記モードタイプは、MODE_TYPE_INTRA又はMODE_TYPE_INTERである、
請求項7に記載の方法。
【請求項9】
前記第1カラーフォーマットは、4:0:0カラーフォーマット又は4:4:4カラーフォーマットであり、前記第2カラーフォーマットは、4:2:0カラーフォーマット又は4:2:2カラーフォーマットであり、
前記第1スキームでは、同じパーティショニングスキームが、前記クロマペアレントブロック及び前記ルーマペアレントブロックをパーティション化するために使用され、
前記第2スキームでは、前記クロマペアレントブロックのモードタイプがMODE_TYPE_INTRAである場合に、異なるパーティショニングスキームが、前記クロマペアレントブロック及び前記ルーマペアレントブロックを個別的にパーティション化するために使用され、
前記第2スキームで、前記クロマペアレントブロックは、パーティション化されることを許されず、前記クロマペアレントブロックのツリータイプは、DUAL_TREE_CHROMAにセットされ、
前記第2スキームで、前記クロマペアレントブロックのモードタイプがMODE_TYPE_INTRAである場合に、前記クロマペアレントブロックのサイズに対する制約は、4:2:0カラーフォーマット及び4:2:2カラーフォーマットについて同じであり、前記制約は、前記クロマペアレントブロックの幅及び高さが両方とも4以上であることを含む、
請求項7に記載の方法。
【請求項10】
前記所定の条件は、前記ルーマペアレントブロックのパーティショニンタイプに更に関係があり、
前記第2スキームで、Iスライスであるスライスタイプを有し、4:2:0カラーフォーマットを有し、かつ所定のサイズM×Nを有するルーマペアレントブロックを有するコーディングツリーノードについて、当該ルーマペアレントブロックは、水平BT(二分木)パーティション又は垂直BTパーティションで2つ以上のルーマブロックに分割されることを許され、前記コーディングツリーノードのクロマペアレントブロックは、前記水平BTパーティション又は前記垂直BTパーティションで分割されることを許されず、前記2つ以上のルーマブロックのモードタイプは、MODE_TYPE_INTRA又はMODE_TYPE_INTERにセットされ、M及びNは正の整数であり、あるいは、
前記第2スキームで、Iスライスであるスライスタイプを有し、4:2:2カラーフォーマットを有し、かつ所定のサイズM×Nを有するルーマペアレントブロックを有するコーディングツリーノードについて、当該ルーマペアレントブロック及び前記コーディングツリーノードのクロマペアレントブロックは両方とも、水平BT(二分木)パーティション又は垂直BTパーティションで2つ以上のルーマブロック及び2つ以上のクロマブロックに分割されることを許され、前記2つ以上のルーマブロック及び前記2つ以上のクロマブロックのモードタイプは、MODE_TYPE_ALLにセットされ、M×N=64である、
請求項7に記載の方法。
【請求項11】
前記所定の条件は、前記ルーマペアレントブロックのパーティショニンタイプに更に関係があり、
前記第2スキームで、Iスライスであるスライスタイプを有し、4:2:0カラーフォーマットを有し、かつ所定のサイズM×Nを有するルーマペアレントブロックを有するコーディングツリーノードについて、当該ルーマペアレントブロックは、水平TT(三分木)パーティション又は垂直TTパーティションで2つ以上のルーマブロックに分割されることを許され、前記コーディングツリーノードのクロマペアレントブロックは、前記水平TTパーティション又は前記垂直TTパーティションで分割されることを許されず、前記2つ以上のルーマブロック及び前記クロマペアレントブロックのモードタイプは、MODE_TYPE_INTRA又はMODE_TYPE_INTERにセットされ、M及びNは正の整数であり、あるいは、
前記第2スキームで、Iスライスであるスライスタイプを有し、4:2:2カラーフォーマットを有し、かつ所定のサイズM×Nを有するルーマペアレントブロックを有するコーディングツリーノードについて、当該ルーマペアレントブロック及び前記コーディングツリーノードのクロマペアレントブロックは両方とも、水平TT(三分木)パーティション又は垂直TTパーティションで2つ以上のルーマブロック及び2つ以上のクロマブロックに分割されることを許され、前記2つ以上のルーマブロック及び前記2つ以上のクロマブロックのモードタイプは、MODE_TYPE_ALLにセットされ、M×N=128である、
請求項7に記載の方法。
【請求項12】
前記ルールは更に、前記第1予測モード又は第2予測モードを適用する前記1つ以上のクロマブロックのうちのクロマブロックが2クロマサンプルよりも大きい幅を有するよう制約されることを定め、
前記第2予測モードは、イントラコーディングモードである、
請求項1乃至11のうちいずれか一項に記載の方法。
【請求項13】
前記ルールは、クロマブロックのツリータイプがデュアルツリータイプに等しい場合に、当該クロマブロックが2クロマサンプルよりも大きい幅を有するよう制約されることを定め、
前記ルールは、前記クロマペアレントブロックのツリータイプがデュアルツリータイプに等しくかつ前記クロマペアレントブロックの幅が4クロマサンプルに等しい場合に、垂直BT(二分木)分割が前記クロマペアレントブロックに対して無効にされることを定め、
前記ルールは、前記クロマペアレントブロックのツリータイプがデュアルツリータイプに等しくかつ前記クロマペアレントブロックの幅が8クロマサンプルに等しい場合に、垂直TT(三分木)分割が前記クロマペアレントブロックに対して無効にされることを定める、
請求項12に記載の方法。
【請求項14】
前記ルーマペアレントブロックは、再帰的パーティション動作を含むルーマパーティションスキームに基づきルーマコーディングツリーブロックから生成され、前記クロマペアレントブロックは、前記ルーマパーティションスキームと同じ再帰的パーティション動作を有するクロマパーティションスキームに基づきクロマコーディングツリーブロックから生成され、
前記ルールは、前記ルーマペアレントブロックが8ルーマサンプルに等しい幅を有し、前記クロマペアレントブロックが4クロマサンプルに等しい幅を有するとき、前記クロマペアレントブロックのモードタイプがMODE_TYPE_INTRAである場合に、垂直BT(二分木)分割が前記クロマペアレントブロックに対して無効にされ、前記ルーマペアレントブロックに対して許されることを定め、MODE_TYPE_INTRAは、イントラモード、パレットモード、及びイントラブロックコピーモードの適用可能性を示し、
前記ルールは、前記ルーマペアレントブロックが8ルーマサンプルに等しい幅を有し、前記クロマペアレントブロックが4クロマサンプルに等しい幅を有するとき、前記クロマペアレントブロックのモードタイプがMODE_TYPE_INTRAでない場合に、前記垂直BT分割が前記クロマペアレントブロック及び前記ルーマペアレントブロックの両方に対して許されることを定め、
前記ルールは、前記ルーマペアレントブロックが16ルーマサンプルに等しい幅を有し、前記クロマペアレントブロックが8クロマサンプルに等しい幅を有するとき、前記クロマペアレントブロックのモードタイプがMODE_TYPE_INTRAである場合に、垂直TT(三分木)分割が前記クロマペアレントブロックに対して無効にされ、前記ルーマペアレントブロックに対して許されることを定め、
前記ルールは、前記ルーマペアレントブロックが16ルーマサンプルに等しい幅を有し、前記クロマペアレントブロックが8クロマサンプルに等しい幅を有するとき、前記クロマペアレントブロックのモードタイプがMODE_TYPE_INTRAでない場合に、前記垂直TT分割が前記クロマペアレントブロック及び前記ルーマペアレントブロックの両方に対して許されることを定める、
請求項12に記載の方法。
【請求項15】
前記ルールは、第3予測モードを適用するクロマブロックが4以上の幅を有するよう制約されることを定め、
前記第3予測モードで、イントラ予測信号及びインター予測信号が、予測信号を生成するよう係数によって結合され、
前記ルールは、前記第3予測モードでの前記イントラ予測信号がプレーナーモードに基づいて導出されることを定める、
請求項1乃至14のうちいずれか一項に記載の方法。
【請求項16】
前記変換は、前記ビデオを前記ビットストリームに符号化することを含む、
請求項1乃至15のうちいずれか一項に記載の方法。
【請求項17】
前記変換は、前記ビデオを前記ビットストリームから復号することを含む、
請求項1乃至15のうちいずれか一項に記載の方法。
【請求項18】
ビデオデータを処理する装置であって、
プロセッサと、命令を有している非一時メモリとを有し、
前記命令は、前記プロセッサによる実行時に、前記プロセッサに、
ビデオのコーディングツリーノードと前記ビデオのビットストリームとの間の変換のために、前記コーディングツリーノードのルーマペアレントブロック及び前記コーディングツリーノードのクロマペアレントブロックを分割し、前記ルーマペアレントブロックからの1つ以上のルーマブロック及び前記クロマペアレントブロックからの1つ以上のクロマブロックを予測するためのルールに従ったスキームを決定するステップと、
前記変換を前記スキームに基づき実行するステップと
を実行させ、
前記ルールは、4サンプルに等しい幅を有する前記1つ以上のルーマブロックのうちのルーマブロックに対して第1予測モードが適用可能であることを定め、
前記第1予測モードで、予測サンプルは、ブロックベクトルによって決定されたのと同じピクチャのサンプル値のブロックから導出される、装置。
【請求項19】
プロセッサに、
ビデオのコーディングツリーノードと前記ビデオのビットストリームとの間の変換のために、前記コーディングツリーノードのルーマペアレントブロック及び前記コーディングツリーノードのクロマペアレントブロックを分割し、前記ルーマペアレントブロックからの1つ以上のルーマブロック及び前記クロマペアレントブロックからの1つ以上のクロマブロックを予測するためのルールに従ったスキームを決定するステップと、
前記変換を前記スキームに基づき実行するステップと
を実行させ、
前記ルールは、4サンプルに等しい幅を有する前記1つ以上のルーマブロックのうちのルーマブロックに対して第1予測モードが適用可能であることを定め、
前記第1予測モードで、予測サンプルは、ブロックベクトルによって決定されたのと同じピクチャのサンプル値のブロックから導出される、非一時的なコンピュータ可読記憶媒体。
【請求項20】
ビデオ処理装置によって実行された方法によって生成されるビデオのビットストリームを記憶する非一時的なコンピュータ可読記録媒体であって、
前記方法は、
ビデオのコーディングツリーノードについて、前記コーディングツリーノードのルーマペアレントブロック及び前記コーディングツリーノードのクロマペアレントブロックを分割し、前記ルーマペアレントブロックからの1つ以上のルーマブロック及び前記クロマペアレントブロックからの1つ以上のクロマブロックを予測するためのルールに従ったスキームを決定するステップと、
前記スキームに基づき前記ビットストリームを生成するステップと
を有し、
前記ルールは、4サンプルに等しい幅を有する前記1つ以上のルーマブロックのうちのルーマブロックに対して第1予測モードが適用可能であることを定め、
前記第1予測モードで、予測サンプルは、ブロックベクトルによって決定されたのと同じピクチャのサンプル値のブロックから導出される、非一時的なコンピュータ可読記録媒体。
【発明の詳細な説明】
【技術分野】
【0001】
[関連出願への相互参照]
本願は、2019年8月6日に出願された国際特許出願第PCT/CN2019/099447号に対する優先権及びその利益を主張して2020年8月6日に出願された国際特許出願第PCT/CN2020/107400号の国内移行である特願2022-506732号の分割出願である。上記の全ての出願は、それらの全文を参照により本願に組み込まれる。
【0002】
[技術分野]
本文書は、ビデオ及びイメージの符号化及び復号化技術に関係がある。
【背景技術】
【0003】
デジタルビデオは、インターネット及び他のデジタル通信ネットワーク上での最大のバンド幅使用を占めている。ビデオを受信し表示することができるユーザデバイスの接続数が増えるにつれて、デジタルビデオ利用のためのバンド幅需要は増え続けることが予想される。
【発明の概要】
【0004】
開示されている技術は、参照ピクチャがビデオ符号化又は復号化で使用されるビデオ又はイメージデコーダ又はエンコーダ実施形態によって使用され得る。
【0005】
一例となる態様では、ビデオ処理の方法が開示される。方法は、ルールに従って、ビデオのカラーフォーマットに基づき、前記ビデオのクロマビデオ領域を1つ以上のクロマブロックにパーティション化するパーティショニングスキームを決定するステップと、前記パーティショニングスキームに従って、前記ビデオと前記ビデオの符号化表現との間の変換を実行するステップとを含む。
【0006】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ビデオのカラーフォーマットに基づき、前記ビデオのコーディングツリーノードのサブブロックのための予測モード又は予測タイプを決定するステップと、前記決定に基づき、前記ビデオと前記ビデオの符号化表現との間の変換を実行するステップとを含み、前記コーディングツリーノードは、前記符号化表現でのコーディングのためにサブブロックにパーティション化される。
【0007】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ルールに従って、1つ以上のルーマブロック及び1つ以上のクロマブロックを有する1つ以上のビデオ領域を有するビデオと、該ビデオの符号化表現との間の変換を実行するステップを含み、前記ルールは、サイズM×Nを有している前記1つ以上のクロマブロックの中のクロマブロックが、イントラモード又はイントラブロックコピーモードを用いて前記符号化表現で表現されることを許可されないことを定め、M及びNは、夫々、前記クロマブロックの幅及び高さを示す整数であり、前記イントラモードは、前に符号化又は再構成されたビデオブロックに基づき前記クロマブロックを符号化することを含み、前記イントラブロックコピーモードは、ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記クロマブロックを符号化することを含む。
【0008】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ビデオのビデオ領域と前記ビデオの符号化表現との間の変換のために、ルールに従って、インター-イントラ複合予測(combined inter and intra prediction,CIIP)モードをイントラモード又はインターモードとして使用すると決定するステップと、前記決定に基づき前記変換を実行するステップとを含み、前記CIIPモードは、加重係数を用いてイントラ予測信号とインター予測信号とを結合することを含む。
【0009】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ビデオのクロマブロックと前記ビデオの符号化表現との間の変換を実行するステップを含み、前記クロマブロックは、サイズルールに従ったイントラコーディングモードを用いて前記符号化表現で表現され、前記サイズルールは、前記クロマブロックの幅がMに等しいか又は前記クロマブロックの高さがNに等しい場合には、前記イントラコーディングモードがイントラコーディングモードタイプの第1セットからであり、そうではない場合には、前記イントラコーディングモードがイントラコーディングモードタイプの第2セットからであることを定め、M及びNは整数である。
【0010】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ビデオのクロマブロックと前記ビデオの符号化表現との間の変換を実行するステップを含み、前記クロマブロックは、ルールに従った変換タイプを用いて前記符号化表現で表現され、前記ルールは、前記クロマブロックの幅がMに等しいか又は前記クロマブロックの高さがNに等しい場合には、前記変換タイプが変換タイプの第1セットからであり、そうではない場合には、前記変換タイプが変換タイプの第2セットからであることを定め、M及びNは整数である。
【0011】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ルールに従って、1つ以上のルーマブロック及び1つ以上のクロマブロックを有するビデオ領域を有するビデオと、該ビデオの符号化表現との間の変換を実行するステップを含み、前記ルールは、M及びNの全ての値について、イントラブロックコピー(intra block copy,IBC)モードの使用が、ブロックサイズM×Nを有している前記1つ以上のルーマブロック及び前記1つ以上のクロマブロックに対して利用可能であることを定め、M及びNは整数であり、前記IBCモードを用いて、ビデオブロックは、該ビデオブロックを含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて符号化される。
【0012】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ビデオのビデオブロックと該ビデオブロックの符号化表現との間の変換を実行するステップを含み、前記符号化表現はフォーマットルールに従い、該フォーマットルールは、前記ビデオブロックのモードタイプに基づいた、前記符号化表現でのインターブロックコピー(IBC)モードの使用を示すシンタックス要素の選択的包含を定め、前記IBCモードは、前記ビデオブロックを含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオブロックを符号化することを含む。
【0013】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ビデオのビデオブロックと該ビデオブロックの符号化表現との間の変換を実行するステップを含み、前記符号化表現はフォーマットルールに従い、該フォーマットルールは、パレットモードの使用を示すシンタックス要素が前記ビデオブロックのモードタイプにかかわらず前記符号化表現に含まれることを定め、前記パレットモードは、代表サンプル値のパレットを用いて前記ビデオブロックを符号化することを含む。
【0014】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ビデオのビデオ領域と前記ビデオの符号化表現との間の変換のために、ルールに基づき、インターブロックコピー(IBC)モードの使用が前記ビデオ領域に許可されることを決定するステップと、前記決定に基づき前記変換を実行するステップとを含み、前記IBCモードは、前記ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオ領域を符号化することを含む。
【0015】
他の例となる態様では、ビデオ処理の他の方法が開示される。方法は、ビデオのビデオ領域と前記ビデオの符号化表現との間の変換のために、ルールに基づき、パレットモードの使用が前記ビデオ領域に許可されるかどうかを決定するステップと、前記決定に基づき前記変換を実行するステップとを含み、前記ルールは、前記ビデオ領域のコーディングモードタイプ又は前記ビデオ領域のカラータイプに基づき、前記パレットモードは、代表サンプル値のパレットを用いて前記ビデオ領域を符号化することを含む。
【0016】
更なる他の例となる態様では、上記の方法は、プロセッサを有するビデオエンコーダ装置によって実装されてもよい。
【0017】
更なる他の例となる態様では、上記の方法は、プロセッサを有するビデオデコーダ装置によって実装されてもよい。
【0018】
更なる他の例となる態様では、これらの方法は、プロセッサ実行可能命令の形で具現化され、コンピュータ可読プログラム媒体に記憶されてもよい。
【0019】
これら及び他の態様は、本文書で更に記載される。
【図面の簡単な説明】
【0020】
【
図1】イントラブロックコピー符号化ツールの例を示す。
【
図2】パレットモードで符号化されたブロックの例を示す。
【
図3】パレットエントリを通知するためのパレット予測子の使用の例を示す。
【
図4】水平及び垂直トラバーススキャンの例を示す。
【
図8】ALFフィルタ形状(クロマ:5×5ダイヤモンド、ルーマ:7×7ダイヤモンド)の例を示す。
【
図9】サブサンプリングされたラプラシアン計算の例を示す。
【
図10】仮想境界での修正ブロック分類の例を示す。
【
図11】仮想境界でのルーマ成分に対する修正ALFフィルタリングの実例を示す。
【
図12】EOでのピクセル分類のための4つの1次元3ピクセルパターンの例を示す。
【
図13】4つのバンドがグループにまとめられ、その開始バンド位置によって表現されることを示す。
【
図14】CIIP重み導出で使用される上及び左隣接ブロックを示す。
【
図15】クロマスケーリングアーキテクチャによるルーママッピングを示す。
【
図17A】本文書で記載されている技術を実装するために使用されるハードウェアプラットフォームの例のブロック図である。
【
図17B】本文書で記載されている技術を実装するために使用されるハードウェアプラットフォームの例のブロック図である。
【
図18】ビデオ処理の方法の例のフローチャートである。
【
図20】空間マージ候補の冗長性検査のために考慮される候補ペアの例を示す。
【
図21A】開示されている技術のいくつかの実施に基づいたビデオ処理の方法の例のフローチャートを示す。
【
図21B】開示されている技術のいくつかの実施に基づいたビデオ処理の方法の例のフローチャートを示す。
【
図22A】開示されている技術のいくつかの実施に基づいたビデオ処理の方法の例のフローチャートを示す。
【
図22B】開示されている技術のいくつかの実施に基づいたビデオ処理の方法の例のフローチャートを示す。
【
図23A】開示されている技術のいくつかの実施に基づいたビデオ処理の方法の例のフローチャートを示す。
【
図23B】開示されている技術のいくつかの実施に基づいたビデオ処理の方法の例のフローチャートを示す。
【発明を実施するための形態】
【0021】
本文書は、圧縮解除又は復号されたデジタルビデオ又はイメージの品質を改善するためにイメージ又はビデオビットストリームのデコーダによって使用され得る様々な技術を提供する。簡潔さのために、「ビデオ」との用語は、ピクチャの連続(従来は、ビデオと呼ばれる)及び個々のイメージの両方を含むようここでは使用されている。更に、ビデオエンコーダも、更なる符号化のために使用される復号されたフレームを再構成するために符号化のプロセス中にそれらの技術を実装してもよい。
【0022】
セクション見出しは、理解を簡単にするために本文書で使用されており、実施形態及び技術を対応するセクションに限定するものではない。そのようなものとして、1つのセクション中の実施形態は、他のセクション中の実施形態と組み合わされ得る。
【0023】
1.概要
この文書は、ビデオコーディング技術に関係がある。具体的に、それは、ビデオコーディングで基本色に基づいた表現を用いるパレットコーディングに関係がある。それは、HEVCのような既存のビデオコーディング標準規格、又は最終決定されることになっている標準規格(Versatile Video Coding)に適用されてもよい。それはまた、将来のビデオコーディング標準規格又はビデオコーデックにも適用可能であり得る。
【0024】
2.最初の議論
ビデオコーディング標準規格は、よく知られているITU-T及びISO/IEC標準規格の開発を通じて主に発展してきた。ITU-TはH.261及びH.263を作り出し、ISO/IECはMPEG-1及びMPEG-4 Visualを作り出し、2つの組織は共同でH.262/MPEG-2 Video及びH264/MPEG-4 Advanced Video Coding(AVC)及びH.265/HEVC標準規格を作り出した。H.262以降、ビデオコーディング標準規格は、時間予測に変換コーディングをプラスしたものが利用されるハイブリッド型ビデオコーディング構造に基づいている。HEVCを超える将来のビデオコーディング技術を探求するために、Joint Video Exploration Team(JVET)が2015年にVCEG及びMPEGによって共同で設立された。それ以降、多くの新しい手法がJVETによって採用され、Joint Exploration Model(JEM)と呼ばれる参照ソフトウェアに置かれてきた。2018年4月に、VCEG(Q6/16)とISO/IEC JTC1 SC29/WG11(MPEG)との間で、Joint Video Expert Team(JVET)が、HEVCと比較して50%のビットレート低減を目標とするVVC標準規格を検討するために作られた。
【0025】
VVC草案の最新バージョン、つまり、Versatile Video Coding(Draft 4)は、http://phenix.it-sudparis.eu/jvet/doc_end_user/current_document.php?id=5755で見つけることができる。
【0026】
VTMと名付けられたVVCの最新の参照ソフトウェアは、https://vcgit.hhi.fraunhofer.de/jvet/VVCSoftware_VTM/tags/VTM-5.0で見つけることができる。
【0027】
2.1 イントラブロックコピー
イントラブロックコピー(intra block copy,IBC)、別名、現在ピクチャ参照(current picture referencing)は、HEVC Screen Content Coding拡張(HEVC-SCC)及び現在のVVCテストモデル(VTM-4.0)で採用されている。IBCは、動き補償の概念をインターフレームコーディングからイントラフレームコーディングに拡張する。
図1で示されるように、現在ブロックは、IBCが適用される場合に、同じピクチャ内の参照ブロックによって予測される。参照ブロック内のサンプルは、現在ブロックが符号化又は復号化される前に既に再構成されている。IBCは、カメラによって捕捉されたシーケンスのほとんどにとってそれほど効率的ではないが、それは、スクリーンコンテンツについてはコーディングの大幅な向上を示す。その理由は、スクリーンコンテンツピクチャにはアイコン及びテキスト文字などの反復パターンが多数存在するからである。IBCは、それらの反復パターンの間の冗長性を有効に除くことができる。HEVC-SCCでは、インターコーディングされたコーディングユニット(coding unit,CU)は、それが現在ピクチャをその参照ピクチャとして選択する場合に、IBCを適用することができる。MVは、この場合にブロックベクトル(block vector,BV)と名称を変更され、BVは常に整数ピクセル精度を有している。メインプロファイルHEVCと互換性を持たせるために、現在ピクチャは、復号化ピクチャバッファ(Decoded Picture Buffer,DPB)で「長期」参照ピクチャとしてマークされる。同様に、マルチビュー/3Dビデオコーディング標準規格では、インタービュー参照ピクチャも「長期」参照ピクチャとしてマークされることが留意されるべきである。
【0028】
その参照ブロックを見つけるためのBVに続いて、予測が、参照ブロックをコピーすることによって生成され得る。元の信号から参照ピクセルを減じることによって、残差が得られる。次いで、変換及び量子化が他のコーディングモードで見られるように適用され得る。
【0029】
【0030】
しかし、参照ブロックがピクチャの外にあるか、又は現在ブロックと重なり合うか、又は再構成されたエリアの外にあるか、又は何らかの制約によって制限された有効エリアの外にある場合に、一部又は全てのピクセル値は定義されない。基本的に、そのような問題を扱うための2つの解決法がある。1つは、例えば、ビットストリームコンフォーマンス(bitstream conformance)で、そのような状況を認めないことである。もう1つは、それらの未定義のピクセル値に対してパディングを適用することである。以下のサブセッションは、これらの解決法について詳細に記載する。
【0031】
2.2 HEVC-SCCにおけるIBC
HEVCのスクリーンコンテンツコーディング拡張(Screen Content Coding extensions)では、ブロックが現在ピクチャを参照として使用する場合に、以下のスペックテキストで示されるように、参照ブロック全体が利用可能な再構成されたエリア内にあることを保証すべきである:
【表1】
【0032】
よって、参照ブロックが現在ブロックと重なり合うか、又は参照ブロックがピクチャの外にある場合は、起こらない。参照又は予測ブロックをパディングする必要はない。
【0033】
2.3 VVCテストモデルにおけるIBC
現在のVVCテストモデル、つまり、VTM-4.0設計では、参照ブロック全体が現在のコーディングツリーユニット(coding tree unit,CTU)と一致している必要があり、現在ブロックとは重なり合わない。よって、参照又は予測ブロックをパディングする必要はない。IBCフラグは、現在CUの予測モードとしてコーディングされる。よって、各CUについて全部で3つの予測モード、すなわち、MODE_INTRA、MODE_INTER、及びMODE_IBCがある。
【0034】
2.3.1 IBCマージモード
IBCマージモードでは、IBCマージ候補リスト(merge candidates list)内のエントリを指し示すインデックスが、ビットストリームからパースされる。IBCマージリストの構成は、次の一連のステップに従って手短に述べられ得る:
・ステップ1:空間候補の導出
・ステップ2:HMVP候補の挿入
・ステップ3:ペアワイズ平均候補の挿入
【0035】
空間マージ候補の導出では、最大4つのマージ候補が、
図19に表されている位置にある候補から選択される。導出の順序は、A
1、B
1、B
0、A
0、及びB
2である。位置B
2は、位置A
1、B
1、B
0、A
0のいずれかのPU(それが他のスライス又はタイルに属するために)利用可能でないか、あるいは、IBCモードでコーディングされていない場合にのみ考慮される。位置A
1での候補が加えられた後、残りの候補の挿入は冗長性検査を受ける。これは、同じ動き情報を有する候補がリストから外されることを確かにし、それにより、コーディング効率は改善される。計算複雑性を低減するために、上記の冗長性検査において、可能性がある全ての候補ペアが考慮されるわけではない。代わりに、
図20において矢印で結ばれているペアが考慮され、候補は、冗長性検査のために使用された対応する候補が同じ動き情報を有していない場合にのみリストに加えられる。
【0036】
空間候補の挿入の後、IBCマージリストサイズが依然として最大IBCマージリストサイズよりも小さい場合には、HMVPテーブルからのIBC候補が挿入されてもよい。HMVP候補を挿入する場合に、冗長性検査が実行される。
【0037】
最後に、ペアワイズ平均候補が、IBCマージリストに挿入される。
【0038】
マージ候補によって識別された参照ブロックがピクチャの外にあるか、又は現在ブロックと重なり合うか、又は再構成されたエリアの外にあるか、又は何らかの制約によって制限された有効エリアの外にある場合に、マージ候補は、無効マージ候補(invalid merge candidate)と呼ばれる。
【0039】
無効マージ候補はIBCマージリストに挿入されてもよいことが留意される。
【0040】
2.3.2 IBC AMVPモード
IBC AMVPモードでは、IBC AMVPリスト内のエントリを指し示すインデックスが、ビットストリームからパースされる。IBC AMVPリストの構成は、次の一連のステップに従って手短に述べられ得る:
・ステップ1:空間候補の導出
・利用可能な候補が見つけられるまでA0、A1をチェックする
・利用可能な候補が見つけられるまでB0、B1、B2をチェックする
・ステップ2:HMVP候補の挿入
・ステップ3:ゼロ候補の挿入
【0041】
空間候補の挿入の後、IBC AMVPリストサイズが依然として最大IBC AMVPリストサイズよりも小さい場合には、HMVPテーブルからのIBC候補が挿入されてもよい。
【0042】
最後に、ゼロ候補が、IBC AMVPリストに挿入される。
【0043】
2.4 パレットモード
パレットモードの背後にある基本的な考えは、CU内のサンプルが代表的な色値の小さいセットによって表現されることである。このセットはパレットと呼ばれる。また、エスケープ記号に続いて(場合により量子化された)成分値を通知することによって、パレットの外にあるサンプルを示すことも可能である。この種のサンプルはエスケープサンプルと呼ばれる。パレットモードは
図2で表されている。
【0044】
図2は、パレットモードで符号化されたブロックの例を示す。
【0045】
HEVC-SCCにおけるパレットモードでは、パレット及びインデックスマップをコーディングするために、予測的な方法が使用される。
【0046】
2.5.1 パレットエントリのコーディング
パレットエントリのコーディングのために、パレット予測子が維持される。パレットの最大サイズは、パレット予測子とともに、SPSで通知される。HEVC-SCCでは、palette_predictor_initializer_present_flagがPPSで導入される。このフラグが1であるとき、パレット予測子を初期化するためのエントリがビットストリームで通知される。パレット予測子は、各CTU行、各スライス、及び各タイルの開始時に初期化される。palette_predictor_initializer_present_flagの値に応じて、パレット予測子は、0にリセットされるか、又はPPCで通知されたパレット予測子初期化子エントリを用いて初期化される。HEVC-SCCでは、サイズ0のパレット予測子初期化子が、PPSレベルでのパレット予測子初期化の明示的な無効化を可能にするよう有効にされた。
【0047】
パレット予測子における各エントリについては、それが現在のパレットの部分であるかどうかを示すために、再利用フラグが通知される。これは
図3に表されている。再利用フラグは、ゼロのランレングスコーディングを用いて送信される。この後に、新しいパレットエントリの数が、次数0の指数ゴロム符号を用いて通知される。最後に、新しいパレットエントリの成分値が通知される。
【0048】
図3は、パレットエントリを通知するためのパレット予測子の使用の例を示す。
【0049】
2.5.2 パレットインデックスのコーディング
パレットインデックスは、
図4に示される水平及び垂直トラバーススキャンを用いてコーディングされる。スキャン順序は、palette_transpose_flagを用いてビットストリームで明示的に通知される。サブセクションの残りの部分については、スキャンは水平であると仮定される。
【0050】
図4は、水平及び垂直トラバーススキャンの例を示す。
【0051】
パレットインデックスは、2つの主なパレットサンプルモード:「INDEX」及び「COPY_ABOVE」を用いてコーディングされる。上述されたように、エスケープ記号も、「INDEX」モードとして通知され、最大パレットサイズに等しいインデックスを割り当てられる。モードは、一番上の行の場合又は前のモードが「COPY_ABOVE」であった場合を除いて、フラグを用いて通知される。「COPY_ABOVE」モードでは、上の行にあるサンプルのパレットインデックスがコピーされる。「INDEX」モードでは、パレットインデックスは明示的に通知される。「INDEX」及び「COPY_ABOVE」の両方のモードについて、ラン値(run value)が通知され、これは、やはり同じモードを用いてコーディングされる後続サンプルの数を指定する。エスケープ記号が「INDEX」又は「COPY_ABOVE」モードでのランの部分である場合に、エスケープ成分値がエスケープ記号ごとに通知される。パレットインデックスのコーディングは、
図5に表されている。
【0052】
このシンタックス順序は次のように達成される。最初に、CUのインデックス値の数が通知される。その後に、トランケーテッドバイナリコーディング(truncated binary coding)を用いて、CU全体の実際のインデックス値の通知が続く。これは、インデックスに関連したバイパスビンをグループにまとめる。次いで、パレットサンプルモード(必要な場合)及びランが、インターリーブ方式で通知される。最後に、CU全体のエスケープサンプル値に対応する成分エスケープ値がグループにまとめられて、バイパスモードでコーディングされる。
【0053】
更なるシンタックス要素として、last_run_type_flagが、インデックス値を通知した後に通知される。このシンタックス要素は、インデックスの数と組み合わせて、ブロック内の最後のランに対応するラン値を通知する必要性を排する。
【0054】
HEVC-SCCでは、パレットモードはまた、4:2:2、4:2:0、及びモノクロクロマフォーマットについても有効にされる。パレットエントリ及びパレットインデックスの通知は、全てのクロマフォーマットについてほぼ同じである。非モノクロフォーマットの場合に、各パレットエントリは3つの成分から成る。モノクロフォーマットについては、各パレットエントリは単一の成分から成る。サブサンプリングされたクロマ方向について、クロマサンプルは、2で除算可能であるルーマサンプルインデックスと関連付けられる。CUのパレットインデックスを再構成した後、サンプルがそれと関連付けられた単一の成分しか有さない場合には、パレットエントリの最初の成分のみが使用される。通知の唯一の相違は、エスケープ成分値に関する。エスケープサンプルごとに、通知されるエスケープ成分値の数は、そのサンプルに関連した成分の数に応じて異なり得る。
【0055】
VVCでは、二分木コーディング構造がイントラスライスのコーディングで使用されるので、ルーマ成分及び2つのクロマ成分は、異なったパレット及びパレットインデックスを有し得る。更に、2つのクロマ成分は、同じパレット及びパレットインデックスを共有する。
【0056】
【0057】
2.6 VVCにおけるイントラモードコーディング
自然ビデオで提示される任意のエッジ方向を捕捉するために、VTM5での指向性イントラモードの数は、HEVCで使用される33から、65に拡張される。HEVCにはない新しい指向性モードは、
図6で赤色破線矢印で表されており、プレーナーモード及びDCモードは同じままである。これらのより密なイントラ予測モードは、全てのブロックサイズについて、ルーマ及びクロマの両方のイントラ予測のために適用される。
【0058】
VTM5では、いくつかの従来の角度イントラ予測モードが、非正方ブロックについて広角イントラ予測モードで適応的に置き換えられる。
【0059】
HEVCでは、あらゆるイントラコーディングされたブロックが正方形状を有しており、その各辺の長さは2の累乗である。よって、DCモードを用いてイントラ予測子を生成するために、分割動作は不要である。VTM5では、ブロックは、一般的な場合にブロックごとに分割動作の使用を必要とする長方形状を有する可能性がある。DC予測のための分割動作を回避するために、長い方の辺のみが、非正方ブロックの平均を計算するために使用される。
【0060】
【0061】
最確モード(most probable mode,MPM)リスト生成の複雑性を低く保つために、6つのMPMによるイントラモードコーディング方法が、2つの利用可能な隣接イントラモードを考えることによって使用される。次の3つの態様が、MPMリストを構成するために考えられる:
・デフォルトイントラモード
・隣接イントラモード
・導出イントラモード
【0062】
統合6-MPMリストが、MRL及びISPコーディングツールが適用されるか否かにかかわらず、イントラブロックに対して使用される。MPMリストは、左及び上隣接ブロックのイントラモードに基づいて構成される。左ブロックのモードはLeftと表され、上ブロックのモードはAboveと表されるとして、統合MPMリストは、次のように構成される(左ブロック及び上ブロックは
図7に示される)。
【0063】
図7は、現在ブロックの左隣及び上隣の例を示す。
・隣接ブロックが利用可能でない場合に、そのイントラモードはデフォルトでプレーナー(Planar)にセットされる。
・両方のモードLeft及びAboveが非角度モードである場合に:
・MPMリスト→{プレーナー,DC,V,H,V-4,V+4}
・モードLeft及びAboveの一方が角度モードであり、他方が非角度モードである場合に:
・モードMaxをLeft及びAboveのうちの大きい方のモードとしてセットする
・MPMリスト→{プレーナー,Max,DC,Max-1,Max+1,Max-2}
・Left及びAboveが両方とも角度モードであり、それらが異なる場合に:
・モードMaxをLeft及びAboveのうちの大きい方のモードとしてセットする
・モードLeft及びAboveの差が2以上62以下の範囲にある場合に:
・MPMリスト→{プレーナー,Left,Above,DC,Max-1,Max+1}
・そうでない場合に:
・MPMリスト→{プレーナー,Left,Above,DC,Max-2,Max+2}
・Left及びAboveが両方とも角度モードであり、それらが同じである場合に:
・MPMリスト→{プレーナー,Left,Left-1,Left+1,DC,Left-2}
【0064】
その上、mpmインデックスコードワードの最初のビンは、CABACコンテキストコーディングされる。現在のイントラブロックがMRL対応であるか、ISP対応であるか、又は通常のイントラブロックであるかに対応して、全部で3つのコンテキストが使用される。
【0065】
6-MPMリストの生成プロセス中、一意のモードのみがMPMリストに含まれ得るように、重複したモードを除くためにプルーニングが使用される。61個の非MPMモードのエントロピコーディングについては、トランケーテッドバイナリコーディング(TBC)が使用される。
【0066】
クロマイントラモードコーディングについては、全部で8つのイントラモードが、クロマイントラモードコーディングのために許されている。それらのモードには、5つの従来のイントラモードと、3つのクロスコンポーネント線形モデルモード(cross-component linear model modes)(CCLM、LM_A、及びLM_L)とが含まれる。クロマモードの通知及び導出のプロセスは、表2-4に示される。クロマモードコーディングは、対応するルーマブロックのイントラ予測モードに直接に依存する。ルーマ成分及びクロマ成分のための別個のブロックパーティショニング構造がIスライスでは可能にされるので、1つのクロマブロックは複数のルーマブロックに対応し得る。そのため、クロマDMモードについては、現在のクロマブロックの中心位置をカバーする対応するルーマブロックのイントラ予測モードが直接に承継される。
【表2】
【0067】
2.7 QR-BDPCM(Quantized residual Block Differential Pulse-Code Modulation)
JVET-M0413では、QR-BDPCM(Quantized residual Block Differential Pulse-Code Modulation)が、スクリーンコンテンツを効率的にコーディングするために提案されている。
【0068】
QR-BDPCMで使用される予測方向は、垂直及び水平予測モードであることができる。イントラ予測は、イントラ予測と同様に予測方向(水平及び垂直方向)でのサンプルコピーによって、ブロック全体に対して行われる。残差は量子化され、量子化された残差とその予測子(水平又は垂直)量子化値との間の差(delta)は符号化される。これは、以下によって説明することができる。サイズM(行)×N(列)のブロックについて、r
i,j,0≦i≦M-1,0≦j≦N-1を、上又は左ブロック境界サンプルからのフィルタリングされていないサンプルを用いてイントラ予測を水平方向に(予測されたブロックにわたって左隣接ピクセル値をラインごとにコピーする)又は垂直方向に(予測されたブロック内の各ラインに上隣接ラインをコピーする)実行した後の予測残差であるとする。Q(r
i,j),0≦i≦M-1,0≦j≦N-1が残差r
i,jの量子化されたバージョンを表すとして、このとき、残差は、元のブロック値と予測されたブロック値との間の差である。次いで、ブロックDPCMが、量子化された残差サンプルに適用され、要素
(外1)
を有する変更されたM×Nアレイ
(外2)
が得られる。垂直BDPCMが通知される場合に:
【数1】
である。
【0069】
水平予測については、同様のルールが適用され、残差量子化サンプルは、
【数2】
によって求められる。
【0070】
残差量子化サンプル
(外3)
は、デコーダへ送られる。
【0071】
デコーダ側では、上記の計算は、Q(r
i,j),0≦i≦M-1,0≦j≦N-1を取り出すために逆にされる、垂直予測の場合については、
【数3】
であり、水平予測の場合については
【数4】
である。
【0072】
逆量子化された残差Q-1(Q(ri,j))が、再構成されたサンプル値を生成するようイントラブロック予測値に加えられる。
【0073】
このスキームの主な利点は、係数がパースされるときに予測子を追加するだけで、係数解析中にオン・ザ・フライで逆DPCMを実行できること、又は解析後に実行できることである。
【0074】
2.8 適応ループフィルタ
VTM5では、ブロックベースのフィルタ適応による適応ループフィルタ(Adaptive Loop Filter,ALF)が適用される。ルーマ成分については、25個のフィルタのうちの1つが、局所勾配の方向及び活性に基づき、4×4ブロックごとに選択される。
【0075】
2.8.1.1フィルタ形状
VTM5では、2つのダイヤモンドフィルタ形状(
図8に図示あり)が使用される。7×7ダイヤモンド形状はルーマ成分に対して適用され、5×5ダイヤモンド形状はクロマ成分に対して適用される。
【0076】
図8は、ALFフィルタ形状(クロマ:5×5ダイヤモンド、ルーマ:7×7ダイヤモンド)の例を示す。
【0077】
2.8.1.2ブロック分類
ルーマ成分については、各4×4ブロックは、25個のクラスの中から1つに分類され得る。分類インデックスCは、次のように、その方向性D及び量子化された活性値A(ハット付き)に基づき導出される:
【数5】
【0078】
D及びハット付きAを計算するために、水平方向、垂直方向、及び2つの対角方向の勾配が最初に、1-Dラプラシアンを用いて計算される:
【数6】
インデックスi及びjは、4×4ブロック内の左上サンプルの座標を指し、R(i,j)は、座標(i,j)での再構成されたサンプルを示す。
【0079】
ブロック分類の複雑性を低減するために、サブサンプリングされた1-Dラプラシアン計算が適用される。
図9に示されるように、同じサブサンプリングされた位置が、全ての方向の勾配計算のために使用される。
【0080】
図9は、サブサンプリングされたラプラシアン計算の例を示す。(a)垂直勾配のためのサブサンプリングされた位置、(b)水平勾配のためのサブサンプリングされた位置、(c)対角勾配のためのサブサンプリングされた位置、(d)対角勾配のためのサブサンプリングされた位置。
【0081】
次いで、水平方向及び垂直方向の勾配のDの最大値及び最小値は:
【数7】
としてセットされる。
【0082】
2つの対角方向の勾配の最大値及び最小値は:
【数8】
としてセットされる。
【0083】
方向性Dの値を導出するために、これらの値は、互いに、そして2つの閾値t
1及びt
2と比較される:
【表3】
【0084】
【0085】
Aは、0以上4以下の範囲に更に量子化され、量子化された値は、ハット付きAとして表される。
【0086】
ピクチャ内のクロマ成分については、分類方法は適用されない。すなわち、ひと組のALF係数がクロマ成分ごとに適用される。
【0087】
2.8.1.3 フィルタ係数及びクリッピング値の幾何変換
各4×4ルーマブロックをフィルタリングする前に、回転又は対角及び垂直フリップなどの幾何変換が、そのブロックについて計算された勾配値に応じて、フィルタ係数f(k,l)及び対応するフィルタクリッピング値c(k、l)に適用される。これは、フィルタサポート領域内のサンプルにこれらの変換を適用することと等価である。アイデアは、ALFが適用される様々なブロックを、それらの方向性を調整することによって、より類似させることである。
【0088】
対角、垂直フリップ、及び回転を含む3つの幾何変換が導入される:
【数10】
ここで、Kは、フィルタのサイズであり、0≦k,l≦K-1は、位置(0,0)が左上隅にあり、位置(K-1,K-1)が右下隅にあるような、係数座標である。変換は、そのブロックについて計算された勾配値に応じて、フィルタ係数f(k,l)及びクリッピング値c(k、l)に適用される。変換と4つの方向の4つの勾配との間の関係は、次の表で手短に述べられている。
【表4】
【0089】
2.8.1.4 フィルタパラメータ通知
VTM5では、ALFフィルタパラメータは、適応パラメータセット(Adaptation Parameter Set,APS)で通知される。1つのAPSでは、最大25組のルーマフィルタ係数及びクリッピング値が通知され得る。ビットオーバヘッドを低減するために、異なる分類のフィルタ係数はマージされ得る。スライスヘッダでは、現在スライスに使用されるAPSのインデックスが通知される。
【0090】
APSから復号されるクリッピング値インデックスは、クリッピング値のルーマテーブル及びクリッピング値のクロマテーブルを用いてクリッピング値を決定することを可能にする。これらのクリッピング値は、内在的なビットデプスに依存する。より厳密は、クリッピング値のルーマテーブル及びクリッピング値のクロマテーブルは、次の式によって取得される:
【数11】
なお、Bは内在的なビットデプスに等しく、Nは4に等しく、VTM5.0での許容クリッピング値の数である。
【0091】
フィルタリングプロセスは、CTBレベルで制御され得る。フラグは、ALFがルーマCTBに適用されるかどうかを示すために常に通知される。ルーマCTBは、16個の固定フィルタセットと、APSからのフィルタセットとから、フィルタセットを選択することができる。フィルタセットインデックスは、ルーマCTBについて、どのフィルタセットが適用されるかを示すために通知される。16個の固定フィルタセットは予め定義され、エンコーダ及びデコーダの両方でハードコーディングされる。
【0092】
フィルタ係数は、128に等しいノルムで量子化される。乗算複雑性を制限するために、非中心位置の係数値が-27以上27-1以下の範囲にあるべきであるように、ビットストリームコンフォーマンスが適用される。中心位置係数は、ビットストリームで通知されず、128に等しいと見なされる。
【0093】
2.8.1.5 フィルタリングプロセス
デコーダ側で、ALFがCTBに対して有効にされる場合に、CU内の各サンプルR(i,j)はフィルタリングされ、以下で示されるサンプル値R’(i,j)が得られる:
【数12】
ここで、f(k、l)は、復号されたフィルタ係数であり、K(x,y)は、クリッピング関数であり、c(k、l)は、復号されたクリッピングパラメータを表す。変数k及びlは、-L/2からL/2の間で変化し、Lは、フィルタ長さを表す。クリッピング関数K(x,y)=min(y,max(-y,x))であり、関数Clip3(-y,y,x)に対応する。
【0094】
2.8.1.6 ラインバッファ低減のための仮想境界フィルタリングプロセス
VTM5では、ラインバッファ要件を低減するために、変更されたブロック分類及びフィルタリングが、水平CTU境界に近いサンプルのために用いられる。このために、仮想境界は、
図10に示されるように、“N”個のサンプルを含む水平CTU境界をシフトすることによってラインとして定義される。Nは、ルーマ成分については4に等しく、クロマ成分については2に等しい。
【0095】
図10は、仮想境界での修正されたブロック分類の例を示す。
【0096】
図11に示されるように、修正されたブロック分類がルーマ成分に適用され、それに応じて、活性値Aは、1Dラプラシアン勾配計算で使用されるサンプル数の減少を考慮に入れることによってスケーリングされる。
【0097】
フィルタリングプロセスについては、仮想境界での対称パディング動作が、ルーマ及びクロマの両方の成分のために使用される。
図11に示されるように、フィルタリングされているサンプルが仮想境界の下に位置している場合に、仮想境界の上に位置している隣接サンプルがパディングされる。一方、他方の側にある対応するサンプルも対称的にパディングされる。
【0098】
図11は、仮想境界でのルーマ成分に対する修正ALFフィルタリングの実例を示す。
【0099】
2.9 サンプル適応オフセット(SAO)
サンプル適応オフセット(sample adaptive offset,SAO)は、エンコーダによってCTBごとに指定されたオフセットを使用することによって、デブロッキングフィルタ後の再構成された信号に適用される。HMエンコーダは最初に、SAOプロセスが現在スライスに適用されるべきか否かを決定する。SAOがスライスに適用される場合に、各CTBは、表2-6に示されるように、5つのSAOタイプのうちの1つとして分類される。SAOの概念は、ピクセルをカテゴリに分類することであり、各カテゴリのピクセルにオフセットを加えることによって歪みを低減する。SAO動作は、SAOタイプ1~4におけるピクセル分類のためにエッジ特性を使用するエッジオフセット(EO)と、SAOタイプ5におけるピクセル分類のためにピクセル強度を使用するバンドオフセット(BO)とを含む。各適用可能なCTBは、sao_merge_left_flag、sao_merge_up_flag、SAOタイプ、及び4つのオフセットを含むSAOパラメータを有している。sao_merge_left_flagが1に等しい場合に、現在CTBは、左側にあるCTBのSAOタイプ及びオフセットを再利用する。sao_merge_up_flagが1に等しい場合に、現在CTBは、上のCTBのSAOタイプ及びオフセットを再利用する。
【表5】
【0100】
2.9.1 各SAOタイプの動作
エッジオフセットは、
図12に示されるように、エッジ方向情報を考慮して、現在ピクセルpの分類のために4つの1次元3ピクセルパターンを使用する。左から右へ、0度、90度、135度、及び45度がある。
【0101】
図12は、EOでのピクセル分類のための4つの1次元3ピクセルパターンの例を示す。
【0102】
各CTBは、表2-7に従って、5つのカテゴリのうちの1つに分類される。
【表6】
【0103】
バンドオフセット(BO)は、1つのCTB領域内の全てのピクセルを、ピクセル値の5つの最上位ビットをバンドインデックスとして使用することによって、32個の一様なバンドに分類する。すなわち、ピクセル強度範囲は、ゼロから最大強度値(例えば、8ビットピクセルについては255)まで32個の等しいセグメントに分ける。4つの隣接バンドはグループにまとめられ、各グループは、
図13に示されるようにその最も左側の位置によって示される。エンコーダは、各バンドのオフセットを補償することによって歪みを最大に低減したグループを取得するよう全ての位置を探索する。
【0104】
図13は、4つのバンドがグループにまとめられ、その開始バンド位置によって表現される例を示す。
【0105】
2.10 インター-イントラ複合予測(CIIP)
VTM5では、CUがマージモードで符号化される場合に、CUが少なくとも64個のルーマサンプルを含むならば(つまり、CU幅×CU高さは64以上である)、かつ、CU幅及びCU高さの両方が128個のルーマサンプルに満たないならば、インター/イントラ複合予測(CIIP)モードが現在CUに適用されるかどうかを示すために、追加のフラグが通知される。その名が示すとおり、CIIP予測は、インター予測信号をイントラ予測信号と組み合わせる。CIIPモードでのインター予測信号P
interは、通常のマージモードに適用されるの同じインター予測プロセスを用いて導出され、イントラ予測信号P
intraは、プレーナーモードによる通常のイントラ予測プロセスに従って導出される。次いで、イントラ予測信号及びインター予測信号は、加重平均を用いて結合される。このとき、重み値は、次のように、上隣接ブロック及び左隣接ブロック(
図14に図示あり)のコーディングモードに応じて計算される:
・上隣接ブロックが利用可能であり、イントラコーディングされている場合に、isIntraTopを1にセットし、そうでない場合には、isIntraTopを0にセットする。
・左隣接ブロックが利用可能であり、イントラコーディングされている場合に、isIntraLeftを1にセットし、そうでない場合には、isIntraLeftを0にセットする。
・(isIntraLeft+isIntraTop)が2に等しい場合には、wtは3にセットされる。
・そうではなく、(isIntraLeft+isIntraTop)が1に等しい場合には、wtは2にセットされる。
・上記以外の場合に、wtを1にセットする。
【0106】
CIIP予測は、次のように形成される:
【数13】
【0107】
図14は、CIIP重み導出で使用される上及び左隣接ブロックを示す。
【0108】
2.11 クロマスケーリング付きルーママッピング(LMCS)
VTM5では、LMCS(luma mapping with chroma scaling)と呼ばれるコーディングルールが、ループフィルタ前に新しい処理ブロックとして加えられる。LMCSは、2つの主なコンポーネント:1)適応区分線形モデルに基づいたルーマ成分のインループマッピング、2)クロマ成分のためのルーマ依存クロマ残差スケーリングの適用を有する。
図15は、デコーダ始点からのLMCSアーキテクチャを示す。
図15のブロックには、逆量子化、逆変換、ルーマイントラ予測、及びルーマ残差とともにルーマ予測の追加が含まれ、処理はマッピング領域で適用される。
図15中の影無しブロックは、処理が元の(すなわち、非マッピング)領域で適用される場所を示し、これらには、デブロッキング、ALF、及びSAOなどのループフィルタ、動き補償付き予測、クロマイントラ予測、クロマ残差とともにクロマ予測の追加、並びに参照ピクチャとしても復号されたピクチャの格納が含まれる。
図15は、ルーマ信号の順方向及び逆方向マッピングと、ルーマ依存クロマスケーリングプロセスとを含む新しいLMCS機能ブロックを示す。VVCにおける他のほとんどのツールと同様に、LMCSは、SPSフラグを用いてシーケンスレベルで有効/無効にされ得る。
【0109】
図15は、クロマスケーリングアーキテクチャによるルーママッピングの例を示す。
【0110】
2.12 二分木パーティショニング
現在のVVC設計では、Iスライスについて、各CTUは、暗黙的な四分木分割を用いて、64×64個のルーマサンプルを有するコーディングユニットに分けられ得る。これらのコーディングユニットは、ルーマ及びクロマについての2つの別個のcoding_treeシンタック構造の根である。
【0111】
イントラピクチャにおける二分木は、ルーマコーディングツリーとは異なるパーティショニングをクロマコーディングツリーで適用することを可能にするので、二分木は、より長いコーディングパイプラインを導入し、クロマツリーでのQTBT MinQTSizeC値範囲並びにMinBtSizeY及びMinTTSizeYは、2×2、4×2、及び2×4などの小さいクロマブロックを可能にする。それは、実際のデコーダ設計で困難性をもたらす。更に、CCLM、プレーナー、及び角度モードなどのいくつかの予測モードは乗算を必要とする。上記の問題を多少なりとも解決するために、小さいクロマブロックサイズ(2×2/2×4/4×2)は、パーティショニング制限として二分木において制限される。
【0112】
2.13 JVET-O0050における最小クロマイントラ予測ユニット(SCIPU)
小さいクロマサイズは、ハードウェア実装にとってフレンドリではない。二分木の場合に、小さすぎるサイズのクロマブロックは許されない。しかし、一分木(singletree)の場合に、VVC草案5は、依然として、2×2、2×4、4×2クロマブロックを許す。クロマブロックのサイズを制限するために、単一コーディングツリーでは、クロマブロックサイズがTHクロマサンプルよりも大きいか又はそれと等しく、かつ、4THルーマサンプルよりも小さい少なくとも1つの子ルーマブロックを有しているコーディングツリーノードとして、SCIPUがJVET-O0050で定義されている。なお、THは、この寄稿では16にセットされる。各SCIPUで、全てのCBはインターであるか、あるいは、全てのCBは非インターである、つまり、イントラ又はIBCのどちらかであることが必要とされる。非インターSCIPUの場合には、更に、非インターSCIPUのクロマがこれ以上分割されるべきではないことが必要とされ、また、SCIPUのルーマは、更に分割されることを許される。このようにして、最小クロマイントラCBサイズは、16個のクロマサンプルであり、2×2、2×4、及び4×2クロマCBは削除される。更に,クロマスケーリングは、非インターSCIPUの場合に適用されない。
【0113】
2つのSCIPUの例が
図16に示される。
図16(a)では、8×4クロマサンプルの1つのクロマCBと、3つのルーマCB(4×8、8×8、4×8ルーマCB)とが1つのSCIPUを形成する。これは、8×4クロマサンプルから分割された三分木(TT)が、16個のクロマサンプルよりも小さいクロマCBをもたらすからである。
図16(b)では、4×4クロマサンプル(8×4クロマサンプルの左側)の1つのクロマCBと、3つのルーマCB(8×4、4×4、4×4ルーマCB)とが1つのSCIPUを形成し、4×4サンプル(8×4クロマサンプルの右側)の1つのクロマCBと、2つのルーマCB(8×4、8×4ルーマCB)とが1つのSCIPUを形成する。これは、4×4クロマサンプルから分割された三分木(TT)が、16個のクロマサンプルよりも小さいクロマCBをもたらすからである。
【0114】
【0115】
現在スライスがIスライスであるか、又は現在のSCIPUが、更に1回分割された後にその中に4x4ルーマパーティションを有する場合に、SCIPUのタイプは非インターであると推測される(VVCでは、インター4×4が許可されないため)。それ以外の場合には、SCIPUのタイプ(インター又は非インター)は、SCIPU内のCUをパースする前に1つのシグナルフラグによって示される。
【0116】
2.14 VVC草案6における小さいクロマブロックの制約
VVC草案6(JVET-O2001-vE.docx)では、小さいクロマブロックに対する制約が、次のように実装される(関連する部分は、太字イタリック体でマークされる)。
【表7】
【0117】
3.課題
(1)現在、IBCはMODE_TYPE_INTRAと見なされているので、小さいクロマブロックは許可されず、不必要なコーディング効率損失が生じている。
(2)現在、パレットはMODE_TYPE_INTRAと見なされているので、小さいクロマブロックは許可されず、不必要なコーディング効率損失が生じている。
(3)現在、小さいクロマブロックの制約は、色サブサンプリングフォーマットを考慮していない。
(4)現在、小さいブロックに対する同じパーティション及び予測モード制約が全てのクロマフォーマットに適用されている。しかし、4:2:0及び4:2:2クロマフォーマットでは、小さいブロックに対する異なった制約メカニズムを設計することが望ましいことがある。
(5)現在、パレットモードフラグ通知は、modeTypeに依存しているが、これは、パレットが小さいブロックの制約を適用しない可能性があるということで望ましくない。
(6)現在、IBCモードフラグは、P/Bスライスについて、cu_skip_fragが1に等しいが、MODE_TYPEがMODE_TYPE_INTRAに等しい場合に、0であると推測されているが、これは、シンタックスパーシングでは不正である。
(7)現在、非4×4ルーマIBCモードは、SCIPUルーマブロックについて許可されていないが、これは望ましくないことがあり、コーディング効率損失を引き起こす可能性がある。
(8)2×Hクロマブロックが依然として許可されているが、これはハードウェア実装にとってフレンドリではない。
(9)CIIPは、MODE_INTERと見なされる一方で、イントラ予測を使用するが、これは、いくつかの場合に制約を破る。
【0118】
4.技術的解決法及び実施形態の例
以下に挙げられているものは、例と見なされるべきである。これらの技術は、狭い意味で解釈されるべきではない。更に、これらの技術は、如何様にも組み合わされ得る。
【0119】
本文書中、「M×Nコーディングツリーノード」は、M×Nブロックを示し、M及びNは、夫々、ルーマサンプルの幅及び高さであり、これは、例えば、QT/BT/TTなどによって、更にパーティション化されてもよい。例えば、ブロックはQTノード、又はBTノード、又はTTのーどであってよい。コーディングツリーノードは、コーディングユニット(例えば、一分木については3つの色成分、二分木クロマコーディングについては2つのクロマ色成分、及び二分木ルーマコーディングについてはただ1つのルーマ成分を有する)、又はルーマコーディングブロック、又はクロマコーディングブロックであってもよい。「小さいコーディングツリーノードユニット」は、ルーマサンプルでブロックサイズM×Nが32/64/128に等しいコーディングツリーノードを示し得る。
【0120】
特に述べられていない場合に、コーディングブロックの幅W及び高さは、ルーマサンプルで測定される。例えば、M×Nコーディングブロックは、M×Nルーマブロック、及び/又は2つの(M/subWidthC)×(N/SubHeightC)クロマブロックを意味し、SubWidthC及びSubHightCは、次のようにクロマフォーマットによって導出される。
【表8】
【0121】
1.小さいブロックにパーティション化すべきかどうか及び/又はどのようにすべきかは、カラーフォーマットに依存してもよい。
a.一例で、4:4:4カラーフォーマットについては、クロマブロックのサイズに対する制約は、ルーマブロックに対するそのような制約に従い得る。
b.一例で、4:2:2カラーフォーマットについては、クロマブロックのサイズに対する制約は、4:2:0カラーフォーマットに着いてのそのような制約に従い得る。
c.一例で、4:0:0及び/又は4:4:4クロマフォーマットについては、小さいブロックのパーティションに対する制約及び/又は予測モードは適用されなくてもよい。
d.一例で、小さいブロックのパーティションに対する制約及び/又は予測モードは、異なるクロマフォーマットについて異なるように適用されてもよい。
i.一例で、水平BT分割を使用したM×N(例えば、8×8)コーディングツリーノードについては、4:2:2クロマフォーマットで、水平BT分割は、クロマブロック及びルーマブロックの両方について許され得るが、4:2:0クロマフォーマットでは、水平BT分割は、ルーマブロックについては許されるが、クロマブロックについては許されなくてもよい。
ii.一例で、垂直BT分割を使用したM×N(例えば、16×4)コーディングツリーノードについては、4:2:2クロマフォーマットで、垂直BT分割は、クロマブロック及びルーマブロックの両方について許され得るが、4:2:0クロマフォーマットでは、垂直BTは、ルーマブロックについては許されるが、クロマブロックについては許されなくてもよい。
iii.一例で、水平TT分割を使用したM×N(例えば、8×16)コーディングツリーノードについては、4:2:2クロマフォーマットで、水平TT分割は、クロマブロック及びルーマブロックの両方について許され得るが、4:2:0クロマフォーマットでは、水平TT分割は、ルーマブロックについては許されるが、クロマブロックについては許されなくてもよい。
iv.一例で、垂直TT分割を使用したM×N(例えば、32×4)コーディングツリーノードについては、4:2:2クロマフォーマットで、垂直TT分割は、クロマブロック及びルーマブロックの両方について許され得るが、4:2:0クロマフォーマットでは、垂直TTは、ルーマブロックについては許されるが、クロマブロックについては許されなくてもよい。
v.一例で、4:0:0及び/又は4:4:4カラーフォーマットについては、小さいブロックの制約は適用されなくてもよい。
e.一例で、SCIPUを有効にすべきかどうかは、カラーフォーマットに依存する。
i.一例で、SCIPUは、4:2:0及び4:2:2カラーフォーマットに対して有効にされる。
ii.一例で、SCIPUは、4:0:0及び/又は4:4:4カラーフォーマットに対しては無効にされる。
【0122】
2.コーディングツリーノードの(サブ)モードのための予測モード(及び/又はmodeType)をどのように決定すべきかは、カラーフォーマットに依存してもよい。
a.一例で、次の条件の1つが真である場合に、このコーディングツリーノードによってパーティション化された(サブ)ブロックのmodeTypeは、4:2:2クロマフォーマットについてはMODE_TYPE_ALLに等しくなり、一方、4:2:0クロマフォーマットについては、modeTypeは、MODE_TYPE_INTRA又はMODE_TYPE_INTERのどちらかに等しくなる。
i.水平BT分割を使用したM×N(例えば、8×8)コーディングツリーノード
ii.垂直BT分割を使用したM×N(例えば、16×4)コーディングツリーノード
iii.水平TT分割を使用したM×N(例えば、8×16)コーディングツリーノード
iv.垂直TT分割を使用したM×N(例えば、32×4)コーディングツリーノード
【0123】
例えば、次の条件:i)水平BTを使用したルーマ8×8ブロック、ii)垂直BTを使用したルーマ16×4ブロック、iii)水平TTを使用したルーマ8×16ブロック、iv)垂直TTを使用したルーマ32×4ブロック、のうちの1つが真である場合に、modeTypeは、4:2:2についてはMODE_TYPE_ALLとしてセットされてもよく、一方、modeTypeは、4:2:0についてはMODE_TYPE_INTRA又はMODE_TYPE_INTERのどちらかでなければならない。
【0124】
よって、コーディングツリーノードにおいて3つの色成分を有するブロックについては、上記の条件の1つが真である場合に、4:2:0のブロックはMODE_TYPE_ALL(全てのコーディングモードが選択され得る)として分類されない。それは、MODE_TYPE_INTRAブロックはパレット、イントラ又はイントラブロックコピーを選択することができる)又はMODE_TYPE_INTER(インターモードしか選択され得ない)のどちらかである。
【0125】
3.ブロック幅がM(例えば、M=2)個のクロマサンプルに等しいクロマイントラ(及び/又はIBC)ブロックは許されなくてもよい。
a.一例で、2×N(例えば、N<=64)のクロマイントラブロックは、二分木で許可されなくてもよい。
i.一例で、treeTypeがDUAL_TREE_CHROMAに等しく、ブロック幅が4クロマサンプルに等しい場合に、垂直BT分割は許されなくてもよい。
ii.一例で、treeTypeがDUAL_TREE_CHROMAに等しく、ブロック幅が8クロマサンプルに等しい場合に、垂直TT分割は許されなくてもよい。
b.一例で、2×N(例えば、N<=64)のクロマイントラ(及び/又はIBC)ブロックは、一分木で許可されなくてもよい。
i.一例で、垂直BT分割を使用したM×N(例えば、M=8及びN<=64)コーディングツリーノードについては、次のプロセスの1つが適用され得る。
1.垂直BT分割は、4×N又は4×(N/2)クロマブロックについては許されないが、8×Nルーマブロックについては許され得る。
2.4×N又は4×(N/2)クロマブロックは、垂直BT分割でなくてもよく、それはMODE_INTRA又はMODE_IBCによってコーディングされ得る。
3.垂直BT分割は、8×Nルーマブロック及び4×N又は4×(N/2)クロマブロックの両方について許され得るが、ルーマブロック及びクロマブロックは両方とも、MODE_INTRAによってコーディングされない(例えば、MODE_INTER又はMODE_IBCによってコーディングされ得る)。
ii.一例で、垂直TT分割を使用したM×N(例えば、M=16及びN<=64)コーディングツリーノードについては、次のプロセスの1つが適用され得る。
1.垂直BT分割は、8×N又は8×(N/2)クロマブロックについては許されないが、16×Nルーマブロックについては許され得る。
2.8×N又は8×(N/2)クロマブロックは、垂直TT分割でなくてもよく、それはMODE_INTRA又はMODE_IBCによってコーディングされ得る。
3.垂直TT分割は、16×Nルーマブロック及び8×N又は8×(N/2)クロマブロックの両方について許され得るが、ルーマブロック及びクロマブロックは両方とも、MODE_INTRAによってコーディングされない(例えば、MODE_INTER又はMODE_IBCによってコーディングされ得る)。
【0126】
4.IBCモードは、ルーマ及び/又はクロマブロックについて、それが小さいブロックサイズであるかどうかにかかわらず許可されてもよい。
a.一例で、IBCモードは、たとえmodeTypeがMODE_TYPE_INTRAに等しいとしても、8×4/8×8/16×4及び4×N(例えば、N<=64)ルーマブロックを含むルーマブロックについて許され得る。
b.一例で、IBCモードは、たとえmodeTypeがMODE_TYPE_INTRAに等しいとしても、クロマブロックについて許され得る。
【0127】
5.IBC予測モードフラグの通知は、予測モードタイプ(例えば、MODE_TYPE_INTRA)に依存してもよい。
a.一例で、非SKIPブロック(例えば、スキップモードによってコーディングされないコーディングモード)のIBC予測モードフラグは、treeTypeがDUAL_TREE_CHROMAに等しくなく、かつ、modeTypeがMODE_TYPE_INTRAに等しい場合に、ビットストリームで明示的に通知され得る。
【0128】
6.IBC予測モードフラグは、CU SKIPフラグ及びモードタイプ(例えば、modeType)に応じて推測されてもよい。
a.一例で、現在ブロックがSKIPモードでコーディングされ(例えば、cu_skip_flagが1に等しく)、かつ、modeTypeがMODE_TYPE_INTRAに等しい場合に、IBC予測モードフラグ(例えば、pred_mode_ibc_flag)は、1に等しいと推測され得る。
【0129】
7.パレットモードフラグの明示的な通知は、modeTypeに依存しなくてもよい。
a.一例で、パレットモードフラグ(例えば、pred_mode_plt_flag)の通知は、スライスタイプ、ブロックサイズ、予測モードなどに依存してもよい。ただし、modeTypeが何であっても。
b.一例で、パレットモードフラグ(例えば。pred_mode_plt_flag)は、modeTypeがMODE_TYPE_INTRA又はMODE_TYPE_INTRAに等しい場合に、0であると推測される。
【0130】
8.IBCモードは、modeTypeがMODE_TYPE_INTERに等しい場合に使用することを許可されてもよい。
a.一例で、クロマIBCは、modeTypeがMODE_TYPE_INTRAに等しい場合に許可されなくてもよい。
b.一例で、IBCモードは、modeTypeがMODE_TYPE_INTRA又はMODE_TYPE_INTERに等しい場合に使用することを許可され得る。
c.一例で、IBCモードは、modeTypeが何であろうとも使用することを許可され得る。
d.一例で、1つのSCIPU内で、IBC及びインターモードは両方とも許可され得る。
e.一例で、IBCクロマブロックのサイズは常に、対応するルーマブロックのサイズに対応し得る。
f.一例で、modeTypeがMODE_TYPE_INTERに等しく、かつ、コーディングユニットサイズがルーマで4×4である場合に、pred_mode_ibc_flagの通知はスキップされてもよく、pred_mode_ibc_flagは、1に等しいと推測され得る。
【0131】
9.パレットモードは、modeTypeがMODE_TYPE_INTERである場合に使用することを許可されてもよい。
a.一例で、クロマパレットは、modeTypeがMODE_TYPE_INTRAである場合に許可されなくてもよい。
b.一例で、パレットモードは、modeTypeがMODE_TYPE_INTRA又はMODE_TYPE_INTERに等しい場合に使用することを許可され得る。
c.一例で、パレットモードは、modeTypeが何であろうとも使用することを許可され得る。
d.一例で、1つのSCIPU内で、パレット及びインターモードは両方とも許可され得る。
e.一例で、1つのSCIPU内で、パレット、IBC及びインターモードは全て許可され得る。
f.一例で、パレットクロマブロックのサイズは常に、対応するルーマブロックのサイズに対応する。
g.一例で、modeTypeがMODE_TYPE_INTERに等しく、かつ、コーディングユニットサイズがルーマで4×4である場合に、pred_mode_plt_flagの通知はスキップされてもよく、pred_mode_plt_flagは、1に等しいと推測され得る。
h.一例で、modeTypeがMODE_TYPE_INTRAに等しく、かつ、コーディングユニットサイズがルーマで4×4である場合に、1つのメッセージは、現在の予測モードがIBC又はパレットであるかどうかを示すために送信されてもよい。
【0132】
10.幅がM(例えば、M=2)に等しくかつ高さがN(例えば、N=2)に等しい小さいクロマブロックについては、許可されているイントラ予測モードは、大きいクロマブロックについて許可されているものとは異なるように制限されてもよい。
a.一例で、利用可能なクロマイントラ予測モードの中のイントラ予測モードのサブセットのみが使用され得る。
b.一例で、INTRA_DCモードのみが使用され得る。
c.一例で、INTRA_PLANARモードのみが使用され得る。
d.一例で、INTRA_ANGULAR18モードのみが使用され得る。
e.一例で、INTRA_ANGULAR50モードのみが使用され得る。
f.一例で、CCLMモードは許可されなくてもよい。
【0133】
11.幅がM(例えば、M=2)に等しくかつ高さがN(例えば、N=2)に等しい小さいクロマブロックについては、変換タイプは、大きいクロマブロックについて許可されているものとは異なるように制限されてもよい。
a.一例で、変換スキップのみが使用され得る。
b.一例で、1次元変換のみが使用され得る。
c.一例で、複数のタイプの変換をサポートするコーディングツールは許可されない。
i.代替的に、複数のタイプの変換をサポートするコーディングツールの通知は省略される。
【0134】
12.CIIPは、MODE_TYPE_INTRAと見なされてもよい。
a.一例で、CIIPモードは、二分木パーティショニングが使用される場合に許可され得る。
i.一例で、CIIPモードは、CUタイプがDUAL_TREE_CHROMAである場合に許可され得る。
b.代替的に、CIIPは、MODE_TYPE_INTERと見なされてもよい。
i.一例で、クロマブロック幅がM(例えば、M=2)に等しい場合に、CIIPモードは許可されなくてもよい。
ii.一例で、クロマブロック幅がM(例えば、M=2)に等しい場合に、CIIPでのクロマのためのイントラ予測モードのサブセットは、単純なイントラ予測モードに制限され得る。
1.一例で、INTRA_DCは、クロマブロック幅がM(例えば、M=2)に等しい場合に、クロマイントラ予測のために使用されてもよい。
2.一例で、INTRA_ANGULAR18は、クロマブロック幅がM(例えば、M=2)に等しい場合に、クロマイントラ予測のために使用されてもよい。
3.一例で、INTRA_ANGULAR50は、クロマブロック幅がM(例えば、M=2)に等しい場合に、クロマイントラ予測のために使用されてもよい。
iii.一例で、CIIPでのクロマのためのイントラ予測モードは、単純なイントラ予測モードに制限され得る。
1.一例で、INTRA_DCは、クロマイントラ予測のために使用され得る。
2.一例で、INTRA_ANGULAR18モードは、クロマイントラ予測のために使用され得る。
3.一例で、INTRA_ANGULAR50モードは、クロマイントラ予測のために使用され得る。
【0135】
13.上記のビュレットについては、変数M及び/又はNは、予め定義されるか、又は通知されてもよい。
a.一例で、M及び/又はNは、カラーフォーマット(例えば、4:2:0、4:2:2、4:4:4)に更に依存してもよい。
【0136】
5.実施形態、
新たに加えられた部分は、太字イタリック体で強調表示されており、VVC作業草案から削除された部分は、二重括弧でマークされている(例えば、[[a]]は、文字“a”の削除を表す)。変更は、最新のVVC作業草案(JVET=O2001-v11)に基づいている。
【0137】
5.1 例となる実施形態#1
以下の実施形態は、小さいブロックのパーティションに対する制約及び予測モードが4:2:0及び4:4:4クロマフォーマットにのみ適用される(4:0:0及び4;4;4クロマフォーマットには適用されない)ことに関する。
【表9】
【0138】
5.2 例となる実施形態#2
以下の実施形態は、パレットモードフラグの通知がmodeTypeに依存しないことに関する。
【表10】
【0139】
5.3 例となる実施形態#3
以下の実施形態は、IBC予測モードフラグがCU SKIPフラグ及びmodeTypeに応じて推測されることに関する。
【表11】
【0140】
5.4 例となる実施形態#4
以下の実施形態は、IBC予測モードフラグの通知がMODE_TYPE_INTRAに依存し、及び/又はIBCモードがルーマブロックについて、それが小さいブロックサイズであるかどうかにかかわらず許可されることに関する。
【表12】
【0141】
5.5 例となる実施形態#5
以下の実施形態は、4:2:0及び4:2:2カラーフォーマットについて異なるイントラブロック制約を適用することに関する。
【表13】
【0142】
5.6 例となる実施形態#6
以下の実施形態は、一分木で2×Nクロマイントラブロックを許可しないことに関する。
【表14】
【0143】
5.7 例となる実施形態#7
以下の実施形態は、二分木で2×Nクロマイントラブロックを許可しないことに関する。
【表15】
【0144】
5.8 例となる実施形態#8
以下の実施形態は、SCIPUクロマブロックに対してMODE_IBCを有効にすることに関する。
【表16】
【0145】
図17Aは、ビデオ処理装置1700のブロック図である。装置1700は、ここで記載されている方法の1つ以上を実装するために使用され得る。装置1700は、スマートフォン、タブレット、コンピュータ、モノのインターネット(IoT)レシーバ、などで具現化されてもよい。装置1700は、1つ以上のプロセッサ1702,1つ以上のメモリ1704、及びビデオ処理ハードウェア1706を含み得る。プロセッサ1702は、本明細書で記載される1つ以上の方法を実装するよう構成され得る。メモリ(複数のメモリ)1704は、本明細書で記載される方法及び技術を実装するために使用されるデータ及びコードを記憶するために使用され得る。ビデオ処理ハードウェア1706は、ハードウェア回路で、本明細書で記載されるいくつかの技術を実装するために使用され得る。いくつかの実施形態において、ビデオ処理ハードウェア1706は、プロセッサ1702(例えば、グラフィクスコプロセッサ)内に少なくとも部分的に又は完全に含まれてもよい。
【0146】
図17Bは、開示されている技術が実装され得るビデオ処理システムのブロック図の他の例である。
図17Bは、ここで開示されている様々な技術が実装され得る、例となるビデオ処理システム1710を示すブロック図である。様々な実施は、システム1710のコンポーネントの一部又は全部を含んでもよい。システム1710は、ビデオコンテンツを受ける入力部1712を含み得る。ビデオコンテンツは、生の又は圧縮されていないフォーマット、例えば、8又は10ビットのマルチコンポーネントピクセル値で受け取られてもよく、あるいは、圧縮された又はエンコードされたフォーマットであってもよい。入力部1712は、ネットワークインターフェース、ペリフェラルバスインターバス、又はストレージインターフェースに相当してもよい。ネットワークインターフェースの例には、Ethernet(登録商標)、受動光ネットワーク(PON)などのような有線インターフェース、及びWi-Fi又はセルラーネットワークなどの無線インターフェースが含まれる。
【0147】
システム1710は、本明細書で記載されている様々なコーディング又は符号化方法を実装し得るコーディングコンポーネント1714を含んでもよい。コーディングコンポーネント1714は、ビデオのコーディングされた表現を生成するよう、入力部1712からコーディングコンポーネント1714の出力部へのビデオの平均ビットレートを低減し得る。コーディング技術は、従って、ビデオ圧縮又はビデオトランスコーディング技術と時々呼ばれる。コーディングコンポーネント1714の出力は、コンポーネント1716によって表されるように、保存されても、あるいは、接続された通信を介して伝送されてもよい。入力部1712で受け取られたビデオの保存又は通信されたビットストリーム(又はコーディングされた)表現は、ピクセル値又は表示インターフェース1720へ送られる表示可能なビデオを生成するコンポーネント1718によって使用されてもよい。ユーザが見ることができるビデオをビットストリーム表現から生成するプロセスは、ビデオ圧縮解除と時々呼ばれる。更に、特定のビデオ処理動作が「コーディング」動作又はツールと呼ばれる一方で、そのようなコーディングツール又は動作はエンコーダで使用され、コーディングの結果を入れ替える対応する復号化ツール又は動作は、デコーダによって実行されることになることが理解されるだろう。
【0148】
ペリフェラルバスインターフェース又は表示インターフェースの例には、ユニバーサルシリアルバス(USB)又は高精細マルチメディアインターフェース(HDMI(登録商標))又はDisplayport(登録商標)などが含まれ得る。ストレージインターフェースの例には、SATA(Serial Advanced Technology Attachment)、PCI、IDEインターフェース、などがある。本明細書で説明されている技術は、携帯電話機、ラップトップ、スマートフォン、又はデジタルデータ処理及び/又はビデオ表示を実行する能力がある他のデバイスなどの様々な電子デバイスで具現化されてもよい。
【0149】
図18は、ビデオを処理する方法1800のフローチャートである。方法1800は、ビデオのビデオ領域とそのビデオ領域の符号化表現との間の変換のために、ビデオ領域のカラーフォーマット及びクロマブロックサイズの間の関係を定義するシンタックスルールに従って符号化表現をパースするステップ(1802)と、シンタックスルールに従ってパーシングを実行することによって変換を実行するステップ(1804)とを含む。
【0150】
図21Aは、ビデオを処理する方法2110のフローチャートである。方法2110は、ステップ2112で、ルールに従って、ビデオのカラーフォーマットに基づき、ビデオのクロマビデオ領域を1つ以上のクロマブロックにパーティション化するパーティショニングスキームを決定することを含む。方法2110は更に、ステップ2114で、パーティショニングスキームに従って、ビデオとビデオの符号化表現との間の変換を実行することを含む。
【0151】
図21Bは、ビデオを処理する方法2120のフローチャートである。方法2120は、ステップ2122で、ビデオのカラーフォーマットに基づき、ビデオのコーディングツリーノードのサブブロックのための予測モード又は予測タイプを決定することを含む。方法2120は、決定に基づき、ビデオとビデオの符号化表現との間の変換を実行することを更に含む。いくつかの実施で、コーディングツリーノードは、符号化表現でのコーディングのためにサブブロックにパーティション化される。
【0152】
図22Aは、ビデオを処理する方法2210のフローチャートである。方法2210は、ステップ2212で、ビデオとそのビデオの符号化表現との間の変換を実行することを含む。いくつかの実施で、変換は、ルールに従って、1つ以上のルーマブロック及び1つ以上のクロマブロックを有する1つ以上のビデオ領域を有するビデオと、そのビデオの符号化表現との間で実行され、ルールは、サイズM×Nを有している1つ以上のクロマブロックの中のクロマブロックが、イントラモード又はイントラブロックコピーモードを用いて符号化表現で表現されることを許可されないことを定め、M及びNは、夫々、クロマブロックの幅及び高さを示す整数であり、イントラモードは、前に符号化又は再構成されたビデオブロックに基づきクロマブロックを符号化することを含み、イントラブロックコピーモードは、ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いてクロマブロックを符号化することを含む。
【0153】
いくつかの実施で、変換は、ビデオのクロマブロックとビデオの符号化表現との間で実行され、クロマブロックは、サイズルールに従ってイントラコーディングモードを用いて符号化表現で表され、サイズルールは、クロマブロックの幅がMに等しいか又はクロマブロックの高さがNに等しい場合には、イントラコーディングモードがイントラコーディングモードタイプの第1セットからであり、そうではない場合には、イントラコーディングモードがイントラコーディングモードタイプの第2セットからであることを定め、M及びNは整数である。
【0154】
いくつかの実施で、変換は、ビデオのクロマブロックとビデオの符号化表現との間で実行され、クロマブロックは、ルールに従って変換タイプを用いて符号化表現で表され、ルールは、クロマブロックの幅がMに等しいか又はクロマブロックの高さがNに等しい場合には、変換タイプが変換タイプの第1セットからであり、そうではない場合には、変換タイプが変換タイプの第2セットからであることを定め、M及びNは整数である。
【0155】
いくつかの実施で、変換は、ルールに従って、1つ以上のルーマブロック及び1つ以上のクロマブロックを有するビデオ領域を有するビデオと、ビデオの符号化表現との間で実行され、ルールは、M及びNの全ての値について、イントラブロックコピー(IBC)モードの使用が、ブロックサイズM×Nを有している1つ以上のルーマブロック及び1つ以上のクロマブロックに対して利用可能であることを定め、M及びNは整数であり、IBCモードを用いて、ビデオブロックは、そのビデオブロックを含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて符号化される。
【0156】
いくつかの実施で、変換は、ビデオのビデオブロックとそのビデオブロックの符号化表現との間で実行され、符号化表現はフォーマットルールに従い、フォーマットルールは、ビデオブロックのモードタイプに基づいた、符号化表現でのインターブロックコピー(IBC)モードの使用を示すシンタックス要素の選択的包含を定め、IBCモードは、ビデオブロックを含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いてビデオブロックを符号化することを含む。
【0157】
いくつかの実施で、変換は、ビデオのビデオブロックとそのビデオブロックの符号化表現との間で実行され、符号化表現はフォーマットルールに従い、フォーマットルールは、パレットモードの使用を示すシンタックス要素がビデオブロックのモードタイプにかかわらず符号化表現に含まれることを定め、パレットモードは、代表サンプル値のパレットを用いてビデオブロックを符号化することを含む。
【0158】
図22Bは、ビデオを処理する方法2220のフローチャートである。方法2220は、ステップ2222で、ビデオのビデオ領域とビデオの符号化表現との間の変換のために、ルールに従って、インター-イントラ複合予測(CIIP)モードをイントラモード又はインターモードとして使用すると決定することを含む。方法2310は、ステップ2314で、決定に基づき変換を実行することを更に含む。CIIPモードは、加重係数を用いてイントラ予測信号とインター予測信号とを結合することを含む。
【0159】
図23Aは、ビデオを処理する方法2310のフローチャートである。方法2310は、ステップ2312で、ビデオのビデオ領域とビデオの符号化表現との間の変換のために、ルールに基づき、インターブロックコピー(IBC)モードの使用がビデオ領域に許可されることを決定することを含む。方法2310は、ステップ2314で、決定に基づき変換を実行することを更に含む。IBCモードは、ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いてビデオ領域を符号化することを含む。
【0160】
図23Bは、ビデオを処理する方法2320のフローチャートである。方法2320は、ステップ2322で、ビデオのビデオ領域とビデオの符号化表現との間の変換のために、ルールに基づき、パレットモードの使用がビデオ領域に許可されるかどうかを決定することを含む。方法2320は、ステップ2324で、決定に基づき変換を実行することを更に含む。いくつかの実施で、ルールは、ビデオ領域のコーディングモードタイプ又はビデオ領域のカラータイプに基づき、パレットモードは、代表サンプル値のパレットを用いてビデオ領域を符号化することを含む。
【0161】
開示されている技術のいくつかの実施形態は、ビデオ処理ツール又はモードを有効にするとの決定又は判定を行うことを含む。例において、ビデオ処理ツール又はモードが有効にされる場合に、エンコーダは、ビデオのブロックの処理でツール又はモードを使用又は実装するが、結果として得られるビットストリームを、ツール又はモードの利用に基づいて必ずしも変更し得ない。つまり、ビデオのブロックからビデオのビットストリーム表現への変換は、ビデオ処理ツール又はモードが決定又は判定に基づいて有効にされる場合にそれを使用する。他の例においては、ビデオ処理ツール又はモードが有効にされる場合に、デコーダは、ビットストリームがビデオ処理ツール又はモードに基づいて変更されていると知った上でビットストリームを処理する。つまり、ビデオのビットストリーム表現からビデオのブロックへの変換は、決定又は判定に基づいて有効にされたビデオ処理ツール又はモードを用いて実行される。
【0162】
開示されている技術のいくつかの実施形態は、ビデオ処理ツール又はモードを無効にするとの決定又は判定を行うことを含む。例において、ビデオ処理ツール又はモードが無効にされる場合に、エンコーダは、ビデオのブロックからビデオのビットストリーム表現への変換でツール又はモードを使用しない。他の例においては、ビデオ処理ツール又はモードが無効にされる場合に、デコーダは、決定又は判定に基づいて有効にされたビデオ処理ツール又はモードを用いてビットストリームが変更されていないと知った上でビットストリームを処理する。
【0163】
本明細書中、「ビデオ処理」という用語は、ビデオ符号化、ビデオ復号化、ビデオ圧縮又はビデオ圧縮解除を指し得る。例えば、ビデオ圧縮アルゴリズムは、ビデオのピクセル表現から、対応するビットストリーム表現への変換中に、又はその逆も同様に、適用されてもよい。現在のビデオブロックのビットストリーム表現は、例えば、シンタックスによって定義されるような、ビットストリーム内で同一位置にあるか又は異なった場所に広がっているかのどちらかであるビットに対応してもよい。例えば、マクロブロックは、変換及びコーディングされた誤差残余値に関して、更には、ビットストリーム内のヘッダ及び他のフィールドにおけるビットを用いて、符号化されてもよい。
【0164】
以下の箇条書きは、いくつかの実施形態及び技術について記載している。箇条書きの第1の組は、前のセクションで開示された技術のある特徴及び態様について記載している。
【0165】
1.ビデオ処理の方法であって、
ビデオのビデオ領域と該ビデオ領域の符号化表現との間の変換のために、前記ビデオ領域のカラーフォーマット及びクロマブロックサイズの間の関係を定義するシンタックスルールに従って、前記符号化表現をパースするステップと、
前記シンタックスルールに従ってパーシングを実行することによって前記変換を実行するステップと
を有する方法。
【0166】
2.箇条1に記載の方法であって、
前記カラーフォーマットは4:4:4であり、
前記シンタックスルールは、クロマブロックがルーマブロックと同じサイズ制約に従うことを定める、
方法。
【0167】
3.箇条1に記載の方法であって、
前記カラーフォーマットは4:2:2であり、
前記シンタックスルールは、クロマブロックが4:2:0カラーフォーマットについてと同じサイズ制約に従うことを定める、
方法。
【0168】
4.箇条1乃至3のうちいずれかに記載の方法であって、
前記シンタックスルールは、予測モード及び小ブロックパーティションがクロマフォーマットに依存して使用されることを定める、
方法。
【0169】
5.箇条1に記載の方法であって、
前記シンタックスルールは、最小許容サイズが前記ビデオ領域の前記カラーフォーマットに基づき前記ビデオ領域の前記変換のために有効にされることを定める、
方法。
【0170】
以下の箇条書きは、前のセクションの項目2で記載されている更なる技術とともに実装され得る。
【0171】
6.ビデオ処理の方法であって、
ビデオの特性及び前記ビデオのクロマフォーマットに基づき、前記ビデオのコーディングツリーノードのコーディングモードを決定するステップと、
前記決定されたコーディングモードを用いて、前記ビデオの符号化表現と前記コーディングツリーノードのビデオブロックとの間の変換を実行するステップと
を有する方法。
【0172】
7.箇条6に記載の方法であって、
前記特性が:
i.前記コーディングツリーノードが水平二分木分割を用いたM×Nコーディングツリーノードであること、
ii.前記コーディングツリーノードが垂直二分木分割を用いたM×Nコーディングツリーノードであること、
iii.前記コーディングツリーノードが水平三分木分割を用いたM×Nコーディングツリーノードであること、又は
iv.前記コーディングツリーノードが垂直三分木分割を用いたM×Nコーディングツリーノードであること
のいずれかである場合に、前記コーディングモードは、前記クロマフォーマットが4:2:2である場合にMODE_TYPE_ALLであると、前記クロマフォーマットが4:2:0である場合にMODE_TYPE_INTRA又はMODE_TYPE_INTERであると決定される、
方法。
【0173】
8.箇条7に記載の方法であって、
M=8、又は16、又は32であり、
N=4、又は8、又は16である、
方法。
【0174】
以下の箇条書きは、前のセクションの項目3で記載されている更なる技術とともに実装され得る。
【0175】
9.ビデオ処理の方法であって、
ルールに基づいて、クロマブロックのあるサイズがビデオのビデオ領域で許されるかどうかを決定するステップと、
前記決定に基づき、前記ビデオ領域と該ビデオ領域の符号化表現との間の変換を実行するステップと
を有する方法。
【0176】
10.箇条9に記載の方法であって、
前記ルールは、2×Nのクロマブロックが、前記ビデオ領域が二分木パーティションを含むことにより許可されないことを定める、
方法。
【0177】
11.箇条9に記載の方法であって、
前記ルールは、2×Nのクロマブロックが、前記ビデオ領域が一分木パーティションを含むことにより許可されないことを定める、
方法。
【0178】
12.箇条10又は11に記載の方法であって、
N<=64である、
方法。
【0179】
以下の箇条書きは、前のセクションの項目4、8及び9で記載されている更なる技術とともに実装され得る。
【0180】
13.ビデオ処理の方法であって、
ビデオ条件に関してコーディングモードの使用を許すルールに基づき、コーディングモードがビデオ領域に対して許されることを決定するステップと、
前記決定に基づき、前記ビデオ領域内のピクセルの符号化表現と前記ビデオ領域のピクセルとの間の変換を実行するステップと
を有する方法。
【0181】
14.箇条13に記載の方法であって、
前記ビデオ条件はブロックサイズであり、
前記ルールは、小ブロックサイズのルーマブロックに対してイントラブロックコピーモードの使用を認める、
方法。
【0182】
15.箇条14に記載の方法であって、
前記小ブロックサイズは、8×8、8×8、16×4又は4×Nのルーマブロックサイズを含む、
方法。
【0183】
16.箇条13に記載の方法であって、
前記ルールは、コーディングのMODE_TYPE_INTERモードを使用する前記ビデオ領域の変換のためにイントラブロックコピーモードの使用を認める、
方法。
【0184】
17.箇条13に記載の方法であって、
前記ルールは、コーディングのMODE_TYPE_INTERモードを使用する前記ビデオ領域の変換のためにパレットコーディングモードの使用を認める、
方法。
【0185】
以下の箇条書きは、前のセクションの項目5、6及び7で記載されている更なる技術とともに実装され得る。
【0186】
18.ビデオ処理の方法であって、
ビデオのビデオブロックと該ビデオブロックの符号化表現との間の変換を、ビデオコーディングモードを用いて実行するステップを有し、
前記コーディングモードを通知するシンタックス要素は、前記ルールに基づき前記符号化表現に選択的に含まれる、
方法。
【0187】
19.箇条18に記載の方法であって、
前記ビデオコーディングモードは、イントラブロックコーディングモードであり、
前記ルールは、前記符号化表現における前記シンタックス要素の包含を制御するために前記ビデオコーディングモードのタイプを使用することを定める、
方法。
【0188】
20.箇条19に記載の方法であって、
前記ルールは、非SKIPブロックを明示的に通知することを定める、
方法。
【0189】
21.箇条18に記載の方法であって、
前記ルールは、前記ビデオブロックのモードタイプ及びスキップフラグに基づきイントラブロックコピーフラグを暗黙的に通知することを定める、
方法。
【0190】
22.箇条18に記載の方法であって、
前記ビデオコーディングモードは、パレットコーディングモードであり、
前記ルールは、前記ビデオブロックのモードタイプに基づきパレットコーディングインジケータを選択的に含めることを定める、
方法。
【0191】
以下の箇条書きは、前のセクションの項目11で記載されている更なる技術とともに実装され得る。
【0192】
23.ビデオ処理の方法であって、
クロマブロックが閾サイズに満たないサイズを有していることにより、前記クロマブロックと該クロマブロックの符号化表現との間の変換中に使用される変換タイプが、対応するルーマブロック変換に使用される変換タイプとは異なることを決定するステップと、
前記決定に基づき前記変換を実行するステップと
を有する方法。
【0193】
24.箇条23に記載の方法であって、
前記閾サイズはM×Nであり、
Mは2であり、あるいは、Nは2である、
方法。
【0194】
以下の箇条書きは、前のセクションの項目12で記載されている更なる技術とともに実装され得る。
【0195】
25.箇条1乃至24のうちいずれかに記載の方法であって、
前記変換は、インター-イントラ複合予測モードをMODE_TYPE_INTRAモードとして使用する、
方法。
【0196】
26.箇条18乃至22のうちいずれかに記載の方法であって、
前記変換は、インター-イントラ複合予測モードをMODE_TYPE_INTERとして使用する、
方法。
【0197】
例えば、CIIPをMODE_TYPE_INTERと見なす場合に、前のセクションで項目5+6+7で記載されている方法が適用され得る。あるいは、項目5+6+7で記載されている方法が適用される場合に、CIIPは、MODE_TYPE_INTERと見なされ得る。
【0198】
27.箇条1乃至26のうちいずれかに記載の方法であって、
前記変換は、前記ビデオを前記符号化表現に符号化することを有する、
方法。
【0199】
28.箇条1乃至26のうちいずれかに記載の方法であって、
前記変換は、前記ビデオのピクセル値を生成するよう前記符号化表現を復号することを有する、
方法。
【0200】
29.箇条1乃至28のうちの1つ以上に記載されている方法を実装するよう構成されたプロセッサを有するビデオ復号化装置。
【0201】
30.箇条1乃至28のうちの1つ以上に記載されている方法を実装するよう構成されたプロセッサを有するビデオ符号化装置。
【0202】
31.コンピュータコードを記憶しているコンピュータプログラム製品であって、
前記コードは、プロセッサによって実行される場合に、該プロセッサに、箇条1乃至28のうちいずれかに記載の方法を実装させる、
コンピュータプログラム製品。
【0203】
32.本明細書で記載されている方法、装置、又はシステム。
【0204】
箇条書きの第2の組は、前のセクション、例えば、例となる実施1、2及び13で開示されている技術のある特徴及び態様について記載している。
【0205】
1.ビデオ処理の方法であって、
ルールに従って、ビデオのカラーフォーマットに基づき、前記ビデオのクロマビデオ領域を1つ以上のクロマブロックにパーティション化するパーティショニングスキームを決定するステップと、
前記パーティショニングスキームに従って、前記ビデオと前記ビデオの符号化表現との間の変換を実行するステップと
を有する方法。
【0206】
2.箇条1に記載の方法であって、
前記ルールは、同じコーディングツリーノードで表されている3つの色成分を有するインタースライス又はイントラスライスを指定する、
方法。
【0207】
3.箇条1又は2に記載の方法であって、
前記ルールは、4:4:4カラーフォーマットについてクロマブロック及びルーマブロックに同じパーティショニングスキームを使用することを定める、
方法。
【0208】
4.箇条1又は2に記載の方法であって、
前記ルールは、4:2:0カラーフォーマット及び4:2:2カラーフォーマットについて同じパーティショニング制約を使用することを定める、
方法。
【0209】
5.箇条1又は2に記載の方法であって、
前記ルールは、4:0:0カラーフォーマット又は4:4:4カラーフォーマットについて予測モードに前記パーティショニングスキーム及び/又は制約を適用しないことを定める、
方法。
【0210】
6.箇条1又は2に記載の方法であって、
前記ルールは、前記ビデオの前記カラーフォーマットに基づき適用される前記パーティショニングスキーム及び/又は予測モードを指定する、
方法。
【0211】
7.箇条6に記載の方法であって、
水平BT(二分木)分割又は推定TT(三分木)分割を伴ったM×Nコーディングツリーノードについて、4:2:2カラーフォーマットにおいて、前記水平BT分割又は前記水平TT分割は、クロマブロック及びルーマブロックの両方に許可される、
方法。
【0212】
8.箇条6に記載の方法であって、
水平BT(二分木)分割又は水平TT(三分木)分割を伴ったM×Nコーディングツリーノードについて、4:2:0カラーフォーマットにおいて、前記水平BT分割又は前記水平TT分割は、ルーマブロックには許可されるが、クロマブロックには許可されない、
方法。
【0213】
9.箇条6に記載の方法であって、
垂直BT(二分木)分割又は垂直TT(三分木)分割を伴ったM×Nコーディングツリーノードについて、4:2:2カラーフォーマットにおいて、前記垂直BT分割又は前記垂直TT分割は、クロマブロック及びルーマブロックの両方に許可される、
方法。
【0214】
10.箇条6に記載の方法であって、
垂直BT(二分木)分割又は垂直TT(三分木)分割を伴ったM×Nコーディングツリーノードについて、4:2:0カラーフォーマットにおいて、前記垂直BT分割又は前記垂直TT分割は、ルーマブロックには許可されるが、クロマブロックには許可されない、
方法。
【0215】
11.箇条7乃至10のうちいずれかに記載の方法であって、
M及び/又はNは、予め定義されるか、又は通知される、
方法。
【0216】
12.箇条11に記載の方法であって、
M及び/又はNは、前記ビデオ領域の前記カラーフォーマットに依存する、
方法。
【0217】
13.箇条6に記載の方法であって、
前記ルールは、4:0:0カラーフォーマット及び/又は4:4:4カラーフォーマットに前記パーティショニングスキームを適用しないと定める、
方法。
【0218】
14.箇条1に記載の方法であって、
前記ルールは、クロマブロックのサイズを制限するよう定義された最小クロマイントラ予測ユニット(SCIPU)が前記ビデオの前記カラーフォーマットに基づき前記変換のために有効にされることを定める、
方法。
【0219】
15.箇条14に記載の方法であって、
前記最小クロマイントラ予測ユニットは、4:2:0カラーフォーマット及び/又は4:2:2カラーフォーマットについて許可される、
方法。
【0220】
16.箇条14に記載の方法であって、
前記最小クロマイントラ予測ユニットは、4:0:0カラーフォーマット及び/又は4:4:4カラーフォーマットについては無効にされる、
方法。
【0221】
17.ビデオ処理の方法であって、
ビデオのカラーフォーマットに基づき、前記ビデオのコーディングツリーノードのサブブロックのための予測モード又は予測タイプを決定するステップと、
前記決定に基づき、前記ビデオと前記ビデオの符号化表現との間の変換を実行するステップと
を有し、
前記コーディングツリーノードは、前記符号化表現でのコーディングのためにサブブロックにパーティション化される、
方法。
【0222】
18.箇条17に記載の方法であって、
サブブロックの予測モードは、前記カラーフォーマットが4:2:2であることにより、インターコーディングモード、イントラモード、パレットモード、及びイントラブロックコピーモードの適用可能性を示すMODE_TYPE_ALLとして決定される、
方法。
【0223】
19.箇条17に記載の方法であって、
サブブロックの予測モードは、前記カラーフォーマットが4:2:0であることにより、i)インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTER、又はii)イントラモード、パレットモード、及びイントラブロックコピーモードの適用可能性を示すMODE_TYPE_INTRA、のどちらか一方であるよう決定される、
方法。
【0224】
20.箇条18又は19に記載の方法であって、
前記インターコーディングモードは、時間相関を用いて前記ビデオを表現又は再構成することを含み、
前記イントラモードは、前に処理されたビデオブロックに基づき前記ビデオを表現又は再構成することを含み、
前記パレットモードは、代表サンプル値のパレットを用いて前記ビデオを表現又は再構成することを含み、あるいは、
前記イントラブロックコピーモードは、ビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオを表現又は再構成することを含む、
方法。
【0225】
21.箇条18乃至20のうちいずれか1つに記載の方法であって、
前記コーディングツリーノードは、次の条件
i)前記コーディングツリーノードが、水平二分木分割を伴った8×8ルーマブロックに対応すること、
ii)前記コーディングツリーノードが、垂直二分木分割を伴った16×4ルーマブロックに対応すること、
iii)前記コーディングツリーノードが、水平三分木分割を伴った8×16ルーマブロックに対応すること、又は
iv)前記コーディングツリーノードが、垂直三分木分割を伴った32×4ルーマブロックに対応すること
のうちの1つを満足する、
方法。
【0226】
22.箇条17に記載の方法であって、
前記コーディングツリーノードは、M×Nコーディングツリーノードであり、M及び/又はNは、予め定義されるか、又は通知される、
方法。
【0227】
23.箇条22に記載の方法であって、
M及び/又はNは、前記ビデオの前記カラーフォーマットに依存する、
方法。
【0228】
24.箇条1乃至23のうちいずれかに記載の方法であって、
前記変換の実行は、前記符号化表現を前記ビデオから生成することを含む、
方法。
【0229】
25.箇条1乃至23のうちいずれかに記載の方法であって、
前記変換の実行は、前記符号化表現から前記ビデオを生成することを含む、
方法。
【0230】
26.箇条1乃至25のうちいずれか1つに記載の方法を実装するよう構成されたプロセッサを有するビデオ処理装置。
【0231】
27.実行される場合に、プロセッサに、箇条1乃至25のうちいずれか1つに記載の方法を実装させるプログラムコードを記憶しているコンピュータ可読媒体。
【0232】
箇条書きの第3の組は、前のセクション、例えば、例となる実施3及び10~13で開示されている技術のある特徴及び態様について記載している。
【0233】
1.ビデオ処理の方法であって、
1つ以上のルーマブロック及び1つ以上のクロマブロックを有する1つ以上のビデオ領域を有するビデオと、該ビデオの符号化表現との間の変換を、ルールに従って実行するステップを有し、
前記ルールは、サイズがM×Nである、前記1つ以上のクロマブロックの中のクロマブロックが、イントラモード又はイントラブロックコピーモードを用いて前記符号化表現で表されることを許可されないことを定め、前記M及びNは、夫々、当該クロマブロックの幅及び高さを示す整数であり、前記イントラモードは、前に符号化又は再構成されたビデオブロックに基づき当該クロマブロックを符号化することを含み、前記イントラブロックコピーモードは、ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記クロマブロックを符号化することを含む、
方法。
【0234】
2.箇条1に記載の方法であって、
前記ルールは、2×Nのサイズを有しているクロマブロックが、前記ビデオ領域が二分木パーティションとしてパーティション化されることにより許可されないことを定める、
方法。
【0235】
3.箇条2に記載の方法であって、
前記ルールは、垂直BT(二分木)分割が、i)前記クロマブロックのツリータイプが二分木タイプに等しく、かつ、ii)Mが4クロマサンプルに等しい場合に、前記クロマブロックに対して許可されないことを定める、
方法。
【0236】
4.箇条2に記載の方法であって、
前記ルールは、垂直TT(三分木)分割が、i)前記クロマブロックのツリータイプが二分木タイプに等しく、かつ、ii)Mが8クロマサンプルに等しい場合に、前記クロマブロックに対して許可されないことを定める、
方法。
【0237】
5.箇条1に記載の方法であって、
前記ルールは、2×Nのサイズを有しているクロマブロックが、前記ビデオ領域が一分木パーティションとしてパーティション化されることにより許可されないことを定める、
方法。
【0238】
6.箇条5に記載の方法であって、
垂直BT(二分木)分割を伴ったM×Nコーディングツリーノードについて、前記垂直BT分割は、4×N又は4×(N/2)のサイズを有しているクロマブロックに対しては許可されず、8×Nのサイズを有しているルーマブロックに対しては許可される、
方法。
【0239】
7.箇条5に記載の方法であって、
垂直BT(二分木)分割を伴ったM×Nコーディングツリーノードについて、前記垂直BT分割は、4×N又は4×(N/2)のサイズを有しているクロマブロックに対して許可されない、
方法。
【0240】
8.箇条5に記載の方法であって、
垂直BT(二分木)分割を伴ったM×Nコーディングツリーノードについて、前記垂直BT分割は、4×N又は4×(N/2)のサイズを有しているクロマブロック及び8×Nのサイズを有しているルーマブロックに対して許可され、前記クロマブロック及びルーマブロックは、前記イントラモードでコーディングされない、
方法。
【0241】
9.箇条5に記載の方法であって、
垂直TT(三分木)分割を伴ったM×Nコーディングツリーノードについて、前記垂直TT分割は、8×N又は8×(N/2)のサイズを有しているクロマブロックに対しては許可されず、16×Nのサイズを有しているルーマブロックに対しては許可される、
方法。
【0242】
10.箇条5に記載の方法であって、
垂直TT(三分木)分割を伴ったM×Nコーディングツリーノードについて、前記垂直TT分割は、8×N又は8×(N/2)のサイズを有しているクロマブロックに対して許可されない、
方法。
【0243】
11.箇条5に記載の方法であって、
垂直TT(三分木)分割を伴ったM×Nコーディングツリーノードについて、前記垂直TT分割は、8×N又は8×(N/2)のサイズを有しているクロマブロック及び16×Nのサイズを有しているルーマブロックに対して許可され、前記クロマブロック及びルーマブロックは、前記イントラモードでコーディングされない、
方法。
【0244】
12.ビデオ処理の方法であって、
ビデオのビデオ領域と前記ビデオの符号化表現との間の変換のために、ルールに従って、インター-イントラ複合予測モード(CIIP)モードをイントラモード又はインターモードとして使用すると決定するステップと、
前記決定に基づき前記変換を実行するステップと
を有し、
前記CIIPモードは、加重係数を用いてイントラ予測信号及びインター予測信号を結合することを含む、
方法。
【0245】
13.箇条12に記載の方法であって、
前記ルールは、前記ビデオ領域で使用される二分木パーティショニングにより、前記CIIPモードを前記イントラモードとして使用することを定める、
方法。
【0246】
14.箇条12に記載の方法であって、
前記ルールは、前記CIIPを前記インターモードとして使用することを定める、
方法。
【0247】
15.箇条14に記載の方法であって、
前記ルールは、クロマブロックがMに等しい幅を有していることにより、前記CIIPモードを無効にすると定める、
方法。
【0248】
16.箇条12に記載の方法であって、
前記ルールは、前記CIIPモードでコーディングされたクロマブロックのためのイントラ予測モードを前記イントラモードに制限すると定める、
方法。
【0249】
17.箇条16に記載の方法であって、
前記イントラ予測モードは、intra_DC、intra_angular18モード、又はintra_angular50モードを含む、
方法。
【0250】
18.箇条16に記載の方法であって、
前記クロマブロックの幅は2に等しい、
方法。
【0251】
19.ビデオ処理の方法であって、
ビデオのクロマブロックと前記ビデオの符号化表現との間の変換を実行するステップを有し、
前記クロマブロックは、サイズルールに従って、イントラコーディングモードを用いて前記符号化表現で表され、
前記サイズルールは、前記クロマブロックの幅がMに等しいか又は前記クロマブロックの高さがNに等しい場合には、前記イントラコーディングモードがイントラコーディングモードタイプの第1セットからであり、そうでない場合には、前記イントラコーディングモードがイントラコーディングモードタイプの第2セットからであると定め、M及びNは整数である、
方法。
【0252】
20.箇条19に記載の方法であって、
M=2又はN=2である、
方法。
【0253】
21.箇条19又は20に記載の方法であって、
前記イントラコーディングモードタイプの第1セットは、前記変換における全ての許可されているイントラコーディングモードタイプのサブセットである、
方法。
【0254】
22.箇条19又は20に記載の方法であって、
前記イントラコーディングモードタイプの第1セットは、INTRA_DCモードに対応する、
方法。
【0255】
23.箇条19又は20に記載の方法であって、
前記イントラコーディングモードタイプの第1セットは、INTRA_PLANARモードに対応する、
方法。
【0256】
24.箇条19又は20に記載の方法であって、
前記イントラコーディングモードタイプの第1セットは、INTRA_ANGULAR18モードに対応する、
方法。
【0257】
25.箇条19又は20に記載の方法であって、
前記イントラコーディングモードタイプの第1セットは、INTRA_ANGULAR50モードに対応する、
方法。
【0258】
26.箇条19又は20に記載の方法であって、
前記ルールは、クロマ成分の予測値を他の成分から導出するために線形モードを使用するCCLMモードが無効にされることを定める、
方法。
【0259】
27.ビデオ処理の方法であって、
ビデオのクロマブロックと前記ビデオの符号化表現との間の変換を実行するステップを有し、
前記クロマブロックは、ルールに従って変換タイプを用いて符号化表現で表され、
前記ルールは、前記クロマブロックの幅がMに等しいか又は前記クロマブロックの高さがNに等しい場合には、前記変換タイプが変換タイプの第1セットからであり、そうでない場合には、前記変換タイプが変換タイプの第2セットからであると定め、M及びNは整数である、
方法。
【0260】
28.箇条27に記載の方法であって、
Mは2であり、あるいは、Nは2である、
方法。
【0261】
29.箇条1乃至11、15、19乃至28のうちいずれか1つに記載の方法であって、
M及び/又はNは、予め定義されるか、又は通知される、
方法。
【0262】
30.箇条29に記載の方法であって、
M及び/又はNは、前記ビデオ領域のカラーフォーマットに依存する、
方法。
【0263】
31.箇条1乃至30のうちいずれかに記載の方法であって、
前記変換は、前記ビデオを前記符号化表現に符号化することを含む、
方法。
【0264】
32.箇条1乃至30のうちいずれかに記載の方法であって、
前記変換は、前記ビデオを生成するよう前記符号化表現を復号することを含む、
方法。
【0265】
33.箇条1乃至32のうちいずれか1つ以上に記載されている方法を実装するよう構成されたプロセッサを有するビデオ処理装置。
【0266】
34.実行される場合に、プロセッサに、箇条1乃至32のうちいずれか1つ以上に記載されている方法を実装させるプログラムコードを記憶しているコンピュータ可読媒体。
【0267】
箇条書きの第4の組は、前のセクション、例えば、例となる実施4~9及び13で開示されている技術のある特徴及び態様について記載している。
【0268】
1.ビデオ処理の方法であって、
1つ以上のルーマブロック及び1つ以上のクロマブロックを有しているビデオ領域を有するビデオと、前記ビデオの符号化表現との間の変換を、ルールに従って実行するステップを有し、
前記ルールは、イントラブロックコピー(IBC)モードの使用が、M×Nの全ての値について、ブロックサイズがM×Nである前記1つ以上のルーマブロック及び前記1つ以上のクロマブロックに対して利用可能であることを定め、M及びNは整数であり、
前記IBCモードを用いて、ビデオブロックは、該ビデオブロックを含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いてコーディングされる、
方法。
【0269】
2.箇条1に記載の方法であって、
前記ルールは、ルーマブロックが8×4、8×8、16×4、又は4×Nのサイズを有することを定める、
方法。
【0270】
3.箇条2に記載の方法であって、
前記ルーマブロックは、イントラモード、前記IBCモード及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しいモードタイプを有する、
方法。
【0271】
4.箇条1に記載の方法であって、
前記ルールは、クロマブロックが、イントラモード、前記IBCモード及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しいモードタイプを有することを定める、
方法。
【0272】
5.ビデオ処理の方法であって、
ビデオのビデオブロックと該ビデオブロックの符号化表現との間の変換を実行するステップを有し、
前記符号化表現はフォーマットルールに従い、該フォーマットルールは、前記ビデオブロックのモードタイプに基づいた、前記符号化表現でのインターブロックコピー(IBC)モードの使用を示すシンタックス要素の選択的包含を定め、前記IBCモードは、前記ビデオブロックを含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオブロックを符号化することを含む、
方法。
【0273】
6.箇条5に記載の方法であって、
前記フォーマットルールは、前記ビデオブロックのツリータイプがDUAL_TREE_CHROMAに等しくなく、かつ、前記ビデオブロックの前記モードタイプが、イントラモード、前記IBCモード、及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しい場合に、スキップモードでコーディングされていない前記ビデオブロックについて前記シンタックス要素を明示的に通知することを定める、
方法。
【0274】
7.箇条5に記載の方法であって、
前記フォーマットルールは、前記ビデオブロックのモードタイプ及びスキップフラグに基づき前記シンタックス要素を推測することを定める、
方法。
【0275】
8.箇条7に記載の方法であって、
前記フォーマットルールは、前記ビデオブロックの前記モードタイプが、イントラモード、前記IBCモード、及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しい場合に、前記シンタックス要素が、スキップモードでコーディングされている前記ビデオブロックについて1に等しいと推測されることを定める、
方法。
【0276】
9.ビデオ処理の方法であって、
ビデオのビデオブロックと該ビデオブロックの符号化表現との間の変換を実行するステップを有し、
前記符号化表現はフォーマットルールに従い、該フォーマットルールは、パレットモードの使用を示すシンタックス要素がビデオブロックのモードタイプにかかわらず前記符号化表現に含まれることを定め、前記パレットモードは、代表サンプル値のパレットを用いて前記ビデオブロックを符号化することを含む、
方法。
【0277】
10.箇条9に記載の方法であって、
前記フォーマットルールは、前記ビデオブロックの予測モード、ブロックサイズ、またはスライスタイプのうちの少なくとも1つに基づいた明示的な通知を定める、
方法。
【0278】
11.箇条9に記載の方法であって、
前記フォーマットルールは、前記ビデオブロックの前記モードタイプが、インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTER、又はイントラモード、IBCモード、及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しい場合に、前記シンタックス要素が0に等しいと推測されることを定める、
方法。
【0279】
12.ビデオ処理の方法であって、
ビデオのビデオ領域と前記ビデオの符号化表現との間の変換のために、ルールに基づき、インターブロックコピー(IBC)モードの使用が前記ビデオ領域について許可されることを決定するステップと、
前記決定に基づき前記変換を実行するステップと
を有し、
前記IBCモードは、前記ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオ領域を符号化することを含む、
方法。
【0280】
13.箇条12に記載の方法であって、
前記ルールは、前記ビデオ領域のモードタイプが、インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTERに等しい場合に、前記IBCモードが許可されることを定める、
方法。
【0281】
14.箇条12に記載の方法であって、
前記ルールは、前記ビデオ領域のモードタイプが、イントラモード、前記IBCモード、及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しい場合に、前記IBCモードがクロマブロックに対して許可されないことを定める、
方法。
【0282】
15.箇条12に記載の方法であって、
前記ルールは、前記ビデオ領域のモードタイプが、インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTER、又はイントラモード、前記IBCモード、及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しい場合に、前記IBCモードが許可されることを定める、
方法。
【0283】
16.箇条12に記載の方法であって、
前記ルールは、前記ビデオ領域のモードタイプとは無関係に前記IBCモードが許可されること定める、
方法。
【0284】
17.箇条12に記載の方法であって、
クロマブロックのサイズを制限するよう定義された最小クロマイントラ予測ユニット(SCIPU)内で前記IBCモード及びインターモードは許可される、
方法。
【0285】
18.箇条12に記載の方法であって、
前記IBCモードを用いてコーディングされたクロマブロックは、該クロマブロックに対応するルーマブロックのサイズに対応するサイズを有している、
方法。
【0286】
19.箇条12に記載の方法であって、
前記IBCモードの使用を示すシンタックス要素の通知はスキップされ、
前記シンタックス要素は、前記ビデオ領域のモードタイプが、インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTERに等しく、かつ、前記ビデオ領域が4×4ルーマブロックに対応する場合に、1に等しいと推測される、
方法。
【0287】
20.ビデオ処理の方法であって、
ビデオのビデオ領域と前記ビデオの符号化表現との間の変換のために、ルールに基づき、パレットモードの使用が前記ビデオ領域に対して許可されるかどうかを決定するステップと、
前記決定に基づき前記変換を実行するステップと
を有し、
前記ルールは、前記ビデオ領域のコーディングモードタイプ又は前記ビデオの領域のカラータイプに基づき、
前記パレットモードは、代表サンプル値のパレットを用いて前記ビデオ領域を符号化することを含む、
方法。
【0288】
21.箇条20に記載の方法であって、
前記ルールは、前記ビデオ領域のモードタイプが、インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTERに等しい場合に、前記パレットモードが許可されることを定める、
方法。
【0289】
22.箇条20に記載の方法であって、
前記ルールは、前記ビデオ領域のモードタイプが、イントラモード、IBCモード、及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しい場合に、前記パレットモードがクロマブロックに対して許可されないことを定め、
前記IBCモードは、前記ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオ領域を符号化することを含む、
方法。
【0290】
23.箇条20に記載の方法であって、
前記ルールは、前記ビデオ領域のモードタイプが、インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTER、又はイントラモード、IBCモード、及びパレットモードの適用可能性を示すMODE_TYPE_INTRAに等しい場合に、前記パレットモードが許可されることを定め、
前記IBCモードは、前記ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオ領域を符号化することを含む、
方法。
【0291】
24.箇条20に記載の方法であって、
前記ルールは、前記ビデオ領域のモードタイプとは無関係に前記パレットモードが許可されることを定める、
方法。
【0292】
25.箇条20に記載の方法であって、
クロマブロックのサイズを制限するよう定義された最小クロマイントラ予測ユニット(SCIPU)内で前記パレットモード及びインターモードは許可される、
方法。
【0293】
26.箇条20に記載の方法であって、
前記パレットモード、IBCモード、及びインターモードの全ては、クロマブロックのサイズを制限するよう定義された最小クロマイントラ予測ユニット(SCIPU)内で許可され、
前記IBCモードは、前記ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオ領域を符号化することを含む、
方法。
【0294】
27.箇条20に記載の方法であって、
前記パレットモードを用いてコーディングされたクロマブロックは、該クロマブロックに対応するルーマブロックのサイズに対応するサイズを有している、
方法。
【0295】
28.箇条20に記載の方法であって、
前記パレットモードの使用を示すシンタックス要素の通知はスキップされ、
前記シンタックス要素は、前記ビデオ領域のモードタイプが、インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTERに等しく、かつ、前記ビデオ領域が4×4ルーマブロックに対応する場合に、1に等しいと推測される、
方法。
【0296】
29.箇条20に記載の方法であって、
前記パレットモード又はIBCモードの使用を示すシンタックス要素は、1)前記ビデオ領域のモードタイプが、インターコーディングモードのみの適用可能性を示すMODE_TYPE_INTERに等しく、2)前記ビデオ領域が4×4ルーマブロックに対応する場合に、前記符号化表現に含まれ、
前記IBCモードは、前記ビデオ領域を含むビデオフレームを指し示す少なくとも1つのブロックベクトルを用いて前記ビデオ領域を符号化することを含む、
方法。
【0297】
30.箇条1乃至4のうちいずれか1つに記載の方法であって、
M及び/又はNは、予め定義されるか、又は通知される、
方法。
【0298】
31.箇条30に記載の方法であって、
M及び/又はNは、前記ビデオ領域のカラーフォーマットに依存する、
方法。
【0299】
32.箇条1乃至31のうちいずれかに記載の方法であって、
前記変換の実行は、前記ビデオから前記符号化表現を生成することを含む、
方法。
【0300】
33.箇条1乃至31のうちいずれかに記載の方法であって、
前記変換の実行は、前記符号化表現から前記ビデオを生成することを含む、
方法。
【0301】
34.箇条1乃至33のうちいずれか1つ以上に記載されている方法を実装するよう構成されたプロセッサを有するビデオ処理装置。
【0302】
35.実行される場合に、プロセッサに、箇条1乃至33のうちいずれか1つ以上に記載されている方法を実装させるプログラムコードを記憶しているコンピュータ可読媒体。
【0303】
本明細書で記載されている開示された及び他の解決法、例、実施形態、モジュール及び機能的動作は、デジタル電子回路で、あるいは、本明細書で開示されている構造及びそれらの構造的同等物を含むコンピュータソフトウェア、ファームウェア、又はハードウェアで、あるいは、それらのうちの1つ以上の組み合わせで実装可能である。開示された及び他の実施形態は、1つ以上のコンピュータプログラム製品、つまり、データ処理装置によって実行されるか又はその動作を制御するコンピュータ可読媒体で符号化されたコンピュータプログラム命令の1つ以上のモジュール、として実装可能である。コンピュータ可読媒体は、マシン可読記憶デバイス、マシン可読記憶基板、メモリデバイス、マシン可読な伝播信号に影響を与える物質の組成、又はそれらの1つ以上の組み合わせであることができる。「データ処理装置」との用語は、例として、プログラム可能なプロセッサ、コンピュータ、又は複数のプロセッサ若しくはコンピュータを含む、データを処理するための全ての装置、デバイス、及びマシンを包含する。装置は、ハードウェアに加えて、問題となっているコンピュータプログラムのための実行環境を作り出すコード、例えば、プロセッサファームウェア、プロトコルスタック、データベース管理システム、オペレーティングシステム、又はそれらの1つ以上の組み合わせを構成するコードを含むことができる。伝播信号は、人工的に生成された信号、例えば、適切な受信器装置への伝送のために情報を符号化するよう生成される、マシンにより生成された電気、光、又は電磁気信号である。
【0304】
コンピュータプログラム(プログラム、ソフトウェア、ソフトウェアアプリケーション、スクリプト、又はコードとしても知られる。)は、コンパイル済み又は解釈済みの言語を含む如何なる形式のプログラミング言語でも記述可能であり、それは、スタンドアロンプログラムとして又はコンピューティング環境における使用に適したモジュール、コンポーネント、サブルーチン、若しくは他のユニットとしてを含め、如何なる形式でもデプロイ可能である。コンピュータプログラムは、必ずしもファイルシステムにおけるファイルに対応しない。プログラムは、問題となっているプログラムに専用の単一のファイルで、又は複数の協調したファイル(例えば、1つ以上のモジュール、サブプログラム、又はコードの部分を保存するファイル)で、他のプログラム又はデータ(例えば、マークアップ言語文書で保存された1つ以上のスクリプト)を保持するファイルの部分において保存可能である。コンピュータプログラムは、1つのコンピュータで、あるいは、1つの場所に位置しているか、又は複数の場所にわたって分布しており、通信ネットワークによって相互接続されている複数のコンピュータで、実行されるようデプロイ可能である。
【0305】
本明細書で説明されているプロセス及びロジックフローは、入力データに作用して出力を生成することによって機能を実行するよう1つ以上のコンピュータプログラムを実行する1つ以上のプログラム可能なプロセッサによって実行可能である。プロセス及びロジックフローはまた、専用のロジック回路、例えば、フィールド・プログラマブル・ゲート・アレイ(FPGA)又は特定用途向け集積回路(ASIC)によっても実行可能であり、装置は、そのようなものとして実装可能である。
【0306】
コンピュータプログラムの実行に適したプロセッサは、例として、汎用のマイクロプロセッサ及び専用のマイクロプロセッサの両方、並びにあらゆる種類のデジタルコンピュータのいずれか1つ以上のプロセッサを含む。一般に、プロセッサは、リード・オンリー・メモリ若しくはランダム・アクセス・メモリ又はその両方から命令及びデータを読み出すことになる。コンピュータの必須の要素は、命令を実行するプロセッサと、命令及びデータを保存する1つ以上のメモリデバイスとである。一般に、コンピュータはまた、データを保存する1つ以上の大容量記憶デバイス、例えば、磁気、光学磁気ディスク、又は光ディスクを含むか、あるいは、そのような1つ以上の大容量記憶デバイスからのデータの受信若しくはそれへのデータの転送又はその両方のために動作可能に結合されることになる。しかし、コンピュータは、そのようなデバイスを有する必要はない。コンピュータプログラム命令及びデータを保存するのに適したコンピュータ可読媒体は、例として、半導体メモリデバイス、例えば、EPROM、EEPROM、及びフラッシュメモリデバイス;磁気ディスク、例えば、内蔵ハードディスク又はリムーバブルディスク;光学磁気ディスク;並びにCD ROM及びDVD-ROMディスクを含む全ての形式の不揮発性メモリ、媒体及びメモリデバイスを含む。プロセッサ及びメモリは、専用のロジック回路によって強化されるか、あるいは、それに組み込まれ得る。
【0307】
本明細書は、多数の詳細を含むが、それらは、あらゆる対象の又は請求される可能性があるものの範囲に対する限定としてではなく、むしろ、特定の技術の特定の実施形態に特有であり得る特徴の説明として解釈されるべきである。別々の実施形態に関連して本明細書で説明されている特定の特徴は、単一の実施形態と組み合わせても実装可能である。逆に、単一の実施形態に関連して説明されている様々な特徴はまた、複数の実施形態で別々に、又は何らかの適切なサブコンビネーションで、実装可能である。更に、特徴は、特定の組み合わせで動作するものとして先に説明され、更には、そのようなものとして最初に請求されることがあるが、請求されている組み合わせからの1つ以上の特徴は、いくつかの場合に、その組み合わせから削除可能であり、請求されている組み合わせは、サブコンビネーション又はサブコンビネーションの変形に向けられてもよい。
【0308】
同様に、動作は、特定の順序で図面において表されているが、これは、所望の結果を達成するために、そのような動作が示されているその特定の順序で又は順次的な順序で実行されること、あるいは、表されている全ての動作が実行されることを求めている、と理解されるべきではない。更に、本明細書で説明されている実施形態における様々なシステムコンポーネントの分離は、全ての実施形態でそのような分離を求めている、と理解されるべきではない。
【0309】
ほんのわずかの実施及び例が説明されており、他の実施、強化及び変形は、本特許文献で記載及び例示されているものに基づいて行われ得る。
【外国語明細書】