JPWO2018131523A1 - 画像処理装置および画像処理方法 - Google Patents

画像処理装置および画像処理方法 Download PDF

Info

Publication number
JPWO2018131523A1
JPWO2018131523A1 JP2018561334A JP2018561334A JPWO2018131523A1 JP WO2018131523 A1 JPWO2018131523 A1 JP WO2018131523A1 JP 2018561334 A JP2018561334 A JP 2018561334A JP 2018561334 A JP2018561334 A JP 2018561334A JP WO2018131523 A1 JPWO2018131523 A1 JP WO2018131523A1
Authority
JP
Japan
Prior art keywords
unit
image
prediction
block
size
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
JP2018561334A
Other languages
English (en)
Inventor
健治 近藤
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sony Corp
Original Assignee
Sony Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sony Corp filed Critical Sony Corp
Publication of JPWO2018131523A1 publication Critical patent/JPWO2018131523A1/ja
Pending legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/102Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
    • H04N19/119Adaptive subdivision aspects, e.g. subdivision of a picture into rectangular or non-rectangular coding blocks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/169Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
    • H04N19/17Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
    • H04N19/176Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a block, e.g. a macroblock
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/513Processing of motion vectors
    • H04N19/517Processing of motion vectors by encoding
    • H04N19/52Processing of motion vectors by encoding by predictive encoding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/53Multi-resolution motion estimation; Hierarchical motion estimation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/537Motion estimation other than block-based
    • H04N19/54Motion estimation other than block-based using feature points or meshes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/537Motion estimation other than block-based
    • H04N19/543Motion estimation other than block-based using regions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/70Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by syntax aspects related to video coding, e.g. related to compression standards
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/85Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)

Abstract

本開示は、ブロックの2つの頂点の動きベクトルに基づいてブロックの予測画像を生成する場合に、長方形のブロックの予測画像を高精度で生成することができるようにする画像処理装置および画像処理方法に関する。予測部は、PUの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、PUの予測画像を生成する。本開示は、例えば、2つの動きベクトルに基づくアフィン変換による動き補償を行い、インター予測処理を行う画像符号化装置等に適用することができる。

Description

