(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2024124416
(43)【公開日】2024-09-12
(54)【発明の名称】ビデオ処理方法、ビデオ処理装置、エンコーダ、デコーダ、媒体、およびコンピュータプログラム
(51)【国際特許分類】
H04N 19/52 20140101AFI20240905BHJP
H04N 19/436 20140101ALI20240905BHJP
【FI】
H04N19/52
H04N19/436
【審査請求】有
【請求項の数】21
【出願形態】OL
【外国語出願】
(21)【出願番号】P 2024095942
(22)【出願日】2024-06-13
(62)【分割の表示】P 2022212116の分割
【原出願日】2019-08-12
(31)【優先権主張番号】62/717,004
(32)【優先日】2018-08-10
(33)【優先権主張国・地域又は機関】US
(71)【出願人】
【識別番号】504161984
【氏名又は名称】ホアウェイ・テクノロジーズ・カンパニー・リミテッド
(74)【代理人】
【識別番号】100110364
【弁理士】
【氏名又は名称】実広 信哉
(74)【代理人】
【識別番号】100133569
【弁理士】
【氏名又は名称】野村 進
(72)【発明者】
【氏名】アナンド・メヘル・コトラ
(72)【発明者】
【氏名】セミフ・エセンリク
(72)【発明者】
【氏名】ジエンレ・チェン
(72)【発明者】
【氏名】ビャオ・ワン
(72)【発明者】
【氏名】ハン・ガオ
(72)【発明者】
【氏名】ジジエ・ジャオ
(57)【要約】
【課題】コーディング効率を改善するための、ビデオ処理方法および対応する装置を提供する。
【解決手段】現在CTUが現在CTU行の開始CTUであるとき、現在CTU行に対するHMVPリストを初期化するステップと、前記HMVPリストに基づいて現在CTU行を処理するステップとを含む、ビデオ処理方法。この方法を行うことによって、符号化効率および復号効率が改善される。
【選択図】
図9
【特許請求の範囲】
【請求項1】
ビデオ処理方法であって、
現在コーディングツリーユニット(CTU)が現在CTU行の開始CTUであるとき、現在CTU行に対する履歴ベースの動きベクトル予測(HMVP)リストを初期化するステップと、
前記HMVPリストに基づいて前記現在CTU行を処理するステップと
を含む、方法。
【請求項2】
前記初期化されたHMVPリスト内の候補動きベクトルの数量はゼロである、請求項1に記載の方法。
【請求項3】
前記現在CTU行は、複数のCTU行からなるピクチャエリアに属し、前記現在CTU行は、前記複数のCTU行のうちのいずれか1つである、請求項1または2に記載の方法。
【請求項4】
前記現在CTU行を除き、前記複数のCTU行の各々に対するHMVPリストを初期化するステップであって、前記複数のCTU行に対するHMVPリストは、同一であるかまたは異なる、初期化するステップ
をさらに含む、請求項1から3のいずれか一項に記載の方法。
【請求項5】
前記HMVPリストに基づいて前記現在CTU行を前記処理するステップは、
前記現在CTU行の前記現在CTUを処理するステップと、
前記処理された現在CTUに基づいて、前記初期化されたHMVPリストを更新するステップと、
前記更新されたHMVPリストに基づいて、前記現在CTU行の第2のCTUを処理するステップと
を含む、請求項1から4のいずれか一項に記載の方法。
【請求項6】
前記HMVPリストは、前記現在CTU行の処理されたCTUに従って更新される、請求項1から5のいずれか一項に記載の方法。
【請求項7】
前記現在CTU行に対する前記HMVPリストは、以下のように、すなわち、
前記現在CTU行に対する前記HMVPリストを空にするように
初期化される、請求項1から6のいずれか一項に記載の方法。
【請求項8】
前記HMVPリストに基づいて前記現在CTU行を前記処理するステップは、
前記現在CTU行の第2のCTUからの前記HMVPリストに基づいて、前記現在CTU行を処理するステップであって、前記第2のCTUは、前記開始CTUに隣接する、処理するステップ
を含む、請求項1から7のいずれか一項に記載の方法。
【請求項9】
前記複数のCTU行は、波面並列処理(WPP)モードで処理される、請求項3から8のいずれか一項に記載の方法。
【請求項10】
前記現在CTU行は、前のCTU行の特定のCTUが処理されるときに処理され始める、請求項9に記載の方法。
【請求項11】
前記前のCTU行は、前記現在CTU行に直接隣接し、前記現在CTU行の上にある、前記CTU行である、請求項10に記載の方法。
【請求項12】
前記前のCTU行の前記特定のCTUは、前記前のCTU行の第2のCTUである;または前記前のCTU行の前記特定のCTUは、前記前のCTU行の第1のCTUである、請求項10または11に記載の方法。
【請求項13】
ビデオ処理装置であって、
現在コーディングツリーユニット(CTU)が現在CTU行の開始CTUであるとき、現在CTU行に対する履歴ベースの動きベクトル予測(HMVP)リストを初期化するように構成された、初期化ユニットと、
前記HMVPリストに基づいて前記現在CTU行を処理するように構成された、処理ユニットと
を含む、ビデオ処理装置。
【請求項14】
前記初期化されたHMVPリスト内の候補動きベクトルの数量はゼロである、請求項13に記載の装置。
【請求項15】
前記現在CTU行は、複数のCTU行からなるピクチャエリアに属し、前記現在CTU行は、前記複数のCTU行のうちのいずれか1つである、請求項13または14に記載の装置。
【請求項16】
前記初期化ユニットは、
前記現在CTU行を除き、前記複数のCTU行の各々に対するHMVPリストを初期化することであって、前記複数のCTU行に対するHMVPリストは、同一であるかまたは異なる、初期化すること
を行うようにさらに構成される、請求項15に記載の装置。
【請求項17】
前記処理ユニットは、以下のように、すなわち、
前記現在CTU行の前記現在CTUを処理し、
前記処理された現在CTUに基づいて、前記初期化されたHMVPリストを更新し、
前記更新されたHMVPリストに基づいて、前記現在CTU行の第2のCTUを処理する
ように
前記HMVPリストに基づいて前記現在CTU行を処理するように構成される、請求項13から16のいずれか一項に記載の装置。
【請求項18】
前記HMVPリストは、前記現在CTU行の処理されたCTUに従って更新される、請求項13から17のいずれか一項に記載の装置。
【請求項19】
前記初期化ユニットは、以下のように、すなわち、
前記現在CTU行に対する前記HMVPリストを空にするように
前記現在CTU行に対する前記HMVPリストを初期化するようにさらに構成される、請求項13から18のいずれか一項に記載の装置。
【請求項20】
前記処理ユニットは、以下のように、すなわち、
前記現在CTU行の第2のCTUからの前記HMVPリストに基づいて、前記現在CTU行を処理することであって、前記第2のCTUは、前記開始CTUに隣接する、処理することを行うように
前記HMVPリストに基づいて前記現在CTU行を処理するようにさらに構成される、請求項13
から19のいずれか一項に記載の装置。
【請求項21】
前記複数のCTU行は、波面並列処理(WPP)モードで処理される、請求項15から20のいずれか一項に記載の装置。
【請求項22】
前記現在CTU行は、前のCTU行の特定のCTUが処理されるときに処理され始める、請求項21に記載の装置。
【請求項23】
前記前のCTU行は、前記現在CTU行に直接隣接し、前記現在CTU行の上にある、前記CTU行である、請求項22に記載の装置。
【請求項24】
前記前のCTU行の前記特定のCTUは、前記前のCTU行の第2のCTUである;または前記前のCTU行の前記特定のCTUは、前記前のCTU行の第1のCTUである、請求項22または23に記載の装置。
【請求項25】
請求項1から12のいずれか一項に記載の方法を行うための処理回路を含む、エンコーダ。
【請求項26】
請求項1から12のいずれか一項に記載の方法を行うための処理回路を含む、デコーダ。
【請求項27】
請求項1から12のいずれか一項に記載の方法を行うためのプログラムコードを含む、コンピュータプログラム製品。
【請求項28】
コンピュータ命令を記憶した、コンピュータ可読記憶媒体であって、前記コンピュータ命令は、1つまたは複数のプロセッサによって実行されると、請求項1から12のいずれか一項に記載の方法を前記1つまたは複数のプロセッサに行わせる、コンピュータ可読記憶媒体。
【請求項29】
デコーダであって、
1つまたは複数のプロセッサと、
前記プロセッサに結合され、前記プロセッサによる実行のためのプログラミングを記憶した、非一時的コンピュータ可読記憶媒体と
を含み、前記プログラミングは、前記プロセッサによって実行されると、請求項1から12のいずれか一項に記載の方法を行うように前記デコーダを構成する
デコーダ。
【請求項30】
エンコーダであって、
1つまたは複数のプロセッサと、
前記プロセッサに結合され、前記プロセッサによる実行のためのプログラミングを記憶した、非一時的コンピュータ可読記憶媒体と
を含み、前記プログラミングは、前記プロセッサによって実行されると、請求項1から12のいずれか一項に記載の方法を行うように前記エンコーダを構成する
エンコーダ。
【発明の詳細な説明】
【技術分野】
【0001】
本出願(開示)の実施形態は、概して、ビデオコーディングの分野に関し、より詳細には、ビデオ処理方法、ビデオ処理装置、エンコーダ、デコーダ、媒体、およびコンピュータプログラムに関する。
【背景技術】
【0002】
ビデオコーディング(ビデオ符号化およびビデオ復号)は、幅広いデジタルビデオアプリケーション、たとえば、ブロードキャストデジタルTV、インターネット網およびモバイルネットワークを介したビデオ送信、ビデオチャットなどのリアルタイム会話アプリケーション、ビデオ会議、DVDおよびBlu-ray(登録商標)ディスク、ビデオコンテンツ取得システムおよびビデオコンテンツ編集システム、ならびにセキュリティアプリケーションのカムコーダにおいて使用される。
【0003】
1990年のH.261規格におけるブロックベースのハイブリッドビデオコーディング手法の発展以来、新たなビデオコーディング技術およびビデオコーディングツールが開発され、新たなビデオコーディング規格の基礎を形成した。さらなるビデオコーディング規格は、MPEG-1ビデオ、MPEG-2ビデオ、ITU-T H.262/MPEG-2、ITU-T H.263、ITU-T H.264/MPEG-4、パート10、アドバンストビデオコーディング(AVC)、ITU-T H.265/高効率ビデオコーディング(HEVC)、ITU-T H.266/多目的ビデオコーディング(VVC:Versatile video coding)、ならびにこれらの規格の拡張、たとえば、スケーラビリティおよび/または3次元(3D)拡張を含む。ビデオの作成および使用がますます偏在するようになるにつれて、ビデオトラフィックは、通信ネットワークおよびデータ記憶に対して最も大きな負荷となり、したがって、多数のビデオコーディング規格の目標のうちの1つは、ピクチャ品質を犠牲にせずに、その前の規格と比較してビットレートの低減を達成することであった。最新の高効率ビデオコーディング(HEVC)ですら、品質を犠牲にせずに、AVCの二倍程度にビデオを圧縮することができ、HEVCと比較してビデオをさらに圧縮する必要が存在する。
【発明の概要】
【課題を解決するための手段】
【0004】
本出願の実施形態は、コーディング効率を改善するための、ビデオ処理方法および対応する装置を提供する。
【0005】
前述のおよび他の目的は、独立請求項の主題によって達成される。さらなる実装形態は、独立請求項、発明を実施するための形態、および図から明らかである。
【0006】
本発明の第1の態様は、ビデオ処理方法であって、現在コーディングツリーユニット(CTU)が現在CTU行の開始CTUであるとき、現在CTU行に対する履歴ベースの動きベクトル予測(HMVP)リストを初期化するステップと、HMVPリストに基づいて現在CTU行を処理するステップとを含む、ビデオ処理方法を提供する。開始CTUは、スタート(starting)CTUと呼ばれることもあり、処理される同じCTU行のCTUの第1のCTUである。
【0007】
現在CTU行に対するHMVPリストは、現在CTU行の処理の開始時に初期化され、現在CTU行のプロセスは、前のCTU行のHMVPリストに基づく必要はなく、それにより、符号化効率および復号効率を改善し得ることが分かる。
【0008】
第1の態様を参照すると、第1の態様の第1の考えられる実装方法では、初期化されたHMVPリスト内の候補動きベクトルの数量はゼロである。
【0009】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第2の考えられる実装方法では、現在CTU行は、複数のCTU行からなるピクチャエリアに属し、現在CTU行は、複数のCTU行のうちのいずれか1つ、たとえば、ピクチャエリアの第1の(たとえば、一番上の)CTU行、第2のCTU行、…および最後の(たとえば、一番下の)CTU行である。
【0010】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第3の考えられる実装方法では、この方法は、現在CTU行を除き、複数のCTU行の各々に対するHMVPリストを初期化するステップであって、複数のCTU行に対するHMVPリストは、同一であるかまたは異なる、初期化するステップをさらに含む。言い換えれば、実施形態は、追加で、ピクチャエリアのすべての他のCTU行に対するHMVPリストを初期化し得、すなわち、ピクチャエリアのすべてのCTU行に対するHMVPリストを初期化し得る。
【0011】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第4の考えられる実装方法では、HMVPリストに基づいて現在CTU行を処理するステップは、現在CTU行の現在CTUを処理するステップと、処理された現在CTUに基づいて、初期化されたHMVPリストを更新するステップと、更新されたHMVPリストに基づいて、現在CTU行の第2のCTUを処理するステップとを含む。
【0012】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第5の考えられる実装方法では、HMVPリストは、現在CTU行の処理されたCTUに従って更新される。
【0013】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第6の考えられる実装方法では、現在CTU行に対するHMVPリストは、以下のように、すなわち、現在CTU行に対するHMVPリストを空にするように、初期化される。
【0014】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第7の考えられる実装方法では、HMVPリストに基づいて現在CTU行を処理するステップは、現在CTU行の第2のCTUからのHMVPリストに基づいて、現在CTU行を処理するステップであって、第2のCTUは、開始CTUに隣接する、処理するステップを含む。
【0015】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第8の考えられる実装方法では、複数のCTU行は、波面並列処理(WPP:wavefront parallel processing)モードで処理される。
【0016】
現在CTU行に対するHMVPリストは現在CTU行の処理の開始時に初期化されるため、WPPモードと組み合わされるとき、ピクチャフレームまたはピクチャエリアのCTU行は、同時に処理可能であり、それにより、符号化効率および復号効率をさらに改善し得ることが分かる。
【0017】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第9の考えられる実装方法では、現在CTU行は、前のCTU行の特定のCTUが処理されるときに処理され始める(または、現在CTU行の処理が始まる)。
【0018】
第1の態様、または第1の態様の前述の実装方法のうちのいずれか1つを参照すると、第1の態様の第10の考えられる実装方法では、前のCTU行は、現在CTU行に直接隣接し、現在CTU行の上または上方にある、CTU行である。
【0019】
第1の態様の第9の実装方法または第1の態様の第10の実装方法を参照すると、第1の態様の第11の考えられる実装形態では、前のCTU行の特定のCTUは、前のCTU行の第2のCTUである;または、前のCTU行の特定のCTUは、前のCTU行の第1のCTUである。
【0020】
本発明の第2の態様は、ビデオ処理装置であって、現在コーディングツリーユニット(CTU)が現在CTU行の開始CTUであるとき、現在CTU行に対する履歴ベースの動きベクトル予測(HMVP)リストを初期化するように構成された、初期化ユニットと、HMVPリストに基づいて現在CTU行を処理するように構成された、処理ユニットとを含む、ビデオ処理装置を提供する。
【0021】
の第2の態様を参照すると、第2の態様の第1の考えられる実装方法では、初期化されたHMVPリスト内の候補動きベクトルの数量はゼロである。
【0022】
第2の態様、または第2の態様の前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第2の考えられる実装方法では、現在CTU行は、複数のCTU行からなるピクチャエリアに属し、現在CTU行は、複数のCTU行のうちのいずれか1つである。
【0023】
第2の態様、または第2の態様の前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第3の考えられる実装方法では、初期化ユニットは、現在CTU行を除き、複数のCTU行の各々に対するHMVPリストを初期化することであって、複数のCTU行に対するHMVPリストは、同一であるかまたは異なる、初期化することを行うようにさらに構成される。
【0024】
第2の態様、または第2の態様の前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第4の考えられる実装方法では、処理ユニットは、現在CTU行の現在CTUを処理し、処理された現在CTUに基づいて、初期化されたHMVPリストを更新し、更新されたHMVPリストに基づいて、現在CTU行の第2のCTUを処理するようにさらに構成される。
【0025】
第2の態様、または第2の態様の前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第5の考えられる実装方法では、HMVPリストは、現在CTU行の処理されたCTUに従って更新される。
【0026】
第2の態様、または第2の態様の前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第6の考えられる実装方法では、初期化ユニットは、以下のように、すなわち、現在CTU行に対するHMVPリストを空にするように、現在CTU行に対するHMVPリストを初期化するようにさらに構成される。
【0027】
第2の態様、または第2の態様の前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第7の考えられる実装方法では、処理ユニットは、以下のように、すなわち、現在CTU行の第2のCTUからのHMVPリストに基づいて、現在CTU行を処理することであって、第2のCTUは、開始CTUに隣接する、処理することを行うように、HMVPリストに基づいて現在CTU行を処理するようにさらに構成される。
【0028】
第2の態様、または第2の態様の前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第8の考えられる実装方法では、複数のCTU行は、波面並列処理(WPP)モードで処理される。
【0029】
第2の態様、または第2の態様その前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第9の考えられる実装方法では、現在CTU行は、前のCTU行の特定のCTUが処理されるときに処理され始める(または、現在CTU行の処理が始まる)。
【0030】
第2の態様、または第2の態様の前述の実装方法のうちのいずれか1つを参照すると、第2の態様の第10の考えられる実装方法では、前のCTU行は、現在CTU行に直接隣接し、現在CTU行の上にある、CTU行である。
【0031】
第2の態様の第9の実装方法または第2の態様の第10の実装方法を参照すると、第2の態様の第11の考えられる実装方法では、前のCTU行の特定のCTUは、前のCTU行の第2のCTUである;または前のCTU行の特定のCTUは、前のCTU行の第1のCTUである。
【0032】
本発明の第3の態様は、復号デバイスによって実装されるコーディングの方法であって、現在CTU行に対するHMVPリストを構築/初期化するステップと、構築/初期化されたHMVPリストに基づいて、現在CTU行のCTUを処理するステップとを含む、コーディングの方法を提供する。
第3の態様を参照すると、第3の態様の第1の考えられる実装方法では、現在CTU行に対するHMVPリストは、以下のように、すなわち、現在CTU行に対するHMVPリストを空にするように、および/もしくは現在CTU行に対するHMVPリストに対するデフォルト値を設定するように、ならびに/または前のCTU行のCTUのHMVPリストに基づいて、現在CTU行に対するHMVPリストを構築/初期化するように、構築/初期化される。
【0033】
第3の態様の第1の考えられる実装方法を参照すると、第3の態様の第2の考えられる実装方法では、現在CTU行に対するHMVPリストに対するデフォルト値を設定するステップは、HMVPリストのMVを単予測方法のMVとしてポピュレートするステップであって、単予測方法のMVは、ゼロ動きベクトルであるか、またはゼロ動きベクトルでないか、のいずれかであり、参照ピクチャは、L0リスト内に第1の参照ピクチャを含む、ポピュレートするステップ、および/またはHMVPリストのMVを双予測方法のMVとしてポピュレートするステップであって、双予測方法のMVは、ゼロ動きベクトルであるか、またはゼロ動きベクトルでないか、のいずれかであり、参照ピクチャは、L0リスト内に第1の参照ピクチャを含み、L1リスト内に第1の参照ピクチャを含む、ポピュレートするステップを含む。
【0034】
第3の態様の第1の考えられる実装方法を参照すると、第3の態様の第3の考えられる実装方法では、各同一位置のピクチャは、各CTU行に対して、またはピクチャ全体に対して、時間的HMVPリストを記憶することができ、現在CTU行に対するHMVPリストに対するデフォルト値を設定するステップは、時間的HMVPリストに基づいて、現在CTU行に対するHMVPリストを初期化/構築するステップを含む。
【0035】
第3の態様の第1の考えられる実装方法を参照すると、第3の態様の第4の考えられる実装方法では、前のCTU行は、現在CTU行に直接隣接し、現在CTU行の上にある、CTU行である。
【0036】
第3の態様の第4の考えられる実装方法を参照すると、第3の態様の第5の考えられる実装方法では、前のCTU行のCTUは、前のCTU行の第2のCTUである。
【0037】
第3の態様の第4の考えられる実装方法を参照すると、第3の態様の第5の考えられる実装方法では、前のCTU行のCTUは、前のCTU行の第1のCTUである。
【0038】
本発明の第4の態様は、符号化デバイスによって実装されるコーディングの方法であって、現在CTU行に対するHMVPリストを構築/初期化するステップと、構築/初期化されたHMVPリストに基づいて、現在CTU行のCTUを処理するステップとを含む、コーディングの方法を提供する。
【0039】
第4の態様を参照すると、第4の態様の第1の考えられる実装方法では、現在CTU行に対するHMVPリストは、以下のように、すなわち、現在CTU行に対するHMVPリストを空にするように;および/もしくは現在CTU行に対するHMVPリストに対するデフォルト値を設定するように、ならびに/または前のCTU行のCTUのHMVPリストに基づいて、現在CTU行に対するHMVPリストを構築/初期化するように、構築/初期化される。
【0040】
第4の態様の第1の考えられる実装方法を参照すると、第4の態様の第2の考えられる実装方法では、現在CTU行に対するHMVPリストに対するデフォルト値を設定するステップは、HMVPリストのMVを単予測方法のMVとしてポピュレートするステップであって、単予測方法のMVは、ゼロ動きベクトルであるか、またはゼロ動きベクトルでないか、のいずれかであり、参照ピクチャは、L0リスト内に第1の参照ピクチャを含む、ポピュレートするステップ;および/またはHMVPリストのMVを双予測方法のMVとしてポピュレートするステップであって、双予測方法のMVは、ゼロ動きベクトルであるか、またはゼロ動きベクトルでないか、のいずれかであり、参照ピクチャは、L0リスト内に第1の参照ピクチャを含み、L1リスト内に第1の参照ピクチャを含む、ポピュレートするステップを含む。
【0041】
第4の態様の第1の考えられる実装方法を参照すると、第4の態様の第3の考えられる実装方法では、各同一位置のピクチャは、各CTU行に対して、またはピクチャ全体に対して、時間的HMVPリストを記憶することができ、現在CTU行に対するHMVPリストに対するデフォルト値を設定するステップは、時間的HMVPリストに基づいて、現在CTU行に対するHMVPリストを初期化/構築するステップを含む。
【0042】
第4の態様の第1の考えられる実装方法を参照すると、第4の態様の第4の考えられる実装方法では、前のCTU行は、現在CTU行に直接隣接し、現在CTU行の上または上方にある、CTU行である。
【0043】
第4の態様の第4の考えられる実装方法を参照すると、第4の態様の第5の考えられる実装方法では、前のCTU行のCTUは、前のCTU行の第2のCTUである。
【0044】
第4の態様の第4の考えられる実装方法を参照すると、第4の態様の第6の考えられる実装方法では、前のCTU行のCTUは、前のCTU行の第1のCTUである。
【0045】
本発明の第5の態様は、エンコーダであって、第1の態様もしくは第1の態様の実装方法のうちのいずれか1つによる、または第3の態様もしくは第3の態様の実装方法のうちのいずれか1つによる、または第4の態様もしくは第4の態様の実装方法のうちのいずれか1つによる、方法を実行するための処理回路を含む、エンコーダを提供する。たとえば、エンコーダは、現在コーディングツリーユニット(CTU)が現在CTU行の開始CTUであるとき、現在CTU行に対する履歴ベースの動きベクトル予測(HMVP)リストを初期化するように構成された、初期化回路と、HMVPリストに基づいて現在CTU行を処理するように構成された、処理回路とを含み得る。
【0046】
本発明の第6の態様は、デコーダであって、第1の態様もしくは第1の態様の実装方法のうちのいずれか1つによる、または第3の態様もしくは第3の態様の実装方法のうちのいずれか1つによる、または第4の態様もしくは第4の態様の実装方法のうちのいずれか1つによる、方法を実行するための処理回路を含む、デコーダを提供する。たとえば、デコーダは、現在コーディングツリーユニット(CTU)が現在CTU行の開始CTUであるとき、現在CTU行に対する履歴ベースの動きベクトル予測(HMVP)リストを初期化するように構成された、初期化回路と、HMVPリストに基づいて現在CTU行を処理するように構成された、処理回路とを含み得る。
【0047】
本発明の第7の態様は、コンピュータプログラム製品であって、第1の態様もしくは第1の態様の実装方法のうちのいずれか1つによる、または第3の態様もしくは第3の態様の実装方法のうちのいずれか1つによる、または第4の態様もしくは第4の態様の実装方法のうちのいずれか1つによる、方法を実行するためのプログラムコードを含む、コンピュータプログラム製品を提供する。
【0048】
本発明の第8の態様は、コンピュータ命令を記憶した、コンピュータ可読記憶媒体であって、コンピュータ命令は、1つまたは複数のプロセッサによって実行されると、第1の態様もしくは第1の態様の実装方法のうちのいずれか1つによる、または第3の態様もしくは第3の態様の実装方法のうちのいずれか1つによる、または第4の態様もしくは第4の態様の実装方法のうちのいずれか1つによる、方法を1つまたは複数のプロセッサに実行させる、コンピュータ可読記憶媒体を提供する。
【0049】
本発明の第9の態様は、デコーダであって、1つまたは複数のプロセッサと、プロセッサに結合され、プロセッサによる実行のためのプログラミングを記憶した、非一時的コンピュータ可読記憶媒体とを含み、プログラミングは、プロセッサによって実行されると、第1の態様もしくは第1の態様の実装方法のうちのいずれか1つによる、または第3の態様もしくは第3の態様の実装方法のうちのいずれか1つによる、または第4の態様もしくは第4の態様の実装方法のうちのいずれか1つによる、方法を実行するようにデコーダを構成する、デコーダを提供する。
【0050】
本発明の第10の態様は、エンコーダであって、1つまたは複数のプロセッサと、プロセッサに結合され、プロセッサによる実行のためのプログラミングを記憶した、非一時的コンピュータ可読記憶媒体とを含み、プログラミングは、プロセッサによって実行されると、第1の態様もしくは第1の態様の実装方法のうちのいずれか1つによる、または第3の態様もしくは第3の態様の実装方法のうちのいずれか1つによる、または第4の態様もしくは第4の態様の実装方法のうちのいずれか1つによる、方法を実行するようにエンコーダを構成する、エンコーダを提供する。
【0051】
以下で、本発明の実施形態は、添付の図および図面を参照してより詳細に説明される。
【図面の簡単な説明】
【0052】
【
図1A】本発明の実施形態を実装するように構成されたビデオコーディングシステムの一例を示すブロック図である。
【
図1B】本発明の実施形態を実装するように構成されたビデオコーディングシステムの他の例を示すブロック図である。
【
図2】本発明の実施形態を実装するように構成されたビデオエンコーダの一例を示すブロック図である。
【
図3】本発明の実施形態を実装するように構成されたビデオデコーダの1つの例示的な構造を示すブロック図である。
【
図4】符号化装置または復号装置の一例を示すブロック図である。
【
図5】符号化装置または復号装置の他の例を示すブロック図である。
【
図6】マージおよびAMVP候補リスト構築において使用される空間的に近接するブロックの位置を示す図である。
【
図9】一実施形態によるビデオデコーダの1つの例示的な動作を示す流れ図である。
【
図10】一実施形態による、1つの例示的な動作を示す流れ図である。
【
図11】ビデオ処理装置の一例を示すブロック図である。
【発明を実施するための形態】
【0053】
以下、同一の参照符号の差異に関して何の特定の注記もない場合、それらの同一の参照符号は、同一の、または少なくとも機能的に同等の特徴を指す。
【0054】
以下の説明において、添付の図を参照し、これらの図は、本開示の一部を成し、例として、本発明の実施形態の特定の態様または本発明の実施形態が使用され得る特定の態様を示す。本発明の実施形態は、他の態様において使用されてもよく、これらの図に示されない構造的または論理的変更を含むことが理解される。以下の詳細な説明は、したがって、限定的な意味で理解すべきではなく、本発明の範囲は、添付の特許請求の範囲によって定義される。
【0055】
たとえば、説明する方法に関する開示は、この方法を実行するように構成された、対応するデバイスまたはシステムにも有効であり得、逆も同様であることが理解される。たとえば、1つまたは複数の特定の方法ステップについて説明する場合、対応するデバイスは、説明する1つまたは複数の方法ステップを実行するための1つまたは複数のユニットがたとえ図において明示的に説明または示されていない場合であっても、そのような1つまたは複数のユニット、たとえば、機能ユニットを含み得る(たとえば、1つのユニットが1つもしくは複数のステップを実行する、または複数のユニットが各々、複数のステップのうちの1つもしくは複数を実行する)。他方で、たとえば、特定の装置について1つまたは複数のユニット、たとえば、機能ユニットに基づいて説明される場合、対応する方法は、そのような1つまたは複数のステップが図において明示的に説明または示されていない場合ですら、1つまたは複数のユニットの機能性を実行するための1つのステップを含み得る(たとえば、1つのステップが1つもしくは複数のユニットの機能性を実行する、または複数のステップが各々、複数のユニットのうちの1つもしくは複数の機能性を実行する)。さらに、本明細書で説明する様々な例示的な実施形態および/または態様の特徴は、別段に明示的な規定がない限り、互いに組み合わされてよいことが理解される。
【0056】
ビデオコーディングは、一般に、ビデオまたはビデオシーケンスを形成するピクチャのシーケンスの処理を指す。「ピクチャ」という用語の代わりに、「フレーム」または「画像」という用語がビデオコーディングの分野において同義語として使用されることがある。本出願(または、本開示)で使用されるビデオコーディングは、ビデオ符号化またはビデオ復号のいずれかを指す。ビデオ符号化は、一般に、(より効率的な記憶および/または送信のための)ビデオピクチャを表すために必要とされるデータの量を低減するために元のビデオピクチャを(たとえば、圧縮によって)処理することを含めて、ソース側において行われる。ビデオ復号は、宛先側において行われ、一般に、ビデオピクチャを再構築するためにエンコーダと比較して逆処理を含む。ビデオピクチャ(または、後で説明されるように、概して、ピクチャ)の「コーディング」を指す実施形態は、ビデオシーケンスに対する「符号化」または「復号」のいずれかに関することを理解されたい。符号化部分と復号部分の組合せは、CODEC(コーディングおよび復号)とも呼ばれる。
【0057】
ロスレスビデオコーディングの場合、元のビデオピクチャは再構築可能であり、すなわち、再構築されたビデオピクチャは、(記憶中または送信中に送信損失または他のデータ損失がないと仮定すると)元のビデオピクチャと同じ品質を有する。ロッシービデオコーディングの場合、ビデオピクチャを表すデータの量を低減するために、たとえば、量子化による、さらなる圧縮が実行されるが、これらのビデオピクチャは、デコーダにおいて完全に再構築され得ず、すなわち、再構築されたビデオピクチャの品質は、元のビデオピクチャの品質と比較してより低いかまたは悪い。
【0058】
H.261以来、いくつかのビデオコーディング規格は、「ロッシー・ハイブリッド・ビデオ・コーデック」のグループに属する(すなわち、サンプル領域内の空間予測および時間予測と変換領域内で量子化を適用するための2D変換コーディングとを組み合わせる)。ビデオシーケンスの各ピクチャは、一般に、重複しないブロックのセットに分割され、コーディングは、一般に、ブロックレベルで行われる。言い換えれば、エンコーダにおいて、ビデオは、一般に、たとえば、予測ブロックを生成するために空間(イントラピクチャ)予測および時間(インターピクチャ)予測を使用し、残差ブロックを取得するために予測ブロックを現在ブロック(現在処理されている/処理されることになるブロック)から差し引き、残差ブロックを変換し、送信されることになるデータ量を低減する(圧縮)ために変換領域内で残差ブロックを量子化することによって、ブロック(ビデオブロック)レベルで処理され、すなわち、符号化される一方で、デコーダでは、エンコーダと対照的に、表現のために現在ブロックを再構築するために、符号化または圧縮されたブロックに逆処理が部分的に適用される。さらに、エンコーダは、デコーダ処理ループを複製し、両方が後続ブロックを処理するため、すなわち、コーディングするために、同一の予測(たとえば、イントラ予測およびインター予測)および/または再構築を生成するようにする。
【0059】
本明細書で使用する「ブロック」という用語は、ピクチャまたはフレームの一部分でありうる。説明の便宜上、本発明の実施形態は、本明細書において、高効率ビデオコーディング(HEVC)、またはITU-Tビデオコーディングエキスパートグループ(VCEG)およびISO/IECモーションピクチャエキスパートグループ(MPEG)のビデオコーディングに対するジョイントコラボレーションチーム(JCT-VC)によって開発された多目的ビデオコーディング(VVC)の基準ソフトウェアを参照しながら説明される。本発明の実施形態はHEVCまたはVVCに限定されないことを当業者は理解されよう。本発明の実施形態は、CU、PU、およびTUを参照することがある。HEVCでは、CTUは、コーディングツリーとして示される四分木構造を使用することによってCUに分割される。インターピクチャ(時間)予測を使用してピクチャエリアをコーディングするか、またはイントラピクチャ(空間)予測を使用してピクチャエリアをコーディングするかに関する決定は、CUレベルで行われる。各CUは、PU分割タイプに従って、1個、2個、または4個のPUにさらに分割され得る。1個のPUの中で、同じ予測プロセスが適用され、関連情報がPUベースでデコーダに送信される。PU分割タイプに基づいて予測プロセスを適用することによって残差ブロックを取得した後、CUは、CUに対するコーディングツリーと同様の他の四分木構造に従って、変換ユニット(TU)に分割され得る。最新のビデオ圧縮技術の開発では、コーディングブロックを分割するために、四分木および二分木(QTBT)分割フレームが使用される。QTBTブロック構造において、CUは、正方形または矩形のいずれかの形状を有し得る。たとえば、コーディングツリーユニット(CTU)は、まず四分木構造によって分割される。四分木リーフノードは、二分木構造によってさらに分割される。二分木リーフノードは、コーディングユニット(CU)と呼ばれ、そのセグメンテーションは、さらなる分割なしに予測および変換処理のために使用される。これは、CU、PU、およびTUが、QTBTコーディングブロック構造において同じブロックサイズを有することを意味する。並行して、QTBTブロック構造とともに使用されるべく多分割、たとえば、三分木分割も提案された。
【0060】
以下、エンコーダ20、デコーダ30、およびコーディングシステム10の実施形態は、
図1から
図3に基づいて説明される。
【0061】
図1Aは、1つの例示的なコーディングシステム10、たとえば、本出願(本開示)の技術を利用し得るビデオコーディングシステム10を示す、概念的または概略的なブロック図である。ビデオコーディングシステム10のエンコーダ20(たとえば、ビデオエンコーダ20)およびデコーダ30(たとえば、ビデオデコーダ30)は、本出願で説明する様々な例による技術を行うように構成され得るデバイスの例を表す。
図1Aに示すように、コーディングシステム10は、符号化されたデータ13を復号するために、符号化されたデータ13、たとえば、符号化されたピクチャ13を、たとえば、宛先デバイス14に提供するように構成されたソースデバイス12を含む。
【0062】
ソースデバイス12は、エンコーダ20を含み、追加として、すなわち、任意選択で、ピクチャソース16、前処理ユニット18、たとえば、ピクチャ前処理ユニット18、および通信インターフェースまたは通信ユニット22を含みうる。
【0063】
ピクチャソース16は、たとえば、実世界ピクチャをキャプチャするための、任意の種類のピクチャキャプチャデバイス、および/または任意の種類のピクチャもしくはコメント(スクリーンコンテンツコーディングの場合、スクリーン上の一部のテキストも符号化されることになるピクチャまたは画像の一部分と見なされる)生成デバイス、たとえば、コンピュータ動画ピクチャを生成するためのコンピュータグラフィックスプロセッサ、または実世界ピクチャ、コンピュータ動画ピクチャ(たとえば、スクリーンコンテンツ、仮想現実(VR)ピクチャ)、および/またはそれらの任意の組合せ(たとえば、拡張現実(AR)ピクチャ)を取得および/または提供するための任意の種類のデバイスを含んでもよく、またはそれらであってもよい。
【0064】
(デジタル)ピクチャは、強度値を有するサンプルの二次元配列もしくは二次元行列であるか、または二次元配列もしくは二次元行列と見なされることができる。配列内のサンプルは、ピクセル(ピクチャ要素の略)またはペル(pel)と呼ばれることもある。配列またはピクチャの水平方向および垂直方向(または、軸)のサンプル数は、ピクチャのサイズおよび/または解像度を定義する。色を表現するために、一般に、3つの色成分が採用され、すなわち、ピクチャは、3つのサンプル配列で表現され得るかまたは含み得る。RBGフォーマットまたは色空間では、ピクチャは、対応する赤、緑、および青のサンプル配列を含む。しかしながら、ビデオコーディングでは、各ピクセルは、一般に、輝度/色度フォーマットまたは色空間、たとえば、Y(ときには、代わりに、Lも使用される)によって示される輝度成分と、CbおよびCrによって示される2つの色度成分とを含む、YCbCrで表される。輝度(または、短く、ルマ)成分Yは、明るさまたは濃度強度(たとえば、グレイスケールピクチャにおけるような)を表し、2つの色度(または、短く、クロマ)成分CbおよびCrは、色度または色情報成分を表す。したがって、YCbCrフォーマットのピクチャは、輝度サンプル値(Y)の輝度サンプル配列、および色度値(CbおよびCr)の2つの色度サンプル配列を含む。RGBフォーマットのピクチャは、YCbCrフォーマットに変換(converted)または変換(transformed)されることが可能であり、逆も同様であり、このプロセスは、色変換(transformation)または色変換(conversion)とも呼ばれる。ピクチャがモノクロである場合、ピクチャは、輝度サンプル配列のみを含み得る。
【0065】
モノクロサンプリングでは、名目上ルマ配列と見なされる、1つのサンプル配列のみが存在する。
【0066】
4:2:0サンプリングでは、2つのクロマ配列の各々は、ルマ配列の半分の高さおよび半分の幅を有する。
【0067】
4:2:2サンプリングでは、2つのクロマ配列の各々は、ルマ配列の同じ高さおよび半分の幅を有する。
【0068】
4:4:4サンプリングでは、separate_colour_plane_flagの値に応じて、以下が適用される:
- separate_colour_plane_flagが0に等しい場合、2つのクロマ配列の各々は、ルマ配列と同じ高さおよび幅を有する。
- そうでない(separate_colour_plane_flagが1に等しい)場合、3つの色平面は、モノクロサンプリングされたピクチャとして別個に処理される。
【0069】
ピクチャソース16(たとえば、ビデオソース16)は、たとえば、ピクチャをキャプチャするためのカメラ、メモリ、たとえば、前にキャプチャもしくは生成されたピクチャを含むか、またはそれを記憶するピクチャメモリ、および/もしくはピクチャを取得もしくは受信するための任意の種類のインターフェース(内部または外部)であってよい。カメラは、たとえば、ローカルカメラ、または、たとえば、ソースデバイス内に一体化された、一体化カメラであってよく、メモリは、ローカルメモリ、または、たとえば、ソースデバイス内に一体化された、一体化メモリであってよい。インターフェースは、たとえば、外部ビデオソース、たとえば、カメラ、外部メモリ、または外部ピクチャ生成デバイス、たとえば、外部コンピュータグラフィックスプロセッサ、コンピュータ、またはサーバなど、外部ピクチャキャプチャデバイスからピクチャを受信するための外部インターフェースであってよい。インターフェースは、任意の種類のインターフェース、たとえば、任意の特性または標準化されたインターフェースプロトコルによる、ワイヤードインターフェースまたはワイヤレスインターフェース、光インターフェースであってよい。ピクチャデータ17を取得するためのインターフェースは、通信インターフェース22と同じインターフェースであってよく、または通信インターフェース22の一部分であってもよい。
【0070】
前処理ユニット18および前処理ユニット18によって行われる処理と区別して、ピクチャまたはピクチャデータ17(たとえば、ビデオデータ16)は、生ピクチャまたは生ピクチャデータ17と呼ばれることもある。
【0071】
前処理ユニット18は、(生)ピクチャデータ17を受信し、ピクチャデータ17に対して前処理を実行して、前処理されたピクチャ19または前処理されたピクチャデータ19を取得するように構成される。前処理ユニット18によって実行される前処理は、たとえば、トリミング、カラーフォーマット変換(たとえば、RGBからYCbCrへ)、色補正、またはノイズ除去を含み得る。前処理ユニット18は任意選択の構成要素であり得ることが理解され得る。
【0072】
エンコーダ20(たとえば、ビデオエンコーダ20)は、前処理されたピクチャデータ19を受信し、符号化されたピクチャデータ21を提供するように構成される(さらなる詳細は、以下で、たとえば、
図2または
図4に基づいて説明される)。
【0073】
ソースデバイス12の通信インターフェース22は、符号化されたピクチャデータ21を受信し、記憶または直接的な再構築のために、それを他のデバイス、たとえば、宛先デバイス14もしくは任意の他のデバイスに送信するように、または、それぞれ、符号化されたデータ13を記憶する前に、かつ/または、復号もしくは記憶のために、符号化されたデータ13を他のデバイス、たとえば、宛先デバイス14または任意の他のデバイスに送信する前に、符号化されたピクチャデータ21を処理するように構成され得る。
【0074】
宛先デバイス14は、デコーダ30(たとえば、ビデオデコーダ30)を含み、追加で、すなわち、任意選択で、通信インターフェースまたは通信ユニット28、後処理ユニット32、およびディスプレイデバイス34を含み得る。
【0075】
宛先デバイス14の通信インターフェース28は、符号化されたピクチャデータ21または符号化されたデータ13を、たとえば、ソースデバイス12から直接的にまたは任意の他のソース、たとえば、記憶デバイス、たとえば、符号化ピクチャデータ記憶デバイスから受信するように構成される。
【0076】
通信インターフェース22および通信インターフェース28は、ソースデバイス12と宛先デバイス14との間の直接的な通信リンク、たとえば、直接的なワイヤード接続もしくはワイヤレス接続を介して、または、任意の種類のネットワーク、たとえば、ワイヤードネットワークもしくはワイヤレスネットワーク、またはそれらの任意の種類の組合せ、または任意の種類のプライベートネットワークおよびパブリックネットワーク、またはそれらの任意の種類の組合せを介して、符号化されたピクチャデータ21または符号化されたデータ13を送信または受信するように構成され得る。
【0077】
通信インターフェース22は、たとえば、通信リンクまたは通信ネットワークを介して送信するために、符号化されたピクチャデータ21を適切なフォーマット、たとえば、パケットにパッケージングするように構成され得る。
【0078】
通信インターフェース22の相手方を成す通信インターフェース28は、たとえば、符号化されたピクチャデータ21を取得するために、符号化されたデータ13をパッケージング解除するように構成され得る。
【0079】
通信インターフェース22と通信インターフェース28は両方とも、ソースデバイス12から宛先デバイス14を指す、
図1Aの符号化されたピクチャデータ13に対する矢印によって示されるような一方向通信インターフェース、または双方向通信インターフェースとして構成されてよく、たとえば、接続をセットアップして、通信リンクおよび/またはデータ送信、たとえば、符号化されたピクチャデータ送信に関する任意の他の情報を肯定応答および交換するために、たとえば、メッセージを送信および受信するように構成されうる。
【0080】
デコーダ30は、符号化されたピクチャデータ21を受信し、復号されたピクチャデータ31または復号されたピクチャ31を提供するように構成される(さらなる詳細は、以下で、たとえば、
図3または
図5に基づいて説明される)。
【0081】
宛先デバイス14のポストプロセッサ32は、後処理されたピクチャデータ33、たとえば後処理されたピクチャ33を取得するために、復号されたピクチャデータ31(再構築されたピクチャデータとも呼ばれる)、たとえば復号されたピクチャ31を後処理するように構成される。後処理ユニット32によって行われる後処理は、たとえば、カラーフォーマット変換(たとえば、YCbCrからRGBへ)、色補正、トリミング、もしくはリサンプリング、または、たとえば、ディスプレイデバイス34によって、たとえば、表示のために復号されたピクチャデータ31を準備するための任意の他の処理を含み得る。
【0082】
宛先デバイス14のディスプレイデバイス34は、ピクチャを、たとえば、ユーザまたは視聴者に表示するために後処理されたピクチャデータ33を受信するように構成される。ディスプレイデバイス34は、再構築されたピクチャを表すための任意の種類のディスプレイ、たとえば、一体化されたまたは外部のディスプレイまたはモニタであってよいか、またはそれを備えてよい。ディスプレイは、たとえば、液晶ディスプレイ(LCD)、有機発光ダイオード(OLED)ディスプレイ、プラズマディスプレイ、プロジェクタ、マイクロLEDディスプレイ、液晶オンシリコン(LCoS:liquid crystal on silicon)、デジタルライトプロセッサ(DLP:digital light processor)、または任意の種類の他のディスプレイを含み得る。
【0083】
図1Aは、ソースデバイス12および宛先デバイス14を別個のデバイスとして示すが、デバイスの実施形態は、両方または両方の機能性、ソースデバイス12または対応する機能性、および宛先デバイス14または対応する機能性を備えてもよい。そのような実施形態では、ソースデバイス12または対応する機能性および宛先デバイス14または対応する機能性は、同じハードウェアおよび/もしくはソフトウェアを使用して、または別個のハードウェアおよび/もしくはソフトウェア、またはそれらの任意の組合せによって実装され得る。
【0084】
説明に基づいて当業者に明らかになるように、
図1Aに示すような、異なるユニットの機能性またはソースデバイス12および/もしくは宛先デバイス14内の機能性の存在および(正確な)分離は、実際のデバイスおよび適用例に応じて異なり得る。
【0085】
エンコーダ20(たとえば、ビデオエンコーダ20)およびデコーダ30(たとえば、ビデオデコーダ30)は各々、1つまたは複数のマイクロプロセッサ、デジタル信号プロセッサ(DSP)、特定用途向け集積回路(ASIC)、フィールドプログラマブルゲートアレイ(FPGA)、ディスクリート論理、ハードウェア、またはそれらの任意の組合せなど、様々な好適な回路のうちのいずれかとして実装され得る。これらの技術が部分的にソフトウェアにおいて実装される場合、デバイスは、好適な、非一時的コンピュータ可読記憶媒体内にソフトウェアに対する命令を記憶することができ、本開示の技術を実行するために、1つまたは複数のプロセッサを使用してハードウェア内で命令を実行し得る。(ハードウェア、ソフトウェア、ハードウェアとソフトウェアの組合せ、などを含めて)前述のうちのいずれも、1つまたは複数のプロセッサと見なされ得る。ビデオエンコーダ20およびビデオデコーダ30は各々、1つまたは複数のエンコーダまたはデコーダ内に含まれてよく、それらのいずれもそれぞれのデバイス内に組み合わされたエンコーダ/デコーダ(CODEC)の部分として一体化され得る。
【0086】
ソースデバイス12は、ビデオ符号化デバイスまたはビデオ符号化装置と呼ばれることがある。宛先デバイス14は、ビデオ復号デバイスまたはビデオ復号装置と呼ばれることがある。ソースデバイス12および宛先デバイス14は、ビデオコーディングデバイスまたはビデオコーディング装置の例であり得る。
【0087】
ソースデバイス12および宛先デバイス14は、任意の種類のハンドヘルドデバイスまたは固定デバイス、たとえば、ノートブックコンピュータまたはラップトップコンピュータ、モバイルフォン、スマートフォン、タブレットまたはタブレットコンピュータ、カメラ、デスクトップコンピュータ、セットトップボックス、テレビジョン、ディスプレイデバイス、デジタルメディアプレーヤー、ビデオゲーム機、ビデオストリーミングデバイス(コンテンツサービスサーバまたはコンテンツ配信サーバなど)、ブロードキャスト受信器デバイス、ブロードキャスト送信器デバイス、などを含めて、幅広い範囲のデバイスのうちのいずれかを備えてよく、何のオペレーティングシステムも使用しなくてよいか、または任意の種類のオペレーティングシステムを使用してよい。
【0088】
場合によっては、ソースデバイス12および宛先デバイス14は、ワイヤレス通信のために装備され得る。したがって、ソースデバイス12および宛先デバイス14は、ワイヤレス通信デバイスであってもよい。
【0089】
場合によっては、
図1Aに示すビデオコーディングシステム10は、単なる一例であり、本出願の技術は、符号化デバイスと復号デバイスとの間に何らかのデータ通信を必ずしも含むとは限らないビデオコーディング設定(たとえば、ビデオ符号化またはビデオ復号)に適用され得る。他の例では、データは、ローカルメモリから取り出され、ネットワークを介してストリーミングされる、などである。ビデオ符号化デバイスは、データを符号化してメモリに記憶することができ、かつ/またはビデオ復号デバイスは、メモリからデータを取り出して復号することができる。いくつかの例では、符号化および復号は、互いと通信せず、メモリに対してデータを単に符号化し、かつ/またはメモリからデータを取り出して復号するデバイスによって実行される。
【0090】
ビデオエンコーダ20を参照しながら説明した上記の例の各々に関して、ビデオデコーダ30は、逆のプロセスを実行するように構成され得ることを理解されたい。シンタックス要素のシグナリングに関しては、ビデオデコーダ30は、そのようなシンタックス要素を受信してパースし、それに応じて、関連するビデオデータを復号するように構成される。いくつかの例では、ビデオエンコーダ20は、1つまたは複数のシンタックス要素を符号化されたビデオビットストリームにエントロピー符号化し得る。そのような例では、ビデオデコーダ30は、そのようなシンタックス要素をパースし、それに応じて、関連するビデオデータを復号し得る。
【0091】
図1Bは、1つの例示的な実施形態による、
図2のエンコーダ20および/または
図3のデコーダ30を含む、他の例示的なビデオコーディングシステム40の例示的な図である。システム40は、本出願で説明する様々な例による技術を実装し得る。示される実装形態では、ビデオコーディングシステム40は、撮像デバイス41、ビデオエンコーダ100、ビデオデコーダ30(および/または、処理ユニット46の論理回路47を介して実装されるビデオコーダ)、アンテナ42、1つまたは複数のプロセッサ43、1つまたは複数のメモリストア44、および/またはディスプレイデバイス45を含み得る。
【0092】
例示するように、撮像デバイス41、アンテナ42、処理ユニット46、論理回路47、ビデオエンコーダ20、ビデオデコーダ30、プロセッサ43、メモリストア44、および/またはディスプレイデバイス45は、互いに通信することが可能であり得る。上述したように、ビデオエンコーダ20とビデオデコーダ30の両方を用いて示されているが、ビデオコーディングシステム40は、様々な例では、ビデオエンコーダ20のみ、またはビデオデコーダ30のみを含みうる。
【0093】
図示するように、いくつかの例では、ビデオコーディングシステム40は、アンテナ42を含み得る。アンテナ42は、たとえば、ビデオデータの符号化されたビットストリームを送信または受信するように構成され得る。さらに、いくつかの例では、ビデオコーディングシステム40は、ディスプレイデバイス45を含み得る。ディスプレイデバイス45は、ビデオデータを提示するように構成され得る。図示するように、いくつかの例では、論理回路47は、処理ユニット46を介して実装され得る。処理ユニット46は、特定用途向け集積回路(ASIC)論理、グラフィックスプロセッサ、汎用プロセッサなどを含み得る。ビデオコーディングシステム40は、特定用途向け集積回路(ASIC)論理、グラフィックスプロセッサ、汎用プロセッサ、などを同様に含み得る、任意のプロセッサ43をやはり含み得る。いくつかの例では、論理回路47は、ハードウェア、ビデオコーディング専用ハードウェア、などを介して実装され得、プロセッサ43は、汎用ソフトウェア、オペレーティングシステムなどを介して実装され得る。加えて、メモリストア44は、揮発性メモリ(たとえば、スタティックランダムアクセスメモリ(SRAM)、ダイナミックランダムアクセスメモリ(DRAM)、など)または不揮発性メモリ(たとえば、フラッシュメモリ、など)など、任意のタイプのメモリであってよい。非限定的な例では、メモリストア44は、キャッシュメモリによって実装され得る。いくつかの例では、論理回路47は、(たとえば、画像バッファの実装のために)メモリストア44にアクセスし得る。他の例では、論理回路47および/または処理ユニット46は、画像バッファなどの実装のためにメモリストア(たとえば、キャッシュなど)を含み得る。
【0094】
いくつかの例では、論理回路を介して実装されるビデオエンコーダ100は、画像バッファ(たとえば、処理ユニット46またはメモリストア44のいずれかを介して))およびグラフィックス処理ユニット(たとえば、処理ユニット46を介して)を含み得る。グラフィックス処理ユニットは、画像バッファに通信可能に結合され得る。グラフィックス処理ユニットは、
図2に関して説明されるような様々なモジュールを実施するために論理回路47を介して実装されるビデオエンコーダ100および/または本明細書に記載の任意の他のエンコーダシステムもしくはサブシステムを含み得る。論理回路は、本明細書で説明するような様々な動作を実行するように構成され得る。
【0095】
ビデオデコーダ30は、
図3のデコーダ30および/または本明細書に記載の任意の他のデコーダシステムもしくはサブシステムに関して説明するような様々なモジュールを実施するために論理回路47を介して実装されるのと同様の方法で実装され得る。いくつかの例では、ビデオデコーダ30は、論理回路を介して実装可能であり、画像バッファ(たとえば、処理ユニット420またはメモリストア44のいずれかを介して))およびグラフィックス処理ユニット(たとえば、処理ユニット46を介して)を含み得る。グラフィックス処理ユニットは、画像バッファに通信可能に結合され得る。グラフィックス処理ユニットは、
図3に関して説明するような様々なモジュールを実施するために論理回路47を介して実装されるようなビデオデコーダ30および/または本明細書に記載の任意の他のデコーダシステムもしくはサブシステムを含み得る。
【0096】
いくつかの例では、ビデオコーディングシステム40のアンテナ42は、ビデオデータの符号化されたビットストリームを受信するように構成され得る。説明されるように、符号化されたビットストリームは、コーディング分割に関連するデータ(たとえば、変換係数または量子化変換係数、(説明されるような)任意のインジケータ、および/またはコーディング区分を定義するデータ)など、本明細書で説明されるようにビデオフレームを符号化することに関連する、データ、インジケータ、インデックス値、モード選択データなどを含み得る。ビデオコーディングシステム40は、アンテナ42に結合され、符号化されたビットストリームを復号するように構成されたビデオデコーダ30をやはり含み得る。ディスプレイデバイス45は、ビデオフレームを提示するように構成される。
【0097】
エンコーダおよび符号化方法
図2は、本出願の技術を実装するように構成された、1つの例示的なビデオエンコーダ20の概略的/概念的なブロック図を示す。
図2の例では、ビデオエンコーダ20は、残差計算ユニット204、変換処理ユニット206、量子化ユニット208、逆量子化ユニット210、および逆変換処理ユニット212、再構築ユニット214、バッファ216、ループフィルタユニット220、復号ピクチャバッファ(DPB)230、予測処理ユニット260、およびエントロピー符号化ユニット270を含む。予測処理ユニット260は、インター予測ユニット244、イントラ予測ユニット254、およびモード選択ユニット262を含み得る。インター予測ユニット244は、動き推定ユニットおよび動き補償ユニット(図示せず)を含み得る。
図2に示すようなビデオエンコーダ20は、ハイブリッドビデオエンコーダ、またはハイブリッドビデオコーデックによるビデオエンコーダと呼ばれることもある。
【0098】
たとえば、残差計算ユニット204、変換処理ユニット206、量子化ユニット208、予測処理ユニット260、およびエントロピー符号化ユニット270は、エンコーダ20の順方向信号経路を形成するが、たとえば、逆量子化ユニット210、逆変換処理ユニット212、再構築ユニット214、バッファ216、ループフィルタ220、復号ピクチャバッファ(DPB)230、予測処理ユニット260は、エンコーダの後方信号経路を形成し、エンコーダの後方信号経路は、デコーダ(
図3のデコーダ30を参照されたい)の信号経路に対応する。
【0099】
エンコーダ20は、たとえば、入力202によって、ピクチャ20またはピクチャ201のブロック203、たとえば、ビデオまたはビデオシーケンスを形成するピクチャのシーケンスのピクチャを受信するように構成される。ピクチャブロック203は、現在ピクチャブロックまたはコーディングされることになるピクチャブロックと呼ばれることもあり、ピクチャ201は、(特に、ビデオコーディングにおいて、現在ピクチャを他のピクチャ、たとえば、同じビデオシーケンス、すなわち、現在ピクチャをやはり含むビデオシーケンスの前に符号化されたかつ/または復号されたピクチャと区別するために)現在ピクチャまたはコーディングされることになるピクチャと呼ばれることがある。
【0100】
分割
エンコーダ20の実施形態は、ピクチャ201を、一般には複数の重複しないブロックである複数のブロック、たとえば、ブロック203のようなブロックに分割するように構成された分割ユニット(
図2に図示せず)を含み得る。分割ユニットは、ビデオシーケンスのすべてのピクチャに対して同じブロックサイズ、およびブロックサイズを定義する対応するグリッドを使用するか、またはピクチャ同士の間またはピクチャのサブセットもしくはグループ同士の間でブロックサイズを変更し、各ピクチャを対応するブロックに分割するように構成され得る。
【0101】
一例では、ビデオエンコーダ20の予測処理ユニット260は、上述した分割技術の任意の組合せを行うように構成され得る。
【0102】
ピクチャ201のように、ブロック203は、この場合も、ピクチャ201よりも小さな寸法のものではあるが、強度値(サンプル値)を有するサンプルの二次元配列もしくは二次元行列であるか、または二次元配列もしくは二次元行列と見なされうる。言い換えれば、ブロック203は、適用されるカラーフォーマットに応じて、たとえば、1つのサンプル配列(たとえば、モノクロピクチャ201の場合、1つのルマ配列)、または3つのサンプル配列(たとえば、カラーピクチャ201の場合、1つのルマ配列および2つのクロマ配列)、または任意の他の数のおよび/もしくは種類の配列を含み得る。ブロック203の水平方向および垂直方向(または、軸)のサンプル数は、ブロック203のサイズを定義する。
【0103】
図2に示すエンコーダ20は、ピクチャ201をブロック単位で符号化するように構成され、たとえば、符号化および予測は、ブロック203ごとに行われる。
【0104】
残差計算
残差計算ユニット204は、たとえば、サンプル領域内の残差ブロック205を取得するために、サンプルごとに(ピクセルごとに)予測ブロック265のサンプル値をピクチャブロック203のサンプル値から差し引くことによって、ピクチャブロック203および予測ブロック265(予測ブロック265に関するさらなる詳細は後述する)に基づいて、残差ブロック205を計算するように構成される。
【0105】
変換
変換処理ユニット206は、変換領域内の変換係数207を取得するために、変換、たとえば、離散コサイン変換(DCT)または離散サイン変換(DST)を残差ブロック205のサンプル値に適用するように構成される。変換係数207は、変換残差係数と呼ばれることもあり、変換領域内の残差ブロック205を表す。
【0106】
変換処理ユニット206は、HEVC/H.265のために指定された変換など、DCT/DSTの整数近似を適用するように構成され得る。直交DCT変換と比較して、そのような整数近似は、一般に、ある係数によってスケーリングされる。順変換および逆変換によって処理される残差ブロックの基準を保つために、変換プロセスの一部として追加のスケーリング係数が適用される。スケーリング係数は、一般に、スケーリング係数がシフト演算では2の冪乗であるなど、一定の制約、変換係数のビット深度、精度と実装コストの間のトレードオフなどに基づいて選定される。特定のスケーリング係数は、たとえば、逆変換処理ユニット212によって、デコーダ30において、逆変換(また、たとえば、逆変換処理ユニット212によって、エンコーダ20において、対応する逆変換)のために指定され、それに応じて、たとえば、変換処理ユニット206によって、エンコーダ20において、対応するスケーリング係数が順変換のために指定され得る。
【0107】
量子化
量子化ユニット208は、たとえば、スカラー量子化またはベクトル量子化を適用することによって、量子化変換係数209を取得するために、変換係数207を量子化するように構成される。量子化変換係数209は、量子化残差係数209と呼ばれることもある。量子化プロセスは、変換係数207のうちのいくつかまたはすべてに関連するビット深度を低減し得る。たとえば、nビット変換係数は、量子化中に、mビット変換係数へと切り捨てされてもよく、ここで、nはmよりも大きい。量子化の程度は、量子化パラメータ(QP)を調整することによって修正され得る。たとえば、スカラー量子化の場合、より細かい量子化またはより粗い量子化を達成するために、異なるスケーリングが適用され得る。より小さな量子化ステップサイズは、より細かい量子化に対応するのに対して、より大きな量子化ステップサイズは、より粗い量子化に対応する。適用可能な量子化ステップサイズは、量子化パラメータ(QP)によって示され得る。量子化パラメータは、たとえば、適用可能な量子化ステップサイズの事前定義されたセットに対するインデックスであり得る。たとえば、小さい量子化パラメータは、細かい量子化(小さな量子化ステップサイズ)に対応し得、大きな量子化パラメータは、粗い量子化(大きな量子化ステップサイズ)に対応し得、またはその逆であり得る。量子化は、量子化ステップサイズによる除算を含んでよく、たとえば、逆量子化210による、対応するまたは逆の量子化解除は、量子化ステップサイズによる乗算を含んでよい。いくつかの規格、たとえば、HEVCによる実施形態は、量子化ステップサイズを決定するために、量子化パラメータを使用するように構成され得る。概して、量子化ステップサイズは、除算を含めて、等式の固定小数点近似を使用して、量子化パラメータに基づいて計算され得る。残差ブロックの基準を復元するために、追加のスケーリング係数が量子化および量子化解除のために導入されてよく、残差ブロックの基準は、量子化ステップサイズおよび量子化パラメータに対する等式の固定小数点近似において使用されるスケーリングにより修正され得る。1つの例示的な実装形態では、逆変換および量子化解除のスケーリングは、組み合わされてよい。あるいは、カスタマイズされた量子化テーブルが使用され、たとえば、ビットストリーム内で、エンコーダからデコーダにシグナリングされてよい。量子化は、損失のある演算であり、損失は、量子化ステップサイズの増大とともに増大する。
【0108】
逆量子化ユニット210は、たとえば、量子化ユニット208と同じ量子化ステップサイズに基づいて、またはそれを使用して、量子化ユニット208によって適用される量子化方式の逆を適用することによって、量子化解除係数211を取得するために、量子化係数に対して量子化ユニット208の逆量子化を適用するように構成される。量子化解除係数211は、量子化解除された残差係数211と呼ばれることもあり、一般に、量子化による損失により変換係数と同一ではないが、変換係数207に対応する。
【0109】
逆変換処理ユニット212は、サンプル領域内で逆変換ブロック213を取得するために、変換処理ユニット206によって適用される変換の逆変換、たとえば、逆離散コサイン変換(DCT)または逆離散サイン変換(DST)を適用するように構成される。逆変換ブロック213は、逆変換量子化解除されたブロック213または逆変換残差ブロック213と呼ばれることもある。
【0110】
再構築ユニット214(たとえば、加算器214)は、たとえば、再構築された残差ブロック213のサンプル値と予測ブロック265のサンプル値とを加算することによって、逆変換ブロック213(すなわち、再構築された残差ブロック213)を予測ブロック265に加えて、サンプル領域内で再構築されたブロック215を取得するように構成される。
【0111】
任意の、バッファユニット216(または、短く「バッファ」216)、たとえばラインバッファ216は、たとえばイントラ予測のために、再構築されたブロック215およびそれぞれのサンプル値をバッファリングまたは記憶するように構成される。さらなる実施形態では、エンコーダは、任意の種類の推定および/または予測、たとえば、イントラ予測のために、フィルタリングされていない、再構築されたブロックおよび/またはバッファユニット216内に記憶されたそれぞれのサンプル値を使用するように構成され得る。
【0112】
エンコーダ20の実施形態は、たとえばバッファユニット216が、イントラ予測254のためだけではなく、ループフィルタユニット220(
図2に図示せず)に対しても、再構築されたブロック215を記憶するために使用されるように、かつ/または、たとえばバッファユニット216および復号ピクチャバッファユニット230が1つのバッファを形成するように、構成され得る。さらなる実施形態は、フィルタリングされたブロック221および/または復号ピクチャバッファ230からのブロックまたはサンプル(両方とも
図2に図示せず)をイントラ予測254のための入力または基礎として使用するように構成され得る。
【0113】
ループフィルタユニット220(または、短く「ループフィルタ」220)は、たとえばピクセル遷移を平滑にするために、またはさもなければ、ビデオ品質を改善するために、再構築されたブロック215をフィルタリングして、フィルタリングされたブロック221を取得するように構成される。ループフィルタユニット220は、デブロッキングフィルタ、サンプル適応オフセット(SAO:sample-adaptive offset)フィルタ、または他のフィルタ、たとえばバイラテラルフィルタ、または適応ループフィルタ(ALF:adaptive loop filter)、または鮮明化(sharpening)もしくは平滑化フィルタ、あるいは協調フィルタなど、1つまたは複数のループフィルタを表すことが意図される。ループフィルタユニット220はインループフィルタであるとして、
図2に示されているが、他の構成では、ループフィルタユニット220は、ポストループフィルタとして実装され得る。フィルタリングされたブロック221は、フィルタリングされた、再構築されたブロック221と呼ばれることもある。復号ピクチャバッファ230は、ループフィルタユニット220が、再構築されたコーディングブロックに対してフィルタリング動作を行った後、再構築されたコーディングブロックを記憶し得る。
【0114】
エンコーダ20の実施形態(それぞれ、ループフィルタユニット220)は、たとえば、デコーダ30が復号のために同じループフィルタパラメータを受け取って適用することができるように、ループフィルタパラメータ(サンプル適応オフセット情報など)を、たとえば、直接的に、またはエントロピー符号化ユニット270もしくは任意の他のエントロピーコーディングユニットを介してエントロピー符号化して出力するように構成され得る。
【0115】
復号ピクチャバッファ(DPB)230は、ビデオエンコーダ20によってビデオデータを符号化する際に使用するための参照ピクチャデータを記憶する参照ピクチャメモリであってよい。DPB230は、同期DRAM(SDRAM)、磁気抵抗RAM(MRAM)、抵抗RAM(RRAM(登録商標))を含む、ダイナミックランダムアクセスメモリ(DRAM)、または他のタイプのメモリデバイスなど、様々なメモリデバイスのうちのいずれかによって形成され得る。DPB230およびバッファ216は、同じメモリデバイスまたは別個のメモリデバイスによって提供され得る。いくつかの例では、復号ピクチャバッファ(DPB)230は、フィルタリングされたブロック221を記憶するように構成される。復号ピクチャバッファ230は、同じ現在ピクチャのまたは異なるピクチャ、たとえば前に再構築されたピクチャの、他の前にフィルタリングされたブロック、たとえば前に再構築されフィルタリングされたブロック221、を記憶するようにさらに構成されてよく、完全な前に再構築された、すなわち、復号されたピクチャ(および、対応する参照ブロックおよびサンプル)および/または部分的に再構築された現在ピクチャ(および、対応する参照ブロックおよびサンプル)を、たとえばインター予測のために提供し得る。いくつかの例では、再構築されたブロック215がインループフィルタリングなしに再構築される場合、復号ピクチャバッファ(DPB)230は、再構築されたブロック215を記憶するように構成される。
【0116】
ブロック予測処理ユニット260と呼ばれることもある予測処理ユニット260は、ブロック203(現在ピクチャ201の現在ブロック203)および再構築されたピクチャデータ、たとえば同じ(現在)ピクチャの参照サンプルを、バッファ216から、かつ/または1つもしくは複数の前に復号されたピクチャからの参照ピクチャデータ231を復号ピクチャバッファ230から受信または取得し、そのようなデータを予測のために、すなわち、インター予測されたブロック245またはイントラ予測されたブロック255であってよい予測ブロック265を提供するために、処理するように構成される。
【0117】
モード選択ユニット262は、予測モード(たとえば、イントラ予測モードまたはインター予測モード)、および/または残差ブロック205の計算のために、かつ再構築されたブロック215の再構築のために、予測ブロック265として使用されることになる対応する予測ブロック245または255を選択するように構成され得る。
【0118】
モード選択ユニット262の実施形態は、(たとえば、予測処理ユニット260によってサポートされる予測モードから)、最良の一致、すなわち言い換えれば、最小残差(最小残差は、送信もしくは記憶のためのより良好な圧縮を意味する)、または最小シグナリングオーバヘッド(最小シグナリングオーバヘッドは、送信もしくは記憶のためのより良好な圧縮を意味する)を与えるもの、または両方を考慮するか、両方のバランスをとるものである予測モードを選択するように構成され得る。モード選択ユニット262は、レート歪み最適化(RDO:rate distortion optimization)に基づいて予測モードを決定するように、すなわち、最小レート歪み最適化を提供する予測モード、またはどの関連付けられるレート歪みが予測モード選択基準を少なくとも満たすかを選択するように構成され得る。
【0119】
以下、1つの例示的なエンコーダ20によって行われる予測処理(たとえば、予測処理ユニット260およびモード選択(たとえば、モード選択ユニット262による)について、より詳細に説明する。
【0120】
上述したように、エンコーダ20は、(所定の)予測モードの集合から、最良のまたは最適な予測モードを決定または選択するように構成される。予測モードの集合は、たとえば、イントラ予測モードおよび/またはインター予測モードを含み得る。
【0121】
イントラ予測モードの集合は、35個の異なるイントラ予測モード、たとえばDC(または、平均)モードおよび平面モードなどの無指向性モード、もしくは、たとえばH.265において定義されるような指向性モードを含み得るか、または67個の異なるイントラ予測モード、たとえばDC(または、平均)モードおよび平面モードなどの無指向性モード、もしくは、たとえば開発中のH.266において定義されるような指向性モードを含み得る。
【0122】
インター予測モードの集合(または、可能なインター予測モード)は、利用可能な参照ピクチャ(すなわち、たとえば、DBP230内に記憶された、前の少なくとも部分的に復号されたピクチャ)、および他のインター予測パラメータ、たとえば最も一致する参照ブロックを探索するために、参照ピクチャの参照ピクチャ全体が使用されるか、もしくは参照ピクチャの一部分、たとえば、現在ブロックのエリアの周囲の探索ウィンドウエリアのみが使用されるか、かつ/または、たとえば、ピクセル補間、たとえば、ハーフ/セミペル(semi-pel)および/もしくは1/4ペル補間が適用されるか、もしくは適用されないか、に依存する。
【0123】
上記の予測モードに加えて、スキップモードおよび/または直接モードが適用され得る。
【0124】
予測処理ユニット260は、たとえば、四分木分割(QT)、二分木分割(BT)、もしくは三分木分割(TT)、またはそれらの任意の組合せを反復的に使用して、ブロック203をより小さなブロック区分またはサブブロックに分割し、たとえば、ブロック区分またはサブブロックの各々に対する予測を行うようにさらに構成可能であり、モード選択は、分割されたブロック203のツリー構造およびブロック区分またはサブブロックの各々に適用される予測モードの選択を含む。
【0125】
インター予測ユニット244は、動き推定(ME)ユニット(
図2に図示せず)および動き補償(MC)ユニット(
図2に図示せず)を含み得る。動き推定ユニットは、動き推定のために、ピクチャブロック203(現在ピクチャ201の現在ピクチャブロック203)および復号されたピクチャ231、または少なくとも1つもしくは複数の前に再構築されたブロック、たとえば、1つもしくは複数の他の/異なる前に復号されたピクチャ231の再構築されたブロック、を受信または取得するように構成される。たとえば、ビデオシーケンスは、現在ピクチャおよび前に復号されたピクチャ231を含んでよく、または、言い換えれば、現在ピクチャおよび前に復号されたピクチャ231は、ビデオシーケンスを形成するピクチャのシーケンスの部分であり得るか、またはそれを形成し得る。
【0126】
エンコーダ20は、たとえば、複数の他のピクチャの同じまたは異なるピクチャの複数の参照ブロックから1個の参照ブロックを選択し、参照ピクチャ(または、参照ピクチャインデックス、…)および/または参照ブロックの位置(x座標、y座標)と現在ブロックの位置との間のオフセット(空間オフセット)をインター予測パラメータとして動き推定ユニット(
図2に図示せず)に提供するように構成され得る。このオフセットは、動きベクトル(MV)とも呼ばれる。
【0127】
動き補償ユニットは、インター予測パラメータを取得し、たとえば、受信し、インター予測パラメータに基づいて、またはそれを使用して、インター予測を行い、インター予測ブロック245を取得するように構成される。動き補償ユニット(
図2に図示せず)によって行われる動き補償は、動き推定によって決定された動き/ブロックベクトルに基づいて、場合によっては、サブピクセル精度に対する補間を行い、予測ブロックをフェッチまたは生成することを必要とし得る。補間フィルタリングは、既知のピクセルサンプルから追加のピクセルサンプルを生成し、それにより、潜在的に、ピクチャブロックをコーディングするために使用され得る候補予測ブロックの数を増大し得る。現在ピクチャブロックのPUに対する動きベクトルを受け取ると、動き補償ユニット246は、参照ピクチャリストのうちの1つの中で動きベクトルが指す予測ブロックを位置特定し得る。動き補償ユニット246は、ビデオスライスのピクチャブロックを復号する際にビデオデコーダ30によって使用するためのブロックおよびビデオスライスに関連付けられるシンタックス要素を生成することもできる。
【0128】
イントラ予測ユニット254は、イントラ推定のために、ピクチャブロック203(現在ピクチャブロック)および同じピクチャの1つまたは複数の前に再構築されたブロック、たとえば再構築された近接ブロックを取得するように、たとえば受信するように、構成される。エンコーダ20は、たとえば、イントラ予測モードを複数の(所定の)イントラ予測モードから選択するように構成され得る。
【0129】
エンコーダ20の実施形態は、最適化基準、たとえば、最小残差(たとえば、現在ピクチャブロック203に最も類似する予測ブロック255を提供するイントラ予測モード)または最小レート歪みに基づいて、イントラ予測モードを選択するように構成され得る。
【0130】
イントラ予測ユニット254は、イントラ予測パラメータ、たとえば、選択されたイントラ予測モード、に基づいて、イントラ予測ブロック255を決定するようにさらに構成される。いずれの場合も、ブロックに対するイントラ予測モードを選択した後、イントラ予測ユニット254はまた、イントラ予測パラメータ、すなわち、そのブロックに対して選択されたイントラ予測モードを示す情報をエントロピー符号化ユニット270に与えるように構成される。一例では、イントラ予測ユニット254は、後で説明するイントラ予測技術の任意の組合せを行うように構成され得る。
【0131】
エントロピー符号化ユニット270は、エントロピー符号化アルゴリズムまたはエントロピー符号化方式(たとえば、可変長コーディング(VLC)方式、コンテキスト適応型VLC方式(CALVC:context adaptive VLC)、算術コーディング方式、コンテキスト適応型バイナリ算術コーディング(CABAC:context adaptive binary arithmetic coding)、シンタックスベースのコンテキスト適応型バイナリ算術コーディング(SBAC:syntax-based context-adaptive binary arithmetic coding)、確率間隔分割エントロピー(PIPE:probability interval partitioning entropy)コーディング、または他のエントロピー符号化方法論もしくはエントロピー符号化技術)を、量子化残差係数209、インター予測パラメータ、イントラ予測パラメータ、および/またはループフィルタパラメータに対して、個々にまたは一緒に適用して(または、まったく適用せずに)、出力272によって、たとえば、符号化されたビットストリーム21の形で出力され得る、符号化されたピクチャデータ21を取得するように構成される。符号化されたビットストリーム21は、ビデオデコーダ30に送信されてもよく、またはビデオデコーダ30による後の送信または取出しのためにアーカイブに保管されてもよい。エントロピー符号化ユニット270は、コーディングされている現在ビデオスライスに対する他のシンタックス要素をエントロピー符号化するようにさらに構成され得る。
【0132】
ビデオエンコーダ20の他の構造的な変形例が、ビデオストリームを符号化するために使用され得る。たとえば、非変換ベースのエンコーダ20は、一定のブロックまたはフレームについて、変換処理ユニット206なしに、残差信号を直接的に量子化し得る。他の実装形態では、エンコーダ20は、量子化ユニット208および逆量子化ユニット210を組み合わせて単一のユニットにすることができる。
【0133】
図3は、本出願の技術を実装するように構成された、1つの例示的なビデオデコーダ30を示す。ビデオデコーダ30は、復号されたピクチャ131を取得するために、たとえば、エンコーダ100によって符号化された、符号化されたピクチャデータ(たとえば、符号化されたビットストリーム)21を受信するように構成される。復号プロセス中、ビデオデコーダ30は、ビデオデータ、たとえば、符号化されたビデオスライスのピクチャブロックを表す、符号化されたビデオビットストリームおよび関連付けられるシンタックス要素をビデオエンコーダ100から受け取る。
【0134】
図3の例では、デコーダ30は、エントロピー復号ユニット304、逆量子化ユニット310、逆変換処理ユニット312、再構築ユニット314(たとえば、加算器314)、バッファ316、ループフィルタ320、復号ピクチャバッファ330、および予測処理ユニット360を含む。予測処理ユニット360は、インター予測ユニット344、イントラ予測ユニット354、およびモード選択ユニット362を含み得る。ビデオデコーダ30は、いくつかの例では、
図2からのビデオエンコーダ100に関して説明した符号化パスに対して概して逆の復号パスを行い得る。
【0135】
エントロピー復号ユニット304は、たとえば、量子化係数309および/または復号されたコーディングパラメータ(
図3に図示せず)、たとえば、インター予測パラメータのうちの(復号された)いずれかまたはすべて、イントラ予測パラメータ、ループフィルタパラメータ、および/または他のシンタックス要素を取得するために、符号化されたピクチャデータ21に対してエントロピー復号を行うように構成される。エントロピー復号ユニット304は、インター予測パラメータ、イントラ予測パラメータ、および/または他のシンタックス要素を予測処理ユニット360に転送するようにさらに構成される。ビデオデコーダ30は、ビデオスライスレベルおよび/またはビデオブロックレベルでシンタックス要素を受け取り得る。
【0136】
逆量子化ユニット310は、機能の点で逆量子化ユニット110と同一であってよく、逆変換処理ユニット312は、機能の点で逆変換処理ユニット112と同一であってよく、再構築ユニット314は、機能の点で同一の再構築ユニット114であってよく、バッファ316は、機能の点でバッファ116と同一であってよく、ループフィルタ320は、機能の点でループフィルタ120と同一であってよく、復号ピクチャバッファ330は、機能の点で復号ピクチャバッファ130と同一であってよい。
【0137】
予測処理ユニット360は、インター予測ユニット344およびイントラ予測ユニット354を含んでよく、インター予測ユニット344は、機能の点でインター予測ユニット144に類似してよく、イントラ予測ユニット354は、機能の点でイントラ予測ユニット154に類似してよい。予測処理ユニット360は、一般に、ブロック予測を行うように、かつ/または予測ブロック365を符号化されたデータ21から取得し、予測関係のパラメータおよび/または選択された予測モードに関する情報を、たとえば、エントロピー復号ユニット304から(明示的にまたは暗示的に)受信または取得するように構成される。
【0138】
ビデオスライスがイントラコーディングされた(I)スライスとしてコーディングされるとき、予測処理ユニット360のイントラ予測ユニット354は、シグナリングされたイントラ予測モード、および現在フレームまたは現在ピクチャの前に復号されたブロックからのデータに基づいて、現在ビデオスライスのピクチャブロックに対する予測ブロック365を生成するように構成される。ビデオフレームがインターコーディングされた(すなわち、BまたはP)スライスとしてコーディングされるとき、予測処理ユニット360のインター予測ユニット344(たとえば、動き補償ユニット)は、動きベクトル、およびエントロピー復号ユニット304から受け取った他のシンタックス要素に基づいて、現在ビデオスライスのビデオブロックに対する予測ブロック365を作成するように構成される。インター予測の場合、予測ブロックは、参照ピクチャリストのうちの1つの中の参照ピクチャのうちの1つから作成され得る。ビデオデコーダ30は、DPB330内に記憶された参照ピクチャに基づいて、デフォルト構築技術を使用して、参照フレームリスト、すなわち、リスト0およびリスト1を構築し得る。
【0139】
予測処理ユニット360は、動きベクトルおよび他のシンタックス要素をパースすることによって、現在ビデオスライスのビデオブロックに関する予測情報を決定するように構成され、予測情報を使用して、復号されている現在ビデオブロックに対する予測ブロックを作成する。たとえば、予測処理ユニット360は、受信されたシンタックス要素のうちのいくつかを使用して、ビデオスライスのビデオブロックをコーディングするために使用される予測モード(たとえば、イントラ予測またはインター予測)、インター予測スライスタイプ(たとえば、Bスライス、Pスライス、またはGPBスライス)、スライスに対する参照ピクチャリストのうちの1つまたは複数に関する構築情報、スライスの各インター符号化されたビデオブロックに対する動きベクトル、スライスの各インターコーディングされたビデオブロックに対するインター予測状態、および現在ビデオスライス内のビデオブロックを復号するための他の情報を決定する。
【0140】
逆量子化ユニット310は、ビットストリーム内で提供され、エントロピー復号ユニット304によって復号された量子化変換係数を逆量子化するように、すなわち、量子化解除するように構成される。逆量子化プロセスは、ビデオスライス内の各ビデオブロックに対してビデオエンコーダ100によって計算された量子化パラメータを使用して、量子化の程度、および同様に、適用されるべき逆量子化の程度を決定することを含み得る。
【0141】
逆変換処理ユニット312は、ピクセル領域内で残差ブロックを作成するために、逆変換、たとえば、逆DCT、逆整数変換、または概念的に同様の逆変換プロセスを変換係数に適用するように構成される。
【0142】
再構築ユニット314(たとえば、加算器314)は、たとえば、再構築された残差ブロック313のサンプル値と予測ブロック365のサンプル値とを加算することによって、逆変換ブロック313(すなわち、再構築された残差ブロック313)を予測ブロック365に加えて、サンプル領域内で再構築されたブロック315を取得するように構成される。
【0143】
ループフィルタユニット320は(コーディングループ中またはコーディングループ後のいずれかにおいて)、たとえば、ピクセル遷移を平滑にするために、またはさもなければ、ビデオ品質を改善するために、再構築されたブロック315をフィルタリングして、フィルタリングされたブロック321を取得するように構成される。一例では、ループフィルタユニット320は、後で説明するフィルタリング技術の任意の組合せを行うように構成され得る。ループフィルタユニット320は、デブロッキングフィルタ、サンプル適応オフセット(SAO)フィルタ、または他のフィルタ、たとえば、バイラテラルフィルタ、もしくは適応ループフィルタ(ALF)、または鮮明化フィルタもしくは平滑化フィルタ、あるいは協調フィルタなど、1つまたは複数のループフィルタを表すことが意図される。ループフィルタユニット320はインループフィルタであるとして
図3に示されるが、他の構成では、ループフィルタユニット320は、ポストループフィルタとして実装されてよい。
【0144】
所与のフレームまたはピクチャ内の復号されたビデオブロック321は、その場合、復号ピクチャバッファ330内に記憶され、復号ピクチャバッファ330は、後続の動き補償のために使用される参照ピクチャを記憶する。
【0145】
デコーダ30は、ユーザに示すため、またはユーザに対する視聴のために、復号されたピクチャ311を、たとえば、出力312を介して出力するように構成される。
【0146】
ビデオデコーダ30の他の変形例が、圧縮されたビットストリームを復号するために使用され得る。たとえば、デコーダ30は、ループフィルタリングユニット320なしに、出力ビデオストリームを作成し得る。たとえば、非変換ベースのデコーダ30は、一定のブロックまたはフレームに対する逆変換処理ユニット312なしに、残差信号を直接的に逆量子化し得る。他の実装形態では、ビデオデコーダ30は、逆量子化ユニット310および逆変換処理ユニット312を組み合わせて単一のユニットにすることができる。
【0147】
図4は、本開示の一実施形態による、ビデオコーディングデバイス400の概略図である。ビデオコーディングデバイス400は、本明細書で説明するような、開示される実施形態を実装するのに好適である。一実施形態では、ビデオコーディングデバイス400は、
図1Aのビデオデコーダ30などのデコーダまたは
図1Aのビデオエンコーダ20などのエンコーダであってよい。一実施形態では、ビデオコーディングデバイス400は、上述のような、
図1Aのビデオデコーダ30または
図1Aのビデオエンコーダ20の1つまたは複数の構成要素であってよい。
【0148】
ビデオコーディングデバイス400は、データを受信するための入口ポート410および受信器ユニット(Rx)420、データを処理するためのプロセッサ、論理ユニット、または中央処理装置(CPU)430;データを送信するための送信器ユニット(Tx)440および出口ポート450;およびデータを記憶するためのメモリ460を含む。ビデオコーディングデバイス400はまた、光信号または電気信号の出口または入口に対する、入口ポート410、受信器ユニット420、送信器ユニット440、および出口ポート450に結合された、光対電気(OE)構成要素および電気対光(EO)構成要素を備え得る。
【0149】
プロセッサ430は、ハードウェアおよびソフトウェアによって実装される。プロセッサ430は、1つまたは複数のCPUチップ、コア(たとえば、マルチコアプロセッサなど)、FPGA、ASIC、およびDSPとして実装され得る。プロセッサ430は、入口ポート410、受信器ユニット420、送信器ユニット440、出口ポート450、およびメモリ460と通信している。プロセッサ430は、コーディングモジュール470を含む。コーディングモジュール470は、上述の開示される実施形態を実装する。たとえば、コーディングモジュール470は、様々なコーディング動作を実装、処理、準備、または提供する。コーディングモジュール470を含むことは、したがって、ビデオコーディングデバイス400の機能性にかなりの改善を与え、ビデオコーディングデバイス400を異なる状態に変換させる。あるいは、コーディングモジュール470は、メモリ460内に記憶され、プロセッサ430によって実行される命令として実装される。
【0150】
メモリ460は、1つまたは複数のディスク、テープドライブ、および固体ドライブを含み、プログラムが実行のために選択されるとき、そのようなプログラムを記憶するために、またプログラム実行中に読み取られる命令およびデータを記憶するために、オーバーフローデータ記憶デバイスとして使用され得る。メモリ460は、揮発性および/または不揮発性であってよく、読取り専用メモリ(ROM)、ランダムアクセスメモリ(RAM)、3値連想メモリ(TCAM:ternary content-addressable memory)、および/またはスタティックランダムアクセスメモリ(SRAM)であってよい。
【0151】
図5は、1つの例示的な実施形態による、
図1からのソースデバイス310および宛先デバイス320のうちのいずれかまたは両方として使用され得る装置500の簡略ブロック図である。装置500は、上述の本出願の技術を実装し得る。装置500は、複数のコンピューティングデバイスを含むコンピューティングシステムの形で、または単一のコンピューティングデバイス、たとえば、モバイルフォン、タブレットコンピュータ、ラップトップコンピュータ、ノートブックコンピュータ、デスクトップコンピュータなどの形であってよい。
【0152】
装置500内のプロセッサ502は、中央処理装置であってよい。あるいは、プロセッサ502は、現在存在するか、または今後開発される、情報を操作または処理することが可能な、任意の他のタイプのデバイス、または複数のデバイスであってよい。開示される実装形態は、図示するように単一のプロセッサ、たとえば、プロセッサ502を用いて実践され得るが、2つ以上のプロセッサを使用して、速度および効率における利点を達成することができる。
【0153】
装置500内のメモリ504は、一実装形態では、読取り専用メモリ(ROM)デバイスまたはランダムアクセスメモリ(RAM)デバイスであってよい。任意の他の好適なタイプの記憶デバイスがメモリ504として使用され得る。メモリ504は、バス512を使用してプロセッサ502がアクセスするコードおよびデータ506を含み得る。メモリ504は、オペレーティングシステム508およびアプリケーションプログラム510をさらに含んでよく、アプリケーションプログラム510は、プロセッサ502が本明細書で説明する方法を行うことを許可する、少なくとも1つのプログラムを含む。たとえば、アプリケーションプログラム510は、アプリケーション1からNを含んでよく、これらは、本明細書で説明する方法を行うビデオコーディングアプリケーションをさらに含む。装置500は、たとえば、モバイルコンピューティングデバイスとともに使用されるメモリカードであってよい、二次記憶装置514の形で追加のメモリを含んでもよい。ビデオ通信セッションは、かなりの量の情報を包含し得るため、これらのセッションは、二次記憶装置514内に全部または部分的に記憶され、処理の必要に応じて、メモリ504内にロードされてよい。
【0154】
装置500は、ディスプレイ518など、1つまたは複数の出力デバイスを含んでもよい。ディスプレイ518は、一例では、ディスプレイとタッチ入力を感知するように動作可能であるタッチセンサー式要素を組み合わせたタッチセンサー式ディスプレイであってよい。ディスプレイ518は、バス512を介してプロセッサ502に結合され得る。ディスプレイ518に加えて、またはその代わりに、ユーザが装置500をプログラムするか、またはさもなければ、それを使用することを許可する他の出力デバイスが提供され得る。出力デバイスがディスプレイであるかまたはディスプレイを含むとき、ディスプレイは、液晶ディスプレイ(LCD)、陰極線管(CRT)ディスプレイ、プラズマディスプレイ、または有機LED(OLED)ディスプレイなどの発光ダイオード(LED)ディスプレイによる、を含めて、様々な方法で実装され得る。
【0155】
装置500は、画像感知デバイス520、たとえば、カメラ、または装置500を操作しているユーザの画像などの画像を感知し得る、現在存在するか、または今後開発される任意の他の画像感知デバイス520を含んでもよいか、またはそれと通信していてもよい。画像感知デバイス520は、画像感知デバイス520が装置500を操作しているユーザに向くように配置され得る。一例では、画像感知デバイス520の位置および光軸は、視野が、ディスプレイ518に直接隣接し、そこからディスプレイ518が見えるエリアを含むように構成され得る。
【0156】
装置500は、音声感知デバイス522、たとえば、マイクロフォン、または、装置500付近の音声を感知し得る、現在存在するか、または今後開発される任意の他の音声感知デバイスを含んでもよいか、またはそれと通信していてもよい。音声感知デバイス522は、音声感知デバイス522が装置500を動作させているユーザに向くように配置され得、ユーザが装置500を動作させている間にユーザが発する音声、たとえば、発語または他の発話を受信するように構成され得る。
【0157】
図5は、単一のユニットに一体化されているとして、装置500のプロセッサ502およびメモリ504を示すが、他の構成が利用され得る。プロセッサ502の動作は、直接的に、またはローカルエリアネットワークもしくは他のネットワークにわたって結合され得る複数の機械(各機械は、プロセッサのうちの1つまたは複数を有する)にわたって分散されてよい。メモリ504は、ネットワークベースのメモリまたは装置500の動作を行う複数の機械内のメモリなど、複数の機械にわたって分散されてよい。ここでは単一のバスとして示されているが、装置500のバス512は、複数のバスからなることがある。さらに、二次記憶装置514は、装置500の他の構成要素に直接的に結合されてよく、またはネットワークを介してアクセスされてよく、メモリカードなど、単一の一体化ユニットを含んでよく、または複数のメモリカードなど、複数のユニットを含んでもよい。装置500は、したがって、多種多様な構成で実装され得る。
【0158】
VVCでは、インターコーディングされたブロックの動きベクトルは、2つの方法でシグナリングされ得る:すなわち、高度動きベクトル予測(AMVP:Advanced motion vector prediction)モードまたはマージモードである。AVMPモードの場合、実際の動きベクトルと動きベクトル予測(MVP)の間の差異、AMVP候補リストを指す参照インデックス(reference index)およびMVPインデックスがシグナリングされ、ここで、参照インデックスは、動き補償のために参照ブロックがそこからコピーされる参照ピクチャを指す。マージモードの場合、マージ候補リストを指すマージインデックスがシグナリングされ、マージ候補に関連するすべての動き情報は継承される。
【0159】
AMVP候補リストとマージ候補リストの両方の場合、これらは、時間的または空間的に近接する、コーディングされたブロックから導出される。より具体的には、マージ候補リストは、以下の4つのタイプのマージMVP候補を順番に検査することによって構築される:
1.
図6に示すように、5個の空間的に近接するブロック、すなわち、左下隅に位置するブロックA
0およびA
1、右上隅に位置するブロックB
0およびB
1、ならびに左上隅に位置するブロックB
2から決定され得る空間マージ候補。
2. 時間MVP(TMVP)マージ候補。
3. 組み合わされた双予測マージング候補。
4. ゼロ動きベクトルマージング候補。
【0160】
利用可能なマージ候補の数がシグナリングされた最大限に可能にされたマージ候補(たとえば、一般的なテスト条件下で5)に達すると、マージ候補リスト構築プロセスは終了する。最大限に可能にされたマージ候補は異なる条件下で異なり得ることに留意されたい。
【0161】
同様に、AMVP候補リストの場合、3つのタイプのMVP候補が順番に検査される:
1. 2つのうちの1つは、
図6に示すように、ブロックB
0、B
1、およびB
2から決定され、2つのうちのもう1つは、
図6に示すように、ブロックA
0およびA
1から決定される、最高で2つの空間MVP候補。
2. 時間MVP(TMVP)候補。
3. ゼロMVP候補。
【0162】
履歴ベースの動きベクトル予測(HMVP)方法は、ITU-T SG 16 WP 3およびISO/IEC JTC 1/SC29/WG 11のジョイントビデオエキスパートチーム(JVET)に対する入力文書である、JVETK104(http://phenix.it-sudparis.eu/jvet/においてアクセス可能)によって導入され、
ここで、HMVP候補は、前にコーディングされたブロックの動き情報と定義される。複数のHMVP候補を備えたテーブルが符号化/復号プロセス中に維持される。このテーブルは、新しいスライスに遭遇するときに空にされる。インターコーディングされたブロックが存在するときはいつでも、関連する動き情報は、新しいHMVP候補として、テーブルの最後のエントリーに追加される。以下を含む、全体的なコーディングフローを
図7に示す
【0163】
ステップ701、テーブルにHMVP候補をロードする。
【0164】
ステップ702、ロードされたテーブル内のHMVP候補でブロックを復号する。
【0165】
ステップ703、ブロックを復号するとき、復号された動き情報でテーブルを更新する。
【0166】
ステップ701~703は、循環して行われてよい。
【0167】
HMVP候補は、マージ候補リスト構築プロセスにおいて使用され得る。テーブル内の最後のエントリーから第1のエントリーまでのすべてのHMVP候補がTMVP候補の後に挿入される。プルーニングがHMVP候補に適用され得る。利用可能なマージ候補の総数がシグナリングされた最大限に可能にされたマージ候補に達すると、マージ候補リスト構築プロセスは、終了する。
【0168】
プルーニングの動作は、リスト内の同一の動き予測器候補を識別し、リストから同一の候補のうちの1つを除去することを表す。
【0169】
同様に、HMVP候補は、AMVP候補リスト構築プロセスにおいて使用されてもよい。テーブル内の最後のK個のHMVP候補の動きベクトルは、TMVP候補の後に挿入される。いくつかの実装方法では、AMVP目標参照ピクチャと同じ参照ピクチャを有するHMVP候補のみがAMVP候補リストを構築するために使用される。プルーニングはHMVP候補に適用され得る。
【0170】
処理効率を改善するために、波面並列処理(WPP)と呼ばれる処理が導入され、ここで、WPPモードは、CTUの行が同時に処理されることを可能にする。WPPモードで、各CTU行は、2個の連続するCTUの遅延を使用することによって、その先行する(直接隣接する)CTU行に対して処理される。たとえば、
図8を参照すると、ピクチャフレームまたはピクチャエリアは、複数のCTU行からなり、各スレッド(行)は、11個のCTUを含む、すなわち、スレッド1は、CTU0からCTU10を含み、スレッド2は、CTU11からCTU21を含み、スレッド3は、CTU22からCTU32を含み、スレッド4は、CTU33から43を含む…。したがって、WPPモードで、スレッド1内のCTU1の符号化/復号プロセスが済んだとき、スレッド2内のCTU11の符号化/復号プロセスが開始し得、同様に、スレッド2内のCTU12の符号化/復号プロセスが済んだとき、スレッド3内のCTU22の符号化/復号プロセスが開始し得、スレッド3内のCTU23の符号化/復号プロセスが済んだとき、スレッド4内のCTU33の符号化/復号プロセスが開始し得、スレッド4内のCTU34の符号化/復号プロセスが済んだとき、スレッド5内のCTU44の符号化/復号プロセスが開始し得る。
【0171】
しかしながら、WPPをHMVPと組み合わせるとき、上述したように、HMVPリストが維持され、各コーディングブロックを処理した後で更新され、したがって、CTU行の最後のCTUまで更新され続ける、1つのHMVPリストが維持され、したがって、スレッドNは、上記のCTU行の中の最後のCTUの処理が済むのを待つ必要があるため、波面並列処理を行うことはできない。
【0172】
図9は、本出願の一実施形態による、
図3のビデオデコーダ30などのビデオデコーダの1つの例示的な動作を示す流れ図である。インター予測ユニット344を含む、ビデオデコーダ30の1つまたは複数の構造的要素は、
図9の技術を行うように構成され得る。
図9の例では、ビデオデコーダ30は、以下のステップを実行し得る。
【0173】
901、CTU行の処理の開始時に、CTU行に対するHMVPリストを構築/初期化するステップが行われる。
【0174】
処理されることになるCTUがCTU行の第1のCTU(開始CTU)であるとき、CTU行に対するHMVPリストが構築または初期化され、したがって、CTU行の第1のCTUは、CTU行に対するHMVPリストに基づいて処理され得る。
【0175】
方法が符号化方法であるとき、CTU行に対するHMVPリストは、
図3のインター予測ユニット344によって構築または初期化され得る。あるいは、方法が復号方法であるとき、CTU行に対するHMVPリストは、
図2のインター予測ユニット244によって構築または初期化され得る。
【0176】
一実装方法では、ピクチャフレームに対して、異なるHMVPリストを有するすべてのCTU行が維持され得る。他の実装方法では、ピクチャエリアに対して、異なるHMVPリストを有するすべてのCTU行が維持され得、ここで、ピクチャエリアは、複数のCTU行からなり、ピクチャは、VVCのスライス、タイル、またはブリックであってよい。
【0177】
ブリックがピクチャ内の特定のタイル内のCTU行の長方形領域である場合、タイルは、複数のブリックに分割されてよく、それらの各々は、タイル内の1つまたは複数のCTU行からなる。複数のブリックに分割されないタイルもブリックと呼ばれる。しかしながら、タイルの真のサブセットであるブリックは、タイルと呼ばれない。
【0178】
すべてのCTU行に対して異なるHMVPリストを維持することは、CTU行に対して特定のHMVPリストが維持され得るが、異なるHMVPリスト内の候補は同じであり得ること、たとえば、1つのHMVPリスト内のすべての候補は、他のHMVPリスト内の候補と同じであることを単に意味することに留意されたく、1つのHMVPリスト内の候補は冗長性を有さない可能性があること;または、異なるHMVPリスト内の候補は、重複を有する可能性があること、たとえば、1つのHMVPリスト内の候補のうちのいくつかは、他のHMVPリスト内の候補のうちのいくつかと同じであり、その1つのHMVPリスト内の候補のうちのいくつかは、他のHMVPリスト内の同一の候補を有さないこと;または、異なるHMVPリスト内の候補は、まったく異なる可能性があること、たとえば、1つのHMVPリスト内の候補のうちのいずれも、他のHMVPリスト内に同一候補を有さないこと、に留意されたい。CTU行の中のすべてのCTUが処理されたとき、そのCTU行に対して維持されたHMVPリストは、解放されてよく、したがって、記憶要件を低減し得ることに留意されたい。
【0179】
本開示は、HMVPリストを構築/初期化するための以下の方法を提供した。
【0180】
方法1:CTU行の処理の開始時に、対応するHMVPリストは、空にされるか、またはデフォルト値に設定される。デフォルト値は、エンコーダとデコーダの両方に知られている所定の候補である。
【0181】
たとえば、対応するHMVPリストは、以下のようなデフォルトMVでポピュレートされる:
a) 単一予測方法からのMV、ここで、MVはゼロ動きベクトルでありえ、参照ピクチャはL0リスト内の第1の参照ピクチャを含み得る、および/または
b) 双予測方法からのMV、ここでMVはゼロ動きベクトルでありえ、参照ピクチャは、L0リスト内の第1の参照ピクチャおよびL1リスト内の第1の参照ピクチャを含み得る、および/または
c) ピクチャ処理順序に従って前に処理されたピクチャのMV。より具体的には、現在ブロック位置が前のピクチャ上にオーバレイされるとき、前に処理されたピクチャに属し、かつ現在ブロックの空間的近傍内にあるMV。および/または
d) 時間的HMVPリストのMV、ここで、各同一位置のピクチャは、各CTU行に対して、またはピクチャ全体に対して、時間的HMVPリストを記憶し得、したがって、時間的HMVPリストは、現在CTU行に対するHMVPリストを構築/初期化するために使用され得る。
【0182】
方法2:現在CTU行の処理の開始時に、対応するHMVPリストは、前のCTU行の第2のCTUのHMVPリストに基づいて構築/初期化され、ここで、前のCTU行は、現在CTU行に直接隣接し、現在CTU行の上にある、CTU行である。
【0183】
図8を一例として利用すると、現在CTU行がスレッド2のCTU行であるとき、前のCTU行はスレッド1のCTU行であり、前の行の第2のCTUはCTU1である;現在CTU行がスレッド3のCTU行であるとき、前のCTU行はスレッド2のCTU行であり、前の行の第2のCTUはCTU12である;現在CTU行がスレッド4のCTU行であるとき、前のCTU行はスレッド3のCTU行であり、前の行の第2のCTUはCTU23である;現在CTU行がスレッド5のCTU行であるとき、前のCTU行はスレッド4のCTU行であり、前の行の第2のCTUはCTU34である;現在CTU行がスレッド6のCTU行であるとき、前のCTU行はスレッド5のCTU行であり、前の行の第2のCTUはCTU45である。
【0184】
方法3:現在CTU行の処理の開始時に、対応するHMVPリストは、前のCTU行の第1のCTUのHMVPリストに基づいて構築/初期化され、前のCTU行は、現在CTU行に直接隣接し、現在CTU行の上にあるCTU行である。
【0185】
図8を一例として利用すると、現在CTU行がスレッド2のCTU行であるとき、前のCTU行はスレッド1のCTU行であり、前の行の第1のCTUはCTU0である;現在CTU行がスレッド3のCTU行であるとき、前のCTU行はスレッド2のCTU行であり、前の行の第1のCTUはCTU11である;現在CTU行がスレッド4のCTU行であるとき、前のCTU行はスレッド3のCTU行であり、前の行の第1のCTUはCTU22である;現在CTU行がスレッド5のCTU行であるとき、前のCTU行はスレッド4のCTU行であり、前の行の第1のCTUはCTU33である;現在CTU行がスレッド6のCTU行であるとき、前のCTU行はスレッド5のCTU行であり、前の行の第1のCTUはCTU44である。
【0186】
方法1から3によれば、現在CTU行の処理は、現在CTU行の前のCTU行の処理が済むのを待つ必要がなく、したがって、現在ピクチャフレームの処理効率を改善し得る。
【0187】
902、構築/初期化されたHMVPリストに基づいて、CTU行の中のCTUを処理する。
【0188】
CTUの処理は、復号プロセス中に実行されるインター予測処理であってよく、すなわち、CTUの処理は、
図3のインター予測ユニット344によって実装され得る。あるいは、CTUの処理は、符号化プロセス中に実行されるインター予測処理であってよく、すなわち、CTUの処理は、
図2のインター予測ユニット244によって実装され得る。
【0189】
HMVPリストを構築/初期化するための上記の方法は、波面なしの通常のHMVP処理、たとえばWPPなしのHMV処理に対しても使用され得ることに留意されたい。結果として、HMVP処理は、WPPの適用にかかわらず同一であり、これは、追加の論理実装の必要性を減らす。
【0190】
図9の処理は、本出願の一実施形態による、
図2のビデオエンコーダ20など、エンコーダによって実装される符号化プロセスであってもよいことに留意されたい。
【0191】
さらに、波面とHMVPベースの予測の組合せに関する上述の方法は、イントラ予測に対しても使用され得ることに留意されたい。すなわち、履歴イントラモードが使用されてよく、各CTU行に対する履歴テーブルは、デフォルト値に初期化される。
【0192】
たとえば、イントラ予測内の各CTU行に対するHMVPリストの初期化は、平面モード、DCモード、垂直モード、水平モード、モード2モード、VDIAモード、およびDIAモードなど、デフォルトイントラモードで行われてよい。
【0193】
図10は、本出願の一実施形態による
図3のビデオデコーダ30および本出願の一実施形態による
図2のビデオエンコーダ20などの、ビデオデコーダまたはビデオエンコーダの1つの例示的な動作を示す流れ図である。インター予測ユニット344/インター予測ユニット244を含む、ビデオデコーダ30/エンコーダ20の1つまたは複数の構造的要素は、
図10の技術を行うように構成され得る。
図10の例では、ビデオデコーダ30/ビデオエンコーダ20は、以下のステップを行い得る。
【0194】
ステップ1010、現在CTUが現在CTU行の開始CTUであるとき、現在CTU行に対するHMVPリストを初期化する。
【0195】
現在CTU行は、複数のCTU行からなるピクチャフレームの任意のCTU行であってよいか、またはピクチャエリア(ピクチャフレームの一部分であってよい)は、複数のCTU行からなることに留意されたい。また、現在CTU行は、複数のCTU行のうちのいずれか1つであってよい。
【0196】
現在CTUが現在CTU行の開始CTU(または、第1のCTU)であるかどうかは、現在CTUのインデックスに基づいて決定され得る。たとえば、
図8で開示したように、各CTUは、一意のインデックスを有し、したがって、現在CTUのインデックスに基づいて、現在CTUが現在CTU行の第1のCTUであるかどうかを決定することができる。たとえば、インデックス0、11、22、33、44、または55…を有するCTUは、それぞれ、CTU行の第1のCTUである。あるいは、
図8を一例として利用すると、各CTU行は、11個のCTUを含み、すなわち、各CTU行の幅は11であり、したがって、CTU行の幅を用いてCTUのインデックスを除算して余りが0であるか否かを決定することができ、余りが0である場合、対応するCTUは、CTU行の第1のCTUである;さもなければ、余りが0でない場合、対応するCTUは、CTU行の第1のCTUではない。すなわち、CTUのインデックス%CTU行の幅=0である場合、CTUは、CTU行の第1のCTUである;さもなければ、CTUのインデックス%CTU行の幅≠0である場合、CTUは、CTU行の第1のCTUではない。CTU行のプロセスが右から左であるとき、CTUがCTU行の開始CTUであるかどうかは、同様の方法で決定され得ることに留意されたい。
【0197】
HMVPリストの初期化の後、初期化されたHMVPリスト内の候補動きベクトルの数量は、ゼロである。
【0198】
初期化は、現在CTU行に対するHMVPリストを空にすることとして、すなわち、現在CTU行に対するHMVPリストの中身を無くすこととして、言い換えれば、現在CTU行に対するHMVPリスト内の候補の数をゼロにすることとして行われ得る。
【0199】
他の実装方法では、この方法は、以下のステップ:すなわち、現在CTU行を除き、複数のCTU行の各々に対するHMVPリストを初期化するステップであって、複数のCTU行に対するHMVPリストは、同一であるか、または異なる、初期化するステップ、をさらに含み得る。
【0200】
初期化は、現在CTU行に対するHMVPリストに対するデフォルト値を設定することとして、または、上述したように、前のCTU行のCTUのHMVPリストに基づいて、現在CTU行に対するHMVPリストを初期化することとして行われ得る。
【0201】
ステップ1020、HMVPリストに基づいて現在CTU行を処理する。
【0202】
処理は、インター予測処理であってよく、それにより、予測ブロックが取得され得る。再構築は、再構築されたブロックを取得するために、予測ブロックに基づいて行われることができ、最終的に、再構築されたブロックに基づいて、復号されたピクチャが取得され得る。これらのプロセスの詳細は、上述されている。
【0203】
図8に示したように、現在ピクチャフレームは、コーディング/復号効率を改善するために複数のCTU行を含み、複数のCTU行は、波面並列処理(WPP)モードで処理され得る。すなわち、前のCTU行の特定のCTUが処理されるとき、現在CTU行が処理され始め(または、現在CTU行の処理が始まり)、ここで、前のCTU行は、現在CTU行に直接隣接し、現在CTU行の上にある、CTU行であり、前のCTU行の特定のCTUは、前のCTU行の第2のCTUである;または前のCTU行の特定のCTUは、前のCTU行の第1のCTUである。
図8を一例として利用すると、現在CTU行がスレッド3であるとき、前のCTU行はスレッド2であり、前のCTU行の特定のCTUは、CTU12であってよく、すなわち、CTU12が処理されるとき、デコーダ/エンコーダは、スレッド3のCTU行を処理し始める、すなわち、デコーダ/エンコーダは、CTU22を処理し始める。
図8を他の例として利用すると、現在CTU行がスレッド4であるとき、前のCTU行はスレッド3であり、前のCTU行の特定のCTUは、CTU23であってよく、すなわち、CTU23が処理されるとき、デコーダ/エンコーダは、スレッド4のCTU行を処理し始める、すなわち、デコーダ/エンコーダは、CTU33を処理し始める。
【0204】
一実装方法では、HMVPリストに基づいて現在CTU行を処理するステップは、現在CTU行の現在CTUを処理するステップと、処理された現在CTUに基づいて、初期化されたHMVPリストを更新するステップと、更新されたHMVPリストに基づいて、現在CTU行の第2のCTUを処理するステップとを含み得る。
【0205】
図11は、本発明の実施形態を実装するように構成されたビデオ処理装置1100の一例を示すブロック図であり、ビデオ処理装置1100は、
図11に示すように、エンコーダ20またはデコーダ30であってよく、この装置は、以下を含む。
【0206】
現在CTUが現在CTU行の開始CTU(第1のCTU)であるとき、現在CTU行に対するHMVPリストを初期化するように構成された、初期化ユニット1110。
【0207】
初期化ユニット1110によって行われる初期化の詳細は、ステップ1010を参照し得る。
【0208】
HMVPリストに基づいて現在CTU行を処理するように構成された、処理ユニット1120。
【0209】
処理ユニット1120によって行われる処理の詳細は、ステップ1020を参照し得る。
【0210】
処理は、インター予測処理であってよく、それにより、予測ブロックが取得され得る。再構築は、再構築されたブロックを取得するために、予測ブロックに基づいて行われることができ、最終的に、再構築されたブロックに基づいて、復号されたピクチャが取得され得る。これらのプロセスの詳細は、上述されている。
【0211】
図8に示したように、現在ピクチャフレームは、複数のCTU行を含み、コーディング/復号効率を改善するために、複数のCTU行は、WPPモードで処理され得る。すなわち、前のCTU行の特定のCTUが処理されるとき、現在CTU行が処理され始め、ここで、前のCTU行は、現在CTU行に直接隣接し、現在CTU行の上にある、CTU行であり、前のCTU行の特定のCTUは、前のCTU行の第2のCTUである;または、前のCTU行の特定のCTUは、前のCTU行の第1のCTUである。
図8を一例として利用すると、現在CTU行がスレッド3であるとき、前のCTU行はスレッド2であり、前のCTU行の特定のCTUは、CTU12であってよく、すなわち、CTU12が処理されるとき、デコーダ/エンコーダは、スレッド3のCTU行を処理し始める、すなわち、デコーダ/エンコーダは、CTU22を処理し始める。
図8を他の例として利用すると、現在CTU行がスレッド4であるとき、前のCTU行はスレッド3であり、前のCTU行の特定のCTUは、CTU23であってよく、すなわち、CTU23が処理されるとき、デコーダ/エンコーダは、スレッド4のCTU行を処理し始める、すなわち、デコーダ/エンコーダは、CTU33を処理し始める。
【0212】
本開示は、ビデオ処理方法または本開示のコーディングの方法を実行するための処理回路を含むエンコーダをさらに開示する。
【0213】
本開示は、ビデオ処理方法または本開示のコーディングの方法を実行するための処理回路を含むデコーダをさらに開示する。
【0214】
本開示は、ビデオ処理方法または本開示のコーディングの方法を実行するためのプログラムコードを含むコンピュータプログラム製品をさらに開示する。
【0215】
本開示は、コンピュータ命令を記憶した、コンピュータ可読記憶媒体であって、これらの命令は、1つまたは複数のプロセッサによって実行されると、ビデオ処理方法または本開示のコーディングの方法を1つまたは複数のプロセッサに実行させる、コンピュータ可読記憶媒体をさらに開示する。コンピュータ可読記憶媒体は、非一時的または一時的である。
【0216】
本開示は、デコーダであって、1つまたは複数のプロセッサと、プロセッサに結合され、プロセッサによる実行のためのプログラミングを記憶した、非一時的コンピュータ可読記憶媒体とを含み、プログラミングは、プロセッサによって実行されると、ビデオ処理方法または本開示のコーディングの方法を実行するようにデコーダを構成する、デコーダをさらに開示する。
【0217】
本開示は、エンコーダであって、1つまたは複数のプロセッサと、プロセッサに結合され、プロセッサによる実行のためのプログラミングを記憶した、非一時的コンピュータ可読記憶媒体とを含み、プログラミングは、プロセッサによって実行されると、ビデオ処理方法または本開示のコーディングの方法を実行するようにエンコーダを構成する、エンコーダをさらに開示する。
【0218】
HMVPリストに対する初期化プロセスは、VVC(ITU-T SG 16 WP 3およびISO/IEC JTC 1/SC 29/WG 11のジョイントビデオエキスパートチーム(JVET)、多目的ビデオコーディング(草案6))の一般的なスライスデータシンタックスに記載され、VVCの第7.3.8.1項は、以下のように記載している:
【0219】
【0220】
ここで、j%BrickWidth[SliceBrickIdx[i]])==0は、インデックスjを有するCTUがCTU行の開始CTUであることを意味し、NumHmvpCand=0は、HMVPリスト内の候補の数量が0に設定されていること、言い換えれば、HMVPリストが空にされたことを意味する。
【0221】
HMVPリストに対する更新プロセスは、VVC(ITU-T SG 16 WP 3およびISO/IEC JTC 1/SC 29/WG 11のジョイントビデオエキスパートチーム(JVET)、多目的ビデオコーディング(草案6))の第8.5.2.16項で説明され、この項は、以下のように記載している:
このプロセスに対する入力は以下の通りである:
1/16分数サンプル精度のルマ動きベクトルmvL0およびmvL1、
参照インデックスrefIdxL0およびrefIdxL1、
予測リスト利用フラグpredFlagL0およびpredFlagL1、
双予測加重インデックスbcwIdx。
MVP候補hMvpCandは、ルマ動きベクトルmvL0およびmvL1、参照インデックスrefIdxL0およびrefIdxL1、予測リスト利用フラグpredFlagL0およびpredFlagL1、および双予測加重インデックスbcwIdxからなる。
候補リストHmvpCandListは、以下の順序とされたステップによって、候補hMvpCandを使用して修正される:
変数identicalCandExistがFALSEに等しく設定され、変数removeIdxが0に等しく設定される。
NumHmvpCandが0を超える場合、hMvpIdx=0..NumHmvpCand-1を有する各インデックスhMvpIdxに対して、identicalCandExistがTRUEに等しくなるまで、以下のステップが適用される:
hMvpCandがHmvpCandList[hMvpIdx]に等しいとき、identicalCandExistがTRUEに等しく設定され、removeIdxがhMvpIdxに等しく設定される。
候補リストHmvpCandListが以下のように更新される:
identicalCandExistがTRUEに等しいか、またはNumHmvpCandが5に等しい場合、以下が適用される:
i=(removeIdx+1)..(NumHmvpCand-1)を有する各インデックスiに対して、HmvpCandList[i-1]がHmvpCandList[i]に等しく設定される。
HmvpCandList[NumHmvpCand-1]がmvCandに等しく設定される。
さもなければ(identicalCandExistがFALSEに等しく、NumHmvpCandが5に満たない)、以下が適用される:
HmvpCandList[NumHmvpCand++]がmvCandに等しく設定される。
【0222】
1つまたは複数の例では、説明された機能は、ハードウェア、ソフトウェア、ファームウェア、またはそれらの任意の組合せにおいて実装され得る。ソフトウェアにおいて実装される場合、機能は、1つまたは複数の命令またはコードとして、コンピュータ可読媒体上に記憶されるか、またはそれを介して送信され、ハードウェアベースの処理ユニットによって実行され得る。コンピュータ可読媒体は、データ記憶媒体などの有形媒体に対応するコンピュータ可読記憶媒体、または、たとえば、通信プロトコルに従って、互いの間でコンピュータプログラムの転送を円滑にする任意の媒体を含む通信媒体を含み得る。このようにして、コンピュータ可読媒体は、概して、(1)非一時的である有形コンピュータ可読記憶媒体、または(2)信号波または搬送波などの通信媒体、に対応し得る。データ記憶媒体は、本開示で説明した技術を実装するための命令、コード、および/またはデータ構造を取り出すために、1つもしくは複数のコンピュータまたは1つもしくは複数のプロセッサによってアクセスされ得る任意の利用可能な媒体であってよい。コンピュータプログラム製品は、コンピュータ可読媒体を含み得る。
【0223】
限定ではなく、例として、そのようなコンピュータ可読記憶媒体は、RAM、ROM、EEPROM、CD-ROMもしくは他の光ディスク記憶装置、磁気ディスク記憶装置、もしくは他の磁気記憶デバイス、フラッシュメモリ、または所望のプログラムコードを命令もしくはデータ構造の形で記憶するために使用可能であり、コンピュータによってアクセスされ得る、任意の他の媒体を含み得る。また、いずれの接続も、適切にはコンピュータ可読媒体と呼ばれる。たとえば、命令が、同軸ケーブル、光ファイバーケーブル、より対線、デジタル加入者回線(DSL)、または赤外線、無線、およびマイクロ波などのワイヤレス技術を使用して、ウェブサイト、サーバ、または他のリモートソースから送信される場合、同軸ケーブル、光ファイバーケーブル、より対線、DSL、または赤外線、無線、およびマイクロ波などのワイヤレス技術は、媒体の定義の中に含まれる。しかしながら、コンピュータ可読記憶媒体およびデータ記憶媒体は、接続、搬送波、信号、または他の一時的媒体を含まず、代わりに、非一時的、有形記憶媒体を対象とすることに留意されたい。本明細書で使用する、ディスク(disk)およびディスク(disc)は、コンパクトディスク(disc)(CD)、レーザーディスク(登録商標)(disc)、光ディスク(disc)、デジタル多目的ディスク(disc)(DVD)、フロッピーディスク(disk)、およびBlu-ray(登録商標)ディスク(disc)を含み、ここで、ディスク(disk)は、通常、磁気でデータを複製し、ディスク(disc)は、レーザーを用いて光学的にデータを複製する。上記の組合せも、コンピュータ可読媒体の範囲内に含まれるべきである。
【0224】
命令は、1つまたは複数のデジタル信号プロセッサ(DSP)、汎用マイクロプロセッサ、特定用途向け集積回路(ASIC)、フィールドプログラマブル論理アレイ(FPGA)、または他の同等の集積論理回路または離散論理回路など、1つまたは複数のプロセッサによって実行され得る。したがって、本明細書で使用する「プロセッサ」という用語は、前述の構造または本明細書で説明した技術の実装に適した任意の他の構造のうちのいずれかを指すことがある。加えて、いくつかの態様では、本明細書で説明した機能性は、符号化および復号するように構成された専用ハードウェアおよび/もしくはソフトウェアモジュール内で提供され得るか、または組み合わされたコーデック内に組み込まれ得る。また、これらの技術は、1つまたは複数の回路要素または論理要素において完全に実装され得る。
【0225】
本開示の技術は、ワイヤレスハンドセット、集積回路(IC)、またはICのセット(たとえば、チップセット)を含めて、多種多様なデバイスまたは装置において実装され得る。様々な構成要素、モジュール、またはユニットは、開示した技術を実行するように構成されたデバイスの機能的態様を強調するために本開示において説明されているが、異なるハードウェアユニットによる実現を必ずしも必要とするとは限らない。むしろ、上述したように、様々なユニットは、コーデックハードウェアユニット内に組み合わされてよく、または、好適なソフトウェアおよび/もしくはファームウェアとともに、上述のような1つもしくは複数のプロセッサを含めて、インターオペラティブな(interoperative)ハードウェアユニットの収集物によって提供されてよい。
【符号の説明】
【0226】
10 コーディングシステム
12 ソースデバイス
13 符号化されたピクチャ
14 宛先デバイス
16 ピクチャソース
17 ピクチャデータ
18 前処理ユニット
19 前処理されたピクチャデータ
20 エンコーダ
21 符号化されたピクチャデータ
22 通信インターフェース
28 通信インターフェース
30 デコーダ
31 復号されたピクチャ
32 ポストプロセッサ
33 後処理されたピクチャ
34 ディスプレイデバイス
40 ビデオコーディングシステム
41 撮像デバイス
42 アンテナ
43 プロセッサ
44 メモリストア
45 ディスプレイデバイス
46 処理ユニット
47 論理回路
110 逆量子化ユニット
112 逆変換処理ユニット
114 再構築ユニット
116 バッファ
120 ループフィルタ
130 復号ピクチャバッファ
131 復号されたピクチャ
144 インター予測ユニット
154 イントラ予測ユニット
201 ピクチャ
202 入力
203 ピクチャブロック
204 残差計算ユニット
205 残差ブロック
206 変換処理ユニット
207 変換係数
208 量子化ユニット
209 量子化係数
210 逆量子化ユニット
211 量子化解除係数
212 逆変換処理ユニット
213 逆変換ブロック
214 再構築ユニット
215 再構築されたブロック
216 バッファ
220 ループフィルタ
221 フィルタリングされたブロック
230 復号ピクチャバッファ
231 復号されたピクチャ
244 インター予測ユニット
245 インター予測されたブロック
254 イントラ予測ユニット
255 イントラ予測されたブロック
260 予測処理ユニット
262 モード選択ユニット
265 予測ブロック
270 エントロピー符号化ユニット
272 出力
304 エントロピー復号ユニット
309 量子化係数
310 逆量子化ユニット
311 復号されたピクチャ
312 逆変換処理ユニット
313 逆変換ブロック
314 再構築ユニット
315 再構築されたブロック
316 バッファ
320 ループフィルタ
321 フィルタリングされたブロック
330 復号ピクチャバッファ
344 インター予測ユニット
354 イントラ予測ユニット
360 予測処理ユニット
362 モード選択ユニット
365 予測ブロック
400 ビデオコーディングデバイス
410 入口ポート
420 Tx/Rx
430 プロセッサ
440 Tx/Rx
450 出口ポート
460 メモリ
470 コーディングモジュール
500 装置
502 プロセッサ
504 メモリ
506 データ
508 オペレーティングシステム
510 アプリケーションプログラム
512 バス
514 二次記憶装置
518 ディスプレイ
520 画像感知デバイス
522 音声感知デバイス
1100 ビデオ処理装置
1110 初期化ユニット
1120 処理ユニット
【手続補正書】
【提出日】2024-07-08
【手続補正1】
【補正対象書類名】特許請求の範囲
【補正対象項目名】全文
【補正方法】変更
【補正の内容】
【特許請求の範囲】
【請求項1】
ビデオ処理方法であって、
ビデオの現在フレームを取得するステップと、
前記現在フレームを、現在エリアを含む1つまたは複数のエリアに分割するステップであって、前記現在エリアが1つまたは複数のコーディングツリーユニット(CTU)行を含み、前記1つまたは複数のCTU行が第1のCTU行および第2のCTU行を含む、ステップと、
前記第1のCTU行を取得するステップであって、前記第1のCTU行が第1のシーケンス内の複数のCTUを含む、ステップと、
前記複数のCTUのうち、前記第1のシーケンスにおける第1の開始CTUを検出するステップと、
前記第1の開始CTUを検出したことに応答して、前記第1のCTU行に対する第1の履歴ベースの動きベクトル予測(HMVP)リストを初期化するステップと、
初期化された前記第1のHMVPリストに基づいて前記第1のCTU行を処理するステップと、
前記第2のCTU行を取得するステップであって、前記第2のCTU行が第2のシーケンス内の複数のCTUを含む、ステップと、
前記複数のCTUのうち、前記第2のシーケンスにおける第2の開始CTUを検出するステップと、
前記第2の開始CTUを検出したことに応答して、前記第2のCTU行に対する第2のHMVPリストを初期化するステップと、
初期化された前記第2のHMVPリストに基づいて前記第2のCTU行を処理するステップと
を含む、ビデオ処理方法。
【請求項2】
第1のHMVPリストを初期化する前記ステップは、
前記第1のHMVPリスト内の候補動きベクトルの数量をゼロに設定するステップ
をさらに含む、請求項1に記載のビデオ処理方法。
【請求項3】
前記第1のHMVPリストに基づいて前記第1のCTU行を処理する前記ステップは、
前記第1のシーケンスにおける前記第1の開始CTUを処理するステップと、
処理された第1の開始CTUに基づいて前記第1のHMVPリストを更新して、第1の更新されたHMVPリストを取得するステップと、
前記第1の更新されたHMVPリストに基づいて前記第1のCTU行の第2のCTUを処理するステップであって、前記第2のCTUが、前記第1のシーケンスにおいて前記第1の開始CTUの後に続くCTUである、ステップと
をさらに含む、請求項1に記載のビデオ処理方法。
【請求項4】
前記第1のCTU行の処理された第2のCTUに基づいて前記第1の更新されたHMVPリストを更新するステップ
をさらに含む、請求項3に記載のビデオ処理方法。
【請求項5】
前記第2のCTU行に対する第2のHMVPリストを初期化する前記ステップは、
前記第2のHMVPリストを空にするステップ
をさらに含む、請求項1に記載のビデオ処理方法。
【請求項6】
前記1つまたは複数のCTU行は、波面並列処理(WPP)モードで処理される、請求項1に記載のビデオ処理方法。
【請求項7】
前記第2のCTU行は、前記第1のCTU行の特定のCTUが処理された後に処理される、請求項6に記載のビデオ処理方法。
【請求項8】
ビデオエンコーダであって、
1つまたは複数のプロセッサと、
前記1つまたは複数のプロセッサに接続され、前記1つまたは複数のプロセッサによる実行のためのプログラムを記憶する第1の非一時的コンピュータ可読記憶媒体と、
前記第1の非一時的コンピュータ可読記憶媒体に接続され、送信のためにビットストリームを記憶する第2の記憶媒体と
を備え、
前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
ビデオの現在フレームを取得することと、
前記現在フレームを、現在エリアを含む1つまたは複数のエリアに分割することであって、前記現在エリアが1つまたは複数のコーディングツリーユニット(CTU)行を含み、前記1つまたは複数のCTU行が第1のCTU行および第2のCTU行を含む、ことと、
前記第1のCTU行を取得することであって、前記第1のCTU行が第1のシーケンス内の複数のCTUを含む、ことと、
前記複数のCTUのうち、前記第1のシーケンスにおける第1の開始CTUを検出することと、
前記第1の開始CTUを検出したことに応答して、前記第1のCTU行に対する第1の履歴ベースの動きベクトル予測(HMVP)リストを初期化することと、
初期化された前記第1のHMVPリストに基づいて前記第1のCTU行を処理することと、
前記第2のCTU行を取得することであって、前記第2のCTU行が第2のシーケンス内の複数のCTUを含む、ことと、
前記複数のCTUのうち、前記第2のシーケンスにおける第2の開始CTUを検出することと、
前記第2の開始CTUを検出したことに応答して、前記第2のCTU行に対する第2のHMVPリストを初期化することと、
初期化された前記第2のHMVPリストに基づいて前記第2のCTU行を処理することと
を行わせる、ビデオエンコーダ。
【請求項9】
第1のHMVPリストを初期化することにおいて、前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
前記第1のHMVPリスト内の候補動きベクトルの数量をゼロに設定すること
を行わせる、請求項8に記載のビデオエンコーダ。
【請求項10】
前記第1のHMVPリストに基づいて前記第1のCTU行を処理することにおいて、前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
前記第1のシーケンスにおける前記第1の開始CTUを処理することと、
処理された第1の開始CTUに基づいて前記第1のHMVPリストを更新して、第1の更新されたHMVPリストを取得することと、
前記第1の更新されたHMVPリストに基づいて前記第1のCTU行の第2のCTUを処理することであって、前記第2のCTUが、前記第1のシーケンスにおいて前記第1の開始CTUの後に続くCTUである、ことと
を行わせる、請求項8に記載のビデオエンコーダ。
【請求項11】
前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
前記第1のCTU行の処理された第2のCTUに基づいて前記第1の更新されたHMVPリストを更新すること
をさらに行わせる、請求項10に記載のビデオエンコーダ。
【請求項12】
前記第2のCTU行に対する第2のHMVPリストを初期化することにおいて、前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
前記第2のHMVPリストを空にすること
を行わせる、請求項8に記載のビデオエンコーダ。
【請求項13】
前記1つまたは複数のCTU行は、波面並列処理(WPP)モードで処理される、請求項8に記載のビデオエンコーダ。
【請求項14】
前記第2のCTU行は、前記第1のCTU行の特定のCTUが処理された後に処理される、請求項13に記載のビデオエンコーダ。
【請求項15】
ビデオデコーダであって、
1つまたは複数のプロセッサと、
前記1つまたは複数のプロセッサに接続され、前記1つまたは複数のプロセッサによる実行のためのプログラムを記憶する第1の非一時的コンピュータ可読記憶媒体と
を備え、
前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
ビデオの現在フレームを取得することと、
前記現在フレームを、現在エリアを含む1つまたは複数のエリアに分割することであって、前記現在エリアが1つまたは複数のコーディングツリーユニット(CTU)行を含み、前記1つまたは複数のCTU行が第1のCTU行および第2のCTU行を含む、ことと、
前記第1のCTU行を取得することであって、前記第1のCTU行が第1のシーケンス内の複数のCTUを含む、ことと、
前記複数のCTUのうち、前記第1のシーケンスにおける第1の開始CTUを検出することと、
前記第1の開始CTUを検出したことに応答して、前記第1のCTU行に対する第1の履歴ベースの動きベクトル予測(HMVP)リストを初期化することと、
初期化された前記第1のHMVPリストに基づいて前記第1のCTU行を処理することと、
前記第2のCTU行を取得することであって、前記第2のCTU行が第2のシーケンス内の複数のCTUを含む、ことと、
前記複数のCTUのうち、前記第2のシーケンスにおける第2の開始CTUを検出することと、
前記第2の開始CTUを検出したことに応答して、前記第2のCTU行に対する第2のHMVPリストを初期化することと、
初期化された前記第2のHMVPリストに基づいて前記第2のCTU行を処理することと
を行わせる、ビデオデコーダ。
【請求項16】
第1のHMVPリストを初期化することにおいて、前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
前記第1のHMVPリスト内の候補動きベクトルの数量をゼロに設定すること
を行わせる、請求項15に記載のビデオデコーダ。
【請求項17】
前記第1のHMVPリストに基づいて前記第1のCTU行を処理することにおいて、前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
前記第1のシーケンスにおける前記第1の開始CTUを処理することと、
処理された第1の開始CTUに基づいて前記第1のHMVPリストを更新して、第1の更新されたHMVPリストを取得することと、
前記第1の更新されたHMVPリストに基づいて前記第1のCTU行の第2のCTUを処理することであって、前記第2のCTUが、前記第1のシーケンスにおいて前記第1の開始CTUの後に続くCTUである、ことと
を行わせる、請求項15に記載のビデオデコーダ。
【請求項18】
前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
前記第1のCTU行の処理された第2のCTUに基づいて前記第1の更新されたHMVPリストを更新すること
をさらに行わせる、請求項17に記載のビデオデコーダ。
【請求項19】
前記第2のCTU行に対する第2のHMVPリストを初期化することにおいて、前記プログラムは、前記1つまたは複数のプロセッサによって実行されると、前記1つまたは複数のプロセッサに、
前記第2のHMVPリストを空にすること
を行わせる、請求項15に記載のビデオデコーダ。
【請求項20】
前記1つまたは複数のCTU行は、波面並列処理(WPP)モードで処理される、請求項15に記載のビデオデコーダ。
【請求項21】
請求項8から14のいずれか一項に記載のエンコーダによって取得されるビットストリームを受信するように構成された受信器と、
前記ビットストリームを記憶するように構成されたストレージと、
前記ビットストリームを送信するように構成された送信器と
を備える、送信デバイス。
【外国語明細書】