以下、本開示を実施するための形態(以下実施の形態とする)について説明する。なお、説明は以下の順序で行う。
1.第1の実施の形態(部分画像の復号負荷定義)
2.第2の実施の形態(画像符号化装置)
3.第3の実施の形態(画像復号装置)
4.第4の実施の形態(多視点画像符号化・多視点画像復号装置)
5.第5の実施の形態(コンピュータ)
6.第6の実施の形態(応用例)
7.第7の実施の形態(スケーラブル符号化の応用例)
8.第8の実施の形態(セット・ユニット・モジュール・プロセッサ)
<1.第1の実施の形態>
<画像符号化の標準化の流れ>
近年、画像情報をデジタルとして取り扱い、その際、効率の高い情報の伝送、蓄積を目的とし、画像情報特有の冗長性を利用して、離散コサイン変換等の直交変換と動き補償により圧縮する符号化方式を採用して画像を圧縮符号する装置が普及しつつある。この符号化方式には、例えば、MPEG(Moving Picture Experts Group)などがある。
特に、MPEG2(ISO/IEC 13818-2)は、汎用画像符号化方式として定義されており、飛び越し走査画像及び順次走査画像の双方、並びに標準解像度画像及び高精細画像を網羅する標準である。例えば、MPEG2は、プロフェッショナル用途及びコンシューマ用途の広範なアプリケーションに現在広く用いられている。MPEG2圧縮方式を用いることにより、例えば720x480画素を持つ標準解像度の飛び越し走査画像であれば4乃至8Mbpsの符号量(ビットレート)を割り当てることができる。また、MPEG2圧縮方式を用いることにより、例えば1920x1088画素を持つ高解像度の飛び越し走査画像であれば18乃至22 Mbpsの符号量(ビットレート)を割り当てることができる。これにより、高い圧縮率と良好な画質の実現が可能である。
MPEG2は主として放送用に適合する高画質符号化を対象としていたが、MPEG1より低い符号量(ビットレート)、つまりより高い圧縮率の符号化方式には対応していなかった。携帯端末の普及により、今後そのような符号化方式のニーズは高まると思われ、これに対応してMPEG4符号化方式の標準化が行われた。画像符号化方式に関しては、1998年12月にISO/IEC 14496-2としてその規格が国際標準に承認された。
更に、近年、当初テレビ会議用の画像符号化を目的として、H.26L (ITU-T(International Telecommunication Union Telecommunication Standardization Sector) Q6/16 VCEG(Video Coding Expert Group))という標準の規格化が進められた。H.26LはMPEG2やMPEG4といった従来の符号化方式に比べ、その符号化、復号化により多くの演算量が要求されるものの、より高い符号化効率が実現されることが知られている。また、現在、MPEG4の活動の一環として、このH.26Lをベースに、H.26Lではサポートされない機能をも取り入れ、より高い符号化効率を実現する標準化がJoint Model of Enhanced-Compression Video Codingとして行われた。
標準化のスケジュールとしては、2003年3月にはH.264及びMPEG-4 Part10 (Advanced Video Coding、以下AVCと記す)という名の元に国際標準となった。
さらに、このH.264/AVCの拡張として、RGBや4:2:2、4:4:4といった、業務用に必要な符号化ツールや、MPEG-2で規定されていた8x8DCTや量子化マトリクスをも含んだFRExt (Fidelity Range Extension) の標準化が2005年2月に完了した。これにより、H.264/AVCを用いて、映画に含まれるフィルムノイズをも良好に表現することが可能な符号化方式となって、Blu-Ray Disc(商標)等の幅広いアプリケーションに用いられる運びとなった。
しかしながら、昨今、ハイビジョン画像の4倍の、4000x2000画素程度の画像を圧縮したい、あるいは、インターネットのような、限られた伝送容量の環境において、ハイビジョン画像を配信したいといった、更なる高圧縮率符号化に対するニーズが高まっている。このため、先述の、ITU-T傘下のVCEGにおいて、符号化効率の改善に関する検討が継続され行なわれている。
そこで、現在、AVCより更なる符号化効率の向上を目的として、ITU-Tと、ISO/IEC(International Organization for Standardization / International Electrotechnical Commission)の共同の標準化団体であるJCTVC(Joint Collaboration Team - Video Coding)により、HEVC(High Efficiency Video Coding)と呼ばれる符号化方式の標準化が進められている。HEVC規格については、2013年1月にドラフト版仕様であるCommittee draftが発行されている(例えば、非特許文献1参照)。
<符号化方式>
以下においては、HEVC(High Efficiency Video Coding)方式の画像符号化・復号に適用する場合を例に、本技術を説明する。
<コーディングユニット>
AVC(Advanced Video Coding)方式においては、マクロブロックとサブマクロブロックによる階層構造が規定されている。しかしながら、16x16画素のマクロブロックでは、次世代符号化方式の対象となるような、UHD(Ultra High Definition;4000画素x2000画素)といった大きな画枠に対して最適ではない。
これに対して、HEVC方式においては、図1に示されるように、コーディングユニット(CU(Coding Unit))が規定されている。
CUは、Coding Tree Block(CTB)とも呼ばれ、AVC方式におけるマクロブロックと同様の役割を果たす、ピクチャ単位の画像の部分領域である。後者は、16x16画素の大きさに固定されているのに対し、前者の大きさは固定されておらず、それぞれのシーケンスにおいて、画像圧縮情報中において指定されることになる。
例えば、出力となる符号化データに含まれるシーケンスパラメータセット(SPS(Sequence Parameter Set))において、CUの最大サイズ(LCU(Largest Coding Unit))と最小サイズ(SCU(Smallest Coding Unit))が規定される。
それぞれのLCU内においては、SCUのサイズを下回らない範囲で、split-flag=1とすることにより、より小さなサイズのCUに分割することができる。図1の例では、LCUの大きさが128であり、最大階層深度が5となる。2Nx2Nの大きさのCUは、split_flagの値が「1」である時、1つ下の階層となる、NxNの大きさのCUに分割される。
更に、CUは、イントラ若しくはインター予測の処理単位となる領域(ピクチャ単位の画像の部分領域)であるプレディクションユニット(Prediction Unit(PU))に分割され、また、直交変換の処理単位となる領域(ピクチャ単位の画像の部分領域)である、トランスフォームユニット(Transform Unit(TU))に分割される。現在、HEVC方式においては、4x4及び8x8に加え、16x16及び32x32直交変換を用いることが可能である。
以上のHEVC方式のように、CUを定義し、そのCUを単位として各種処理を行うような符号化方式の場合、AVC方式におけるマクロブロックはLCUに相当し、ブロック(サブブロック)はCUに相当すると考えることができる。また、AVC方式における動き補償ブロックは、PUに相当すると考えることができる。ただし、CUは、階層構造を有するので、その最上位階層のLCUのサイズは、例えば128x128画素のように、AVC方式のマクロブロックより大きく設定されることが一般的である。
よって、以下、LCUは、AVC方式におけるマクロブロックをも含むものとし、CUは、AVC方式におけるブロック(サブブロック)をも含むものとする。つまり、以下の説明に用いる「ブロック」は、ピクチャ内の任意の部分領域を示し、その大きさ、形状、および特性等は限定されない。つまり、「ブロック」には、例えば、TU、PU、SCU、CU、LCU、サブブロック、マクロブロック、またはスライス等任意の領域(処理単位)が含まれる。もちろん、これら以外の部分領域(処理単位)も含まれる。サイズや処理単位等を限定する必要がある場合は、適宜説明する。
また、本明細書において、CTU(Coding Tree Unit)は、LCU(最大数のCU)のCTB(Coding Tree Block)と、そのLCUベース(レベル)で処理するときのパラメータを含む単位であるとする。また、CTUを構成するCU(Coding Unit)は、CB(Coding Block)と、そのCUベース(レベル)で処理するときのパラメータを含む単位であるとする。
<モード選択>
ところで、AVCそしてHEVC符号化方式において、より高い符号化効率を達成するには、適切な予測モードの選択が重要である。
かかる選択方式の例として、JM (Joint Model) と呼ばれるH.264/MPEG-4 AVCの参照ソフトウエア (http://iphome.hhi.de/suehring/tml/index.htm において公開されている) に実装されている方法を挙げることが出来る。
JMにおいては、以下に述べる、High Complexity Modeと、Low Complexity Modeの2通りのモード判定方法を選択することが可能である。どちらも、それぞれの予測モードModeに関するコスト関数値を算出し、これを最小にする予測モードを当該ブロック乃至マクロブロックに対する最適モードとして選択する。
High Complexity Modeにおけるコスト関数は、以下の式(1)のように示される。
ここで、Ωは、当該ブロック乃至マクロブロックを符号化するための候補モードの全体集合Dは、当該予測モードで符号化した場合の、復号画像と入力画像の差分エネルギーである。λは、量子化パラメータの関数として与えられるLagrange未定乗数である。Rは、直交変換係数を含んだ、当該モードで符号化した場合の総符号量である。
つまり、High Complexity Modeでの符号化を行うには、上記パラメータD及びRを算出するため、全ての候補モードにより、一度、仮エンコード処理を行う必要があり、より高い演算量を要する。
Low Complexity Modeにおけるコスト関数は、以下の式(2)のように示される。
ここで、Dは、High Complexity Modeの場合と異なり、予測画像と入力画像の差分エネルギーとなる。QP2Quant(QP)は、量子化パラメータQPの関数として与えられ、HeaderBitは、直交変換係数を含まない、動きベクトルや、モードといった、Headerに属する情報に関する符号量である。
すなわち、Low Complexity Modeにおいては、それぞれの候補モードに関して、予測処理を行う必要があるが、復号画像までは必要ないため、符号化処理まで行う必要はない。このため、High Complexity Modeより低い演算量での実現が可能である。
<階層符号化>
ところで、これまでの、MPEG2、AVCといった画像符号化方式は、スケーラビリティ(scalability)機能を有していた。スケーラブル符号化(階層符号化)とは、画像を複数レイヤ化(階層化)し、レイヤ毎に符号化する方式である。図2は、階層画像符号化方式の一例を示す図である。
図2に示されるように、画像の階層化においては、スケーラビリティ機能を有する所定のパラメータを基準として1の画像が複数の階層(レイヤ)に分割される。つまり、階層化された画像(階層画像)は、その所定のパラメータの値が互いに異なる複数の階層(レイヤ)の画像を含む。この階層画像の複数のレイヤは、他のレイヤの画像を利用せずに自身のレイヤの画像のみを用いて符号化・復号を行うベースレイヤ(base layer)と、他のレイヤの画像を利用して符号化・復号を行うノンベースレイヤ(non-base layer)(エンハンスメントレイヤ(Enhancement layer)とも称する)とによりなる。ノンベースレイヤは、ベースレイヤの画像を利用するようにしても良いし、他のノンベースレイヤの画像を利用するようにしてもよい。
一般的に、ノンベースレイヤは、冗長性が低減されるように、自身の画像と、他のレイヤの画像との差分画像のデータ(差分データ)により構成される。例えば、1の画像をベースレイヤとノンベースレイヤ(エンハンスメントレイヤとも称する)に2階層化した場合、ベースレイヤのデータのみで元の画像よりも低品質な画像が得られ、ベースレイヤのデータとノンベースレイヤのデータを合成することで、元の画像(すなわち高品質な画像)が得られる。
このように画像を階層化することにより、状況に応じて多様な品質の画像を容易に得ることができる。例えば携帯電話のような、処理能力の低い端末に対しては、ベースレイヤのみの画像圧縮情報を伝送し、空間時間解像度の低い、或いは、画質の良くない動画像を再生し、テレビやパーソナルコンピュータのような、処理能力の高い端末に対しては、ベースレイヤに加えて、エンハンスメントレイヤの画像圧縮情報を伝送し、空間時間解像度の高い、或いは、画質の高い動画像を再生するといったように、トランスコード処理を行うことなく、端末やネットワークの能力に応じた画像圧縮情報を、サーバから送信することが可能となる。
<スケーラブルなパラメータ>
このような階層画像符号化・階層画像復号(スケーラブル符号化・スケーラブル復号)において、スケーラビリティ(scalability)機能を有するパラメータは、任意である。例えば、図3に示されるような空間解像度をそのパラメータとしてもよい(spatial scalability)。このスペーシャルスケーラビリティ(spatial scalability)の場合、レイヤ毎に画像の解像度が異なる。つまり、図3に示されるように、各ピクチャが、元の画像より空間的に低解像度のベースレイヤと、ベースレイヤの画像と合成することにより元の画像(元の空間解像度)が得られるエンハンスメントレイヤの2階層に階層化される。もちろん、この階層数は一例であり、任意の階層数に階層化することができる。
また、このようなスケーラビリティ性を持たせるパラメータとして、他には、例えば、図4に示されるような、時間解像度を適用しても良い(temporal scalability)。このテンポラルスケーラビリティ(temporal scalability)の場合、レイヤ毎にフレームレートが異なる。つまり、この場合、図4に示されるように、互いに異なるフレームレートのレイヤに階層化されており、低フレームレートのレイヤに、高フレームレートのレイヤを加えることで、より高フレームレートの動画像を得ることができ、全てのレイヤを加えることで、元の動画像(元のフレームレート)を得ることができる。この階層数は一例であり、任意の階層数に階層化することができる。
さらに、このようなスケーラビリティ性を持たせるパラメータとして、他には、例えば、図5に示されるような、信号雑音比(SNR(Signal to Noise ratio))を適用しても良い(SNR scalability)。このSNRスケーラビリティ(SNR scalability)の場合、レイヤ毎にSN比が異なる。つまり、この場合、図5に示されるように、各ピクチャが、元の画像よりSNRの低いベースレイヤと、ベースレイヤの画像と合成することにより元の画像(元のSNR)が得られるエンハンスメントレイヤの2階層に階層化される。すなわち、ベースレイヤ(base layer)画像圧縮情報においては、低PSNRの画像に関する情報が伝送されており、これに、エンハンスメントレイヤ(enhancement layer)画像圧縮情報を加えることで、高PSNR画像を再構築することが可能である。もちろん、この階層数は一例であり、任意の階層数に階層化することができる。
スケーラビリティ性を持たせるパラメータは、上述した例以外であっても、もちろんよい。例えば、ベースレイヤ(base layer)が8ビット(bit)画像よりなり、これにエンハンスメントレイヤ(enhancement layer)を加えることにより、10ビット(bit)画像が得られるビット深度スケーラビリティ(bit-depth scalability)がある。
また、ベースレイヤ(base layer)が4:2:0フォーマットのコンポーネント画像よりなり、これにエンハンスメントレイヤ(enhancement layer)を加えることにより、4:2:2フォーマットのコンポーネント画像が得られるクロマスケーラビリティ(chroma scalability)がある。
<タイル構造とレイヤの定義>
HEVCでは、タイル(Tile)構造を利用し、アプリケーションにより復号が必要となる領域のみを復号することが可能となっている。タイル領域が単独で復号可能であることを示すために、HEVC第2版以降(MV-HEVC, SHVC, Range Ext.等含む)で、Motion-constrained tile sets SEIによりサポートされる。
<アプリケーション例>
本技術を適用するアプリケーションの例について説明する。
サーバから端末に画像を配信するシステムにおいて、例えば、図6に示される例のように、1枚の画面を複数に分割し、表示領域を切り替えながら配信するアプリケーションがある。また、例えば、図7に示される例のように、画像のアスペクト比や解像度を選択するために、表示する(配信する)部分領域を選択するアプリケーションもある。
図6のアプリケーションの場合、画像の符号化・復号におけるタイル(Tile)を単位として全体画像から部分画像が切り出されて端末に配信される。この切り出す部分画像の全体画像における位置は、例えば端末のユーザ等が指定することができる。したがって、端末には、全体画像の中の所望の位置の部分画像を表示させることができる。例えば、スポーツ中継等のサービスにおいて、サーバ等により提供される、会場全体やフィールド全体等を撮像した広角の画像から、ユーザが所望の部分(例えば、お気に入りの選手、監督、ゴール前、ベンチ、客席等)に注目し、その部分画像を切り出してダウンロード(若しくはストリーミング)し、端末に表示させることができる。つまり、端末のユーザは、全体画像の中の所望の部分に注目することができる。
図7のアプリケーションの場合、タイルを選択するだけで、表示画像の解像度をHDにしたり、シネマサイズにしたりすることができる。
しかしながら、デコーダが、ストリームを復号できるかの判別をするための基準となっているレベル(Level)やバッファ(Buffer)容量関連の情報は、ストリーム全体としての値若しくはレイヤ(Layer)単位の値が定義されているのみであった。
そのため、全体画像の一部のみを復号するアプリケーションにおいても、復号可否の判断は、画面全体を復号する場合の負荷を想定して行われることになり、不要に高いレベル(Level)のデコーダが必要になってしまう恐れがあった。また、そのために配信できるアプリケーションが不要に制限されてしまう恐れもあった。
そこで、符号化される画像データの画像の、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報を設定し、その復号負荷定義情報を伝送するようにする。例えば、復号負荷定義情報を、画像データの符号化データとともに、符号化側から復号側に伝送するようにする。
このようにすることにより、デコーダは、その復号負荷定義情報にしたがって、部分領域を復号するのに必要な性能を把握し、復号可否判断を行うことができる。つまり、復号に必要な性能を、より正確に把握することができる。したがって、この画像データにより適切な性能のデコーダを選択することができる。これにより、画像データの復号負荷に対して不要に高いレベル(Level)のデコーダを適用する事態の発生を抑制することができる。また、そのために配信できるアプリケーションが不要に制限されてしまうことも抑制することができる。
<復号負荷定義情報の設定>
復号負荷定義情報の定義は、例えば、図8のように行う。例えば、図8のAの例のように、単一のレイヤの独立に復号することができる部分領域に対して、その部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報を設定するようにしてもよい。図8のAの例では、単一レイヤの画像の全体の復号に対してレベル4.0が設定され、その画像の中の単独デコード可能なタイル(部分領域)の復号に対してレベル2.0が設定されている。
また、例えば、図8のBの例のように、複数のレイヤからなる画像の各レイヤの独立に復号することができる部分領域に対して、復号負荷定義情報を設定するようにしてもよい。図8のBの例では、全レイヤの画像の復号に対してレベル5.0が設定され、ベースレイヤ(レイヤ0)の画像全体の復号に対してレベル4.0が設定されている。さらに、ベースレイヤ(レイヤ0)の画像の中の単独デコード可能なタイル(部分領域)の復号に対してレベル2.0が設定されている。さらに、エンハンスメントレイヤ(レイヤ1)の画像の中の、そのベースレイヤ(レイヤ0)の画像の中の単独デコード可能なタイルのみを参照するタイルの復号(つまり、参照されるベースレイヤ(レイヤ0)のタイル、および、それを参照するエンハンスメントレイヤ(レイヤ1)のタイルの復号)に対してレベル4.0が設定されている。
さらに、例えば、図8のCの例のように、独立に復号することができる部分領域のみを参照するレイヤの全体画像と、その参照される部分領域に対して、復号負荷定義情報を設定するようにしてもよい。つまり、単独デコード可能なタイル(部分領域)を参照する側は、部分領域でなく全体画像であってもよい。図8のCの例では、基本的に図8のBの例の場合と同様にレベルが設定される。ただし、図8のBの例では、エンハンスメントレイヤ(レイヤ1)の画像の中の、ベースレイヤ(レイヤ0)の画像の中の単独デコード可能なタイルのみを参照するタイルの復号に対してレベルが設定されていたが、図8のCの例では、その代わりに、そのベースレイヤ(レイヤ0)の画像の中の単独デコード可能なタイルのみを参照するエンハンスメントレイヤ(レイヤ1)の全体画像の復号(つまり、参照されるベースレイヤ(レイヤ0)のタイル、および、それを参照するエンハンスメントレイヤ(レイヤ1)の全体画像の復号)に対してレベル4.0が設定されている。
なお、この場合、エンハンスメントレイヤ(レイヤ1)の全体画像が参照する部分領域(タイル)(の位置)を識別するために、参照元となるエンハンスメントレイヤ(レイヤ1)の全体画像に、参照先となるベースレイヤ(レイヤ0)のタイルの位置情報を対応付ける(マッピングする)ようにしてもよい。図8のCの例では、エンハンスメントレイヤ(レイヤ1)の全体画像における左上隅の座標に、ベースレイヤ(レイヤ0)のタイルにおける同位置の座標がマッピングされている。
<レベルで規定されるパラメータ>
なお、レベルで規定されているパラメータには、画像の最大ピクセル(pixel)数(MaxLumaPs)、最大バッファ容量(MaxCPB Size)、1秒当たりの画像の最大ピクセル(pixel)数(MaxLumaSr)、最大ビットレート(MaxBR)等がある。
<復号負荷定義情報>
復号に必要な負荷の大きさの定義は、例えば、MCTS SEI(Motion constrained tile set Supplemental Enhancement Information)を拡張して行う。
例えば、図9のAに示されるシンタクスのように、MCTS SEIにおいて、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報として、その部分領域の復号処理の負荷の大きさを表すレベル(mcts_level_idc[i])を設定するようにしてもよい。ここで、「i」は、単数または複数のタイルにより構成される部分領域であるセット(タイルセットとも称する)を示す。つまり、図9のAの例では、復号に必要なレベル情報(mcts_level_idc)の値がこのセット毎に設定される。この場合、セマンティクスは、例えば図9のBのようにしてもよい。
MCTS SEIにおいて、独立に復号することができる部分領域は、矩形のセット毎に設定されている。例えば、図10のAの左上の斜線部分が独立に復号することができる部分領域であるとすると、その部分領域は、MCTS SEIにおいて、図10のBに示されるようにセット毎に設定されている。なお、図10のCに示される例のように、セットに含まれるタイルが他のセットとオーバーラップしてもよい。部分領域のピクセル数は、各セットのピクセル数から、例えば、図10のDの例のように算出することができる。
また、例えば、図11のAに示されるシンタクスのように、MCTS SEIにおいて、複数レイヤの独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報として、各レイヤの部分領域の復号処理の負荷の大きさを表すレベル(mcts_level_idc[i][j])を設定するようにしてもよい。ここで、「i」はセットを示し、「j」はレイヤを示す。つまり、図11のAの例では、復号に必要なレベル情報(mcts_level_idc)の値がセット毎、かつ、レイヤ毎に設定される。この場合、セマンティクスは、例えば図11のBのようにしてもよい。
さらに、例えば、図12のAに示されるシンタクスのように、MCTS SEIにおいて、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報として、その部分領域の大きさを示す情報(maxLumaPS_in_set[i])を設定するようにしてもよい。ここで、「i」はセットを示す。つまり、図12のAの例では、セット(部分領域)の大きさを示す情報(maxLumaPS_in_set)の値がセット毎に設定される。この場合、セマンティクスは、例えば図12のBのようにしてもよい。
また、例えば、図13のAに示されるシンタクスのように、MCTS SEIにおいて、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報として、その部分領域の、縦方向の長さを示す情報(mcts_height_in_luma_samples[i])と横方向の長さを示す情報(mcts_width_in_luma_samples[i])とを設定するようにしてもよい。ここで、「i」はセットを示す。つまり、図13のAの例では、セット(部分領域)の、縦方向の長さを示す情報(mcts_height_in_luma_samples)の値と横方向の長さを示す情報(mcts_width_in_luma_samples)の値とがセット毎に設定される。この場合、セマンティクスは、例えば図13のBのようにしてもよい。
さらに、例えば、図14に示されるシンタクスのように、MCTS SEIにおいて、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報として、その部分領域を復号する仮想参照デコーダのパラメータ(mcts_hrd_parameters())を設定するようにしてもよい。
その場合、例えば、図15のAに示されるシンタクスのように、仮想参照デコーダのパラメータ(mcts_hrd_parameters())として、仮想参照デコーダの最大入力ビットレート(mcts_bit_rate_value_minus1)とバッファ容量(mcts_cpb_size_value_minus1)を設定するようにしてもよい。この場合、セマンティクスは、例えば図15のBのようにしてもよい。
また、例えば、図16のAに示されるように、以上のようなMCTS SEIの拡張に加えて、シーケンスパラメータセット(SPS(Sequence Parameter Set))において、MCTS SEIに上述したような復号負荷定義情報が設定されているか否かを示す情報(mcts_present_flag)を設定するようにしてもよい。この場合、セマンティクスは、例えば図16のBのようにしてもよい。
さらに、例えば、図17のAに示されるように、シーケンスパラメータセット(SPS)において、その復号負荷定義情報が設定されているか否かを示す情報の代わりに、MCTS SEIに設定される復号負荷定義情報と同様の復号負荷定義情報を設定するようにしてもよい。この場合、セマンティクスは、例えば図17のBのようにしてもよい。
なお、シーケンスパラメータセット(SPS)に設定する情報は、シーケンスパラメータセット(SPS)の代わりに、ビデオパラメータセット(VPS(Video Parameter Set))に設定するようにしてもよい。
もちろん、復号負荷定義情報の設定の仕方は、任意であり、上述した例に限らない。また、上述した複数の方法を組み合わせても良い。さらに、上述した方法と、その他の方法とを組み合わせても良い。
以上のように独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報を設定することにより、その復号負荷定義情報に基づいて、復号に必要な性能をより正確に把握することができる。また、その復号負荷定義情報を復号側に伝送することにより、復号側においても、復号に必要な性能をより正確に把握することができる。
<DASHへの適応>
例えば図6のようなDASHのユースケースでは、一定数のタイル領域を動かしながら再生することができることが望ましい。しかしながら、再生し得る部分画像(タイルの組み合わせ)を全てタイルセット(tile_set)として登録し、それぞれについて復号負荷定義情報を設定するようにすると、そのタイルセットの数が多い場合、情報量が増大する可能性がある。
例えば、図18の例のように、2x2タイルの部分画像(タイルセット)を再生(表示)させる場合において、その部分画像の位置を移動させると(全体画像の中で表示させる部分を変更すると)、その移動の間の全て部分画像(タイルセット)が表示(再生)されることになる。このような部分画像の数は、図中右側の式に示されるように膨大なものとなる可能性がある。そのため、このような部分画像の全てについて、復号負荷定義情報を設定すると、情報量が現実的でない程増大する可能性がある。また、その際の各タイルセットについての復号負荷情報の冗長性は極めて高いものとなる可能性がある。つまり、不要に情報量が増大する可能性がある。
そこで、例えば、MCTS SEIを拡張し、復号負荷情報として、基準とする部分画像の大きさを示す情報と、その部分画像の復号処理の負荷の大きさを表すレベルを設定する。つまり、部分画像の大きさによって復号処理の負荷の大きさを推定することができるような情報をMCTS SEIに格納する。
そして、例えば、このような情報を参照することにより(復号する領域の大きさとその基準とする部分画像の大きさと比較することにより)、その領域の復号処理の負荷の大きさをより正しく把握することができる。
ここで、基準とする部分画像の大きさは、どのような情報によって示されるようにしても良いが、例えば、全体画像が均等に分割されたタイル(Tile)を単位として示すようにしてもよい。また、その基準とする大きさの数は任意であるが、復号処理の負荷の大きさをより正しく把握するためには複数である方が望ましい。また、復号処理の負荷の大きさを、どのような情報によって示されるようにしても良いが、例えば、レベル情報(level)により表すようにしてもよい。
ところで、既存のROIは、アプリケーションが任意に場所を指定できることが前提となっており、 逆に言うと、必ず、何かしらの領域(ROI)が定義されることが絶対となっている。
しかしながら、DASHのタイルストリーミング(Tiled Streaming)のようなアプリケーションの場合、ユーザが選択した領域を切り出して表示するというのがコンセプトになっている(解像度の違うストリームに切り替える のも含めて)。つまり、どの領域が選択されるかは、ユーザが任意に決定することができるので、全てのタイルが単独デコード可能なタイルであり、さらに、均等に分割されているという前提で、再生するデバイスの能力(Level)によって、選択するタイルの数が異なるというのが、最も、通常的なサービスの運用になることが想定される。
よって、既存のROIのためのアプリの前提と、DASHのTiled Streamingのためのアプリの前提は、方向性が少し異なる。
そこで、両方の前提を1つのSEIで満たしながらも、アプリケーションが復号する領域(タイル)単位のレベル(Level)が定義できるようにアプリケーションのモードというものを導入し、そのモードごとに、定義するべき情報を、変更できるように拡張してもよい。
例えば、アプリケーションごとに、必要となる定義する情報を変更できるように、モードという概念を定義する。例えば、DASHモードを設定する。そして、DASHモード == 均等割り+全タイル独立 と定義する。つまり、DASHモードにおいては、画面が均等タイル分割(uniform_spacing_flag=1@PPS)であるとする。また、個々のタイルが独立デコード可能であることがわかっているものとする。
そしてこのDASHモードの場合に、一度にデコードするタイル数と、それに対応するレベル情報を記述(定義)するようにする。例えば、図19の場合、一度にデコードするタイル数として、4、12、30の3つが設定され、その3つの場合のそれぞれについて、レベル情報(復号負荷情報)が設定される。
このようにすることにより、上述した両方のアプリケーションに対して、より適切に復号負荷情報を設定することができる。
その場合の、MCTS SEIの拡張例(シンタクスの例)を図20に示す。図20の例の場合、上から2行目においてアプリケーションのモード(mcts_mode)が設定される。そして、上から4行目のように、そのモードが従来のROIに対するアプリケーションのモード(mode for current ROI application)である場合(mcts_mode==0)、上述した各例と同様に、独立に復号可能な部分画像毎に復号負荷情報が設定される。例えば、上から13行目においては、復号に必要なレベル情報(mcts_level_idc[i])が設定される。
また、アプリケーションのモードがDASHモード(mode for DASH application)である場合(mcts_mode==1)、一度にデコードする領域のタイル数と、それに対応するレベル情報が設定される。例えば、上から17行目において、その領域の識別情報(mcts_id[i])が設定され、その次の行においては、その識別情報が示す領域に含まれるタイル数を示す情報(num_of_tiles_minus1[i])が設定され、さらに、その次の行においては、その領域を復号するのに必要なレベル情報(mcts_level_idc[i])が設定される。
ここで、「i」はセットを示す。つまり、図20の例では、復号に必要なレベル情報(mcts_level_idc)の値、識別情報(mcts_id)の値、および、その識別情報が示す領域に含まれるタイル数を示す情報(num_of_tiles_minus1)の値がこのセット毎に設定される。
以上のように復号負荷情報を設定することにより、その復号負荷情報に基づいて、復号する領域の大きさ(タイル数)に応じて、復号に必要な性能をより正確に把握することができる。また、その復号負荷定義情報を復号側に伝送することにより、復号側においても、復号する領域の大きさ(タイル数)に応じて、復号に必要な性能をより正確に把握することができる。
<復号負荷定義情報の設定の他の例1>
以上において、タイルセットは、矩形であるように説明した。この場合、例えば、MCTS(単独で復号可能なタイル群(部分領域))が「L」字型であるとすると、文字「L」の縦線部分を表す縦方向を長手方向とするタイルセットと、文字「L」の横線部分を表す横方向を長手方向とするタイルセットとの2つのセットを定義する必要がある。
また、以上において、復号負荷定義情報として、部分領域の復号処理の負荷の大きさを表すレベル(復号に必要なレベル)を示す情報(mcts_level_idc[i])の値がその矩形のセット毎に設定されるように説明した。つまり、この場合、「L」字型の部分領域について、復号に必要なレベルを示す情報(mcts_level_idc[i])を2つ設定しなければならない。もちろん、このようにすることにより、各セットの復号に必要なレベルが互いに異なる場合に対応することができるが、各セットの復号に必要なレベルが互いに同一である場合は冗長となり、符号化効率が低減する可能性がある。
そこで、セット毎ではなく、単独に復号可能な部分領域に対して1つのレベルを設定することができるようにしてもよい。単独に復号可能なセットは、単独に復号可能な部分領域でもある。つまり、単独に復号可能な複数の部分領域に共通のレベルを定義することができるようにしてもよい。その場合のシンタクスの例を図21のAに示す。また、その場合のセマンティクスの例を図21のBに示す。
図21のAの例では、上から3行目において、全てのタイルが単独で復号可能なセットを形成するか否かを示す情報(each_tile_one_tile_set_flag)が設定され、上から4行目において、SEIメッセージに定義されたmotion-constrained tile setsに、復号に必要なレベルを示す情報(mcts_level_idc)が含まれるか否かを示す情報(mcts_level_idc_present_flag)が設定される。
そして、上から5行目において、全てのタイルが独自に復号可能なセットを形成するわけではないと判定された場合(! each_tile_one_tile_set_flag)、上から7行目乃至16行目のループにおいて、各セットについての設定が行われるが、復号に必要なレベル(mcts_level_idc)の設定は、そのループの外の上から18行目において行われる。
つまり、図22の例のように、いずれも単独で復号可能な、「0」番目の識別情報(mcts_id[0])が割り当てられたセットと、「1」番目の識別情報(mcts_id[1])が割り当てられたセットとが互いに隣接し、各セットの復号に必要なレベルが互いに等しい場合、セット毎にレベル情報(mcts_level_idc[i])を設定するのではなく、両セット共通のレベル情報(mcts_level_idc)を設定することができる。
このようにすることにより、単独で復号可能な複数の部分領域(例えば複数のセットで表す必要がある部分領域)に対して、1つの(共通の)レベル情報のみを設定することができ、冗長性を低減し、符号化効率を向上させることができる。
なお、非特許文献1に記載のHEVCにおいては、レベルは全体画像(ピクチャ)単位で定義されることが想定されており、レベルでのパラメータの規定も、全体画像(ピクチャ)単位で行われる。そこで、上述したように部分領域単位でレベルを定義するにあたって、その部分領域用のレベルについてのパラメータの規定も行い、その規定を全体画像(ピクチャ)単位のレベルでの規定に割り当てる(パラメータのマッピングを行う)ようにしてもよい。
例えば、単独で復号可能な部分領域が四角形の場合、その部分領域についてレベルでのパラメータを規定し、全体画像(ピクチャ)単位のレベルでの規定を、その規定に置き換えるようにしてもよい。また、例えば、単独で復号可能な部分領域が「L」字型の場合、その「L」字型の部分領域を内包する四角形を設定し、その四角形の領域についてレベルでのパラメータを規定し、全体画像(ピクチャ)単位のレベルでの規定を、その規定に置き換えるようにしてもよい。
例えば、図22の場合、単独で復号可能な部分領域が、識別情報(mcts_id[0])のセットと識別情報(mcts_id[1])のセットとにより構成される場合、その両セットを含む四角形の領域を設定し、これをピクチャ(レベルでのパラメータの規定の単位)に割り当てる。つまりこの四角形の領域の横方向の大きさWをpic_width_in_luma_samplesとして推定し、この四角形の領域の縦方向の大きさHをpic_height_in_luma_samplesとして推定し、この四角形の領域の大きさWxHをPicSizeInSamplesYとして推定し、この四角形の領域についてレベルでのパラメータを規定するようにしてもよい。
このようにすることにより、四角形の領域について規定したパラメータの値をピクチャ単位で規定されるパラメータにマッピングすることができる。そして、このようなパラメータのマッピングを行うことにより、単独で復号可能な部分領域に対してより適切な規定を採用することができるようになる。
ところで、全てのタイルが単独で復号可能な場合、その部分領域の大きさに応じて、その部分領域の復号に必要なレベル(mcts_level_idc[i])を設定することができる。この場合、その部分領域の大きさを、その部分領域の縦方向のタイル数(行数)と横方向のタイル数(列数)とで表すようにしてもよい。ここで、「i」は、部分領域の大きさとレベルの対応関係の数を示す。
図21のAの例では、上から20行目乃至28行目のループにおいて、部分領域の大きさとレベルが対応づけられる。そのループ中において、部分領域の縦方向のタイル数を示す情報(num_mc_tile_columns_minus1[i])が設定され(上から24行目)、部分領域の横方向のタイル数を示す情報(num_mc_tile_rows_minus1[i])が設定される(上から25行目)。
例えば、図23の場合、識別情報(mcts_level_id[0])が設定される「0」番目の対応関係では、レベル(meta_level_idc[0])に対して、タイル数2x2の部分領域が対応づけられる。つまり、この対応関係において、部分領域の縦方向のタイル数を示す情報(num_mc_tile_columns_minus1[0])の値が「1」に設定され、部分領域の横方向のタイル数を示す情報(num_mc_tile_rows_minus1[0])が「1」に設定される。このような情報を設定することにより、レベル(meta_level_idc[0])に対応する部分領域のタイル数が4であることだけでなく、部分領域の形状(縦2タイルx横2タイルの矩形であること)も示される。
また、例えば、図23の場合、識別情報(mcts_level_id[1])が設定される「1」番目の対応関係では、レベル(meta_level_idc[1])に対して、タイル数4x4の部分領域が対応づけられる。つまり、この対応関係において、部分領域の縦方向のタイル数を示す情報(num_mc_tile_columns_minus1[1])の値が「3」に設定され、部分領域の横方向のタイル数を示す情報(num_mc_tile_rows_minus1[1])が「3」に設定される。このような情報を設定することにより、レベル(meta_level_idc[1])に対応する部分領域のタイル数が16であることだけでなく、部分領域の形状(縦4タイルx横4タイルの矩形であること)も示される。
このようにすることにより、部分領域とレベルとを対応付ける情報の利便性を向上させることができる。例えば、この部分画像を取得して表示する端末が、この情報に基づいて、部分領域が横長であるか否かを判断し、部分領域が横長の場合、上下に黒帯を入れて表示する等の表示画像のアスペクト比の調整をより容易に行うことができる。
<復号負荷定義情報の設定の他の例2>
全てのタイルが単独で復号可能な場合、ピクチャ内におけるタイル単位のレベルの最大値(max_level_idc)を設定するようにしてもよい。つまり、1タイルを1セットとし、各セットに対して設定されるレベルの、ピクチャ内における最大値を設定するようにしてもよい。その場合のシンタクスの例を図24のAに示す。また、その場合のセマンティクスの例を図24のBに示す。
図24のAの例では、上から21行目において、そのピクチャにおけるレベルの最大値(max_level_idc)が設定される。このレベルは、図26の例に示されるように、1タイルにより構成されるセットに対して設定されるレベルである。例えば、図26の場合、ピクチャ内の縦6セット(6タイル)x横10セット(10タイル)の合計60セット(60タイル)の各セットに対して設定されたレベルの最大値がmax_level_idcとして設定されている。
全体画像からいくつのタイルを切り出すかはアプリケーションが決定する。そのアプリケーションは、各レベルに対応するタイル数が全て定義されていなくても、このレベルの最大値(max_level_idc)に基づいて、切り出すことができる(復号等の処理を行うことができる)タイルの数を十分に正確に判断することができる。
つまり、各レベルに対応するタイル数が全て定義する代わりに、ピクチャにおける、1タイルで構成されるセット毎(すなわち、タイル毎)に設定されるレベルの最大値(max_level_idc)のみを設定するだけで、アプリケーションは、その設定に基づいて、復号等の処理を破綻させないように、切り出すタイルの数を制御することができる。
そして、このようにすることにより、各レベルに対応するタイル数が全て定義する場合よりも、全てのタイルのシンタクスを簡易化し、処理の負荷を低減させることができる。また、各レベルに対応するタイル数が全て定義する場合よりも、伝送する情報量を低減させることができ、符号化効率を向上させることができる。
なお、図24のAの例では、上から17行目において、各部分領域についてレベル(mcts_level_idc[i])が設定される。つまり、図25のAの例のように、いずれも単独で復号可能な、識別情報(mcts_id[0])が割り当てられたセットと識別情報(mcts_id[1])が割り当てられたセットとが存在する場合、そのセット毎にレベル(mcts_level_idc[i])を設定することができる。
その際、セットを含む四角形の領域をセット毎に設定し、これらをそれぞれピクチャ(レベルでのパラメータの規定の単位)に割り当てるようにしてもよい。例えば、図25のAの場合、識別情報(mcts_id[0])のセットを含む四角形の領域を設定し、この四角形の領域の横方向の大きさWをpic_width_in_luma_samplesとして推定し、この四角形の領域の縦方向の大きさHをpic_height_in_luma_samplesとして推定し、この四角形の領域の大きさWxHをPicSizeInSamplesYとして推定し、この四角形の領域についてレベルでのパラメータを規定するようにしてもよい。同様に、識別情報(mcts_id[1])のセットを含む四角形の領域を設定し、この四角形の領域の横方向の大きさWをpic_width_in_luma_samplesとして推定し、この四角形の領域の縦方向の大きさHをpic_height_in_luma_samplesとして推定し、この四角形の領域の大きさWxHをPicSizeInSamplesYとして推定し、この四角形の領域についてレベルでのパラメータを規定するようにしてもよい。
このようにすることにより、各四角形の領域について規定したパラメータの値をピクチャ単位で規定されるパラメータにマッピングすることができる。そして、このようなパラメータのマッピングを行うことにより、単独で復号可能な各部分領域に対してより適切な規定を採用することができるようになる。
なお、単独で復号可能な部分領域が複数の矩形領域により形成される場合、それら全ての矩形領域を含む四角形を設定するようにすればよい。例えば、図25のBの場合、識別情報(mcts_id[0])のセットは2つの矩形領域よりなるが、このセットを全て含む四角形の領域を設定し、この四角形の領域の横方向の大きさWをpic_width_in_luma_samplesとして推定し、この四角形の領域の縦方向の大きさHをpic_height_in_luma_samplesとして推定し、この四角形の領域の大きさWxHをPicSizeInSamplesYとして推定し、この四角形の領域についてレベルでのパラメータを規定するようにしてもよい。
このようにすることにより、単独で復号可能な部分領域が複数の矩形領域により形成される場合であっても、四角形の領域について規定したパラメータの値をピクチャ単位で規定されるパラメータにマッピングすることができる。そして、このようなパラメータのマッピングを行うことにより、単独で復号可能な部分領域が複数の矩形領域により形成される場合であっても、その部分領域に対してより適切な規定を採用することができるようになる。
<2.第2の実施の形態>
<画像符号化装置>
次に、以上のような本技術を実現する装置とその方法について説明する。図27は、本技術を適用した画像処理装置の一態様である、画像符号化装置を示す図である。図27に示される画像符号化装置100は、階層画像符号化(スケーラブル符号化)を行う装置である。図27に示されるように、画像符号化装置100は、ベースレイヤ画像符号化部101、エンハンスメントレイヤ画像符号化部102、多重化部103、および制御部104を有する。
ベースレイヤ画像符号化部101は、ベースレイヤ画像を符号化し、ベースレイヤ画像符号化ストリームを生成する。エンハンスメントレイヤ画像符号化部102は、エンハンスメントレイヤ画像を符号化し、エンハンスメントレイヤ画像符号化ストリームを生成する。多重化部103は、ベースレイヤ画像符号化部101において生成されたベースレイヤ画像符号化ストリームと、エンハンスメントレイヤ画像符号化部102において生成されたエンハンスメントレイヤ画像符号化ストリームとを多重化し、階層画像符号化ストリームを生成する。多重化部103は、生成した階層画像符号化ストリームを復号側に伝送する。
制御部104は、画像データ全体に関係する設定を行い、その設定に基づいてベースレイヤ画像符号化部101およびエンハンスメントレイヤ画像符号化部102を制御することにより、各レイヤの符号化を制御する。また、制御部104は、その設定を用いてビデオパラメータセット(VPS)を生成し、多重化部103に供給し、復号側に伝送させる。その際、ビデオパラメータセットは、階層画像符号化ストリームに含めて伝送するようにしてもよいし、階層画像符号化ストリームとは別のデータとして伝送するようにしてもよい。
また、復号負荷定義情報若しくは復号負荷定義情報が設定されているかを示す情報をビデオパラメータセット(VPS)に設定する場合、制御部104は、ベースレイヤ画像符号化部101およびエンハンスメントレイヤ画像符号化部102から復号負荷定義情報等を収集し、その情報に基づいて、復号負荷定義情報若しくは復号負荷定義情報が設定されているかを示す情報をビデオパラメータセット(VPS)に設定する。
また、ベースレイヤ画像符号化部101およびエンハンスメントレイヤ画像符号化部102は、互いに、復号処理の負荷の大きさに関する情報である復号負荷関連情報を授受することもできる。例えば、図11の例のように複数レイヤの復号負荷定義情報を設定する場合、そのレイヤの符号化部は、他のレイヤの復号負荷関連情報を収集する。
<ベースレイヤ画像符号化部>
図28は、図27のベースレイヤ画像符号化部101の主な構成例を示すブロック図である。図28に示されるように、ベースレイヤ画像符号化部101は、A/D変換部111、画面並べ替えバッファ112、演算部113、直交変換部114、量子化部115、可逆符号化部116、蓄積バッファ117、逆量子化部118、および逆直交変換部119を有する。また、ベースレイヤ画像符号化部101は、演算部120、ループフィルタ121、フレームメモリ122、選択部123、イントラ予測部124、インター予測部125、予測画像選択部126、およびレート制御部127を有する。
A/D変換部111は、入力された画像データ(ベースレイヤ画像情報)をA/D変換し、変換後の画像データ(デジタルデータ)を、画面並べ替えバッファ112に供給し、記憶させる。画面並べ替えバッファ112は、記憶した表示の順番のフレームの画像を、GOP(Group Of Picture)に応じて、符号化のためのフレームの順番に並べ替え、フレームの順番を並び替えた画像を、演算部113に供給する。また、画面並べ替えバッファ112は、フレームの順番を並び替えた画像を、イントラ予測部124およびインター予測部125にも供給する。
演算部113は、画面並べ替えバッファ112から読み出された画像から、予測画像選択部126を介してイントラ予測部124若しくはインター予測部125から供給される予測画像を減算し、その差分情報を直交変換部114に出力する。例えば、イントラ符号化が行われる画像の場合、演算部113は、画面並べ替えバッファ112から読み出された画像から、イントラ予測部124から供給される予測画像を減算する。また、例えば、インター符号化が行われる画像の場合、演算部113は、画面並べ替えバッファ112から読み出された画像から、インター予測部125から供給される予測画像を減算する。
直交変換部114は、演算部113から供給される差分情報に対して、離散コサイン変換やカルーネン・レーベ変換等の直交変換を施す。直交変換部114は、その変換係数を量子化部115に供給する。
量子化部115は、直交変換部114から供給される変換係数を量子化する。量子化部115は、レート制御部127から供給される符号量の目標値に関する情報に基づいて量子化パラメータを設定し、その量子化を行う。量子化部115は、量子化された変換係数を可逆符号化部116に供給する。
可逆符号化部116は、量子化部115において量子化された変換係数を任意の符号化方式で符号化する。係数データは、レート制御部127の制御の下で量子化されているので、この符号量は、レート制御部127が設定した目標値となる(若しくは目標値に近似する)。
また、可逆符号化部116は、イントラ予測のモードを示す情報などをイントラ予測部124から取得し、インター予測のモードを示す情報や差分動きベクトル情報などをインター予測部125から取得する。さらに、可逆符号化部116は、シーケンスパラメータセット(SPS)、およびピクチャパラメータセット(PPS)等を含むベースレイヤのNAL(Network Abstraction Layer)ユニットを適宜生成する。
可逆符号化部116は、これらの各種情報を任意の符号化方式で符号化し、符号化データ(符号化ストリームとも称する)の一部とする(多重化する)。可逆符号化部116は、符号化して得られた符号化データを蓄積バッファ117に供給して蓄積させる。
可逆符号化部116の符号化方式としては、例えば、可変長符号化または算術符号化等が挙げられる。可変長符号化としては、例えば、H.264/AVC方式で定められているCAVLC(Context-Adaptive Variable Length Coding)などが挙げられる。算術符号化としては、例えば、CABAC(Context-Adaptive Binary Arithmetic Coding)などが挙げられる。
蓄積バッファ117は、可逆符号化部116から供給された符号化ストリーム(ベースレイヤ符号化ストリーム)を、一時的に保持する。蓄積バッファ117は、所定のタイミングにおいて、保持しているベースレイヤ符号化ストリームを多重化部103(図27)に出力する。すなわち、蓄積バッファ117は、ベースレイヤ符号化ストリームを伝送する伝送部でもある。
また、量子化部115において量子化された変換係数は、逆量子化部118にも供給される。逆量子化部118は、その量子化された変換係数を、量子化部115による量子化に対応する方法で逆量子化する。逆量子化部118は、得られた変換係数を、逆直交変換部119に供給する。
逆直交変換部119は、逆量子化部118から供給された変換係数を、直交変換部114による直交変換処理に対応する方法で逆直交変換する。逆直交変換された出力(復元された差分情報)は、演算部120に供給される。
演算部120は、逆直交変換部119から供給された逆直交変換結果である、復元された差分情報に、予測画像選択部126を介してイントラ予測部124若しくはインター予測部125からの予測画像を加算し、局部的に復号された画像(復号画像)を得る。その復号画像は、ループフィルタ121またはフレームメモリ122に供給される。
ループフィルタ121は、デブロックフィルタや適応ループフィルタ等を含み、演算部120から供給される再構成画像に対して適宜フィルタ処理を行う。例えば、ループフィルタ121は、再構成画像に対してデブロックフィルタ処理を行うことにより再構成画像のブロック歪を除去する。また、例えば、ループフィルタ121は、そのデブロックフィルタ処理結果(ブロック歪みの除去が行われた再構成画像)に対して、ウィナーフィルタ(Wiener Filter)を用いてループフィルタ処理を行うことにより画質改善を行う。ループフィルタ121は、フィルタ処理結果(以下、復号画像と称する)をフレームメモリ122に供給する。
なお、ループフィルタ121が、再構成画像に対してさらに、他の任意のフィルタ処理を行うようにしてもよい。また、ループフィルタ121は、必要に応じて、フィルタ処理に用いたフィルタ係数等の情報を可逆符号化部116に供給し、それを符号化させるようにすることもできる。
フレームメモリ122は、供給される復号画像を記憶し、所定のタイミングにおいて、記憶している復号画像を参照画像として、選択部123に供給する。
より具体的には、フレームメモリ122は、演算部120から供給される再構成画像と、ループフィルタ121から供給される復号画像とをそれぞれ記憶する。フレームメモリ122は、所定のタイミングにおいて、若しくは、イントラ予測部124等の外部からの要求に基づいて、記憶している再構成画像を、選択部123を介してイントラ予測部124に供給する。また、フレームメモリ122は、所定のタイミングにおいて、若しくは、インター予測部125等の外部からの要求に基づいて、記憶している復号画像を、選択部123を介して、インター予測部125に供給する。
選択部123は、フレームメモリ122から供給される参照画像の供給先を選択する。例えば、イントラ予測の場合、選択部123は、フレームメモリ122から供給される参照画像(カレントピクチャ内の画素値若しくはベースレイヤ復号画像)をイントラ予測部124に供給する。また、例えば、インター予測の場合、選択部123は、フレームメモリ122から供給される参照画像(エンハンスメントレイヤのカレントピクチャ外の復号画像若しくはベースレイヤ復号画像)をインター予測部125に供給する。
イントラ予測部124は、処理対象のフレームの画像であるカレントピクチャについて、予測処理を行い、予測画像を生成する。イントラ予測部124は、この予測処理を、所定のブロック毎に(ブロックを処理単位として)行う。つまり、イントラ予測部124は、カレントピクチャの、処理対象であるカレントブロックの予測画像を生成する。その際、イントラ予測部124は、選択部123を介してフレームメモリ122から参照画像として供給される再構成画像を用いて予測処理(画面内予測(イントラ予測とも称する))を行う。つまり、イントラ予測部124は、再構成画像に含まれる、カレントブロックの周辺の画素値を用いて予測画像を生成する。このイントラ予測に利用される周辺画素値は、カレントピクチャの、過去に処理された画素の画素値である。このイントラ予測には(すなわち、予測画像の生成の仕方には)、複数の方法(イントラ予測モードとも称する)が、候補として予め用意されている。イントラ予測部124は、この予め用意された複数のイントラ予測モードでこのイントラ予測を行う。
イントラ予測部124は、候補となる全てのイントラ予測モードで予測画像を生成し、画面並べ替えバッファ112から供給される入力画像を用いて各予測画像のコスト関数値を評価し、最適なモードを選択する。イントラ予測部124は、最適なイントラ予測モードを選択すると、その最適なモードで生成された予測画像を、予測画像選択部126に供給する。
また、上述したように、イントラ予測部124は、採用されたイントラ予測モードを示すイントラ予測モード情報等を、適宜可逆符号化部116に供給し、符号化させる。
インター予測部125は、カレントピクチャについて、予測処理を行い、予測画像を生成する。インター予測部125は、この予測処理を、所定のブロック毎に(ブロックを処理単位として)行う。つまり、インター予測部125は、カレントピクチャの、処理対象であるカレントブロックの予測画像を生成する。その際、インター予測部125は、画面並べ替えバッファ112から供給される入力画像の画像データと、フレームメモリ122から参照画像として供給される復号画像の画像データとを用いて、予測処理を行う。この復号画像は、カレントピクチャより前に処理されたフレームの画像(カレントピクチャでない他のピクチャ)である。つまり、インター予測部125は、他のピクチャの画像を用いて予測画像を生成する予測処理(画面間予測(インター予測とも称する))を行う。
このインター予測は、動き予測と動き補償よりなる。より具体的には、インター予測部125は、入力画像と参照画像を用いて、カレントブロックについて動き予測を行い、動きベクトルを検出する。そして、インター予測部125は、参照画像を用いて、検出された動きベクトルに応じて動き補償処理を行い、カレントブロックの予測画像(インター予測画像情報)を生成する。このインター予測には(すなわち、予測画像の生成の仕方には)、複数の方法(インター予測モードとも称する)が、候補として予め用意されている。インター予測部125は、この予め用意された複数のインター予測モードでこのようなインター予測を行う。
インター予測部125は、候補となる全てのインター予測モードで予測画像を生成する。インター予測部125は、画面並べ替えバッファ112から供給される入力画像と、生成した差分動きベクトルの情報などを用いて、各予測画像のコスト関数値を評価し、最適なモードを選択する。インター予測部125は、最適なインター予測モードを選択すると、その最適なモードで生成された予測画像を、予測画像選択部126に供給する。
インター予測部125は、採用されたインター予測モードを示す情報や、符号化データを復号する際に、そのインター予測モードで処理を行うために必要な情報等を可逆符号化部116に供給し、符号化させる。必要な情報としては、例えば、生成された差分動きベクトルの情報や、予測動きベクトル情報として予測動きベクトルのインデックスを示すフラグなどがある。
予測画像選択部126は、演算部113や演算部120に供給する予測画像の供給元を選択する。例えば、イントラ符号化の場合、予測画像選択部126は、予測画像の供給元としてイントラ予測部124を選択し、そのイントラ予測部124から供給される予測画像を演算部113や演算部120に供給する。また、例えば、インター符号化の場合、予測画像選択部126は、予測画像の供給元としてインター予測部125を選択し、そのインター予測部125から供給される予測画像を演算部113や演算部120に供給する。
レート制御部127は、蓄積バッファ117に蓄積された符号化データの符号量に基づいて、オーバフローあるいはアンダーフローが発生しないように、量子化部115の量子化動作のレートを制御する。
また、フレームメモリ122は、記憶しているベースレイヤ復号画像を、エンハンスメントレイヤ画像符号化部102に供給する。
また、図28に示されるように、ベースレイヤ画像符号化部101は、ヘッダ情報生成部128をさらに有する。
ヘッダ情報生成部128は、シーケンスパラメータセット(SPS)やMCTS SEI等のヘッダ情報を生成する。その際、ヘッダ情報生成部128は、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報の設定に関する処理を行う。例えば、ヘッダ情報生成部128は、可逆符号化部116からベースレイヤの復号負荷関連情報を取得し、その復号負荷関連情報に基づいて、ベースレイヤの、独立に復号することができる部分領域の復号負荷定義情報を生成することができる。また、ヘッダ情報生成部128は、例えば、エンハンスメントレイヤ画像符号化部102からエンハンスメントレイヤの復号負荷関連情報を取得し、その復号負荷関連情報に基づいて、エンハンスメントレイヤの、独立に復号することができる部分領域の復号負荷定義情報を生成することができる。
さらに、ヘッダ情報生成部128は、制御部104に復号負荷定義情報等を供給し、ビデオパラメータセットに復号負荷定義情報に関する設定を行わせることができる。
<エンハンスメントレイヤ画像符号化部>
図29は、図27のエンハンスメントレイヤ画像符号化部102の主な構成例を示すブロック図である。図29に示されるように、エンハンスメントレイヤ画像符号化部102は、図28のベースレイヤ画像符号化部101と基本的に同様の構成を有する。
つまり、エンハンスメントレイヤ画像符号化部102は、図29に示されるように、A/D変換部131、画面並べ替えバッファ132、演算部133、直交変換部134、量子化部135、可逆符号化部136、蓄積バッファ137、逆量子化部138、および逆直交変換部139を有する。また、エンハンスメントレイヤ画像符号化部102は、演算部140、ループフィルタ141、フレームメモリ142、選択部143、イントラ予測部144、インター予測部145、予測画像選択部146、およびレート制御部147を有する。
これらのA/D変換部131乃至レート制御部147は、図28のA/D変換部111乃至レート制御部127に対応し、それぞれ、対応する処理部と同様の処理を行う。ただし、エンハンスメントレイヤ画像符号化部102の各部は、ベースレイヤではなく、エンハンスメントレイヤ画像情報の符号化についての処理を行う。したがって、A/D変換部131乃至レート制御部147の処理の説明として、上述した図28のA/D変換部111乃至レート制御部127についての説明を適用することができるが、その場合、処理するデータは、ベースレイヤのデータではなく、エンハンスメントレイヤのデータであるものとする必要がある。また、データの入力元や出力先の処理部は、適宜、A/D変換部131乃至レート制御部147の中の対応する処理部に置き換えて読む必要がある。
エンハンスメントレイヤ画像符号化部102は、さらに、ヘッダ情報生成部148を有する。
ヘッダ情報生成部148は、図28のヘッダ情報生成部128に対応し、ヘッダ情報生成部128と同様の処理を行う。ただし、ヘッダ情報生成部148は、ベースレイヤではなく、エンハンスメントレイヤについての処理を行う。
なお、エンハンスメントレイヤの復号負荷定義情報もベースレイヤのヘッダ情報生成部128において作成する場合、エンハンスメントレイヤのヘッダ情報生成部148は、省略することができる。
<ヘッダ情報生成部>
図30は、図28のヘッダ情報生成部128が有する機能ブロックの構成例を示す図である。ヘッダ情報生成部128において、例えば、CPUがROM等から読み出したプログラムをRAMを用いて実行する等して、上述した処理が実行されることにより、図30に示される各種の機能ブロックが実現される。
図30に示されるように、ヘッダ情報生成部128は、復号負荷関連情報取得部151、MCTS SEI生成部152、およびSPS生成部153を有する。
復号負荷関連情報取得部151は、独立に復号することができる部分領域の復号負荷定義情報を生成するのに用いられる復号処理の負荷に関する情報を取得する。この復号処理の負荷に関する情報の内容は、復号負荷定義情報を生成するのに用いられるものであれば、どのようなものであってもよい。
MCTS SEI生成部152は、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号負荷定義情報を含むMCTS SEIを生成する。つまり、MCTS SEI生成部152は、MCTS SEIにおいて、独立に復号することができる部分領域の復号負荷定義情報を設定する。この復号負荷定義情報の内容は任意である。例えば、第1の実施の形態において、図9乃至図26を参照して説明した各種情報のいずれか1つ以上がこの復号負荷定義情報に含まれるようにしてもよい。なお、MCTS SEI生成部152が、部分領域単位でレベルを定義するにあたって、第1の実施の形態において説明したように、その部分領域用のレベルについてのパラメータの規定も行い、その規定を全体画像(ピクチャ)単位のレベルでの規定に割り当てる(パラメータのマッピングを行う)ようにしてもよい。
SPS生成部153は、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号負荷定義情報、若しくは、MCTS SEIに独立に復号することができる部分領域の復号負荷定義情報が設定されているかを示す情報(それらをまとめて復号負荷の定義に関する情報とも称する)を含むシーケンスパラメータセット(SPS)を生成する。つまり、SPS生成部153は、シーケンスパラメータセット(SPS)において、独立に復号することができる部分領域の復号負荷の定義に関する情報を設定する。この復号負荷の定義に関する情報の内容は任意である。例えば、第1の実施の形態において、図9乃至図26を参照して説明した各種情報のいずれか1つ以上がこの復号負荷定義情報に含まれるようにしてもよい。
なお、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号負荷定義情報をMCTS SEIにのみ設定し、シーケンスパラメータセット(SPS)において、これらの情報を設定しないようにすることもできる。その場合、SPS生成部153は、省略することもできる。
<画像符号化処理の流れ>
次に、以上のような画像符号化装置100により実行される各処理の流れについて説明する。最初に、図31のフローチャートを参照して、画像符号化処理の流れの例を説明する。
画像符号化処理が開始されると、画像符号化装置100の制御部104は、ステップS101において、スケーラブル符号化全体の設定を行う。
ステップS102において、制御部104は、ステップS101において行った設定に従ってベースレイヤ画像符号化部101乃至多重化部103の各部を制御する。
ステップS103において、制御部104は、ステップS101において行った設定を反映させてビデオパラメータセット(VPS)を生成する。
ステップS104において、ベースレイヤ画像符号化部101は、ベースレイヤの画像データを符号化する。
ステップS105において、エンハンスメントレイヤ画像符号化部102は、エンハンスメントレイヤの画像データを符号化する。
ステップS106において、多重化部103は、ステップS104において生成されたベースレイヤ画像符号化ストリームと、ステップS105において生成されたエンハンスメントレイヤ画像符号化ストリームとを(すなわち、各レイヤのビットストリームを)多重化し、1系統の階層画像符号化ストリームを生成する。なお、多重化部103は、必要に応じて、ステップS103において生成されたビデオパラメータセット(VPS)を階層画像符号化ストリームに含める。多重化部103は、その階層画像符号化ストリームを出力し、復号側に伝送する。
ステップS106の処理が終了すると、画像符号化装置100は、画像符号化処理を終了する。このような画像符号化処理により1ピクチャが処理される。したがって、画像符号化装置100は、このような画像符号化処理を階層化された動画像データの各ピクチャについて繰り返し実行する。ただし、例えば、ステップS101乃至ステップS103の処理等、ピクチャ毎に行う必要の無い処理は、適宜省略する。
<ベースレイヤ符号化処理の流れ>
次に、図31のステップS104において、ベースレイヤ画像符号化部101により実行されるベースレイヤ符号化処理の流れの例を、図32のフローチャートを参照して説明する。
ベースレイヤ符号化処理が開始されると、ベースレイヤ画像符号化部101のA/D変換部111は、ステップS121において、入力された動画像の各フレーム(ピクチャ)の画像をA/D変換する。
ステップS122において、画面並べ替えバッファ112は、ステップS121においてA/D変換された画像を記憶し、各ピクチャの表示する順番から符号化する順番への並べ替えを行う。
ステップS123において、イントラ予測部124は、イントラ予測モードのイントラ予測処理を行う。
ステップS124において、インター予測部125は、インター予測モードでの動き予測や動き補償等を行うインター予測処理を行う。
ステップS125において、予測画像選択部126は、コスト関数値等に基づいて、予測画像を選択する。つまり、予測画像選択部126は、ステップS123のイントラ予測により生成された予測画像と、ステップS124のインター予測により生成された予測画像のいずれか一方を選択する。
ステップS126において、演算部113は、ステップS122の処理によりフレーム順を並び替えられた入力画像と、ステップS125の処理により選択された予測画像との差分を演算する。つまり、演算部113は、入力画像と予測画像との差分画像の画像データを生成する。このようにして求められた差分画像の画像データは、元の画像データに比べてデータ量が低減される。したがって、画像をそのまま符号化する場合に較べて、データ量を圧縮することができる。
ステップS127において、直交変換部114は、ステップS126の処理により生成された差分画像の画像データを直交変換する。
ステップS128において、量子化部115は、レート制御部127により算出された量子化パラメータを用いて、ステップS127の処理により得られた直交変換係数を量子化する。
ステップS129において、逆量子化部118は、ステップS128の処理により生成された量子化された係数(量子化係数とも称する)を、量子化部115の特性に対応する特性で逆量子化する。
ステップS130において、逆直交変換部119は、ステップS129の処理により得られた直交変換係数を逆直交変換する。
ステップS131において、演算部120は、ステップS130の処理により復元された差分画像に、ステップS125の処理により選択された予測画像を加算することにより、再構成画像の画像データを生成する。
ステップS132においてループフィルタ121は、ステップS131の処理により生成された再構成画像の画像データにループフィルタ処理を行う。これにより、再構成画像のブロック歪み等が除去される。
ステップS133において、フレームメモリ122は、ステップS132の処理により得られた復号画像(ベースレイヤ復号画像)やステップS131の処理により得られた再構成画像等のデータを記憶する。
ステップS134において、可逆符号化部116は、ステップS128の処理により得られた、量子化された係数を符号化する。すなわち、差分画像に対応するデータに対して、可変長符号化や算術符号化等の可逆符号化が行われる。
また、このとき、可逆符号化部116は、ステップS125の処理により選択された予測画像の予測モードに関する情報を符号化し、差分画像を符号化して得られる符号化データに付加する。つまり、可逆符号化部116は、イントラ予測部124から供給される最適イントラ予測モード情報、または、インター予測部125から供給される最適インター予測モードに応じた情報なども符号化し、符号化データに付加する。
ステップS135において、ヘッダ情報生成部128は、各種ナルユニット等のヘッダ情報を生成する。生成されたヘッダ情報は、可逆符号化部116に供給され、符号化データに付加される。
ステップS136において蓄積バッファ117は、ステップS134およびステップS135の処理により得られた符号化データ(ベースレイヤ画像符号化ストリーム)を蓄積する。蓄積バッファ117に蓄積されたベースレイヤ画像符号化ストリームは、適宜読み出され、多重化部103に供給されてエンハンスメントレイヤ画像符号化ストリームと多重化された後、伝送路や記録媒体を介して復号側に伝送される。
ステップS137においてレート制御部127は、ステップS136の処理により蓄積バッファ117に蓄積された符号化データの符号量(発生符号量)に基づいて、オーバフローあるいはアンダーフローが発生しないように、量子化部115の量子化動作のレートを制御する。また、レート制御部127は、量子化パラメータに関する情報を、量子化部115に供給する。
ステップS137の処理が終了すると、ベースレイヤ符号化処理が終了し、処理は図31に戻る。
<エンハンスメントレイヤ符号化処理の流れ>
次に、図31のステップS105において、エンハンスメントレイヤ画像符号化部102により実行されるエンハンスメントレイヤ符号化処理の流れの例を、図33のフローチャートを参照して説明する。
このエンハンスメントレイヤ符号化処理の各処理(ステップS141乃至ステップS157)は、ベースレイヤ符号化処理の各処理(ステップS121乃至ステップS137)に対応し、それらの処理と基本的に同様に実行される。ただし、ベースレイヤ符号化処理の各処理がベースレイヤに対して行われたのに対し、このエンハンスメントレイヤ符号化処理の各処理(ステップS141乃至ステップS157)は、エンハンスメントレイヤに対して行われる。
また、独立に復号することができる部分領域の復号負荷定義情報の設定を、ベースレイヤのみで行う場合、ステップS155において、復号負荷定義情報の設定は省略することができる。
ステップS157の処理が終了すると、エンハンスメントレイヤ符号化処理が終了し、処理は、図31に戻る。
<ヘッダ生成処理の流れ>
次に、図34のフローチャートを参照して、図32のステップS135において実行されるヘッダ生成処理の流れの例を説明する。
ヘッダ生成処理が開始されると、ヘッダ情報生成部128は、ステップS161において、例えばシーケンスパラメータセット(SPS)、SEI、ピクチャパラメータセット(PPS(Picture Parameter Set))、スライスヘッダ(SliceHeader)等の各種ヘッダ情報を生成する。
ステップS162において、復号負荷関連情報取得部151は、独立に復号することができる部分領域の復号負荷定義情報の生成に必要な、その部分領域の復号処理の負荷に関する情報である復号負荷関連情報を取得する。なお、エンハンスメントレイヤの復号負荷定義情報も設定する場合、エンハンスメントレイヤからも復号負荷関連情報を取得する。この復号負荷関連情報の内容は、復号負荷定義情報を生成するのに用いられるものであれば、どのようなものであってもよい。
ステップS163において、MCTS SEI生成部152は、ステップS161において生成した独立に復号することができる部分領域のMCTS SEIに、その部分領域の復号負荷定義情報を設定する。例えば、MCTS SEI生成部152は、第1の実施の形態において図9乃至図26のシンタクス等を参照して説明したように、復号負荷定義情報を設定する。
例えば図10のように、独立に復号することができる部分領域が複数のセット(複数のタイル(Tile))からなる場合、MCTS SEI生成部152は、各タイルの復号負荷関連情報を用いて、復号負荷関連情報をセット毎に設定する。また、MCTS SEI生成部152が、各タイルの復号負荷関連情報を用いて、その部分領域全体の復号負荷定義情報を設定するようにしてもよい。
なお、独立に復号することができる部分領域が複数存在する場合、MCTS SEI生成部152は、各部分領域について復号負荷定義情報をそれぞれ設定するようにしてもよい。この復号負荷定義情報の内容は任意である。例えば、第1の実施の形態において、図9乃至図26を参照して説明した各種情報のいずれか1つ以上がこの復号負荷定義情報に含まれるようにしてもよい。
ステップS164において、SPS設定部153は、ステップS161において生成したシーケンスパラメータセット(SPS)に、独立に復号することができる部分領域の復号負荷定義情報、若しくは、MCTS SEIにその部分領域の復号負荷定義情報が設定されているかを示す情報(復号負荷の定義に関する情報とも称する)を設定する。この復号負荷の定義に関する情報の内容は任意である。例えば、第1の実施の形態において、図9乃至図26を参照して説明した各種情報のいずれか1つ以上がこの復号負荷定義情報に含まれるようにしてもよい。
ステップS164の処理が終了すると、ヘッダ情報生成処理が終了し、処理は図32に戻る。
なお、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号負荷定義情報をMCTS SEIにのみ設定し、シーケンスパラメータセット(SPS)において、これらの情報を設定しないようにすることもできる。その場合、ステップS164の処理は、省略することもできる。
また、ステップS163において、MCTS SEI生成部152が、部分領域単位でレベルを定義するにあたって、第1の実施の形態において説明したように、その部分領域用のレベルについてのパラメータの規定も行い、その規定を全体画像(ピクチャ)単位のレベルでの規定に割り当てる(パラメータのマッピングを行う)ようにしてもよい。
以上のように設定されたヘッダ情報は、可逆符号化部116に供給され、符号化データに含められる。
以上のように各処理を実行することにより、画像符号化装置100は、復号に必要な性能をより正確に把握できるようにすることができる。
なお、エンハンスメントレイヤにおいて独立に復号することができる部分領域の復号負荷定義情報を設定する場合、ヘッダ情報生成部148は、図34のフローチャートを参照して説明したように実行すればよい。逆に、復号負荷定義情報を設定しない場合は、図34のステップS161の処理だけ実行するようにすればよい。
<3.第3の実施の形態>
<画像復号装置>
次に、以上のように符号化された符号化データの復号について説明する。図35は、本技術を適用した画像処理装置の一態様である、画像符号化装置100に対応する画像復号装置の主な構成例を示すブロック図である。図35に示される画像復号装置200は、画像符号化装置100が生成した符号化データを、その符号化方法に対応する復号方法で復号する(すなわち、階層符号化された符号化データを階層復号する)。図35に示されるように、画像復号装置200は、逆多重化部201、ベースレイヤ画像復号部202、エンハンスメントレイヤ画像復号部203、および制御部204を有する。
逆多重化部201は、符号化側から伝送された、ベースレイヤ画像符号化ストリームとエンハンスメントレイヤ画像符号化ストリームとが多重化された階層画像符号化ストリームを受け取り、それを逆多重化し、ベースレイヤ画像符号化ストリームと、エンハンスメントレイヤ画像符号化ストリームとを抽出する。ベースレイヤ画像復号部202は、逆多重化部201により抽出されたベースレイヤ画像符号化ストリームを復号し、ベースレイヤ画像を得る。エンハンスメントレイヤ画像復号部203は、逆多重化部201により抽出されたエンハンスメントレイヤ画像符号化ストリームを復号し、エンハンスメントレイヤ画像を得る。
制御部204は、逆多重化部201から供給されたビデオパラメータセット(VPS)を解析し、その情報に基づいてベースレイヤ画像復号部202およびエンハンスメントレイヤ画像復号部203を制御する(各レイヤの符号化を制御する)。
また、制御部204は、ベースレイヤ画像復号部202およびエンハンスメントレイヤ画像復号部203からヘッダ情報の復号負荷定義情報の解析結果を取得し、その解析結果に応じて、画像復号装置200の各処理部の動作を制御する。
<ベースレイヤ画像復号部>
図36は、図35のベースレイヤ画像復号部202の主な構成例を示すブロック図である。図36に示されるようにベースレイヤ画像復号部202は、蓄積バッファ211、可逆復号部212、逆量子化部213、逆直交変換部214、演算部215、ループフィルタ216、画面並べ替えバッファ217、およびD/A変換部218を有する。また、ベースレイヤ画像復号部202は、フレームメモリ219、選択部220、イントラ予測部221、インター予測部222、および予測画像選択部223を有する。
蓄積バッファ211は、伝送されてきた符号化データ(逆多重化部201から供給されるベースレイヤ画像符号化ストリーム)を受け取る受け取り部でもある。蓄積バッファ211は、伝送されてきた符号化データを受け取って、蓄積し、所定のタイミングにおいてその符号化データを可逆復号部212に供給する。この符号化データには、予測モード情報などの復号に必要な情報が付加されている。
可逆復号部212は、蓄積バッファ211より供給された、可逆符号化部116により符号化された情報を、その符号化方式に対応する復号方式で復号する。可逆復号部212は、復号して得られた差分画像の量子化された係数データを、逆量子化部213に供給する。
また、可逆復号部212は、最適な予測モードにイントラ予測モードが選択されたかインター予測モードが選択されたかを判定し、その最適な予測モードに関する情報を、イントラ予測部221およびインター予測部222の内、選択されたと判定したモードの方に供給する。つまり、例えば、符号化側において最適な予測モードとしてイントラ予測モードが選択された場合、その最適な予測モードに関する情報(イントラ予測モード情報)がイントラ予測部221に供給される。また、例えば、符号化側において最適な予測モードとしてインター予測モードが選択された場合、その最適な予測モードに関する情報(インター予測モード情報)がインター予測部222に供給される。
さらに、可逆復号部212は、例えば、量子化行列や量子化パラメータ等の、逆量子化に必要な情報を、符号化データから抽出し、逆量子化部213に供給する。
逆量子化部213は、可逆復号部212により復号されて得られた量子化された係数データを、量子化部115の量子化方式に対応する方式で逆量子化する。なお、この逆量子化部213は、逆量子化部118と同様の処理部である。逆量子化部213は、得られた係数データ(直交変換係数)を逆直交変換部214に供給する。
逆直交変換部214は、逆量子化部213から供給される直交変換係数を、必要に応じて、直交変換部114の直交変換方式に対応する方式で逆直交変換する。なお、この逆直交変換部214は、逆直交変換部119と同様の処理部である。
この逆直交変換処理により差分画像の画像データが復元される。この復元された差分画像の画像データは、符号化側において直交変換される前の差分画像の画像データに対応する。以下においては、この、逆直交変換部214の逆直交変換処理により得られた、復元された差分画像の画像データを、復号残差データとも称する。逆直交変換部214は、この復号残差データを、演算部215に供給する。また、演算部215には、予測画像選択部223を介して、イントラ予測部221若しくはインター予測部222から予測画像の画像データが供給される。
演算部215は、この復号残差データと予測画像の画像データとを用いて、差分画像と予測画像とを加算した再構成画像の画像データを得る。この再構成画像は、演算部113により予測画像が減算される前の入力画像に対応する。演算部215は、その再構成画像をループフィルタ216に供給する。
ループフィルタ216は、供給された再構成画像に対して、デブロックフィルタ処理や適応ループフィルタ処理等を含むループフィルタ処理を適宜施して復号画像を生成する。例えば、ループフィルタ216は、再構成画像に対してデブロックフィルタ処理を行うことにより、ブロック歪を除去する。また、例えば、ループフィルタ216は、そのデブロックフィルタ処理結果(ブロック歪みの除去が行われた再構成画像)に対して、ウィナーフィルタ(Wiener Filter)を用いてループフィルタ処理を行うことにより画質改善を行う。
なお、ループフィルタ216が行うフィルタ処理の種類は任意であり、上述した以外のフィルタ処理を行ってもよい。また、ループフィルタ216が、画像符号化装置から供給されたフィルタ係数を用いてフィルタ処理を行うようにしてもよい。さらに、ループフィルタ216が、このようなフィルタ処理を省略し、入力されたデータをフィルタ処理せずに出力することもできる。
ループフィルタ216は、フィルタ処理結果である復号画像(若しくは再構成画像)を画面並べ替えバッファ217およびフレームメモリ219に供給する。
画面並べ替えバッファ217は、復号画像についてフレームの順番の並べ替えを行う。すなわち、画面並べ替えバッファ217は、画面並べ替えバッファ112により符号化順に並べ替えられた各フレームの画像を、元の表示順に並べ替える。つまり、画面並べ替えバッファ217は、符号化順に供給される各フレームの復号画像の画像データを、その順に記憶し、符号化順に記憶した各フレームの復号画像の画像データを、表示順に読み出してD/A変換部218に供給する。D/A変換部218は、画面並べ替えバッファ217から供給された各フレームの復号画像(デジタルデータ)をD/A変換し、アナログデータとして、図示せぬディスプレイに出力し、表示させる。
フレームメモリ219は、供給される復号画像を記憶し、所定のタイミングにおいて、若しくは、イントラ予測部221やインター予測部222等の外部の要求に基づいて、記憶している復号画像を参照画像として、選択部220を介してイントラ予測部221やインター予測部222に供給する。
イントラ予測部221には、イントラ予測モード情報等が可逆復号部212から適宜供給される。イントラ予測部221は、イントラ予測部124において用いられたイントラ予測モード(最適イントラ予測モード)でイントラ予測を行い、予測画像を生成する。その際、イントラ予測部221は、選択部220を介してフレームメモリ219から供給される再構成画像の画像データを用いてイントラ予測を行う。すなわち、イントラ予測部221は、この再構成画像を参照画像(周辺画素)として利用する。イントラ予測部221は、生成した予測画像を予測画像選択部223に供給する。
インター予測部222には、最適予測モード情報や動き情報等が可逆復号部212から適宜供給される。インター予測部222は、可逆復号部212から取得された最適予測モード情報が示すインター予測モード(最適インター予測モード)で、フレームメモリ219から取得した復号画像(参照画像)を用いてインター予測を行い、予測画像を生成する。
予測画像選択部223は、イントラ予測部221から供給される予測画像またはインター予測部222から供給される予測画像を、演算部215に供給する。そして、演算部215においては、その予測画像と逆直交変換部214からの復号残差データ(差分画像情報)とが加算されて再構成画像が得られる。
また、フレームメモリ219は、記憶しているベースレイヤ復号画像を、エンハンスメントレイヤ画像復号部203に供給する。
ベースレイヤ画像復号部202は、さらにヘッダ情報解析部224を有する。ヘッダ情報解析部224は、可逆復号部212により符号化ストリームから抽出されたヘッダ情報を取得し、それを解析する。例えば、ヘッダ情報解析部224は、ヘッダ情報に含まれる復号負荷定義情報を解析する。ヘッダ情報解析部224は、その解析結果を示す情報を、制御部204に供給する。
<エンハンスメントレイヤ画像復号部>
図37は、図35のエンハンスメントレイヤ画像復号部203の主な構成例を示すブロック図である。図37に示されるように、エンハンスメントレイヤ画像復号部203は、図36のベースレイヤ画像復号部202と基本的に同様の構成を有する。
つまり、エンハンスメントレイヤ画像復号部203は、図37に示されるように、蓄積バッファ231、可逆復号部232、逆量子化部233、逆直交変換部234、演算部235、ループフィルタ236、画面並べ替えバッファ237、およびD/A変換部238を有する。また、エンハンスメントレイヤ画像復号部203は、フレームメモリ239、選択部240、イントラ予測部241、インター予測部242、および予測画像選択部243を有する。
これらの蓄積バッファ231乃至予測画像選択部243は、図36の蓄積バッファ211乃至予測画像選択部223に対応し、それぞれ、対応する処理部と同様の処理を行う。ただし、エンハンスメントレイヤ画像復号部203の各部は、ベースレイヤではなく、エンハンスメントレイヤ画像情報の符号化についての処理を行う。したがって、蓄積バッファ231乃至予測画像選択部243の処理の説明として、上述した図36の蓄積バッファ211乃至予測画像選択部223についての説明を適用することができるが、その場合、処理するデータは、ベースレイヤのデータではなく、エンハンスメントレイヤのデータであるものとする必要がある。また、データの入力元や出力先の処理部は、適宜、エンハンスメントレイヤ画像復号部203の、対応する処理部に置き換えて読む必要がある。
なお、フレームメモリ239は、ベースレイヤ画像復号部202から供給されるベースレイヤ復号画像を取得し、例えばロングターム参照フレーム等として記憶する。このベースレイヤ復号画像は、イントラ予測部241やインター予測部242による予測処理において、例えばレイヤ間予測の参照画像として利用される。
エンハンスメントレイヤ画像復号部203は、さらに、ヘッダ情報解析部244を有する。
可逆復号部232は、エンハンスメントレイヤ画像符号化ストリームから例えばシーケンスパラメータセット(SPS)やMCTS SEI等のヘッダ情報を取得する。このヘッダ情報には、独立に復号することができる部分領域の復号負荷定義情報が含まれている可能性がある。可逆復号部232は、そのヘッダ情報をヘッダ情報解析部244に供給する。
ヘッダ情報解析部244は、供給されたヘッダ情報に含まれる、独立に復号することができる部分領域の復号負荷定義情報を解析し、その解析結果を制御部204に供給する。
なお、復号負荷定義情報がベースレイヤにおいてのみ設定される場合、エンハンスメントレイヤのヘッダ情報解析部244は、省略するようにしてもよい。
<ヘッダ情報解析部>
図38は、図36のヘッダ情報解析部224が有する機能ブロックの構成例を示す図である。ヘッダ情報解析部224において、例えば、CPUがROM等から読み出したプログラムをRAMを用いて実行する等して、上述した処理が実行されることにより、図38に示される各種の機能ブロックが実現される。
図38に示されるように、ヘッダ情報解析部224は、ヘッダ情報取得部251、SPS解析部252、MCTS SEI解析部253、レベル特定部254、および提供部255を有する。
ヘッダ情報取得部251は、可逆復号部212から供給される各種ヘッダ情報を取得する。SPS解析部252は、ヘッダ情報取得部251によりヘッダ情報として取得されたシーケンスパラメータセット(SPS)を解析する。このシーケンスパラメータセット(SPS)には、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号負荷の定義に関する情報が含まれる。この復号負荷の定義に関する情報の内容は任意である。例えば、第1の実施の形態において、図9乃至図26を参照して説明した各種情報のいずれか1つ以上がこの復号負荷定義情報に含まれるようにしてもよい。
MCTS SEI解析部253は、ヘッダ情報取得部251によりヘッダ情報として取得されたMCTS SEIを解析する。このMCTS SEIは、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号負荷定義情報を含む。この復号負荷定義情報の内容は任意である。例えば、第1の実施の形態において、図9乃至図26を参照して説明した各種情報のいずれか1つ以上がこの復号負荷定義情報に含まれるようにしてもよい。
レベル特定部254は、SPS解析部252およびMCTS SEIの解析結果に基づいて、独立に復号することができる部分領域の復号に必要なレベルを特定する。提供部255は、レベル特定部254により特定されたレベル、若しくは、そのレベルに対応する復号処理の負荷に関する情報を制御部104に提供する。
なお、全体画像(ピクチャ)単位のレベルでの規定に対して、第1の実施の形態において説明したように部分領域用を含む所定の領域で規定されたパラメータがマッピングされている場合、レベル特定部254若しくは提供部255は、レベルの特定若しくはレベルの解釈の際に、そのマッピングされたパラメータを採用することができる。
また、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号負荷定義情報をMCTS SEIにのみ設定し、シーケンスパラメータセット(SPS)において、これらの情報を設定しないようにすることもできる。その場合、SPS解析部252は、省略することもできる。
<画像復号処理の流れ>
次に、以上のような画像復号装置200により実行される各処理の流れについて説明する。最初に、図39のフローチャートを参照して、画像復号処理の流れの例を説明する。
画像復号処理が開始されると、ステップS201において、画像復号装置200の逆多重化部201は、符号化側から伝送される階層画像符号化ストリームをレイヤ毎に逆多重化する。
ステップS202において、可逆復号部212は、ステップS201の処理により抽出されたベースレイヤ画像符号化ストリームから復号負荷定義情報を含むヘッダ情報を抽出する。
なお、例えば、復号負荷定義情報がエンハンスメントレイヤにも存在する場合、可逆復号部232も同様にこの処理を行い、エンハンスメントレイヤのヘッダ情報を抽出する。
ステップS203において、ヘッダ情報解析部224は、ステップS202において抽出されたヘッダ情報を解析し、復号負荷定義情報から復号に必要なレベルを特定する。
ステップS204において、制御部204は、ステップS203の解析結果に基づいて、符号化ストリームを復号可能か否かを判定する。復号可能と判定された場合、処理はステップS205に進む。
ステップS205において、ベースレイヤ画像復号部202は、ベースレイヤ画像符号化ストリームを復号する。ステップS206において、エンハンスメントレイヤ画像復号部203は、エンハンスメントレイヤ画像符号化ストリームを復号する。
ステップS206の処理が終了すると、画像復号処理が終了する。
また、ステップS204において、復号不可能と判定された場合、処理はステップS207に進む。この場合、ステップS207において、制御部204は、復号を正常に出来ない場合の所定の処理であるエラー処理を行う。
このエラー処理はどのような処理であっても良い。例えば、復号を強制終了(中断、一時停止等を含む)してもよいし、画像や音声などでユーザに対して警告するようにしてもよい。また、例えばレベルがより低い他の符号化ストリームを取得して復号をやり直すようにしてもよい。さらに、例えば、復号画像に乱れが生じることを許容し、その符号化ストリームを強制的に復号するようにしてもよい。
ステップS207の処理が終了すると、画像復号処理が終了する。
<ヘッダ情報解析処理の流れ>
次に、図40のフローチャートを参照して、図39のステップS203において実行されるヘッダ情報解析処理の流れの例を説明する。
ヘッダ情報解析処理が開始されると、SPS解析部252は、ステップS211において、シーケンスパラメータセット(SPS)を参照するか否かを判定する。ヘッダ情報として取得されたシーケンスパラメータセット(SPS)に、独立に復号することができる部分領域の復号負荷の定義に関する情報が含まれており、シーケンスパラメータセット(SPS)を参照すると判定された場合、処理はステップS212に進む。
ステップS212において、SPS解析部252は、シーケンスパラメータセット(SPS)に含まれる、独立に復号することができる部分領域の復号負荷の定義に関する情報を解析する。この復号負荷の定義に関する情報の内容は任意である。例えば、第1の実施の形態において、図9乃至図26を参照して説明した各種情報のいずれか1つ以上がこの復号負荷定義情報に含まれるようにしてもよい。解析が終了すると、処理はステップS213に進む。また、ステップS211において、シーケンスパラメータセット(SPS)に、独立に復号することができる部分領域の復号負荷の定義に関する情報が含まれておらず、シーケンスパラメータセット(SPS)を参照しないと判定された場合、処理はステップS213に進む。
ステップS213において、MCTS SEI解析部253は、MCTS SEIを参照するか否かを判定する。ヘッダ情報として取得されたMCTS SEIに、独立に復号することができる部分領域の復号負荷定義情報が設定されており、MCTS SEIを参照すると判定された場合、処理はステップS214に進む。
ステップS214において、MCTS SEI解析部253は、MCTS SEIに含まれる、独立に復号することができる部分領域の復号負荷定義情報を解析する。この復号負荷定義情報の内容は任意である。例えば、第1の実施の形態において、図9乃至図26を参照して説明した各種情報のいずれか1つ以上がこの復号負荷定義情報に含まれるようにしてもよい。解析が終了すると、処理はステップS215に進む。また、ステップS213において、MCTS SEIに、独立に復号することができる部分領域の復号負荷定義情報が設定されておらず、MCTS SEIを参照しないと判定された場合、処理はステップS215に進む。
ステップS215において、レベル特定部254は、ステップS212およびステップS214の解析結果に基づいて、復号に必要なレベルを特定する。
ステップS216において、提供部255は、ステップS215において特定された復号に必要なレベルを示す情報を制御部104に提供する。
ステップS216の処理が終了すると、ヘッダ情報解析処理が終了し、処理は図39に戻る。
なお、全体画像(ピクチャ)単位のレベルでの規定に対して、第1の実施の形態において説明したように部分領域用を含む所定の領域で規定されたパラメータがマッピングされている場合、レベル特定部254若しくは提供部255は、ステップS215若しくはステップS216の処理において、そのマッピングされたパラメータを採用することができる。
また、第1の実施の形態において説明したように、独立に復号することができる部分領域の復号負荷定義情報をMCTS SEIにのみ設定し、シーケンスパラメータセット(SPS)において、これらの情報を設定しないようにすることもできる。その場合、ステップS211およびステップS212の処理は、省略することもできる。
<ベースレイヤ復号処理の流れ>
以上のような復号負荷定義情報に基づく復号可否判定の結果、復号可能とされた場合、図39のステップS205においてベースレイヤ復号処理が実行される。そのベースレイヤ復号処理の流れの例を、図41のフローチャートを参照して説明する。
ベースレイヤ復号処理が開始されると、ステップS221において、ベースレイヤ画像復号部202の蓄積バッファ211は、伝送されてきたベースレイヤ符号化ストリームを蓄積する。ステップS222において、可逆復号部212は、蓄積バッファ211から供給されるベースレイヤ符号化ストリームを復号する。すなわち、可逆符号化部116により符号化されたIスライス、Pスライス、並びにBスライス等の画像データが復号される。このとき、ヘッダ情報などのビットストリームに含められた画像データ以外の各種情報も復号される。
ステップS223において、逆量子化部213は、ステップS222の処理により得られた、量子化された係数を逆量子化する。
ステップS224において、逆直交変換部214は、ステップS223において逆量子化された係数を逆直交変換する。
ステップS225において、イントラ予測部221およびインター予測部222は、予測処理を行い、予測画像を生成する。つまり、可逆復号部212において判定された、符号化の際に適用された予測モードで予測処理が行われる。より具体的には、例えば、符号化の際にイントラ予測が適用された場合、イントラ予測部221が、符号化の際に最適とされたイントラ予測モードで予測画像を生成する。また、例えば、符号化の際にインター予測が適用された場合、インター予測部222が、符号化の際に最適とされたインター予測モードで予測画像を生成する。
ステップS226において、演算部215は、ステップS225において逆直交変換されて得られた差分画像に、ステップS226において生成された予測画像を加算する。これにより再構成画像の画像データが得られる。
ステップS227において、ループフィルタ216は、ステップS227の処理により得られた再構成画像の画像データに対して、デブロックフィルタ処理や適応ループフィルタ処理等を含むループフィルタ処理を適宜行う。
ステップS228において、画面並べ替えバッファ217は、ステップS227においてフィルタ処理された再構成画像の各フレームの並べ替えを行う。すなわち、符号化の際に並べ替えられたフレームの順序が、元の表示の順序に並べ替えられる。
ステップS229において、D/A変換部218は、ステップS228においてフレームの順序が並べ替えられた画像をD/A変換する。この画像が図示せぬディスプレイに出力され、画像が表示される。
ステップS230において、フレームメモリ219は、ステップS227の処理により得られた復号画像やステップS226の処理により得られた再構成画像等のデータを記憶する。
ステップS230の処理が終了すると、ベースレイヤ復号処理が終了し、処理は図39に戻る。
<エンハンスメントレイヤ復号処理の流れ>
ベースレイヤ復号処理と同様に、以上のような復号負荷定義情報に基づく復号可否判定の結果、復号可能とされた場合、図39のステップS206においてエンハンスメントレイヤ復号処理が実行される。そのエンハンスメントレイヤ復号処理の流れの例を、図42のフローチャートを参照して説明する。
エンハンスメントレイヤ復号処理の各処理(ステップS241乃至ステップS250)は、図41のベースレイヤ復号処理の各処理(ステップS221乃至ステップS230)に対応し、それらの処理と基本的に同様に実行される。ただし、ベースレイヤ復号処理の各処理(ステップS221乃至ステップS230)がベースレイヤに対して行われたのに対し、エンハンスメントレイヤ復号処理の各処理(ステップS241乃至ステップS250)は、エンハンスメントレイヤに対して行われる。
ステップS250の処理が終了すると、エンハンスメントレイヤ復号処理が終了し、処理は、図39に戻る。
以上のように各処理を実行することにより、画像復号装置200は、独立に復号することができる部分領域の復号負荷定義情報を用いることにより、復号に必要な性能をより正確に把握することができる。
本技術の適用範囲は、部分画像を符号化・復号可能なあらゆる画像符号化装置及び画像復号装置に適用することができる。
また、本技術は、例えば、MPEG、H.26x等の様に、離散コサイン変換等の直交変換と動き補償によって圧縮された画像情報(ビットストリーム)を、衛星放送、ケーブルテレビジョン、インターネット、または携帯電話機などのネットワークメディアを介して受信する際に用いられる画像符号化装置および画像復号装置に適用することができる。また、本技術は、光、磁気ディスク、およびフラッシュメモリのような記憶メディア上で処理する際に用いられる画像符号化装置および画像復号装置に適用することができる。
<4.第4の実施の形態>
<多視点画像符号化・多視点画像復号への適用>
上述した一連の処理は、多視点画像符号化・多視点画像復号に適用することができる。図43は、多視点画像符号化方式の一例を示す。
図43に示されるように、多視点画像は、複数の視点(ビュー(view))の画像を含む。この多視点画像の複数のビューは、他のビューの情報を利用せずに自身のビューの画像のみを用いて符号化・復号を行うベースビューと、他のビューの情報を利用して符号化・復号を行うノンベースビューとによりなる。ノンベースビューの符号化・復号は、ベースビューの情報を利用するようにしても良いし、他のノンベースビューの情報を利用するようにしてもよい。
つまり、多視点画像符号化・復号におけるビュー間の参照関係は、階層画像符号化・復号におけるレイヤ間の参照関係と同様である。したがって、図43のような多視点画像の符号化・復号において、上述した方法を適用するようにしてもよい。このようにすることにより、多視点画像の場合も同様に、復号に必要な性能をより正確に把握することができる。
<多視点画像符号化装置>
図44は、上述した多視点画像符号化を行う多視点画像符号化装置を示す図である。図44に示されるように、多視点画像符号化装置600は、符号化部601、符号化部602、および多重化部603を有する。
符号化部601は、ベースビュー画像を符号化し、ベースビュー画像符号化ストリームを生成する。符号化部602は、ノンベースビュー画像を符号化し、ノンベースビュー画像符号化ストリームを生成する。多重化部603は、符号化部601において生成されたベースビュー画像符号化ストリームと、符号化部602において生成されたノンベースビュー画像符号化ストリームとを多重化し、多視点画像符号化ストリームを生成する。
この多視点画像符号化装置600の符号化部601としてベースレイヤ画像符号化部101を適用し、符号化部602としてエンハンスメントレイヤ画像符号化部102を適用してもよい。このようにすることにより、復号に必要な性能をより正確に把握することができる。
<多視点画像復号装置>
図45は、上述した多視点画像復号を行う多視点画像復号装置を示す図である。図45に示されるように、多視点画像復号装置610は、逆多重化部611、復号部612、および復号部613を有する。
逆多重化部611は、ベースビュー画像符号化ストリームとノンベースビュー画像符号化ストリームとが多重化された多視点画像符号化ストリームを逆多重化し、ベースビュー画像符号化ストリームと、ノンベースビュー画像符号化ストリームとを抽出する。復号部612は、逆多重化部611により抽出されたベースビュー画像符号化ストリームを復号し、ベースビュー画像を得る。復号部613は、逆多重化部611により抽出されたノンベースビュー画像符号化ストリームを復号し、ノンベースビュー画像を得る。
この多視点画像復号装置610の復号部612としてベースレイヤ画像復号部202を適用し、復号部613としてエンハンスメントレイヤ画像復号部203を適用してもよい。このようにすることにより、復号に必要な性能をより正確に把握することができる。
<5.第5の実施の形態>
<コンピュータ>
上述した一連の処理は、ハードウエアにより実行させることもできるし、ソフトウエアにより実行させることもできる。一連の処理をソフトウエアにより実行する場合には、そのソフトウエアを構成するプログラムが、コンピュータにインストールされる。ここでコンピュータには、専用のハードウエアに組み込まれているコンピュータや、各種のプログラムをインストールすることで、各種の機能を実行することが可能な、例えば汎用のパーソナルコンピュータ等が含まれる。
図46は、上述した一連の処理をプログラムにより実行するコンピュータのハードウエアの構成例を示すブロック図である。
図46に示されるコンピュータ800において、CPU(Central Processing Unit)801、ROM(Read Only Memory)802、RAM(Random Access Memory)803は、バス804を介して相互に接続されている。
バス804にはまた、入出力インタフェース810も接続されている。入出力インタフェース810には、入力部811、出力部812、記憶部813、通信部814、およびドライブ815が接続されている。
入力部811は、例えば、キーボード、マウス、マイクロホン、タッチパネル、入力端子などよりなる。出力部812は、例えば、ディスプレイ、スピーカ、出力端子などよりなる。記憶部813は、例えば、ハードディスク、RAMディスク、不揮発性のメモリなどよりなる。通信部814は、例えば、ネットワークインタフェースよりなる。ドライブ815は、磁気ディスク、光ディスク、光磁気ディスク、または半導体メモリなどのリムーバブルメディア821を駆動する。
以上のように構成されるコンピュータでは、CPU801が、例えば、記憶部813に記憶されているプログラムを、入出力インタフェース810およびバス804を介して、RAM803にロードして実行することにより、上述した一連の処理が行われる。RAM803にはまた、CPU801が各種の処理を実行する上において必要なデータなども適宜記憶される。
コンピュータ(CPU801)が実行するプログラムは、例えば、パッケージメディア等としてのリムーバブルメディア821に記録して適用することができる。その場合、プログラムは、リムーバブルメディア821をドライブ815に装着することにより、入出力インタフェース810を介して、記憶部813にインストールすることができる。
また、このプログラムは、ローカルエリアネットワーク、インターネット、デジタル衛星放送といった、有線または無線の伝送媒体を介して提供することもできる。その場合、プログラムは、通信部814で受信し、記憶部813にインストールすることができる。
その他、このプログラムは、ROM802や記憶部813に、あらかじめインストールしておくこともできる。
なお、コンピュータが実行するプログラムは、本明細書で説明する順序に沿って時系列に処理が行われるプログラムであっても良いし、並列に、あるいは呼び出しが行われたとき等の必要なタイミングで処理が行われるプログラムであっても良い。
また、本明細書において、記録媒体に記録されるプログラムを記述するステップは、記載された順序に沿って時系列的に行われる処理はもちろん、必ずしも時系列的に処理されなくとも、並列的あるいは個別に実行される処理をも含むものである。
また、本明細書において、システムとは、複数の構成要素(装置、モジュール(部品)等)の集合を意味し、全ての構成要素が同一筐体中にあるか否かは問わない。したがって、別個の筐体に収納され、ネットワークを介して接続されている複数の装置、及び、1つの筐体の中に複数のモジュールが収納されている1つの装置は、いずれも、システムである。
また、以上において、1つの装置(または処理部)として説明した構成を分割し、複数の装置(または処理部)として構成するようにしてもよい。逆に、以上において複数の装置(または処理部)として説明した構成をまとめて1つの装置(または処理部)として構成されるようにしてもよい。また、各装置(または各処理部)の構成に上述した以外の構成を付加するようにしてももちろんよい。さらに、システム全体としての構成や動作が実質的に同じであれば、ある装置(または処理部)の構成の一部を他の装置(または他の処理部)の構成に含めるようにしてもよい。
以上、添付図面を参照しながら本開示の好適な実施形態について詳細に説明したが、本開示の技術的範囲はかかる例に限定されない。本開示の技術分野における通常の知識を有する者であれば、請求の範囲に記載された技術的思想の範疇内において、各種の変更例または修正例に想到し得ることは明らかであり、これらについても、当然に本開示の技術的範囲に属するものと了解される。
例えば、本技術は、1つの機能を、ネットワークを介して複数の装置で分担、共同して処理するクラウドコンピューティングの構成をとることができる。
また、上述のフローチャートで説明した各ステップは、1つの装置で実行する他、複数の装置で分担して実行することができる。
さらに、1つのステップに複数の処理が含まれる場合には、その1つのステップに含まれる複数の処理は、1つの装置で実行する他、複数の装置で分担して実行することができる。
上述した実施形態に係る画像符号化装置及び画像復号装置は、例えば、衛星放送、ケーブルTVなどの有線放送、インターネット上での配信、及びセルラー通信による端末への配信などにおける送信機若しくは受信機、光ディスク、磁気ディスク及びフラッシュメモリなどの媒体に画像を記録する記録装置、又は、これら記憶媒体から画像を再生する再生装置などの様々な電子機器に応用され得る。以下、4つの応用例について説明する。
<6.第6の実施の形態>
<第1の応用例:テレビジョン受像機>
図47は、上述した実施形態を適用したテレビジョン装置の概略的な構成の一例を示している。テレビジョン装置900は、アンテナ901、チューナ902、デマルチプレクサ903、デコーダ904、映像信号処理部905、表示部906、音声信号処理部907、スピーカ908、外部インタフェース(I/F)部909、制御部910、ユーザインタフェース(I/F)部911、及びバス912を備える。
チューナ902は、アンテナ901を介して受信される放送信号から所望のチャンネルの信号を抽出し、抽出した信号を復調する。そして、チューナ902は、復調により得られた符号化ビットストリームをデマルチプレクサ903へ出力する。即ち、チューナ902は、画像が符号化されている符号化ストリームを受信する、テレビジョン装置900における伝送部としての役割を有する。
デマルチプレクサ903は、符号化ビットストリームから視聴対象の番組の映像ストリーム及び音声ストリームを分離し、分離した各ストリームをデコーダ904へ出力する。また、デマルチプレクサ903は、符号化ビットストリームからEPG(Electronic Program Guide)などの補助的なデータを抽出し、抽出したデータを制御部910に供給する。なお、デマルチプレクサ903は、符号化ビットストリームがスクランブルされている場合には、デスクランブルを行ってもよい。
デコーダ904は、デマルチプレクサ903から入力される映像ストリーム及び音声ストリームを復号する。そして、デコーダ904は、復号処理により生成される映像データを映像信号処理部905へ出力する。また、デコーダ904は、復号処理により生成される音声データを音声信号処理部907へ出力する。
映像信号処理部905は、デコーダ904から入力される映像データを再生し、表示部906に映像を表示させる。また、映像信号処理部905は、ネットワークを介して供給されるアプリケーション画面を表示部906に表示させてもよい。また、映像信号処理部905は、映像データについて、設定に応じて、例えばノイズ除去などの追加的な処理を行ってもよい。さらに、映像信号処理部905は、例えばメニュー、ボタン又はカーソルなどのGUI(Graphical User Interface)の画像を生成し、生成した画像を出力画像に重畳してもよい。
表示部906は、映像信号処理部905から供給される駆動信号により駆動され、表示デバイス(例えば、液晶ディスプレイ、プラズマディスプレイ又はOELD(Organic ElectroLuminescence Display)(有機ELディスプレイ)など)の映像面上に映像又は画像を表示する。
音声信号処理部907は、デコーダ904から入力される音声データについてD/A変換及び増幅などの再生処理を行い、スピーカ908から音声を出力させる。また、音声信号処理部907は、音声データについてノイズ除去などの追加的な処理を行ってもよい。
外部インタフェース部909は、テレビジョン装置900と外部機器又はネットワークとを接続するためのインタフェースである。例えば、外部インタフェース部909を介して受信される映像ストリーム又は音声ストリームが、デコーダ904により復号されてもよい。即ち、外部インタフェース部909もまた、画像が符号化されている符号化ストリームを受信する、テレビジョン装置900における伝送部としての役割を有する。
制御部910は、CPUなどのプロセッサ、並びにRAM及びROMなどのメモリを有する。メモリは、CPUにより実行されるプログラム、プログラムデータ、EPGデータ、及びネットワークを介して取得されるデータなどを記憶する。メモリにより記憶されるプログラムは、例えば、テレビジョン装置900の起動時にCPUにより読み込まれ、実行される。CPUは、プログラムを実行することにより、例えばユーザインタフェース部911から入力される操作信号に応じて、テレビジョン装置900の動作を制御する。
ユーザインタフェース部911は、制御部910と接続される。ユーザインタフェース部911は、例えば、ユーザがテレビジョン装置900を操作するためのボタン及びスイッチ、並びに遠隔制御信号の受信部などを有する。ユーザインタフェース部911は、これら構成要素を介してユーザによる操作を検出して操作信号を生成し、生成した操作信号を制御部910へ出力する。
バス912は、チューナ902、デマルチプレクサ903、デコーダ904、映像信号処理部905、音声信号処理部907、外部インタフェース部909及び制御部910を相互に接続する。
このように構成されたテレビジョン装置900において、デコーダ904は、上述した実施形態に係る画像復号装置200の機能を有する。それにより、テレビジョン装置900での画像の復号に必要な性能をより正確に把握することができる。
<第2の応用例:携帯電話機>
図48は、上述した実施形態を適用した携帯電話機の概略的な構成の一例を示している。携帯電話機920は、アンテナ921、通信部922、音声コーデック923、スピーカ924、マイクロホン925、カメラ部926、画像処理部927、多重分離部928、記録再生部929、表示部930、制御部931、操作部932、及びバス933を備える。
アンテナ921は、通信部922に接続される。スピーカ924及びマイクロホン925は、音声コーデック923に接続される。操作部932は、制御部931に接続される。バス933は、通信部922、音声コーデック923、カメラ部926、画像処理部927、多重分離部928、記録再生部929、表示部930、及び制御部931を相互に接続する。
携帯電話機920は、音声通話モード、データ通信モード、撮影モード及びテレビ電話モードを含む様々な動作モードで、音声信号の送受信、電子メール又は画像データの送受信、画像の撮像、及びデータの記録などの動作を行う。
音声通話モードにおいて、マイクロホン925により生成されるアナログ音声信号は、音声コーデック923に供給される。音声コーデック923は、アナログ音声信号を音声データへ変換し、変換された音声データをA/D変換し圧縮する。そして、音声コーデック923は、圧縮後の音声データを通信部922へ出力する。通信部922は、音声データを符号化及び変調し、送信信号を生成する。そして、通信部922は、生成した送信信号を、アンテナ921を介して基地局(図示せず)へ送信する。また、通信部922は、アンテナ921を介して受信される無線信号を増幅し及び周波数変換し、受信信号を取得する。そして、通信部922は、受信信号を復調及び復号して音声データを生成し、生成した音声データを音声コーデック923へ出力する。音声コーデック923は、音声データを伸張し及びD/A変換し、アナログ音声信号を生成する。そして、音声コーデック923は、生成した音声信号をスピーカ924に供給して音声を出力させる。
また、データ通信モードにおいて、例えば、制御部931は、操作部932を介するユーザによる操作に応じて、電子メールを構成する文字データを生成する。また、制御部931は、文字を表示部930に表示させる。また、制御部931は、操作部932を介するユーザからの送信指示に応じて電子メールデータを生成し、生成した電子メールデータを通信部922へ出力する。通信部922は、電子メールデータを符号化及び変調し、送信信号を生成する。そして、通信部922は、生成した送信信号を、アンテナ921を介して基地局(図示せず)へ送信する。また、通信部922は、アンテナ921を介して受信される無線信号を増幅し及び周波数変換し、受信信号を取得する。そして、通信部922は、受信信号を復調及び復号して電子メールデータを復元し、復元した電子メールデータを制御部931へ出力する。制御部931は、表示部930に電子メールの内容を表示させると共に、電子メールデータを記録再生部929に供給し、その記憶媒体に書き込ませる。
記録再生部929は、読み書き可能な任意の記憶媒体を有する。例えば、記憶媒体は、RAM又はフラッシュメモリなどの内蔵型の記憶媒体であってもよく、ハードディスク、磁気ディスク、光磁気ディスク、光ディスク、USB(Universal Serial Bus)メモリ、又はメモリカードなどの外部装着型の記憶媒体であってもよい。
また、撮影モードにおいて、例えば、カメラ部926は、被写体を撮像して画像データを生成し、生成した画像データを画像処理部927へ出力する。画像処理部927は、カメラ部926から入力される画像データを符号化し、符号化ストリームを記録再生部929に供給し、その記憶媒体に書き込ませる。
さらに、画像表示モードにおいて、記録再生部929は、記憶媒体に記録されている符号化ストリームを読み出して画像処理部927へ出力する。画像処理部927は、記録再生部929から入力される符号化ストリームを復号し、画像データを表示部930に供給し、その画像を表示させる。
また、テレビ電話モードにおいて、例えば、多重分離部928は、画像処理部927により符号化された映像ストリームと、音声コーデック923から入力される音声ストリームとを多重化し、多重化したストリームを通信部922へ出力する。通信部922は、ストリームを符号化及び変調し、送信信号を生成する。そして、通信部922は、生成した送信信号を、アンテナ921を介して基地局(図示せず)へ送信する。また、通信部922は、アンテナ921を介して受信される無線信号を増幅し及び周波数変換し、受信信号を取得する。これら送信信号及び受信信号には、符号化ビットストリームが含まれ得る。そして、通信部922は、受信信号を復調及び復号してストリームを復元し、復元したストリームを多重分離部928へ出力する。多重分離部928は、入力されるストリームから映像ストリーム及び音声ストリームを分離し、映像ストリームを画像処理部927、音声ストリームを音声コーデック923へ出力する。画像処理部927は、映像ストリームを復号し、映像データを生成する。映像データは、表示部930に供給され、表示部930により一連の画像が表示される。音声コーデック923は、音声ストリームを伸張し及びD/A変換し、アナログ音声信号を生成する。そして、音声コーデック923は、生成した音声信号をスピーカ924に供給して音声を出力させる。
このように構成された携帯電話機920において、画像処理部927は、上述した実施形態に係る画像符号化装置100や画像復号装置200の機能を有する。それにより、携帯電話機920での復号に必要な性能をより正確に把握することができる。
<第3の応用例:記録再生装置>
図49は、上述した実施形態を適用した記録再生装置の概略的な構成の一例を示している。記録再生装置940は、例えば、受信した放送番組の音声データ及び映像データを符号化して記録媒体に記録する。また、記録再生装置940は、例えば、他の装置から取得される音声データ及び映像データを符号化して記録媒体に記録してもよい。また、記録再生装置940は、例えば、ユーザの指示に応じて、記録媒体に記録されているデータをモニタ及びスピーカ上で再生する。このとき、記録再生装置940は、音声データおよび映像データを復号する。
記録再生装置940は、チューナ941、外部インタフェース(I/F)部942、エンコーダ943、HDD(Hard Disk Drive)944、ディスクドライブ945、セレクタ946、デコーダ947、OSD(On-Screen Display)948、制御部949、およびユーザインタフェース(I/F)部950を備える。
チューナ941は、アンテナ(図示せず)を介して受信される放送信号から所望のチャンネルの信号を抽出し、抽出した信号を復調する。そして、チューナ941は、復調により得られた符号化ビットストリームをセレクタ946へ出力する。即ち、チューナ941は、記録再生装置940における伝送部としての役割を有する。
外部インタフェース部942は、記録再生装置940と外部機器又はネットワークとを接続するためのインタフェースである。外部インタフェース部942は、例えば、IEEE(Institute of Electrical and Electronic Engineers)1394インタフェース、ネットワークインタフェース、USBインタフェース、又はフラッシュメモリインタフェースなどであってよい。例えば、外部インタフェース部942を介して受信される映像データおよび音声データは、エンコーダ943へ入力される。即ち、外部インタフェース部942は、記録再生装置940における伝送部としての役割を有する。
エンコーダ943は、外部インタフェース部942から入力される映像データおよび音声データが符号化されていない場合に、映像データおよび音声データを符号化する。そして、エンコーダ943は、符号化ビットストリームをセレクタ946へ出力する。
HDD944は、映像および音声などのコンテンツデータが圧縮された符号化ビットストリーム、各種プログラムおよびその他のデータを内部のハードディスクに記録する。また、HDD944は、映像および音声の再生時に、これらデータをハードディスクから読み出す。
ディスクドライブ945は、装着されている記録媒体へのデータの記録および読み出しを行う。ディスクドライブ945に装着される記録媒体は、例えばDVD(Digital Versatile Disc)ディスク(DVD-Video、DVD-RAM(DVD - Random Access Memory)、DVD-R(DVD - Recordable)、DVD-RW(DVD - Rewritable)、DVD+R(DVD + Recordable)、DVD+RW(DVD + Rewritable)等)又はBlu-ray(登録商標)ディスクなどであってよい。
セレクタ946は、映像および音声の記録時には、チューナ941又はエンコーダ943から入力される符号化ビットストリームを選択し、選択した符号化ビットストリームをHDD944又はディスクドライブ945へ出力する。また、セレクタ946は、映像及び音声の再生時には、HDD944又はディスクドライブ945から入力される符号化ビットストリームをデコーダ947へ出力する。
デコーダ947は、符号化ビットストリームを復号し、映像データ及び音声データを生成する。そして、デコーダ947は、生成した映像データをOSD948へ出力する。また、デコーダ947は、生成した音声データを外部のスピーカへ出力する。
OSD948は、デコーダ947から入力される映像データを再生し、映像を表示する。また、OSD948は、表示する映像に、例えばメニュー、ボタン又はカーソルなどのGUIの画像を重畳してもよい。
制御部949は、CPUなどのプロセッサ、並びにRAM及びROMなどのメモリを有する。メモリは、CPUにより実行されるプログラム、及びプログラムデータなどを記憶する。メモリにより記憶されるプログラムは、例えば、記録再生装置940の起動時にCPUにより読み込まれ、実行される。CPUは、プログラムを実行することにより、例えばユーザインタフェース部950から入力される操作信号に応じて、記録再生装置940の動作を制御する。
ユーザインタフェース部950は、制御部949と接続される。ユーザインタフェース部950は、例えば、ユーザが記録再生装置940を操作するためのボタンおよびスイッチ、並びに遠隔制御信号の受信部などを有する。ユーザインタフェース部950は、これら構成要素を介してユーザによる操作を検出して操作信号を生成し、生成した操作信号を制御部949へ出力する。
このように構成された記録再生装置940において、エンコーダ943は、上述した実施形態に係る画像符号化装置100の機能を有する。また、デコーダ947は、上述した実施形態に係る画像復号装置200の機能を有する。それにより、記録再生装置940での画像の復号に必要な性能をより正確に把握することができる。
<第4の応用例:撮像装置>
図50は、上述した実施形態を適用した撮像装置の概略的な構成の一例を示している。撮像装置960は、被写体を撮像して画像を生成し、画像データを符号化して記録媒体に記録する。
撮像装置960は、光学ブロック961、撮像部962、信号処理部963、画像処理部964、表示部965、外部インタフェース(I/F)部966、メモリ部967、メディアドライブ968、OSD969、制御部970、ユーザインタフェース(I/F)部971、およびバス972を備える。
光学ブロック961は、撮像部962に接続される。撮像部962は、信号処理部963に接続される。表示部965は、画像処理部964に接続される。ユーザインタフェース部971は、制御部970に接続される。バス972は、画像処理部964、外部インタフェース部966、メモリ部967、メディアドライブ968、OSD969、および制御部970を相互に接続する。
光学ブロック961は、フォーカスレンズ及び絞り機構などを有する。光学ブロック961は、被写体の光学像を撮像部962の撮像面に結像させる。撮像部962は、CCD(Charge Coupled Device)又はCMOS(Complementary Metal Oxide Semiconductor)などのイメージセンサを有し、撮像面に結像した光学像を光電変換によって電気信号としての画像信号に変換する。そして、撮像部962は、画像信号を信号処理部963へ出力する。
信号処理部963は、撮像部962から入力される画像信号に対してニー補正、ガンマ補正、色補正などの種々のカメラ信号処理を行う。信号処理部963は、カメラ信号処理後の画像データを画像処理部964へ出力する。
画像処理部964は、信号処理部963から入力される画像データを符号化し、符号化データを生成する。そして、画像処理部964は、生成した符号化データを外部インタフェース部966またはメディアドライブ968へ出力する。また、画像処理部964は、外部インタフェース部966またはメディアドライブ968から入力される符号化データを復号し、画像データを生成する。そして、画像処理部964は、生成した画像データを表示部965へ出力する。また、画像処理部964は、信号処理部963から入力される画像データを表示部965へ出力して画像を表示させてもよい。また、画像処理部964は、OSD969から取得される表示用データを、表示部965へ出力する画像に重畳してもよい。
OSD969は、例えばメニュー、ボタン又はカーソルなどのGUIの画像を生成して、生成した画像を画像処理部964へ出力する。
外部インタフェース部966は、例えばUSB入出力端子として構成される。外部インタフェース部966は、例えば、画像の印刷時に、撮像装置960とプリンタとを接続する。また、外部インタフェース部966には、必要に応じてドライブが接続される。ドライブには、例えば、磁気ディスク又は光ディスクなどのリムーバブルメディアが装着され、リムーバブルメディアから読み出されるプログラムが、撮像装置960にインストールされ得る。さらに、外部インタフェース部966は、LAN又はインターネットなどのネットワークに接続されるネットワークインタフェースとして構成されてもよい。即ち、外部インタフェース部966は、撮像装置960における伝送部としての役割を有する。
メディアドライブ968に装着される記録媒体は、例えば、磁気ディスク、光磁気ディスク、光ディスク、又は半導体メモリなどの、読み書き可能な任意のリムーバブルメディアであってよい。また、メディアドライブ968に記録媒体が固定的に装着され、例えば、内蔵型ハードディスクドライブ又はSSD(Solid State Drive)のような非可搬性の記憶部が構成されてもよい。
制御部970は、CPUなどのプロセッサ、並びにRAM及びROMなどのメモリを有する。メモリは、CPUにより実行されるプログラム、及びプログラムデータなどを記憶する。メモリにより記憶されるプログラムは、例えば、撮像装置960の起動時にCPUにより読み込まれ、実行される。CPUは、プログラムを実行することにより、例えばユーザインタフェース部971から入力される操作信号に応じて、撮像装置960の動作を制御する。
ユーザインタフェース部971は、制御部970と接続される。ユーザインタフェース部971は、例えば、ユーザが撮像装置960を操作するためのボタン及びスイッチなどを有する。ユーザインタフェース部971は、これら構成要素を介してユーザによる操作を検出して操作信号を生成し、生成した操作信号を制御部970へ出力する。
このように構成された撮像装置960において、画像処理部964は、上述した実施形態に係る画像符号化装置100や画像復号装置200の機能を有する。それにより、撮像装置960での復号に必要な性能をより正確に把握することができる。
<7.第7の実施の形態>
<スケーラブル符号化の応用例:第1のシステム>
次に、スケーラブル符号化(階層(画像)符号化)されたスケーラブル符号化データの具体的な利用例について説明する。スケーラブル符号化は、例えば、図51に示される例のように、伝送するデータの選択のために利用される。
図51に示されるデータ伝送システム1000において、配信サーバ1002は、スケーラブル符号化データ記憶部1001に記憶されているスケーラブル符号化データを読み出し、ネットワーク1003を介して、パーソナルコンピュータ1004、AV機器1005、タブレットデバイス1006、および携帯電話機1007等の端末装置に配信する。
その際、配信サーバ1002は、端末装置の能力や通信環境等に応じて、適切な品質の符号化データを選択して伝送する。配信サーバ1002が不要に高品質なデータを伝送しても、端末装置において高画質な画像を得られるとは限らず、遅延やオーバフローの発生要因となる恐れがある。また、不要に通信帯域を占有したり、端末装置の負荷を不要に増大させたりしてしまう恐れもある。逆に、配信サーバ1002が不要に低品質なデータを伝送しても、端末装置において十分な画質の画像を得ることができない恐れがある。そのため、配信サーバ1002は、スケーラブル符号化データ記憶部1001に記憶されているスケーラブル符号化データを、適宜、端末装置の能力や通信環境等に対して適切な品質の符号化データとして読み出し、伝送する。
例えば、スケーラブル符号化データ記憶部1001は、スケーラブルに符号化されたスケーラブル符号化データ(BL+EL)1011を記憶するとする。このスケーラブル符号化データ(BL+EL)1011は、ベースレイヤとエンハンスメントレイヤの両方を含む符号化データであり、復号することにより、ベースレイヤの画像およびエンハンスメントレイヤの画像の両方を得ることができるデータである。
配信サーバ1002は、データを伝送する端末装置の能力や通信環境等に応じて、適切なレイヤを選択し、そのレイヤのデータを読み出す。例えば、配信サーバ1002は、処理能力の高いパーソナルコンピュータ1004やタブレットデバイス1006に対しては、高品質なスケーラブル符号化データ(BL+EL)1011をスケーラブル符号化データ記憶部1001から読み出し、そのまま伝送する。これに対して、例えば、配信サーバ1002は、処理能力の低いAV機器1005や携帯電話機1007に対しては、スケーラブル符号化データ(BL+EL)1011からベースレイヤのデータを抽出し、スケーラブル符号化データ(BL+EL)1011と同じコンテンツのデータであるが、スケーラブル符号化データ(BL+EL)1011よりも低品質なスケーラブル符号化データ(BL)1012として伝送する。
このようにスケーラブル符号化データを用いることにより、データ量を容易に調整することができるので、遅延やオーバフローの発生を抑制したり、端末装置や通信媒体の負荷の不要な増大を抑制したりすることができる。また、スケーラブル符号化データ(BL+EL)1011は、レイヤ間の冗長性が低減されているので、各レイヤの符号化データを個別のデータとする場合よりもそのデータ量を低減させることができる。したがって、スケーラブル符号化データ記憶部1001の記憶領域をより効率よく使用することができる。
なお、パーソナルコンピュータ1004乃至携帯電話機1007のように、端末装置には様々な装置を適用することができるので、端末装置のハードウエアの性能は、装置によって異なる。また、端末装置が実行するアプリケーションも様々であるので、そのソフトウエアの能力も様々である。さらに、通信媒体となるネットワーク1003も、例えばインターネットやLAN(Local Area Network)等、有線若しくは無線、またはその両方を含むあらゆる通信回線網を適用することができ、そのデータ伝送能力は様々である。さらに、他の通信等によっても変化する恐れがある。
そこで、配信サーバ1002は、データ伝送を開始する前に、データの伝送先となる端末装置と通信を行い、端末装置のハードウエア性能や、端末装置が実行するアプリケーション(ソフトウエア)の性能等といった端末装置の能力に関する情報、並びに、ネットワーク1003の利用可能帯域幅等の通信環境に関する情報を得るようにしてもよい。そして、配信サーバ1002が、ここで得た情報を基に、適切なレイヤを選択するようにしてもよい。
なお、レイヤの抽出は、端末装置において行うようにしてもよい。例えば、パーソナルコンピュータ1004が、伝送されたスケーラブル符号化データ(BL+EL)1011を復号し、ベースレイヤの画像を表示しても良いし、エンハンスメントレイヤの画像を表示しても良い。また、例えば、パーソナルコンピュータ1004が、伝送されたスケーラブル符号化データ(BL+EL)1011から、ベースレイヤのスケーラブル符号化データ(BL)1012を抽出し、記憶したり、他の装置に転送したり、復号してベースレイヤの画像を表示したりするようにしてもよい。
もちろん、スケーラブル符号化データ記憶部1001、配信サーバ1002、ネットワーク1003、および端末装置の数はいずれも任意である。また、以上においては、配信サーバ1002がデータを端末装置に伝送する例について説明したが、利用例はこれに限定されない。データ伝送システム1000は、スケーラブル符号化された符号化データを端末装置に伝送する際、端末装置の能力や通信環境等に応じて、適切なレイヤを選択して伝送するシステムであれば、任意のシステムに適用することができる。
そして、図51のようなデータ伝送システム1000においても、図1乃至図42を参照して上述した階層符号化・階層復号への適用と同様に本技術を適用することにより、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
<スケーラブル符号化の応用例:第2のシステム>
また、スケーラブル符号化は、例えば、図52に示される例のように、複数の通信媒体を介する伝送のために利用される。
図52に示されるデータ伝送システム1100において、放送局1101は、地上波放送1111により、ベースレイヤのスケーラブル符号化データ(BL)1121を伝送する。また、放送局1101は、有線若しくは無線またはその両方の通信網よりなる任意のネットワーク1112を介して、エンハンスメントレイヤのスケーラブル符号化データ(EL)1122を伝送する(例えばパケット化して伝送する)。
端末装置1102は、放送局1101が放送する地上波放送1111の受信機能を有し、この地上波放送1111を介して伝送されるベースレイヤのスケーラブル符号化データ(BL)1121を受け取る。また、端末装置1102は、ネットワーク1112を介した通信を行う通信機能をさらに有し、このネットワーク1112を介して伝送されるエンハンスメントレイヤのスケーラブル符号化データ(EL)1122を受け取る。
端末装置1102は、例えばユーザ指示等に応じて、地上波放送1111を介して取得したベースレイヤのスケーラブル符号化データ(BL)1121を、復号してベースレイヤの画像を得たり、記憶したり、他の装置に伝送したりする。
また、端末装置1102は、例えばユーザ指示等に応じて、地上波放送1111を介して取得したベースレイヤのスケーラブル符号化データ(BL)1121と、ネットワーク1112を介して取得したエンハンスメントレイヤのスケーラブル符号化データ(EL)1122とを合成して、スケーラブル符号化データ(BL+EL)を得たり、それを復号してエンハンスメントレイヤの画像を得たり、記憶したり、他の装置に伝送したりする。
以上のように、スケーラブル符号化データは、例えばレイヤ毎に異なる通信媒体を介して伝送させることができる。したがって、負荷を分散させることができ、遅延やオーバフローの発生を抑制することができる。
また、状況に応じて、伝送に使用する通信媒体を、レイヤ毎に選択することができるようにしてもよい。例えば、データ量が比較的多いベースレイヤのスケーラブル符号化データ(BL)1121を帯域幅の広い通信媒体を介して伝送させ、データ量が比較的少ないエンハンスメントレイヤのスケーラブル符号化データ(EL)1122を帯域幅の狭い通信媒体を介して伝送させるようにしてもよい。また、例えば、エンハンスメントレイヤのスケーラブル符号化データ(EL)1122を伝送する通信媒体を、ネットワーク1112とするか、地上波放送1111とするかを、ネットワーク1112の利用可能帯域幅に応じて切り替えるようにしてもよい。もちろん、任意のレイヤのデータについて同様である。
このように制御することにより、データ伝送における負荷の増大を、より抑制することができる。
もちろん、レイヤ数は任意であり、伝送に利用する通信媒体の数も任意である。また、データ配信先となる端末装置1102の数も任意である。さらに、以上においては、放送局1101からの放送を例に説明したが、利用例はこれに限定されない。データ伝送システム1100は、スケーラブル符号化された符号化データを、レイヤを単位として複数に分割し、複数の回線を介して伝送するシステムであれば、任意のシステムに適用することができる。
そして、以上のような43のようなデータ伝送システム1100においても、図1乃至図42を参照して上述した階層符号化・階層復号への適用と同様に本技術を適用することにより、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
<スケーラブル符号化の応用例:第3のシステム>
また、スケーラブル符号化は、例えば、図53に示される例のように、符号化データの記憶に利用される。
図53に示される撮像システム1200において、撮像装置1201は、被写体1211を撮像して得られた画像データをスケーラブル符号化し、スケーラブル符号化データ(BL+EL)1221として、スケーラブル符号化データ記憶装置1202に供給する。
スケーラブル符号化データ記憶装置1202は、撮像装置1201から供給されるスケーラブル符号化データ(BL+EL)1221を、状況に応じた品質で記憶する。例えば、通常時の場合、スケーラブル符号化データ記憶装置1202は、スケーラブル符号化データ(BL+EL)1221からベースレイヤのデータを抽出し、低品質でデータ量の少ないベースレイヤのスケーラブル符号化データ(BL)1222として記憶する。これに対して、例えば、注目時の場合、スケーラブル符号化データ記憶装置1202は、高品質でデータ量の多いスケーラブル符号化データ(BL+EL)1221のまま記憶する。
このようにすることにより、スケーラブル符号化データ記憶装置1202は、必要な場合のみ、画像を高画質に保存することができるので、画質劣化による画像の価値の低減を抑制しながら、データ量の増大を抑制することができ、記憶領域の利用効率を向上させることができる。
例えば、撮像装置1201が監視カメラであるとする。撮像画像に監視対象(例えば侵入者)が写っていない場合(通常時の場合)、撮像画像の内容は重要でない可能性が高いので、データ量の低減が優先され、その画像データ(スケーラブル符号化データ)は、低品質に記憶される。これに対して、撮像画像に監視対象が被写体1211として写っている場合(注目時の場合)、その撮像画像の内容は重要である可能性が高いので、画質が優先され、その画像データ(スケーラブル符号化データ)は、高品質に記憶される。
なお、通常時であるか注目時であるかは、例えば、スケーラブル符号化データ記憶装置1202が、画像を解析することにより判定しても良い。また、撮像装置1201が判定し、その判定結果をスケーラブル符号化データ記憶装置1202に伝送するようにしてもよい。
なお、通常時であるか注目時であるかの判定基準は任意であり、判定基準とする画像の内容は任意である。もちろん、画像の内容以外の条件を判定基準とすることもできる。例えば、収録した音声の大きさや波形等に応じて切り替えるようにしてもよいし、所定の時間毎に切り替えるようにしてもよいし、ユーザ指示等の外部からの指示によって切り替えるようにしてもよい。
また、以上においては、通常時と注目時の2つの状態を切り替える例を説明したが、状態の数は任意であり、例えば、通常時、やや注目時、注目時、非常に注目時等のように、3つ以上の状態を切り替えるようにしてもよい。ただし、この切り替える状態の上限数は、スケーラブル符号化データのレイヤ数に依存する。
また、撮像装置1201が、スケーラブル符号化のレイヤ数を、状態に応じて決定するようにしてもよい。例えば、通常時の場合、撮像装置1201が、低品質でデータ量の少ないベースレイヤのスケーラブル符号化データ(BL)1222を生成し、スケーラブル符号化データ記憶装置1202に供給するようにしてもよい。また、例えば、注目時の場合、撮像装置1201が、高品質でデータ量の多いベースレイヤのスケーラブル符号化データ(BL+EL)1221を生成し、スケーラブル符号化データ記憶装置1202に供給するようにしてもよい。
以上においては、監視カメラを例に説明したが、この撮像システム1200の用途は任意であり、監視カメラに限定されない。
そして、図53のような撮像システム1200においても、図1乃至図42を参照して上述した階層符号化・階層復号への適用と同様に本技術を適用することにより、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
なお、本技術は、予め用意された解像度等が互いに異なる複数の符号化データの中から適切なものをセグメント単位で選択して使用する、例えばMPEG DASH等のようなHTTPストリーミングにも適用することができる。つまり、このような複数の符号化データ間で、符号化や復号に関する情報を共有することもできる。
<8.第8の実施の形態>
<実施のその他の例>
以上において本技術を適用する装置やシステム等の例を説明したが、本技術は、これに限らず、このような装置またはシステムを構成する装置に搭載するあらゆる構成、例えば、システムLSI(Large Scale Integration)等としてのプロセッサ、複数のプロセッサ等を用いるモジュール、複数のモジュール等を用いるユニット、ユニットにさらにその他の機能を付加したセット等(すなわち、装置の一部の構成)として実施することもできる。
<ビデオセット>
本技術をセットとして実施する場合の例について、図54を参照して説明する。図54は、本技術を適用したビデオセットの概略的な構成の一例を示している。
近年、電子機器の多機能化が進んでおり、その開発や製造において、その一部の構成を販売や提供等として実施する場合、1機能を有する構成として実施を行う場合だけでなく、関連する機能を有する複数の構成を組み合わせ、複数の機能を有する1セットとして実施を行う場合も多く見られるようになってきた。
図54に示されるビデオセット1300は、このような多機能化された構成であり、画像の符号化や復号(いずれか一方でもよいし、両方でも良い)に関する機能を有するデバイスに、その機能に関連するその他の機能を有するデバイスを組み合わせたものである。
図54に示されるように、ビデオセット1300は、ビデオモジュール1311、外部メモリ1312、パワーマネージメントモジュール1313、およびフロントエンドモジュール1314等のモジュール群と、コネクティビティ1321、カメラ1322、およびセンサ1323等の関連する機能を有するデバイスとを有する。
モジュールは、互いに関連するいくつかの部品的機能をまとめ、まとまりのある機能を持った部品としたものである。具体的な物理的構成は任意であるが、例えば、それぞれ機能を有する複数のプロセッサ、抵抗やコンデンサ等の電子回路素子、その他のデバイス等を配線基板等に配置して一体化したものが考えられる。また、モジュールに他のモジュールやプロセッサ等を組み合わせて新たなモジュールとすることも考えられる。
図54の例の場合、ビデオモジュール1311は、画像処理に関する機能を有する構成を組み合わせたものであり、アプリケーションプロセッサ、ビデオプロセッサ、ブロードバンドモデム1333、およびRFモジュール1334を有する。
プロセッサは、所定の機能を有する構成をSoC(System On a Chip)により半導体チップに集積したものであり、例えばシステムLSI(Large Scale Integration)等と称されるものもある。この所定の機能を有する構成は、論理回路(ハードウエア構成)であってもよいし、CPU、ROM、RAM等と、それらを用いて実行されるプログラム(ソフトウエア構成)であってもよいし、その両方を組み合わせたものであってもよい。例えば、プロセッサが、論理回路とCPU、ROM、RAM等とを有し、機能の一部を論理回路(ハードウエア構成)により実現し、その他の機能をCPUにおいて実行されるプログラム(ソフトウエア構成)により実現するようにしてもよい。
図54のアプリケーションプロセッサ1331は、画像処理に関するアプリケーションを実行するプロセッサである。このアプリケーションプロセッサ1331において実行されるアプリケーションは、所定の機能を実現するために、演算処理を行うだけでなく、例えばビデオプロセッサ1332等、ビデオモジュール1311内外の構成を必要に応じて制御することもできる。
ビデオプロセッサ1332は、画像の符号化・復号(その一方若しくは両方)に関する機能を有するプロセッサである。
ブロードバンドモデム1333は、インターネットや公衆電話回線網等の広帯域の回線を介して行われる有線若しくは無線(またはその両方)の広帯域通信により送信するデータ(デジタル信号)をデジタル変調する等してアナログ信号に変換したり、その広帯域通信により受信したアナログ信号を復調してデータ(デジタル信号)に変換したりする。ブロードバンドモデム1333は、例えば、ビデオプロセッサ1332が処理する画像データ、画像データが符号化されたストリーム、アプリケーションプログラム、設定データ等、任意の情報を処理する。
RFモジュール1334は、アンテナを介して送受信されるRF(Radio Frequency)信号に対して、周波数変換、変復調、増幅、フィルタ処理等を行うモジュールである。例えば、RFモジュール1334は、ブロードバンドモデム1333により生成されたベースバンド信号に対して周波数変換等を行ってRF信号を生成する。また、例えば、RFモジュール1334は、フロントエンドモジュール1314を介して受信されたRF信号に対して周波数変換等を行ってベースバンド信号を生成する。
なお、図54において点線1341に示されるように、アプリケーションプロセッサ1331とビデオプロセッサ1332を、一体化し、1つのプロセッサとして構成されるようにしてもよい。
外部メモリ1312は、ビデオモジュール1311の外部に設けられた、ビデオモジュール1311により利用される記憶デバイスを有するモジュールである。この外部メモリ1312の記憶デバイスは、どのような物理構成により実現するようにしてもよいが、一般的にフレーム単位の画像データのような大容量のデータの格納に利用されることが多いので、例えばDRAM(Dynamic Random Access Memory)のような比較的安価で大容量の半導体メモリにより実現するのが望ましい。
パワーマネージメントモジュール1313は、ビデオモジュール1311(ビデオモジュール1311内の各構成)への電力供給を管理し、制御する。
フロントエンドモジュール1314は、RFモジュール1334に対してフロントエンド機能(アンテナ側の送受信端の回路)を提供するモジュールである。図54に示されるように、フロントエンドモジュール1314は、例えば、アンテナ部1351、フィルタ1352、および増幅部1353を有する。
アンテナ部1351は、無線信号を送受信するアンテナおよびその周辺の構成を有する。アンテナ部1351は、増幅部1353から供給される信号を無線信号として送信し、受信した無線信号を電気信号(RF信号)としてフィルタ1352に供給する。フィルタ1352は、アンテナ部1351を介して受信されたRF信号に対してフィルタ処理等を行い、処理後のRF信号をRFモジュール1334に供給する。増幅部1353は、RFモジュール1334から供給されるRF信号を増幅し、アンテナ部1351に供給する。
コネクティビティ1321は、外部との接続に関する機能を有するモジュールである。コネクティビティ1321の物理構成は、任意である。例えば、コネクティビティ1321は、ブロードバンドモデム1333が対応する通信規格以外の通信機能を有する構成や、外部入出力端子等を有する。
例えば、コネクティビティ1321が、Bluetooth(登録商標)、IEEE 802.11(例えばWi-Fi(Wireless Fidelity、登録商標))、NFC(Near Field Communication)、IrDA(InfraRed Data Association)等の無線通信規格に準拠する通信機能を有するモジュールや、その規格に準拠した信号を送受信するアンテナ等を有するようにしてもよい。また、例えば、コネクティビティ1321が、USB(Universal Serial Bus)、HDMI(登録商標)(High-Definition Multimedia Interface)等の有線通信規格に準拠する通信機能を有するモジュールや、その規格に準拠した端子を有するようにしてもよい。さらに、例えば、コネクティビティ1321が、アナログ入出力端子等のその他のデータ(信号)伝送機能等を有するようにしてもよい。
なお、コネクティビティ1321が、データ(信号)の伝送先のデバイスを含むようにしてもよい。例えば、コネクティビティ1321が、磁気ディスク、光ディスク、光磁気ディスク、または半導体メモリ等の記録媒体に対してデータの読み出しや書き込みを行うドライブ(リムーバブルメディアのドライブだけでなく、ハードディスク、SSD(Solid State Drive)、NAS(Network Attached Storage)等も含む)を有するようにしてもよい。また、コネクティビティ1321が、画像や音声の出力デバイス(モニタやスピーカ等)を有するようにしてもよい。
カメラ1322は、被写体を撮像し、被写体の画像データを得る機能を有するモジュールである。カメラ1322の撮像により得られた画像データは、例えば、ビデオプロセッサ1332に供給されて符号化される。
センサ1323は、例えば、音声センサ、超音波センサ、光センサ、照度センサ、赤外線センサ、イメージセンサ、回転センサ、角度センサ、角速度センサ、速度センサ、加速度センサ、傾斜センサ、磁気識別センサ、衝撃センサ、温度センサ等、任意のセンサ機能を有するモジュールである。センサ1323により検出されたデータは、例えば、アプリケーションプロセッサ1331に供給されてアプリケーション等により利用される。
以上においてモジュールとして説明した構成をプロセッサとして実現するようにしてもよいし、逆にプロセッサとして説明した構成をモジュールとして実現するようにしてもよい。
以上のような構成のビデオセット1300において、後述するようにビデオプロセッサ1332に本技術を適用することができる。したがって、ビデオセット1300は、本技術を適用したセットとして実施することができる。
<ビデオプロセッサの構成例>
図55は、本技術を適用したビデオプロセッサ1332(図54)の概略的な構成の一例を示している。
図55の例の場合、ビデオプロセッサ1332は、ビデオ信号およびオーディオ信号の入力を受けてこれらを所定の方式で符号化する機能と、符号化されたビデオデータおよびオーディオデータを復号し、ビデオ信号およびオーディオ信号を再生出力する機能とを有する。
図55に示されるように、ビデオプロセッサ1332は、ビデオ入力処理部1401、第1画像拡大縮小部1402、第2画像拡大縮小部1403、ビデオ出力処理部1404、フレームメモリ1405、およびメモリ制御部1406を有する。また、ビデオプロセッサ1332は、エンコード・デコードエンジン1407、ビデオES(Elementary Stream)バッファ1408Aおよび1408B、並びに、オーディオESバッファ1409Aおよび1409Bを有する。さらに、ビデオプロセッサ1332は、オーディオエンコーダ1410、オーディオデコーダ1411、多重化部(MUX(Multiplexer))1412、逆多重化部(DMUX(Demultiplexer))1413、およびストリームバッファ1414を有する。
ビデオ入力処理部1401は、例えばコネクティビティ1321(図54)等から入力されたビデオ信号を取得し、デジタル画像データに変換する。第1画像拡大縮小部1402は、画像データに対してフォーマット変換や画像の拡大縮小処理等を行う。第2画像拡大縮小部1403は、画像データに対して、ビデオ出力処理部1404を介して出力する先でのフォーマットに応じて画像の拡大縮小処理を行ったり、第1画像拡大縮小部1402と同様のフォーマット変換や画像の拡大縮小処理等を行ったりする。ビデオ出力処理部1404は、画像データに対して、フォーマット変換やアナログ信号への変換等を行って、再生されたビデオ信号として例えばコネクティビティ1321等に出力する。
フレームメモリ1405は、ビデオ入力処理部1401、第1画像拡大縮小部1402、第2画像拡大縮小部1403、ビデオ出力処理部1404、およびエンコード・デコードエンジン1407によって共用される画像データ用のメモリである。フレームメモリ1405は、例えばDRAM等の半導体メモリとして実現される。
メモリ制御部1406は、エンコード・デコードエンジン1407からの同期信号を受けて、アクセス管理テーブル1406Aに書き込まれたフレームメモリ1405へのアクセススケジュールに従ってフレームメモリ1405に対する書き込み・読み出しのアクセスを制御する。アクセス管理テーブル1406Aは、エンコード・デコードエンジン1407、第1画像拡大縮小部1402、第2画像拡大縮小部1403等で実行される処理に応じて、メモリ制御部1406により更新される。
エンコード・デコードエンジン1407は、画像データのエンコード処理、並びに、画像データが符号化されたデータであるビデオストリームのデコード処理を行う。例えば、エンコード・デコードエンジン1407は、フレームメモリ1405から読み出した画像データを符号化し、ビデオストリームとしてビデオESバッファ1408Aに順次書き込む。また、例えば、ビデオESバッファ1408Bからビデオストリームを順次読み出して復号し、画像データとしてフレームメモリ1405に順次書き込む。エンコード・デコードエンジン1407は、これらの符号化や復号において、フレームメモリ1405を作業領域として使用する。また、エンコード・デコードエンジン1407は、例えばマクロブロック毎の処理を開始するタイミングで、メモリ制御部1406に対して同期信号を出力する。
ビデオESバッファ1408Aは、エンコード・デコードエンジン1407によって生成されたビデオストリームをバッファリングして、多重化部(MUX)1412に供給する。ビデオESバッファ1408Bは、逆多重化部(DMUX)1413から供給されたビデオストリームをバッファリングして、エンコード・デコードエンジン1407に供給する。
オーディオESバッファ1409Aは、オーディオエンコーダ1410によって生成されたオーディオストリームをバッファリングして、多重化部(MUX)1412に供給する。オーディオESバッファ1409Bは、逆多重化部(DMUX)1413から供給されたオーディオストリームをバッファリングして、オーディオデコーダ1411に供給する。
オーディオエンコーダ1410は、例えばコネクティビティ1321等から入力されたオーディオ信号を例えばデジタル変換し、例えばMPEGオーディオ方式やAC3(AudioCode number 3)方式等の所定の方式で符号化する。オーディオエンコーダ1410は、オーディオ信号が符号化されたデータであるオーディオストリームをオーディオESバッファ1409Aに順次書き込む。オーディオデコーダ1411は、オーディオESバッファ1409Bから供給されたオーディオストリームを復号し、例えばアナログ信号への変換等を行って、再生されたオーディオ信号として例えばコネクティビティ1321等に供給する。
多重化部(MUX)1412は、ビデオストリームとオーディオストリームとを多重化する。この多重化の方法(すなわち、多重化により生成されるビットストリームのフォーマット)は任意である。また、この多重化の際に、多重化部(MUX)1412は、所定のヘッダ情報等をビットストリームに付加することもできる。つまり、多重化部(MUX)1412は、多重化によりストリームのフォーマットを変換することができる。例えば、多重化部(MUX)1412は、ビデオストリームとオーディオストリームとを多重化することにより、転送用のフォーマットのビットストリームであるトランスポートストリームに変換する。また、例えば、多重化部(MUX)1412は、ビデオストリームとオーディオストリームとを多重化することにより、記録用のファイルフォーマットのデータ(ファイルデータ)に変換する。
逆多重化部(DMUX)1413は、多重化部(MUX)1412による多重化に対応する方法で、ビデオストリームとオーディオストリームとが多重化されたビットストリームを逆多重化する。つまり、逆多重化部(DMUX)1413は、ストリームバッファ1414から読み出されたビットストリームからビデオストリームとオーディオストリームとを抽出する(ビデオストリームとオーディオストリームとを分離する)。つまり、逆多重化部(DMUX)1413は、逆多重化によりストリームのフォーマットを変換(多重化部(MUX)1412による変換の逆変換)することができる。例えば、逆多重化部(DMUX)1413は、例えばコネクティビティ1321やブロードバンドモデム1333等から供給されたトランスポートストリームを、ストリームバッファ1414を介して取得し、逆多重化することにより、ビデオストリームとオーディオストリームとに変換することができる。また、例えば、逆多重化部(DMUX)1413は、例えばコネクティビティ1321により各種記録媒体から読み出されたファイルデータを、ストリームバッファ1414を介して取得し、逆多重化することにより、ビデオストリームとオーディオストリームとに変換することができる。
ストリームバッファ1414は、ビットストリームをバッファリングする。例えば、ストリームバッファ1414は、多重化部(MUX)1412から供給されたトランスポートストリームをバッファリングし、所定のタイミングにおいて、若しくは外部からの要求等に基づいて、例えばコネクティビティ1321やブロードバンドモデム1333等に供給する。
また、例えば、ストリームバッファ1414は、多重化部(MUX)1412から供給されたファイルデータをバッファリングし、所定のタイミングにおいて、若しくは外部からの要求等に基づいて、例えばコネクティビティ1321等に供給し、各種記録媒体に記録させる。
さらに、ストリームバッファ1414は、例えばコネクティビティ1321やブロードバンドモデム1333等を介して取得したトランスポートストリームをバッファリングし、所定のタイミングにおいて、若しくは外部からの要求等に基づいて、逆多重化部(DMUX)1413に供給する。
また、ストリームバッファ1414は、例えばコネクティビティ1321等において各種記録媒体から読み出されたファイルデータをバッファリングし、所定のタイミングにおいて、若しくは外部からの要求等に基づいて、逆多重化部(DMUX)1413に供給する。
次に、このような構成のビデオプロセッサ1332の動作の例について説明する。例えば、コネクティビティ1321等からビデオプロセッサ1332に入力されたビデオ信号は、ビデオ入力処理部1401において4:2:2Y/Cb/Cr方式等の所定の方式のデジタル画像データに変換され、フレームメモリ1405に順次書き込まれる。このデジタル画像データは、第1画像拡大縮小部1402または第2画像拡大縮小部1403に読み出されて、4:2:0Y/Cb/Cr方式等の所定の方式へのフォーマット変換および拡大縮小処理が行われ、再びフレームメモリ1405に書き込まれる。この画像データは、エンコード・デコードエンジン1407によって符号化され、ビデオストリームとしてビデオESバッファ1408Aに書き込まれる。
また、コネクティビティ1321等からビデオプロセッサ1332に入力されたオーディオ信号は、オーディオエンコーダ1410によって符号化され、オーディオストリームとして、オーディオESバッファ1409Aに書き込まれる。
ビデオESバッファ1408Aのビデオストリームと、オーディオESバッファ1409Aのオーディオストリームは、多重化部(MUX)1412に読み出されて多重化され、トランスポートストリーム若しくはファイルデータ等に変換される。多重化部(MUX)1412により生成されたトランスポートストリームは、ストリームバッファ1414にバッファされた後、例えばコネクティビティ1321やブロードバンドモデム1333等を介して外部ネットワークに出力される。また、多重化部(MUX)1412により生成されたファイルデータは、ストリームバッファ1414にバッファされた後、例えばコネクティビティ1321等に出力され、各種記録媒体に記録される。
また、例えばコネクティビティ1321やブロードバンドモデム1333等を介して外部ネットワークからビデオプロセッサ1332に入力されたトランスポートストリームは、ストリームバッファ1414にバッファされた後、逆多重化部(DMUX)1413により逆多重化される。また、例えばコネクティビティ1321等において各種記録媒体から読み出され、ビデオプロセッサ1332に入力されたファイルデータは、ストリームバッファ1414にバッファされた後、逆多重化部(DMUX)1413により逆多重化される。つまり、ビデオプロセッサ1332に入力されたトランスポートストリームまたはファイルデータは、逆多重化部(DMUX)1413によりビデオストリームとオーディオストリームとに分離される。
オーディオストリームは、オーディオESバッファ1409Bを介してオーディオデコーダ1411に供給され、復号されてオーディオ信号が再生される。また、ビデオストリームは、ビデオESバッファ1408Bに書き込まれた後、エンコード・デコードエンジン1407により順次読み出されて復号されてフレームメモリ1405に書き込まれる。復号された画像データは、第2画像拡大縮小部1403によって拡大縮小処理されて、フレームメモリ1405に書き込まれる。そして、復号された画像データは、ビデオ出力処理部1404に読み出されて、4:2:2Y/Cb/Cr方式等の所定の方式にフォーマット変換され、さらにアナログ信号に変換されて、ビデオ信号が再生出力される。
このように構成されるビデオプロセッサ1332に本技術を適用する場合、エンコード・デコードエンジン1407に、上述した各実施形態に係る本技術を適用すればよい。つまり、例えば、エンコード・デコードエンジン1407が、上述した実施の形態に係る画像符号化装置100や画像復号装置200の機能を有するようにすればよい。このようにすることにより、ビデオプロセッサ1332は、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
なお、エンコード・デコードエンジン1407において、本技術(すなわち、上述した各実施形態に係る画像符号化装置や画像復号装置の機能)は、論理回路等のハードウエアにより実現するようにしてもよいし、組み込みプログラム等のソフトウエアにより実現するようにしてもよいし、それらの両方により実現するようにしてもよい。
<ビデオプロセッサの他の構成例>
図56は、本技術を適用したビデオプロセッサ1332の概略的な構成の他の例を示している。図56の例の場合、ビデオプロセッサ1332は、ビデオデータを所定の方式で符号化・復号する機能とを有する。
より具体的には、図56に示されるように、ビデオプロセッサ1332は、制御部1511、ディスプレイインタフェース1512、ディスプレイエンジン1513、画像処理エンジン1514、および内部メモリ1515を有する。また、ビデオプロセッサ1332は、コーデックエンジン1516、メモリインタフェース1517、多重化・逆多重化部(MUX DMUX)1518、ネットワークインタフェース1519、およびビデオインタフェース1520を有する。
制御部1511は、ディスプレイインタフェース1512、ディスプレイエンジン1513、画像処理エンジン1514、およびコーデックエンジン1516等、ビデオプロセッサ1332内の各処理部の動作を制御する。
図56に示されるように、制御部1511は、例えば、メインCPU1531、サブCPU1532、およびシステムコントローラ1533を有する。メインCPU1531は、ビデオプロセッサ1332内の各処理部の動作を制御するためのプログラム等を実行する。メインCPU1531は、そのプログラム等に従って制御信号を生成し、各処理部に供給する(つまり、各処理部の動作を制御する)。サブCPU1532は、メインCPU1531の補助的な役割を果たす。例えば、サブCPU1532は、メインCPU1531が実行するプログラム等の子プロセスやサブルーチン等を実行する。システムコントローラ1533は、メインCPU1531およびサブCPU1532が実行するプログラムを指定する等、メインCPU1531およびサブCPU1532の動作を制御する。
ディスプレイインタフェース1512は、制御部1511の制御の下、画像データを例えばコネクティビティ1321等に出力する。例えば、ディスプレイインタフェース1512は、デジタルデータの画像データをアナログ信号に変換し、再生されたビデオ信号として、またはデジタルデータの画像データのまま、コネクティビティ1321のモニタ装置等に出力する。
ディスプレイエンジン1513は、制御部1511の制御の下、画像データに対して、その画像を表示させるモニタ装置等のハードウエアスペックに合わせるように、フォーマット変換、サイズ変換、色域変換等の各種変換処理を行う。
画像処理エンジン1514は、制御部1511の制御の下、画像データに対して、例えば画質改善のためのフィルタ処理等、所定の画像処理を施す。
内部メモリ1515は、ディスプレイエンジン1513、画像処理エンジン1514、およびコーデックエンジン1516により共用される、ビデオプロセッサ1332の内部に設けられたメモリである。内部メモリ1515は、例えば、ディスプレイエンジン1513、画像処理エンジン1514、およびコーデックエンジン1516の間で行われるデータの授受に利用される。例えば、内部メモリ1515は、ディスプレイエンジン1513、画像処理エンジン1514、またはコーデックエンジン1516から供給されるデータを格納し、必要に応じて(例えば、要求に応じて)、そのデータを、ディスプレイエンジン1513、画像処理エンジン1514、またはコーデックエンジン1516に供給する。この内部メモリ1515は、どのような記憶デバイスにより実現するようにしてもよいが、一般的にブロック単位の画像データやパラメータ等といった小容量のデータの格納に利用することが多いので、例えばSRAM(Static Random Access Memory)のような比較的(例えば外部メモリ1312と比較して)小容量だが応答速度が高速な半導体メモリにより実現するのが望ましい。
コーデックエンジン1516は、画像データの符号化や復号に関する処理を行う。このコーデックエンジン1516が対応する符号化・復号の方式は任意であり、その数は1つであってもよいし、複数であってもよい。例えば、コーデックエンジン1516は、複数の符号化・復号方式のコーデック機能を備え、その中から選択されたもので画像データの符号化若しくは符号化データの復号を行うようにしてもよい。
図56に示される例において、コーデックエンジン1516は、コーデックに関する処理の機能ブロックとして、例えば、MPEG-2 Video1541、AVC/H.2641542、HEVC/H.2651543、HEVC/H.265(Scalable)1544、HEVC/H.265(Multi-view)1545、およびMPEG-DASH1551を有する。
MPEG-2 Video1541は、画像データをMPEG-2方式で符号化したり復号したりする機能ブロックである。AVC/H.2641542は、画像データをAVC方式で符号化したり復号したりする機能ブロックである。HEVC/H.2651543は、画像データをHEVC方式で符号化したり復号したりする機能ブロックである。HEVC/H.265(Scalable)1544は、画像データをHEVC方式でスケーラブル符号化したりスケーラブル復号したりする機能ブロックである。HEVC/H.265(Multi-view)1545は、画像データをHEVC方式で多視点符号化したり多視点復号したりする機能ブロックである。
MPEG-DASH1551は、画像データをMPEG-DASH(MPEG-Dynamic Adaptive Streaming over HTTP)方式で送受信する機能ブロックである。MPEG-DASHは、HTTP(HyperText Transfer Protocol)を使ってビデオのストリーミングを行う技術であり、予め用意された解像度等が互いに異なる複数の符号化データの中から適切なものをセグメント単位で選択し伝送することを特徴の1つとする。MPEG-DASH1551は、規格に準拠するストリームの生成やそのストリームの伝送制御等を行い、画像データの符号化・復号については、上述したMPEG-2 Video1541乃至HEVC/H.265(Multi-view)1545を利用する。
メモリインタフェース1517は、外部メモリ1312用のインタフェースである。画像処理エンジン1514やコーデックエンジン1516から供給されるデータは、メモリインタフェース1517を介して外部メモリ1312に供給される。また、外部メモリ1312から読み出されたデータは、メモリインタフェース1517を介してビデオプロセッサ1332(画像処理エンジン1514若しくはコーデックエンジン1516)に供給される。
多重化・逆多重化部(MUX DMUX)1518は、符号化データのビットストリーム、画像データ、ビデオ信号等、画像に関する各種データの多重化や逆多重化を行う。この多重化・逆多重化の方法は任意である。例えば、多重化の際に、多重化・逆多重化部(MUX DMUX)1518は、複数のデータを1つにまとめるだけでなく、所定のヘッダ情報等をそのデータに付加することもできる。また、逆多重化の際に、多重化・逆多重化部(MUX DMUX)1518は、1つのデータを複数に分割するだけでなく、分割した各データに所定のヘッダ情報等を付加することもできる。つまり、多重化・逆多重化部(MUX DMUX)1518は、多重化・逆多重化によりデータのフォーマットを変換することができる。例えば、多重化・逆多重化部(MUX DMUX)1518は、ビットストリームを多重化することにより、転送用のフォーマットのビットストリームであるトランスポートストリームや、記録用のファイルフォーマットのデータ(ファイルデータ)に変換することができる。もちろん、逆多重化によりその逆変換も可能である。
ネットワークインタフェース1519は、例えばブロードバンドモデム1333やコネクティビティ1321等向けのインタフェースである。ビデオインタフェース1520は、例えばコネクティビティ1321やカメラ1322等向けのインタフェースである。
次に、このようなビデオプロセッサ1332の動作の例について説明する。例えば、コネクティビティ1321やブロードバンドモデム1333等を介して外部ネットワークからトランスポートストリームを受信すると、そのトランスポートストリームは、ネットワークインタフェース1519を介して多重化・逆多重化部(MUX DMUX)1518に供給されて逆多重化され、コーデックエンジン1516により復号される。コーデックエンジン1516の復号により得られた画像データは、例えば、画像処理エンジン1514により所定の画像処理が施され、ディスプレイエンジン1513により所定の変換が行われ、ディスプレイインタフェース1512を介して例えばコネクティビティ1321等に供給され、その画像がモニタに表示される。また、例えば、コーデックエンジン1516の復号により得られた画像データは、コーデックエンジン1516により再符号化され、多重化・逆多重化部(MUX DMUX)1518により多重化されてファイルデータに変換され、ビデオインタフェース1520を介して例えばコネクティビティ1321等に出力され、各種記録媒体に記録される。
さらに、例えば、コネクティビティ1321等により図示せぬ記録媒体から読み出された、画像データが符号化された符号化データのファイルデータは、ビデオインタフェース1520を介して多重化・逆多重化部(MUX DMUX)1518に供給されて逆多重化され、コーデックエンジン1516により復号される。コーデックエンジン1516の復号により得られた画像データは、画像処理エンジン1514により所定の画像処理が施され、ディスプレイエンジン1513により所定の変換が行われ、ディスプレイインタフェース1512を介して例えばコネクティビティ1321等に供給され、その画像がモニタに表示される。また、例えば、コーデックエンジン1516の復号により得られた画像データは、コーデックエンジン1516により再符号化され、多重化・逆多重化部(MUX DMUX)1518により多重化されてトランスポートストリームに変換され、ネットワークインタフェース1519を介して例えばコネクティビティ1321やブロードバンドモデム1333等に供給され図示せぬ他の装置に伝送される。
なお、ビデオプロセッサ1332内の各処理部の間での画像データやその他のデータの授受は、例えば、内部メモリ1515や外部メモリ1312を利用して行われる。また、パワーマネージメントモジュール1313は、例えば制御部1511への電力供給を制御する。
このように構成されるビデオプロセッサ1332に本技術を適用する場合、コーデックエンジン1516に、上述した各実施形態に係る本技術を適用すればよい。つまり、例えば、コーデックエンジン1516が、上述した実施の形態に係る画像符号化装置100や画像復号装置200を実現する機能ブロックを有するようにすればよい。このようにすることにより、ビデオプロセッサ1332は、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
なお、コーデックエンジン1516において、本技術(すなわち、上述した各実施形態に係る画像符号化装置や画像復号装置の機能)は、論理回路等のハードウエアにより実現するようにしてもよいし、組み込みプログラム等のソフトウエアにより実現するようにしてもよいし、それらの両方により実現するようにしてもよい。
以上にビデオプロセッサ1332の構成を2例示したが、ビデオプロセッサ1332の構成は任意であり、上述した2例以外のものであってもよい。また、このビデオプロセッサ1332は、1つの半導体チップとして構成されるようにしてもよいが、複数の半導体チップとして構成されるようにしてもよい。例えば、複数の半導体を積層する3次元積層LSIとしてもよい。また、複数のLSIにより実現されるようにしてもよい。
<装置への適用例>
ビデオセット1300は、画像データを処理する各種装置に組み込むことができる。例えば、ビデオセット1300は、テレビジョン装置900(図47)、携帯電話機920(図48)、記録再生装置940(図49)、撮像装置960(図50)等に組み込むことができる。ビデオセット1300を組み込むことにより、その装置は、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
また、ビデオセット1300は、例えば、図51のデータ伝送システム1000におけるパーソナルコンピュータ1004、AV機器1005、タブレットデバイス1006、および携帯電話機1007等の端末装置、図52のデータ伝送システム1100における放送局1101および端末装置1102、並びに、図53の撮像システム1200における撮像装置1201およびスケーラブル符号化データ記憶装置1202等にも組み込むことができる。ビデオセット1300を組み込むことにより、その装置は、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
なお、上述したビデオセット1300の各構成の一部であっても、ビデオプロセッサ1332を含むものであれば、本技術を適用した構成として実施することができる。例えば、ビデオプロセッサ1332のみを本技術を適用したビデオプロセッサとして実施することができる。また、例えば、上述したように点線1341により示されるプロセッサやビデオモジュール1311等を本技術を適用したプロセッサやモジュール等として実施することができる。さらに、例えば、ビデオモジュール1311、外部メモリ1312、パワーマネージメントモジュール1313、およびフロントエンドモジュール1314を組み合わせ、本技術を適用したビデオユニット1361として実施することもできる。いずれの構成の場合であっても、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
つまり、ビデオプロセッサ1332を含むものであればどのような構成であっても、ビデオセット1300の場合と同様に、画像データを処理する各種装置に組み込むことができる。例えば、ビデオプロセッサ1332、点線1341により示されるプロセッサ、ビデオモジュール1311、または、ビデオユニット1361を、テレビジョン装置900(図47)、携帯電話機920(図48)、記録再生装置940(図49)、撮像装置960(図50)、図51のデータ伝送システム1000におけるパーソナルコンピュータ1004、AV機器1005、タブレットデバイス1006、および携帯電話機1007等の端末装置、図52のデータ伝送システム1100における放送局1101および端末装置1102、並びに、図53の撮像システム1200における撮像装置1201およびスケーラブル符号化データ記憶装置1202等に組み込むことができる。そして、本技術を適用したいずれかの構成を組み込むことにより、その装置は、ビデオセット1300の場合と同様に、図1乃至図42を参照して上述した効果と同様の効果を得ることができる。
また、本明細書では、各種情報が、符号化ストリームに多重化されて、符号化側から復号側へ伝送される例について説明した。しかしながら、これら情報を伝送する手法はかかる例に限定されない。例えば、これら情報は、符号化ビットストリームに多重化されることなく、符号化ビットストリームと関連付けられた別個のデータとして伝送され又は記録されてもよい。ここで、「関連付ける」という用語は、ビットストリームに含まれる画像(スライス若しくはブロックなど、画像の一部であってもよい)と当該画像に対応する情報とを復号時にリンクさせ得るようにすることを意味する。即ち、情報は、画像(又はビットストリーム)とは別の伝送路上で伝送されてもよい。また、情報は、画像(又はビットストリーム)とは別の記録媒体(又は同一の記録媒体の別の記録エリア)に記録されてもよい。さらに、情報と画像(又はビットストリーム)とは、例えば、複数フレーム、1フレーム、又はフレーム内の一部分などの任意の単位で互いに関連付けられてよい。
なお、本技術は以下のような構成も取ることができる。
(1) 画像データを符号化する符号化部と、
前記画像データの画像の、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報を設定する復号負荷定義情報設定部と、
前記符号化部により生成された前記画像データの符号化データと、前記復号負荷定義情報設定部により設定された前記復号負荷定義情報とを伝送する伝送部と
を備える画像符号化装置。
(2) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表すレベルにより前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(1)、(3)乃至(13)のいずれかに記載の画像符号化装置。
(3) 前記復号負荷定義情報は、前記部分領域の大きさを示す情報により前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(1)、(2)、(4)乃至(13)のいずれかに記載の画像符号化装置。
(4) 前記復号負荷定義情報は、前記部分領域の、縦方向の長さを示す情報と横方向の長さを示す情報とにより前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(1)乃至(3)、(5)乃至(13)のいずれかに記載の画像符号化装置。
(5) 前記復号負荷定義情報は、前記部分領域を復号する仮想参照デコーダの最大入力ビットレートおよびバッファ容量を示す情報により前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(1)乃至(4)、(6)乃至(13)のいずれかに記載の画像符号化装置。
(6) 前記復号負荷定義情報は、複数の前記部分領域に共通の、前記復号処理の負荷の大きさを表すレベルにより前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(1)乃至(5)、(7)乃至(13)のいずれかに記載の画像符号化装置。
(7) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表す各レベルに対応する前記部分領域の縦方向の大きさと横方向の大きさとを定義する情報を含む
(1)乃至(6)、(8)乃至(13)のいずれかに記載の画像符号化装置。
(8) 前記復号負荷定義情報は、前記画像内における前記復号処理の負荷の大きさを表すレベルの最大値を定義する情報を含む
(1)乃至(7)、(9)乃至(13)のいずれかに記載の画像符号化装置。
(9) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表すレベルにより前記部分領域の復号処理の負荷の大きさを定義する情報を含み、
前記復号負荷定義情報設定部は、前記レベルでのパラメータを、前記部分領域を含む所定の領域について規定し、前記画像単位での規定に割り当てる
(1)乃至(8)、(10)乃至(13)のいずれかに記載の画像符号化装置。
(10) 前記復号負荷定義情報設定部は、独立に復号することができる部分領域のSEI(Supplemental Enhancement Information)に、前記部分領域毎に前記復号負荷定義情報を設定する
(1)乃至(9)、(11)乃至(13)のいずれかに記載の画像符号化装置。
(11) 前記画像データは複数レイヤよりなり、
前記復号負荷定義情報設定部は、前記SEIに、前記複数レイヤの前記復号負荷定義情報を設定する
(1)乃至(10)、(12)、(13)のいずれかに記載の画像符号化装置。
(12) 前記復号負荷定義情報設定部は、さらに、シーケンスパラメータセット(SPS(Sequence Parameter Set))に、前記SEIに前記復号負荷定義情報が設定されているかを示す情報か、若しくは、前記SEIに設定される前記復号負荷定義情報と同様の復号負荷定義情報を設定する
(1)乃至(11)、(13)のいずれかに記載の画像符号化装置。
(13) 前記復号負荷定義情報は、基準とする前記部分領域の大きさを示す情報と、前記部分領域の復号処理の負荷の大きさを表すレベルを含む
(1)乃至(12)のいずれかに記載の画像符号化装置。
(14) 画像データを符号化し、
前記画像データの画像の、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報を設定し、
生成された前記画像データの符号化データと、設定された前記復号負荷定義情報とを伝送する
画像符号化方法。
(15) 画像データの符号化データと、前記画像データの画像の、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報とを取得する取得部と、
前記取得部により取得された前記復号負荷定義情報を解析する解析部と、
前記解析部による前記復号負荷定義情報の解析結果に基づいて、前記取得部により取得された前記符号化データの復号を制御する制御部と、
前記制御部による制御に従って、前記取得部により取得された前記符号化データを復号する復号部と
を備える画像復号装置。
(16) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表すレベルにより前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(15)、(17)乃至(27)のいずれかに記載の画像復号装置。
(17) 前記復号負荷定義情報は、前記部分領域の大きさを示す情報により前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(15)、(16)、(18)乃至(27)のいずれかに記載の画像復号装置。
(18) 前記復号負荷定義情報は、前記部分領域の、縦方向の長さを示す情報と横方向の長さを示す情報とにより前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(15)乃至(17)、(19)乃至(27)のいずれかに記載の画像復号装置。
(19) 前記復号負荷定義情報は、前記部分領域を復号する仮想参照デコーダの最大入力ビットレートおよびバッファ容量を示す情報により前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(15)乃至(18)、(20)乃至(27)のいずれかに記載の画像復号装置。
(20) 前記復号負荷定義情報は、複数の前記部分領域に共通の、前記復号処理の負荷の大きさを表すレベルにより前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(15)乃至(19)、(21)乃至(27)のいずれかに記載の画像復号装置。
(21) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表す各レベルに対応する前記部分領域の縦方向の大きさと横方向の大きさとを定義する情報を含む
(15)乃至(20)、(22)乃至(27)のいずれかに記載の画像復号装置。
(22) 前記復号負荷定義情報は、前記画像内における前記復号処理の負荷の大きさを表すレベルの最大値を定義する情報を含む
(15)乃至(21)、(23)乃至(27)のいずれかに記載の画像復号装置。
(23) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表すレベルにより前記部分領域の復号処理の負荷の大きさを定義する情報を含み、
前記制御部は、前記部分領域を含む所定の領域について規定され、前記画像単位での規定に割り当てられた前記レベルでのパラメータを用いて、前記符号化データの復号を制御する
(15)乃至(22)(24)乃至(27)のいずれかに記載の画像復号装置。
(24) 前記解析部は、独立に復号することができる部分領域のSEI(Supplemental Enhancement Information)に、前記部分領域毎に設定された前記復号負荷定義情報を解析する
(15)乃至(23)、(25)乃至(27)のいずれかに記載の画像復号装置。
(25) 前記画像データは複数レイヤよりなり、
前記解析部は、前記SEIに設定された前記複数レイヤの前記復号負荷定義情報を解析する
(15)乃至(24)、(26)、(27)のいずれかに記載の画像復号装置。
(26) 前記解析部は、さらに、シーケンスパラメータセット(SPS(Sequence Parameter Set))に設定された、前記SEIに前記復号負荷定義情報が設定されているかを示す情報、若しくは、前記SEIに設定される前記復号負荷定義情報と同様の復号負荷定義情報を解析する
(15)乃至(25)、(27)のいずれかに記載の画像復号装置。
(27) 前記復号負荷定義情報は、基準とする前記部分領域の大きさを示す情報と、前記部分領域の復号処理の負荷の大きさを表すレベルを含む
(15)乃至(26)のいずれかに記載の画像復号装置。
(28) 画像データの符号化データと、前記画像データの画像の、独立に復号することができる部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報とを取得し、
取得された前記復号負荷定義情報を解析し、
前記復号負荷定義情報の解析結果に基づいて、取得された前記符号化データの復号を制御し、
その制御に従って、取得された前記符号化データを復号する
画像復号方法。
(31) 画像データの符号化データと、前記画像データの画像の部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報とを取得する取得部と、
前記取得部により取得された前記復号負荷定義情報に基づいて、前記取得部により取得された前記符号化データの復号を制御する制御部と、
前記制御部による制御に従って、前記取得部により取得された前記符号化データを復号する復号部と
を備える画像復号装置。
(32) 前記部分領域は、独立に復号することができる
(31)に記載の画像復号装置。
(33) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表すレベルにより前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(31)または(32)に記載の画像復号装置。
(34) 前記復号負荷定義情報は、前記部分領域の大きさを示す情報により前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(31)乃至(33)のいずれかに記載の画像復号装置。
(35) 前記復号負荷定義情報は、前記部分領域の、縦方向の長さを示す情報と横方向の長さを示す情報とにより前記部分領域の復号処理の負荷の大きさを定義する情報を含む
(31)乃至(34)のいずれかに記載の画像復号装置。
(36) 前記復号負荷定義情報は、独立に復号することができる部分領域のSEI(Supplemental Enhancement Information)に含まれる
(31)乃至(35)のいずれかに記載の画像復号装置。
(37) 前記画像データは複数レイヤよりなり、
前記複数レイヤの前記復号負荷定義情報は、前記SEIに含まれる
(31)乃至(36)のいずれかに記載の画像復号装置。
(38) 前記復号負荷定義情報は、基準とする前記部分領域の大きさを示す情報と、前記部分領域の復号処理の負荷の大きさを表すレベルを含む
(31)乃至(37)のいずれかに記載の画像復号装置。
(39) 前記部分領域は、タイルである
(31)乃至(38)のいずれかに記載の画像復号装置。
(40) 前記部分領域は、複数のタイルの集合である
(31)乃至(39)のいずれかに記載の画像復号装置。
(41) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表すレベルにより、前記画像データのピクチャに含まれる複数の部分領域の中で、最大の復号処理の負荷の大きさを定義する情報を含む
(31)乃至(40)のいずれかに記載の画像復号装置。
(42) 前記復号負荷定義情報は、前記復号処理の負荷の大きさを表すレベルにより、前記画像データのピクチャに含まれる複数の部分領域に共通の負荷の大きさを定義する情報を含む
(31)乃至(41)のいずれかに記載の画像復号装置。
(43) 前記ピクチャに含まれる複数の前記部分領域がL字型の場合、前記L字型を内包する四角形の領域に対して、前記負荷の大きさを定義する
(31)乃至(42)のいずれかに記載の画像復号装置。
(44) 前記取得部は、さらに前記復号負荷定義情報が設定されているかを示す情報を取得し、前記取得された情報が、前記復号負荷定義情報が設定されていることを示す場合に、前記前記復号負荷定義情報を取得する
(31)乃至(43)のいずれかに記載の画像復号装置。
(45) 画像データの符号化データと、前記画像データの画像の部分領域の復号処理の負荷の大きさを定義する復号負荷定義情報とを取得し、
取得された前記復号負荷定義情報に基づいて、取得された前記符号化データの復号を制御し、
その制御に従って、取得された前記符号化データを復号する
画像復号方法。