本開示は、画像処理装置および画像処理方法に関し、特に、ブロックの2つの頂点の動きベクトルに基づいてブロックの予測画像を生成する場合に、長方形のブロックの予測画像を高精度で生成することができるようにした画像処理装置および画像処理方法に関する。
ITU-T(International Telecommunication Union Telecommunication Standardization Sector)の次世代ビデオ符号化を探索するJVET(Joint Video Exploration Team)では、2つの頂点の動きベクトルに基づいて参照画像をアフィン変換することによりインター予測処理(Affine motion compensation (MC) prediction)を行うことが提案されている(例えば、非特許文献1および2参照)。これにより、インター予測処理時に、画面間の並進移動(平行移動)や回転方向の動き、並びに、拡大や縮小といった形状の変化を補償して予測画像を生成することができる。
また、JVETでは、CU(Coding Unit)を形成する技術として、非特許文献3に記載されているQTBT(Quad tree plus binary tree)と呼ばれる技術が採用されている。従って、CUの形状は、正方形だけでなく、長方形になる可能性がある。
Jianle Chen等,"Algorithm Description of Joint Exploration Test Model 4(JVET-C1001)", JVET of ITU-T SG16 WP3 and ISO/IEC JTC1/SC29/WG11,26 May-1 June 2016 Feng Zou,"Improved affine motion prediction(JVET-C0062)",JVET of ITU-T SG16 WP3 and ISO/IEC JTC1/SC29/WG11,26 May-1 June 2016 "EE2.1: Quadtree plus binary tree structure integration with JEM tools(JVET-C0024)" ,JVET of ITU-T SG16 WP3 and ISO/IEC JTC1/SC29/WG11,2016年5月16日
PU(Prediction Unit)がCUと同一の長方形のブロックである場合、インター予測処理におけるアフィン変換を、PUの短辺の2つの頂点の動きベクトルに基づいて行うと、長辺の2つの頂点の動きベクトルに基づいて行う場合に比べて、動きベクトルの誤差による予測精度の低下が大きくなる。
しかしながら、インター予測処理のアフィン変換で用いられる2つの動きベクトルに対応する頂点のPUにおける位置を、PUの形状に応じて変更することは考案されていなかった。従って、PUの形状が長方形である場合、高精度で予測画像を生成することができない場合があった。
本開示は、このような状況に鑑みてなされたものであり、ブロックの2つの頂点の動きベクトルに基づいてブロックの予測画像を生成する場合に、長方形のブロックの予測画像を高精度で生成することができるようにするものである。
本開示の一側面の画像処理装置は、ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの予測画像を生成する予測部を備える画像処理装置である。
本開示の一側面の画像処理方法は、本開示の一側面の画像処理装置に対応する。
本開示の一側面においては、ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの予測画像が生成される。
本開示の一側面によれば、予測画像を生成することができる。また、本開示の一側面によれば、ブロックの2つの頂点の動きベクトルに基づいてブロックの予測画像を生成する場合に、長方形のブロックの予測画像を高精度で生成することができる。
なお、ここに記載された効果は必ずしも限定されるものではなく、本開示中に記載されたいずれかの効果であってもよい。
1つの動きベクトルに基づいて動き補償を行うインター予測処理を説明する図である。 1つの動きベクトルと回転角に基づいて動き補償を行うインター予測処理を説明する図である。 2つの動きベクトルに基づいて動き補償を行うインター予測処理を説明する図である。 3つの動きベクトルに基づいて動き補償を行うインター予測処理を説明する図である。 3つの動きベクトルに基づくアフィン変換前後のブロックを説明する図である。 QTBTを説明する図である。 長方形のPUに対する2つの動きベクトルに基づくインター予測処理を説明する図である。 長方形のPUに対する誤差が発生した2つの動きベクトルに基づくインター予測処理を説明する図である。 長方形のPUに対する3つの動きベクトルに基づくインター予測処理を説明する図である。 画像符号化装置の一実施の形態の構成例を示すブロック図である。 2つの動きベクトル情報を説明する図である。 隣接ベクトルを説明する図である。 Affine flagが1であるCUの領域を示す例である。 Affine flagが1であるCUの領域の境界の例を示す図である。 Affine flagが1であるCUの領域の境界の他の例を示す図である。 画像符号化処理を説明するフローチャートである。 インター予測処理モード設定処理の第1の例を説明するフローチャートである。 インター予測処理モード設定処理の第2の例を説明するフローチャートである。 マージアフィン変換モード符号化処理を説明するフローチャートである。 AMVPアフィン変換モード符号化処理を説明するフローチャートである。 Affine flag符号化処理を説明するフローチャートである。 画像復号装置の一実施の形態の構成例を示すブロック図である。 画像復号処理を説明するフローチャートである。 マージアフィン変換モード復号処理を説明するフローチャートである。 AMVPアフィン変換モード復号処理を説明するフローチャートである。 コンピュータのハードウエアの構成例を示すブロック図である。 テレビジョン装置の概略的な構成の一例を示すブロック図である。 携帯電話機の概略的な構成の一例を示すブロック図である。 記録再生装置の概略的な構成の一例を示すブロック図である。 撮像装置の概略的な構成の一例を示すブロック図である。 ビデオセットの概略的な構成の一例を示すブロック図である。 ビデオプロセッサの概略的な構成の一例を示すブロック図である。 ビデオプロセッサの概略的な構成の他の例を示すブロック図である。 ネットワークシステムの概略的な構成の一例を示すブロック図である。
以下、本開示の前提および本開示を実施するための形態(以下、実施の形態という)について説明する。なお、説明は以下の順序で行う。
0.本開示の前提(図1乃至図9)
1.第1実施の形態:画像処理装置(図10乃至図25)
2.第2実施の形態:コンピュータ(図26)
3.第3実施の形態:テレビジョン装置(図27)
4.第4実施の形態:携帯電話機(図28)
5.第5実施の形態:記録再生装置(図29)
6.第6実施の形態:撮像装置(図30)
7.第7実施の形態:ビデオセット(図31乃至図33)
8.第8実施の形態:ネットワークシステム(図34)
<本開示の前提>
(1つの動きベクトルに基づいて動き補償を行うインター予測処理の説明)
図1は、1つの動きベクトルに基づいて動き補償を行うインター予測処理を説明する図である。
なお、以下では、特に断りの無い限り、画像(ピクチャ)の横方向(水平方向)をx方向とし、縦方向(垂直方向)をy方向とする。
図1に示すように、1つの動きベクトルに基づいて動き補償を行うインター予測処理では、予測対象のPU11(カレントブロック)に対して1つの動きベクトルv(vcx,vcy)が決定される。そして、PU11を含むピクチャ10とは異なる時刻の参照画像内の、PU11から動きベクトルvだけ離れた位置に存在するPU11と同一のサイズのブロック13を、動きベクトルvに基づいて並進移動することにより、PU11の予測画像が生成される。
即ち、1つの動きベクトルに基づいて動き補償を行うインター予測処理では、参照画像に対してアフィン変換が行われず、画面間の並進移動のみを補償した予測画像が生成される。また、インター予測処理に用いられるパラメータは、vcxとvcyの2つである。このようなインター予測処理は、AVC(Advanced Video Coding)やHEVC(High Efficiency Video Coding)などで採用されている。
(1つの動きベクトルと回転角に基づいて動き補償を行うインター予測処理の説明)
図2は、1つの動きベクトルと回転角に基づいて動き補償を行うインター予測処理を説明する図である。
図2に示すように、1つの動きベクトルと回転角に基づいて動き補償を行うインター予測処理では、予測対象のPU11に対して1つの動きベクトルv(vcx,vcy)と回転角θが決定される。そして、PU11を含むピクチャ10とは異なる時刻の参照画像内の、PU11から動きベクトルvだけ離れた位置に回転角θの傾きで存在するPU11と同一のサイズのブロック21を、動きベクトルvと回転角θに基づいてアフィン変換することにより、PU11の予測画像が生成される。
即ち、1つの動きベクトルと回転角に基づいて動き補償を行うインター予測処理では、1つの動きベクトルと回転角に基づいて参照画像に対してアフィン変換が行われる。これにより、画面間の並進移動と回転方向の動きを補償した予測画像が生成される。従って、1つの動きベクトルに基づいて動き補償を行うインター予測処理に比べて、予測画像の精度が向上する。また、インター予測処理に用いられるパラメータは、vcx,vcy、およびθの3つである。
(2つの動きベクトルに基づいて動き補償を行うインター予測処理の説明)
図3は、2つの動きベクトルに基づいて動き補償を行うインター予測処理を説明する図である。
図3に示すように、2つの動きベクトルに基づいて動き補償を行うインター予測処理では、予測対象のPU31に対して、PU31の左上の頂点Aにおける動きベクトルv(v0x,v0y)と右上の頂点Bにおける動きベクトルv(v1x,v1y)が決定される。
そして、PU31を含むピクチャとは異なる時刻の参照画像内の、頂点Aから動きベクトルvだけ離れた点A´を左上の頂点とし、頂点Bから動きベクトルvだけ離れた点B´を右上の頂点とするブロック32を、動きベクトルvと動きベクトルvに基づいてアフィン変換することにより、PU31の予測画像が生成される。
具体的には、PU31が所定のサイズのブロック(以下、動き補償単位ブロックという)に分割される。そして、各動き補償単位ブロックの動きベクトルv(v,v)が、動きベクトルv(v0x,v0y)と動きベクトルv(v1x,v1y)に基づいて、以下の式(1)により求められる。
Figure 2018131523
なお、Wは、PU31のx方向のサイズであり、Hは、PU31のy方向のサイズである。従って、PU31が正方形である場合、WとHは等しい。また、x,yは、それぞれ、動き補償単位ブロックのx方向、y方向の位置である。式(1)によれば、動き補償単位ブロックの位置に基づいて、動き補償単位ブロックの動きベクトルvが決定される。
そして、参照画像内の、各動き補償単位ブロックから動きベクトルvだけ離れた動き補償単位ブロックと同一のサイズのブロックを、動きベクトルvに基づいて並進移動することにより、各動き補償単位ブロックの予測画像を生成する。
以上のように、2つの動きベクトルに基づいて動き補償を行うインター予測処理では、2つの動きベクトルに基づいて参照画像に対してアフィン変換が行われる。これにより、画面間の並進移動および回転方向の動きだけでなく、拡大や縮小といった形状の変化を補償した予測画像が生成される。従って、1つの動きベクトルと回転角に基づいて動き補償を行うインター予測処理に比べて、予測画像の精度が向上する。また、インター予測処理に用いられるパラメータは、v0x,v0y,v1x、およびv1yの4つである。このようなインター予測処理は、JEM(Joint Exploration Model)参照ソフトウエアで採用されている。
なお、2つの動きベクトルに基づくアフィン変換は、アフィン変換前後のブロックが矩形であることを前提としたアフィン変換である。アフィン変換前後のブロックが矩形以外の四角形である場合にもアフィン変換を行うためには、3つの動きベクトルが必要である。
(3つの動きベクトルに基づいて動き補償を行うインター予測処理の説明)
図4は、3つの動きベクトルに基づいて動き補償を行うインター予測処理を説明する図である。
図4に示すように、3つの動きベクトルに基づいて動き補償を行うインター予測処理では、予測対象のPU31に対して、動きベクトルv(v0x,v0y)と動きベクトルv(v1x,v1y)だけでなく、左下の頂点Cの動きベクトルv(v2x,v2y)が決定される。
そして、PU31を含むピクチャとは異なる時刻の参照画像内の、頂点Aから動きベクトルvだけ離れた点A´を左上の頂点とし、頂点Bから動きベクトルvだけ離れた点B´を右上の頂点とし、頂点Cから動きベクトルvだけ離れた点C´を左下の頂点とするブロック42を、動きベクトルv乃至vに基づいてアフィン変換することにより、PU31の予測画像が生成される。
即ち、3つの動きベクトルに基づいて動き補償を行うインター予測処理では、3つの動きベクトルに基づいて参照画像に対してアフィン変換が行われる。これにより、ブロック42が図5のAに示すように並進移動(Translation)したり、図5のBに示すようにスキュー(Skew)したり、図5のCに示すように回転(Rotation)したり、図5のDに示すように拡大または縮小(Scaling)したりする。
その結果、画面間の並進移動および回転方向の動き、並びに、拡大や縮小、およびスキューといった形状の変化を補償した予測画像が生成される。なお、図5では、アフィン変換前のブロック42を実線で示し、アフィン変換後のブロック42を点線で示している。
これに対して、図3で説明した2つの動きベクトルに基づいて動き補償を行うインター予測処理では、予測画像に対して、画面間の並進移動および回転方向の動き、並びに、拡大や縮小といった形状の変化を補償することができるが、スキューを補償することはできない。従って、3つの動きベクトルに基づいて動き補償を行うインター予測処理では、2つの動きベクトルに基づいて動き補償を行うインター予測処理に比べて、予測画像の精度が向上する。
しかしながら、3つの動きベクトルに基づいて動き補償を行うインター予測処理では、インター予測処理に用いられるパラメータは、v0x,v0y,v1x,v1y,v2x、およびv2yの6つである。従って、1つの動きベクトルと回転角度、または、2つの動きベクトルに基づいて動き補償を行うインター予測処理に比べて、インター予測処理に用いられるパラメータの数が増加する。よって、アフィン変換を用いたインター予測処理の予測精度の向上とオーバーヘッドの抑制とは、トレードオフの関係になる。
そこで、JVETでは、制御信号により、2つの動きベクトルに基づいて動き補償を行うインター予測処理と3つの動きベクトルに基づいて動き補償を行うインター予測処理を切り替える技術が提案されている。
(QTBTの説明)
MPEG2(Moving Picture Experts Group 2(ISO/IEC 13818-2))やAVCなどの旧来の画像符号化方式では、符号化処理は、マクロブロックと呼ばれる処理単位で実行される。マクロブロックは、16x16画素の均一なサイズを有するブロックである。これに対し、HEVCでは、符号化処理は、CUと呼ばれる処理単位(符号化単位)で実行される。CUは、最大符号化単位であるLCU(Largest Coding Unit)を再帰的に分割することにより形成される、可変的なサイズを有するブロックである。選択可能なCUの最大サイズは、64x64画素である。選択可能なCUの最小サイズは、8x8画素である。最小サイズのCUは、SCU(Smallest Coding Unit)と呼ばれる。なお、CUの最大サイズは、64x64画素に限定されず、より大きい128x128画素、256x256画素などのブロックサイズとしてもよい。
このように、可変的なサイズを有するCUが採用される結果、HEVCでは、画像の内容に応じて画質及び符号化効率を適応的に調整することが可能である。予測符号化のための予測処理は、PUと呼ばれる処理単位で実行される。PUは、CUをいくつかの分割パタンのうちの1つで分割することにより形成される。また、PUは、輝度(Y)及び色差(Cb,Cr)毎のPB(Prediction Block)と呼ばれる処理単位から構成される。さらに、直交変換処理は、TU(Transform Unit)と呼ばれる処理単位で実行される。TUは、CU又はPUをある深さまで分割することにより形成される。また、TUは、輝度(Y)及び色差(Cb,Cr)毎のTB(Transform Block)と呼ばれる処理単位(変換ブロック)から構成される。
以下においては、画像(ピクチャ)の部分領域や処理単位として「ブロック」を用いて説明する場合がある(処理部のブロックではない)。この場合の「ブロック」は、ピクチャ内の任意の部分領域を示し、その大きさ、形状、および特性等は限定されない。つまり、この場合の「ブロック」には、例えば、TB、TU、PB、PU、SCU、CU、LCU(CTB)、サブブロック、マクロブロック、タイル、またはスライス等、任意の部分領域(処理単位)が含まれるものとする。
図6は、JVETにおいて採用されたQTBTを説明する図である。
HEVCでは、1つのブロックを水平方向および垂直方向に分割して4(=2x2)個のサブブロックにのみすることができる。これに対して、QTBTでは、1つのブロックを4(=2x2)個のサブブロックだけでなく、水平方向および垂直方向のいずれか一方にのみ分割して2(=1x2,2x1)個のサブブロックにもすることができる。即ち、QTBTでは、CUの形成は、1つのブロックの4個または2個のサブブロックへの分割を再帰的に繰り返すことにより行われ、結果として四分木(Quad-Tree)状、または、2分木(Binary-Tree)状のツリー構造が形成される。なお、以下では、PUとTUは、CUと同一であるものとする。
(長方形のPUに対する2つの動きベクトルに基づくインター予測処理の説明)
図7および図8は、長方形のPUに対する2つの動きベクトルに基づくインター予測処理を説明する図である。
図7の例では、予測対象のPU61が、x方向のサイズWに比べてy方向のサイズHが大きい縦長の長方形である。この場合、PU61に対して、図3の場合と同様に、2つの動きベクトルに基づいて動き補償を行うインター予測処理が行われると、図7に示すように、PU61を含むピクチャとは異なる時刻の参照画像内のブロック62を、動きベクトルvと動きベクトルvに基づいてアフィン変換することにより、PU61の予測画像が生成される。なお、ブロック62は、頂点Aから動きベクトルvだけ離れた点A´を左上の頂点とし、頂点Bから動きベクトルvだけ離れた点B´を右上の頂点とするブロックである。
ここで、図8に示すように、動きベクトルvに誤差eが発生し、動きベクトルvに誤差eが発生すると、参照画像内のブロック71を、動きベクトルv+eと動きベクトルv+eに基づいてアフィン変換することにより、PU61の予測画像が生成される。なお、ブロック71は、頂点Aから動きベクトルv+eだけ離れた点A´´を左上の頂点とし、頂点Bから動きベクトルv+eだけ離れた点B´´を右上の頂点とするブロックである。
PU61の各動き補償ブロックの動きベクトルvの誤差は、その動きベクトルvの計算に用いられる動きベクトルvの誤差eと動きベクトルvの誤差eの影響を受ける。また、その影響は、動きベクトルvに対応する頂点Aと動きベクトルvに対応する頂点Bから遠いほど大きい。
また、図7および図8の例では、頂点Aと頂点Bは、PU61の短辺方向であるx方向に並んでいるため、頂点Aに対向する頂点Cと頂点Aの距離、および、頂点Bに対向する頂点Dと頂点Bの距離は大きい。
従って、ブロック62とブロック71のズレは大きくなる。よって、予測画像の精度が低下し、PU61と予測画像との残差が大きくなる。その結果、直交変換された残差が量子化によりゼロにされない場合、量子化後の残差を含む符号化ストリームの符号化効率が悪化する。また、直交変換された残差が量子化によりゼロにされる場合、予測画像の精度が低下しているため、復号画像の画質が低下する。
(長方形のPUに対する3つの動きベクトルに基づくインター予測処理の説明)
図9は、長方形のPUに対する3つの動きベクトルに基づくインター予測処理を説明する図である。
縦長の長方形のPU61に対して、図4の場合と同様に、3つの動きベクトルに基づいて動き補償を行うインター予測処理が行われると、図9に示すように、PU61を含むピクチャとは異なる時刻の参照画像内のブロック72を、動きベクトルv乃至vに基づいてアフィン変換することにより、PU61の予測画像が生成される。なお、ブロック72は、頂点Aから動きベクトルvだけ離れた点A´を左上の頂点とし、頂点Bから動きベクトルvだけ離れた点B´を右上の頂点とし、頂点Cから動きベクトルvだけ離れた点C´を左下の頂点とするブロックである。
ここで、図9に示すように、動きベクトルv乃至vにそれぞれ誤差e乃至eが発生すると、参照画像内のブロック73を、動きベクトルv+e,v+e、およびv+eに基づいてアフィン変換することにより、PU61の予測画像が生成される。なお、ブロック73は、頂点Aから動きベクトルv+eだけ離れた点A´´を左上の頂点とし、頂点Bから動きベクトルv+eだけ離れた点B´´を右上の頂点とし、頂点Cから動きベクトルv+eだけ離れた点C´´を左下の頂点とするブロックである。
この場合、動きベクトルv+eにより、図8の場合のように、PU61内の下側の動き補償ブロックほど動きベクトルvの誤差が大きくなることを防止することができる。
しかしながら、上述したように、3つの動きベクトルに基づくインター予測処理では、パラメータの数が6つであるため、オーバーヘッドが大きくなり、符号化効率が低下する。従って、本開示では、サイズHとサイズWの大小関係に基づいて、2つの動きベクトルに対応する頂点の位置を変更することにより、2つの動きベクトルに基づくインター予測処理の予測精度を向上させる。
<第1実施の形態>
(画像符号化装置の構成例)
図10は、本開示を適用した画像処理装置としての画像符号化装置の一実施の形態の構成例を示すブロック図である。図10の画像符号化装置100は、AVCやHEVCのように、画像とその予測画像との予測残差を符号化する装置である。例えば、画像符号化装置100は、HEVCの技術や、JVETにて提案された技術を実装している。
なお、図10においては、処理部やデータの流れ等の主なものを示しており、図10に示されるものが全てとは限らない。つまり、画像符号化装置100において、図10においてブロックとして示されていない処理部が存在したり、図10において矢印等として示されていない処理やデータの流れが存在したりしてもよい。
図10の画像符号化装置100は、制御部101、演算部111、変換部112、量子化部113、符号化部114、逆量子化部115、逆変換部116、演算部117、フレームメモリ118、および予測部119を有する。画像符号化装置100は、入力されるフレーム単位の動画像であるピクチャに対してCUごとに符号化を行う。
具体的には、画像符号化装置100の制御部101は、外部からの入力およびRDO(Rate-Distortion Optimization)等に基づいて、符号化パラメータ(ヘッダ情報Hinfo、予測情報Pinfo、変換情報Tinfo等)を設定する。
ヘッダ情報Hinfoは、例えば、ビデオパラメータセット(VPS(Video Parameter Set))、シーケンスパラメータセット(SPS(Sequence Parameter Set))、ピクチャパラメータセット(PPS(Picture Parameter Set))、スライスヘッダ(SH)等の情報を含む。例えば、ヘッダ情報Hinfoには、画像サイズ(横幅PicWidth、縦幅PicHeight)、ビット深度(輝度bitDepthY, 色差bitDepthC)、CUサイズの最大値MaxCUSize/最小値MinCUSizeなどを規定する情報が含まれる。もちろん、ヘッダ情報Hinfoの内容は任意であり、上述した例以外のどのような情報がこのヘッダ情報Hinfoに含まれるようにしてもよい。
予測情報Pinfoには、例えば、PU(CU)の形成時の各分割階層における水平方向または垂直方向の分割の有無を示すsplit flagが含まれる。また、予測情報Pinfoには、PUごとに、そのPUの予測処理がイントラ予測処理であるか、または、インター予測処理であるかを示すモード情報pred_mode_flagが含まれる。
モード情報pred_mode_flagがインター予測処理を示す場合、予測情報Pinfoには、Merge flag、Affine flag、動きベクトル情報、参照画像を特定する参照画像特定情報などが含まれる。Merge flagは、インター予測処理のモードが、マージモードであるか、または、AMVPモードであるかを示す情報である。マージモードとは、処理対象のPUに隣接する符号化済みの隣接PUの動きベクトルに基づいて生成される動きベクトル(以下、隣接ベクトルという)を含む候補の中から選択された予測ベクトルに基づいてインター予測処理を行うモードである。AMVPモードとは、処理対象のPUの動きベクトルに基づいてインター予測処理を行うモードである。Merge flagは、マージモードであることを示す場合1であり、AMVPモードであることを示す場合0である。
Affine flagは、インター予測処理において、アフィン変換モードで動き補償を行うか、または、並進移動モードで動き補償を行うかを示す情報である。並進移動モードとは、1つの動きベクトルに基づいて参照画像に対して並進移動を行うことにより動き補償を行うモードである。アフィン変換モードとは、2つの動きベクトルに基づいて参照画像に対してアフィン変換を行うことにより動き補償を行うモードである。Affine flag(複数ベクトル予測情報)は、アフィン変換モードで動き補償を行うことを示す場合1であり、並進移動モードで動き補償を行うことを示す場合0である。
動きベクトル情報は、Merge flagが1である場合、隣接ベクトルを含む候補の中から予測ベクトルを特定する予測ベクトル情報であり、Merge flagが0である場合、予測ベクトル情報、および、予測ベクトルと処理対象のPUの動きベクトルとの差分である。また、Affine flagが1である場合、予測情報Pinfoには、2つの動きベクトル情報が含められ、Affine flagが0である場合、1つの動きベクトル情報が含められる。
モード情報pred_mode_flagがイントラ予測処理を示す場合、予測情報Pinfoには、そのイントラ予測処理のモードであるイントラ予測モードを示すイントラ予測モード情報などが含まれる。もちろん、予測情報Pinfoの内容は任意であり、上述した例以外のどのような情報がこの予測情報Pinfoに含まれるようにしてもよい。
変換情報Tinfoには、TBのサイズを示すTBSizeなどが含まれる。もちろん、変換情報Tinfoの内容は任意であり、上述した例以外のどのような情報がこの変換情報Tinfoに含まれるようにしてもよい。
演算部111は、入力されるピクチャを順に符号化対象のピクチャとし、予測情報Pinfoのsplit flagに基づいて、符号化対象のピクチャに対して符号化対象のCU(PU,TU)を設定する。演算部111は、符号化対象のPUの画像I(カレントブロック)から、予測部119から供給されたPUの予測画像P(予測ブロック)を減算して予測残差Dを求め、それを変換部112に供給する。
変換部112は、制御部101から供給される変換情報Tinfoに基づいて、演算部111から供給される予測残差Dに対して直交変換等を行い、変換係数Coeffを導出する。変換部112は、変換係数Coeffを量子化部113に供給する。
量子化部113は、制御部101から供給される変換情報Tinfoに基づいて、変換部112から供給される変換係数Coeffをスケーリング(量子化)し、量子化変換係数レベルlevelを導出する。量子化部113は、量子化変換係数レベルlevelを符号化部114および逆量子化部115に供給する。
符号化部114は、量子化部113から供給される量子化変換係数レベルlevel等を所定の方法で符号化する。例えば、符号化部114は、シンタックステーブルの定義に沿って、制御部101から供給される符号化パラメータ(ヘッダ情報Hinfo、予測情報Pinfo、変換情報Tinfo等)と、量子化部113から供給される量子化変換係数レベルlevelを、各シンタックス要素のシンタックス値へ変換する。そして、符号化部114は、各シンタックス値を符号化(例えば、CABAC(Context-based Adaptive Binary Arithmetic Coding)などの算術符号化)する。
符号化部114は、例えば、符号化の結果得られる各シンタックス要素のビット列である符号化データを多重化し、符号化ストリームとして出力する。
逆量子化部115は、制御部101から供給される変換情報Tinfoに基づいて、量子化部113から供給される量子化変換係数レベルlevelの値をスケーリング(逆量子化)し、逆量子化後の変換係数Coeff_IQを導出する。逆量子化部115は、その変換係数Coeff_IQを逆変換部116に供給する。この逆量子化部115により行われる逆量子化は、量子化部113により行われる量子化の逆処理であり、後述する画像復号装置において行われる逆量子化と同様の処理である。
逆変換部116は、制御部101から供給される変換情報Tinfoに基づいて、逆量子化部115から供給される変換係数Coeff_IQに対して逆直交変換等を行い、予測残差D’を導出する。逆変換部116は、その予測残差D’を演算部117に供給する。この逆変換部116により行われる逆直交変換は、変換部112により行われる直交変換の逆処理であり、後述する画像復号装置において行われる逆直交変換と同様の処理である。
演算部117は、逆変換部116から供給される予測残差D’と、予測部119より供給される、その予測残差D’に対応する予測画像Pとを加算して局所的な復号画像Recを導出する。演算部117は、その局所的な復号画像Recをフレームメモリ118に供給する。
フレームメモリ118は、演算部117より供給される局所的な復号画像Recを用いてピクチャ単位の復号画像を再構築し、フレームメモリ118内のバッファへ格納する。フレームメモリ118は、予測部119により指定される復号画像を参照画像としてバッファより読み出し、予測部119に供給する。また、フレームメモリ118は、復号画像の生成に係るヘッダ情報Hinfo、予測情報Pinfo、変換情報Tinfoなどを、フレームメモリ118内のバッファに格納するようにしても良い。
予測部119は、予測情報Pinfoのモード情報pred_mode_flagに基づいて、フレームメモリ118に格納された符号化対象のCUと同一時刻の復号画像を参照画像として取得する。そして、予測部119は、参照画像を用いて、符号化対象のPUに対して、イントラ予測モード情報が示すイントラ予測モードのイントラ予測処理を行う。
また、予測部119は、予測情報Pinfoのモード情報pred_mode_flagと参照画像特定情報に基づいて、フレームメモリ118に格納された符号化対象のCUとは異なる時刻の復号画像を参照画像として取得する。予測部119は、Merge flag、Affine flag、および動きベクトル情報に基づいて、参照画像に対して並進移動モードまたはアフィン変換モードで動き補償を行い、マージモードまたはAMVPモードのインター予測処理を行う。
予測部119は、イントラ予測処理またはインター予測処理の結果生成される符号化対象のPUの予測画像Pを演算部111や演算部117に供給する。
(2つの動きベクトル情報の説明)
図11は、制御部101によりRDOに基づいて設定される2つの動きベクトル情報を説明する図である。
図11のAに示すように、予測対象のPU121がy方向のサイズHに比べてx方向のサイズWが大きい横長の長方形である場合、制御部101は、RDOに基づいて、PU121の左上の頂点Aの動きベクトルvと右上の頂点Bの動きベクトルvの動きベクトル情報を設定する。即ち、制御部101は、RDOに基づいて、サイズHとサイズWのうちの大きいサイズWの方向であるx方向に並ぶ2つの頂点Aと頂点Bの動きベクトルvとvの動きベクトル情報を設定する。
従って、予測部119は、PU121とは異なる時刻の参照画像内のブロック122を、設定された2つの動きベクトル情報に対応する動きベクトルvと動きベクトルvに基づいてアフィン変換することにより、PU121の予測画像を生成する。なお、ブロック122は、頂点Aから動きベクトルvだけ離れた点A´を左上の頂点とし、頂点Bから動きベクトルvだけ離れた点B´を右上の頂点とするブロックである。
ここで、図11のAに示すように、動きベクトルvに誤差eが発生し、動きベクトルvに誤差eが発生すると、予測部119は、参照画像内のブロック123を、動きベクトルv+eと動きベクトルv+eに基づいてアフィン変換することにより、PU121の予測画像を生成する。なお、ブロック123は、頂点Aから動きベクトルv+eだけ離れた点A´´を左上の頂点とし、頂点Bから動きベクトルv+eだけ離れた点B´´を右上の頂点とするブロックである。
PU121の各動き補償ブロックの動きベクトルvの誤差は、その動きベクトルvの計算に用いられる動きベクトルvの誤差eと動きベクトルvの誤差eの影響を受ける。また、その影響は、動きベクトルvに対応する頂点Aと動きベクトルvに対応する頂点Bから遠いほど大きい。
しかしながら、図11のAでは、頂点Aと頂点Bは、PU121の長辺方向であるx方向に並んでいるため、頂点Aに対向する頂点Cと頂点Aの距離、および、頂点Bに対向する頂点Dと頂点Bの距離は小さい。従って、ブロック122とブロック123のズレは、PU121の短辺方向に並ぶ頂点Aと頂点Cの動きベクトルに基づいてアフィン変換を行う場合に比べて、小さくなる。
一方、図11のBに示すように、予測対象のPU131がx方向のサイズWに比べてy方向のサイズHが大きい縦長の長方形である場合、制御部101は、RDOに基づいて、PU131の左上の頂点Aの動きベクトルvと左下の頂点Cの動きベクトルvの動きベクトル情報を設定する。即ち、制御部101は、RDOに基づいて、サイズWとサイズHのうちの大きいサイズHの方向であるy方向に並ぶ2つの頂点Aと頂点Cの動きベクトルvとvの動きベクトル情報を設定する。
従って、予測部119は、PU131とは異なる時刻の参照画像内のブロック132を、設定された2つの動きベクトル情報に対応する動きベクトルvと動きベクトルvに基づいてアフィン変換することにより、PU131の予測画像を生成する。なお、ブロック132は、頂点Aから動きベクトルvだけ離れた点A´を左上の頂点とし、頂点Cから動きベクトルvだけ離れた点C´を左下の頂点とするブロックである。
ここで、図11のBに示すように、動きベクトルvに誤差eが発生し、動きベクトルvに誤差eが発生すると、予測部119は、参照画像内のブロック133を、動きベクトルv+eと動きベクトルv+eに基づいてアフィン変換することにより、PU131の予測画像を生成する。なお、ブロック133は、頂点Aから動きベクトルv+eだけ離れた点A´´を左上の頂点とし、頂点Cから動きベクトルv+eだけ離れた点C´´を左下の頂点とするブロックである。
この場合、PU131の各動き補償ブロックの動きベクトルv(v,v)は、以下の式(2)により求められ、動きベクトルvの誤差は、その動きベクトルvの計算に用いられる動きベクトルvの誤差eと動きベクトルvの誤差eの影響を受ける。また、その影響は、動きベクトルvに対応する頂点Aと動きベクトルvに対応する頂点Cから遠いほど大きい。
Figure 2018131523
しかしながら、図11のBでは、頂点Aと頂点Cは、PU131の長辺方向であるy方向に並んでいるため、頂点Aに対向する頂点Bと頂点Aの距離、および、頂点Cに対向する頂点Dと頂点Cの距離は小さい。従って、ブロック132とブロック133のズレは、PU131の短辺方向に並ぶ頂点Aと頂点Bの動きベクトルに基づいてアフィン変換を行う場合に比べて、小さくなる。
なお、動きベクトルv乃至vに誤差が発生していない場合、動きベクトルvと動きベクトルvに基づくアフィン変換により生成される予測画像と、動きベクトルvと動きベクトルvに基づくアフィン変換により生成される予測画像は同一である。
(隣接ベクトルの説明)
図12は、予測ベクトルの候補となる隣接ベクトルを説明する図である。
予測部119は、図12の予測対象のPU151の左上の頂点Aの動きベクトルvの予測ベクトルpvの候補となる隣接ベクトルを、頂点Aを頂点とするPU151の左上の符号化済みのPUであるブロックa、上側の符号化済みのPUであるブロックb、または左側の符号化済みのPUであるブロックcの動きベクトルに基づいて生成する。
また、予測部119は、PU151の右上の頂点Bの動きベクトルvの予測ベクトルpvの候補となる隣接ベクトルを、頂点Bを頂点とするPU151の上側の符号化済みのPUであるブロックd、または、右上側の符号化済みのPUであるブロックeの動きベクトルに基づいて生成する。
予測部119は、頂点Cの動きベクトルvの予測ベクトルpvの候補となる隣接ベクトルを、頂点Cを頂点とするPU151の左側の符号化済みのPUであるブロックf、または、左下側の符号化済みのPUであるブロックgの動きベクトルに基づいて生成する。なお、ブロックa乃至gの動きベクトルは、予測部119において保持される、ブロックに対して1つの動きベクトルである。
以上により、予測ベクトルpv乃至pvの候補となる隣接ベクトルの生成に用いられる動きベクトルの組み合わせの候補は、12(=3×2×2)通りある。予測部119は、この12通りの組み合わせの候補のうち、以下の式(3)により求められるDVが最も小さくなる組み合わせを、予測ベクトルpv乃至pvの候補となる隣接ベクトルの生成に用いられる動きベクトルの組み合わせとして選択する。
Figure 2018131523
なお、v0x´,v0y´は、予測ベクトルpvの生成に用いられるブロックa乃至cのいずれかのx方向、y方向の動きベクトルである。v1x´,v1y´は、予測ベクトルpvの生成に用いられるブロックdおよびeのいずれかのx方向、y方向の動きベクトルである。v2x´,v2y´は、予測ベクトルpvの生成に用いられるブロックfおよびgのいずれかのx方向、y方向の動きベクトルである。
式(3)によれば、動きベクトルv´(v0x´,v0y´)乃至v´(v2x´,v2y´)に基づくアフィン変換により、2つの動きベクトルに基づくアフィン変換では不可能なスキュー以外が行われる場合、DVが小さくなる。
(Affine flagの符号化の説明)
図13は、Affine flagが1であるCU(PU)の領域を示す例である。
なお、図13において、画像170内の白色の矩形は、Affine flagが0であるCU(PU)を表し、斜線が付された矩形は、Affine flagが1であるCU(PU)を表す。また、図13では、図面を見やすくするため、画像170内の一部のCUのみを図示している。
図13に示すように、画像170内のAffine flagが1であるCU(PU)の領域171は、まとまって存在していると推測される。
従って、例えば、図14のAに示すように、サイズWがサイズHに比べて大きい横長のPU191が存在する場合、PU191のx方向の上辺の頂点Aおよび頂点Bに隣接するブロックa乃至eのAffine flagが1であるとき、PU191の下辺が領域171の境界192である可能性が高い。従って、PU191のAffine flagは1である可能性が高い。
また、図14のBに示すように、PU191のx方向の下辺の頂点Cに隣接するブロックfおよびgのAffine flagが1であるとき、PU191の上辺が境界192である可能性が高い。従って、PU191のAffine flagは1である可能性が高い。
一方、図15のAに示すように、サイズHがサイズWに比べて大きい縦長のPU193が存在する場合、PU193のy方向の左辺の頂点Aおよび頂点Cに隣接するブロックa乃至c,f、およびgのAffine flagが1であるとき、PU193の右辺が領域171の境界194である可能性が高い。従って、PU193のAffine flagは1である可能性が高い。
また、図15のBに示すように、PU193のy方向の右辺の頂点Bに隣接するブロックdおよびeのAffine flagが1であるとき、PU193の左辺が境界194である可能性が高い。従って、PU193のAffine flagは1である可能性が高い。
よって、符号化部114は、PU(CU)のx方向のサイズWとy方向のサイズHのうちの大きいサイズの方向の辺の頂点に隣接する隣接PUのAffine flagが1であるかどうかに基づいて、そのPUのAffine flagのCABACの確率モデルのコンテキストを切り替える。
具体的には、符号化部114は、横長のPU191のAffine flagをCABACで符号化する場合、ブロックa乃至e、または、ブロックfおよびgのうちの所定数以上のブロックのAffine flagが1であるとき、Affine flagが1である可能性が高いことを確率モデルのコンテキストとして用いる。
一方、ブロックa乃至e、または、ブロックfおよびgのうちの所定数未満のブロックのAffine flagが1であるとき、符号化部114は、Affine flagが1である可能性が低いことを確率モデルのコンテキストとして用いる。
また、縦長のPU193のAffine flagをCABACで符号化する場合、符号化部114は、ブロックa乃至c,f、およびg、または、ブロックdおよびeのうちの所定数以上のブロックのAffine flagが1であるとき、Affine flagが1である可能性が高いことを確率モデルのコンテキストとして用いる。
一方、ブロックa乃至c,f、およびg、または、ブロックdおよびeのうちの所定数未満のブロックのAffine flagが1であるとき、符号化部114は、Affine flagが1である可能性が低いことを確率モデルのコンテキストとして用いる。
さらに、PUが正方形である場合、符号化部114は、ブロックa乃至eのうちの所定数以上のブロックのAffine flagが1であるとき、Affine flagが1である可能性が高いことを確率モデルのコンテキストとして用いる。
一方、ブロックa乃至eのうちの所定数未満のブロックのAffine flagが1であるとき、符号化部114は、Affine flagが1である可能性が低いことを確率モデルのコンテキストとして用いる。
そして、符号化部114は、Affine flagが1である可能性が高いことを確率モデルのコンテキストとして用いてAffine flagをCABACで符号化する場合、CABACの確率モデルを、1である確率が高くなるように設定して符号化を行う。これにより、Affine flagが1である場合の符号量が、Affine flagが0である場合の符号量に比べて小さくなる。
また、符号化部114は、Affine flagが1である可能性が低いことをコンテキストとして用いてAffine flagをCABACで符号化する場合、CABACの確率モデルを、0である確率が高くなるように設定して符号化を行う。これにより、Affine flagが0である場合の符号量が、Affine flagが1である場合の符号量に比べて小さくなる。
その結果、符号化部114は、オーバーヘッドであるAffine flagの符号量を削減し、符号化効率を向上させることができる。
なお、Affine flagが1であるブロックの数が所定数以上であるかどうかで、コンテキストを切り替えるのではなく、Affine flagが1であるブロックの数で、コンテキストを切り替えるようにしてもよい。この場合、例えば、Affine flagが1であるブロックの数に応じて、CABACの確率モデルの1である確率が変更される。
また、符号化部114は、ブロックa乃至gのAffine flagに基づいて、CABACの確率モデルのコンテキストを切り替えるのではなく、Affine flagに割り当てる符号(ビット列)を切り替えるようにしてもよい。
この場合、符号化部114は、CABACの確率モデルを、1である確率が高くなるように設定する代わりに、1であるAffine flagに割り当てる符号の符号長(ビット長)を、0であるAffine flagに比べて短くする。また、符号化部114は、CABACの確率モデルを、0である確率が高くなるように設定する代わりに、0であるAffine flagに割り当てる符号の符号長を、1であるAffine flagに比べて短くする。
(画像処理装置の処理の説明)
図16は、図10の画像符号化装置100の画像符号化処理を説明するフローチャートである。
図16のステップS11において、制御部101は、外部からの入力およびRDO等に基づいて、符号化パラメータ(ヘッダ情報Hinfo、予測情報Pinfo、変換情報Tinfo等)を設定する。制御部101は、設定された符号化パラメータを各ブロックへ供給する。
ステップS12において、予測部119は、予測情報Pinfoのモード情報pred_mode_flagが、インター予測処理を示すかどうかを判定する。ステップS12でインター予測処理を示すと判定された場合、ステップS13において、予測部119は、予測情報PinfoのMerge flagが1であるかどうかを判定する。
ステップS13でMerge flagが1であると判定された場合、ステップS14において、予測部119は、予測情報PinfoのAffine flagが1であるかどうかを判定する。ステップS14でAffine flagが1であると判定された場合、処理はステップS15に進む。
ステップS15において、予測部119は、アフィン変換モードで動き補償を行い、マージモードのインター予測処理を行うことにより生成された予測画像Pを用いて符号化対象の画像Iを符号化するマージアフィン変換モード符号化処理を行う。このマージアフィン変換モード符号化処理の詳細は、後述する図19を参照して説明する。マージアフィン変換モード符号化処理の終了後、画像符号化処理は終了する。
一方、ステップS14でAffine flagが1ではないと判定された場合、即ちAffine flagが0である場合、処理はステップS16に進む。
ステップS16において、予測部119は、並進移動モードで動き補償を行い、マージモードのインター予測処理を行うことにより生成された予測画像Pを用いて符号化対象の画像Iを符号化するマージモード符号化処理を行う。マージモード符号化処理の終了後、画像符号化処理は終了する。
また、ステップS13でMerge flagが1ではないと判定された場合、即ちMerge flagが0である場合、ステップS17において、予測部119は、予測情報PinfoのAffine flagが1であるかどうかを判定する。ステップS17でAffine flagが1であると判定された場合、処理はステップS18に進む。
ステップS18において、予測部119は、アフィン変換モードで動き補償を行い、AMVPモードのインター予測処理を行うことにより生成された予測画像Pを用いて符号化対象の画像Iを符号化するAMVPアフィン変換モード符号化処理を行う。このAMVPアフィン変換モード符号化処理の詳細は、後述する図20を参照して説明する。AMVPアフィン変換モード符号化処理の終了後、画像符号化処理は終了する。
一方、ステップS17でAffine flagが1ではないと判定された場合、即ちAffine flagが0である場合、処理はステップS19に進む。
ステップS19において、予測部119は、並進移動モードで動き補償を行い、AMVPモードのインター予測処理を行うことにより生成された予測画像Pを用いて符号化対象の画像Iを符号化するAMVPモード符号化処理を行う。AMVPモード符号化処理の終了後、画像符号化処理は終了する。
また、ステップS12でインター予測処理を示さないと判定された場合、即ちモード情報pred_mode_flagがイントラ予測処理を示す場合、処理はステップS20に進む。
ステップS20において、予測部119は、イントラ予測処理により生成された予測画像Pを用いて符号化対象の画像Iを符号化するイントラ符号化処理を行う。そして、画像符号化処理は終了する。
図17は、図16のステップS11の処理のうちの、Merge flag とAffine flagを設定するインター予測処理モード設定処理の第1の例を説明するフローチャートである。このインター予測処理モード設定処理は、例えば、PU(CU)単位で行われる。
図17のステップS41において、制御部101は、各ブロックを制御して、処理対象のPU(CU)に対して、候補となるMerge flag とAffine flag以外の予測情報Pinfoごとにマージモード符号化処理を行い、RDコストJMRGを計算する。なお、RDコストの計算は、符号化の結果得られる発生ビット量(符号量)、復号画像のSSE(Error Sum of Squares)などに基づいて行われる。
ステップS42において、制御部101は、各ブロックを制御して、処理対象のPU(CU)に対して候補となるMerge flag とAffine flag以外の予測情報PinfoごとにAMVPモード符号化処理を行い、RDコストJAMVPを計算する。
ステップS43において、制御部101は、各ブロックを制御して、処理対象のPU(CU)に対して、候補となるMerge flag とAffine flag以外の予測情報Pinfoごとにマージアフィン変換モード符号化処理を行い、RDコストJMRGAFFINEを計算する。
ステップS44において、制御部101は、各ブロックを制御して、処理対象のPU(CU)に対して候補となるMerge flag とAffine flag以外の予測情報PinfoごとにAMVPアフィン変換モード符号化処理を行い、RDコストJAMVPAFFINEを計算する。
ステップS45において、制御部101は、RDコストJMRGが、RDコストJMRG,JAMVP,JMRGAFFINE、およびJAMVPAFFINEの中で最小であるかどうかを判定する。
ステップS45でRDコストJMRGが最小であると判定された場合、ステップS46において、制御部101は、処理対象のPUのMerge flagを1に設定し、Affine flagを0に設定する。そして、インター予測処理モード設定処理は終了する。
ステップS45でRDコストJMRGが最小ではないと判定された場合、処理はステップS47に進む。ステップS47において、制御部101は、RDコストJAMVPが、RDコストJMRG,JAMVP,JMRGAFFINE、およびJAMVPAFFINEの中で最小であるかどうかを判定する。
ステップS47でRDコストJAMVPが最小であると判定された場合、ステップS48において、制御部101は、処理対象のPUのMerge flagとAffine flagを0に設定し、インター予測処理モード設定処理を終了する。
一方、ステップS47でRDコストJAMVPが最小ではないと判定された場合、処理はステップS49に進む。ステップS49において、制御部101は、RDコストJMRGAFFINEが、RDコストJMRG,JAMVP,JMRGAFFINE、およびJAMVPAFFINEの中で最小であるかどうかを判定する。
ステップS49でRDコストJMRGAFFINEが最小であると判定された場合、ステップS50において、制御部101は、処理対象のPUのMerge flagとAffine flagを1に設定し、インター予測処理モード設定処理を終了する。
一方、ステップS49でRDコストJMRGAFFINEが最小ではないと判定された場合、即ちRDコストJAMVPAFFINEがRDコストJMRG,JAMVP,JMRGAFFINE、およびJAMVPAFFINEの中で最小である場合、処理はステップS51に進む。ステップS51において、制御部101は、処理対象のPUのMerge flagを0に設定し、Affine flagを1に設定する。そして、インター予測処理モード設定処理は終了する。
図18は、図16のステップS11の処理のうちの、Merge flag とAffine flagを設定するインター予測処理モード設定処理の第2の例を説明するフローチャートである。このインター予測処理モード設定処理は、例えば、PU(CU)単位で行われる。
図18のステップS71およびS72の処理は、図17のステップS41およびS42の処理と同様であるので、説明は省略する。
ステップS73において、制御部101は、処理対象のPUのy方向のサイズHがx方向のサイズWに比べて小さいかどうかを判定する。ステップS73でサイズHがサイズWに比べて小さいと判定された場合、即ち処理対象のPUの形状が横長の長方形である場合、処理はステップS74に進む。
ステップS74において、制御部101は、処理対象のPUに隣接するブロックa乃至e、または、ブロックfおよびgのうちの所定数以上のブロックのAffine flagが1であるかどうかを判定する。
ステップS74でブロックa乃至e、または、ブロックfおよびgのうちの所定数以上のブロックのAffine flagが1であると判定された場合、制御部101は、処理対象のPUのAffine flagが1である可能性が高いと判断し、処理をステップS78に進める。
一方、ステップS73でサイズHがサイズWに比べて小さくはないと判定された場合、処理はステップS75に進む。ステップS75において、制御部101は、処理対象のPUのy方向のサイズHがx方向のサイズWに比べて大きいかどうかを判定する。ステップS75でサイズHがサイズWに比べて大きいと判定された場合、即ち処理対象のPUの形状が縦長の長方形である場合、処理はステップS76に進む。
ステップS76において、制御部101は、処理対象のPUに隣接するブロックa乃至c,f、およびg、または、ブロックdおよびeのうちの所定数以上のブロックのAffine flagが1であるかどうかを判定する。
ステップS76でブロックa乃至c,f、およびg、または、ブロックdおよびeのうちの所定数以上のブロックのAffine flagが1であると判定された場合、制御部101は、処理対象のPUのAffine flagが1である可能性が高いと判断する。そして、制御部101は、処理をステップS78に進める。
一方、ステップS75でサイズHがサイズWに比べて大きくはないと判定された場合、即ちサイズHとサイズWが同一である場合、処理はステップS77に進む。ステップS77において、制御部101は、処理対象のPUに隣接するブロックa乃至gのうちの所定数以上のブロックのAffine flagが1であるかどうかを判定する。
ステップS77でブロックa乃至gのうちの所定数以上のブロックのAffine flagが1であると判定された場合、制御部101は、処理対象のPUのAffine flagが1である可能性が高いと判断し、処理をステップS78に進める。
ステップS78およびS79の処理は、図17のステップS43およびS44の処理と同様であるので、説明は省略する。ステップS79の処理後、処理はステップS80に進む。
ステップS74でブロックa乃至e、または、ブロックfおよびgのうちの所定数未満のブロックのAffine flagが1であると判定された場合、制御部101は、処理対象のPUのAffine flagが1である可能性が低いと判断する。そして、制御部101は、ステップS78およびS79をスキップし、処理をステップS80に進める。
また、ステップS76でブロックa乃至c,f、およびg、または、ブロックdおよびeのうちの所定数未満のブロックのAffine flagが1であると判定された場合、制御部101は、処理対象のPUのAffine flagが1である可能性が低いと判断する。そして、制御部101は、ステップS78およびS79をスキップし、処理をステップS80に進める。
さらに、ステップS77でブロックa乃至gのうちの所定数未満のブロックのAffine flagが1であると判定された場合、制御部101は、処理対象のPUのAffine flagが1である可能性が低いと判断する。そして、制御部101は、ステップS78およびS79をスキップし、処理をステップS80に進める。
ステップS80において、制御部101は、RDコストJMRGが、計算されたRDコストJMRG,JAMVP,JMRGAFFINE、およびJAMVPAFFINE、または、RDコストJMRGおよびJAMVPの中で最小であるかどうかを判定する。
ステップS80でRDコストJMRGが最小であると判定された場合、ステップS81において、制御部101は、処理対象のPUのMerge flagを1に設定し、Affine flagを0に設定する。そして、インター予測処理モード設定処理は終了する。
ステップS80でRDコストJMRGが最小ではないと判定された場合、処理はステップS82に進む。ステップS82において、制御部101は、計算されたRDコストJMRG,JAMVP,JMRGAFFINE、およびJAMVPAFFINE、または、RDコストJMRGおよびJAMVPの中で最小であるかどうかを判定する。
ステップS82でRDコストJAMVPが最小であると判定された場合、ステップS83において、制御部101は、処理対象のPUのMerge flagとAffine flagを0に設定し、インター予測処理モード設定処理を終了する。
一方、ステップS82でRDコストJAMVPが最小ではないと判定された場合、処理はステップS84に進む。ステップS84において、制御部101は、RDコストJMRGAFFINEが、計算されたRDコストJMRG,JAMVP,JMRGAFFINE、およびJAMVPAFFINE、または、RDコストJMRGおよびJAMVPの中で最小であるかどうかを判定する。
ステップS84でRDコストJMRGAFFINEが最小であると判定された場合、ステップS85において、制御部101は、処理対象のPUのMerge flagとAffine flagを1に設定し、インター予測処理モード設定処理を終了する。
一方、ステップS84でRDコストJMRGAFFINEが最小ではないと判定された場合、即ちRDコストJAMVPAFFINEが、計算されたRDコストJMRG,JAMVP,JMRGAFFINE、およびJAMVPAFFINE、または、RDコストJMRGおよびJAMVPの中で最小である場合、処理はステップS86に進む。ステップS86において、制御部101は、処理対象のPUのMerge flagを0に設定し、Affine flagを1に設定する。そして、インター予測処理モード設定処理は終了する。
以上のように、図18のインター予測処理モード設定処理では、図13で説明したようにAffine flagが1であるPUの領域が画像内にまとまって存在していると推測して、処理対象のPUに隣接する所定数以上のブロックのAffine flagが1である場合にのみ、ステップS78およびS79の処理が行われる。従って、図17のインター予測処理モード設定処理に比べて、計算量を削減することができる。
図19は、マージアフィン変換モード符号化処理を説明するフローチャートである。このマージアフィン変換モード符号化処理は、例えば、CU(PU)単位で行われる。
図19のステップS101において、予測部119は、処理対象のPUのサイズHがサイズWに比べて大きいかどうかを判定する。ステップS101で処理対象のPUのサイズHがサイズWに比べて大きいと判定された場合、即ち処理対象のPUの形状が縦長の長方形である場合、処理はステップS102に進む。
ステップS102において、予測部119は、予測ベクトル情報に基づいて、予測ベクトルpvおよび予測ベクトルpvを決定する。具体的には、予測部119は、予測ベクトル情報が隣接ベクトルを特定する情報である場合、保持しているブロックa乃至gの動きベクトルに基づいて、予測ベクトルpv乃至pvとなる隣接ベクトルの生成に用いられる動きベクトルの全ての組み合わせのDVを計算する。そして、予測部119は、DVが最も小さくなる動きベクトルの組み合わせを用いて、予測ベクトルpvおよび予測ベクトルpvを決定する。そして、処理はステップS104に進む。
一方、ステップS101で処理対象のPUのサイズHがサイズWに比べて大きくはないと判定された場合、即ち、処理対象のPUの形状が正方形または横長の長方形である場合、処理はステップS103に進む。
ステップS103において、予測部119は、予測ベクトル情報に基づいて、予測ベクトルpvおよび予測ベクトルpvを決定する。具体的には、予測部119は、予測ベクトル情報が隣接ベクトルを特定する情報である場合、保持しているブロックa乃至gの動きベクトルに基づいて、予測ベクトルpv乃至pvとなる隣接ベクトルの生成に用いられる動きベクトルの全ての組み合わせのDVを計算する。そして、予測部119は、DVが最も小さくなる動きベクトルの組み合わせを用いて、予測ベクトルpvおよび予測ベクトルpvを決定する。そして、処理はステップS104に進む。
なお、サイズHがサイズWと同一である場合、即ち、処理対象のPUの形状が正方形である場合、予測部119は、ステップS103の処理ではなく、ステップS102の処理を行うようにしてもよい。
ステップS104において、予測部119は、ステップS102またはS103で決定された各予測ベクトルを、処理対象のPUの動きベクトルとして用いて、上述した式(1)または(2)により、各動き補償ブロックの動きベクトルvを計算する。
具体的には、ステップS102で予測ベクトルpvと予測ベクトルpvが決定される場合、予測部119は、予測ベクトルpvを動きベクトルvとし、予測ベクトルpvを動きベクトルvとして、式(2)により動きベクトルvを計算する。
一方、ステップS103で予測ベクトルpvと予測ベクトルpvが決定される場合、予測部119は、予測ベクトルpvを動きベクトルvとし、予測ベクトルpvを動きベクトルvとして、式(1)により動きベクトルvを計算する。
ステップS105において、予測部119は、動き補償ブロックごとに、動きベクトルvに基づいて、フレームメモリ118に格納された参照画像特定情報により特定される参照画像のブロックを並進移動させることにより、参照画像に対してアフィン変換を行う。予測部119は、アフィン変換により動き補償が行われた参照画像を予測画像Pとして、演算部111や演算部117に供給する。
ステップS106において、演算部111は、画像Iと予測画像Pとの差分を予測残差Dとして演算し、それを変換部112に供給する。このようにして求められた予測残差Dは、元の画像Iに比べてデータ量が低減される。したがって、画像Iをそのまま符号化する場合に比べて、データ量を圧縮することができる。
ステップS107において、変換部112は、制御部101から供給される変換情報Tinfoに基づいて、演算部111から供給される予測残差Dに対して直交変換等を行い、変換係数Coeffを導出する。変換部112は、変換係数Coeffを量子化部113に供給する。
ステップS108において、量子化部113は、制御部101から供給される変換情報Tinfoに基づいて、変換部112から供給される変換係数Coeffをスケーリング(量子化)し、量子化変換係数レベルlevelを導出する。量子化部113は、量子化変換係数レベルlevelを符号化部114および逆量子化部115に供給する。
ステップS109において、逆量子化部115は、制御部101から供給される変換情報Tinfoに基づいて、量子化部113から供給される量子化変換係数レベルlevelを、ステップS108の量子化の特性に対応する特性で逆量子化する。逆量子化部115は、その結果得られる変換係数Coeff_IQを逆変換部116に供給する。
ステップS110において、逆変換部116は、制御部101から供給される変換情報Tinfoに基づいて、逆量子化部115から供給される変換係数Coeff_IQに対して、ステップS107の直交変換等に対応する方法で逆直交変換等を行い、予測残差D’を導出する。
ステップS111において、演算部117は、ステップS110の処理により導出された予測残差D’を、予測部119から供給される予測画像Pと加算することにより、局所的な復号画像Recを生成する。
ステップS112において、フレームメモリ118は、ステップS111の処理により得られた、局所的な復号画像Recを用いてピクチャ単位の復号画像を再構築し、フレームメモリ118内のバッファへ記憶する。
ステップS113において、符号化部114は、図16のステップS11の処理により設定された符号化パラメータとステップS108の処理により得られた量子化変換係数レベルlevelを所定の方法で符号化する。符号化部114は、その結果得られる符号化データを多重化し、符号化ストリームとして画像符号化装置100の外部に出力する。この符号化ストリームは、例えば、伝送路や記録媒体を介して復号側に伝送される。
ステップS113の処理が終了すると、マージアフィン変換モード符号化処理が終了する。
図20は、AMVPアフィン変換モード符号化処理を説明するフローチャートである。このAMVPアフィン変換モード符号化処理は、例えば、CU(PU)単位で行われる。
図20のステップS131乃至S133は、図19のステップS101乃至S103の処理と同様であるので、説明は省略する。
ステップS134において、予測部119は、ステップS132またはS133で決定された各予測ベクトルと、その予測ベクトルに対応する動きベクトル情報のうちの差分とをそれぞれ加算し、処理対象のPUの動きベクトルを計算する。
具体的には、ステップS132で予測ベクトルpvと予測ベクトルpvが決定される場合、予測部119は、予測ベクトルpvと、動きベクトル情報のうちの予測ベクトルpvと処理対象のPUの動きベクトルとの差分dvとを加算する。そして、予測部119は、加算の結果得られる動きベクトルを、処理対象のPUの動きベクトルvとする。また、予測部119は、予測ベクトルpvと、動きベクトル情報のうちの予測ベクトルpvと処理対象のPUの動きベクトルとの差分dvとを加算し、その結果得られる動きベクトルを、処理対象のPUの動きベクトルvとする。
一方、ステップS133で予測ベクトルpvと予測ベクトルpvが決定される場合、予測部119は、予測ベクトルpvと差分dvとを加算し、その結果得られる動きベクトルを、処理対象のPUの動きベクトルvとする。また、予測部119は、予測ベクトルpvと、動きベクトル情報のうちの予測ベクトルpvと処理対象のPUの動きベクトルとの差分dvとを加算し、その結果得られる動きベクトルを、処理対象のPUの動きベクトルvとする。
ステップS135において、予測部119は、ステップS134で計算された処理対象のPUの動きベクトルを用いて、上述した式(1)または(2)により、各動き補償ブロックの動きベクトルvを計算する。
具体的には、ステップS134で動きベクトルvと動きベクトルvが決定される場合、予測部119は、動きベクトルvと動きベクトルvを用いて、式(2)により動きベクトルvを計算する。
一方、ステップS134で動きベクトルvと動きベクトルvが決定される場合、予測部119は、動きベクトルvと動きベクトルvを用いて、式(1)により動きベクトルvを計算する。
ステップS136乃至S144の処理は、図19のステップS105乃至S113の処理と同様であるので、説明は省略する。
図21は、図19のステップS113および図20のステップS144の処理のうちの、Affine flagを符号化するAffine flag符号化処理を説明するフローチャートである。
図21のステップS161およびステップS162の処理は、予測部119ではなく符号化部114が行う点を除いて、図18のステップS73およびS74の処理と同様であるので、説明は省略する。
ステップS162でブロックa乃至e、または、ブロックfおよびgのうちの所定数以上のブロックのAffine flagが1であると判定された場合、符号化部114は、処理対象のPUのAffine flagが1である可能性が高いと判断する。そして、符号化部114は、処理をステップS163に進める。
ステップS163において、符号化部114は、Affine flagが1である可能性が高いことを確率モデルのコンテキストとして用いて、Affine flagをCABACで符号化し、Affine flag符号化処理を終了する。
一方、ステップS161でサイズHがサイズWより小さくはないと判定された場合、処理はステップS164に進む。ステップS164乃至S166の処理は、制御部101ではなく符号化部114により行われる点を除いて、図18のステップS75乃至S77と同様でるので、説明は省略する。
ステップS165でブロックa乃至c,f、およびg、または、ブロックdおよびeのうちの所定数以上のブロックのAffine flagが1であると判定された場合、符号化部114は、処理対象のPUのAffine flagが1である可能性が高いと判断する。そして、符号化部114は、処理をステップS163に進める。
また、ステップS166でブロックa乃至gのうちの所定数以上のブロックのAffine flagが1であると判定された場合、符号化部114は、処理対象のPUのAffine flagが1である可能性が高いと判断する。そして、符号化部114は、処理をステップS163に進める。
一方、ステップS162でブロックa乃至e、または、ブロックfおよびgのうちの所定数未満のブロックのAffine flagが1であると判定された場合、符号化部114は、処理対象のPUのAffine flagが1である可能性が低いと判断する。そして、符号化部114は、処理をステップS167に進める。
また、ステップS165でブロックa乃至c,f、およびg、または、ブロックdおよびeのうちの所定数未満のブロックのAffine flagが1であると判定された場合、符号化部114は、処理対象のPUのAffine flagが1である可能性が低いと判断する。そして、符号化部114は、処理をステップS167に進める。
さらに、ステップS166でブロックa乃至gのうちの所定数未満のブロックのAffine flagが1であると判定された場合、符号化部114は、処理対象のPUのAffine flagが1である可能性が低いと判断する。そして、符号化部114は、処理をステップS167に進める。
ステップS167において、符号化部114は、Affine flagが1である可能性が低いことをコンテキストとして用いて、Affine flagをCABACで符号化し、Affine flag符号化処理を終了する。
以上のように、画像符号化装置100は、アフィン変換によるインター予測処理を行う場合に、PUのx方向のサイズWとy方向のサイズHのうちの大きいサイズの方向に並ぶ頂点の2つの動きベクトルに基づいて、PUの予測画像Pを生成する。従って、長方形のPUの頂点の動きベクトルに発生した誤差の予測画像Pの精度への影響を抑制することができる。
その結果、長方形のPUの予測画像Pを高精度で生成することができる。これにより、量子化変換係数レベルlevelがゼロではない場合、量子化変換係数レベルlevelの情報量を削減し、符号化効率を向上することができる。また、量子化変換係数レベルlevelがゼロである場合、復号画像の画質を向上させることができる。
また、画像符号化装置100は、2つの動きベクトルに基づいてアフィン変換を行うので、3つの動きベクトルに基づいてアフィン変換を行う場合に比べて、オーバーヘッドを削減し、符号化効率を向上させることができる。
(画像復号装置の構成例)
図22は、図10の画像符号化装置100により生成された符号化ストリームを復号する、本技術を適用した画像処理装置としての画像復号装置の一実施の形態の構成例を示すブロック図である。図22の画像復号装置200は、画像符号化装置100により生成された符号化ストリームを、画像符号化装置100における符号化方法に対応する復号方法で復号する。例えば、画像復号装置200は、HEVCに提案された技術や、JVETにて提案された技術を実装している。
なお、図22においては、処理部やデータの流れ等の主なものを示しており、図22に示されるものが全てとは限らない。つまり、画像復号装置200において、図22においてブロックとして示されていない処理部が存在したり、図22において矢印等として示されていない処理やデータの流れが存在したりしてもよい。
図22の画像復号装置200は、復号部211、逆量子化部212、逆変換部213、演算部214、フレームメモリ215、および予測部216を有する。画像符号化装置100は、画像符号化装置100により生成された符号化ストリームに対してCUごとに復号を行う。
具体的には、画像復号装置200の復号部211は、画像符号化装置100により生成された符号化ストリームを、符号化部114における符号化方法に対応する所定の復号方法で復号する。例えば、復号部211は、シンタックステーブルの定義に沿って、符号化ストリームのビット列から、符号化パラメータ(ヘッダ情報Hinfo、予測情報Pinfo、変換情報Tinfo等)と量子化変換係数レベルlevelを復号する。復号部211は、符号化パラメータに含まれるsplit flagに基づいてLCUを分割し、各量子化変換係数レベルlevelに対応するCUを順に復号対象のCU(PU,TU)に設定する。
復号部211は、符号化パラメータを各ブロックへ供給する。例えば、復号部211は、予測情報Pinfoを予測部216に供給し、変換情報Tinfoを逆量子化部212と逆変換部213に供給し、ヘッダ情報Hinfoを各ブロックに供給する。また、復号部211は、量子化変換係数レベルlevelを逆量子化部212に供給する。
逆量子化部212は、復号部211から供給される変換情報Tinfoに基づいて、復号部211から供給される量子化変換係数レベルlevelの値をスケーリング(逆量子化)し、変換係数Coeff_IQを導出する。この逆量子化は、画像符号化装置100の量子化部113(図10)により行われる量子化の逆処理である。なお、逆量子化部115(図10)は、この逆量子化部212と同様の逆量子化を行う。逆量子化部212は、得られた変換係数Coeff_IQを逆変換部213に供給する。
逆変換部213は、復号部211から供給される変換情報Tinfo等に基づいて、逆量子化部212より供給される変換係数Coeff_IQに対して逆直交変換等を行い、予測残差D’を導出する。この逆直交変換は、画像符号化装置100の変換部112(図10)により行われる直交変換の逆処理である。なお、逆変換部116は、この逆変換部213と同様の逆直交変換を行う。逆変換部213は、得られた予測残差D’を演算部214に供給する。
演算部214は、逆変換部213から供給される予測残差D’とその予測残差D’に対応する予測画像Pとを加算し、局所的な復号画像Recを導出する。演算部214は、得られた局所的な復号画像Recを用いてピクチャ単位毎の復号画像を再構築し、得られた復号画像を画像復号装置200の外部に出力する。また、演算部214は、その局所的な復号画像Recをフレームメモリ215にも供給する。
フレームメモリ215は、演算部214より供給される局所的な復号画像Recを用いてピクチャ単位毎の復号画像を再構築し、フレームメモリ215内のバッファに格納する。フレームメモリ215は、予測部216により指定される復号画像を参照画像としてバッファより読み出し、予測部216に供給する。また、フレームメモリ215は、その復号画像の生成に係るヘッダ情報Hinfo、予測情報Pinfo、変換情報Tinfoなどをフレームメモリ215内のバッファに格納するようにしても良い。
予測部216は、予測情報Pinfoのモード情報pred_mode_flagに基づいて、フレームメモリ215に格納された符号化対象のCUと同一時刻の復号画像を参照画像として取得する。そして、予測部216は、参照画像を用いて、符号化対象のPUに対して、イントラ予測モード情報が示すイントラ予測モードのイントラ予測処理を行う。
また、予測部216は、予測情報Pinfoのモード情報pred_mode_flagと参照画像特定情報に基づいて、フレームメモリ215に格納された符号化対象のCUとは異なる時刻の復号画像を参照画像として取得する。予測部216は、図10の予測部119と同様に、Merge flag、Affine flag、および動きベクトル情報に基づいて、参照画像に対して、並進移動モードまたはアフィン変換モードで動き補償を行い、マージモードまたはAMVPモードのインター予測処理を行う。予測部216は、イントラ予測処理またはインター予測処理の結果生成される予測画像Pを演算部214に供給する。
(画像復号装置の処理)
図23は、図22の画像復号装置200の画像復号処理を説明するフローチャートである。
ステップS201において、復号部211は、画像復号装置200に供給される符号化ストリームを復号し、符号化パラメータと量子化変換係数レベルlevelを得る。復号部211は、符号化パラメータを各ブロックへ供給する。また、復号部211は、量子化変換係数レベルlevelを逆量子化部212に供給する。
ステップS202において、復号部211は、符号化パラメータに含まれるsplit flagに基づいてLCUを分割し、各量子化変換係数レベルlevelに対応するCUを復号対象のCU(PU,TU)に設定する。後述するステップS203乃至S211の処理は、復号対象のCU(PU,TU)ごとに行われる。
ステップS203乃至S205の処理は、予測部119ではなく予測部216により行われる点を除いて、図16のステップS12乃至S14の処理と同様であるので、説明は省略する。
ステップS205でAffine flagが1であると判定された場合、処理はステップS206に進む。ステップS206において、予測部216は、アフィン変換モードで動き補償を行い、マージモードのインター予測処理を行うことにより生成された予測画像Pを用いて復号対象の画像を復号するマージアフィン変換モード復号処理を行う。このマージアフィン変換モード復号処理の詳細は、後述する図24を参照して説明する。マージアフィン変換モード復号処理の終了後、画像復号処理は終了する。
一方、ステップS205でAffine flagが1ではないと判定された場合、即ちAffine flagが0である場合、処理はステップS207に進む。ステップS207において、予測部216は、並進移動モードで動き補償を行い、マージモードのインター予測処理を行うことにより生成された予測画像Pを用いて復号対象の画像を復号するマージモード復号処理を行う。マージモード復号処理の終了後、画像復号処理は終了する。
また、ステップS204でMerge flagが1ではないと判定された場合、即ちMerge flagが0である場合、ステップS208において、予測部216は、予測情報PinfoのAffine flagが1であるかどうかを判定する。ステップS208でAffine flagが1であると判定された場合、処理はステップS209に進む。
ステップS209において、予測部216は、アフィン変換モードで動き補償を行い、AMVPモードのインター予測処理を行うことにより生成された予測画像Pを用いて復号対象の画像を復号するAMVPアフィン変換モード復号処理を行う。このAMVPアフィン変換モード復号処理の詳細は、後述する図25を参照して説明する。AMVPアフィン変換モード復号処理の終了後、画像復号処理は終了する。
一方、ステップS208でAffine flagが1ではないと判定された場合、即ちAffine flagが0である場合、処理はステップS210に進む。
ステップS210において、予測部216は、並進移動モードで動き補償を行い、AMVPモードのインター予測処理を行うことにより生成された予測画像Pを用いて復号対象の画像を復号するAMVPモード復号処理を行う。AMVPモード復号処理の終了後、画像復号処理は終了する。
また、ステップS203でインター予測処理を示さないと判定された場合、即ちモード情報pred_mode_flagがイントラ予測処理を示す場合、処理はステップS211に進む。
ステップS211において、予測部216は、イントラ予測処理により生成された予測画像Pを用いて復号対象の画像を復号するイントラ復号処理を行う。そして、画像復号処理は終了する。
図24は、図23のステップS206のマージアフィン変換モード復号処理を説明するフローチャートである。
ステップS231において、逆量子化部212は、図23のステップS201の処理により得られた量子化変換係数レベルlevelを逆量子化して変換係数Coeff_IQを導出する。この逆量子化は、画像符号化処理のステップS108(図19)において行われる量子化の逆処理であり、画像符号化処理のステップS109(図19)において行われる逆量子化と同様の処理である。
ステップS232において、逆変換部213は、ステップS231の処理により得られた変換係数Coeff_IQに対して逆直交変換等を行い、予測残差D'を導出する。この逆直交変換は、画像符号化処理のステップS107(図19)において行われる直交変換の逆処理であり、画像符号化処理のステップS110(図19)において行われる逆直交変換と同様の処理である。
ステップS233乃至S237の処理は、予測部119ではなく予測部216により行われる点を除いて、図19のステップS101乃至S105の処理と同様であるので、説明は省略する。
ステップS238において、演算部214は、逆変換部213から供給される予測残差D’を、予測部216から供給される予測画像Pと加算し、局所的な復号画像Recを導出する。演算部214は、得られた局所的な復号画像Recを用いてピクチャ単位毎の復号画像を再構築し、得られた復号画像を画像復号装置200の外部に出力する。また、演算部214は、その局所的な復号画像Recをフレームメモリ215に供給する。
ステップS239において、フレームメモリ215は、演算部214より供給される局所的な復号画像Recを用いてピクチャ単位毎の復号画像を再構築し、フレームメモリ215内のバッファに記憶する。そして、処理は、図23のステップS206に戻り、画像復号処理を終了する。
図25は、図23のステップS209のAMVPアフィン変換モード復号処理を説明するフローチャートである。
図25のステップS251およびS252の処理は、図24のステップS231およびS232の処理と同様であるので、説明は省略する。
ステップS253乃至S258の処理は、予測部119ではなく予測部216により行われる点を除いて、図20のステップS131乃至S136の処理と同様であるので、説明は省略する。
ステップS259およびS260の処理は、図24のステップS238およびS239の処理と同様であるので、説明は省略する。
以上のように、画像復号装置200は、アフィン変換によるインター予測処理を行う場合に、PUのx方向のサイズWとy方向のサイズHのうちの大きいサイズの方向に並ぶ頂点の2つの動きベクトルに基づいて、PUの予測画像Pを生成する。従って、長方形のPUの頂点の動きベクトルに発生した誤差の予測画像Pの精度への影響を抑制することができる。その結果、長方形のPUの予測画像Pを高精度で生成することができる。
なお、画像符号化装置100と画像復号装置200が、イントラ予測処理やインター予測処理の代わりに、イントラBC予測処理を行う場合、イントラBC予測処理における動き補償をインター予測処理における動き補償と同様に行うようにしてもよい。
<第2実施の形態>
(本開示を適用したコンピュータの説明)
上述した一連の処理は、ハードウエアにより実行することもできるし、ソフトウエアにより実行することもできる。一連の処理をソフトウエアにより実行する場合には、そのソフトウエアを構成するプログラムが、コンピュータにインストールされる。ここで、コンピュータには、専用のハードウエアに組み込まれているコンピュータや、各種のプログラムをインストールすることで、各種の機能を実行することが可能な、例えば汎用のパーソナルコンピュータなどが含まれる。
図26は、上述した一連の処理をプログラムにより実行するコンピュータのハードウエアの構成例を示すブロック図である。
コンピュータ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は、ハードディスクや不揮発性のメモリなどよりなる。通信部814は、ネットワークインタフェースなどよりなる。ドライブ815は、磁気ディスク、光ディスク、光磁気ディスク、又は半導体メモリなどのリムーバブルメディア821を駆動する。
以上のように構成されるコンピュータ800では、CPU801が、例えば、記憶部813に記憶されているプログラムを、入出力インタフェース810及びバス804を介して、RAM803にロードして実行することにより、上述した一連の処理が行われる。
コンピュータ800(CPU801)が実行するプログラムは、例えば、パッケージメディア等としてのリムーバブルメディア821に記録して提供することができる。また、プログラムは、ローカルエリアネットワーク、インターネット、デジタル衛星放送といった、有線または無線の伝送媒体を介して提供することができる。
コンピュータ800では、プログラムは、リムーバブルメディア821をドライブ815に装着することにより、入出力インタフェース810を介して、記憶部813にインストールすることができる。また、プログラムは、有線または無線の伝送媒体を介して、通信部814で受信し、記憶部813にインストールすることができる。その他、プログラムは、ROM802や記憶部813に、あらかじめインストールしておくことができる。
なお、コンピュータ800が実行するプログラムは、本明細書で説明する順序に沿って時系列に処理が行われるプログラムであっても良いし、並列に、あるいは呼び出しが行われたとき等の必要なタイミングで処理が行われるプログラムであっても良い。
<第3実施の形態>
図27は、上述した実施形態を適用したテレビジョン装置の概略的な構成の一例を示している。テレビジョン装置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の機能を有するようにしてもよい。つまり、デコーダ904が、符号化データを、以上の各実施の形態において説明した方法で復号するようにしてもよい。このようにすることにより、テレビジョン装置900は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
また、このように構成されたテレビジョン装置900において、映像信号処理部905が、例えば、デコーダ904から供給される画像データを符号化し、得られた符号化データを、外部インタフェース部909を介してテレビジョン装置900の外部に出力させることができるようにしてもよい。そして、その映像信号処理部905が、上述した画像符号化装置100の機能を有するようにしてもよい。つまり、映像信号処理部905が、デコーダ904から供給される画像データを、以上の各実施の形態において説明した方法で符号化するようにしてもよい。このようにすることにより、テレビジョン装置900は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
<第4実施の形態>
図28は、上述した実施形態を適用した携帯電話機の概略的な構成の一例を示している。携帯電話機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の機能を有するようにしてもよい。つまり、画像処理部927が、画像データを、以上の各実施の形態において説明した方法で符号化するようにしてもよい。このようにすることにより、携帯電話機920は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
また、このように構成された携帯電話機920において、例えば画像処理部927が、上述した画像復号装置200の機能を有するようにしてもよい。つまり、画像処理部927が、符号化データを、以上の各実施の形態において説明した方法で復号するようにしてもよい。このようにすることにより、携帯電話機920は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
<第5実施の形態>
図29は、上述した実施形態を適用した記録再生装置の概略的な構成の一例を示している。記録再生装置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へ出力する。
HDD部944は、映像および音声などのコンテンツデータが圧縮された符号化ビットストリーム、各種プログラムおよびその他のデータを内部のハードディスクに記録する。また、HDD部944は、映像および音声の再生時に、これらデータをハードディスクから読み出す。
ディスクドライブ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から入力される符号化ビットストリームを選択し、選択した符号化ビットストリームをHDD部944又はディスクドライブ945へ出力する。また、セレクタ946は、映像及び音声の再生時には、HDD部944又はディスクドライブ945から入力される符号化ビットストリームをデコーダ947へ出力する。
デコーダ947は、符号化ビットストリームを復号し、映像データ及び音声データを生成する。そして、デコーダ947は、生成した映像データをOSD部948へ出力する。また、デコーダ947は、生成した音声データを外部のスピーカへ出力する。
OSD部948は、デコーダ947から入力される映像データを再生し、映像を表示する。また、OSD部948は、表示する映像に、例えばメニュー、ボタン又はカーソルなどのGUIの画像を重畳してもよい。
制御部949は、CPUなどのプロセッサ、並びにRAM及びROMなどのメモリを有する。メモリは、CPUにより実行されるプログラム、及びプログラムデータなどを記憶する。メモリにより記憶されるプログラムは、例えば、記録再生装置940の起動時にCPUにより読み込まれ、実行される。CPUは、プログラムを実行することにより、例えばユーザインタフェース部950から入力される操作信号に応じて、記録再生装置940の動作を制御する。
ユーザインタフェース部950は、制御部949と接続される。ユーザインタフェース部950は、例えば、ユーザが記録再生装置940を操作するためのボタンおよびスイッチ、並びに遠隔制御信号の受信部などを有する。ユーザインタフェース部950は、これら構成要素を介してユーザによる操作を検出して操作信号を生成し、生成した操作信号を制御部949へ出力する。
このように構成された記録再生装置940において、例えばエンコーダ943が、上述した画像符号化装置100の機能を有するようにしてもよい。つまり、エンコーダ943が、画像データを、以上の各実施の形態において説明方法で符号化するようにしてもよい。このようにすることにより、記録再生装置940は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
また、このように構成された記録再生装置940において、例えばデコーダ947が、上述した画像復号装置200の機能を有するようにしてもよい。つまり、デコーダ947が、符号化データを、以上の各実施の形態において説明した方法で復号するようにしてもよい。このようにすることにより、記録再生装置940は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
<第6実施の形態>
図30は、上述した実施形態を適用した撮像装置の概略的な構成の一例を示している。撮像装置960は、被写体を撮像して画像を生成し、画像データを符号化して記録媒体に記録する。
撮像装置960は、光学ブロック961、撮像部962、信号処理部963、画像処理部964、表示部965、外部インタフェース(I/F)部966、メモリ部967、メディアドライブ968、OSD部969、制御部970、ユーザインタフェース(I/F)部971、およびバス972を備える。
光学ブロック961は、撮像部962に接続される。撮像部962は、信号処理部963に接続される。表示部965は、画像処理部964に接続される。ユーザインタフェース部971は、制御部970に接続される。バス972は、画像処理部964、外部インタフェース部966、メモリ部967、メディアドライブ968、OSD部969、および制御部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は、OSD部969から取得される表示用データを、表示部965へ出力する画像に重畳してもよい。
OSD部969は、例えばメニュー、ボタン又はカーソルなどの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の機能を有するようにしてもよい。つまり、画像処理部964が、画像データを、以上の各実施の形態において説明した方法で符号化するようにしてもよい。このようにすることにより、撮像装置960は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
また、このように構成された撮像装置960において、例えば画像処理部964が、上述した画像復号装置200の機能を有するようにしてもよい。つまり、画像処理部964が、符号化データを、以上の各実施の形態において説明した方法で復号するようにしてもよい。このようにすることにより、撮像装置960は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
<第7実施の形態>
また、本技術は、任意の装置またはシステムを構成する装置に搭載するあらゆる構成、例えば、システムLSI(Large Scale Integration)等としてのプロセッサ、複数のプロセッサ等を用いるモジュール、複数のモジュール等を用いるユニット、ユニットにさらにその他の機能を付加したセット等(すなわち、装置の一部の構成)として実施することもできる。図31は、本技術を適用したビデオセットの概略的な構成の一例を示している。
近年、電子機器の多機能化が進んでおり、その開発や製造において、その一部の構成を販売や提供等として実施する場合、1機能を有する構成として実施を行う場合だけでなく、関連する機能を有する複数の構成を組み合わせ、複数の機能を有する1セットとして実施を行う場合も多く見られるようになってきた。
図31に示されるビデオセット1300は、このような多機能化された構成であり、画像の符号化や復号(いずれか一方でもよいし、両方でも良い)に関する機能を有するデバイスに、その機能に関連するその他の機能を有するデバイスを組み合わせたものである。
図31に示されるように、ビデオセット1300は、ビデオモジュール1311、外部メモリ1312、パワーマネージメントモジュール1313、およびフロントエンドモジュール1314等のモジュール群と、コネクティビティ1321、カメラ1322、およびセンサ1323等の関連する機能を有するデバイスとを有する。
モジュールは、互いに関連するいくつかの部品的機能をまとめ、まとまりのある機能を持った部品としたものである。具体的な物理的構成は任意であるが、例えば、それぞれ機能を有する複数のプロセッサ、抵抗やコンデンサ等の電子回路素子、その他のデバイス等を配線基板等に配置して一体化したものが考えられる。また、モジュールに他のモジュールやプロセッサ等を組み合わせて新たなモジュールとすることも考えられる。
図31の例の場合、ビデオモジュール1311は、画像処理に関する機能を有する構成を組み合わせたものであり、アプリケーションプロセッサ、ビデオプロセッサ、ブロードバンドモデム1333、およびRFモジュール1334を有する。
プロセッサは、所定の機能を有する構成をSoC(System On a Chip)により半導体チップに集積したものであり、例えばシステムLSI(Large Scale Integration)等と称されるものもある。この所定の機能を有する構成は、論理回路(ハードウエア構成)であってもよいし、CPU、ROM、RAM等と、それらを用いて実行されるプログラム(ソフトウエア構成)であってもよいし、その両方を組み合わせたものであってもよい。例えば、プロセッサが、論理回路とCPU、ROM、RAM等とを有し、機能の一部を論理回路(ハードウエア構成)により実現し、その他の機能をCPUにおいて実行されるプログラム(ソフトウエア構成)により実現するようにしてもよい。
図31のアプリケーションプロセッサ1331は、画像処理に関するアプリケーションを実行するプロセッサである。このアプリケーションプロセッサ1331において実行されるアプリケーションは、所定の機能を実現するために、演算処理を行うだけでなく、例えばビデオプロセッサ1332等、ビデオモジュール1311内外の構成を必要に応じて制御することもできる。
ビデオプロセッサ1332は、画像の符号化・復号(その一方または両方)に関する機能を有するプロセッサである。
ブロードバンドモデム1333は、インターネットや公衆電話回線網等の広帯域の回線を介して行われる有線若しくは無線(またはその両方)の広帯域通信により送信するデータ(デジタル信号)をデジタル変調する等してアナログ信号に変換したり、その広帯域通信により受信したアナログ信号を復調してデータ(デジタル信号)に変換したりする。ブロードバンドモデム1333は、例えば、ビデオプロセッサ1332が処理する画像データ、画像データが符号化されたストリーム、アプリケーションプログラム、設定データ等、任意の情報を処理する。
RFモジュール1334は、アンテナを介して送受信されるRF(Radio Frequency)信号に対して、周波数変換、変復調、増幅、フィルタ処理等を行うモジュールである。例えば、RFモジュール1334は、ブロードバンドモデム1333により生成されたベースバンド信号に対して周波数変換等を行ってRF信号を生成する。また、例えば、RFモジュール1334は、フロントエンドモジュール1314を介して受信されたRF信号に対して周波数変換等を行ってベースバンド信号を生成する。
なお、図31において点線1341に示されるように、アプリケーションプロセッサ1331とビデオプロセッサ1332を、一体化し、1つのプロセッサとして構成されるようにしてもよい。
外部メモリ1312は、ビデオモジュール1311の外部に設けられた、ビデオモジュール1311により利用される記憶デバイスを有するモジュールである。この外部メモリ1312の記憶デバイスは、どのような物理構成により実現するようにしてもよいが、一般的にフレーム単位の画像データのような大容量のデータの格納に利用されることが多いので、例えばDRAM(Dynamic Random Access Memory)のような比較的安価で大容量の半導体メモリにより実現するのが望ましい。
パワーマネージメントモジュール1313は、ビデオモジュール1311(ビデオモジュール1311内の各構成)への電力供給を管理し、制御する。
フロントエンドモジュール1314は、RFモジュール1334に対してフロントエンド機能(アンテナ側の送受信端の回路)を提供するモジュールである。図31に示されるように、フロントエンドモジュール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は、本技術を適用したセットとして実施することができる。
(ビデオプロセッサの構成例)
図32は、本技術を適用したビデオプロセッサ1332(図31)の概略的な構成の一例を示している。
図32の例の場合、ビデオプロセッサ1332は、ビデオ信号およびオーディオ信号の入力を受けてこれらを所定の方式で符号化する機能と、符号化されたビデオデータおよびオーディオデータを復号し、ビデオ信号およびオーディオ信号を再生出力する機能とを有する。
図32に示されるように、ビデオプロセッサ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(図31)等から入力されたビデオ信号を取得し、デジタル画像データに変換する。第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は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
なお、エンコード・デコードエンジン1407において、本技術(すなわち、画像符号化装置100の機能若しくは画像復号装置200の機能またはその両方)は、論理回路等のハードウエアにより実現するようにしてもよいし、組み込みプログラム等のソフトウエアにより実現するようにしてもよいし、それらの両方により実現するようにしてもよい。
(ビデオプロセッサの他の構成例)
図33は、本技術を適用したビデオプロセッサ1332の概略的な構成の他の例を示している。図33の例の場合、ビデオプロセッサ1332は、ビデオデータを所定の方式で符号化・復号する機能を有する。
より具体的には、図33に示されるように、ビデオプロセッサ1332は、制御部1511、ディスプレイインタフェース1512、ディスプレイエンジン1513、画像処理エンジン1514、および内部メモリ1515を有する。また、ビデオプロセッサ1332は、コーデックエンジン1516、メモリインタフェース1517、多重化・逆多重化部(MUX DMUX)1518、ネットワークインタフェース1519、およびビデオインタフェース1520を有する。
制御部1511は、ディスプレイインタフェース1512、ディスプレイエンジン1513、画像処理エンジン1514、およびコーデックエンジン1516等、ビデオプロセッサ1332内の各処理部の動作を制御する。
図33に示されるように、制御部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は、複数の符号化・復号方式のコーデック機能を備え、その中から選択されたもので画像データの符号化または符号化データの復号を行うようにしてもよい。
図33に示される例において、コーデックエンジン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は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
なお、コーデックエンジン1516において、本技術(すなわち、画像符号化装置100の機能)は、論理回路等のハードウエアにより実現するようにしてもよいし、組み込みプログラム等のソフトウエアにより実現するようにしてもよいし、それらの両方により実現するようにしてもよい。
以上にビデオプロセッサ1332の構成を2例示したが、ビデオプロセッサ1332の構成は任意であり、上述した2例以外のものであってもよい。また、このビデオプロセッサ1332は、1つの半導体チップとして構成されるようにしてもよいが、複数の半導体チップとして構成されるようにしてもよい。例えば、複数の半導体を積層する3次元積層LSIとしてもよい。また、複数のLSIにより実現されるようにしてもよい。
(装置への適用例)
ビデオセット1300は、画像データを処理する各種装置に組み込むことができる。例えば、ビデオセット1300は、テレビジョン装置900(図27)、携帯電話機920(図28)、記録再生装置940(図29)、撮像装置960(図30)等に組み込むことができる。ビデオセット1300を組み込むことにより、その装置は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
なお、上述したビデオセット1300の各構成の一部であっても、ビデオプロセッサ1332を含むものであれば、本技術を適用した構成として実施することができる。例えば、ビデオプロセッサ1332のみを本技術を適用したビデオプロセッサとして実施することができる。また、例えば、上述したように点線1341により示されるプロセッサやビデオモジュール1311等を、本技術を適用したプロセッサやモジュール等として実施することができる。さらに、例えば、ビデオモジュール1311、外部メモリ1312、パワーマネージメントモジュール1313、およびフロントエンドモジュール1314を組み合わせ、本技術を適用したビデオユニット1361として実施することもできる。いずれの構成の場合であっても、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
つまり、ビデオプロセッサ1332を含むものであればどのような構成であっても、ビデオセット1300の場合と同様に、画像データを処理する各種装置に組み込むことができる。例えば、ビデオプロセッサ1332、点線1341により示されるプロセッサ、ビデオモジュール1311、または、ビデオユニット1361を、テレビジョン装置900(図27)、携帯電話機920(図28)、記録再生装置940(図29)、撮像装置960(図30)等に組み込むことができる。そして、本技術を適用したいずれかの構成を組み込むことにより、その装置は、ビデオセット1300の場合と同様に、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
<第8実施の形態>
また、本技術は、複数の装置により構成されるネットワークシステムにも適用することもできる。図34は、本技術を適用したネットワークシステムの概略的な構成の一例を示している。
図34に示されるネットワークシステム1600は、機器同士が、ネットワークを介して画像(動画像)に関する情報を授受するシステムである。このネットワークシステム1600のクラウドサービス1601は、自身に通信可能に接続されるコンピュータ1611、AV(Audio Visual)機器1612、携帯型情報処理端末1613、IoT(Internet of Things)デバイス1614等の端末に対して、画像(動画像)に関するサービスを提供するシステムである。例えば、クラウドサービス1601は、所謂動画配信(オンデマンドやライブ配信)のような、画像(動画像)のコンテンツの供給サービスを端末に提供する。また、例えば、クラウドサービス1601は、端末から画像(動画像)のコンテンツを受け取って保管するバックアップサービスを提供する。また、例えば、クラウドサービス1601は、端末同士の画像(動画像)のコンテンツの授受を仲介するサービスを提供する。
クラウドサービス1601の物理構成は任意である。例えば、クラウドサービス1601は、動画像を保存し、管理するサーバ、動画像を端末に配信するサーバ、動画像を端末から取得するサーバ、ユーザ(端末)や課金を管理するサーバ等の各種サーバや、インターネットやLAN等の任意のネットワークを有するようにしてもよい。
コンピュータ1611は、例えば、パーソナルコンピュータ、サーバ、ワークステーション等のような情報処理装置により構成される。AV機器1612は、例えば、テレビジョン受像機、ハードディスクレコーダ、ゲーム機器、カメラ等のような画像処理装置により構成される。携帯型情報処理端末1613は、例えば、ノート型パーソナルコンピュータ、タブレット端末、携帯電話機、スマートフォン等のような携帯型の情報処理装置により構成される。IoTデバイス1614は、例えば、機械、家電、家具、その他の物、ICタグ、カード型デバイス等、画像に関する処理を行う任意の物体により構成される。これらの端末は、いずれも通信機能を有し、クラウドサービス1601に接続し(セッションを確立し)、クラウドサービス1601と情報の授受を行う(すなわち通信を行う)ことができる。また、各端末は、他の端末と通信を行うこともできる。端末間の通信は、クラウドサービス1601を介して行うようにしてもよいし、クラウドサービス1601を介さずに行うようにしてもよい。
以上のようなネットワークシステム1600に本技術を適用し、端末間や、端末とクラウドサービス1601との間で画像(動画像)のデータが授受される際に、その画像データを各実施の形態において上述したように符号化・復号するようにしてもよい。つまり、端末(コンピュータ1611乃至IoTデバイス1614)やクラウドサービス1601が、それぞれ、上述した画像符号化装置100や画像復号装置200の機能を有するようにしてもよい。このようにすることにより、画像データを授受する端末(コンピュータ1611乃至IoTデバイス1614)やクラウドサービス1601は、図10乃至図25を参照して上述した各実施の形態と同様の効果を得ることができる。
なお、符号化データ(ビットストリーム)に関する各種情報は、符号化データに多重化されて伝送され又は記録されるようにしてもよいし、符号化データに多重化されることなく、符号化データと関連付けられた別個のデータとして伝送され又は記録されるようにしてもよい。ここで、「関連付ける」という用語は、例えば、一方のデータを処理する際に他方のデータを利用し得る(リンクさせ得る)ようにすることを意味する。つまり、互いに関連付けられたデータは、1つのデータとしてまとめられてもよいし、それぞれ個別のデータとしてもよい。例えば、符号化データ(画像)に関連付けられた情報は、その符号化データ(画像)とは別の伝送路上で伝送されるようにしてもよい。また、例えば、符号化データ(画像)に関連付けられた情報は、その符号化データ(画像)とは別の記録媒体(又は同一の記録媒体の別の記録エリア)に記録されるようにしてもよい。なお、この「関連付け」は、データ全体でなく、データの一部であってもよい。例えば、画像とその画像に対応する情報とが、複数フレーム、1フレーム、又はフレーム内の一部分などの任意の単位で互いに関連付けられるようにしてもよい。
また、上述したように、本明細書において、「合成する」、「多重化する」、「付加する」、「一体化する」、「含める」、「格納する」、「入れ込む」、「差し込む」、「挿入する」等の用語は、例えば符号化データとメタデータとを1つのデータにまとめるといった、複数の物を1つにまとめることを意味し、上述の「関連付ける」の1つの方法を意味する。
なお、本明細書に記載された効果はあくまで例示であって限定されるものではなく、他の効果があってもよい。
また、本開示の実施の形態は、上述した実施の形態に限定されるものではなく、本開示の要旨を逸脱しない範囲において種々の変更が可能である。
なお、本開示は、以下のような構成もとることができる。
(1)
ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの予測画像を生成する予測部
を備える画像処理装置。
(2)
前記予測部は、前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向の辺の頂点に隣接する隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成される場合、前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの予測画像を生成する
ように構成された
前記(1)に記載の画像処理装置。
(3)
前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて前記ブロックの予測画像を生成することを示す複数ベクトル予測情報を符号化する符号化部
をさらに備える
前記(1)または(2)に記載の画像処理装置。
(4)
前記符号化部は、前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向の辺の頂点に隣接する隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成されるかどうかに基づいて、前記複数ベクトル予測情報を符号化する
ように構成された
前記(3)に記載の画像処理装置。
(5)
前記符号化部は、前記隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成されるかどうかに基づいて、前記複数ベクトル予測情報の符号化における確率モデルのコンテキストを切り替える
ように構成された
前記(4)に記載の画像処理装置。
(6)
前記符号化部は、前記隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成されるかどうかに基づいて、前記複数ベクトル予測情報の符号を切り替える
ように構成された
前記(4)に記載の画像処理装置。
(7)
前記符号化部は、前記隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成される場合、前記隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成されない場合に比べて符号量が小さくなるように、前記複数ベクトル予測情報を符号化する
ように構成された
前記(4)乃至(6)のいずれかに記載の画像処理装置。
(8)
前記予測部は、前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの参照画像をアフィン変換することにより、前記ブロックの予測画像を生成する
ように構成された
前記(1)乃至(7)のいずれかに記載の画像処理装置。
(9)
前記ブロックは、1つのブロックの水平方向および垂直方向の少なくとも一方への分割を再帰的に繰り返すことにより生成される
ように構成された
前記(1)乃至(8)のいずれかに記載の画像処理装置。
(10)
画像処理装置が、
ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの予測画像を生成するステップ
を含む画像処理方法。
100 画像符号化装置, 114 符号化部, 119 予測部, 121,131,191,193 PU, 200 画像復号装置, 216 予測部

