IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ ドルビー ラボラトリーズ ライセンシング コーポレイションの特許一覧

特許7411727フレームレートスケーラブルビデオ符号化
<>
  • 特許-フレームレートスケーラブルビデオ符号化 図1
  • 特許-フレームレートスケーラブルビデオ符号化 図2
  • 特許-フレームレートスケーラブルビデオ符号化 図3
  • 特許-フレームレートスケーラブルビデオ符号化 図4
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2023-12-27
(45)【発行日】2024-01-11
(54)【発明の名称】フレームレートスケーラブルビデオ符号化
(51)【国際特許分類】
   H04N 19/70 20140101AFI20231228BHJP
   H04N 19/31 20140101ALI20231228BHJP
【FI】
H04N19/70
H04N19/31
【請求項の数】 8
【外国語出願】
(21)【出願番号】P 2022093134
(22)【出願日】2022-06-08
(62)【分割の表示】P 2020551482の分割
【原出願日】2020-03-11
(65)【公開番号】P2022120065
(43)【公開日】2022-08-17
【審査請求日】2022-06-08
(31)【優先権主張番号】62/816,521
(32)【優先日】2019-03-11
(33)【優先権主張国・地域又は機関】US
(31)【優先権主張番号】62/850,985
(32)【優先日】2019-05-21
(33)【優先権主張国・地域又は機関】US
(31)【優先権主張番号】62/883,195
(32)【優先日】2019-08-06
(33)【優先権主張国・地域又は機関】US
(31)【優先権主張番号】62/904,744
(32)【優先日】2019-09-24
(33)【優先権主張国・地域又は機関】US
(73)【特許権者】
【識別番号】507236292
【氏名又は名称】ドルビー ラボラトリーズ ライセンシング コーポレイション
(74)【代理人】
【識別番号】110002952
【氏名又は名称】弁理士法人鷲田国際特許事務所
(72)【発明者】
【氏名】アトキンス ロビン
(72)【発明者】
【氏名】イン ポン
(72)【発明者】
【氏名】ルー タオラン
(72)【発明者】
【氏名】プー ファンチュン
(72)【発明者】
【氏名】マッカーシー ショーン トーマス
(72)【発明者】
【氏名】フサーク ウォルター ジェイ.
(72)【発明者】
【氏名】チェン タオ
(72)【発明者】
【氏名】スー コアン-ミン
【審査官】田部井 和彦
(56)【参考文献】
【文献】特開2016-005244(JP,A)
【文献】国際公開第2015/115946(WO,A1)
【文献】Sean McCarthy et al.,AHG17: Shutter interval information SEI message [online],JVET-P0338-v1,インターネット <URL: https://jvet-experts.org/doc_end_user/documents/16_Geneva/wg11/JVET-P0338-v1.zip>,2019年09月24日
【文献】Information technology - High efficiency coding and media delivery in heterogeneous environments - Part 2: High efficiency video coding AMENDMENT 1: Shutter interval information SEI message,ISO文書(SC29) FINAL DRAFT AMENDMENT ISO/IEC 23008-2:2020 FDAM 1 ,ISO,2021年04月08日
(58)【調査した分野】(Int.Cl.,DB名)
H04N 19/70
H04N 19/31
(57)【特許請求の範囲】
【請求項1】
ビデオビットストリームを復号する方法であって、
ビデオピクチャのシーケンスの符号化を含む符号化ピクチャセクションと、シャッタインターバルパラメータを含むシグナリングセクションとを含む符号化ビデオビットストリームを受信することであって、前記シャッタインターバルパラメータは、
1秒間に経過する時間単位の数を示す、シャッタインターバルタイムスケールパラメータと、
前記シャッタインターバルタイムスケールパラメータの周波数で作動するクロックの時間単位の数を示す、シャッタインターバルクロックチックパラメータと、
前記符号化ピクチャセクション内のすべての時間的サブレイヤについて露光持続時間情報が固定されているかを示すシャッタインターバル持続時間フラグと、を含み、
前記シャッタインターバル持続時間フラグが、露光持続時間情報が固定されていることを示す場合、前記符号化ピクチャセクション内のすべての時間的サブレイヤについてビデオピクチャのシーケンスの符号化バージョンは、前記シャッタインターバルタイムスケールパラメータおよび前記シャッタインターバルクロックチックパラメータに基づいて、露光持続時間値を算出することにより復号され、そうでない場合、
前記シグナリングセクションは、サブレイヤパラメータの1つ以上のアレイを含み、前記シャッタインターバルタイムスケールパラメータと結合されたサブレイヤパラメータの1つ以上のアレイにおける値は、ビデオピクチャのシーケンスの時間的サブレイヤの復号されたバージョンを表示するために、各サブレイヤについて対応するサブレイヤ露光持続時間値を算出するのに使用される、受信することと、
前記シャッタインターバルパラメータに基づいて、ビデオピクチャのシーケンスを復号することと、を含む方法。
【請求項2】
サブレイヤパラメータの前記1つ以上のアレイは、各値が前記シャッタインターバルタイムスケールパラメータの周波数で作動する前記クロックの時間単位の数を示す、サブレイヤシャッタインターバルクロックチック値のアレイを含む、請求項1に記載の方法。
【請求項3】
前記露光持続時間値は、前記シャッタインターバルクロックチックパラメータを前記シャッタインターバルタイムスケールパラメータで割った商として計算される、請求項1に記載の方法。
【請求項4】
前記シグナリングセクションは、補足エンハンスメント情報(SEI)メッセージングセクションまたはビデオユーザ情報(VUI)メッセージングセクションを含む、請求項1に記載の方法。
【請求項5】
ビデオビットストリームを符号化する方法であって、
ビデオピクチャのシーケンスと、関連するシャッタインターバル情報とを受信することと、
ビデオピクチャのシーケンスの符号化を含む符号化ピクチャセクションと、前記ビデオピクチャのシーケンスのためのシャッタインターバルパラメータを含むシグナリングセクションとを含む符号化ビデオビットストリームを生成することと、を含み、
前記シャッタインターバルパラメータは、
1秒間に経過する時間単位の数を示す、シャッタインターバルタイムスケールパラメータと、
前記シャッタインターバルタイムスケールパラメータの周波数で作動するクロックの時間単位の数を示す、シャッタインターバルクロックチックパラメータと、
前記符号化ピクチャセクション内のすべての時間的サブレイヤについて露光持続時間情報が固定されているかを示すシャッタインターバル持続時間フラグと、を含み、
前記シャッタインターバル持続時間フラグが、露光持続時間情報が固定されていることを示す場合、前記符号化ピクチャセクション内のすべての時間的サブレイヤについてビデオピクチャのシーケンスの符号化バージョンは、前記シャッタインターバルタイムスケールパラメータおよび前記シャッタインターバルクロックチックパラメータに基づいて、露光持続時間値を算出することにより復号され、そうでない場合、
前記シグナリングセクションは、サブレイヤパラメータの1つ以上のアレイを含み、前記シャッタインターバルタイムスケールパラメータと結合されたサブレイヤパラメータの1つ以上のアレイにおける値は、ビデオピクチャのシーケンスの時間的サブレイヤの復号されたバージョンを表示するために、各サブレイヤについて対応するサブレイヤ露光持続時間値を算出するのに使用される、方法。
【請求項6】
サブレイヤパラメータの前記1つ以上のアレイは、各値が前記シャッタインターバルタイムスケールパラメータの周波数で作動する前記クロックの時間単位の数を示す、サブレイヤシャッタインターバルクロックチック値のアレイを含む、請求項5に記載の方法。
【請求項7】
前記露光持続時間値は、前記シャッタインターバルクロックチックパラメータを前記シャッタインターバルタイムスケールパラメータで割った商として計算される、請求項5に記載の方法。
【請求項8】
前記シグナリングセクションは、補足エンハンスメント情報(SEI)メッセージングセクションまたはビデオユーザ情報(VUI)メッセージングセクションを含む、請求項5に記載の方法。
【発明の詳細な説明】
【技術分野】
【0001】
関連出願の相互参照
本出願は2019年3月11日に出願された米国仮出願第62/816,521号、2019年5月21日に出願された米国仮出願第62/850,985号、2019年8月6日に出願された米国仮出願第62/883,195号、および2019年9月24日に出願された米国仮出願第62/904,744号からの優先権の利益を主張するものであり、それらの各々は参照によりその全体が援用される。
【0002】
本文書は、一般に画像に関する。より詳細には、本発明の一実施形態がフレームレートスケーラブルビデオ符号化に関する。
【背景技術】
【0003】
本明細書で使用されるように、用語「ダイナミックレンジ」(DR)は、例えば、最も暗いグレー(黒)から最も明るい白(ハイライト)までの、画像内の強度(例えば、ルミナンス、ルマ)の範囲を知覚する人間の視覚系(HVS)の能力に関連し得る。この意味で、DRは「シーンリファード」強度に関連する。DRは、特定の幅の強度範囲を適切にまたは概ねレンダリングするディスプレイ装置の能力にも関係し得る。この意味で、DRは「表示参照」強度に関連する。本明細書の説明の任意の時点で特定の意味を有するように明示的に指定されていない限り、用語はいずれの意味でも、例えば、互換的に使用され得ることが推測されるべきである。
【0004】
本明細書で使用されるように、高ダイナミックレンジ(HDR)という用語は、人間の視覚系(HVS)の14~15桁にわたるDR幅に関する。実際には、人間が強度範囲の広い幅を同時に知覚することができるDRは、HDRに関していくらか切り捨てることができる。
【0005】
実際には、画像が1つ以上の色成分(例えば、ルマYおよびクロマCbおよびCr)を含み、各色成分は、ピクセル当たりnビットの精度(例えば、n=8)によって表される。線形輝度符号化を使用すると、n≦8の画像(例えば、カラー24ビットJPEG画像)は標準ダイナミックレンジ(SDR)の画像と考えられ、n>8の画像は強化されたダイナミックレンジの画像と考えられる。また、HDR画像は、Industrial Light and Magicによって開発されたOpenEXRファイルフォーマットなどの高精度(例えば、16ビット)浮動小数点フォーマットを使用して、格納し、配布することもできる。
【0006】
現在、ドルビー研究所からのドルビービジョン(Dolby Vision)またはブルーレイ(Blue-Ray)におけるHDR10などのビデオ高ダイナミックレンジコンテンツの配信は、多くの再生装置の能力によって、4K解像度(例えば、4096×2160または3840×2160など)および60フレーム/秒(fps)に制限されている。将来のバージョンでは、8K解像度(例えば、7680×4320)および120fpsまでのコンテンツが配信および再生のために利用可能であり得ることが予想される。ドルビービジョンのようなHDR再生コンテンツエコシステムを単純化するために、将来のコンテンツタイプが既存の再生装置と互換性があることが望ましい。理想的には、コンテンツプロデューサが、既存のHDRデバイス(HDR10またはドルビービジョンなど)と互換性のあるコンテンツの特別なバージョンを導出および配信する必要なしに、将来のHDR技術を採用し、配信することができなければならない。本発明者らによって理解されるように、ビデオコンテンツ、特にHDRコンテンツのスケーラブルな配信のための改善された技術が望まれている。
【0007】
このセクションで説明されるアプローチは追求されることができるアプローチであるが、必ずしも、以前に考えられたまたは追求されたアプローチではない。したがって、特に断らない限り、このセクションに記載されているアプローチのいずれも、単にこのセクションに含まれているために先行技術として適格であると仮定すべきではない。同様に、1つ以上のアプローチに関して特定された問題は特に断らない限り、このセクションに基づいていかなる先行技術においても認識されていると推測すべきではない。
【図面の簡単な説明】
【0008】
本発明の実施形態は限定ではなく例として、添付の図面の図に示されており、同様の参照番号は同様の要素を指す。
図1】ビデオ配信パイプラインの例示的なプロセスを示す。
図2】本発明の一実施形態による、ターゲットシャッタ角度でターゲットフレームレートをレンダリングするために連続するオリジナルフレームを結合する例示的なプロセスを示す。
図3】本発明の一実施形態による、固定フレームレートを有するコンテナ内の、可変入力フレームレートおよび可変シャトル角度を有する入力シーケンスの例示的な表示を示す。
図4】本発明の一実施形態による、後方互換性を有する、種々のフレームレートおよびシャッタ角度における、時間的スケーラビリティのための例示的な表示を示す。
【発明を実施するための形態】
【0009】
ビデオ符号化のためのフレームレートスケーラビリティに関連する例示的な実施形態が、本明細書で説明される。以下の説明において、説明の目的のために、本発明の完全な理解を提供するために、多数の特定の詳細が記載される。しかしながら、本発明は、これらの特定の詳細なしに実施されてもよいことは明らかであろう。他の例では、本発明を不必要に閉塞し、不明瞭にし、または難読化することを回避するために、周知の構造および装置は網羅的な詳細では説明されない。
【0010】
概要
本明細書で説明される例示的な実施形態は、ビデオ符号化におけるフレームレートスケーラビリティに関する。一実施形態では、プロセッサを有するシステムが符号化ビデオフレームを含む符号化ビットストリームを受信し、1つ以上の符号化されたフレームは、第1のフレームレートおよび第1のシャッタ角度で符号化される。プロセッサは、第2のフレームレートおよび第2のシャッタ角度で復号されるべき符号化フレームのグループの存在を示す第1のフラグを受信し、符号化フレームのグループのための第2のフレームレートおよび第2のシャッタ角度の符号化ビットストリーム値からアクセスし、符号化フレームのグループ、第1のフレームレート、第1のシャッタ角度、第2のフレームレート、および第2のシャッタ角度に基づいて、第2のフレームレートおよび第2のシャッタ角度で復号フレームを生成する。
【0011】
第2の実施形態では、プロセッサ有するデコーダであって、
符号化ビデオフレームのグループを含む符号化ビットストリームを受信することであって、符号化ビットストリーム内のすべての符号化ビデオフレームは、第1のフレームレートで符号化される、符号化ビットストリームを受信することと、
結合されたN個のフレームの数を受信することと、
ベースラインフレームレートのための値を受信することと、
N個の連続符号化フレームのグループにアクセスすることであって、N個の連続符号化フレームのグループ内のi番目の符号化フレームは、第1のシャッタ角度および第1のフレームレートに基づいて、ベースラインフレームレートおよびi番目のシャッタ角度でエンコーダにおいて符号化されたi番目までの入力ビデオフレームの平均を示し、ここで、i=1、2、...Nである、N個の連続符号化フレームのグループにアクセスすることと、
第2のフレームレートおよび第2のシャッタ角度でN個の連続する符号化フレームのグループを復号するために、符号化ビットストリームから、または第2のフレームレートおよび第2のシャッタ角度についてのユーザ入力値からアクセスすることと、
N個の連続する符号化フレームのグループ、第1のフレームレート、第1のシャッタ角度、第2のフレームレート、および第2のシャッタ角度に基づいて、第2のフレームレートおよび第2のシャッタ角度で復号フレームを生成することと、を実行する。
【0012】
第3の実施形態では、符号化ビデオストリーム構造は、
ビデオピクチャのシーケンスの符号化を含む符号化ピクチャセクションと、
シグナリングセクションであって、
1秒間に経過する時間単位の数を示す、シャッタインターバルタイムスケールパラメータと、
シャッタインターバルタイムスケールパラメータの周波数で作動するクロックの時間単位の数を示す、シャッタインターバルクロックチックパラメータであって、シャッタインターバルタイムスケールパラメータにより割られたシャッタインターバルは、露光持続時間値を示す、シャッタインターバルクロックチックパラメータと、
符号化ピクチャセクション内のすべての時間的サブレイヤについて露光持続時間情報が固定されているかを示すシャッタインターバル持続時間フラグと、の符号化を含む、シグナリングセクションと、を含み、
シャッタインターバル持続時間フラグが、露光持続時間情報が固定されていることを示す場合、符号化ピクチャセクション内のすべての時間的サブレイについてビデオピクチャのシーケンスの符号化バージョンは、シャッタインターバルタイムスケールパラメータおよびシャッタインターバルクロックチックパラメータに基づいて、露光持続時間値を算出することにより復号され、そうでない場合、
シグナリングセクションは、サブレイヤパラメータの1つ以上のアレイを含み、シャッタインターバルタイムスケールパラメータと結合されたサブレイヤパラメータの1つ以上のアレイにおける値は、ビデオピクチャのシーケンスの時間的サブレイヤの復号されたバージョンを表示するために、各サブレイヤについて対応するサブレイヤ露光持続時間値を算出するのに使用される。
【0013】
ビデオ配信処理パイプラインの例
図1は、ビデオキャプチャからビデオコンテンツ表示までの様々な段階を示す従来のビデオ配信パイプライン(100)の例示的なプロセスを示す。一連のビデオフレーム(102)は、画像生成ブロック(105)を使用してキャプチャまたは生成される。ビデオフレーム(102)は、ビデオデータ(107)を提供するために、(例えば、デジタルカメラによって)デジタル的に取り込まれてもよく、または(例えば、コンピュータアニメーションを使用して)コンピュータによって生成されてもよい。代替的に、ビデオフレーム(102)は、フィルムカメラによってフィルム上にキャプチャされてもよい。フィルムは、ビデオデータ(107)を提供するためにデジタルフォーマットに変換される。プロダクションフェーズ(110)では、ビデオデータ(107)が編集されて、ビデオプロダクションストリーム(112)が提供される。
【0014】
次いで、プロダクションストリーム(112)のビデオデータは、ポストプロダクション編集のために、ブロック(115)でプロセッサに供給される。ポストプロダクション編集のブロック(115)は、ビデオクリエータの創作意図に従って、画質を向上させるか、または画像の特定の外観を達成するために、画像の特定の領域における色または明るさを調整または修正することを含むことができる。これは「カラータイミング」または「カラーグレーディング」というものである。他の編集(例えば、シーン選択およびシーケンシング、画像クロッピング、コンピュータ生成される視覚特殊効果の追加、ジャダーまたはブラー制御、フレームレート制御など)は、ブロック(115)で実行されて、配信のためのプロダクションの最終バージの間、ビデオ画像は参照ディスプレイ(125)に表示される。ポストプロダクション(115)に続いて、最終プロダクション(117)のビデオデータは、テレビジョンセット、セットトップボックス、ムービーシアター等のような復号および再生装置にダウンストリームで配信するために、符号化ブロック(120)に配信されてもよい。いくつかの実施形態では、符号化ブロック(120)は、符号化ビットストリーム(122)を生成するために、ATSC、DVB、DVD、Blu-Ray、および他の配信フォーマットによって定義されるものなどの、オーディオエンコーダおよびビデオエンコーダを含むことができる。受信機では、符号化ビットストリーム(122)は復号ユニット(130)によって復号され、信号(117)の同一または近似を表す復号信号(132)を生成する。受信機は、参照ディスプレイ(125)とは全く異なる特性を有することができるターゲットディスプレイ(140)に取り付けることができる。その場合、ディスプレイ管理ブロック(135)を使用して、ディスプレイマップ信号(137)を生成することによって、復号信号(132)のダイナミックレンジをターゲットディスプレイ(140)の特性にマッピングすることができる。
【0015】
スケーラブル符号化
スケーラブル符号化は、すでに、MPEG-2、AVC、およびHEVCのような多くのビデオ符号化標準の一部である。本発明の実施形態では、スケーラブル符号化は、特に非常に高解像度のHDRコンテンツに関するので、性能および柔軟性を改善するために拡張される。
【0016】
本明細書で使用されるように、「シャッタ角度」という用語は、各フレームインターバルの間にフィルムが光に曝される時間の割合を制御する調節可能なシャッタ設定を示す。例えば、一実施形態では、
【数1】
である。
【0017】
この用語は、伝来の機械的な回転シャッタに起源を持つが、現代のデジタルカメラもまた、シャッタを電子的に調整することができる。映画撮影者は、シャッタ角度を使用して、各フレームに記録されるモーションブラーやジャダーの量を制御することができる。なお、「露光時間」の代わりに、「露光持続時間」、「シャッタインターバル」、「シャッタスピード」などの代替用語を用いてもよい。同様に、「フレームインターバル」の代わりに、「フレーム持続時間」という用語を用いてもよい。あるいは、「フレームインターバル」を「1/フレームレート」に置き換えてもよい。露光時間の値は、通常、フレームの持続時間以下である。例えば、180度のシャッタ角度は、露光時間がフレーム持続時間の半分であることを示す。いくつかの状況では、露光時間が、例えば、符号化フレームレートが120fpsであり、符号化および表示前の関連するビデオコンテンツのフレームレートが60fpsである場合、符号化ビデオのフレーム持続時間よりも長くてもよい。
【0018】
限定ではなく、オリジナルコンテンツが360度のシャッタ角度でオリジナルフレームレート(例えば、120fps)で撮影(または生成)される実施形態を考える。次に、受信装置では、例えば、平均化または当技術分野で知られている他の動作によって、オリジナルフレームの判断力のある結合によって、オリジナルフレームレート以下の様々なフレームレートでビデオ出力をレンダリングすることができる。
【0019】
結合プロセスは、(例えば、ガンマ、PQまたはHLGを使用して)非線形符号化信号で実行されてもよいが、最良の画質は、最初に、非線形符号化信号を線形光表示に変換し、次に、変換されたフレームを結合し、最後に、出力を非線形伝達関数で再符号化することによって、線形光領域内のフレームを結合することによって得られる。このプロセスは、非線形領域で結合するよりも、物理的なカメラ露光のより正確なシミュレーションを提供する。
【0020】
一般的に、フレームを結合するプロセスは、オリジナルフレームレート、ターゲットフレームレート、ターゲットシャッタ角度、および結合されるフレーム数の観点から下記のように表現することができる。
【数2】
これは、
【数3】
と同等である。
【0021】
ここで、n_framesは結合されたフレームの数であり、original_frame_rateはオリジナルコンテンツのフレームレートであり、target_frame_rateはレンダリングされるフレームレートであり(ここで、target_frame_rate≦original_frame_rate)、target_shutter_angleは所望のモーションブラーの量を示す。この例では、target_shutter_angleの最大値は360度であり、最大モーションブラーに対応する。target_shutter_angleの最小値は360*(target_frame_rate/original_frame_rate)と表すことができ、最小モーションブラーに対応する。n_framesの最大値は、(original_frame_rate/target_frame_rate)として表すことができる。target_frame_rateおよびtarget_shutter_angleの値は、n_frameの値が非ゼロ整数であるように選択されるべきである。
【0022】
オリジナルフレームレートが120fpsである特別な場合、数式(2)は、
【数4】
として書き換えることができ、これは、
【数5】
と同等である。
target_frame_rate、n_frames、およびtarget_shutter_angleの値の間の関係は、original_frame_rate=120fpsの場合について表1に示される。表1において、「NA」は、ターゲットフレームレートと結合フレーム数との対応する結合が許可されていないことを示す。
【表1】
【0023】
図2は、一実施形態による、ターゲットシャッタ角度でターゲットフレームレートをレンダリングするために、連続したオリジナルフレームを結合する例示的なプロセスを示す。120fpsでの入力シーケンス(205)および360度のシャッタ角度が与えられた場合、プロセスは、5つの連続するフレームのセット内の入力フレームの3つ(例えば、最初の3つの連続するフレーム)を結合させ、他の2つをドロップすることによって、24fpsおよび216度のシャッタ角度での出力ビデオシーケンス(210)を生成する。いくつかの実施形態では、(210)の出力フレーム01は、フレーム1、3、および5、またはフレーム2、4、および5などの入力フレーム(205)のどれかを結合することによって生成され得るが、連続するフレームを結合することはより良好な品質のビデオ出力をもたらすと考えられることに留意されたい。
【0024】
例えば、芸術的およびスタイル的効果を管理するために、可変フレームレートでオリジナルコンテンツをサポートすることが望ましい。また、オリジナルコンテンツの可変入力フレームレートは、コンテンツの生成、交換、および配信を単純化するために、固定フレームレートを有する「コンテナ」にパッケージ化されることが望ましい。一例として、固定フレームレートコンテナにおいて可変フレームレートビデオデータをどのように表現するか、に関する3つの実施形態が提示される。明確にするために、および限定することなく、以下の説明は固定120fpsコンテナを使用するが、アプローチは代替のフレームレートコンテナに容易に拡張することができる。
【0025】
第1の実施形態(可変フレームレート)
第1の実施形態は、一定のフレームレートを有するコンテナにパッケージされた可変(一定でない)フレームレートを有するオリジナルコンテンツの明示的な記述である。例えば、異なるシーンに対して、異なるフレームレート、例えば、24、30、40、60、または120fpsを有するオリジナルコンテンツは、120fpsの一定のフレームレートを有するコンテナにパッケージされてもよい。この例では、各入力フレームは、5x、4x、3x、2x、または1x回複製して、共通の120fpsコンテナにパッケージ化できる。
【0026】
図3は、固定フレームレートを有する符号化ビットストリームBで表される可変フレームレートおよび可変シャッタ角度を有する入力ビデオシーケンスAの一例を示す。そして、デコーダにおいて、デコーダは、シーン毎に変化し得る、所望のフレームレートおよびシャッタ角度で出力ビデオシーケンスCを再構成する。例えば、図3に示すように、シーケンスBを構成するために、入力フレームのいくつかは複製され、いくつかはそのまま(複製なしで)符号化され、いくつかは4回コピーされる。次いで、シーケンスCを構築するために、各複製フレームから任意の1つのフレームを選択し、オリジナルフレームレートおよびシャッタ角度が一致する出力フレームを生成する。
【0027】
この実施形態では、メタデータがビットストリームに挿入され、オリジナル(基本)フレームレートおよびシャッタ角度を示す。メタデータは、シーケンスパラメータセット(SPS)、ピクチャパラメータセット(PPS)、スライスまたはタイルグループヘッダなどの高レベルシンタックスを使用して、信号を送ることができる。メタデータの存在は、エンコーダおよびデコーダが以下のような有益な機能を実行することを可能にする。
a)エンコーダは複製したフレームを無視することができ、それによって、符号化速度を向上させ、プロセスを単純化する。たとえば、複製フレーム内のすべてのコーディングツリーユニット(CTU)は、SKIPモードおよび参照フレームのLIST0における参照インデックス0を使用して符号化できる。これは複製フレームがコピーされる復号されたフレームを参照する。
b)デコーダは複製フレームの復号をバイパスすることができ、それによってプロセスを単純化する。たとえば、ビットストリーム内のメタデータは、フレームが、新しいフレームをコピーすることによりおよび復号することなく、デコーダが再現できる、以前に復号されたフレームの複製であることを示すことができる。
c)再生装置は、ベースフレームレートを示すことによって、例えばフレームレート変換またはノイズ低減アルゴリズムを調整することによって、ダウンストリームプロセスを最適化することができる。
【0028】
この実施形態は、エンドユーザがコンテンツクリエータによって意図されたフレームレートでレンダリングされたコンテンツを見ることを可能にする。この実施形態は、コンテナのフレームレート、例えば120fpsをサポートしないデバイスとの後方互換性を提供しない。
【0029】
表2および表3は、シーケンスパラメータセットおよびタイルグループヘッダの生バイトシーケンスペイロード(RBSP)のシンタックス例を示しており、ここでは、提案された新しいシンタックス要素は強調表示されたフォントで示されている。残りのシンタックスは、汎用ビデオコーデック(VVC)(参照文献[2])の提案された仕様におけるシンタックスに従う。
【0030】
例として、SPS(表2参照)では、可変フレームレートを有効にするフラグを追加できる。
sps_vfr_enabled_flagが1に等しいことは、コード化ビデオシーケンス(CVS)に可変フレームレートコンテンツを含めることができることを明示する。sps_vfr_enabled_flagが0に等しいことは、CVSに固定フレームレートコンテンツを含めることができることを明示する。
tile_group header()(表3参照)では、
tile_group_vrf_info_present_flagが1に等しいことは、シンタックス要素tile_group_true_frおよびtile_group_shutterangleがシンタックスに存在することを明示する。tile_group_vrf_info_present_flagが0に等しいことは、シンタックス要素tile_group_true_frおよびtile_group_shutterangleがシンタックスに存在しないことを明示する。tile_group_vrf_info_present_flagが存在しない場合、0であることを暗示する。
tile_group_true_frは、このビットストリームで伝送されるビデオデータの実際のフレームレートを示す。tile_group_shutterangleは、このビットストリームで伝送されるビデオデータの実際のフレームレートに対応するシャッタ角度を示す。
tile_group_skip_flagが1に等しいことは、現在のタイルグループが別のタイルグループからコピーされることを明示する。tile_group_skip_flagが0に等しいことは、現在のタイルグループが別のタイルグループからコピーされないことを明示する。
tile_group_copy_pic_order_cnt_lsbは、tile_group_skip_flagが1に設定されているときに現在のピクチャがコピーする、以前に復号されたピクチャのピクチャオーダーカウントモジュロMaxPicOrderCntLsbを明示する。
【表2】
【表3-1】
【表3-2】
【0031】
第2の実施形態-固定フレームレートコンテナ
第2の実施形態は、固定フレームレートおよびシャッタ角度を有するオリジナルコンテンツが、図2に例示されているような、代替フレームレートおよび可変シミュレートされたシャッタ角度で、デコーダによってレンダリングされ得るユースケースを可能にする。例えば、オリジナルコンテンツが、120fpsのフレームレートおよび360度のシャッタ角度(シャッタが1/120秒開いていることを意味する)を有する場合、デコーダは、120fps以下の複数のフレームレートをレンダリングすることができる。例えば、表1に記載されるように、216度のシミュレートされたシャッタ角度で24fpsを復号するために、デコーダは3つの復号されたフレームを結合し、24fpsで表示することができる。表4は表1に拡大され、出力ターゲットフレームレートおよび所望のターゲットシャッタ角度でレンダリングするために、異なる数の符号化フレームを組み合わせる方法を示す。フレームの結合は、単純なピクセル平均によって、あるフレームからのピクセルが他のフレームのピクセルよりも多く重み付けされ、すべての重みの合計が1になる重み付けピクセル平均によって、または当技術分野で知られている他のフィルタ補間スキームによって実行され得る。表4において、関数Ce(a,b)は、符号化フレームa~bの組み合わせを示し、この組み合わせは、平均化、重み付け平均化、フィルタリングなどによって実行することができる。
【表4-1】
【表4-2】
【0032】
ターゲットシャッタ角度の値が360度未満の場合、デコーダは異なる組の復号フレームを結合できる。例えば、表1から、120fps、360度でのオリジナルストリームが与えられると、40fpsおよび240度のシャッタ角度でストリームを生成するために、デコーダは、3つの可能なフレームのうちの2つのフレームを結合する必要がある。したがって、1番目と2番目のフレーム、または2番目と3番目のフレームのいずれかを組み合わせることができる。どのフレームを結合するかの選択は、以下のように表現される「復号フェーズ」に関して説明することができる。
【数6】
ここで、decode_phase_idxは、[0,n_frames_max-1]のインデックス値を持つ一連のシーケンシャルフレーム内のオフセットインデックスを示し、ここで、n_framesは数式(2)によって与えられる。
【数7】
【0033】
一般に、decode_phase_idxは、[0,n_frames_max-n_frames]の範囲である。例えば、120fpsおよび360度のシャッタ角度におけるオリジナルシーケンスに対して、240度のシャッタ角度における40fpsのターゲットフレームレートに対して、n_frames_max=120/40=3である。数式(2)から、n_frames=2であるため、decode_phase_idxは[0,1]の範囲である。したがって、decode_phase_idx=0は、インデックス0と1のフレームを選択することを示し、decode_phase_idx=1は、インデックス1と2のフレームを選択することを示す。
【0034】
この実施形態では、コンテンツ作成者によって意図されたレンダリングされた可変フレームレートは、補足エンハンスメント情報(supplemental enhancement information)(SEI)メッセージのような、またはビデオユーザビリティ情報(video usability information)(VUI)のようなメタデータとしてシグナリングされてもよい。任意選択的に、レンダリングされたフレームレートは、受信機またはユーザによって制御され得る。コンテンツ作成者の好ましいフレームレートおよびシャッタ角度を指定するフレームレート変換SEIメッセージングの一例を表5に示す。SEIメッセージは、結合フレームが符号化信号領域(例えば、ガンマ、PQなど)または線形光領域で実行されるかどうかを示すこともできる。ポスト処理には、デコーダピクチャバッファ(DPB)に加えてフレームバッファが必要であることに留意されたい。SEIメッセージは、必要な追加フレームバッファの数、またはフレームを結合するためのいくつかの代替方法を示し得る。例えば、複雑さを低減するために、フレームは低減された空間解像度で再結合されてもよい。
【0035】
表4に示すように、フレームレートとシャッタ角度とのある組み合わせ(例えば、30fpsおよび360度、または24fpsおよび288または360度)では、デコーダは3つ以上の復号フレームを結合する必要があり、これはデコーダによって必要とされるバッファスペースの数を増加させる。デコーダ内の余分なバッファ空間の負担を軽減するために、いくつかの実施形態では、フレームレートおよびシャッタ角度の特定の組み合わせは、許容される復号パラメータのセットに対して(例えば、適切なコーディングプロファイルおよびレベルを設定することによって)限定されてもよい。
【0036】
再び、一例として、24fpsでの再生の場合を考えると、デコーダは、120fpsの出力フレームレートで表示されるべき同じフレームを5回表示することを決定することができる。これは、24fpsの出力フレームレートでフレームを1回示すことと全く同じである。一定の出力フレームレートを維持する利点は、ディスプレイが一定のクロック速度で動作できることであり、これにより、すべてのハードウェアがはるかに単純になる。ディスプレイがクロックスピードを動的に変化させることができる場合、同じフレームを5回(それぞれ1/120秒)繰り返す代わりに、フレームを1回(1/24秒)だけ表示する方が理にかなう。前者のアプローチは、わずかに高い画質、わずかにより良い光学的効率、またはわずかにより良い電力効率をもたらし得る。同様の考察は、他のフレームレートにも適用可能である。
【0037】
表5は、一実施形態によるフレームレート変換SEIメッセージングシンタックスの一例を示す。
【表5】
【0038】
framerate_conversion_cancel_flag=1は、SEIメッセージが出力順で以前のフレームレート変換SEIメッセージの永続性をキャンセルすることを示す。framerate_conversion_cancel_flag=0は、フレームレート変換情報が後に続くことを示す。
base_frame_rateは、所望のフレームレートを指定する。
base_shutter_angleは、所望のシャッタ角度を指定する。
decode_phase_idx_present_flag=1は、復号フェーズ情報が存在することを指定する。decode_phase_idx_present_flag=0は、復号フェーズ情報が存在しないことを指定する。
decode_phase_idxは、インデックス値0..(n_frames_max-1)を有する一連のシーケンシャルフレーム内のオフセットインデックスを示し、ここで、n_frames_max=120/base_frame_rateである。decode_phase_idxの値は、0..(n_frames_max-n_frames)の範囲でなければならず、ここで、n_frames=base_shutter_angle/(3*base_frame_rate)である。decode_phase_idxが存在しない場合、0と推測される。
conversion_domain_idc=0は、フレーム結合が線形領域で実行されることを指定する。conversion_domain_idc=1は、フレーム結合が非線形領域で実行されることを指定する。
num_frame_buffersは、追加のフレームバッファ数を指定する(DPBはカウントしない)。
framerate_conversion_persistence_flagは、カレントレイヤのフレームレート変換SEIメッセージの持続性を指定する。framerate_conversion_persistence_flag=0の場合、フレームレート変換SEIメッセージが現在の復号ピクチャにのみ適用されることを指定する。picAをカレントピクチャとする。framerate_conversion_persistence_flag=1は、以下の条件の1つ以上が真になるまで、カレントレイヤのフレームレート変換SEIメッセージが出力順に持続することを指定する。
-カレントレイヤの新しい符号化レイヤワイズビデオシーケンス(CLVS)が始まる。
-ビットストリームが終了する。
-カレントレイヤに適用可能なフレーマレート変換SEIメッセージを含むアクセスユニット内のカレントレイヤ内のピクチャpicBが出力され(PicOrderCnt(picB)はPicOrderCnt(picA)よりも大きい)、ここで、PicOrderCnt(picB)およびPicOrderCnt(picA)はそれぞれ、picBおよびpicAのPicOrderCntVal値であり、picBのピクチャ順序カウントのための復号プロセスの呼び出しの直後である。
【0039】
第3の実施形態-複数のシャッタ角度で符号化された入力
第3の実施形態は、ビットストリームからのサブフレームレートの抽出を可能にし、したがって、後方互換性をサポートする符号化方式である。HEVCでは、これは時間的スケーラビリティによって達成される。時間的レイヤのスケーラビリティは、復号フレームのtemporal_idシンタックス要素に異なる値を割り当てることによって有効になる。これにより、ビットストリームはtemporal_id値に基づいて単純に抽出できる。しかしながら、時間的スケーラビリティに対するHEVCスタイルのアプローチは、異なるシャッタ角度で出力フレームレートをレンダリングすることを可能にしない。例えば、120fpsのオリジナルから抽出された60fpsのベースフレームレートは、常に180度のシャッタ角度を有する。
【0040】
ATSC3.0では、360度のシャッタ角度を有する60fpsのフレームが2つの120fpsフレームの重み付け平均としてエミュレートされる他の方法が記載されている。エミュレートされた60fpsフレームには0のtemporal_id値が割り当てられ、temporal_id値1が割り当てられたオリジナルの120fpsフレームと交互に結合される。60fpsが必要な場合、デコーダはtemporal_idが0のフレームのみを復号する必要がある。120fpsが必要な場合、デコーダは、対応する各temporal_id=0フレーム(すなわち、エミュレートされた60fpsフレーム)のスケールされたバージョンから各temporal_id=1フレーム(すなわち、120fpsフレーム)を減算して、明示的に送信されなかった対応するオリジナルの120fpsフレームを回復し、それによって、オリジナルの120fpsフレームをすべて再構成することができる。
【0041】
本発明の実施形態では、後方互換性(BC)である方法で、複数のターゲットフレームレートおよびターゲットシャッタ角度をサポートする新しいアルゴリズムが記載される。オリジナルの120fpsコンテンツをいくつかのシャッタ角度での基本フレームレートで前処理することが提案される。次いで、デコーダにおいて、種々の他のシャッタ角度における他のフレームレートを簡単に導出することができる。ATSC3.0手法は提案された方式の特殊なケースと考えることができ、ここで、temporal_id=0を有するフレームは60fps@360シャッタ角度でフレームを搬送し、temporal_id=1を有するフレームは、60fps@180シャッタ角度でフレームを搬送する。
【0042】
第1の例として、図4に描かれているように、40fpsのベースレイヤフレームレートと、120、240、および360度のシャッタ角度とを有するシーケンスを符号化するために使用される、120fpsおよび360シャッタ角度での入力シーケンスを検討する。この方式では、エンコーダは、オリジナルの入力フレームのうちの3つまでを結合することによって新しいフレームを算出する。例えば、40fpsおよび240度での入力を表す符号化フレーム2(En-2)は入力フレーム1および2を結合することによって生成され、40fpsおよび360度での入力を表す符号化フレーム3(En-3)はフレームEn-2を入力フレーム3に結合することによって生成される。デコーダでは、入力シーケンスを再構成するために、復号フレーム2(Dec-2)はフレームEn-2からフレームEn-1を減算することによって生成され、復号フレーム3(Dec-3)はフレームEn-3からフレームEn-2を減算することによって生成される。3つの復号フレームは、120fpsの基本フレームレートおよび360度のシャッタ角度での出力を表す。追加のフレームレートおよびシャッタ角度は、表6に示されるように、復号フレームを使用して外挿することができる。表6において、関数Cs(a,b)は、入力フレームa~bの組み合わせを示し、この組み合わせは、平均化、重み付け平均化、フィルタリングなどによって実行することができる。
【表6-1】
【表6-2】
【0043】
このアプローチの利点は、表6に示すように、40fpsバージョンすべてを、さらなる処理なしに復号できることである。別の利点は、他のフレームレートを様々なシャッタ角度で導出することができることである。例えば、30fpsおよび360のシャッタ角度で復号するデコーダを考える。表4から、出力は、Ce(1,4)=Cs(1,4)、Cs(5,8)、Cs(9,12)などによって生成されるフレームのシーケンスに対応し、これらは表6に示される復号シーケンスにも一致するが、表6では、Cs(5,8)=e6-e4+e8である。一実施形態では、ルックアップテーブル(LUT)を使用して、指定された出力フレームレートおよびエミュレートされたシャッタ角度で出力シーケンスを生成するために、復号フレームをどのように組み合わせる必要があるかを定義することができる。
【0044】
別の例では、以下に示すように、72、144、216、288、および360度のシャッタ角度での24fpsベースレイヤの抽出を単純化するために、エンコーダ内で最大5つのフレームを結合させることが提案される。これは、レガシーテレビ上で、24fpsで最良に提示される映画コンテンツにとって望ましい。
【表7-1】
【表7-2】
【0045】
表7に示すように、復号フレームレートがベースラインフレームレート(24fps)と一致する場合、5つのフレーム(例えば、e1~e5)の各グループにおいて、デコーダは所望のシャッタ角度(例えば、144度のシャッタ角度に対してe2)で1つのフレームを単に選択することができる。異なるフレームレートおよび特定のシャッタ角度で復号するために、デコーダは、復号フレームを(例えば、加算または減算によって)どのように適切に結合するかを決定する必要がある。例えば、30fpsおよび180度のシャッタ角度で復号するために、以下のステップに従うことができる。
a)デコーダは、120fpsおよび360度で、後方互換性を何ら考慮することなく送信する仮想エンコーダを検討することができ、次いで、表1から、デコーダは、所望のフレームレートおよびシャッタ角度で出力シーケンスを生成するために、4フレームのうち2フレームを組み合わせる必要がある。例えば、表4に示されるように、シーケンスはCe(1,2)=Avg(s1,s2)、Ce(5,6)=Avg(s5,s6)などを含み、ここで、Avg(s1,s2)は、フレームs1およびs2の平均を示すことができる。
b)定義により、符号化フレームはe1=s1、e2=Avg(s1,s2)、e3=Avg(s1,s3)などと表現できることを前提として、ステップa)におけるフレームのシーケンスも次のように表現できることを容易に導き出すことができる。
-Ce(1,2)=Avg(s1,s2)=e2
-Ce(5,6)=Avg(s5,s6)=Avg(s1,s5)-Avg(s1,s4)+s6=e5-e4+e6
-etc.
以前と同様に、復号フレームの適切な結合を事前に算出し、LUTとして利用可能にすることができる。
【0046】
提案された方法の利点は、コンテンツ作成者とユーザの両方にオプションを提供すること、すなわち、ディレクトリ/編集上の選択およびユーザの選択を可能にすることである。例えば、エンコーダ内の前処理内容は、様々なシャッタ角度でベースフレームレートを作成することを可能にする。各シャッタ角度には[0,(n_frames-1)]の範囲のtemporal_id値を割り当てることができ、ここで、n_framesは基本フレームレートで割った120に等しい値を有する。(たとえば、ベースフレームレートが24fpsの場合、temporal_idは[0,4]の範囲にある。)圧縮効率を最適化するか、もしくは美的な理由によるか、選択できる。一部のユースケースでは、たとえば、上位ストリーミングの場合、異なる基本レイヤを持つ複数のビットストリームを符号化して保存し、ユーザに提供して選択することができる。
【0047】
開示される方法の第2の例では、複数の後方互換性フレームレートがサポートされ得る。理想的には、24fpsの基本レイヤを得るために24フレーム/秒で復号し、30fpsのシーケンスを得るために30フレーム/秒で、60fpsのシーケンスを得るために60フレーム/秒で復号し、等々が可能であることを望む。ターゲットシャッタ角度が指定されていない場合、ソースフレームレートおよびターゲットフレームレートに許容されるシャッタ角度のうち、180度にできるだけ近いデフォルトターゲットシャッタ角度が推奨される。例えば、表7に示す値では、120、60、40、30、および24でのfpsの好ましいターゲットシャッタ角度は、360度、180度、120度、180度、および216度である。
【0048】
上記の例から、コンテンツをどのように符号化するかの選択は、特定のベースレイヤフレームレートを復号する複雑さに影響を及ぼし得ることが認められる。本発明の一実施形態は、所望のベースレイヤフレームレートに基づいて符号化方式を適応的に選択することである。映画コンテンツの場合、これは、例えば、24fpsとすることができ、一方、スポーツの場合、60fpsとすることができる。
【0049】
本発明のBC実施形態のための例示的なシンタックスは、以下の表8および表9に示される。
SPS(表8)では、SPS_hfr_BC_enabled_flagおよびSPS_base_framerateの2つのシンタックス要素が追加される(SPS_hfr_BC_enabled_flagが1に設定されている場合)。
sps_hfr_BC_enabled_flag=1は、後方互換性のある高フレームレートが符号化ビデオシーケンス(CVS)で有効になることを指定する。sps_hfr_BC_enabled_flag=0は、後方互換性のある高フレームレートがCVSで有効になっていないことを指定する。
sps_base_framerateは、カレントCVSの基本フレームレートを指定する。
タイルグループヘッダでは、sps_hfr_BC_enabled_flagが1 に設定されている場合、シンタックスnumber_avg_framesがビットストリームで送信される。
number_avg_framesは、ベースフレームレートでカレントピクチャを生成するために結合される、最も高いフレームレート(例えば、120fps)でのフレーム数を指定する。
【表8】
【表9】
【0050】
第2の実施形態(固定フレームレート)の変形例
HEVC(H.265)符号化標準(参照文献[1])および開発中のVersatile Video Coding Standard(一般にVVCと呼ばれる。参照文献[2]を参照)では、ピクチャをフレームとして、または1つ以上のフィールドとして表示するかどうか、および復号ピクチャを繰り返すかどうか、を示すシンタックス要素pic_structを定義する。HEVCからの表D.2「pic_structの解釈」のコピーは、参照のために付録に提供される。
【0051】
発明者によって認識されるように、既存のpic_structシンタックス要素は、固定フレームレートコーディングコンテナを使用する場合に、コンテンツフレームレートの特定のサブセットのみをサポートできることに留意することが重要である。たとえば、60fpsの固定フレームレートコンテナを使用する場合、既存のpic_structシンタックスは、fixed_pic_rate_within_cvs_flag=1のとき、フレームダブリングを使用することで30fpsを、フレームダブリングとフレームトリプルを使用することで24fpsを、互いのフレームごとに交互にサポートできる。ただし、120fpsの固定フレームレートコンテナを使用する場合、カレントpic_structシンタックスは、24fpsまたは30fpsのフレームレートをサポートできない。この問題を軽減するために、2つの新しい方法が提案されている。一方はHEVCバージョンの拡張であり、他方はそうではない。
【0052】
方法1:後方互換性のないpic_struct
VVCは依然として開発中であり、したがって、最大の自由度でシンタックスを設計することができる。一実施形態では、pic_structにおいて、フレームダブリングおよびフレームトリプリングのためのオプションを除去し、pic_structの特定の値を使用して任意のフレーム繰り返しを示し、繰り返すフレームの数を指定する、新しいシンタックス要素num_frame_repetition_minus2を追加することが提案される。提案されたシンタックスの一例は以下の表に記載されており、ここで、表10はHEVCにおける表D.2.3に対する変更を示し、表11は、付録に示される表D.2の変更を示す。
【表10】
num_frame_repetition_minus2+2は、fixed_pic_rate_within_cvs_flag=1の場合、数式E-73で与えられるDpbOutputElementalInterval[n]に等しいフレーム更新インターバルで、フレームをnum_frame_repetition_minus2+2回連続してディスプレイに表示する必要があることを示す。
【表11】
【0053】
方法2:HEVCバージョンのpic_structの拡張バージョン
AVCおよびHEVCデコーダはすでに採用されているため、古いオプションを削除せずに、既存のpic_structシンタックスを単に拡張することが望ましい場合がある。実施形態では、新しいpic_struct=13、「フレーム繰り返し拡張」値、および新しいシンタックス要素num_frame_repetition_minus4が追加される。提案されたシンタックスの一例は、表12および13に記載されている。pic_struct値0~12では、提案されたシンタックスは表D.2のものと同じであるため(付録に示すように)、これらの値は簡略化のために省略されている。
【表12】
num_frame_repetition_minus4+4は、fixed_pic_rate_within_cvs_flag=1の場合、数式E-73で与えられるDpbOutputElementalInterval[n]に等しいフレーム更新インターバルで、フレームをnum_frame_repetition_minus4+4回連続してディスプレイに表示する必要があることを示す。
【表13】
【0054】
HEVCでは、パラメータFrame_field_info_present_flagがビデオユーザビリティ情報(VUI)中に存在するが、シンタックス要素pic_struct、source_scan_type、およびduplicate_flagはpic_timing()SEIメッセージ中にある。実施形態では、frame_field_info_present_flagと共に、すべての関連するシンタックス要素をVUIに移動することが提案される。提案されたシンタックスの一例を表14に示す。
【表14】
【0055】
シャッタ角度情報の代替シグナリング
可変フレームレートを扱う場合、所望のフレームレートと所望のシャッタ角度の両方を識別することが望ましい。従来のビデオ符号化規格では「ビデオユーザビリティ情報」(VUI)がアスペクト比、カラープライマリ、クロマサブサンプリングなどのビデオコンテンツの適切な表示のための必須情報を提供する。VUIは固定ピクレートが1に設定される場合、フレームレート情報を提供することもあるが、シャッタ角度情報のためのサポートはない。実施形態は異なる時間的レイヤに対して異なるシャッタ角度を使用することを可能にし、デコーダは、シャッタ角度情報を使用して、ディスプレイ上の最終的な外観を改善することができる。
【0056】
例えば、HEVCは、より高いフレームレートからより低いフレームレートに移行するために、本質的にフレームドロップ技法を使用する時間的サブレイヤをサポートする。これに関する主問題は、各フレームドロップで有効シャッタ角度が減少することである。たとえば、60fpsは1フレームおきにドロップすることで120fpsビデオから派生できる。30fpsは4フレームのうち3フレームをドロップすることで派生でき、24fpsは5フレームのうち4フレームをドロップすることで派生できる。120Hz用の完全な360度シャッタを想定すると、単純なフレームドロッピングでは、60fps、30fps、および24fpsのシャッタ角度はそれぞれ180、90、および72度になる[3]。180度未満のシャッタ角度は特に50Hz未満のフレームレートでは一般的に許容できないことが、経験によって示されている。シャッタ角度情報を提供することによって、例えば、ディスプレイが、各時間的レイヤに対してシャッタ角度を低減した120Hzビデオから映画効果を生成することが望ましい場合、スマート技術を適用して、最終的な外観を改善することができる。
【0057】
別の例では、同じシャッタ角度で異なる時間的レイヤ(例えば、120fpsビットストリーム内の60fpsサブビットストリーム)をサポートしたい場合がある。そして、主問題は、120fpsのビデオが120Hzで表示されるとき、偶数/奇数フレームは異なる有効シャッタ角度を有することである。ディスプレイが関連情報を有する場合、スマート技術を適用して最終的な外観を改善することができる。提案されたシンタックスの一例が表15に示されており、ここでは、HEVCにおけるE.2.1VUIパラメータシンタックステーブル(参照文献[1])は、上述のようにシャッタ角度情報をサポートするように修正される。なお、別の実施形態では、シャッタ角度シンタックスを絶対度で表現する代わりに、シャッタ速度に対するフレームレートの比率として表現することもできる(数式(1)参照)。
【表15】
vui_shutter_angle_info_present_flag=1は、vui_parameters()シンタックス構造にシャッタ角度情報が存在することを指定する。vui_shutter_angle_info_present_flag=0は、vui_parameters()シンタックス構造にシャッタ角度情報が存在しないことを指定する。
fixed_shutter_angle_within_cvs_flag=1は、シャッタ角度情報がCVS内のすべての時間的サブレイヤで同じであることを指定する。fixed_shutter_angle_within_cvs_flag=0は、シャッタ角度情報がCVS内のすべての時間的サブレイヤで同じではないことを指定する。
fixed_shutter_angleは、CVS内のシャッタ角度を度で指定する。fixed_shutter_angleの値は、0~360の範囲である。
sub_layer_shutter_angle[i]は、HighestTidがiに等しいとき、シャッタ角度を度で指定する。sub_layer_shutter_angle[i]の値は、0~360の範囲である。
【0058】
符号化ビデオシーケンス(CVS)内の段階的フレームレート更新
実験は、HDRディスプレイ上に表示されるHDRコンテンツに対して、100ニト(nits)表示における標準ダイナミックレンジ(SDR)再生と同じ動きジャダリングを知覚するために、コンテンツの明るさに基づいてフレームレートを増加させる必要があることを示す。ほとんどの標準(AVC、HEVC、VVCなど)では、ビデオフレームレートは、vui_time_scale、vui_num_units_in_tick、elemental_duration_in_tc_minus1[temporal_id_max]シンタックス要素を使用して、VUI(SPSに含まれる)で示すことができる。たとえば、以下の表16に示される(参照文献[1]のセクションE.2.1を参照)。
【表16】
参照文献[1]で論じているように、変数ClockTickは、以下のように導出され、クロックチックと呼ばれる。
ClockTick=vui_num_units_in_tick÷vui_time_scale
picture_duration=ClockTick*(elemental_duration_in_tc_minus1[i]+1)
frame_rate=1/pic_duration
【0059】
しかしながら、フレームレートは、例えば、HEVCにおいて、イントラランダムアクセスポイント(IRAP)フレームにおいてのみ、または新たなCVSの開始においてのみ、特定の時点においてのみ変更することができる。HDR再生では、フェードインやフェードアウトの場合、ピクチャの明るさがフレームごとに変わるため、ピクチャごとにフレームレート、またはピクチャの持続時間を変更する必要がある場合がある。フレームレートまたはピクチャ持続時間を任意の時点で(フレーム毎にでも)リフレッシュ可能にするために、一実施形態では、表17に示すように、「漸進的リフレッシュレート」のための新しいSEIメッセージが提案される。
【表17】
【0060】
新しいシンタックスnum_units_in_tickの定義は、vui_num_units_in_tickと同じであり、time_scaleの定義は、vui_time_scaleと同じである。
num_units_in_tickは、クロックチックカウンタの1つのインクリメント(クロックチックと呼ばれる)に対応する周波数time_scale Hzで動作するクロックの時間単位の数である。num_units_in_tickは0より大きいものとする。秒単位のクロックチックは、num_units_in_tickをtime_scaleで割った商に等しくなる。例えば、ビデオ信号のピクチャレートが25Hzである場合、time_scaleは27 000 000に等しく、num_units_in_tickは1 080 000に等しく、したがってクロックチックは0.04秒に等しくてもよい。
time_scaleは、1秒間に経過する時間単位の数である。例えば、27MHzクロックを使用して時間を測定する時間座標系は、27 000 000のtime_scaleを有する。time_scaleの値は0より大きいものとする。
gradual_refresh_rateSEIメッセージを使用するピクチャのピクチャ持続時間は、次のように定義される。
picture_duration=num_units_in_tick÷time_scale。
【0061】
SEIメッセージによるシャッタ角度情報のシグナリング
前述のように、表15は、シャッタ角度サポートを有するVUIパラメータシンタックスの例を提供する。一例として、限定するものではないが、表18は同一のシンタックス要素を列挙しているが、ここではシャッタ角度情報のためのSEIメッセージの一部として挙げられている。SEIメッセージングは一例としてのみ使用されており、シーケンスパラメータセット(SPS)、ピクチャパラメータセット(PPS)、スライスまたはタイルグループヘッダなどのような、高レベルシンタックスの他のレイヤで同様のメッセージングが構築されてもよいことに注意されたい。
【表18】
【0062】
シャッタ角度は、通常、0~360度で表される。例えば、180度のシャッタ角度は、露光持続時間がフレーム持続時間の1/2であることを示す。シャッタ角度は、shutter_angle=frame_rate*360*shutter_speedとして表すことができ、ここで、shutter_speedは露光持続時間であり、frame_rateはフレーム持続時間の逆数である。与えられた時間的サブレイヤTidに対するframe_rateは、num_units_in_tick、time_scale,elemental_duration_in_tc_minus1[Tid]で示すことができる。例えば、fixed_pic_rate_within_cvs_flag[Tid]=1の場合、
frame_rate=
time_scale/(num_units_in_tick*(elemental_duration_in_tc_minus1[Tid]+1))。
【0063】
いくつかの実施形態では、シャッタ角度の値(例えば、fixed_shutter_angle)は整数でなくてもよく、例えば、135.75度であってもよい。より高い精度を可能にするために、表21では、u(9)(符号なし9ビット)をu(16)または他の何らかの適切なビット深度(例えば、12ビット、14ビット、または16ビットを超える)で置き換えることができる。
【0064】
いくつかの実施形態において、シャッタ角度情報を「クロックチック」の観点で表現することが有益であり得る。VVCにおいて、変数ClockTickは、以下のように導出される。
【数8】
次に、フレーム持続時間と露光持続時間の両方を、クロックチックの倍数または分数として表すことができる。
【数9】
【数10】
ここで、fNおよびfMは浮動小数点値であり、fN≦fMである。
そして、
【数11】
ここで、NumeratorおよびDenominatorは、fN/fM比を近似する整数である。
【0065】
表19は、式(11)によって示されるSEIメッセージングの例を示す。この例では、シャッタ角度は、実世界のカメラのための0より大きくなければならない。
【表19】
前述のように、シャッタ角精度のためのu(16)(符号なし16ビット)の使用は、例示として示され、360/216=0.0055の精度に対応する。精度は、実際の用途に基づいて調整することができる。たとえば、u(8)を使用すると、精度は360/2=1.4063になる。
注記:シャッタ角度は0度より大きいが、360度以下で表される。例えば、180度のシャッタ角度は、露光持続時間がフレーム持続時間の1/2であることを示す。
fixed_shutter_angle_within_cvs_flag=1は、シャッタ角度値がCVS内のすべての時間的サブレイヤについて同じであることを指定する。fixed_shutter_angle_in_cvs_flag=0は、シャッタ角度値がCVS内のすべての時間的サブレイヤについて同じではないことを指定する。
fixed_shutter_angle_numer_minus1+1は、シャッタ角度値を導出するために使用される分子を指定する。fixed_shutter_angle_numer_minus1の値は、0から65535までの範囲内でなければならない。
fixed_shutter_angle_demom_minus1+1は、シャッタ角度値を導出するために使用される分母を指定する。fixed_shutter_angle_demom_minus1の値は、0から65535までの範囲でなければならない。
fixed_shutter_angle_numer_minus1の値は、fixed_shutter_angle_demom_minus1の値以下でなければならない。
可変シャッタ角度は、度で、次のように導出される。
shutterAngle=360*(fixed_shutter_angle_numer_minus1+1)÷(fixed_shutter_angle_demom_minus1+1))
sub_layer_shutter_angle_numer_minus1[i]+1は、HighestTidがiに等しいときに、シャッタ角度値を導出するために使用される分子を指定する。sub_layer_shutter_angle_numer_minus1[i]の値は、0から65535までの範囲内でなければならない(区間の両端を含む)。
sub_layer_shutter_angle_demom_minus1[i]+1は、HighestTidがiに等しいときに、シャッタ角度値を導出するために使用される分母を指定する。sub_layer_shutter_angle_demom_minus1[i]の値は、0から65535までの範囲内でなければならない(区間の両端を含む)。
sub_layer_shutter_angle_numer_minus1[i]の値は、sub_layer_shutter_angle_denom_minus1[i]の値以下でなければならない。
可変サブレイヤシャッタ角度[i]は、度で、以下のように導出される。
subLayerShutterAngle[i]=360*
(sub_layer_shutter_angle_numer_minus1[i]+1)÷(sub_layer_shutter_angle_demom_minus1[i]+1)
【0066】
別の実施形態では、フレーム持続時間(例えば、frame_duration)は何らかの他の手段によって指定されてもよい。例えば、DVB/ATSCにおいて、fixed_pic_rate_within_cvs_flag[Tid]=1のとき、
frame_rate=time_scale/(num_units_in_tick*(elemental_duration_in_tc_minus1[Tid]+1)),frame_duration=1/frame_rate。
【0067】
表19および後続の表のいくつかのシンタックスは、シャッタ角度が常にゼロよりも大きいと仮定するが、シャッタ角度=0はいかなるモーションブラーもなくコンテンツが表示されるべき創造的な意図をシグナリングするために使用され得る。これは、グラフィックス、アニメーション、CGIテクスチャ、マット画面などを動かすためのケースである。したがって、例えば、シグナリングシャッタ角度=0は、トランスコーダにおいて、(例えば、エッジを保存するトランスコーディングモードを選択するために)ならびにCTAインターフェースまたは3GPPインターフェースを介してシャッタ角度メタデータを受信するディスプレイにおいて、モード決定に有用であり得る。例えば、シャッタ角度=0を使用して、ノイズ除去、フレーム補間などの動き処理を実行すべきでないディスプレイに指示することができる。そのような実施形態では、シンタックス要素fixed_shutter_angle_nume_minus1およびsub_layer_shutter_angle_numer_minus1[i]が、シンタックス要素fixed_shutter_angle_numerおよびsub_layer_shutter_angle_nume[i]によって置き換えることができ、ここで、fixed_shutter_angle_numerは、シャッタ角度値を導出するのに使用される分子を指定する。fixed_shutter_angle_numerの値は、0から65535までの範囲でなければならない(区間の両端を含む)。
sub_layer_shutter_angle_numer[i]は、HighestTidがiに等しいときにシャッタ角度値を導出するために使用される分子を指定する。sub_layer_shutter_angle_numer[i]の値は、0~65535の範囲でなければならない(区間の両端を含む)。
【0068】
別の実施形態では、fixed_shutter_angle_denom_minus1およびsub_layer_shutter_angle_denom_minus1[i]はまた、シンタックス要素fixed_shutter_angle_denomおよびsub_layer_shutter_angle_denom[i]により置き換えられる。
【0069】
一実施形態では、表20に示すように、VVCでgeneral_hrd_parameters_present_flag=1に設定することによって、SPSで定義されたnum_units_In_tickおよびtime_scaleシンタックスを再利用することができる。このシナリオの下では、SEIメッセージは露光持続時間SEIメッセージとして名前を変更することができる。
【表20】
fixed_exposure_duration_within_cvs_flag=1は、有効露光持続時間値はCVSにおけるすべての時間的サブレイヤについて同じである、ということを指定する。
fixed_exposure_duration_numer_minus1+1は、露光持続時間値を導出するのに使用する分子を指定する。fixed_exposure_duration_numer_minus1の値は、0から65535までの範囲でなければならない(区間の両端を含む)。
fixed_exposure_duration_demom_minus1+1は、露光持続時間値を導出するために使用される分母を指定する。fixed_exposure_duration_demom_minus1は、0から65535までの範囲でなければならない(区間の両端を含む)。
fixed_exposure_during_numer_minus1の値は、fixed_exposure_duration_demom_minus1の値以下でなければならない。
変数fixedExposureDurationは、次のように導出される。
fixedExposureDuration=(fixed_exposure_duration_numer_minus1+1)÷(fixed_exposure_duration_demom_minus1+1)*ClockTicks。
sub_layer_exposure_duration_duration_numer_minus1[i]+1は、HighestTidがiに等しいときの露光持続時間値を導出するために使用される分子を指定する。sub_layer_exposure_duration_numer_minus1[i]の値は、0から65535までの範囲でなければならない(区間の両端を含む)。
sub_layer_exposure_duration_demom_minus1[i]+1は、HighestTidがiに等しいときの露光持続時間値を導出するために使用される分母を指定する。sub_layer_exposure_duration_demom_minus1[i]の値は、0から65535までの範囲でなければならない(区間の両端を含む)。
sub_layer_exposure_duration_numer_minus1[i]の値は、sub_layer_exposure_duration_demom_minus1[i]の値以下でなければならない。
iに等しいHigestTidについての変数subLayerExposureDuration[i]は次のように導出される。
subLayerExposureDuration[i]=(sub_layer_exposure_duration_numer_minus1[i]+1)÷(sub_layer_exposure_duration_demom_minus1[i]+1)*ClockTick。
【0070】
別の実施形態では、表21に示すように、シンタックス要素expo_num_units_in_tickおよびexpo_time_scaleによってclockTickを明示的に定義することができる。ここでの利点は、前の実施形態と同様に、VVCにおいて、general_hrd_parameters_present_flagセットが1に設定されているかどうかに依存しないことである。
【数12】
【表21】
expo_num_units_in_tickは、クロックチックカウンタの1つのインクリメント(クロックチックと呼ばれる)に対応する周波数タイムスケールHzで作動するクロックの時間単位の数である。expo_num_units_in_tickは0より大きくなければならない。変数clockTicによって定義されるクロックチックは、秒単位で、expo_num_units_in_tickをexpo_time_scaleで割った商に等しい。
expo_time_scaleは、1秒間に経過する時間単位の数である。
clockTick=expo_num_units_in_tick÷expo_time_scaleである。
注記:2つのシンタックス要素(expo_num_units_in_tickおよびexpo_time_scale)は、露光時間を測定するために定義される。
num_units_in_tickおよびtime_scaleが存在する場合、clockTickはClockTick以下でなければならない。
fixed_exposure_duration_within_cvs_flag=1は、有効露光持続時間値がCVS内のすべての時間的副レイヤに対して同じであることを指定する。fixed_exposure_duration_in_CVS_flag=0は、CVS内のすべての時間的サブレイヤについて有効露光持続時間値が同じでないことを指定する。
fixed_exposure_duration_within_cvs_flag=1の場合、変数fixedExposureDurationはclockTickに設定される。
sub_layer_exposure_duration_numer_minus1[i]+1は、HighestTidがiに等しいときの露光持続時間値を導出するために使用される分子を指定する。sub_layer_exposure_duration_numer_minus1[i]の値は、0から65535までの範囲でなければならない(区間の両端を含む)。
sub_layer_exposure_duration_demom_minus1[i]+1は、HighestTidがiに等しいときの露光持続時間値を導出するために使用される分母を指定する。sub_layer_exposure_duration_demom_minus1[i]の値は、0以上65535までの範囲でなければならない(区間の両端を含む)。
sub_layer_exposure_duration_numer_minus1[i]の値は、sub_layer_exposure_duration_demom_minus1[i]の値以下でなければならない。
iに等しいHigestTidについての変数subLayerExposureDuration[i]は、以下のように導出される。
subLayerExposureDuration[i]=(sub_layer_exposure_duration_numer_minus1[i]+1)÷(sub_layer_exposure_duration_denom_minus1[i]+1)*clockTick。
【0071】
前述したように、シンタックスパラメータ、sub_layer_exposure_duration_numer_minus1[i]およびsub_layer_exposure_duration_denom_minus1[i]はまた、sub_layer_exposure_duration_numer[i]およびsub_layer_exposure_duration_denom[i]によって置き換えられる。
【0072】
別の実施形態では、表22に示すように、シンタックス要素sii_num_units_in_shutter_intervalおよびsii_time_scaleによってパラメータShutterInterval(すなわち、露光持続時間)を定義することができ、ここで、
【数13】
【表22】
シャッタインターバル情報SEIメッセージセマンティクス
シャッタインターバル情報SEIメッセージは、符号化および表示の前の関連するビデオコンテンツ、例えばカメラキャプチャコンテンツに対するシャッタインターバル、画像センサがピクチャを生成するために露光された時間の量を示す。
sii_num_units_in_shutter_intervalは、シャッタクロックチックカウンタの1つのインクリメントに対応する周波数sii_time_scale Hzで動作するクロックの時間単位の数を指定する。変数ShutterIntervalによって定義されるシャッタインターバルは、秒単位で、sii_num_units_in_shutter_intervalをsii_time_scaleで割った商に等しい。例えば、ShutterIntervalが0.04秒に等しいとき、sii_time_scaleは、27 000 000に等しく、sii_num_units_in_shutter_intervalは、1 080 000に等しくてもよい。
sii_time_scaleは、1秒間に経過する時間単位の数を指定する。たとえば、27MHzクロックを使用して時間を計測する時間座標系では、sii_time_scaleは27 000 000になる。
sii_time_scaleの値が0より大きい場合、ShutterIntervalの値は下記によって指定される。
ShutterInterval=sii_num_units_in_shutter_interval÷sii_time_scale。それ以外の場合(sii_time_scaleの値が0に等しい)、ShutterIntervalは未知または指定されていないとして解釈されなければならない。
注記1:0に等しいShutterIntervalの値は、関連するビデオコンテンツがスクリーンキャプチャコンテンツ、コンピュータ生成コンテンツ、または他の非カメラキャプチャコンテンツを含むことを指定する。
注記2:符号化ピクチャレートの逆数の値よりも大きいShutterIntervalの値、符号化ピクチャインターバルは、符号化ピクチャレートが関連するビデオコンテンツが作成されたピクチャレートよりも大きいことを示してもよく、例えば、符号化ピクチャレートが120Hzであり、符号化および表示前の関連するビデオコンテンツのピクチャレートが60Hzである場合である。与えられた時間的サブレイヤTidのための符号化インターバルは、ClockTickおよびelemental_duration_in_tc_minus1[Tid]によって示されることがある。例えば、fixed_pic_rate_within_cvs_flag[Tid]=1のとき、変数PictureInterval[Tid]によって定義される所与の時間的サブレイヤTidのためのピクチャインターバルは、下記によって指定されることがある。
PictureInterval[Tid]=ClockTick*(elemental_duration_in_tc_minus1[Tid]+1)。
fixed_shutter_interval_into_cvs_flag=1は、ShutterIntervalの値がCVS内のすべての時間的サブレイヤについて同じであることを指定する。fixed_shutter_interval_within_cvs_flag=0は、ShutterIntervalの値がCVS内のすべての時間的サブレイヤについて同じでないことを指定する。
sub_layer_shutter_interval_numer[i]は、HighestTidがiに等しい場合、変数subLayerShutterInterval[i]で定義される、サブレイヤシャッタインターバルを導出するために使用される分子を秒単位で指定する。
sub_layer_shutter_interval_denom[i]は、HighestTidがiに等しい場合に、変数subLayerShutterInterval[i]によって定義される、サブレイヤシャッタインターバルを導出するために使用される分母を秒単位で指定する。
iに等しいHighestTidについてのsubLayerShutterInterval[i]の値は、以下のように導出される。fixed_shutter_interval_within_cvs_flagの値が0に等しく、sub_layer_shutter_interval_denom[i]の値が0より大きい場合、
subLayerShutterInterval[i]=ShutterInterval*sub_layer_shutter_interval_numer[i]÷sub_layer_shutter_interval_denom[i]である。
そうでない場合(sub_layer_shutter_interval_denom[i]の値が0に等しい)、subLayerShutterInterval[i]は未知または指定されていないとして解釈されるべきである。fixed_shutter_interval_within_cvs_flagの値が0に等しくない場合、subLayerShutterInterval[i]=ShutterIntervalである。
【0073】
代替的な実施形態では、サブレイヤシャッタインターバルをシグナリングするための分子および分母を使用する代わりに、単一値を使用する。このようなシンタックスの例を表23に示す。
【表23】
シャッタインターバル情報SEIメッセージセマンティクス
シャッタインターバル情報SEIメッセージは、符号化および表示の前の関連するビデオコンテンツについてのシャッタインターバル、例えば、カメラキャプチャコンテンツに対して、画像センサがピクチャを生成するために露光された時間の量を示す。
sii_num_units_in_shutterは、シャッタクロックチックカウンタの1つのインクリメントに対応する周波数sii_time_scale Hzで動作するクロックの時間単位の数を指定する。変数ShutterIntervalによって定義されるシャッタインターバルは、秒単位で、sii_num_units_in_shutter_intervalをsii_time_scaleで割った商に等しい。例えば、ShutterIntervalが0.04秒に等しいとき、sii_time_scaleは27 000 000に等しく、sii_num_units_in_shutter_intervalは1 080 000に等しくてもよい。
sii_time_scaleは、1秒間に経過する時間単位の数を指定する。たとえば、27MHzクロックを使用して時間を計測する時間座標系では、sii_time_scaleは27 000 000になる。
sii_time_scaleの値が0より大きい場合、ShutterIntervalの値は下記により指定される。
ShutterInterval=sii_num_units_in_shutter_interval÷sii_time_scale。
それ以外の場合(sii_time_scaleの値が0に等しい)、ShutterIntervalは未知または指定されていないとして解釈されるべきである。
注記1:0に等しいShutterIntervalの値は、関連するビデオコンテンツがスクリーンキャプチャコンテンツ、コンピュータ生成コンテンツ、または他の非カメラキャプチャコンテンツを含むことを示し得る。
注記2:符号化ピクチャレートの逆数の値よりも大きいShutterIntervalの値、符号化ピクチャインターバルは、符号化ピクチャレートが関連するビデオコンテンツが生成されたピクチャレートよりも大きいことを示してもよく、例えば、符号化ピクチャレートが120Hzであり、符号化および表示前の関連するビデオコンテンツのピクチャレートが60Hzである場合である。所与の時間的副レイヤTidについての符号化ピクチャインターバルは、ClockTickおよびelemental_duration_in_tc_minus1[Tid]によって示されることがある。例えば、fixed_pic_rate_within_cvs_flag[Tid]=1のとき、変数PictureInterval[Tid]によって定義される所定の時間的サブレイヤTidのためのピクチャインターバルは、下記によって指定される。
PictureInterval[Tid]=ClockTick*(elemental_duration_in_tc_minus1[Tid]+1)
fixed_shutter_interval_into_cvs_flag=1は、ShutterIntervalの値がCVS内のすべての時間的サブレイヤについて同じであることを指定する。fixed_shutter_interval_within_cvs_flag=0は、ShutterIntervalの値がCVS内のすべての時間的サブレイヤについて同じでないことを指定する。
sub_layer_num_units_in_shutter_interval[i]は、シャッタクロックチックカウンタの1つのインクリメントに対応する周波数sii_time_scale Hzで動作するクロックの時間単位の数を指定する。変数subLayerShutterInterval[i]によって定義されるサブレイヤシャッタインターバルは、秒単位で、HighestTidがiに等しいとき、sub_layer_num_units_in_shutter_interval[i]をsii_time_scaleで割った商に等しい。
fixed_shutter_interval_within_cvs_flagの値が0に等しく、sii_time_scaleの値が0より大きい場合、subLayerShutterInterval[i]の値は、以下によって指定される。
subLayerShutterInterval[i]=sub_layer_num_units_in_shutter_interval[i]÷sii_time_scale
それ以外の場合(sii_time_scaleの値が0に等しい)、subLayerShutterInterval[i]は未知または指定されていないとして解釈されるべきである。fixed_shutter_interval_within_cvs_flagの値が0に等しくない場合、subLayerShutterInterval[i]=ShutterIntervalである。
【0074】
表24は、シャッタ角度または露光持続時間に関連するSEIメッセージングを提供するための、表18~23で議論される6つのアプローチの概要を提供する。
【表24】
【0075】
可変フレームレートシグナリング
2019年8月06日に出願された米国仮出願第62/883,195号に記載されているように、多くの出願において、デコーダが可変フレームレートで再生をサポートすることが望まれている。フレームレート適応は典型的には、例えば、参照文献[2]の付属書Cに記載されているように、仮想参照デコーダ(HRD)における動作の一部である。一実施形態では、90kHzクロックの関数として、ピクチャプレゼンテーション時間(PPT)を定義するシンタックス要素をSEIメッセージングまたは他の手段を介してシグナリングすることが提案される。これは、HRDで指定された公称デコーダピクチャバッファ(DPB)出力時間の一種の繰り返しであるが、現在は、MPEG-2システムで指定された90kHzClockTicks精度を使用している。このSEIメッセージの利点は、a)HRDがイネーブルされない場合、各フレームのタイミングを示すためにPPT SEIメッセージを依然として使用することができること、b)ビットストリームタイミングおよびシステムタイミングの変換を容易にすることができることである。
【0076】
表25は、MPEG-2トランスポート(H.222)(参照[4])で使用されているプレゼンテーションタイムスタンプ(PTS)変数のシンタックスに一致する、提案されたPPTタイミングメッセージのシンタックスの例を説明する。
【表25】
PPT (ピクチャプレゼンテーションタイム)
プレゼンテーションタイムは、以下のように復号時間に関連する。PPTは、3つの別個のフィールドで符号化された33ビット数である。これは、基本ストリームnのプレゼンテーションユニットkのシステムターゲットデコーダにおけるプレゼンテーションの時間tp(k)を示す。PPTの値は、システムクロック周波数を300で割った単位(90kHzが生成)で指定される。ピクチャプレゼンテーションタイムは、以下の数式に従ってPPTから導出される。
PPT(k)=((system_clock_frequency x tp(k))/300)%233
ここで、tp(k)はプレゼンテーションユニットP(k)のプレゼンテーションタイムである。
【0077】
参照文献
本明細書に列挙された参照文献の各々は、その全体が参照により組み込まれる。
[1]高効率ビデオコーディング(HEVC),H.265,シリーズH、動画の符号化、ITU、(02/2018)
[2]B.Bross,J.Chen,and S.Liu,「多様なビデオ符号化(VVC)(ドラフト5)」JVET アウトプットドキュメント、JVET-N1001,v5,(2019年5月14日にアップされた)
[3]C.Carbonara,J.DeFilippis,M.Korpi,「高フレームレートキャプチャおよび生成」SMPTE、2015年技術コンファレンスおよびエキシビション、2015年10月26-29日
[4]オーディオビジュアルサービスのインフラストラクチャ-伝送多重化および同期、H.222.0,シリーズH、動画および関連するオーディオ情報の汎用コーディング:Systems,ITU,08/2018
【0078】
コンピュータシステム実装例
本発明の実施形態は、コンピュータシステム、電子回路およびコンポーネントで構成されたシステム、マイクロコントローラなどの集積回路(IC)デバイス、フィールドプログラマブルゲートアレイ(FPGA)、または別の構成可能またはプログラマブル論理デバイス(PLD)、離散時間またはデジタル信号プロセッサ(DSP)、特定用途向けIC(ASIC)、および/またはそのようなシステム、デバイス、またはコンポーネントのうちの1つ以上を含む装置で実装され得る。コンピュータおよび/またはICは、本明細書で説明されるようなフレームレートスケーラビリティに関する命令を実行、制御、または実行することができる。コンピュータおよび/またはICは、本明細書に記載するフレームレートスケーラビリティに関連する様々なパラメータまたは値のいずれかを計算してもよい。画像およびビデオの実施形態は、ハードウェア、ソフトウェア、ファームウェア、およびそれらの様々な組合せで実施することができる。
【0079】
本発明のある特定の実施形態は、プロセッサに本発明の方法を実行させるソフトウェア命令を実行するコンピュータプロセッサを含む。例えば、ディスプレイ内の1つ以上のプロセッサ、エンコーダ、セットトップボックス、トランスコーダなどは、プロセッサにアクセス可能なプログラムメモリ内でソフトウェア命令を実行することによって、上述のフレームレートスケーラビリティに関連する方法を実装することができる。本発明の実施形態はまた、プログラム製品の形態で提供されてもよい。プログラム製品は、データプロセッサによって実行されると、データプロセッサに本発明の方法を実行させる命令を含む1組のコンピュータ可読信号を搬送する任意の非一時的かつ有形の媒体を含むことができる。本発明によるプログラム製品は、多種多様な非一時的かつ有形の形態のいずれであってもよい。プログラム製品は、例えば、フロッピーディスケット、ハードディスクドライブを含む磁気データ記憶媒体、CD ROM、DVDを含む光データ記憶媒体、ROM、フラッシュRAMなどを含む電子データ記憶媒体などの物理媒体を含むことができる。プログラム製品上のコンピュータ可読信号は、任意選択で、圧縮または暗号化することができる。
構成要素(例えば、ソフトウェアモジュール、プロセッサ、アセンブリ、デバイス、回路など)が上記で言及されている場合、別段の指示がない限り、その構成要素(「手段」への言及を含む)への言及は、本発明の例示的な実施形態において機能を実行する開示された構造と構造的に同等でない構成要素を含む、説明された構成要素(例えば、機能的に同等)の機能を実行する任意の構成要素の同等物を含むものとして解釈されるべきである。
【0080】
等価物、拡張物、代替物およびその他
したがって、フレームレートスケーラビリティに関連する例示的な実施形態が説明される。前述の明細書では、本発明の実施形態が実施ごとに変化し得る多数の特定の詳細を参照して説明されてきた。したがって、本発明が何であり、出願人によって本発明であることが意図されているものの唯一の排他的な指標は、後続の訂正を含む、そのような特許請求の範囲が発行される特定の形態で、本出願から発行される請求項のセットである。当該請求項に含まれる用語につき本明細書に明示的に記載される定義は、請求項で使用される用語の意味に優先する。したがって、請求項に明示的に記載されていない限定、要素、特性、特徴、利点または属性は、当該請求項の範囲をいかなる方法でも制限すべきではない。したがって、本明細書および図面は、制限的な意味ではなく例示的な意味に考えられるべきである。
【0081】
付録
この付録は、表D.2のコピーと、H.265仕様(参照文献[1])からの関連するpic_struct関連情報を提供する。
【表D.2-1】
【表D.2-2】
pic_structシンタックス要素のセマンティック
pic_structは、ピクチャをフレームとして表示するか、または1つ以上のフィールドとして表示するかを示し、また、fixed_pic_rate_within_cvs_flag=1のときのフレームの表示については、式E-73で与えられるDpbOutputElementalInterval[n]に等しい固定フレーム更新インターバルを使用するディスプレイのフレームダブリングまたはトリプリング繰り返し期間を示すことができる。pic_structの解釈は表D.2で規定されている。表D.2に列挙されていないpic_structの値は、ITU-T|ISO/IECによる将来の使用のために予約され、この仕様のこのバージョンに準拠するビットストリームには存在しない。デコーダはpic_structの予約値を無視する。
存在する場合、pic_structの値が以下の条件のうちの正確に1つが真であるように制約されることが、ビットストリーム適合性の要件である。
-pic_structの値は、CVS内のすべてのピクチャについて0、7、または8に等しくなる。
-pic_structの値は、CVS内のすべてのピクチャについて1、2、9、10、11、または12に等しくなる。
-pic_structの値は、CVS内のすべてのピクチャに対して3、4、5、または6に等しくなる。
fixed_pic_rate_within_cvs_flag=1のとき、フレームダブリングは7に等しいpic_structによって示され、それは、数式E-73によって与えられるように、DpbOutputElementalInterval[n]に等しいフレームリフレッシュインターバルでディスプレイ上に2回連続して表示されるべきであることを示し、そして、フレームトリプリングは8に等しいpic_structによって示され、それは、数式E-73によって与えられるように、DpbOutputElementalInterval[n]に等しいフレームリフレッシュインターバルでディスプレイ上に3回連続して表示されるべきであることを示す。
注記3:フレームダブリングを使用すると、表示を容易にすることができ、たとえば、50Hzプログレッシブスキャンディスプレイでは25Hzプログレッシブスキャンビデオ、60Hzプログレッシブスキャンディスプレイでは30Hzプログレッシブスキャンビデオを使用できる。フレームダブリングおよびフレームトリプリングを他の各フレーム上で交互に組み合わせて使用することにより、60Hzプログレッシブスキャンディスプレイ上の24Hzプログレッシブスキャンビデオの表示を容易にすることができる。
4:2:0、4:2:2、および4:4:4のクロマフォーマットに対するトップフィールドおよびボトムフィールドにおけるサンプルの公称垂直サンプリング位置および公称水平サンプリング位置を、それぞれ図D.1、図D.2、および図D.3に示す。
フィールドのアソシエーションインジケータ(pic_structが9から12に等しい)は、相補パリティのフィールドをフレームとして関連付けるためのヒントを提供する。フィールドのパリティはトップまたはボトムとすることができ、一方のフィールドのパリティがトップであり、他方のフィールドのパリティがボトムである場合、2つのフィールドのパリティは相補的と見なされる。
frame_field_info_present_flag=1の場合、表D.2の3番目の列で指定された制約が適用されることは、ビットストリーム適合性の要件である。
注4:frame_field_info_present_flag=0の場合、多くの場合、デフォルト値が他の手段によって推論または示されることができる。ピクチャの意図された表示タイプの他の指示がない場合、デコーダは、frame_field_info_present_flag=0のとき、pic_structの値を0と推論する必要がある。
図1
図2
図3
図4