(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-04-23
(45)【発行日】2024-05-02
(54)【発明の名称】サブピクチャ復号のバッファ管理
(51)【国際特許分類】
H04N 19/593 20140101AFI20240424BHJP
H04N 19/423 20140101ALI20240424BHJP
H04N 19/176 20140101ALI20240424BHJP
【FI】
H04N19/593
H04N19/423
H04N19/176
(21)【出願番号】P 2022508461
(86)(22)【出願日】2020-08-10
(86)【国際出願番号】 CN2020108182
(87)【国際公開番号】W WO2021027776
(87)【国際公開日】2021-02-18
【審査請求日】2022-02-17
(31)【優先権主張番号】PCT/CN2019/100114
(32)【優先日】2019-08-10
(33)【優先権主張国・地域又は機関】CN
【前置審査】
(73)【特許権者】
【識別番号】520476341
【氏名又は名称】北京字節跳動網絡技術有限公司
【氏名又は名称原語表記】Beijing Bytedance Network Technology Co., Ltd.
【住所又は居所原語表記】Room B-0035, 2/F, No.3 Building, No.30, Shixing Road, Shijingshan District Beijing 100041 China
(73)【特許権者】
【識別番号】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)【発明者】
【氏名】ザン,リー
(72)【発明者】
【氏名】シュイ,ジィジォン
【審査官】久保 光宏
(56)【参考文献】
【文献】Benjamin Bross, et al.,"Versatile Video Coding (Draft 6)",Document: JVET-O2001-vE, [online],JVET-O2001 (version 14),Joint Video Experts Team (JVET) of ITU-T SG 16 WP 3 and ISO/IEC JTC 1/SC 29/WG 11,2019年07月31日,p.37-40,87-97,137-146,198,199,279,280,[令和5年2月27日検索], インターネット, <URL: https://jvet-experts.org/doc_end_user/current_document.php?id=7824> and <URL: https://jvet-experts.org/doc_end_user/documents/15_Gothenburg/wg11/JVET-O2001-v14.zip>.,(See document file "JVET-O2001-vE.docx" in the zip file "JVET-O2001-v14.zip".)
【文献】Byeongdoo Choi, et al.,"AHG12: On sub-picture partitioning",Document: JVET-N0055-v2, [online],JVET-N0055 (version 2),Joint Video Experts Team (JVET) of ITU-T SG 16 WP 3 and ISO/IEC JTC 1/SC 29/WG 11,2019年03月20日,p.1-7,[令和6年3月15日検索], インターネット, <URL: https://jvet-experts.org/doc_end_user/current_document.php?id=5775> and <URL: https://jvet-experts.org/doc_end_user/documents/14_Geneva/wg11/JVET-N0055-v2.zip>.,(See document file "JVET-N0055-v2.docx" in the zip file "JVET-N0055-v2.zip".)
【文献】Xiaozhong Xu, et al.,"Intra Block Copy in HEVC Screen Content Coding Extensions",IEEE Journal on Emerging and Selected Topics in Circuits and Systems,IEEE,2016年12月,Vol.6, No.4,p.409-419,ISSN: 2156-3357, <DOI: 10.1109/JETCAS.2016.2597645>.
【文献】Yu-Chen Sun, et al.,"Improvements of HEVC SCC Palette Mode and Intra Block Copy",IEEE Journal on Emerging and Selected Topics in Circuits and Systems,IEEE,2016年12月,Vol.6, No.4,p.433-445,ISSN: 2156-3357, <DOI: 10.1109/JETCAS.2016.2598193>.
【文献】Wei Pu, et al.,"Palette Mode Coding in HEVC Screen Content Coding Extension",IEEE Journal on Emerging and Selected Topics in Circuits and Systems,IEEE,2016年12月,Vol.6, No.4,p.420-432,ISSN: 2156-3357, <DOI: 10.1109/JETCAS.2016.2605661>.
【文献】Jizheng Xu, et al.,"Overview of the Emerging HEVC Screen Content Coding Extension",IEEE Transactions on Circuits and Systems for Video Technology,IEEE,2016年01月,Vol.26, No.1,p.50-62,ISSN: 1051-8215, <DOI: 10.1109/TCSVT.2015.2478706>.
【文献】Shan Liu, et al.,"Overview of HEVC extensions on screen content coding",APSIPA Transactions on Signal and Information Processing, [online],Cambridge University Press,2015年09月22日,Vol.4,全12頁,[令和5年2月28日検索], インターネット, <URL: https://www.cambridge.org/core/journals/apsipa-transactions-on-signal-and-information-processing/article/overview-of-hevc-extensions-on-screen-content-coding/E12DCF69B0A59DD269EFE14CD1AFBFBE>,<DOI: https://doi.org/10.1017/ATSIP.2015.11>.
【文献】Jianle Chen, et al.,"Algorithm description for Versatile Video Coding and Test Model 9 (VTM 9)",Document: JVET-R2002-v2, [online],JVET-R2002 (version 2),Joint Video Experts Team (JVET) of ITU-T SG 16 WP 3 and ISO/IEC JTC 1/SC 29/WG 11,2020年06月15日,Pages 1,8,9,90-93,[令和5年9月9日検索], インターネット, <URL: https://jvet-experts.org/doc_end_user/current_document.php?id=10156> and <URL: https://jvet-experts.org/doc_end_user/documents/18_Alpbach/wg11/JVET-R2002-v2.zip>.
(58)【調査した分野】(Int.Cl.,DB名)
H04N19/00-19/98
CSDB(日本国特許庁)
学術文献等データベース(日本国特許庁)
IEEEXplore(IEEE)
(57)【特許請求の範囲】
【請求項1】
ビデオデータを処理する方法であって、
ビデオの第1ピクチャの第1ビデオブロックと前記ビデオのビットストリームとの間の第1変換のために、第1予測モードが前記第1ビデオブロックに適用されると決定するステップと、
前記第1予測モードのために、前記第1ピクチャのサンプル値のブロックから導出された参照サンプルを含む仮想バッファを維持するステップと、
前記第1ビデオブロックについて、前記決定に基づき予測サンプルを導出するステップと、
前記第1ビデオブロックと前記ビットストリームとの間の前記第1変換を実行するステップと、
を含み、
前記第1予測モードでは、前記仮想バッファ内のブロックベクトルにより決定された前記参照サンプルは、前記予測サンプルの導出のために使用され、
ビデオピクチャが複数のサブピクチャに分割されるサブピクチャコーディングモードが前記第1ピクチャに対して有効であり、前記仮想バッファは前記第1ピクチャのサブピクチャを処理する前にリセットされる、方法。
【請求項2】
前記仮想バッファ内の前記参照サンプルは-1になるようリセットされる、請求項1に記載の方法。
【請求項3】
前記ビデオの第2ピクチャの第2ビデオブロックと前記ビットストリームとの間の第2変換のために、第2予測モードが前記第2ビデオブロックに適用されると決定するステップと、
前記第2予測モードのために、予測子パレットを維持するステップと、
前記第2予測モードに基づき、前記第2ビデオブロックと前記ビットストリームとの間の前記第2変換を実行するステップと、
を更に含み、
前記第2予測モードでは、再構成サンプルは代表カラー値のセットにより表され、前記代表カラー値のセットは、前記ビットストリームに含まれる
パレット予測子
を少なくとも
含み、
前記サブピクチャコーディングモードは前記第2ピクチャに対して有効であり、前記予測子パレットのエントリリストは、前記第2ピクチャのサブピクチャを処理する前にリセットされる、請求項1又は2に記載の方法。
【請求項4】
予測子パレットのサイズは、前記第2ピクチャの前記サブピクチャを処理する前に、0になるよう設定される、請求項3に記載の方法。
【請求項5】
前記サブピクチャコーディングモードが有効であると示す第1シンタックスエレメントが、前記ビットストリーム内のシーケンスパラメータセットに含まれる、請求項1~4のいずれか一項に記載の方法。
【請求項6】
サブピクチャの幅を示すために、第2シンタックスエレメントが前記ビットストリームに含まれ、サブピクチャの高さを示すために、第3シンタックスエレメントが前記ビットストリームに含まれる、請求項1~5のいずれか一項に記載の方法。
【請求項7】
サブピクチャの左上位置を示すために、第4シンタックスエレメントが前記ビットストリームに含まれる、請求項1~6のいずれか一項に記載の方法。
【請求項8】
前記ビデオピクチャの2つのサブピクチャは重なり合わない領域を有する、請求項1~7のいずれか一項に記載の方法。
【請求項9】
サブピクチャは長方形形状を有するよう制約される、請求項1~8のいずれか一項に記載の方法。
【請求項10】
前記変換は、前記ビデオを前記ビットストリームに符号化することを含む、請求項1~9のいずれか一項に記載の方法。
【請求項11】
前記変換は、前記ビットストリームから前記ビデオを復号することを含む、請求項1~9のいずれか一項に記載の方法。
【請求項12】
ビデオデータを処理する機器であって、前記機器はプロセッサと格納された命令を有する非一時的メモリとを含み、前記命令は、前記プロセッサにより実行されると、前記プロセッサに、
ビデオの第1ピクチャの第1ビデオブロックと前記ビデオのビットストリームとの間の第1変換のために、第1予測モードが前記第1ビデオブロックに適用されると決定させ、
前記第1予測モードのために、前記第1ピクチャのサンプル値のブロックから導出された参照サンプルを含む仮想バッファを維持させ、
前記第1ビデオブロックについて、前記決定に基づき予測サンプルを導出させ、
前記第1ビデオブロックと前記ビットストリームとの間の前記第1変換を実行させ、
前記第1予測モードでは、前記仮想バッファ内のブロックベクトルにより決定された前記参照サンプルは、前記予測サンプルの導出のために使用され、
ビデオピクチャが複数のサブピクチャに分割されるサブピクチャコーディングモードが前記第1ピクチャに対して有効であり、前記仮想バッファは前記第1ピクチャのサブピクチャを処理する前にリセットされる、機器。
【請求項13】
命令を格納している非一時的コンピュータ可読記憶媒体であって、前記命令はプロセッサに、
ビデオの第1ピクチャの第1ビデオブロックと前記ビデオのビットストリームとの間の第1変換のために、第1予測モードが前記第1ビデオブロックに適用されると決定させ、
前記第1予測モードのために、前記第1ピクチャのサンプル値のブロックから導出された参照サンプルを含む仮想バッファを維持させ、
前記第1ビデオブロックについて、前記決定に基づき予測サンプルを導出させ、
前記第1ビデオブロックと前記ビットストリームとの間の前記第1変換を実行させ、
前記第1予測モードでは、前記仮想バッファ内のブロックベクトルにより決定された前記参照サンプルは、前記予測サンプルの導出のために使用され、
ビデオピクチャが複数のサブピクチャに分割されるサブピクチャコーディングモードが前記第1ピクチャに対して有効であり、前記仮想バッファは前記第1ピクチャのサブピクチャを処理する前にリセットされる、非一時的コンピュータ可読記憶媒体。
【請求項14】
ビデオのビットストリームを格納する方法であって、前記方法は、
ビデオの第1ピクチャの第1ビデオブロックについて、第1予測モードが前記第1ビデオブロックに適用されると決定するステップと、
前記第1予測モードのために、前記第1ピクチャのサンプル値のブロックから導出された参照サンプルを含む仮想バッファを維持するステップと、
前記第1ビデオブロックについて、前記決定に基づき予測サンプルを導出するステップと、
前記決定に基づき、前記ビットストリームを生成するステップと、
前記ビットストリームを非一時的コンピュータ可読記録媒体に格納するステップと、
を含み、
前記第1予測モードでは、前記仮想バッファ内のブロックベクトルにより決定された前記参照サンプルは、前記予測サンプルの導出のために使用され、
ビデオピクチャが複数のサブピクチャに分割されるサブピクチャコーディングモードが前記第1ピクチャに対して有効であり、前記仮想バッファは前記第1ピクチャのサブピクチャを処理する前にリセットされる、
方法。
【発明の詳細な説明】
【技術分野】
【0001】
[関連出願]
本願は、国際特許出願番号第PCT/CN2019/100114号、2019年8月10日出願の優先権及び利益を請求する国際特許出願番号第PCT/CN2020/108182号、2020年8月10日出願に基づく。前述の出願の全ての開示は、参照によりここに組み込まれる。
【0002】
[技術分野]
本願明細書は、ビデオ及び画像コーディング及び復号技術に関する。
【背景技術】
【0003】
デジタルビデオは、インターネット及び他のデジタル通信ネットワーク上で最大の帯域幅使用を占める。ビデオを受信及び表示可能な接続されたユーザ装置の数が増加するにつれ、デジタルビデオ使用のための帯域幅要求は増大し続けることが予想される。
【発明の概要】
【0004】
開示の技術は、サブピクチャに基づくコーディング又は復号が実行されるビデオ又は画像デコーダ又はエンコーダの実施形態により使用されてよい。
【0005】
1つの例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ビデオの第1ピクチャの現在ブロックと前記ビデオのビットストリーム表現との間の変換のために、ルールに従い、第2ピクチャからの動き情報に基づき、動き候補を決定するステップを含む。前記ルールは、前記動き情報がアクセスされる位置が、前記第2ピクチャの特定のサブピクチャの範囲内であるよう制約されることを指定する。前記方法は、前記決定に基づき変換を実行するステップを含む。
【0006】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ビデオの第1ピクチャの現在ブロックと前記ビデオのビットストリーム表現の変換のために、ルールに従い、第2ピクチャからの整数サンプルを決定するステップを含む。前記第2ピクチャは、補間処理において使用されない参照ピクチャを含む。前記ルールは、前記整数サンプルがアクセスされる位置が、前記第2ピクチャの特定のサブピクチャの範囲内であるよう制約されることを指定する。前記方法は、前記決定に基づき変換を実行するステップを含む。
【0007】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ビデオの現在ブロックと前記ビデオのビットストリーム表現の変換のために、ルールに従い、再構成ルマサンプルがアクセスされる位置を決定するステップを含む。前記ルールは、前記位置が、前記ビデオピクチャの特定のサブピクチャの範囲内であるよう制約されることを指定する。前記方法は、前記決定に基づき変換を実行するステップを含む。
【0008】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ビデオの現在ブロックと前記ビデオのビットストリーム表現の変換のために、ルールに従い、ピクチャ境界チェックが実行される位置を決定するステップを含む。前記ルールは、前記位置が、前記ビデオピクチャの特定のサブピクチャの範囲内であるよう制約されることを指定する。前記方法は、前記決定に基づき変換を実行するステップを含む。
【0009】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ビデオのビデオピクチャのサブピクチャと前記ビデオのビットストリーム表現の変換の後に、過去の変換に基づき導出された動き候補のテーブルを再設定するステップと、前記再設定の後の前記テーブルを用いて、前記ビデオピクチャの後続のサブピクチャと前記ビットストリーム表現の変換を実行するステップと、を含む。
【0010】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ルールに従い、複数のサブピクチャ及び複数のビデオブロックを含むビデオピクチャを有するビデオと、前記ビデオのコーディング表現との間の変換を実行するステップを含む。前記ルールは、任意の2つのサブピクチャが、2つのビデオブロックの間の境界でもあることを指定する。前記ビデオピクチャ内のビデオブロックは、前記ビデオピクチャの単一のサブピクチャによりカバーされる。
【0011】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、少なくともビデオピクチャを用いて、ビデオのビデオユニットと前記ビデオのコーディング表現との間の変換を実行するステップを含み、サブピクチャコーディングモード又は解像度変化コーディングモードのうちの1つのみが、前記ビデオユニットに対して有効である。前記サブピクチャコーディングモードは、前記ビデオピクチャが複数のサブピクチャに分割されるモードであり、前記解像度変化コーディングモードは、前記ビデオピクチャの解像度が前記変換中に調整されるモードである。
【0012】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、少なくともビデオピクチャを用いて、ビデオのビデオユニットと前記ビデオのコーディング表現との間の変換を実行するステップを含み、サブピクチャコーディングモード及び解像度変化コーディングモードの両方が、前記ビデオユニットに対して有効である。前記サブピクチャコーディングモードは、前記ビデオピクチャが複数のサブピクチャに分割されるモードであり、前記解像度変化コーディングモードは、前記ビデオピクチャの解像度が前記変換中に調整されるモードである。
【0013】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、1つ以上のビデオピクチャを含むビデオと前記ビデオのコーディング表現との間の変換を実行するステップ、を含み、個々のビデオピクチャの寸法は、8以上になるよう制約される。幾つかの実施形態では、前記寸法は前記個々のビデオピクチャの幅である。
【0014】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ルールに従い、ビデオのビデオピクチャと前記ビデオのコーディング表現との間の変換を実行するステップを含む。前記ビデオピクチャは少なくとも1つのサブピクチャを含み、前記ルールは、サブピクチャの特性が前記コーディング表現の中の少なくとも1つのシンタックスエレメントとして表現されることを指定し、前記少なくとも1つのシンタックスエレメントは、前記ビデオピクチャ内のサブピクチャグリッドのインデックス値と異なる。
【0015】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ルールに従い、ビデオのビデオユニットと前記ビデオのコーディング表現との間の変換を実行するステップを含む。前記ビデオピクチャは複数のサブピクチャを含み、各サブピクチャは複数のエレメントを含む。前記ルールは、サブピクチャ内の個々のエレメントの寸法が制約を満たすことを指定する。
【0016】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ルールに従い、コーディングモードを用いて、複数のサブピクチャを含むピクチャを有するビデオと、前記ビデオのコーディング表現との間の変換を実行するステップを含む。前記ルールは、前のサブピクチャに関する特定の格納された情報が、前記複数のサブピクチャのうちの各々の次のサブピクチャを処理する前に、再設定されることを指定する。
【0017】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ルールに従い、ビデオと前記ビデオのコーディング表現との間の変換において、時間フィルタリング動作を実行するステップを含む。前記ビデオは複数のビデオピクチャを含み、各ビデオピクチャは複数のサブピクチャを含む。前記ルールは、ビデオピクチャの現在サブピクチャ内の現在サンプルを時間フィルタリングするために、同じ現在サブピクチャ又は現在サブピクチャに対応する異なるビデオピクチャ内のサブピクチャの範囲内のサンプルのみが利用可能であることを指定する。
【0018】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ビデオのビデオピクチャ内のブロックと前記ビデオのコーディング表現との間の変換のために、前記ブロックが前記ビデオピクチャの1つ以上のサブピクチャ境界と交差するかどうかに基づき、前記ブロックにパーティション方法を適用する方法を決定するステップを含む。前記方法は、前記決定に基づき変換を実行するステップを含む。
【0019】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ビデオのビデオピクチャと前記ビデオのコーディング表現との間の変換のために、前記ビデオピクチャのうちの2つのサブ領域を含む。第1サブ領域は、前記ビデオピクチャの複数のサブピクチャを含み、第2サブ領域は、前記ビデオピクチャ内のサンプルを維持することを含む。前記方法は、前記決定に基づき変換を実行するステップを含む。
【0020】
別の例示的な態様では、ビデオ処理の方法が開示される。前記方法は、ビデオの第1ビデオ領域内のビデオブロックについて、アフィンモードを用いて前記ビデオブロックと現在ビデオブロックのビットストリーム表現との間の変換のために時間動きベクトル予測子が決定される位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップと、前記決定に基づき前記変換を実行するステップと、を含む。
【0021】
別の例示的な態様では、ビデオ処理の別の方法が開示される。前記方法は、ビデオの第1ビデオ領域内のビデオブロックについて、前記ビデオブロックと現在ビデオブロックのビットストリーム表現との間の変換のために参照ピクチャ内の整数サンプルがフェッチされる位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップであって、前記参照ピクチャは前記変換中に補間処理において使用されない、ステップと、前記決定に基づき前記変換を実行するステップと、を含む。
【0022】
別の例示的な態様では、ビデオ処理の別の方法が開示される。前記方法は、ビデオの第1ビデオ領域内のビデオブロックについて、前記ビデオブロックと現在ビデオブロックのビットストリーム表現との間の変換のために再構成ルマサンプル値がフェッチされる位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップと、前記決定に基づき前記変換を実行するステップと、を含む。
【0023】
別の例示的な態様では、ビデオ処理の別の方法が開示される。前記方法は、ビデオの第1ビデオ領域内のビデオブロックについて、前記ビデオブロックと前記現在ビデオブロックのビットストリーム表現との間の変換中に、前記ビデオブロックについて分割に関するチェック、深さ導出、又は分割フラグシグナリングが実行される位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップと、前記決定に基づき前記変換を実行するステップと、を含む。
【0024】
別の例示的な態様では、ビデオ処理の別の方法が開示される。前記方法は、1つ以上のビデオブロックを含む1つ以上のビデオピクチャを含むビデオと、前記ビデオのコーディング表現との間の変換を実行するステップを含み、前記コーディング表現は、前記変換がサブピクチャコーディング/復号、及び動的解像度変換コーディング/復号ツール又は参照ピクチャ再サンプリングツールをビデオユニット内で使用しないというコーディングシンタックス要件に従う。
【0025】
別の例示的な態様では、ビデオ処理の別の方法が開示される。前記方法は、1つ以上のビデオブロックを含む1つ以上のビデオピクチャを含むビデオと、前記ビデオのコーディング表現との間の変換を実行するステップを含み、前記コーディング表現は、第1シンタックスエレメントsubpic_grid_idx[i][j]が第2シンタックスエレメントmax_subpics_minus1より大きくないというコーディングシンタックス要件に従う。
【0026】
更に別の例示的な態様では、上述の方法は、プロセッサを含むビデオエンコーダ機器により実施されてよい。
【0027】
更に別の例示的な態様では、上述の方法は、プロセッサを含むビデオデコーダ機器により実施されてよい。
【0028】
更に別の例示的な態様では、これらの方法は、プロセッサ実行可能命令の形式で具現命令され、コンピュータ可読プログラム媒体に格納されてよい。
【0029】
これら及び他の態様は、本願明細書において更に記載される。
【図面の簡単な説明】
【0030】
【
図1】時間動きベクトル予測(TMVP)及びサブブロックTMVPにおける領域制約の例を示す。
【0031】
【0032】
【
図3】本願明細書に記載される技術を実施するために使用されるハードウェアプラットフォームの例のブロック図である。
【0033】
【
図4】ビデオ処理の例示的な方法のフローチャートである。
【0034】
【
図5】本願明細書に開示される種々の技術が実施され得る例示的なビデオ処理システムを示すブロック図である。
【0035】
【
図6】本発明の技術によるビデオ処理の方法のフローチャート表現である。
【0036】
【
図7】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0037】
【
図8】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0038】
【
図9】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0039】
【
図10】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0040】
【
図11】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0041】
【
図12】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0042】
【
図13】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0043】
【
図14】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0044】
【
図15】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0045】
【
図16】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0046】
【
図17】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0047】
【
図18】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0048】
【
図19】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【0049】
【
図20】本発明の技術によるビデオ処理の別の方法のフローチャート表現である。
【発明を実施するための形態】
【0050】
本願明細書は、伸長又は復号デジタルビデオ又は画像の品質を向上するために画像又はビデオビットストリームのデコーダにより使用できる種々の技術を提供する。簡単のために、用語「ビデオ」は、本願明細書で、ピクチャのシーケンス(伝統的にビデオと呼ばれる)及び個々の画像の両方を含むために使用される。更に、ビデオエンコーダも、更なる符号化のために使用される復号フレームを再構成するために、符号化の処理の間に、これらの技術を実施してよい。
【0051】
章見出しは、本願明細書において理解を容易にするために使用され、実施形態及び技術を対応する章に限定するものではない。従って、1つの章からの実施形態は、他の章からの実施形態と結合できる。
【0052】
1.概要
【0053】
本願明細書は、ビデオコーディング技術に関する。具体的に、ビデオコーディングにおける下地色(base colors)に基づく表現を利用するパレットコーディングに関する。それは、HEVCのような既存のビデオコーディング規格、又は完成されるべき規格(Versatile Video Coding)に適用されてよい。それは、将来のビデオコーディング規格又はビデオコーデックにも適用可能であってよい。
【0054】
2.最初の議論
【0055】
ビデオコーディング規格は、主によく知られたITU-T及びISO/IEC規格の発展を通じて進化している。ITU-TはH.261及びH.263を策定し、ISO/IECはMPEG-1及びMPEG-4ビジュアルを策定し、及び2つの組織は共同でH.262/MPEG-2ビデオ、及びH.264/MPEG-4アドバンストビデオコーディング(Advanced Video Coding)及びH.265/HEVC規格を策定した[1,2]。H.262以降、ビデオコーディング規格は、ハイブリッドビデオコーディング構造に基づき、ここでは時間予測及び変換コーディングが利用される。HEVCより先の将来のコーディング技術を開発するために、共同ビデオ探索チーム(Joint Video Exploration Team (JVET))が2015年にVCEG及びMPEGにより共同で設立された。それ以来、多くの新しい方法がJVETにより採用され、共同探索モデル(Joint Exploration Model (JEM))と呼ばれる参照ソフトウェアに取り入れられてきた。2018年4月には、HEVCと比べて50%のビットレート削減を目標とするVVC規格に取り組むために、VCEG(Q6/16)とISO/IEC JTC1 SC29/WG11(MPEG)との間の共同ビデオ専門家チーム(Joint Video Expert Team (JVET))が作成された。
【0056】
2.1 TMVP及びVVCのサブブロックTMVPにおける領域制約
【0057】
図1は、TMVP及びサブブロックTMVPにおける例示的な領域制約を示す。TMVP及びサブブロックTMVPでは、時間MVは、
図1に示されるように、同一位置CTU、及び4×4ブロックの列からのみフェッチできる。
【0058】
2.2 例示的なサブピクチャ
【0059】
幾つかの実施形態では、フレキシブルタイリングアプローチに基づく、サブピクチャに基づくコーディング技術が実施できる。サブピクチャに基づくコーディング技術の要約は、以下を含む:
(1)ピクチャは、サブピクチャに分割できる。
【0060】
(2)サブピクチャの存在の指示は、サブピクチャの他のシーケンスレベル情報と一緒に、SPS内で示される。
【0061】
(3)サブピクチャが復号処理(インループフィルタリング動作を除く)においてピクチャとして扱われるかどうかは、ビットストリームにより制御できる。
【0062】
(4)サブピクチャ境界に跨がるインループフィルタリングが無効にされるかどうかはサブピクチャ毎にビットストリームにより制御できる。DBF、SAO、及びALF処理は、サブピクチャ境界に跨がるインループフィルタリング動作の制御のために更新される。
【0063】
(5)簡単のために、開始点として、サブピクチャ幅、高さ、水平オフセット、及び垂直オフセットが、SPS内のルマサンプルのユニットの中でシグナリングされる。サブピクチャ境界は、スライス境界になるよう制約される。
【0064】
(6)復号処理(インループフィルタリング動作を除く)においてサブピクチャをピクチャとして扱うことは、coding_tree_unit()シンタックスを僅かに更新することにより指定され、以下の復号処理を更新する:
【0065】
-(高度)時間ルマ動きベクトル予測の導出処理。
【0066】
-ルマサンプル双線形補間処理。
【0067】
-ルマサンプル8タップ補間フィルタリング処理。
【0068】
-クロマサンプル補間処理。
【0069】
(7)サブピクチャIDは、VCL NALユニットを変更する必要を伴わずにサブピクチャシーケンスの抽出を可能にするために、SPS内で明示的に指定され、タイルグループヘッダに含まれる。
【0070】
(8)出力サブピクチャセット(Output sub-picture sets (OSPS))は、サブピクチャ及びそのセットについて、基準となる抽出及び適合点を指定するために提案される。
【0071】
2.3 VVC(Versatile Video Coding)における例示的なサブピクチャ
シーケンスパラメータセット(sequence parameter set (RBSP))シンタックス
【表1】
subpics_present_flagが1に等しいことは、SPS RBSPシンタックス内にサブピクチャパラメータが存在することを示す。subpics_present_flagが0に等しいことは、SPS RBSPシンタックス内にサブピクチャパラメータが存在しないことを示す。
注2:ビットストリームがサブビットストリーム抽出処理の結果であり、サブビットストリーム抽出処理への入力ビットストリームのサブピクチャの一部のみを含むとき、SPSのRBSP内のsubpics_present_flagの値を1に等しく設定することが要求され得る。
max_subpics_minus1に1を加えたものは、CVS内に存在し得るサブピクチャの最大数を指定する。max_subpics_minus1は、0~254の範囲内であるべきである。255の値は、ITU-T|ISO/IECによる将来の使用のために予約されている。
subpic_grid_col_width_minus1に1を加えたものは、4個のサンプルのユニット内のサブピクチャ識別子の各要素の幅を指定する。シンタックスエレメントの長さは、Ceil(Log2(pic_width_max_in_luma_samples/4))ビットである。
変数NumSubPicGridColsは、以下のように導出される。
【数1】
subpic_grid_row_height_minus1に1を加えたものは、4個のサンプルのユニット内のサブピクチャ識別子の各要素の高さを指定する。シンタックスエレメントの長さは、Ceil(Log2(pic_height_max_in_luma_samples/4))ビットである。
変数NumSubPicGridRowsは、以下のように導出される。
【数2】
subpic_grid_idx[i][j]は、グリッド位置(i,j)のサブピクチャインデックスを指定する。シンタックスエレメントの長さは、Ceil(Log2(max_subpics_minus1+1))ビットである。
変数SubPicTop[subpic_grid_idx[i][j]]、SubPicLeft[subpic_grid_idx[i][j]、SubPicWidth[subpic_grid_idx[i][j]]、SubPicHeight[subpic_grid_idx[i][j]]、及びNumSubPicsは、以下のように導出される:
【数3】
subpic_treated_as_pic_flag[i]が1に等しいことは、CVS内の各コーディングピクチャのi番目のサブピクチャが、インループフィルタリング動作を除く復号処理でピクチャとして扱われることを指定する。subpic_treated_as_pic_flag[i]が0に等しいことは、CVS内の各コーディングピクチャのi番目のサブピクチャが、インループフィルタリング動作を除く復号処理でピクチャとして扱われないことを指定する。存在しないとき、subpic_treated_as_pic_flag[i]の値は0に等しいと推定される。
loop_filter_across_subpic_enabled_flag[i]が1に等しいことは、CVS内の各コーディングピクチャ内のi番目のサブピクチャの境界に渡り、インループフィルタリング動作が実行されてよいことを指定する。loop_filter_across_subpic_enabled_flag[i]が0に等しいことは、CVS内の各コーディングピクチャ内のi番目のサブピクチャの境界に渡り、インループフィルタリング動作が実行されないことを指定する。存在しないとき、vloop_filter_across_subpic_enabled_pic_flag[i]の値は1に等しいと推定される。
ビットストリーム適合の要件は、以下の制約を適用することである:
任意の2つのサブピクチャsubpicA及びsubpicBについて、subpicAのインデックスがsubpicBのインデックスより小さいとき、subpicAの任意のコーディングNALユニットは、復号順序で、subpicBの任意のコーディングNALユニットの後に続くべきである。
サブピクチャの形状は、各サブピクチャが、復号されるとき、ピクチャ境界を構成する又は前に復号されたサブピクチャの境界を構成する、その左境界全体及び上境界全体を有するべきである。
両端を含む0~PicSizeInCtbsY-1の範囲のctbAddrRsのリストCtbToSubPicIdx[ctbAddrRs]は、ピクチャラスタスキャンにおけるCTBからサブピクチャインデックスへの変換を指定し、以下のように導出される:
【数4】
num_bricks_in_slice_minus1は、存在するとき、スライス内のブリック数-1を指定する。num_bricks_in_slice_minus1の値は、両端を含む0~NumBricksInPic-1の範囲内であるべきである。rect_slice_flagが0に等しく、single_brick_per_slice_flagが1に等しいとき、num_bricks_in_slice_minus1の値は0に等しいと推定される。single_brick_per_slice_flagが1に等しいとき、num_bricks_in_slice_minus1の値は0に等しいと推定される。
現在スライス内のブリックの数を指定する変数NNumBricksInCurrSlice、及び現在スライス内のi番目のブリックのブリックインデックスを指定するSliceBrickIdx[i]は、以下のように導出されてよい:
【数5】
変数SubPicIdx、SubPicLeftBoundaryPos、SubPicTopBoundaryPos、SubPicRightBoundaryPos、及びSubPicBotBoundaryPosは、以下のように導出される:
【数6】
時間ルマ動きベクトル予測の導出処理
この処理への入力は:
-現在ピクチャの左上ルマサンプルに対する、現在ルマコーディングブロックの左上サンプルのルマ位置(xCb,yCb)、
-ルマサンプルの中で現在コーディングブロックの幅を指定する変数cbWidth、
-ルマサンプルの中で現在コーディングブロックの高さを指定する変cbHeight、
-参照インデックスrefIdxLX、Xは0又は1である。
この処理の出力は:
-1/16分数サンプル精度の動きベクトル予測mvLXCol、
-利用可能性フラグavailableFlagLXCol。
変数currCbは、ルマ位置(xCb,yCb)にある現在ルマコーディングブロックを指定する。
変数mvLXCol及びavailableFlagLXColは、以下のように導出される:
-slice_temporal_mvp_enabled_flagが0に等しいか、又は(cbWidth*cbHeight)が32以下である場合、mvLXColの両方の成分は0に等しく設定され、availableFlagLXColは0に等しく設定される。
-その他の場合(slice_temporal_mvp_enabled_flagが1に等しい)、以下の順序付きステップが適用される:
1.右下同一位置動きベクトル、並びに下及び右境界サンプル位置は、以下のように導出される:
【数7】
-yCb>>CtbLog2SizeYがyColBr>>CtbLog2SizeYと等しい場合、yColBrはbotBoundaryPos以下であり、xColBrはrightBoundaryPos以下であり、以下が適用される:
・変数colCbは、ColPicにより指定される同一位置ピクチャの内側の、((xColBr>>3)<<3,(yColBr>>3)<<3)により与えられる変更位置をカバーするルマコーディングブロックを指定する。
・ルマ位置(xColCb,yColCb)は、ColPicにより指定される同一位置ピクチャの左上ルマサンプルに対する、colCbにより指定される同一位置ルマコーディングブロックの左上サンプルに等しく設定される。
・8.5.2.12項に指定される同一位置動きベクトルの導出処理は、currCb、colCb、(xColCb,yColCb)、refIdxLX、及び0に等しく設定されたsbFlagを入力として呼び出され、出力はmvLXCol及びavailableFlagLXColに割り当てられる。
その他の場合、mvLXColの両方のコンポーネントは0に等しく設定され、availableFlagLXColは0に等しく設定される。
…
ルマサンプル双線形補間処理
この処理への入力は:
-フルサンプルユニット内のルマ位置(xInt
L,yInt
L)、
-分数サンプルユニット内のルマ位置(xFrac
L,yFrac
L)、
-ルマ参照サンプルアレイrefPicLX
L。
この処理の出力は、予測ルマサンプル値predSampleLX
Lである。
変数shift1、shift2、shift3、shift4、offset1、offset2、及びoffset3は、以下のように導出される:
【数8】
変数picWは、pic_width_in_luma_samplesに等しく設定され、変数picHはpic_height_in_luma_samplesに等しく設定される。
【0072】
xFrac
L又はyFrac
Lに等しい1/16分数サンプル位置p毎のルマ補間フィルタ係数fb
L[p]は、表8-10で指定される。
フルサンプルユニットのルマ位置(xInt
i,yInt
i)は、i=0..1について以下のように導出される:
-subpic_treated_as_pic_flag[SubPicIdx]が1に等しい場合、以下が適用される。
【数9】
-その他の場合(subpic_treated_as_pic_flag[SubPicIdx]が0に等しい)、以下が適用される:
【数10】
サブブロックに基づく時間マージ候補の導出処理
この処理への入力は:
-現在ピクチャの左上ルマサンプルに対する、現在ルマコーディングブロックの左上サンプルのルマ位置(xCb,yCb)、
-ルマサンプルの中で現在コーディングブロックの幅を指定する変数cbWidth、
-ルマサンプルの中で現在コーディングブロックの高さを指定する変数cbHeight、
-近隣コーディングユニットの利用可能性フラグavailableFlagA
1、
-近隣コーディングユニットの参照インデックスrefIdxLXA
1、Xは0又は1、
-近隣コーディングユニットの予測リスト利用フラグpredFlagLXA
1、Xは0又は1、
-近隣コーディングユニットの1/16分数サンプル精度の動きベクトルmvLXA
1、Xは0又は1。
この処理の出力は:
-利用可能性フラグavailableFlagSbCol、
-水平方向のルマコーディングサブブロックの数numSbX、及び垂直方向のnumSbY、
-参照インデックスrefIdxL0SbCol及びrefIdxL1SbCol、
-1/16分数サンプル精度のルマ動きベクトルmvL0SbCol[xSbIdx][ySbIdx]及びmvL1SbCol[xSbIdx][ySbIdx]、xSbIdx=0..numSbX-1,ySbIdx=0..numSbY-1、
-予測リスト利用フラグpredFlagL0SbCol[xSbIdx][ySbIdx]及びpredFlagL1SbCol[xSbIdx][ySbIdx]、xSbIdx=0..numSbX-1,ySbIdx=0..numSbY-1。
利用可能性フラグavailableFlagSbColは以下のように導出される。
-以下の条件のうちの1つ以上が真である場合、availableFlagSbColが0に等しく設定される。
・-slice_temporal_mvp_enabled_flagが0に等しい。
・sps_sbtmvp_enabled_flagが0に等しい。
・cbWidthが8未満である。
・cbHeightが8未満である。
-その他の場合、以下の順序付きステップが適用される:
1.現在コーディングブロックを含むルマコーディングツリーブロックの左上サンプルの位置(xCtb,yCtb)及び現在ルマコーディングブロックの右下中央の位置(xCtr,yCtr)が以下のように導出される:
【数11】
2.ルマ位置(xColCtrCb,yColCtrCb)は、ColPicにより指定される同一位置ピクチャの左上ルマサンプルに対する、ColPicの内側の(xCtr,yCtr)により与えられる位置をカバーする同一位置ルマコーディングブロックの左上サンプルに等しく設定される。
3.8.5.5.4項で指定されるようなサブブロックに基づく時間マージ基本動きデータの導出処理は、位置(xCtb,yCtb)、位置(xColCtrCb,yColCtrCb)、利用可能性フラグavailableFlagA
1及び予測リスト利用フラグpredFlagLXA
1、並びに参照インデックスrefIdxLXA
1、及び動きベクトルvectormvLXA
1、Xは0又は1、を入力として呼び出され、同一位置ブロックの動きベクトルctrMvLX及び予測リスト利用フラグctrPredFlagLX、Xは0又は1、及び時間動きベクトルtempMvを出力とする。
4.変数availableFlagSbColは、以下のように導出される:
-ctrPredFlagL0及びctrPredFlagL1の両方が0に等しい場合、availableFlagSbColは0に等しく設定される。
-その他の場合、availableFlagSbColが1に等しく設定される。
availableFlagSbColが1に等しいとき、以下が適用される:
-変数numSbX,、numSbY、sbWidth、sbHeight及びrefIdxLXSbColは、以下のように導出される:
【数12】
-xSbIdx=0..numSbX-1及びySbIdx=0..numSbY-1について、動きベクトルmvLXSbCol[xSbIdx][ySbIdx]及び予測リスト利用フラグpredFlagLXSbCol[xSbIdx][ySbIdx]は、以下のように導出される:
・現在ピクチャの左上ルマサンプルに対する、現在コーディングサブブロックの左上サンプルを指定するルマ位置(xSb,ySb)は、以下のように導出される:
【数13】
・ColPic内の同一位置サブブロックの位置(xColSb,yColSb)は以下のように導出される:
・以下が適用される:
【数14】
・subpic_treated_as_pic_flag[SubPicIdx]が1に等しい場合、以下が適用される:
【数15】
・その他の場合(subpic_treated_as_pic_flag[SubPicIdx]が0に等しい)、以下が適用される:
【数16】
サブブロックに基づく時間マージベース動きデータの導出処理
この処理への入力は:
-現在コーディングブロックを含むルマコーディングツリーブロックの左上サンプルの位置(xCtb,yCtb)、
-右下中央サンプルをカバーする同一位置ルマコーディングブロックの左上サンプルの位置(xColCtrCb,yColCtrCb)、
-近隣コーディングユニットの利用可能性フラグavailableFlagA
1、
-近隣コーディングユニットの参照インデックスrefIdxLXA
1、
-近隣コーディングユニットの予測リスト利用フラグpredFlagLXA
1、
-近隣コーディングユニットの1/16分数サンプル精度の動きベクトルmvLXA
1。
この処理の出力は:
-動きベクトルctrMvL0及びctrMvL1、
-予測リスト利用フラグctrPredFlagL0及びctrPredFlagL1、
-時間動きベクトルtempMv。
変数tempMvは、以下のように設定される:
【数17】
変数currPicは、現在ピクチャを指定する。
availableFlagA
1がTRUEに等しいとき、以下が適用される:
-以下の条件のうちの全部が真である場合、tempMvはmvL0A
1に等しく設定される:
・predFlagL0A
1が1に等しい、
・DiffPicOrderCnt(ColPic,RefPicList[0][refIdxL0A
1])が0に等しい、
-その他の場合、以下の条件のうちの全部が真である場合、tempMvはmvL1A
1に等しく設定される:
・slice_typeがBにひとs、
・predFlagL1A
1が1に等しい、
・DiffPicOrderCnt(ColPic,RefPicList[1][refIdxL1A
1])が0に等しい。
ColPic内の同一位置ブロックの位置(xColCb,yColCb)は以下のように導出される:
-以下が適用される:
【数18】
-subpic_treated_as_pic_flag[SubPicIdx]が1に等しい場合、以下が適用される:
【数19】
-その他の場合(subpic_treated_as_pic_flag[SubPicIdx]が0に等しい)、以下が適用される:
【数20】
ルマサンプル補間フィルタリング処理
この処理への入力は:
-フルサンプルユニットのルマ位置(xInt
L,yInt
L)、
-分数サンプルユニットのルマ位置(xFrac
L,yFrac
L)、
-参照ピクチャの左上ルマサンプルに対する、参照サンプルパディングのための結合(bounding)ブロックの左上サンプルを指定するフルサンプルユニットのルマ位置(xSbInt
L,ySbInt
L)、
-ルマ参照サンプルアレイrefPicLX
L、
-ハーフサンプル補間フィルタインデックスhpelIfIdx、
-現在サブブロックの幅を指定する変数sbWidth、
-現在サブブロックの高を指定する変数sbHeight、
-現在ピクチャの左上ルマサンプルに対する、現在サブブロックの左上サンプルを指定するルマ位置(xSb,ySb)、
この処理の出力は、予測ルマサンプル値predSampleLX
Lである。
変数shift1、shift2及びshift3は、以下のように導出される:
-変数shift1はMin(4,BitDepth
Y-8)に等しく設定され、変数shift2は6に等しく設定され、変数shift3はMax(2,14-BitDepth
Y)に等しく設定される。
-変数picWは、pic_width_in_luma_samplesに等しく設定され、変数picHはpic_height_in_luma_samplesに等しく設定される。
xFrac
L又はyFrac
Lに等しい1/16分数サンプル位置p毎のルマ補間フィルタ係数f
L[p]は、以下のように導出される:
-MotionModelIdc[xSb][ySb]が0より大きく、sbWidth及びsbHeightが両方とも4に等しい場合、ルマ補間フィルタ係数f
L[p]は表8-12に指定される。
-その他の場合、ルマ補間フィルタ係数f
L[p]は、hpelIfIdxに依存して表8-11に指定される。
フルサンプルユニットのルマ位置(xInt
i,yInt
i)は、i=0..7について以下のように導出される:
-subpic_treated_as_pic_flag[SubPicIdx]が1に等しい場合、以下が適用される:
【数21】
-その他の場合(subpic_treated_as_pic_flag[SubPicIdx]が0に等しい)、以下が適用される:
【数22】
クロマサンプル補間処理
この処理への入力は:
-フルサンプルユニットのクロマ位置(xInt
C,yInt
C)、
-1/32分数サンプルユニットのクロマ位置(xFrac
C,yFrac
C)、
-参照ピクチャの左上クロマサンプルに対する、参照サンプルパディングのための結合(bounding)ブロックの左上サンプルを指定するフルサンプルユニットのクロマ位置(xSbIntC,ySbIntC)、
-現在サブブロックの幅を指定する変数sbWidth、
-現在サブブロックの高を指定する変数sbHeight、
-クロマ参照サンプルアレイrefPicLX
C。
この処理の出力は、予測クロマサンプル値predSampleLX
Cである。
変数shift1、shift2及びshift3は、以下のように導出される:
-変数shift1はMin(4,BitDepth
C-8)に等しく設定され、変数shift2は6に等しく設定され、変数shift3はMax(2,14-BitDepth
C)に等しく設定される。
-変数picW
Cは、pic_width_in_luma_samples/SubWidthCに等しく設定され、変数picH
Cはpic_height_in_luma_samples/SubHeightCに等しく設定される。
xFrac
C又はyFrac
Cに等しい1/32分数サンプル位置p毎のクロマ補間フィルタ係数f
C[p]は、表8-13で指定される。
変数xOffsetは、(sps_ref_wraparound_offset_minus1+1)*MinCbSizeY)/SubWidthCに等しく設定される。
フルサンプルユニットのクロマ位置(xInt
i,yInt
i)は、i=0..3について以下のように導出される:
-subpic_treated_as_pic_flag[SubPicIdx]が1に等しい場合、以下が適用される。
【数23】
-その他の場合(subpic_treated_as_pic_flag[SubPicIdx]が0に等しい)、以下が適用される:
【数24】
【0073】
2.4 例示的なエンコーダのみのGOPに基づく時間フィルタ
【0074】
幾つかの実施形態では、エンコーダのみの時間フィルタが実装できる。フィルタリングは、エンコーダ側で、前処理ステップとして行われる。符号化するために選択されたピクチャの前後のソースピクチャが読み出され、選択されたピクチャに対するブロックに基づく動き補償方法が、それらのソースピクチャに適用される。選択されたピクチャ内のサンプルは、動き補償後のサンプル値を用いて、時間フィルタされる。
【0075】
全体的なフィルタ強度は、QPと共に選択されたピクチャの時間サブレイヤに依存して設定される。時間サブレイヤ0及び1にあるピクチャのみがフィルタリングされ、レイヤ0のピクチャは、レイヤ1のピクチャより強力なフィルタによりフィルタリングされる。サンプル毎フィルタ強度は、選択されたピクチャ内のサンプル値と動き補償済みピクチャ内の同一位置サンプルとの間の差に依存して調整され、その結果、動き補償済みピクチャと選択されたピクチャとの間の小さな差は、大きな差よりも強力にフィルタリングされる。
【0076】
GOPに基づく時間フィルタ
【0077】
時間フィルタは、ピクチャを読み出した後、及び符号化前に直接導入される。以下は、より詳細に説明されるステップである。
【0078】
動作1:ピクチャがエンコーダにより読み出される。
【0079】
動作2:ピクチャがコーディング階層構造の中で十分に低い場合、符号化前にフィルタリングされる。その他の場合、ピクチャは、フィルタリングしないで符号化される。POC%8==0を有するRAピクチャは、POC%4==0を有するLDピクチャと同様にフィルタリングされる。AIピクチャはフィルタリングされない。
【0080】
全体のフィルタ強度s
oは、RAについて次式に従い設定される。
【数25】
【0081】
ここで、nは、読み出されたピクチャの数である。
【0082】
LDの場合、so(n)=0.95である。
【0083】
動作3:選択されたピクチャ(以下では元のピクチャと呼ばれる)の前及び/又は後の2つのピクチャが読み出される。エッジの場合、例えば、最初のピクチャ又は最後のピクチャに近い場合、利用可能なピクチャのみが読み出される。
【0084】
動作4:前及び後に読み出されたピクチャの、元のピクチャに対する動きは、8×8ピクチャブロック毎に推定される。
【0085】
階層的動き推定方式が使用され、レイヤL0、L1、及びL2が
図2に示される。サブサンプリングピクチャは、全部の読み出されたピクチャ及び元のピクチャ、例えば
図1のL1について各2×2ブロックを平均することにより生成される。L2は、同じサブサンプリング方法を用いてL1から導出される。
【0086】
図2は、階層動き推定の異なるレイヤの例を示す。L0は元の解像度である。L1はL0のサブサンプリングバージョンである。L2はL1のサブサンプリングバージョンである。
【0087】
先ず、動き推定は、L2内の16×16ブロック毎に行われる。選択された動きベクトル毎に差の平方が計算され、最小の差に対応する動きベクトルが選択される。選択された動きベクトルは、次に、L1内で動きベクトルを推定するときの初期値として使用される。次に、L0内の動きを推定するために同じことが行われる。最終ステップとして、L0上の補間フィルタを用いて、8×8ブロック毎に、サブピクセル動きが推定される。
【0088】
VTM6タップ補間フィルタが使用できる:
【表2】
【0089】
動作5:動き補償は、ブロック毎に最も一致する動きに従い、元のピクチャの前及び後のピクチャに適用される。例えば、その結果、各ブロック内の元のピクチャのサンプル座標は、参照されるピクチャの中の最も一致する座標を有する。
【0090】
動作6:ルマ及びクロマチャネルについて処理されたもの1つずつのサンプルは、以下のステップで説明される通りである。
【0091】
動作7:新しいサンプル値I
nが、次式を用いて計算される。
【数26】
【0092】
ここで、Ioは元のサンプルのサンプル値であり、Ir(i)は動き補償済みピクチャiの対応するサンプルの強度であり、wr(i,a)は、利用可能な動き補償済みピクチャの数がaであるとき、動き補償済みピクチャiの重みである。
【0093】
ルマチャネルでは、重みw
r(i,a)は以下のように定義される:
【数27】
【0094】
【0095】
【0096】
クロマチャネルでは、重みw
r(i,a)は以下のように定義される:
【数30】
【0097】
【0098】
動作8:フィルタは、現在サンプルに適用される。結果として生じるサンプル値は、個別に格納される。
【0099】
動作9:フィルタリング済みピクチャが符号化される。
【0100】
3. 開示の実施形態により解決される技術的問題の例
【0101】
(1)サブピクチャ制約に違反し得る幾つかの設計がある。
【0102】
(A)アフィン再構成候補におけるTMVPは、現在サブピクチャの範囲外にある同一位置ピクチャ内のMVをフェッチすることがある。
【0103】
(B)双方向オプティカルフロー(Bi-Directional Optical Flow (BDOF))及び予測精緻化オプティカルフロー(Prediction Refinement Optical Flow (PROF))における勾配を導出するとき、整数参照サンプルの2つの拡張された行及び2つの拡張された列が、フェッチされる必要がある。これらの参照サンプルは、現在サブピクチャの範囲外にある場合がある。
【0104】
(C)ルママッピングクロマスケーリング(luma mapping chroma scaling (LMCS))においてクロマ残差スケーリング因子を導出するとき、アクセスされる再構成済みルマサンプルは、現在サブピクチャの範囲の範囲外にある場合がある。
【0105】
(D)ルマイントラ予測モード、イントラ予測のための参照サンプル、CCLMのための参照サンプル、マージ/AMVP/CIIP/IBC/LMCSのための空間近隣候補のための近隣ブロック利用可能性、量子化パラメータ、CABAC初期化処理、左及び上シンタックスエレメントを用いるctxInc導出、及びctxIncfor、シンタックスエレメントmtt_split_cu_vertical_flagを導出するとき、近隣ブロックが現在サブピクチャの範囲外にある場合がある。サブピクチャの表現は、不完全なCTUを有するサブピクチャをもたらすことがある。CTUパーティション及びCU分割処理は、不完全なCTUを考慮する必要があり得る。
【0106】
(2)サブピクチャに関連するシグナリングされるシンタックスエレメントは、任意の大きさであってよく、これはオーバフロー問題を生じ得る。
【0107】
(3)サブピクチャの表現は、非長方形サブピクチャを生じ得る。
【0108】
(4)現在、サブピクチャ及びサブピクチャグリッドは、4サンプルの単位で定義される。そして、シンタックスエレメントの長さは、ピクチャの高さを4で割ったものに依存する。しかしながら、現在のpic_width_in_luma_samples及びpic_height_in_luma_samplesは、Max(8,MinCbSizeY)の整数倍でなければならず、サブピクチャグリッドは8サンプルの単位で定義される必要がある。
【0109】
(5)SPSシンタックスpic_width_max_in_luma_samples及びpic_height_max_in_luma_samplesは、8未満にならないよう制約される必要があり得る。
【0110】
(6)参照ピクチャ再サンプリング/スケーラビリティとサブピクチャとの間の相互作用は、現在の設計では考慮されない。
【0111】
(7)時間フィルタリングで、異なるサブピクチャに渡るサンプルが必要であることがある。
【0112】
4.例示的な技術及び実施形態
【0113】
以下の詳細なリストは、一般的な概念を説明するための例として考えられるべきである。これらの項目は、狭義に解釈されるべきではない。更に、これらの項目は任意の方法で結合できる。以後、時間フィルタは、他のピクチャ内のサンプルを必要とするフィルタを表すために使用される。Max(x,y)は、x及びyのうちの大きい方を返す。Min(x,y)は、x及びyのうちの小さい方を返す。
(1)アフィン動き候補(例えば、構成されたアフィンマージ候補)を生成するためにピクチャ内で時間MV予測子がフェッチされる位置(位置RBと命名する)は、必要なサブピクチャの左上角座標が(xTL,yTL)であり、必要なサブピクチャの右下座標が(xBR,yBR)であると仮定すると、必要なサブピクチャ内に存在しなければならない。
(a)一例では、必要なサブピクチャは、現在ブロックをカバーするサブピクチャである。
(b)一例では、座標(x,y)を有する位置RBが必要なサブピクチャの外側にある場合、時間MV予測子は利用できないとして扱われる。
i.一例では、x>xBRの場合、位置RBは必要なサブピクチャの外側にある。
ii.一例では、y>yBRの場合、位置RBは必要なサブピクチャの外側にある。
iii.一例では、x<xTLの場合、位置RBは必要なサブピクチャの外側にある。
iv.一例では、y<yTLの場合、位置RBは必要なサブピクチャの外側にある。
(c)一例では、位置RBが必要なサブピクチャの外側にある場合、BRの置換が利用される。
i.代替として、更に、置換位置は必要なサブピクチャ内に存在するべきである。
(d)一例では、位置RBは、必要なサブピクチャ内になるようクリッピングされる。
i.一例では、xは、x=Min(x,xBR)のようにクリッピングされる。
ii.一例では、yは、y=Min(y,yBR)のようにクリッピングされる。
iii.一例では、xは、x=Max(x,xTL)のようにクリッピングされる。
iv.一例では、yは、y=Max(y,yTL)のようにクリッピングされる。
(e)一例では、位置RBは、同一位置ピクチャ内の現在ブロックの対応するブロックの内側の右下位置であってよい。
(f)提案される方法は、現在ピクチャと異なるピクチャから動き情報にアクセスする必要がある、他のコーディングツールで利用されてよい。
(g)一例では、上述の方法が適用される((例えば、1.a及び/又は1.bに記載されるように行うために)例えば、位置RBが必要なサブピクチャの中に存在しなければならない)かどうかは、VPS/DPS/SPS/PPS/APS/スライスヘッダ/タイルグループヘッダの中でシグナリングされる1つ以上のシンタックスエレメントに依存してよい。例えば、シンタックスエレメントは、subpic_treated_as_pic_flag[SubPicIdx]であってよく、ここで、SubPicIdxは現在ブロックをカバーするサブピクチャのサブピクチャインデックスである。
(2)補間処理で使用されない参照の中で整数サンプルがフェッチされる位置(位置Sと命名する)は、必要なサブピクチャの左上角座標が(xTL,yTL)であり、必要なサブピクチャの右下座標が(xBR,yBR)であると仮定すると、必要なサブピクチャ内に存在しなければならない。
(a)一例では、必要なサブピクチャは、現在ブロックをカバーするサブピクチャである。
(b)一例では、座標(x,y)を有する位置Sが必要なサブピクチャの外側にある場合、参照サンプルは利用できないとして扱われる。
i.一例では、x>xBRの場合、位置Sは必要なサブピクチャの外側にある。
ii.一例では、y>yBRの場合、位置Sは必要なサブピクチャの外側にある。
iii.一例では、x<xTLの場合、位置Sは必要なサブピクチャの外側にある。
iv.一例では、y<yTLの場合、位置Sは必要なサブピクチャの外側にある。
(c)一例では、位置Sは、必要なサブピクチャ内になるようクリッピングされる。
i.一例では、xは、x=Min(x,xBR)のようにクリッピングされる。
ii.一例では、yは、y=Min(y,yBR)のようにクリッピングされる。
iii.一例では、xは、x=Max(x,xTL)のようにクリッピングされる。
iv.一例では、yは、y=Max(y,yTL)のようにクリッピングされる。
(d)一例では、(例えば、2.a及び/又は2.bに記載されるように行うために)位置Sが必要なサブピクチャの中に存在しなければならないかどうかは、VPS/DPS/SPS/PPS/APS/スライスヘッダ/タイルグループヘッダの中でシグナリングされる1つ以上のシンタックスエレメントに依存してよい。例えば、シンタックスエレメントは、subpic_treated_as_pic_flag[SubPicIdx]であってよく、ここで、SubPicIdxは現在ブロックをカバーするサブピクチャのサブピクチャインデックスである。
(e)一例では、フェッチされた整数サンプルは、BDOF及び/又はPORFにおける勾配を生成するために使用される。
(3)再構成ルマサンプル値がフェッチされる位置(位置Rと命名する)は、必要なサブピクチャの左上角座標が(xTL,yTL)であり、必要なサブピクチャの右下座標が(xBR,yBR)であると仮定すると、必要なサブピクチャ内に存在しなければならない。
(a)一例では、必要なサブピクチャは、現在ブロックをカバーするサブピクチャである。
(b)一例では、座標(x,y)を有する位置Rが必要なサブピクチャの外側にある場合、参照サンプルは利用できないとして扱われる。
i.一例では、x>xBRの場合、位置Rは必要なサブピクチャの外側にある。
ii.一例では、y>yBRの場合、位置Rは必要なサブピクチャの外側にある。
iii.一例では、x<xTLの場合、位置Rは必要なサブピクチャの外側にある。
iv.一例では、y<yTLの場合、位置Rは必要なサブピクチャの外側にある。
(c)一例では、位置Rは、必要なサブピクチャ内になるようクリッピングされる。
i.一例では、xは、x=Min(x,xBR)のようにクリッピングされる。
ii.一例では、yは、y=Min(y,yBR)のようにクリッピングされる。
iii.一例では、xは、x=Max(x,xTL)のようにクリッピングされる。
iv.一例では、yは、y=Max(y,yTL)のようにクリッピングされる。
(d)一例では、(例えば、4.a及び/又は4.bに記載されるように行うために)位置Rが必要なサブピクチャの中に存在しなければならないかどうかは、VPS/DPS/SPS/PPS/APS/スライスヘッダ/タイルグループヘッダの中でシグナリングされる1つ以上のシンタックスエレメントに依存してよい。例えば、シンタックスエレメントは、subpic_treated_as_pic_flag[SubPicIdx]であってよく、ここで、SubPicIdxは現在ブロックをカバーするサブピクチャのサブピクチャインデックスである。
(e)一例では、フェッチされたルマサンプルは、LMCSにおけるクロマコンポーネントのスケーリング因子を導出するために使用される。
(4)BT/TT/QT分割、BT/TT/QT深さ導出、及び/又はCU分割フラグのシグナリングのためのピクチャ境界チェックの位置(位置Nと命名する)は、必要なサブピクチャの左上角座標が(xTL,yTL)であり、必要なサブピクチャの右下座標が(xBR,yBR)であると仮定すると、必要なサブピクチャ内に存在しなければならない。
(a)一例では、必要なサブピクチャは、現在ブロックをカバーするサブピクチャである。
(b)一例では、座標(x,y)を有する位置Nが必要なサブピクチャの外側にある場合、参照サンプルは利用できないとして扱われる。
i.一例では、x>xBRの場合、位置Nは必要なサブピクチャの外側にある。
ii.一例では、y>yBRの場合、位置Nは必要なサブピクチャの外側にある。
iii.一例では、x<xTLの場合、位置Nは必要なサブピクチャの外側にある。
iv.一例では、y<yTLの場合、位置Nは必要なサブピクチャの外側にある。
(c)一例では、位置Nは、必要なサブピクチャ内になるようクリッピングされる。
i.一例では、xは、x=Min(x,xBR)のようにクリッピングされる。
ii.一例では、yは、y=Min(y,yBR)のようにクリッピングされる。
iii.一例では、xは、x=Max(x,xTL)のようにクリッピングされる。
(d)一例では、yは、y=Max(y,yTL)のようにクリッピングされる。一例では、(例えば、5.a及び/又は5.bに記載されるように行うために)位置Nが必要なサブピクチャの中に存在しなければならないかどうかは、VPS/DPS/SPS/PPS/APS/スライスヘッダ/タイルグループヘッダの中でシグナリングされる1つ以上のシンタックスエレメントに依存してよい。例えば、シンタックスエレメントは、subpic_treated_as_pic_flag[SubPicIdx]であってよく、ここで、SubPicIdxは現在ブロックをカバーするサブピクチャのサブピクチャインデックスである。
(5)履歴に基づく動きベクトル予測(History-based Motion Vector Prediction (HMVP))テーブルは、1つのピクチャ内の新しいサブピクチャを復号する前に、再設定(リセット)されてよい。
(a)一例では、IBCコーディングのために使用されるHMVPテーブルは、リセットされてよい。
(b)一例では、インターコーディングのために使用されるHMVPテーブルは、リセットされてよい。
(c)一例では、イントラコーディングのために使用されるHMVPテーブルは、リセットされてよい。
(6)サブピクチャシンタックスエレメントは、N(N=8、32、等)個のサンプルの単位で定義されてよい。
(a)一例では、は、サブピクチャ識別子グリッドの各要素の幅はN個のサンプルの単位である。
(b)一例では、サブピクチャ識別子グリッドの各要素の高さは、N個のサンプルの単位である。
(c)一例では、Nは、CTUの幅及び/又は高さに設定される。
(7)ピクチャ幅及びピクチャ高さのシンタックスエレメントは、K(K>=8)未満にならないよう制約されてよい。
(a)一例では、ピクチャ幅は、8未満にならないよう制約される必要があり得る。
(b)一例では、ピクチャ高さは、8未満にならないよう制約される必要があり得る。
(8)適合ビットストリームは、1ビデオユニット(例えば、シーケンス)について有効にされるために、サブピクチャコーディング及び適応解像度変換(Adaptive resolution conversion (ARC))/動的解像度変換(Dynamic resolution conversion (DRC))/参照ピクチャ再サンプリング(Reference picture resampling (RPR))が許可されないことを満たすべきである。
(a)一例では、サブピクチャコーディングを有効にするシグナリングは、ARC/DRC/RPRを許可しないという条件の下にあってよい。
i.一例では、サブピクチャが有効にされるとき、例えばsubpics_present_flagが1に等しいとき、このSPSがアクティブである全部のピクチャのpic_width_in_luma_samplesは、max_width_in_luma_samplesに等しい。
(b)代替として、サブピクチャコーディング及びARC/DRC/RPRは、両方とも、1ビデオユニット(例えば、シーケンス)について有効にされてよい。
i.一例では、適合ビットストリームは、ARC/DRC/RPRによりダウンサンプリングされたサブピクチャが、依然として、幅がK個のCTUであり高さがM個のCTUである形式であることを満たすべきである。ここで、K及びMは両方とも整数である。
ii.一例では、適合ビットストリームは、ピクチャ境界(例えば、右境界及び/又は下境界)に位置しないサブピクチャについて、ARC/DRC/RPRによりダウンサンプリングされたサブピクチャが、依然として、幅がK個のCTUであり高さがM個のCTUである形式であることを満たすべきである。ここで、K及びMは両方とも整数である。
iii.一例では、CTUサイズは、ピクチャ解像度に基づき適応して変更されてよい。
1)一例では、最大CTUサイズはSPS内でシグナリングされてよい。より低い解像度を有する各ピクチャについて、CTUサイズは、低下された解像度に基づき相応して変更されてよい。
2)一例では、CTUサイズは、SPS及びPPS内、及び/又はサブピクチャレベルでシグナリングされてよい。
(9)シンタックスエレメントsubpic_grid_col_width_minus1及びsubpic_grid_row_height_minus1は、制約されてよい。
(a)一例では、subpic_grid_col_width_minus1はT1より大きくてはならない(又は小さくてはならない)。
(b)一例では、subpic_grid_row_height_minus1はT2より大きくてはならない(又は小さくてはならない)。
(c)一例では、適合ビットストリームでは、subpic_grid_col_width_minus1及び/又はsubpic_grid_row_height_minus1は、項目3.a及び3.bのような制約に従わなければならない。
(d)一例では、3.aにおけるT1、及び/又は3.bにおけるT2は、ビデオコーディング標準のプロファイル/レベル/ティアに依存してよい。
(e)一例では、3.aにおけるT1は、ピクチャ幅に依存してよい。
i.例えば、T1はpic_width_max_in_luma_samples/4又はpic_width_max_in_luma_samples/4+Offに等しい。Offは、1、2、-1、-2等であってよい。
(f)一例では、3.bにおけるT2は、ピクチャ幅に依存してよい。
i.例えば、T2はpic_height_max_in_luma_samples/4又はpic_height_max_in_luma_samples/4-1+Offに等しい。Offは、1、2、-1、-2等であってよい。
(10)任意の2つのサブピクチャの間の境界が、2つのCTUの間の境界でなければならないという制約がある。
(a)言い換えると、CTUは、1つより多くのサブピクチャによりカバーできない。
(b)一例では、subpic_grid_col_width_minus1の単位は、VVCにおけるような4の代わりに、CTU幅(例えば、32、64、128)であってよい。サブピクチャグリッド幅は、(subpic_grid_col_width_minus1+1)*CTU幅であるべきである。
(c)一例では、subpic_grid_col_height_minus1の単位は、VVCにおけるような4の代わりに、CTU高さ(例えば、32、64、128)であってよい。サブピクチャグリッド高さは、(subpic_grid_col_height_minus1+1)*CTU高さであるべきである。
(d)一例では、適合ビットストリームでは、サブピクチャアプローチが適用される場合、制約が満たされなければならない。
(11)サブピクチャの形状が長方形でなければならないという制約がある。
(a)一例では、適合ビットストリームでは、サブピクチャアプローチが適用される場合、制約が満たされなければならない。
(b)サブピクチャは、長方形スライスのみを含んでよい。例えば、適合ビットストリームでは、サブピクチャアプローチが適用される場合、制約が満たされなければならない。
(12)2つのサブピクチャは重なり合うことができないという制約がある。
(a)一例では、適合ビットストリームでは、サブピクチャアプローチが適用される場合、制約が満たされなければならない。
(b)代替として、2つのサブピクチャは、互いに重なり合ってよい。
(13)ピクチャ内の任意の位置が1つの及び1つのみのサブピクチャによりカバーされなければならないという制約がある。
(a)一例では、適合ビットストリームでは、サブピクチャアプローチが適用される場合、制約が満たされなければならない。
(b)代替として、1つのサンプルは、任意のサブピクチャに属さなくてよい。
(c)代替として、1つのサンプルは、1つより多くのサブピクチャに属してよい。
(14)同じシーケンス内で提示される全ての解像度にマッピングされるSPS内で定義されるサブピクチャは、上述の制約された位置及び/又はサイズに従うべきであるという制約があってよい。
(a)一例では、同じシーケンス内で提示される解像度にマッピングされるSPS内で定義されたサブピクチャの幅及び高さは、N(例えば、8、16、32)個のルマサンプルの整数倍であるべきである。
(b)一例では、サブピクチャは、特定のレイヤについて定義されてよく、他のレイヤにマッピングされてよい。
i.例えば、サブピクチャは、シーケンス内の最高解像度を有するレイヤについて定義されてよい。
ii.例えば、サブピクチャは、シーケンス内の最低解像度を有するレイヤについて定義されてよい。
iii.どのレイヤについてサブピクチャが定義されるかは、SPS/VPS/PPS/スライスヘッダ内でシグナリングされてよい。
(c)一例では、サブピクチャ及び異なる解像度の両方が適用されるとき、全ての解像度(例えば幅及び/又は高さ)は、所与の解像度の整数倍であってよい。
(d)一例では、SPS内で定義されたサブピクチャの幅及び/又は高さは、CTUサイズの整数倍(例えば、M)であってよい。
(e)代替として、シーケンス内のサブピクチャ及び異なる解像度は、同時に許可されなくてよい。
(15)サブピクチャは、特定のレイヤにのみ適用されてよい。
(a)一例では、SPS内で定義されたサブピクチャは、シーケンス内の最高解像度を有するレイヤにのみ適用されてよい。
(b)一例では、SPS内で定義されたサブピクチャは、シーケンス内の最低解像度を有するレイヤにのみ適用されてよい。
(c)どのレイヤにサブピクチャが適用され得るかは、SPS/VPS/PPS内の1又は複数のシンタックスエレメントにより示されてよい。
(d)どのレイヤにサブピクチャが適用できないかは、SPS/VPS/PPS内の1又は複数のシンタックスエレメントにより示されてよい。
(16)一例では、サブピクチャの位置及び/又は寸法は、subpic_grid_idxを使用せずに、シグナリングされてよい。
(a)一例では、サブピクチャの左上位置がシグナリングされてよい。
(b)一例では、サブピクチャの右下位置がシグナリングされてよい。
(c)一例では、サブピクチャの幅がシグナリングされてよい。
(d)一例では、サブピクチャの高さがシグナリングされてよい。
(17)時間フィルタでは、サンプルの時間フィルタリングを実行するとき、現在サンプルが属する同じサブピクチャの範囲内のサンプルのみが、使用されてよい。必要なサンプルは、現在サンプルが属する同じピクチャ内に、又は他のピクチャ内に存在してよい。
(18)一例では、パーティション方法(例えば、QT、水平BT、垂直BT、水平TT、垂直TT、又は分割無し、等)を適用するかどうか及び/又はどのように適用するかは、現在ブロック(又はパーティション)がサブピクチャの1又は複数の境界を横切るかどうかに依存してよい。
(a)一例では、VVCにおけるパーティションのためのピクチャ境界処理方法は、ピクチャ境界がサブピクチャ境界により置換されるときにも適用されてよい。
(b)一例では、パーティション方法(例えば、QT、水平BT、垂直BT、水平TT、垂直TT、又は分割無し、等)を表すシンタックスエレメント(例えば、フラグ)をパースするかどうか及び/又はどのように適用するかは、現在ブロック(又はパーティション)がサブピクチャの1又は複数の境界を横切るかどうかに依存してよい。
(19)1つのピクチャを複数のサブピクチャに分割して各サブピクチャを独立してコーディングする代わりに、ピクチャを少なくとも2つのサブ領域セットに分割して、複数のサブピクチャを含む第1セットと、全部の残りのサンプルを含む第2セットとにすることが提案される。
(a)一例では、第2セット内のサンプルは、任意のサブピクチャ内に存在しない。
(b)代替として、更に、第2セットは、第1セットの情報に基づき符号化/復号されてよい。
(c)一例では、デフォルト値は、サンプル/M×Kサブ領域が第2セットに属するかどうかをマークするために利用されてよい。
(i)一例では、デフォルト値は、(max_subpics_minus1+K)に等しく設定されてよい。ここで、Kは1より大きい整数である。
(ii)デフォルト値は、グリッドが第2セットに属することを示すために、subpic_grid_idx[i][j]に割り当てられてよい。
(20)シンタックスエレメントsubpic_grid_idx[i][j]は、max_subpics_minus1より大きくならないことが提案される。
(a)例えば、適合ビットストリームでは、subpic_grid_idx[i][j]はmax_subpics_minus1より大きくなることができないという制約がある。
(b)例えば、subpic_grid_idx[i][j]をコーディングするためのコードワードは、max_subpics_minus1より大きくなることができない。
(21)0からmax_subpics_minus1までの任意の整数は、少なくとも1つのsubpic_grid_idx[i][j]に等しくなければならないことが提案される。
(22)IBC仮想バッファは、1つのピクチャ内の新しいサブピクチャを復号する前に、リセットされてよい。
(a)一例では、IBC仮想バッファ内の全部のサンプルは、-1にリセットされてよい。
(23)パレットエントリリストは、1つのピクチャ内の新しいサブピクチャを復号する前に、リセットされてよい。
(a)一例では、PredictorPaletteSizeは、1つのピクチャ内の新しいサブピクチャを復号する前に、0に等しくなるよう設定されてよい。
【0114】
5.実施形態
【0115】
以下の実施形態では、新たに追加されたテキストは太字の斜体であり、削除されたテキストは「[[]]」によりマークされる。
【0116】
5.1 実施形態1:アフィン構成マージ候補に対するサブピクチャ制約
8.5.5.6 構成されたアフィン制御点動きベクトルマージ候補のための導出処理
この処理への入力は:
-現在ピクチャの左上ルマサンプルに対する、現在ルマコーディングブロックの左上サンプルを指定するルマ位置(xCb,yCb)、
-現在ルマコーディングブロックの幅及び高さを指定する2つの変数cbWidth及びcbHeight、
-利用可能性フラグavailableA
0,availableA
1,availableA
2,availableB
0,availableB
1,availableB
2,availableB
3、
-サンプル位置(xNbA
0,yNbA
0),(xNbA
1,yNbA
1),(xNbA
2,yNbA
2),(xNbB
0,yNbB
0),(xNbB
1,yNbB
1),(xNbB
2,yNbB
2)及び(xNbB
3,yNbB
3)。
この処理の出力は:
構成されたアフィン制御点動きベクトルマージ候補の利用可能性フラグavailableFlagConstK、K=1...6、
-参照インデックスrefIdxLXConstK,、K=1..6、Xは0又は1、
-予測リスト利用フラグpredFlagLXConstK、K=1..6,Xは0又は1、
-アフィン動き
モデルインデックスmotionModelIdcConstK、K=1..6、
-双予測重みインデックスbcwIdxConstK、K=1..6、
-構成されたアフィン制御点動きベクトル、cpIdx=0..2、K=1..6、Xは0又は1。
…
第4(同一位置右下)制御点動きベクトルcpMvLXCorner[3]、参照インデックスrefIdxLXCorner[3]、予測リスト利用フラグpredFlagLXCorner[3]、及び利用可能性フラグavailableFlagCorner[3]、ここでXは0又は1、は、以下のように導出される:
-時間マージ候補の参照インデックスrefIdxLXCorner[3]、ここでXは0又は1、は0に等しく設定される。
-変数mvLXCol及びavailableFlagLXCol、ここでXは0又は1、は以下のように導出される:
・slice_temporal_mvp_enabled_flagが0に等しい場合、mvLXColの両方のコンポーネントは0に等しく設定され、availableFlagLXColは0に等しく設定される。
・その他の場合(slice_temporal_mvp_enabled_flagが1に等しい)、以下が適用される:
【数32】
【数33】
・変数colCbは、ColPicにより指定される同一位置ピクチャの内側の、((xColBr>>3)<<3,(yColBr>>3)<<3)により与えられる変更位置をカバーするルマコーディングブロックを指定する。
・ルマ位置(xColCb,yColCb)は、ColPicにより指定される同一位置ピクチャの左上ルマサンプルに対する、colCbにより指定される同一位置ルマコーディングブロックの左上サンプルに等しく設定される。
・8.5.2.12項に指定される同一位置動きベクトルの導出処理は、currCb、colCb、(xColCb,yColCb)、refIdxLXCorner[3]、及び0に等しく設定されたsbFlagを入力として呼び出され、出力はmvLXCol及びavailableFlagLXColに割り当てられる。
-その他の場合、mvLXColの両方のコンポーネントは0に等しく設定され、availableFlagLXColは0に等しく設定される。
…
【0117】
5.2 実施形態2:アフィン構成マージ候補に対するサブピクチャ制約
8.5.5.6 構成されたアフィン制御点動きベクトルマージ候補のための導出処理
この処理への入力は:
-現在ピクチャの左上ルマサンプルに対する、現在ルマコーディングブロックの左上サンプルを指定するルマ位置(xCb,yCb)、
-現在ルマコーディングブロックの幅及び高さを指定する2つの変数cbWidth及びcbHeight、
-利用可能性フラグavailableA
0,availableA
1,availableA
2,availableB
0,availableB
1,availableB
2,availableB
3、
-サンプル位置(xNbA
0,yNbA
0),(xNbA
1,yNbA
1),(xNbA
2,yNbA
2),(xNbB
0,yNbB
0),(xNbB
1,yNbB
1),(xNbB
2,yNbB
2)及び(xNbB
3,yNbB
3)。
この処理の出力は:
構成されたアフィン制御点動きベクトルマージ候補の利用可能性フラグavailableFlagConstK、K=1...6、
-参照インデックスrefIdxLXConstK,、K=1..6、Xは0又は1、
-予測リスト利用フラグpredFlagLXConstK、K=1..6,Xは0又は1、
-アフィン動き
モデルインデックスmotionModelIdcConstK、K=1..6、
-双予測重みインデックスbcwIdxConstK、K=1..6、
-構成されたアフィン制御点動きベクトル、cpIdx=0..2、K=1..6、Xは0又は1。
…
第4(同一位置右下)制御点動きベクトルcpMvLXCorner[3]、参照インデックスrefIdxLXCorner[3]、予測リスト利用フラグpredFlagLXCorner[3]、及び利用可能性フラグavailableFlagCorner[3]、ここでXは0又は1、は、以下のように導出される:
-時間マージ候補の参照インデックスrefIdxLXCorner[3]、ここでXは0又は1、は0に等しく設定される。
-変数mvLXCol及びavailableFlagLXCol、ここでXは0又は1、は以下のように導出される:
・slice_temporal_mvp_enabled_flagが0に等しい場合、mvLXColの両方のコンポーネントは0に等しく設定され、availableFlagLXColは0に等しく設定される。
・その他の場合(slice_temporal_mvp_enabled_flagが1に等しい)、以下が適用される:
【数34】
・yCb>>CtbLog2SizeYがyColBr>>CtbLog2SizeYと等しい場合、[[yColBrpic_height_in_luma_samples以下であり、xColBrpic_width_in_luma_samples以下であり、以下が適用される]]:
-変数colCbは、ColPicにより指定される同一位置ピクチャの内側の、((xColBr>>3)<<3,(yColBr>>3)<<3)により与えられる変更位置をカバーするルマコーディングブロックを指定する。
-ルマ位置(xColCb,yColCb)は、ColPicにより指定される同一位置ピクチャの左上ルマサンプルに対する、colCbにより指定される同一位置ルマコーディングブロックの左上サンプルに等しく設定される。
-8.5.2.12項に指定される同一位置動きベクトルの導出処理は、currCb、colCb、(xColCb,yColCb)、refIdxLXCorner[3]、及び0に等しく設定されたsbFlagを入力として呼び出され、出力はmvLXCol及びavailableFlagLXColに割り当てられる。
・その他の場合、mvLXColの両方のコンポーネントは0に等しく設定され、availableFlagLXColは0に等しく設定される。
…
【0118】
5.3 実施形態3:サブピクチャ制約の下で整数サンプルをフェッチする
8.5.6.3.3 ルマ整数サンプルフェッチ処理
この処理への入力は:
-フルサンプルユニットのルマ位置(xInt
L,yInt
L)、
-ルマ参照サンプルアレイrefPicLX
L、
この処理の出力は、予測ルマサンプル値predSampleLX
Lである。
変数shiftは、Max(2,14-BitDepth
Y)に等しく設定される。
変数picWは、pic_width_in_luma_samplesに等しく設定され、変数picHはpic_height_in_luma_samplesに等しく設定される。
フルサンプルユニットのルマ位置(xInti,yInti)は、以下のように導出される:
【数35】
予測されたルマサンプル値はpredSampleLX
Lは以下のように導出される:
【数36】
【0119】
5.4 実施形態4:LMCSのクロマ残差スケーリングにおける変数invAvgLumaの導出
8.7.5.3 クロマサンプルのルマ依存クロマ残差スケーリング処理によるピクチャ再構成
この処理への入力は:
-現在ピクチャの左上クロマサンプルに対する、現在クロマ変換ブロックの左上クロマサンプルのクロマ位置(xCurr,yCurr)、
-クロマ変換ブロック幅を指定する変数nCurrSw、
-クロマ変換ブロック高さを指定する変数nCurrSh、
-現在クロマ変換ブロックのコーディングブロックフラグを指定する変数tuCbfChroma、
-現在ブロックのクロマ予測サンプルを指定する(nCurrSw)x(nCurrSh)アレイpredSamples、
-現在ブロックのクロマ残差サンプルを指定する(nCurrSw)x(nCurrSh)アレイresSamples。
この処理の出力は、再構成クロマピクチャサンプルアレイrecSamplesである。
変数sizeYは、Min(CtbSizeY,64)に等しく設定される。
再構成クロマピクチャサンプルrecSamplesは、i=0..nCurrSw-1,j=0..nCurrSh-1について以下のように導出される:
…
その他の場合、以下が適用される。
…
変数currPicは、現在ピクチャ内の再構成ルマサンプルのアレイを指定する。
変数varScaleの導出のために、以下の順序付きステップが適用される:
【数37】
【0120】
5.5 実施形態5:4個のサンプル以外のN(例えばN=8又は32)個の単位でサブピクチャエレメントを定義する例
7.4.3.3 シーケンスパラメータセットRBSPセマンティクス
【数38】
7.4.7.1 汎用スライスヘッダセマンティクス
変数SubPicIdx、SubPicLeftBoundaryPos、SubPicTopBoundaryPos、SubPicRightBoundaryPos、及びSubPicBotBoundaryPosは、以下のように導出される:
【数39】
【0121】
5.6 実施形態6:ピクチャ幅及びピクチャ高さが8以上になるよう制約する
7.4.3.3 シーケンスパラメータセットRBSPセマンティクス
【数40】
【0122】
5.7 実施形態7:BT/TT/QT分割、BT/TT/QT深さ導出、及び/又はCU分割フラグのシグナリングのためのサブピクチャ境界チェック
6.4.2 許可されるバイナリ分割処理
変数allowBtSplitは、以下のように導出される:
【数41】
6.4.2 許可される3分割処理
変数allowTtSplitは、以下のように導出される:
【数42】
7.3.8.2 コーディングツリーユニットシンタックス
【表3】
7.3.8.4 コーディングツリーシンタックス
【表4】
【0123】
図3は、ビデオ処理機器300のブロック図である。機器300は、ここに記載した方法のうちの1つ以上を実施するために使用されてよい。機器300は、スマートフォン、タブレット、コンピュータ、モノのインターネット(Internet of Things (IoT))受信機、等において実施されてよい。機器300は、1つ以上のプロセッサ302、1つ以上のメモリ304、及びビデオ処理ハードウェア306を含んでよい。プロセッサ302は、本願明細書に記載した1つ以上の方法を実施するよう構成されてよい。メモリ(複数のメモリ)304は、本願明細書に記載の方法及び技術を実施するために使用されるデータ及びコードを格納するために使用されてよい。ビデオ処理ハードウェア306は、ハードウェア回路で、本願明細書に記載した幾つかの技術を実施するために使用されてよい。
【0124】
図4は、ビデオを処理する方法400のフローチャートである。方法1800は、ビデオの第1ビデオ領域内のビデオブロックについて、アフィンモードを用いてビデオブロックと現在ビデオブロックのビットストリーム表現との間の変換のために時間動きベクトル予測子が決定される位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップ(402)と、決定に基づき変換を実行するステップ(404)と、を含む。
【0125】
以下のソリューションは、幾つかの実施形態において好適なソリューションとして実装されてよい。
【0126】
以下のソリューションは、前の章(例えば、項目1)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0127】
(ソリューション1)ビデオ処理の方法であって、ビデオの第1ビデオ領域内のビデオブロックについて、アフィンモードを用いて前記ビデオブロックと現在ビデオブロックのビットストリーム表現との間の変換のために時間動きベクトル予測子が決定される位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップと、前記決定に基づき前記変換を実行するステップと、を含む方法。
【0128】
(ソリューション2)前記ビデオブロックは、前記第1領域及び前記第2領域によりカバーされる、ソリューション1に記載の方法。
【0129】
(ソリューション3)前記時間動きベクトル予測子の位置が前記第2ビデオ領域の外側にある場合、前記時間動きベクトル予測子は利用できないとマークされ、前記変換において使用されない、ソリューション1~2のいずれかに記載の方法。
【0130】
以下のソリューションは、前の章(例えば、項目2)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0131】
(ソリューション4)ビデオ処理の方法であって、ビデオの第1ビデオ領域内のビデオブロックについて、前記ビデオブロックと現在ビデオブロックのビットストリーム表現との間の変換のために参照ピクチャ内の整数サンプルがフェッチされる位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップであって、前記参照ピクチャは前記変換中に補間処理において使用されない、ステップと、前記決定に基づき前記変換を実行するステップと、を含む方法。
【0132】
(ソリューション5)前記ビデオブロックは、前記第4領域及び前記第2領域によりカバーされる、ソリューション1に記載の方法。
【0133】
(ソリューション6)前記サンプルの位置が前記第2ビデオ領域の外側にある場合、前記サンプルは利用できないとマークされ、前記変換において使用されない、ソリューション4~5のいずれかに記載の方法。
【0134】
以下のソリューションは、前の章(例えば、項目3)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0135】
(ソリューション7)ビデオ処理の方法であって、ビデオの第1ビデオ領域内のビデオブロックについて、前記ビデオブロックと現在ビデオブロックのビットストリーム表現との間の変換のために再構成ルマサンプル値がフェッチされる位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップと、前記決定に基づき前記変換を実行するステップと、を含む方法。
【0136】
(ソリューション8)前記ルマサンプルは、前記第1領域及び前記第2領域によりカバーされる、ソリューション7に記載の方法。
【0137】
(ソリューション9)前記ルマサンプルの位置が前記第2ビデオ領域の外側にある場合、前記ルマサンプルは利用できないとマークされ、前記変換において使用されない、ソリューション7~8のいずれかに記載の方法。
【0138】
以下のソリューションは、前の章(例えば、項目4)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0139】
(ソリューション10)ビデオ処理の方法であって、ビデオの第1ビデオ領域内のビデオブロックについて、前記ビデオブロックと前記現在ビデオブロックのビットストリーム表現との間の変換中に、前記ビデオブロックについて分割に関するチェック、深さ導出、又は分割フラグシグナリングが実行される位置が、第2ビデオ領域の範囲内であるかどうかを決定するステップと、前記決定に基づき前記変換を実行するステップと、を含む方法。
【0140】
(ソリューション11)前記位置は、前記第1領域及び前記第2領域によりカバーされる、ソリューション10に記載の方法。
【0141】
(ソリューション12)前記位置が前記第2ビデオ領域の外側にある場合、前記ルマサンプルは利用できないとマークされ、前記変換において使用されない、ソリューション10~11のいずれかに記載の方法。
【0142】
以下のソリューションは、前の章(例えば、項目8)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0143】
(ソリューション13)ビデオ処理の方法であって、1つ以上のビデオブロックを含む1つ以上のビデオピクチャを含むビデオと、前記ビデオのコーディング表現との間の変換を実行するステップを含み、前記コーディング表現は、前記変換がサブピクチャコーディング/復号、及び動的解像度変換コーディング/復号ツール又は参照ピクチャ再サンプリングツールをビデオユニット内で使用しないというコーディングシンタックス要件に従う、方法。
【0144】
(ソリューション14)前記ビデオユニットは、前記1つ以上のビデオピクチャのシーケンスに対応する、ソリューション13に記載の方法。
【0145】
(ソリューション15)前記動的解像度変換コーディング/復号ツールは、適応解像度変換コーディング/復号ツールを含む、ソリューション13~14のいずれかに記載の方法。
【0146】
(ソリューション16)前記動的解像度変換コーディング/復号ツールは、動的解像度変換コーディング/復号ツールを含む、ソリューション13~14のいずれかに記載の方法。
【0147】
(ソリューション17)前記コーディング表現は、前記ビデオユニットが前記コーディングシンタックス要件に従うことを示す、ソリューション13~16のいずれかに記載の方法。
【0148】
(ソリューション18)前記コーディング表現は、前記ビデオユニットが前記サブピクチャを使用することを示す、ソリューション17に記載の方法。
【0149】
(ソリューション19)前記コーディング表現は、前記ビデオユニットが前記動的解像度変換コーディング/復号ツール又は前記参照ピクチャ再サンプリングツールを使用することを示す、ソリューション17に記載の方法。
【0150】
以下のソリューションは、前の章(例えば、項目10)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0151】
(ソリューション20)前記第2ビデオ領域はビデオサブピクチャを含み、前記第2ビデオ領域と別のビデオ領域との境界は、2つのコーディングツリーユニットの間の境界も含む、ソリューション1~19のいずれかに記載の方法。
【0152】
(ソリューション21)前記第2ビデオ領域はビデオサブピクチャを含み、前記第2ビデオ領域と別のビデオ領域との境界は、2つのコーディングツリーユニットの間の境界も含む、ソリューション1~19のいずれかに記載の方法。
【0153】
以下のソリューションは、前の章(例えば、項目11)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0154】
(ソリューション22)前記第1ビデオ領域及び前記第2ビデオ領域は長方形形状を有する、ソリューション1~21のいずれかに記載の方法。
【0155】
以下のソリューションは、前の章(例えば、項目12)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0156】
(ソリューション23)前記第1ビデオ領域及び前記第2ビデオ領域は重なり合わない、ソリューション1~22のいずれかに記載の方法。
【0157】
以下のソリューションは、前の章(例えば、項目13)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0158】
(ソリューション24)前記ビデオピクチャは、前記ビデオピクチャ内のピクセルが1つの且つ1つのみのビデオ領域によりカバーされるように、ビデオ領域に分割される、ソリューション1~23のいずれかに記載の方法。
【0159】
以下のソリューションは、前の章(例えば、項目15)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0160】
(ソリューション25)前記ビデオピクチャが前記ビデオシーケンスの特定レイヤ内にあることに起因して、前記ビデオピクチャは、前記第1ビデオ領域及び前記第2ビデオ領域に分割される、ソリューション1~24のいずれかに記載の方法。
【0161】
以下のソリューションは、前の章(例えば、項目10)にリストされた項目で説明した追加技術と一緒に実装されてよい。
【0162】
(ソリューション26)ビデオ処理の方法であって、1つ以上のビデオブロックを含む1つ以上のビデオピクチャを含むビデオと、前記ビデオのコーディング表現との間の変換を実行するステップを含み、前記コーディング表現は、第1シンタックスエレメントsubpic_grid_idx[i][j]が第2シンタックスエレメントmax_subpics_minus1より大きくないというコーディングシンタックス要件に従う、方法。
【0163】
(ソリューション27)前記第1シンタックスエレメントを表すコードワードは、前記第2シンタックスエレメントを表すコードワードより大きくない、ソリューション26に記載の方法。
【0164】
(ソリューション28)前記第1ビデオ領域はビデオサブピクチャを含む、ソリューション1~27のいずれかに記載の方法。
【0165】
(ソリューション29)前記第2ビデオ領域はビデオサブピクチャを含む、ソリューション1~28のいずれかに記載の方法。
【0166】
(ソリューション30)前記変換は、前記ビデオを前記コーディング表現に符号化することを含む、ソリューション1~29のいずれかに記載の方法。
【0167】
(ソリューション31)前記変換は、前記コーディング表現を復号して前記ビデオのピクセル値を生成することを含む、ソリューション1~29のいずれかに記載の方法。
【0168】
(ソリューション32)ビデオ復号機器であって、ソリューション1~31のうちの1つ以上に記載の方法を実施するよう構成されるプロセッサを含むビデオ復号機器。
【0169】
(ソリューション33)ビデオ符号化機器であって、ソリューション1~31のうちの1つ以上に記載の方法を実施するよう構成されるプロセッサを含むビデオ符号化機器。
【0170】
(ソリューション34)格納されたコンピュータコードを有するコンピュータプログラムプロダクトであって、前記コードは、プロセッサにより実行されると、前記プロセッサにソリューション1~31のいずれかに記載の方法を実施させる、コンピュータプログラムプロダクト。
【0171】
(ソリューション35)本願明細書に記載された方法、機器、又はシステム。
【0172】
図5は、ここに開示される種々の技術が実施され得る例示的なビデオ処理システム500を示すブロック図である。種々の実装は、システム500のコンポーネントの一部又は全部を含んでよい。システム500は、ビデオコンテンツを受信する入力502を含んでよい。ビデオコンテンツは、生(raw)又は非圧縮フォーマット、例えば8又は10ビット複数成分ピクセル値で受信されてよく、或いは圧縮又は符号化フォーマットであってよい。入力502は、ネットワークインタフェース、周辺機器バスインタフェース、又はストレージインタフェースを表してよい。ネットワークインタフェースの例は、イーサネット(登録商標)、受動光ネットワーク(passive optical network (PON))等のような有線インタフェース、及びWi-Fi又はセルラインタフェースのような無線インタフェースを含む。
【0173】
システム500は、本願明細書に記載された種々のコーディング又は符号化方法を実施し得るコーディングコンポーネント504を含んでよい。コーディングコンポーネント504は、入力502からコーディングコンポーネント504の出力へのビデオの平均ビットレートを低減して、ビデオのコーディング表現を生成してよい。コーディング技術は、従って、時に、ビデオ圧縮又はビデオトランスコーディング技術と呼ばれる。コーディングコンポーネント504の出力は、コンポーネント506により表されるように、格納されるか、又は通信接続を介して送信されてよい。入力502で受信された、格納され又は通信されたビットストリーム(又はコーディングされた)表現は、コンポーネント508により、ディスプレイインタフェース510へ送信されるピクセル値又は表示可能なビデオを生成するために、使用されてよい。ビットストリーム表現からユーザに閲覧可能なビデオを生成する処理は、時に、ビデオ伸長と呼ばれる。更に、特定のビデオ処理動作は「コーディング」動作又はツールと呼ばれるが、コーディングツール又は動作は、エンコーダにおいて使用され、コーディングの結果を逆にする対応する復号ツール又は動作がデコーダにより実行されることが理解される。
【0174】
周辺機器バスインタフェース又はディスプレイインタフェースの例は、ユニバーサルシリアルバス(universal serial bus (USB))又は高解像度マルチメディアインタフェース(high definition multimedia interface (HDMI(登録商標)))又はディスプレイポート(Displayport)、等を含んでよい。ストレージインタフェースの例は、SATA(serial advanced technology attachment)、PCI、IDEインタフェース、等を含む。本願明細書に記載した技術は、移動電話機、ラップトップ、スマートフォン、又はデジタルデータ処理を実行可能な他の装置、及び/又はビデオディスプレイのような種々の電子装置に実装されてよい。
【0175】
図6は、本発明の技術によるビデオ処理の方法600のフローチャート表現である。方法600は、動作610において、ビデオの第1ピクチャの現在ブロックとビデオのビットストリーム表現との間の変換のために、ルールに従い、第2ピクチャからの動き情報に基づき、動き候補を決定するステップを含む。ルールは、動き情報がアクセスされる位置が、第2ピクチャの特定のサブピクチャの範囲内であるよう制約されることを指定する。方法600は、動作620で、決定に基づき変換を実行するステップを更に含む。
【0176】
幾つかの実施形態では、動き情報は動きベクトルを含み、動き候補はアフィン動き候補を含む。幾つかの実施形態では、ルールは、第1位置が特定サブピクチャの外側にある場合に、第1位置の代わりとして、位置が使用されることを指定する。幾つかの実施形態では、位置は、現在ブロックに対応するビデオピクチャ内のブロックの右下角にある。
【0177】
図7は、本発明の技術によるビデオ処理の方法700のフローチャート表現である。方法700は、動作710で、ビデオの第1ピクチャの現在ブロックと前記ビデオのビットストリーム表現の変換のために、ルールに従い、第2ピクチャからの整数サンプルを決定するステップを含む。第2ピクチャは、補間処理において使用されない参照ピクチャを含む。ルールは、整数サンプルがアクセスされる位置が、第2ピクチャの特定のサブピクチャの範囲内であるよう制約されることを指定する。方法700は、動作720で、決定に基づき
変換を実行するステップを更に含む。幾つかの実施形態では、整数サンプルは、双方向オプティカルフロー又は予測精緻化オプティカルフロー処理における1つ以上の勾配を生成するために使用される。
【0178】
図8は、本発明の技術によるビデオ処理の方法800のフローチャート表現である。方法800は、動作810において、ビデオの現在ブロックと前記ビデオのビットストリーム表現の変換のために、ルールに従い、再構成ルマサンプルがアクセスされる位置を決定するステップを含む。ルールは、位置が、ビデオピクチャの特定のサブピクチャの範囲内であるよう制約されることを指定する。方法800は、動作820で、決定に基づき変換を実行するステップを更に含む。幾つかの実施形態では、再構成ルマサンプルは、ルママッピングクロマスケーリング処理においてクロマコンポーネントのスケーリング因子を導出するためにアクセスされる。
【0179】
図9は、本発明の技術によるビデオ処理の方法900のフローチャート表現である。方法900は、動作910において、ビデオの現在ブロックとビデオのビットストリーム表現の変換のために、ルールに従い、ピクチャ境界チェックが実行される位置を決定するステップを含む。ルールは、位置が、ビデオピクチャの特定のサブピクチャの範囲内であるよう制約されることを指定する。方法900は、動作920で、決定に基づき変換を実行するステップを更に含む。
【0180】
幾つかの実施形態では、ピクチャ境界チェックは、以下:(1)2分木、3分木、又は4分木の分割、(2)2分木、3分木、又は4分木の深さ導出、或いは(3)現在ブロックの分割フラグのシグナリング、のうちの少なくとも1つのために実行される。幾つかの実施形態では、特定サブピクチャは、現在ブロックをカバーする同一位置サブピクチャである。
【0181】
幾つかの実施形態では、ルールは、位置が特定サブピクチャの外側にある場合に、位置における情報が利用可能ではないとして扱われることを指定する。位置は(x,y)として表され、特定サブピクチャの左上角は(xTL,yTL)として表され、特定サブピクチャの右下角は(xBR,yBR)として表される。幾つかの実施形態では、x>xBR、y>yBR、x<xTL、又はy<yTLの場合、位置は、特定サブピクチャの外側にある。幾つかの実施形態では、位置は、ビデオピクチャの特定サブピクチャの範囲内になるようクリッピングされることを指定する。位置は(x,y)として表され、特定サブピクチャの左上角は(xTL,yTL)として表され、特定サブピクチャの右下角は(xBR,yBR)として表される。幾つかの実施形態では、xは、x及びxRのうちの小さい方の値になるようクリッピングされる。幾つかの実施形態では、yは、y及びyRのうちの小さい方の値になるようクリッピングされる。幾つかの実施形態では、xは、x及びxTLうちの大きい方の値になるようクリッピングされる。幾つかの実施形態では、y、yびyTLのうちの大きい方の値になるようクリッピングされる。
【0182】
幾つかの実施形態では、ルールが適用可能かどうかは、ビットストリーム表現の中のシンタックスエレメントに基づく。幾つかの実施形態では、シンタックスエレメントは、ビデオパラメータセット、依存性パラメータセット、スライスパラメータセット、ピクチャパラメータセット、アクティブパラメータセット、スライスヘッダ、又はタイルグループヘッダの中でシグナリングされる。幾つかの実施形態では、シンタックスエレメントは、subpic_treated_as_pic_flag[SubPicIdx]を含み、SubPicIdxは、現在ブロックをカバーする特定サブピクチャのサブピクチャインデックスである。
【0183】
幾つかの実施形態では、変換は、ビットストリーム表現から現在ブロックを生成する。幾つかの実施形態では、変換は、現在ブロックからビットストリーム表現を生成する。
【0184】
図10は、本発明の技術によるビデオ処理の方法1000のフローチャート表現である。方法1000は、動作1010で、ビデオのビデオピクチャのサブピクチャとビデオのビットストリーム表現の変換の後に、過去の変換に基づき導出された動き候補のテーブルを再設定(リセット)するステップを含む。方法1000は、動作1020で、リセット後のテーブルを用いて、ビデオピクチャの後続のサブピクチャとビットストリーム表現の変換を実行するステップを更に含む。
【0185】
幾つかの実施形態では、動き候補のテーブルは、イントラブロックコーディングモードのための動き候補を含む。幾つかの実施形態では、動き候補のテーブルは、インターコーディングモードのための動き候補を含む。幾つかの実施形態では、動き候補のテーブルは、イントラコーディングモードのための動き候補を含む。
【0186】
幾つかの実施形態では、変換は、ビットストリーム表現からサブピクチャ及び後続のサブピクチャを生成する。幾つかの実施形態では、変換は、サブピクチャ及び後続のサブピクチャからビットストリーム表現を生成する。
【0187】
図11は、本発明の技術によるビデオ処理の方法1100のフローチャート表現である。方法1100は、動作1110で、ルールに従い、複数のサブピクチャ及び複数のビデオブロックを含むビデオピクチャを有するビデオと、前記ビデオのコーディング表現との間の変換を実行するステップを含む。ルールは、任意の2つのサブピクチャが、2つのビデオブロックの間の境界でもあることを指定する。ビデオピクチャ内のビデオブロックは、ビデオピクチャの単一のサブピクチャによりカバーされる。
【0188】
幾つかの実施形態では、ビデオピクチャ内の任意の位置は、ビデオピクチャの最大でも1つのサブピクチャによりカバーされる。幾つかの実施形態では、ビデオピクチャ内の位置は、ビデオピクチャのサブピクチャによりカバーされない。幾つかの実施形態では、ビデオピクチャの2つのサブピクチャは、重なり合う領域を有しない。
【0189】
幾つかの実施形態では、ビデオピクチャのサブピクチャの寸法は、ビデオブロックの寸法に基づき決定される。幾つかの実施形態では、サブピクチャは複数のエレメントを含む。サブピクチャ内のエレメントの幅を示すシンタックスエレメントは、N個のサンプルとして表され、サブピクチャの幅はN個のサンプルに基づき決定される。幾つかの実施形態では、ビデオブロックの幅はN個のサンプルを有する。
【0190】
幾つかの実施形態では、サブピクチャは複数のエレメントを含む。サブピクチャ内のエレメントの高さを示すシンタックスエレメントは、N個のサンプルとして表され、サブピクチャの高さはN個のサンプルに基づき決定される。幾つかの実施形態では、ビデオブロックの高さはN個のサンプルを有する。
【0191】
幾つかの実施形態では、ビデオブロックは、コーディングツリーブロック(coding tree block (CTB))又はコーディングツリーユニット(coding tree unit (CTU))である。幾つかの実施形態では、サブピクチャは長方形形状を有する。幾つかの実施形態では、サブピクチャは長方形スライスエレメントを含む。幾つかの実施形態では、サブピクチャは、ビデオの選択された1つ以上のレイヤにのみ適用可能である。幾つかの実施形態では、サブピクチャは、ビットストリーム表現内に設定されたシーケンスパラメータセットの中で定義され、サブピクチャは、対応するシーケンスの中で最高解像度を有するレイヤに適用可能である。幾つかの実施形態では、サブピクチャは、ビットストリーム表現内に設定されたシーケンスパラメータセットの中で定義され、サブピクチャは、対応するシーケンスの中で最低解像度を有するレイヤに適用可能である。幾つかの実施形態では、サブピクチャが適用可能な選択された1つ以上のレイヤは、ビットストリーム表現内の1つ以上のシンタックスエレメントの中でシグナリングされる。幾つかの実施形態では、サブピクチャが適用可能ではない1つ以上のレイヤは、ビットストリーム表現内の1つ以上のシンタックスエレメントの中でシグナリングされる。幾つかの実施形態では、1つ以上のシンタックスエレメントは、ビットストリーム表現内の、シーケンスパラメータセット、ビデオパラメータセット、又はピクチャパラメータセットの中でシグナリングされる。
【0192】
図12は、本発明の技術によるビデオ処理の方法1200のフローチャート表現である。方法1200は、動作1210で、少なくともビデオピクチャを用いて、ビデオのビデオユニットとビデオのコーディング表現との間の変換を実行するステップを含み、サブピクチャコーディングモード又は解像度変化コーディングモードのうちの1つのみが、ビデオユニットに対して有効である。サブピクチャコーディングモードは、ビデオピクチャが複数のサブピクチャに分割されるモードであり、解像度変化コーディングモードは、ビデオピクチャの解像度が変換中に調整されるモードである。
【0193】
幾つかの実施形態では、ビデオピクチャは、現在ピクチャ又は参照ピクチャを含む。幾つかの実施形態では、解像度変化コーディングモードは、参照ピクチャ再サンプリング(PRP)モードを含む。幾つかの実施形態では、解像度変化コーディングモードは、動的解像度変換(DRC)モードを含む。幾つかの実施形態では、解像度変化コーディングモードは、適応解像度変換(ARC)モードを含む。
【0194】
幾つかの実施形態では、ビデオユニットは、ビデオシーケンスを含む。幾つかの実施形態では、解像度変化コーディングモードが許可されない場合に、サブピクチャコーディングモードがコーディングユニットに対して有効であることを示すために、コーディング表現の中にシンタックスエレメントが含まれる。幾つかの実施形態では、サブピクチャコーディングモードが有効であると示すシンタックスエレメントがコーディング表現に含まれる場合、解像度変化コーディングモードは許可されない。幾つかの実施形態では、シンタックスエレメントはsubpics_present_flagを含む。幾つかの実施形態では、シンタックスエレメントが、サブピクチャコーディングモードが有効であると示す場合、ビデオピクチャの幅は、ビデオユニット内のビデオピクチャに対して許容される最大幅に等しく設定される。
【0195】
図13は、本発明の技術によるビデオ処理の方法1300のフローチャート表現である。方法1300は、動作1310で、少なくともビデオピクチャを用いて、ビデオのビデオユニットとビデオのコーディング表現との間の変換を実行するステップを含み、サブピクチャコーディングモード及び解像度変化コーディングモードの両方が、ビデオユニットに対して有効である。サブピクチャコーディングモードは、ビデオピクチャが複数のサブピクチャに分割されるモードであり、解像度変化コーディングモードは、ビデオピクチャの解像度が変換中に調整されるモードである。
【0196】
幾つかの実施形態では、ビデオユニットは、ビデオシーケンスを含む。幾つかの実施形態では、解像度変化コーディングモードは、適応解像度変換(ARC)モード、動的解像度変換(DRC)モード、参照ピクチャ再サンプリング(PRP)モード、を含む。
【0197】
幾つかの実施形態では、ビデオピクチャは複数のブロックを含み、各ブロックはW×Hの寸法を有する。解像度変化コーディングモードに従い調整されたサブピクチャは、K×Wの幅、及びM×Hの高さを有し、K及びMは整数である。幾つかの実施形態では、サブピクチャは、ビデオピクチャの境界に位置しない。幾つかの実施形態では、境界は、右境界又は下境界を含む。
【0198】
幾つかの実施形態では、ビデオピクチャは複数のビデオブロックを含み、個々のビデオブロックの寸法はビデオピクチャの解像度に基づき調整される。幾つかの実施形態では、コーディング表現は、ビデオブロックの最大寸法を示すシンタックスエレメントを含み、個々のビデオブロックの寸法は、ビデオピクチャの最大寸法及び解像度に基づき調整される。幾つかの実施形態では、個々のビデオブロックの寸法は、シーケンスパラメータセット、ピクチャパラメータセット、又はコーディング表現中のサブピクチャレベルでシグナリングされる。
【0199】
図14は、本発明の技術によるビデオ処理の方法1400のフローチャート表現である。方法1400は、動作1410で、1つ以上のビデオピクチャを含むビデオと前記ビデオのコーディング表現との間の変換を実行するステップ、を含み、個々のビデオピクチャの寸法は、8以上になるよう制約される。幾つかの実施形態では、寸法は個々のビデオピクチャの幅である。幾つかの実施形態では、寸法は個々のビデオピクチャの高さである。
【0200】
図15は、本発明の技術によるビデオ処理の方法1500のフローチャート表現である。方法1500は、動作1510で、ルールに従い、ビデオのビデオピクチャとビデオのコーディング表現との間の変換を実行するステップを含む。ビデオピクチャは少なくとも1つのサブピクチャを含み、ルールは、サブピクチャの特性がコーディング表現の中の少なくとも1つのシンタックスエレメントとして表現されることを指定し、少なくとも1つのシンタックスエレメントは、ビデオピクチャ内のサブピクチャグリッドのインデックス値と異なる。
【0201】
幾つかの実施形態では、特性は、サブピクチャの左上位置を含む。幾つかの実施形態では、特性は、サブピクチャの右下位置を含む。幾つかの実施形態では、特性は、サブピクチャの幅を含む。幾つかの実施形態では、特性は、サブピクチャの高さを含む。幾つかの実施形態では、ビデオピクチャ内のサブピクチャのインデックス値は、ビデオピクチャ内のサブピクチャの最大数より小さい。幾つかの実施形態では、[0,サブピクチャの最大数-1]の範囲にある整数値は、ビデオピクチャ内のサブピクチャのインデックス値と1対1対応を有する。
【0202】
図16は、本発明の技術によるビデオ処理の方法1600のフローチャート表現である。方法1600は、動作1610で、ルールに従い、ビデオのビデオピクチャとビデオのコーディング表現との間の変換を実行するステップを含む。ビデオピクチャは複数のサブピクチャを含み、各サブピクチャは複数のエレメントを含む。ルールは、サブピクチャ内の個々のエレメントの寸法が制約を満たすことを指定する。
【0203】
幾つかの実施形態では、制約は、個々のエレメントの幅がT1より小さいことを指定する。幾つかの実施形態では、制約は、個々のエレメントの高さがT2より小さいことを指定する。幾つかの実施形態では、ビデオピクチャは複数のビデオブロックを含み、制約は、個々のエレメントの寸法に基づき決定されたサブピクチャが、変換中に処理される現在ビデオブロックによりカバーされることを指定する。幾つかの実施形態では、現在ビデオブロックによりカバーされるサブピクチャの外部にあるサンプルは、変換のために利用できないと見なされる。幾つかの実施形態では、制約は、個々のエレメントの寸法が、ビデオコーディング標準のプロファイル、レベル、又はティアに基づき決定されることを指定する。幾つかの実施形態では、制約は、個々のビデオブロックの寸法がビデオピクチャの幅に基づき決定されることを指定する。幾つかの実施形態では、個々のビデオブロックの幅は、pic_width_max_in_luma_samples/4+offsetに等しく、pic_width_max_in_luma_samplesはルマサンプルにおける最大ピクチャ幅を表し、offsetは0又は0でない整数である。幾つかの実施形態では、制約は、個々のエレメントの寸法が、ビデオピクチャの高さに基づき決定されることを指定する。幾つかの実施形態では、個々のエレメントの高さは、pic_height_max_in_luma_samples/4+offsetに等しく、pic_height_max_in_luma_samplesはルマサンプルにおける最大ピクチャ高さを表し、offsetは0又は0でない整数である。
【0204】
幾つかの実施形態では、変換は、ビットストリーム表現からビデオピクチャを生成する。幾つかの実施形態では、変換は、ビデオピクチャからビットストリーム表現を生成する。
【0205】
図17は、本発明の技術によるビデオ処理の方法1700のフローチャート表現である。方法1700は、動作1710で、ルールに従い、コーディングモードを用いて、複数のサブピクチャを含むピクチャを有するビデオと、ビデオのコーディング表現との間の変換を実行するステップを含む。ルールは、前のサブピクチャに関する特定の格納された情報が、複数のサブピクチャのうちの各々の次のサブピクチャを処理する前に、再設定されることを指定する。
【0206】
幾つかの実施形態では、特定の格納された情報は、ビデオピクチャ内の現在ブロックがビデオピクチャからのサンプルによりコーディングされるイントラブロックコピーモードのために使用される仮想バッファを含む。幾つかの実施形態では、特定の格納された情報は、ビデオピクチャ内の現在ブロックがそれぞれのサンプル値のパレットを用いてコーディングされるパレットコーディングモードのために使用されるエントリのリストを含む。
【0207】
図18は、本発明の技術によるビデオ処理の方法1800のフローチャート表現である。方法1800は、動作1810で、ルールに従い、ビデオと前記ビデオのコーディング表現との間の変換において、時間フィルタリング動作を実行するステップを含む。ビデオは複数のビデオピクチャを含み、各ビデオピクチャは複数のサブピクチャを含む。ルールは、ビデオピクチャの現在サブピクチャ内の現在サンプルを時間フィルタリングするために、同じ現在サブピクチャ又は現在サブピクチャに対応する異なるビデオピクチャ内のサブピクチャの範囲内のサンプルのみが利用可能であることを指定する。
【0208】
図19は、本発明の技術によるビデオ処理の方法1900のフローチャート表現である。方法1900は、動作1910で、ビデオのビデオピクチャ内のブロックとビデオのコーディング表現との間の変換のために、ブロックがビデオピクチャの1つ以上のサブピクチャ境界と交差するかどうかに基づき、ブロックにパーティション方法を適用する方法を決定するステップを含む。方法1900は、動作1920で、決定に基づき変換を実行するステップを更に含む。
【0209】
幾つかの実施形態では、パーティション方法は、以下:4分木パーティション方法、水平2分木パーティション方法、垂直2分木パーティション方法、水平3分木パーティション方法、垂直3分木パーティション方法、又は非分割方法、のうちの少なくとも1つを含む。幾つかの実施形態では、方法は、境界処理方法がブロックに適用可能かどうかを更に指定する。幾つかの実施形態では、方法は、ブロックがビデオピクチャのサブピクチャの1つ以上の境界に跨がり位置するかどうかに基づき、パーティション方法を示すコーディング表現内のシンタックスエレメントを処理する方法を決定するステップを含む。
【0210】
図20は、本発明の技術によるビデオ処理の方法2000のフローチャート表現である。方法2000は、動作2010で、ビデオのビデオピクチャとビデオのコーディング表現との間の変換のために、ビデオピクチャのうちの2つのサブ領域を決定するステップを含む。第1サブ領域は、ビデオピクチャの複数のサブピクチャを含み、第2サブ領域は、ビデオピクチャ内のサンプルを維持することを含む。方法2000は、動作2020で、決定に基づき変換を実行するステップを更に含む。
【0211】
幾つかの実施形態では、第2サブ領域内のサンプルは、ビデオピクチャの任意のサブピクチャ内に位置しない。幾つかの実施形態では、第2サブ領域は、第1サブ領域に関する情報に基づき、変換のために処理される。幾つかの実施形態では、デフォルト値は、ビデオピクチャのサンプル又は領域が第2サブ領域内に位置するかどうかを示すために、変換中に使用される。幾つかの実施形態では、デフォルト値は(max_subpics_minus1+K)に設定され、max_subpics_minus1は、ビデオピクチャ内のサブピクチャの最大数を示し、Kは1より大きい整数である。幾つかの実施形態では、デフォルト値は、ビデオピクチャ内のサブピクチャを表すインデックス値のアレイの中の各要素に割り当てられる。
【0212】
幾つかの実施形態では、変換は、コーディング表現からビデオを生成する。幾つかの実施形態では、変換は、ビデオからコーディング表現を生成する。
【0213】
開示した技術の幾つかの実施形態は、ビデオ処理ツール又はモードを有効にすることの決定又は判断を行うことを含む。例では、ビデオ処理ツール又はモードが有効にされると、エンコーダは、ビデオのブロックの処理において該ツール又はモードを使用又は実施するが、必ずしもツール又はモードの使用に基づき結果として生じるビットストリームを変更する必要はない。つまり、ビデオのブロックからビデオのビットストリーム表現への変換は、決定又は判断に基づき有効にされるとき、ビデオ処理ツール又はモードを使用する。別の例では、ビデオ処理ツール又はモードが有効にされると、デコーダは、ビットストリームがビデオ処理ツール又はモードに基づき変更されているという知識により、ビットストリームを処理する。つまり、ビデオのビットストリーム表現からビデオのブロックへの変換は、決定又は判断に基づき有効にされたビデオ処理ツール又はモードを使用して実行される。
【0214】
開示した技術の幾つかの実施形態は、ビデオ処理ツール又はモードを無効にすることの決定又は判断を行うことを含む。例では、ビデオ処理ツール又はモードが無効にされるとき、エンコーダは、ビデオのブロックをビデオのビットストリーム表現へ変換する際にツール又はモードを使用しない。別の例では、ビデオ処理ツール又はモードが無効にされると、デコーダは、ビットストリームが決定又は判断に基づき有効にされたビデオ処理ツール又はモードを用いて変更されていないという知識により、ビットストリームを処理する。
【0215】
本願明細書に記載された本開示の及び他のソリューション、例、実施形態、モジュール、及び機能動作は、デジタル電子回路で、又は本願明細書に開示された構造を含む、コンピュータソフトウェア、ファームウェア、又はハードウェア、及びそれらの構造的均等物で、又はそれらの1つ以上の結合で、実装できる。本開示の及び他の実施形態は、1つ以上のコンピュータプログラムプロダクト、例えば、データ処理機器による実行のために又はその動作を制御するために、コンピュータ可読媒体上に符号化されたコンピュータプログラム命令の1つ以上のモジュールとして実装できる。コンピュータ可読媒体は、機械可読記憶装置、機械可読記憶基板、メモリ装置、機械可読伝搬信号に影響を与える物質の組成、又は1つ以上のそれらの組合せであり得る。用語「データ処理機器」は、データを処理するあらゆる機器、装置、及び機械を包含し、例として、プログラマブルプロセッサ、コンピュータ、又は複数のプロセッサ若しくはコンピュータを含む。機器は、ハードウェアに加えて、対象となるコンピュータプログラムの実行環境を生成するコード、例えばプロセッサファームウェア、プロトコルスタック、データベース管理システム、オペレーティングシステム、又はそれらの1つ以上の組合せを構成するコードを含むことができる。伝搬信号は、人工的に生成された信号、例えば、適切な受信機への送信のために情報を符号化するために生成された、機械により生成された電気、光、又は電磁気信号である。
【0216】
コンピュータプログラム(プログラム、ソフトウェア、ソフトウェアアプリケーション、スクリプト、又はコードとしても知られる)は、コンパイルされた又はインタープリットされた言語を含む任意の形式のプログラミング言語で記述でき、それは、スタンドアロンプログラム又はモジュール、コンポーネント、サブルーチン、又はコンピューティング環境内での使用に適する他のユニットを含む任意の形式で展開できる。コンピュータプログラムは、必ずしもファイルシステム内のファイルに対応する必要はない。プログラムは、他のプログラム又はデータ(例えばマークアップ言語文書内に格納された1つ以上のスクリプト)を保持するファイルの一部に、問題のプログラムに専用の単一のファイルに、又は複数の連携ファイル(例えば、1つ以上モジュール、サブプログラム、又はコードの部分を格納するファイル)に、格納できる。コンピュータプログラムは、1つのコンピュータ上で、又は1つの場所に置かれた若しくは複数の場所に分散されて通信ネットワークにより相互接続される複数のコンピュータ上で、実行されるよう展開できる。
【0217】
本願明細書に記載の処理及びロジックフローは、入力データに作用し及び出力を生成することにより機能を実行する1つ以上のコンピュータプログラムを実行する1つ以上のプログラマブルプロセッサにより実行できる。特定用途論理回路、例えば、FPGA(field programmable gate array)又はASIC(application specific integrated circuit)により、処理及びロジックフローが実行でき、それとして機器が実装できる。
【0218】
コンピュータプログラムの実行に適するプロセッサは、例えば、汎用及び特定用途向けマイクロプロセッサの両方、及び任意の種類のデジタルコンピュータの任意の1つ以上のプロセッサを含む。通常、プロセッサは、命令及びデータを読み出し専用メモリ又はランダムアクセスメモリ又は両者から受信する。コンピュータの基本的要素は、命令を実行するプロセッサ、及び命令及びデータを格納する1つ以上のメモリ装置である。通常、コンピュータは、データを格納する1つ以上の大容量記憶装置、例えば、磁気、光磁気ディスク、又は光ディスク、も含み、又はそれらからデータを受信し又はそれらへデータを転送するために又は両者のために動作可能に結合される。しかしながら、コンピュータはこのような装置を有する必要はない。コンピュータプログラム命令及びデータを格納するのに適するコンピュータ可読媒体は、例えば半導体メモリ装置、例えばEPROM、EEPROM,及びフラッシュメモリ装置、磁気ディスク、例えば内部ハードディスク又は取り外し可能ディスク、光磁気ディスク、及びCD-ROM及びDVD-ROMディスクを含む、全ての形式の-不揮発性メモリ、媒体、及びメモリ装置を含む。プロセッサ及びメモリは、特定用途向け論理回路により補足され、又はその中に組み込むことができる。
【0219】
本願明細書は多数の特定事項を含むが、これらは、任意の主題の又は請求され得るものの範囲に対する限定としてではなく、むしろ、特定の技術の特定の実施形態に固有の特徴の説明として考えられるべきである。別個の実装の文脈で本願明細書に記載された特定の特徴は、単一の実施形態において組み合わせることもできる。反対に、単一の実施形態の文脈で記載された種々の特徴は、複数の実施形態の中で別個に又は任意の適切な部分的組み合わせで実装されることもできる。更に、特徴は特定の組み合わせで動作するよう上述され、そのように初めに請求され得るが、請求される組み合わせからの1つ以上の特徴は、幾つかの場合には、組み合わせから切り離されてよく、請求される組み合わせは、部分的組み合わせ又は部分的組み合わせの変形に向けられてよい。
【0220】
同様に、動作は、図中に特定の順序で示されるが、これは、望ましい結果を達成するために、そのような動作が示された特定の順序で又はシーケンシャルに実行されること、及び全ての図示の動作が実行されること、を要求すると理解されるべきではない。更に、本願明細書に記載された実施形態における種々のシステムコンポーネントの分離は、全ての実施形態においてこのような分離を必要とすると理解されるべきではない。
【0221】
小数の実装及び例のみが記載され、本願明細書に記載され示されたものに基づき他の実装、拡張、及び変形が行われ得る。