Claims (10)

  1. ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの予測画像を生成する予測部
    を備える画像処理装置。
  2. 前記予測部は、前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向の辺の頂点に隣接する隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成される場合、前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの予測画像を生成する
    ように構成された
    請求項1に記載の画像処理装置。
  3. 前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて前記ブロックの予測画像を生成することを示す複数ベクトル予測情報を符号化する符号化部
    をさらに備える
    請求項1に記載の画像処理装置。
  4. 前記符号化部は、前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向の辺の頂点に隣接する隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成されるかどうかに基づいて、前記複数ベクトル予測情報を符号化する
    ように構成された
    請求項3に記載の画像処理装置。
  5. 前記符号化部は、前記隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成されるかどうかに基づいて、前記複数ベクトル予測情報の符号化における確率モデルのコンテキストを切り替える
    ように構成された
    請求項4に記載の画像処理装置。
  6. 前記符号化部は、前記隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成されるかどうかに基づいて、前記複数ベクトル予測情報の符号を切り替える
    ように構成された
    請求項4に記載の画像処理装置。
  7. 前記符号化部は、前記隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成される場合、前記隣接ブロックの予測画像が、前記隣接ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて生成されない場合に比べて符号量が小さくなるように、前記複数ベクトル予測情報を符号化する
    ように構成された
    請求項4に記載の画像処理装置。
  8. 前記予測部は、前記ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの参照画像をアフィン変換することにより、前記ブロックの予測画像を生成する
    ように構成された
    請求項1に記載の画像処理装置。
  9. 前記ブロックは、1つのブロックの水平方向および垂直方向の少なくとも一方への分割を再帰的に繰り返すことにより生成される
    ように構成された
    請求項1に記載の画像処理装置。
  10. 画像処理装置が、
    ブロックの縦方向と横方向のサイズのうちの大きいサイズの方向に並ぶ2つの頂点の動きベクトルに基づいて、前記ブロックの予測画像を生成するステップ
    を含む画像処理方法。
JP2018561334A 2017-01-12 2017-12-28 画像処理装置および画像処理方法 Pending JPWO2018131523A1 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
JP2017003465 2017-01-12
JP2017003465 2017-01-12
PCT/JP2017/047373 WO2018131523A1 (ja) 2017-01-12 2017-12-28 画像処理装置および画像処理方法

Publications (1)

Publication Number Publication Date
JPWO2018131523A1 true JPWO2018131523A1 (ja) 2019-11-07

Family

ID=62840581

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2018561334A Pending JPWO2018131523A1 (ja) 2017-01-12 2017-12-28 画像処理装置および画像処理方法

Country Status (10)

Country Link
US (1) US20190335191A1 (ja)
EP (1) EP3570547A4 (ja)
JP (1) JPWO2018131523A1 (ja)
KR (1) KR20190105572A (ja)
CN (1) CN110169071A (ja)
AU (1) AU2017393148A1 (ja)
BR (1) BR112019013978A2 (ja)
CA (1) CA3048569A1 (ja)
RU (1) RU2019120751A (ja)
WO (1) WO2018131523A1 (ja)

Families Citing this family (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10609384B2 (en) * 2017-09-21 2020-03-31 Futurewei Technologies, Inc. Restriction on sub-block size derivation for affine inter prediction
WO2019139309A1 (ko) * 2018-01-15 2019-07-18 삼성전자 주식회사 부호화 방법 및 그 장치, 복호화 방법 및 그 장치
GB2577318B (en) * 2018-09-21 2021-03-10 Canon Kk Video coding and decoding
CN113170192B (zh) * 2018-11-15 2023-12-01 北京字节跳动网络技术有限公司 仿射的merge与mvd
WO2020173477A1 (en) * 2019-02-27 2020-09-03 Beijing Bytedance Network Technology Co., Ltd. Regression-based motion vector field based sub-block motion vector derivation
WO2020181428A1 (zh) * 2019-03-08 2020-09-17 Oppo广东移动通信有限公司 预测方法、编码器、解码器及计算机存储介质
AU2020321002B2 (en) 2019-07-26 2023-06-01 Beijing Bytedance Network Technology Co., Ltd. Determination of picture partition mode based on block size
CN114175650A (zh) * 2019-07-26 2022-03-11 北京字节跳动网络技术有限公司 视频编解码中的变换尺寸和编解码树单元尺寸的相互依赖

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5716437B2 (ja) * 2011-02-08 2015-05-13 株式会社Jvcケンウッド 画像符号化装置、画像符号化方法および画像符号化プログラム
US10560712B2 (en) * 2016-05-16 2020-02-11 Qualcomm Incorporated Affine motion prediction for video coding

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
FENG ZOU ET AL., EE4: IMPROVED AFFINE MOTION PREDICTION, JPN6021039472, 6 October 2016 (2016-10-06), ISSN: 0004613096 *

Also Published As

Publication number Publication date
EP3570547A4 (en) 2020-02-12
US20190335191A1 (en) 2019-10-31
CA3048569A1 (en) 2018-07-19
AU2017393148A1 (en) 2019-07-25
RU2019120751A (ru) 2021-01-13
CN110169071A (zh) 2019-08-23
WO2018131523A1 (ja) 2018-07-19
EP3570547A1 (en) 2019-11-20
BR112019013978A2 (pt) 2020-03-03
KR20190105572A (ko) 2019-09-17

Similar Documents

Publication Publication Date Title
US11997316B2 (en) Image processing apparatus and method for curbing deterioration in coding efficiency
WO2018047668A1 (ja) 画像処理装置および画像処理方法
WO2018131523A1 (ja) 画像処理装置および画像処理方法
WO2018070267A1 (ja) 画像処理装置および画像処理方法
RU2669685C2 (ru) Устройство и способ декодирования изображения
WO2018131515A1 (ja) 画像処理装置及び画像処理方法
WO2017126333A1 (ja) 画像処理装置および方法
US20200213610A1 (en) Image processor and image processing method
WO2015008652A1 (ja) 画像処理装置および方法
JP6497562B2 (ja) 画像符号化装置および方法
JP6891895B2 (ja) 画像処理装置および画像処理方法
WO2016104179A1 (ja) 画像処理装置および画像処理方法
WO2020008724A1 (ja) 画像処理装置、画像処理方法及びプログラム
WO2017073362A1 (ja) 画像処理装置および方法
JPWO2016147836A1 (ja) 画像処理装置および方法
WO2017073360A1 (ja) 画像処理装置および方法
RU2679990C2 (ru) Устройство и способ кодирования изображения и устройство и способ декодирования изображения
WO2020008769A1 (ja) 画像処理装置、画像処理方法、及び画像処理プログラム
WO2017126331A1 (ja) 画像処理装置および方法
JP2015050738A (ja) 復号装置および復号方法、並びに、符号化装置および符号化方法
JPWO2017169722A1 (ja) 画像処理装置および方法
JP2016096457A (ja) 画像処理装置および方法

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20201106

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20211012

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20220405