JP5587508B2 - ビデオコード化のためのイントラ平滑化フィルタ - Google Patents

ビデオコード化のためのイントラ平滑化フィルタ Download PDF

Info

Publication number
JP5587508B2
JP5587508B2 JP2013531897A JP2013531897A JP5587508B2 JP 5587508 B2 JP5587508 B2 JP 5587508B2 JP 2013531897 A JP2013531897 A JP 2013531897A JP 2013531897 A JP2013531897 A JP 2013531897A JP 5587508 B2 JP5587508 B2 JP 5587508B2
Authority
JP
Japan
Prior art keywords
filter
mode
block size
block
current block
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.)
Active
Application number
JP2013531897A
Other languages
English (en)
Other versions
JP2013543315A (ja
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.)
Qualcomm Inc
Original Assignee
Qualcomm Inc
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 Qualcomm Inc filed Critical Qualcomm Inc
Publication of JP2013543315A publication Critical patent/JP2013543315A/ja
Application granted granted Critical
Publication of JP5587508B2 publication Critical patent/JP5587508B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

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/117Filters, e.g. for pre-processing or post-processing
    • 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
    • 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/103Selection of coding mode or of prediction mode
    • 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/103Selection of coding mode or of prediction mode
    • H04N19/11Selection of coding mode or of prediction mode among a plurality of spatial predictive coding modes
    • 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/12Selection from among a plurality of transforms or standards, e.g. selection between discrete cosine transform [DCT] and sub-band transform or selection between H.263 and H.264
    • H04N19/122Selection of transform size, e.g. 8x8 or 2x4x8 DCT; Selection of sub-band transforms of varying structure or type
    • 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/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/146Data rate or code amount at the encoder output
    • H04N19/147Data rate or code amount at the encoder output according to rate distortion criteria
    • 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/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/157Assigned coding mode, i.e. the coding mode being predefined or preselected to be further used for selection of another element or parameter
    • 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/46Embedding additional information in the video signal during the compression process
    • 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/59Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial sub-sampling or interpolation, e.g. alteration of picture size or resolution
    • 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/593Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial prediction techniques
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/80Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation
    • H04N19/82Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation involving filtering within a prediction loop

Landscapes

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

Description

本開示は、ビデオコード化に関し、より詳細には、イントラ予測ビデオコード化に関する。
[0002]デジタルビデオ機能は、デジタルテレビジョン、デジタルダイレクトブロードキャストシステム、ワイヤレスブロードキャストシステム、携帯情報端末(PDA)、ラップトップまたはデスクトップコンピュータ、デジタルカメラ、デジタル記録デバイス、デジタルメディアプレーヤ、ビデオゲームデバイス、ビデオゲームコンソール、セルラー電話または衛星無線電話、ビデオ遠隔会議デバイスなどを含む、広範囲にわたるデバイスに組み込まれ得る。デジタルビデオデバイスは、デジタルビデオ情報をより効率的に送信および受信するために、MPEG−2、MPEG−4、ITU−T H.263またはITU−T H.264/MPEG−4、Part10、Advanced Video Coding(AVC)によって定義された規格、およびそのような規格の拡張に記載されているビデオ圧縮技法など、ビデオ圧縮技法を実装する。MPEGとITU−TとのコラボレーションであるJCTVC(Joint Collaborative Team-Video Coding)によって開発されている高効率映像符号化(HEVC:High Efficiency Video Coding)規格など、新しいビデオ規格が出現し、発展し続けている。この新しいHEVC規格はH.265と呼ばれることもある。
[0003]ビデオ圧縮技法では、ビデオシーケンスに固有の冗長性を低減または除去するために空間的予測および/または時間的予測を実行する。ブロックベースのビデオコード化の場合、ビデオフレームまたはスライスがコード化ユニット(CU)と呼ばれるブロックに区分され得る。概して、CUは、CUがサイズ差異を有さないことを除いて、H.264規格のマクロブロックと同様の目的を有する。イントラコード化(I)フレームまたはスライス中のCUは、同じフレームまたはスライス中の隣接CUに関する空間的予測を使用して符号化される。インターコード化(PまたはB)フレームまたはスライス中のCUは、同じフレームまたはスライス中の隣接CUに関する空間的予測、あるいは他の参照フレームに関する時間的予測を使用し得る。
[0004]概して、本開示は、ビデオデータのイントラ予測コード化における、予測サンプルの周囲のピクセルに平滑化フィルタを適用するための技法について記載する。詳細には、これらの技法は、イントラ予測コード化において使われる予測サンプルに、平滑化フィルタを決定し適用する方法を提供する。いくつかの例では、これらの技法は、現在のブロックに関連付けられたブロックサイズとイントラ予測モードとの組合せに基づいて、予測サンプルの周囲のピクセルに適用すべき平滑化フィルタを選択することを含む。
[0005]固定モード依存イントラ平滑化において、ビデオ符号器は、現在のブロックに関連付けられたブロックサイズとイントラ予測モードとの組合せに基づいて、予測サンプルに適用される平滑化フィルタのタイプを決定する。ブロックサイズとイントラ予測モードとの組合せは、フィルタテーブル中でフィルタを探すために使用される。この場合、復号器側でフィルタテーブルが利用可能であり、ブロックサイズとイントラ予測モードとの組合せが復号器側で同様に使用されるので、平滑化に使われるフィルタタイプをシグナリングするために復号器に送られるオーバーヘッドがなくなる。
[0006]適応モード依存イントラ平滑化において、ビデオ符号器は、2つのフィルタオプションから平滑化フィルタを選択し、すなわち、1つは第1のフィルタテーブルから、他の1つは第2のフィルタテーブルから選択し、両方のフィルタを適用して、どちらがより良好な結果を生じるかを決定する。この場合、選択されたフィルタを示すシンタックスがビデオとともに符号化され、選択されたフィルタタイプをシグナリングするために復号器に送られ得る。一例において、第2のフィルタテーブルからのフィルタがより良好な結果を生じる場合、ビデオ符号器はフィルタリング指示を符号化する。第1のフィルタテーブルからのフィルタが使われるときは、フィルタリング指示は符号化されない。
[0007]これらの技法により、イントラ予測コード化を使って符号化されるブロックとともに符号化される追加データの量を削減でき、それゆえ、復号器に送信されるデータの量を削減することができる。イントラ予測符号化ブロックを受信したビデオ復号器は、フィルタリング指示がブロックとともに符号化されていなければ、第1のフィルタテーブルを使って、復号中に平滑化フィルタを適用する。フィルタリング指示がブロックとともに符号化されている場合、ビデオ復号器は、フィルタリング指示によって指示されるフィルタを使って、復号中に平滑化フィルタを適用する。
[0008]一例において、本開示は、ビデオデータの現在のブロックに関連付けられたブロックサイズを判断することと、現在のブロックに関連付けられたイントラ予測コード化モードを判断することと、ブロックサイズおよびコード化モードに基づいて、現在のブロックに適用するためにフィルタテーブルからフィルタを選択することと、選択されたフィルタを使って、現在のブロックをイントラ予測コード化することとを備える方法を対象とする。
[0009]別の例では、本開示は、ビデオデータをコード化するための装置を対象とし、この装置は、ビデオデータの現在のブロックに関連付けられたブロックサイズを判断し、現在のブロックに関連付けられたイントラ予測コード化モードを判断し、ブロックサイズおよびコード化モードに基づいて、現在のブロックに適用するためにフィルタテーブルからフィルタを選択し、選択されたフィルタを使って、現在のブロックをイントラ予測コード化するように構成されたプロセッサを備える。
[0010]別の例では、本開示は、ビデオデータを符号化するための装置を対象とし、この装置は、ビデオデータの現在のブロックに関連付けられたブロックサイズを判断する手段と、現在のブロックに関連付けられたイントラ予測コード化モードを判断する手段と、ブロックサイズおよびコード化モードに基づいて、現在のブロックに適用するためにフィルタテーブルからフィルタを選択する手段と、選択されたフィルタを使って、現在のブロックをイントラ予測コード化する手段とを備える。
[0011]さらなる一例では、本開示は、プロセッサで実行されると、プロセッサに、ビデオデータの現在のブロックに関連付けられたブロックサイズを判断させ、現在のブロックに関連付けられたイントラ予測コード化モードを判断させ、ブロックサイズおよびコード化モードに基づいて、現在のブロックに適用するためにフィルタテーブルからフィルタを選択させ、選択されたフィルタを使って、現在のブロックをイントラ予測コード化させる、ビデオデータをコード化するための命令を備えるコンピュータ可読記憶媒体を対象とする。
イントラ平滑化をサポートするための本開示の技法を使用し得る例示的なビデオ符号化および復号システムを示すブロック図。 様々なイントラ予測モードに関連付けられた予測方向の例示的なセットを描いたグラフを示す概念図。 様々なイントラ予測モードに関連付けられた予測方向の例示的なセットを描いた別のグラフを示す概念図。 様々なイントラ予測モードに関連付けられた予測方向の例示的なセットを示す概念図。 イントラ平滑化をサポートするための技法を実装し得るビデオ符号器の一例を示すブロック図。 符号化されたビデオシーケンスを復号するビデオ復号器の一例を示すブロック図。 本開示の技法による、ビデオデータを符号化するための例示的な方法を示すフローチャート。 本開示の技法による、ビデオデータを復号するための例示的な方法を示すフローチャート。 本開示の技法による、ビデオデータを符号化するための別の例示的な方法を示すフローチャート。 本開示の技法による、ビデオデータを復号するための別の例示的な方法を示すフローチャート。
[0022]概して、本開示は、ビデオデータのイントラ予測コード化において使われる予測サンプルを取り囲むピクセルに平滑化フィルタを判断し、適用するための技法について記載する。これらの技法は、符号化中であるビデオデータの現在のブロックに平滑化フィルタを適用するかどうか判断することを含み得る。たとえば、平滑化フィルタを適用するかどうかの判断は、符号化される現在のブロックのサイズと、現在のブロックに関連付けられた符号化モードとに基づき得る。現在のブロックの符号化モードは、現在のブロックのイントラ予測コード化または現在のブロックがそこから予測されるブロックと比較した現在のブロックの方向に関連付けられる方向に基づき得る。現在のブロックにイントラ平滑化フィルタリングを適用するかどうか、および/または現在のブロックに適用すべきイントラ平滑化フィルタのタイプに関する決定を行うために、フィルタリング決定テーブルが生成され、使用され得る。それゆえ、フィルタリング決定は、現在のブロックに関連付けられたブロックサイズおよびイントラ予測モードの関数であり得る。
[0023]ビデオコード化において、予測は、効率を高め、符号化ビデオデータの量を削減し、それゆえ、送信またはその後の取出しおよび表示のために記憶されるビデオデータの量を削減するのに使用することができる。2つのタイプの予測、すなわちインター予測およびイントラ予測が、現代のビデオコード化システムでは頻繁に使われる。インター予測では、現在のビデオブロックが、ビデオシーケンス中の別のフレーム中のビデオブロックから予測される。イントラ予測では、現在のビデオブロックは、同じフレーム内のビデオブロックから予測される。
[0024]上述したように、イントラ予測コード化は、現在のブロックの周囲のピクセルの方向性外挿を実施することによって、フレームの現在のブロックのピクセルを、同じフレームの前に符号化されたブロックのピクセルに関して符号化することを伴う。このように、周囲のピクセルは、現在のブロックについてピクセルを形成するための予測サンプルとして使われる。概して、ピクセルは、指定された方向に沿って現在のブロックを形成するために使われる。現在のブロックサイズが増大すると、予測サンプルからさらに遠ざかる、現在のブロックのピクセルの予測の正確さが低下し得る。イントラ予測コード化における低下を克服するために、周囲の予測サンプルに平滑化が適用される。
[0025]ビデオコード化プロセスは、予測ピクセルに平滑化フィルタを適用し、フィルタリング済みピクセルと非フィルタリングピクセルの両方を使って予測を実施及び比較し、比較の出力結果に基づいて、フィルタリング済みピクセルまたは非フィルタリングピクセルを使うかを判断し、シグナリングする。適応イントラ平滑化(AIS: adaptive intra smoothing)と呼ばれるこの方法を用いると、平滑化フィルタを各ブロックに適用し、結果を非フィルタリングブロックと比較することが要求されるので、符号器の複雑さが増す結果となる。また、この方法を用いると、特定の平滑化フィルタが適用されるべきかどうかを明示的にシグナリングするので、各コード化ユニットに関連付けられたオーバーヘッド情報が増える。さらに、AISデータ(たとえば、信号、平滑化フィルタなど)のエントロピーコード化および復号により、符号化および復号プロセスの複雑さが増す。
[0026]AISの別の実施法は、符号器および復号器においてフィルタインジケータテーブルを利用するものであり、インジケータ値は、ブロックサイズと、予測の方向を示すイントラ予測モードとに依存する。このテーブルは、設計段階中に生成することができ、したがって、ピクセルがフィルタリングされるかどうかに関する決定が符号化プロセス中には実施されないので、符号器の計算の複雑度の増大が回避される。ただし、ビデオ符号器/復号器に対するいくつかの変更は、現在のテーブルと置き換わる新たなテーブルの生成を要求し得る。
[0027]本開示の技法は、規則に基づく簡易AIS方式またはモード依存イントラ平滑化(MDIS:mode-dependent intra smoothing)を提案し、平滑化フィルタを適用するかどうかに関する規則は、現在のブロックのサイズと、予測モードまたは方向とに基づく。MDISは予測モードを階層状に順序付け、階層は異なるブロックサイズにマッッピングされ、ブロックサイズが増大すると、より多くのモードが階層に従ってフィルタリングされる。いくつかの例では、平滑化フィルタを適用するかどうかの判断は、より大きいブロックとより小さいブロックとの間でさらに区別することができ、平滑化フィルタを適用するかどうか判断する手順は、ブロックサイズに基づいて変わり得る。さらに、いくつかのビデオシーケンス、たとえば、方向性テクスチャをもつシーケンスの場合、平滑化フィルタの適用は、ほとんど、または全く有利にならない場合がある。本開示の技法は、これらの問題に対処するための平滑化フィルタ判断を行い得る。イントラ予測および平滑化フィルタ情報は、対応するブロックのヘッダ中に符号化され、復号中に適切な平滑化フィルタを適用するために、ビデオ復号器によって復号され得る。
[0028]図1は、イントラ予測コード化中に平滑化フィルタを適用するための本開示の技法を使用することができる例示的なビデオ符号化および復号システム10を示すブロック図である。図1に示すように、システム10は、通信チャネル16を介して符号化ビデオを宛先デバイス14に送信するソースデバイス12を含む。ソースデバイス12および宛先デバイス14は、広範囲のデバイスのいずれかを備えることができる。いくつかの例では、ソースデバイス12および宛先デバイス14は、いわゆるセルラー電話または衛星無線電話といったワイヤレスハンドセットのようなワイヤレス通信デバイス、または通信チャネル16を介してビデオ情報を通信することができる任意のワイヤレスデバイスを備え得、その場合、通信チャネル16はワイヤレスである。
[0029]本開示の技法は、概して、イントラ予測コード化のための技法に関するが、必ずしもワイヤレスアプリケーションまたはワイヤレス設定に限定されるものではない。たとえば、これらの技法は、物理ワイヤー、光ファイバーまたは他の物理もしくはワイヤレス媒体を介して通信するデバイスを含む、広範な他の設定およびデバイスにおいても有用であり、オーバージエア(over-the-air)のテレビ放送、ケーブルテレビ送信、衛星テレビ送信、インターネットビデオ送信、記憶媒体上に符号化される符号化デジタルビデオ、または他のシナリオに適用され得る。たとえば、符号化ビデオは、宛先デバイス14による、その後の取出し、復号、および表示のために、記憶デバイスに記憶することができる。さらに、本符号化技法または復号技法は、必ずしも他のデバイスと通信するとは限らないスタンドアロンデバイスにおいても適用され得る。したがって、通信チャネル16は、符号化ビデオデータまたは他の記憶媒体の送信に好適なワイヤレスまたはワイヤード媒体の任意の組合せを備え、デバイス12、14は、携帯電話、スマートフォン、デジタルメディアプレーヤ、セットトップボックス、テレビジョン、ディスプレイ、デスクトップコンピュータ、ポータブルコンピュータ、タブレットコンピュータ、ゲームコンソール、ポータブルゲームデバイスなどの様々なワイヤードまたはワイヤレス媒体デバイスのいずれかを備え得る。
[0030]図1の例では、ソースデバイス12は、ビデオソース18と、ビデオ符号器20と、変調器/復調器(モデム)22と、送信機24とを含む。宛先デバイス14は、受信機26と、モデム28と、ビデオ復号器30と、ディスプレイデバイス32とを含む。他の例では、ソースデバイスおよび宛先デバイスは他の構成要素または構成を含み得る。たとえば、ソースデバイス12は、外部カメラ、ビデオストレージアーカイブ、コンピュータグラフィックスソースなどの外部ビデオソース18からビデオデータを受信し得る。同様に、宛先デバイス14は、一体型ディスプレイデバイスを含むのではなく、外部ディスプレイデバイスとインターフェースし得る。
[0031]図1の図示のシステム10は一例にすぎない。イントラ予測コード化において平滑化フィルタを適用するための技法は、どのデジタルビデオ符号化および/または復号デバイスによっても実施することができる。概して、本開示の技法はビデオ符号化デバイスによって実行されるが、本技法は、一般に「コーデック」と呼ばれるビデオ符号器/復号器によっても実行され得る。さらに、本開示の技法はまた、ビデオプリプロセッサによって実行され得る。ソースデバイス12および宛先デバイス14は、ソースデバイス12が宛先デバイス14に送信するためのコード化ビデオデータを生成するコード化デバイスの例にすぎない。いくつかの例では、デバイス12、14の各々がビデオ符号化構成要素と復号構成要素とを含むので、デバイス12、14は、実質的に対称的に動作する。したがって、システム10は、たとえば、ビデオストリーミング、ビデオ再生、ビデオブロードキャストまたはビデオ電話通信のためのビデオデバイス12とビデオデバイス14との間の一方向または双方向のビデオ送信をサポートする。
[0032]ソースデバイス12のビデオソース18は、ビデオカメラのようなビデオキャプチャデバイス、以前にキャプチャされたビデオを含むビデオアーカイブ、および/またはビデオコンテンツプロバイダからのビデオフィードを含み得る。さらなる代替として、ビデオソース18は、ソースビデオとしてのコンピュータグラフィックスベースのデータ、またはライブビデオとアーカイブビデオとコンピュータ生成ビデオとの組合せを生成し得る。場合によっては、ビデオソース18がビデオカメラである場合、ソースデバイス12および宛先デバイス14は、いわゆるカメラ付き携帯電話またはビデオ電話を形成する。ただし、上述のように、本開示で説明する技法は、一般にビデオコード化に適用可能であり、ワイヤレスおよび/またはワイヤードアプリケーションに適用可能であり得る。各場合において、キャプチャされたビデオ、あらかじめキャプチャされたビデオ、またはコンピュータ生成ビデオをビデオ符号器20によって符号化することができる。次いで、符号化ビデオ情報は、通信規格に従ってモデム22によって変調され、送信機24を介して宛先デバイス14に送信され得る。モデム22は、信号変調のために設計された様々なミキサ、フィルタ、増幅器または他の構成要素を含み得る。送信機24は、増幅器、フィルタ、および1つまたは複数のアンテナを含む、データを送信するために設計された回路を含み得る。
[0033]宛先デバイス14の受信機26はチャネル16を介して情報を受信し、モデム28はその情報を復調する。繰返しになるが、ビデオ符号化プロセスは、現在のブロックのイントラ予測コード化中に平滑化フィルタを適用するための、本明細書で説明する技法の1つまたは複数を実装することができる。チャネル16を介して通信される情報は、ビデオ符号器20によって定義されるシンタックス情報を含み、シンタックス情報は、ビデオ復号器30によっても使用され、予測ユニット(PU)、コード化ユニット(CU)またはコード化ビデオの他のユニット、たとえば、ビデオスライス、ビデオフレーム、およびビデオシーケンスまたはピクチャグループ(GOP:group of pictures)の特性および/または処理を記述するシンタックス要素を含み得る。ディスプレイデバイス32は、復号されたビデオデータをユーザに対して表示し、陰極線管(CRT)、液晶ディスプレイ(LCD)、プラズマディスプレイ、有機発光ダイオード(OLED)ディスプレイ、または別のタイプのディスプレイデバイスなど、様々なディスプレイデバイスのいずれかを備え得る。
[0034]図1の例では、通信チャネル16は、無線周波数(RF)スペクトルあるいは1つまたは複数の物理伝送線路などの任意のワイヤレスまたはワイヤード通信媒体、あるいはワイヤレスおよびワイヤード媒体の任意の組合せを備え得る。通信チャネル16は、ローカルエリアネットワーク、ワイドエリアネットワーク、またはインターネットのようなグローバルネットワークなどのパケットベースのネットワークの一部を形成し得る。通信チャネル16は、一般に、ワイヤードまたはワイヤレス媒体の任意の好適な組合せを含む、ビデオデータをソースデバイス12から宛先デバイス14に送信するのに好適な任意の通信媒体、または様々な通信媒体の集合体を表す。通信チャネル16は、ソースデバイス12から宛先デバイス14への通信を可能にするのに有用であり得るルータ、スイッチ、基地局、または任意の他の機器を含み得る。
[0035]ビデオ符号器20およびビデオ復号器30は、新たな高効率ビデオコード化(HEVC:High Efficiency Video Coding)規格、または代替的にMPEG−4、Part10、アドバンストビデオコード化(AVC)とも呼ばれるITU−T H.264規格などのビデオ圧縮規格に従って動作し得る。ただし、本開示の技法は、いかなる特定のコード化規格にも限定されない。他の例にはMPEG−2およびITU−T H.263がある。図1には示されていないが、いくつかの態様では、ビデオ符号器20およびビデオ復号器30は、それぞれオーディオ符号器および復号器と統合され、適切なMUX−DEMUXユニットまたは他のハードウェアおよびソフトウェアを含み、共通のデータストリームまたは別個のデータストリーム中のオーディオとビデオの両方の符号化を処理する。適用可能な場合、MUX−DEMUXユニットはITU H.223マルチプレクサプロトコル、またはユーザデータグラムプロトコル(UDP)などの他のプロトコルに準拠することができる。
[0036]ITU−T H.264/MPEG−4(AVC)規格は、Joint Video Team(JVT)として知られる共同パートナーシップの成果として、ISO/IEC Moving Picture Experts Group(MPEG)とともにITU−T Video Coding Experts Group(VCEG)によって策定された。いくつかの態様では、本開示で説明する技法は、一般にH.264規格に準拠するデバイスに適用することができる。H.264規格は、ITU−T研究グループによる2005年3月付けのITU−T勧告H.264「Advanced Video Coding for generic audiovisual services」に記載されており、本明細書ではH.264規格またはH.264仕様、あるいはH.264/AVC規格または仕様と呼ぶ。
[0037]Joint Video Team(JVT)は、H.264/AVCの拡張に従事し、たとえばHEVCのための新しい規格を開発し続ける。HEVCの規格化の取り組みは、HEVCテストモデル(HM)と呼ばれるビデオコード化デバイスのモデルに基づく。HMは、たとえば、ITU−T H.264/AVCに従う既存のデバイスと比較して、ビデオコード化デバイスのいくつかの追加の能力を前提とする。たとえば、H.264は9つのイントラ予測符号化モードを提供するが、HMは35個ものイントラ予測符号化モードを提供する。
[0038]HMは、ビデオデータのブロックをコード化ユニット(CU)と呼ぶ。ビットストリーム内のシンタックスデータは、ピクセルの数に関して最大のコード化ユニットである最大コード化ユニット(LCU:largest coding unit)を定義し得る。概して、CUは、CUがサイズ差異を有さないことを除いて、H.264規格のマクロブロックと同様の目的を有する。したがって、CUは複数のサブCUに分割され得る。概して、本開示におけるCUへの言及は、ピクチャの最大コード化ユニットまたはLCUのサブCUを指すことがある。LCUは複数のサブCUに分割され、各サブCUはさらに複数のサブCUに分割され得る。ビットストリームのシンタックスデータは、CU深度と呼ばれ、LCUが分割される最大回数を定義し得る。それに応じて、ビットストリームは最小コード化ユニット(SCU:smallest coding unit)をも定義し得る。本開示ではまた、CU、PU、またはTUのいずれかを指すために「ブロック」という用語を使用する。さらに、本開示が、コード化ユニットすなわちCUを伴う例に言及する場合、コード化ユニットに代替されるマクロブロックに関して他の例を挙げる場合があることを理解されたい。
[0039]LCUは4分木データ構造に関連付けられ得る。概して、4分木データ構造はCUごとに1つのノードを含み、ルートノードはLCUに対応する。CUが4つのサブCUに分割された場合、CUに対応するノードは4つのリーフノードを含み、リーフノードの各々はサブCUのうちの1つに対応する。4分木データ構造の各ノードは、対応するCUのシンタックスデータを与え得る。たとえば、4分木の1つのノードは、そのノードに対応するCUがサブCUに分割されるかどうかを示す分割フラグを含む。CUのシンタックス要素は、再帰的に定義され、CUがサブCUに分割されるかどうかに依存し得る。
[0040]分割されない(たとえば、4分木データ構造におけるリーフノードに対応する)CUは、1つまたは複数の予測ユニット(PU)を含み得る。概して、1つのPUは、対応するCUの全部または一部分を表し、そのPUの参照サンプルを取り出すためのデータを含む。たとえば、PUがイントラモード符号化されるとき、PUは、そのPUのためのイントラ予測モードを記述するデータを含む。イントラ予測モードを記述するデータは、たとえば、PUについてのイントラ予測モードに関連付けられた方向(ルーマおよびクロマ成分)と、PUに関連付けられたブロックサイズとを定義する。別の例として、PUがインターモード符号化されるとき、PUは、PUの動きベクトルを定義するデータを含む。動きベクトルを定義するデータは、たとえば、動きベクトルの水平成分、動きベクトルの垂直成分、動きベクトルの分解能(たとえば、1/4ピクセル精度もしくは1/8ピクセル精度)、動きベクトルが指す参照フレーム、および/または動きベクトルについての参照フレームリスト(たとえば、リスト0もしくはリスト1)、および動きベクトル予測子インデックスを記述する。また、(1つまたは複数の)PUを定義するCUについてのデータは、たとえば、1つまたは複数のPUへのCUの区分について記述する。区分モードは、CUがコード化されないか、イントラ予測モード符号化されるか、またはインター予測モード符号化されるかによって異なる。
[0041]1つまたは複数のPUを有するCUは、1つまたは複数の変換ユニット(TU:transform unit)をも含み得る。PUを使用した予測の後に、ビデオ符号器は、PUに対応するCUの部分について残差値を計算し得る。残差値は、エントロピーコード化のためのシリアル化変換係数(serialized transform coefficient)を生成するために、変換係数に変換され、量子化され、走査され得るピクセル差分値に対応する。TUのサイズは、必ずしもPUのサイズに制限されるとは限らない。具体的には、TUは、CUについての対応するPUと同じサイズでも、それよりも小さくてもよい。いくつかの例では、TUの最大サイズは、対応するCUのサイズである。概して、TUは、所与のCUに関連する残差変換係数を含むデータ構造を備え得る。
[0042]ビデオ符号器20およびビデオ復号器30はそれぞれ、1つまたは複数のマイクロプロセッサ、デジタル信号プロセッサ(DSP)、特定用途向け集積回路(ASIC)、フィールドプログラマブルゲートアレイ(FPGA)、ディスクリート論理、ソフトウェア、ハードウェア、ファームウェアなど、様々な好適な符号器回路のいずれか、またはそれらの任意の組合せとして実装され得る。ビデオ符号器20およびビデオ復号器30の各々は1つまたは複数の符号器または復号器中に含まれ得、そのいずれも複合符号器/復号器(コーデック)の一部としてそれぞれのカメラ、コンピュータ、モバイルデバイス、加入者デバイス、ブロードキャストデバイス、セットトップボックス、サーバなどに統合され得る。
[0043]ビデオシーケンスは、一般に一連のビデオフレームを含む。ピクチャグループ(GOP)は、概して、一連の1つまたは複数のビデオフレームを備える。GOPは、GOP中に含まれるいくつかのフレームを記述するシンタックスデータを、GOPのヘッダ、GOPの1つもしくは複数のフレームのヘッダ、または他の場所中に含み得る。各フレームは、それぞれのフレームについての符号化モードを記述するフレームシンタックスデータを含み得る。ビデオ符号器20は、一般に、ビデオデータを符号化するために、個々のビデオフレーム内のビデオブロックに対して動作する。ビデオブロックは、コード化ユニット(CU)またはCUのパーティションユニット(PU:partition unit)に対応し得る。ビデオブロックは、サイズを固定することも変更することもでき、指定のコード化規格に応じてサイズが異なることがある。各ビデオフレームは複数のスライスを含み得る。各スライスは、1つまたは複数のPUを含み得る、複数のCUを含み得る。
[0044]一例として、HEVCテストモデル(HM)は、様々なCUサイズでの予測をサポートする。LCUのサイズは、シンタックス情報によって定義され得る。特定のCUのサイズが2N×2Nであると仮定すると、HMは、2N×2NまたはN×Nのサイズでのイントラ予測をサポートし、2N×2N、2N×N、N×2N、またはN×Nの対称サイズでのインター予測をサポートする。HMはまた、2N×nU、2N×nD、nL×2N、およびnR×2Nのインター予測のための非対称分割をサポートする。非対称分割では、CUの一方向は分割されないが、他の方向が25%と75%とに分割される。25%の分割に対応するCUの一部分は、「n」の後ろに付く「Up」、「Down」、「Left」、または「Right」という指示によって示される。したがって、たとえば「2N×nU」は、上部に2N×0.5N PUと下部に2N×1.5N PUとに水平方向に分割される2N×2N CUを指す。
[0045]本開示では、「N×N」と「N by N」とは、垂直次元および水平次元に関するビデオブロック(たとえば、CU、PU、またはTU)のピクセル次元、たとえば、16×16ピクセルまたは16 by 16ピクセルを指すために互換的に使用され得る。一般に、16×16ブロックは、垂直方向に16ピクセルを有し(y=16)、水平方向に16ピクセルを有する(x=16)。同様に、N×Nブロックは、一般に、垂直方向にNピクセルを有し、水平方向にNピクセルを有し、Nは、非負整数値を表す。ブロック中のピクセルは行と列に配置され得る。さらに、ブロックは、必ずしも、水平方向に垂直方向と同じ数のピクセルを有する必要はない。たとえば、ブロックは、N×Mピクセルを備え得、Mは必ずしもNに等しいとは限らない。
[0046]上述したように、CUは、インター予測コード化またはイントラ予測コード化を使って符号化され得る。イントラ予測では、現在のブロックは、すでに符号化されている同じフレーム中のブロックと比較して予測され得る。通常、フレームのブロックは、左から右および上から下に、またはいくつかの例ではz−スキャン順序でコード化される。それゆえ、現在のブロックは、現在のブロックの上または左のどこにあるブロックと比較しても予測し得る。イントラ予測コード化におけるブロックサイズは、比較的小さいサイズ、たとえば、2×2から、比較的大きいサイズ、たとえば、128×128まで変わり得る。予測の方向またはすでに符号化されているブロックから現在のブロックへの方向は、イントラ予測モードを判断し得る。HMは、外挿方向に対応する33個の異なるイントラ予測方向性モードと、1つのDCモードとを含む最大34モードを可能にする。33個のイントラ予測方向性モードのそれぞれは、現在のブロックのピクセルを予測するのに使われるブロックからのピクセルの外挿の方向を示す5.625°に近い角度分解能で、0と180との間(または、図2Aの例では、水平から時計回りに、45度と−135度との間)の角度に対応する。非方向性モード(モード2で指定される)は、DCに対応し、隣接ピクセルのサンプリングは、現在のブロックのピクセルを予測するのに使われる。いくつかの例では、HMは、平面(planar)モードに対応する第35のモード(モード34)を認め、ここでピクセルの値は、後でより詳しく論じる勾配関数(gradient function)を使って調整し得る。
[0047]イントラ予測コード化中、予測の正確さの質は影響を受け低下し得る。たとえば、PUのサイズが増大すると、予測子ピクセルからより遠くにあるピクセルの予測の正確さは低下する。予測の正確さが低下した結果、より多くの残差データが生じ、その結果、符号化、送信、または記憶する必要があるデータが増える。平滑化フィルタを、ブロックを予測するのに使われる予測子ピクセルに適用して、予測の正確さを向上することができる。ただし、場合によっては、平滑化フィルタを使わなくても、より良好な結果が達成される。上述したように、現在の規格は、適応イントラ平滑化(AIS)技法を使用する。
[0048]本開示の技法は、規則ベース簡易AIS方式を提案し、平滑化フィルタを適用するかどうかに関する規則は、主に、現在のブロックのサイズと、予測モードまたは方向とに基づく。HMでは、ブロックサイズは、小さいサイズ、たとえば2×2から、たとえば128×128もの大きさまで変わる。各ブロックに利用可能なイントラ予測モードは、後でより詳しく説明するように、サイズに基づいて変わり得る。方向が異なるイントラ予測モードに対応する場合、各ブロックサイズに対して、いくつかの方向では、予測が適用されるときに平滑化フィルタが必要とされるが、別の方向では必要とされない。一例では、平滑化フィルタが適用されるサイズとイントラ予測モードの組合せは、ルックアップテーブル(LUT)においてあらかじめ定義することができる。それゆえ、平滑化フィルタを適用するかどうかの判断は汎用でよく、符号器および/または復号器に対する変更にかかわらず同じままであり、フィルタリング判断のシグナリングは必要とされない。さらに、平滑化フィルタを適用するかどうかの判断を行っても、符号器を大幅に複雑化することはない。
[0049]いくつかの例では、平滑化フィルタを適用するかどうかの判断は、より大きいブロックとより小さいブロックとの間でさらに区別することができ、平滑化フィルタを適用するかどうか判断する手順は、ブロックサイズに基づいて変わり得る。たとえば、いくつかのブロックサイズの場合、符号器は、フィルタリング済みピクセルと非フィルタリングピクセルの両方を使って予測を実施し、結果を比較して、平滑化フィルタを使うかどうか判断する。符号器は次いで、フィルタリングモード、すなわち、ブロックを符号化する際に平滑化フィルタが使われるかどうかをシグナリングすることができる。一例では、フィルタリングモードは、LUTに基づいて取得される決定、すなわち、デフォルトのフィルタリング決定とは異なる場合にシグナリングされる。
[0050]一例では、1つまたは複数の平滑化フィルタ(たとえば、フィルタ候補)を定義することができる。ブロックサイズとイントラ予測モードとの各組合せに対して、使うべき適切なフィルタをテーブルが定義され得る。平滑化フィルタが使われない組合せに対して、定義されるフィルタは全域通過フィルタでよい。一次テーブルは、ブロックサイズとイントラ予測モードとの各対応する組合せに対する最も確実な平滑化フィルタを含み得る。いくつかの例では、二次テーブル(またはいくつかの追加テーブル)が、ブロックサイズとイントラ予測モードとの各対応する組合せに対し、2番目に確実な平滑化フィルタ(または、いくつかの追加テーブルの場合ではいくつかの可能平滑化フィルタ)を含むように定義され得る。一例では、別段に示されていない限り、最も確実な平滑化フィルタ情報を使用してよい。イントラ予測コード化に関連付けられた情報(たとえば、ブロックサイズおよびイントラ予測モード)と平滑化フィルタ情報(たとえば、フィルタリングモードおよび確実な1つまたは複数の平滑化フィルタテーブル)が、対応するブロックのヘッダ(または、フッターなどの他のデータ構造)中に符号化され、復号中に適切な平滑化フィルタを適用するために、ビデオ復号器によって復号され得る。
[0051]予測データ(たとえば、CUのためのPU)を生成するためのイントラ予測コード化またはインター予測コード化の後、ビデオ符号器20は、CUのための1つまたは複数の変換ユニット(TU)を生成するために、残差データを計算し得る。CUのPUは、(ピクセル領域とも呼ばれる)空間領域におけるピクセルデータを備えるが、CUのTUは、たとえば、残差ビデオデータへの離散コサイン変換(DCT)、整数変換、ウェーブレット変換、または概念的に同様の変換などの変換が適用された後の変換領域における係数を備え得る。残差データは、非符号化ピクチャ(unencoded picture)のピクセルとCUのPUの予測値との間のピクセル差分に対応し得る。ビデオ符号器20は、CUについての残差データを含む1つまたは複数のTUを形成し得る。ビデオ符号器20は、次いで、TUを変換し得る。
[0052]変換係数を生成するための変換の後、変換係数の量子化が実行され得る。量子化は、概して、係数を表すために使用されるデータ量をできるだけ低減するために変換係数を量子化するプロセスを指す。量子化プロセスは、係数の一部または全部に関連するビット深度を低減することができる。たとえば、量子化中にnビット値がmビット値に丸められる、ここでnはmよりも大きい。
[0053]いくつかの例では、ビデオ符号器20は、エントロピー符号化され得るシリアル化ベクトルを生成するために、量子化変換係数を走査するためにあらかじめ定義された走査順序を利用し得る。他の例では、ビデオ符号器20は、適応型走査を実行し得る。1次元ベクトルを形成するために、量子化変換係数を走査して後、ビデオ符号器20は、たとえば、コンテキスト適応型可変長コード化(CAVLC:context adaptive variable length coding)、コンテキスト適応型2値算術コード化(CABAC:context adaptive binary arithmetic coding)、シンタックスベースコンテキスト適応型2値算術コード化(SBAC:syntax-based context-adaptive binary arithmetic coding)、または別のエントロピーコード化方法に従って、該1次元ベクトルをエントロピー符号化し得る。
[0054]エントロピーコード化用に構成された処理ユニットまたは別の処理ユニットは、量子化係数のゼロランレングスコード化、および/またはコード化ブロックパターン(CBP)値、マクロブロックタイプ、コード化モード、LCUサイズなどのシンタックス情報の生成などの、他の処理機能を実行し得る。
[0055]宛先デバイス14のビデオ復号器30は、本開示のビデオ符号器20の技法のいずれかまたはすべてと同様であり、概ね対称である技法を実施するように構成され得る。たとえば、ビデオ復号器30は、ビデオフレームのエントロピー符号化されたCUを受信する。この受信データは、ビデオ符号器20においてCUを符号化するのにイントラ予測コード化が使用されたかどうかを示すシンタックス要素を含み得る。本開示の技法によると、イントラ予測コード化に関連付けられたシンタックス要素は、たとえば、イントラ予測モードまたは予測の方向、ブロックサイズ、および適用可能なときは平滑化フィルタに関連付けられた他の情報のような情報を含み得る。たとえば、ビデオ復号器30は、イントラ予測コード化を使ってCUが符号化されたと判断し、符号化CUとともに含まれるシンタックス要素を復号して、CUのイントラ予測モードを判断する。ビデオ符号器30は、イントラ予測コード化において使われるブロックのサイズをも判断し、ブロックサイズおよびイントラ予測モード情報を使って、ビデオ復号器30は、ブロックを予測するときに予測子ピクセルに平滑化フィルタを適用するかどうか判断し得る。
[0056]一例では、ビデオ復号器30は、ブロックを符号化するのに使われるブロックサイズとイントラ予測モードとの組合せに基づいて平滑化フィルタを適用するかどうか判断する。そうではないとの指示がない限り、ビデオ復号器30は、ブロックサイズとイントラ予測モードとの組合せに関連付けられた最も確実な平滑化フィルタを使用し得る。ブロックサイズとイントラ予測モードとの組合せに対し使われる平滑化フィルタが、その組合せに対し最も確実な平滑化フィルタとは異なる場合、ブロックに関連付けられたシンタックス要素から、ビデオ復号器30によって指示を復号し、その組合せに対する2番目(またはそれ以降)に確実な平滑化フィルタからの平滑化フィルタが、ビデオ復号器30によって選択され、使用される。
[0057]このようにして、イントラ予測コード化において平滑化フィルタが適用されるかどうかを示すように符号化された情報の量が最小限にされ、場合によっては削除される。たとえば、平滑化フィルタ適用決定が、ブロックサイズとイントラ予測モードとの組合せにとって最も確実である場合、平滑化フィルタに関するシグナリングは符号化されず、ビデオ復号器30は、ブロックサイズおよびイントラ予測モード以外の追加情報を必要とすることなく、判断を行うことができる。
[0058]ビデオ符号器20およびビデオ復号器30はそれぞれ、適用可能なとき、1つまたは複数のマイクロプロセッサ、デジタル信号プロセッサ(DSP)、特定用途向け集積回路(ASIC)、フィールドプログラマブルゲートアレイ(FPGA)、ディスクリート論理回路、ソフトウェア、ハードウェア、ファームウェアなどの様々な好適な符号器または復号器回路のいずれか、あるいはそれらの任意の組合せとして実装され得る。ビデオ符号器20およびビデオ復号器30の各々は1つまたは複数の符号器または復号器中に含まれ、そのいずれも複合ビデオ符号器/復号器(コーデック)の一部として統合され得る。ビデオ符号器20および/またはビデオ復号器30を含む装置は、集積回路、マイクロプロセッサ、および/またはセルラー電話などのワイヤレス通信デバイスを備え得る。
[0059]図2Aは、様々なイントラ予測モードに関連付けられた予測方向の例示的なセットを示すグラフを示す概念図である。上述したように、HMは、33個ものイントラ予測方向性符号化モードを提供する。HM符号器(たとえば、ビデオ符号器20)は、ブロックについてのイントラ予測モードの利用可能なセットがブロックまたはPUのサイズに依存し得るように構成され得る。すなわち、ブロックのサイズによってそのブロックのために利用可能なイントラ予測モードの番号が決定され、そこから、符号器は、ブロックを予測するためにイントラ予測モードを選択し得る。以下の表1に、ブロックのサイズと、そのサイズのブロックのために利用可能なイントラ予測モードとの間の対応の一例を示す。イントラ予測モードに関連付けられた方向を図3に示す。モード2は、図3には示されていないが、DCモードに対応し、DCモードでは、隣接ピクセルのサンプリングが、現在のブロックのピクセルを予測するのに使われる。
Figure 0005587508
[0060]図2Aの例では、(破線で示す)ブロック106は、選択されたイントラ予測モードに応じて隣接ピクセル100A〜100AG(隣接ピクセル100)から予測され得る。矢印102A〜102AG(矢印102)は、様々なイントラ予測モードに関連付けられた方向または角度を表す。図2Aの例は、HMによって与えられるイントラ予測モードを表す。ただし、他の例では、より多いまたはより少ないイントラ予測モードが与えられ得る。ブロック106の例は8×8ピクセルブロックであるが、概して、ブロックは、任意の数のピクセル、たとえば、4×4、8×8、16×16、32×32、64×64、128×128などを有し得る。ブロック106の例は正方形であるが、本開示の技法は、他のブロックサイズ、たとえば、N×Mブロックにも適用され得、ここでNは必ずしもMに等しいとは限らない。
[0061]イントラ予測モードは、たとえば、ブロック106の垂直側に直角な水平軸に対する、予測方向の角度に従って定義される。したがって、矢印102の各々は、対応するイントラ予測モードの予測方向の特定の角度を表し得る。いくつかの例では、イントラ予測方向モードは、対応するイントラ予測モードがコンテキストピクセル外挿のために使用する方向を表す整数ペア(dx,dy)によって定義され得る。すなわち、イントラ予測モードの角度はdy/dxとして計算され得る。言い換えれば、その角度は水平オフセットdxと垂直オフセットdyとによって表され得る。ブロック106中のロケーション(x,y)におけるピクセルの値は、dy/dxの角度でロケーション(x,y)も通るラインが通る、隣接ピクセル100のうちの1つまたは複数から決定され得る。
[0062]図2Bは、様々なイントラ予測モードに関連付けられた予測方向の別の例示的なセットを示すグラフを示す概念図である。図2Bの例では、図2Aに示すものと同様の、33個のイントラ予測方向性符号化モードを示す。この例では、33個の方向性モードに加え、2つの追加モード、すなわちDCモードに対応するモード2、および平面(planar)モードに対応するモード34がある。
[0063]図2Bの例において、符号器および/または復号器は、ブロックについてのイントラ予測モードの利用可能なセットが、ブロック、たとえばPU、CU、またはTUのサイズに依存するように構成され得る。すなわち、ブロックのサイズによってそのブロックのために利用可能なイントラ予測モードの番号が決定され、そこから、符号器は、ブロックを予測するためにイントラ予測モードを選択し得る。以下の表2に、ブロックのサイズと、そのサイズのブロックのために利用可能なイントラ予測モードとの間の対応の別の例を示す。
Figure 0005587508
[0064]図3は、様々なイントラ予測モードに関連付けられた予測方向の例示的なセットを示す概念図である。HMによって提供される33個のイントラ予測方向性モードの各々は、指定された角度をもつ方向に対応する。たとえば、モード1は、水平外挿方向または水平線から0°の角度に対応し、モード1を使って符号化されたブロックは、その左に向けられたピクセルから予測される。別の例として、モード0は、垂直外挿方向または水平線から90°の角度に対応し、モード0を使って符号化されたブロックは、その真上のピクセルから予測される。別の例として、モード3、6、および9は、45°の角度分解能での対角外挿方向に対応する。モード0、1、および3〜33は、5.625°に近い角度分解能をもつ、(モード6と9との間の)180°にわたる予測方向に対応する。モード2は、HMの例では、DCモードに対応し、8個の隣接ピクセルのサンプリングは、現在のブロックのピクセルを予測するのに使われる。モード34は、平面モードに対応し、ここでは、予測目的のブロックに適合された線形平面関数が含まれ得る。平面モードは、滑らかに変化する輝度のエリアにおいて、うまく働き得る。平面モードは、より大きいブロックの予測には効果的であるが、より小さいブロックの予測に使われるときは、比較的効率的でない場合がある。図3のサークル(円)は、各サークルに関連付けられたイントラ予測方向性モードの角度分解能を表す。たとえば、サークル0の場合、サークルの内側のモード(モード0と1)の間の分解能は90度であり、サークル1の内側のモード(モード3、6、および9)の間の分解能は45度であり、サークル2の内側のモード(モード4、5、7、および8)の間の分解能は22.5度であり、以下同様である。
[0065]図4は、ビデオデータのイントラ予測コード化において使われる予測サンプルの周囲のピクセルに平滑化フィルタを適用するための技法を実装することができるビデオ符号器20の例を示すブロック図である。ビデオ符号器20は、LCU、CU、及びPUを含むビデオフレーム内のビデオブロックのイントラおよびインター予測を実施し、TUとして符号化され得る残差値を計算することができる。イントラコード化は、所与のビデオフレーム内のビデオの空間的冗長性を低減または除去するために空間的予測に依拠する。インターコード化は、ビデオシーケンスの隣接フレーム内のビデオの時間的冗長性を低減または除去するために時間的予測に依拠する。イントラ(I)モードは、いくつかの空間ベースの圧縮モードのいずれかを指すことがある。単方向予測(Pモード)、双方向予測(Bモード)、または一般化P/B予測(GPBモード)などのインターモードは、いくつかの時間ベースの圧縮モードのいずれかを指すことがある。動き推定ユニット42および動き補償ユニット44はインター予測コード化を実施することができ、イントラ予測ユニット46はイントラ予測コード化を実施することができる。
[0066]図4に示すように、ビデオ符号器20は、符号化すべきビデオフレームまたはスライス内の現在のビデオブロックを受信する。図4の例では、ビデオ符号器20は、モード選択ユニット40と、予測ユニット41と、参照フレームストア64と、加算器50と、変換ユニット52と、量子化ユニット54と、エントロピーコード化ユニット56とを含む。予測ユニット41は、動き推定ユニット42と、動き補償ユニット44と、イントラ予測ユニット46とを含む。ビデオブロック再構成のために、ビデオ符号器20はまた、逆量子化ユニット58と、逆変換ユニット60と、加算器62とを含む。再構成されたビデオからブロッキネスアーティファクトを除去するためにブロック境界をフィルタリングするデブロッキングフィルタ(図4に図示せず)も含まれ得る。所望される場合、デブロッキングフィルタは、一般に、加算器62の出力をフィルタ処理する。
[0067]符号化プロセス中に、ビデオ符号器20はコード化されるべきビデオフレームまたはスライスを受信する。フレームまたはスライスは、複数のビデオブロックまたはCUに分割され得る。動き推定ユニット42および動き補償ユニット44は、時間圧縮を行うために、1つまたは複数の参照フレーム中の1つまたは複数のブロックに対して、受信されたビデオブロックのインター予測コード化を実行する。イントラ予測ユニット46は、空間圧縮を行うために、コード化されるべきブロックと同じフレームまたはスライス中の1つまたは複数の隣接ブロックに対して、受信されたビデオブロックのイントラ予測コード化を実行し得る。
[0068]モード選択ユニット40は、コード化モード、すなわちイントラまたはインターの1つを、たとえば、誤差結果に基づいて選択し、コード化モードの選択を予測ユニット41に与える。予測ユニット41は次いで、イントラまたはインターコード化ブロックを生成じ、コード化ブロックを、残差ブロックデータを生成するために加算器50に、および符号化ブロックを参照フレームとして使用するように再構成するために加算器62に与える。モード選択ユニット40が、あるブロックに対しイントラ予測符号化を選択すると、イントラ予測ユニット46は、そのブロックに対しイントラ予測モードを選択し得る。たとえば、選択されたイントラ予測モードは、HMによって提供される35個のモードの1つである。所与のブロックに対しイントラ予測モードがそこから選択されるイントラ予測モードの番号は、上の表1の例に示すように、ブロックのサイズに依存し得る。
[0069]一例では、モード選択ユニット40がインター予測コード化を選択すると、動き推定ユニット42および動き補償ユニット44は、インター予測コード化に関連付けられた処理を実施して、インターコード化ブロックを生成する。動き推定ユニット42と動き補償ユニット44とは、高度に統合され得るが、概念的な目的のために別々に示してある。動き推定ユニット42によって実行される動き推定は、ビデオブロックの動きを推定する動きベクトルを生成するプロセスである。動きベクトルは、たとえば、現在のフレーム(または、他のコード化ユニット)内のコード化されている現在のブロックに対する予測参照フレーム(または、他のコード化ユニット)内の予測ブロックまたはPUの変位を示し得る。予測ブロックは、絶対値差分和(SAD:sum of absolute difference)、2乗差分和(SSD:sum of square difference)、または他の差分メトリックによって判断され得るピクセル差分に関して、コード化されるべきビデオブロックまたはPUにぴったり一致することがわかるブロックである。
[0070]動きベクトルはまた、マクロブロックの区分の変位を示し得る。動き補償は、動き推定によって決定された動きベクトルに基づいて予測ブロックをフェッチまたは生成することを伴う。いくつかの例では、ビデオ符号器20は、参照フレームストア64に記憶された参照フレームのサブ整数ピクセル位置の値を計算し得る。たとえば、ビデオ符号器20は、参照フレームの1/4ピクセル位置、1/8ピクセル位置、または他の分数ピクセル位置の値を計算する。したがって、動き推定ユニット42は、フルピクセル位置と分数ピクセル位置とに対する動き探索を実行し、分数ピクセル精度で動きベクトルを出力し得る。
[0071]動き推定ユニット42は、PUを参照フレームストア64中の参照フレームのブロックと比較することによって、インターコード化フレームのビデオブロックまたはPUの動きベクトルを計算する。動き補償ユニット44はまた、参照フレーム、たとえば、IフレームまたはPフレームのサブ整数ピクセルを補間し得る。HMは、一例として、2つのリスト、すなわち、符号化されている現在のフレームよりも早い表示順序をもつ参照フレームを含むリスト0と、符号化されている現在のフレームよりも遅い表示順序をもつ参照フレームを含むリスト1とを記述する。したがって、参照フレームストア64に記憶されたデータは、これらのリストに従って編成され得る。いくつかの場合には、動き推定ユニット42は、動きベクトルについての動きベクトル差分(MVD)値をさらに計算し、動きベクトル自体ではなくMVD値を、エントロピーコード化ユニット56に渡すことができる。
[0072]一例では、モード選択ユニット40がイントラ予測コード化を選択すると、イントラ予測ユニット46は、イントラ予測コード化に関連付けられた処理を実施して、イントラコード化されたブロックを生成する。上述したように、ブロックのサイズに基づいて、ブロックに利用可能なイントラ予測モードの番号が判断され得る。ブロックサイズと、そのサイズのブロックに利用可能なイントラ予測モードの番号との間の対応の例を、上の表1および表2に示す。イントラ予測ユニット46は、隣接する、前にコード化されたブロック、たとえば、左から右、上から下への符号化順序またはブロックを仮定すると、現在のブロックの上ブロック、右上ブロック、左上ブロック、または左ブロックに対して、現在のビデオブロックをイントラ予測符号化する。イントラ予測ユニット46は、現在のブロック用について選択されたイントラ予測モードに基づいて、隣接ブロックを使用し得る。
[0073]イントラ予測ユニット46は、利用可能イントラ予測モードの1つを選択することによって、ブロックに対し適切なイントラ予測モードを決定し得る。イントラ予測ユニット46は、たとえば、ブロックサイズに関連付けられた様々なイントラ予測モードについて誤差値を計算し、最も低い誤差値を生じるモードを選択することによって、イントラ予測モードを選択し得る。方向性予測モードは、空間的に隣接するピクセルの値を合成し、その合成された値を予測ユニット(PU)中の1つまたは複数のピクセル位置に適用するための機能を含み得る。PU中のすべてのピクセル位置の値が計算されると、イントラ予測ユニット46は、PUと符号化されるべき現在のブロックとの間のピクセル差分に基づいて予測モードの誤差値を計算し得る。イントラ予測ユニット46は、許容できる誤差値を生じるイントラ予測モードが発見されるまで、現在のブロックのブロックサイズに関連付けられたイントラ予測モードをテストし続け得る。次いで、最も低い誤差値を生じるイントラ予測モードが、現在のブロックについてのPUを生成するために使われ得る。イントラ予測ユニット46は、選択されたイントラ予測モードをシグナリングし、それにより、そのモードは、コード化ブロックに関連付けられたシンタックス要素とともに符号化される。
[0074]本開示によると、ビデオ符号器20は、イントラ予測コード化を使って符号化される現在のブロックの予測サンプルの周りのピクセルに平滑化フィルタを適用するかどうか判断することができる。判断は、ブロックサイズと、現在のブロックをコード化する際に使われるイントラ予測モードとに基づき得る。本開示の技法による一例では、垂直、水平、およびDCモードにそれぞれ対応するモード0、1、または2が使われるとき、これらのモードのそれぞれは、平滑化を適用することなく比較的正確な予測結果を与えるので、平滑化フィルタは適用されない。それゆえ、予測方向が完全に水平、垂直であり、またはイントラ予測モードがDCモードであるとき、平滑化フィルタは適用されない。他のモード(すなわち、対角モード)について平滑化フィルタを適用するかどうかの判断は、予測ユニットサイズおよびイントラ予測モードに依存する。下の表3は、平滑化フィルタが適用される、ブロックサイズとイントラ予測モードとの組合せの例示的関係を示す。フィルタリングが適用され得るブロックサイズとイントラ予測モードとの組合せは、オフライントレーニングおよび統計的結果に基づき得る。表3は、定義され得る関係のうち唯一のタイプを表すのではなく、本開示に一致する一例を挙げるにすぎない。
Figure 0005587508
[0075]表3が示すように、平滑化フィルタを適用するかどうかの判断は汎用であり、ブロックを符号化するのに使われるブロックサイズおよびイントラ予測モードに基づくのと同じである。一例では、上の表3に示したサイズとイントラ予測モードの組合せは、平滑化フィルタが適用されるために、ルックアップテーブル(LUT)においてあらかじめ定義され得る。LUTは、符号器もしくは復号器の両方において利用可能であるか、または符号器がLUTを復号器に送ってもよい。それゆえ、平滑化フィルタを適用するかどうかの判断は、汎用でよく、符号器および/または復号器に対する変更にかかわらず同じままであり、フィルタリング判断のシグナリングは必要とされない。さらに、平滑化フィルタを適用するかどうかの判断を行っても、符号器を大幅に複雑化することはない。
[0076]一例では、ブロックのイントラ予測符号化中に、符号器は、ブロックのサイズと、使われるイントラ予測モードとの組合せに基づいて、およびLUTにおいて定義された組合せに従って、予測サンプルに平滑化フィルタを適用するかどうか判断する。これらの組合せは、最も確実なフィルタテーブル中で指示される最も確実なフィルタリングオプションに関連付けられ得る。たとえば、最も確実なフィルタテーブルは、ブロックサイズとイントラ予測モードの各組合せに対して、どのフィルタリングオプションを使用するかを示すように作成される。一例では、ブロックサイズとイントラ予測モードの各組合せ向けのフィルタの候補リストから、平滑化フィルタが選択される。どのフィルタリングオプションも、全域通過フィルタである平滑化フィルタに一般化されない。いくつかの例では、1つまたは複数の平滑化フィルタを使うことができ、ここではたとえば、1つの平滑化フィルタが、ブロックサイズとイントラ予測モードのいくつかの組合せに対してよりうまく働くことができ、第2の平滑化フィルタが、ブロックサイズとイントラ予測モードの他の組合せに対してよりうまく働くことができる。平滑化フィルタの候補セット中のフィルタの数は、システムによって変わり得る。一例では、ブロックサイズとイントラ予測モードの1つの組合せに対するフィルタオプションは、異なるトレーニングビデオデータをもつオフライントレーニングに基づき得る。簡単のために、フィルタの数は、フィルタ0、フィルタ1、およびフィルタ2の3つであり、フィルタ0は全域通過フィルタリングを示す(すなわち、フィルタリングなし)。候補フィルタを使うと、最も確実なフィルタテーブルは、擬似コードで表される以下のテーブルに従って生成され得る。
Figure 0005587508
[0077]上の例では、各ブロックサイズおよびイントラ予測モードに対して、最も確実な平滑化フィルタが定義され得る。ある特定の組合せに対する平滑化フィルタのテーブルインデックスは、サイズおよびモードに対応する[S,M]と定義され得る。ブロックサイズは、たとえば、ブロックサイズ2×2、4×4、8×8、16×16、32×32、64×64、および128×128に対応する、1〜7の範囲である。イントラ予測モードは、たとえば、1〜40の範囲である。ただし、本開示の例では、35個のモードのみが定義され、それゆえ、モードの残りには、フィルタ0または全域通過フィルタを示す0が加えられる。上のテーブルの例は、テーブル中の各エントリについて、例示的フィルタセット(0,1,2)からの平滑化フィルタを示す。平滑化フィルタ1または2が適用されるイントラ予測モードは、上の表3で定義された組合せに対応する。
[0078]一例では、符号化中に、ビデオ符号器20は、固定モード依存イントラ予測コード化を実装することができ、ここで、ビデオ符号器20は、上のテーブルで定義されるように、ブロックサイズとイントラ予測モードとの各組合せに対し最も確実な平滑化フィルタを選択する。この例では、ビデオ符号器20は、ブロックに対しどの平滑化フィルタが使われるかを符号化する必要なく、固定モード依存イントラ予測コード化を指示することができる。復号中に、固定モード依存イントラ予測コード化が指示された場合、復号器(たとえば、ビデオ復号器30)は、テーブルに対するインデックスとして使われるブロックサイズおよびイントラ予測モード情報に基づいて、上のテーブルにある情報を使って、どの平滑化フィルタを適用するか判断することができる。たとえば、イントラ予測モード6を使って符号化された8×8ブロックは、平滑化フィルタ2であるフィルタ1([3,6])に対応し得る。フィルタ1は、最も確実なフィルタテーブルに対応するテーブルから情報が取得されることを示し得る。
[0079]いくつかの場合には、固定モード依存イントラ予測コード化を用いると、より大きいブロックサイズ、たとえば、64×64および128×128の一部に対して最良の結果が生じない場合がある。一例では、ブロックのイントラ予測符号化中に、ビデオ符号器20は、適応モード依存イントラ予測コード化を使って、予測サンプルに平滑化フィルタを適用するかどうか判断する。閾値サイズ、たとえば64×64よりも小さいブロックに対して、ビデオ符号器20は、上に示した最も確実なフィルタテーブルを使用する。閾値以上のブロック、たとえば、64×64およびそれよりも大きいブロックに対しては、ビデオ符号器20は、フィルタなしを含む異なる複数の平滑化フィルタを予測サンプルに適用する結果を評価し、どれがより良好な結果を生じるか判断する。結果は、品質メトリックまたはレート歪みメトリックに基づいて判断され得る。レート部分のメトリックは、現在のブロックのコード化レートを示し、歪み部分のメトリックは、現在のブロックにおける歪みの量を示す。レート歪みメトリックは、レート、歪み、または両方の組合せに基づき得る。
[0080]一例では、異なる複数の平滑化フィルタの適用の評価は、現在のブロックへのフィルタの各々の適用に関連付けられたコード化レートに基づく。平滑化フィルタが使われるとき、コード化レートは、現在のブロックに対応する残差データの量に比例する。残差データの量が多いほど、現在のブロックに対するコード化レートは高くなる。より少量の残差データを生じ、従って、より良好なコード化レートを生じる平滑化フィルタは、より良好な結果を生じるフィルタと見なされ得る。
[0081]別の例では、異なる複数の平滑化フィルタの適用の評価は、現在のブロックへのフィルタの各々の適用に関連付けられた歪みの量に基づく。一例では、歪みの量は、予測ブロックとオリジナルブロックとの間の平均2乗誤差値に基づいて判断される。予測ブロックは、選択された平滑化フィルタを適用することによって得られた予測サンプルを使った結果であり得る。より小さい平均2乗誤差値を生じ、従って、より少ない歪みを生じる平滑化フィルタは、より良好な結果を生じるフィルタと見なされ得る。
[0082]一例では、ビデオ符号器20は、上に示した最も確実なフィルタテーブルによって指定されたフィルタを適用した結果を、下に示す擬似コードで表された2番目に確実なフィルタテーブルによって指定されたフィルタと比較する。
Figure 0005587508
[0083]いくつかの例では、より多くのテーブルを使って、他のフィルタを指定することができる。最も確実なフィルタテーブルと2番目に確実なフィルタテーブルとを使う簡単な例では、第1のテーブルにおける非ゼロフィルタ、たとえばフィルタ1および2に対応するエントリは、第2のテーブル中のフィルタ0で置き換えることができ、逆もまた同様である。このように、最も確実なフィルタと2番目に確実なフィルタとの間の比較は、フィルタリングと非フィルタリングとの間の比較である。より良好な結果を生じるフィルタリングオプションが、最も確実なフィルタテーブル中で指定されたものである場合、そうではないとの指定がなければ最も確実なフィルタが使われると復号器は仮定するので、ビデオ符号器20は何も指示する必要がない。より良好な結果を生じるフィルタリングオプションが、2番目に確実なフィルタテーブル中で指定されたものである場合、ビデオ符号器20は、復号中に最も確実なフィルタ以外のフィルタが適用されるべきであることを示すために、フィルタリングモードをシグナリングする。フィルタテーブルは、ビデオ符号器20に関連付けられたメモリユニット(図示せず)に記憶され、コード化中にイントラ予測ユニット46によってアクセスされ得る。
[0084]フィルタリングモードのシグナリングは、いくつかのやり方で行うことができる。一例では、ビデオ符号器20は、フィルタリングモードフラグを使って、最も確実なフィルタテーブル中で指定されたもの以外のフィルタリングが、ある特定のブロックに対して使われるかどうかをシグナリングする。2つよりも多いフィルタテーブルが使用される場合、たとえば、3番目(またはそれ以降)に確実なフィルタテーブルがある場合、ビデオ符号器20は、特定のブロックに対して、2番目もしくは3番目(またはそれ以降)に確実なフィルタテーブルのどちらが使われるかを指示する。さらに別の例では、シグナリングは、現在のブロックのブロックサイズ、予測モード、および隣接ブロックのフィルタリングモードなどのコンテキスト情報の組合せに基づく。コンテキスト情報は、現在のブロックに対してフィルタリングが使われたかどうかについての信号をエントロピーコード化するVLC表またはCABAC表を作成するために使用され得る。このようにして、復号器は、コンテキスト情報に基づいて、ブロックに対しフィルタリングが使われるべきか、それとも使われるべきでないか判断し、VLC表またはCABAC情報を使って、フィルタリングモードを判断できる。
[0085]他の例では、他の技法を使用して、平滑化フィルタを適用するかどうか判断することができる。本開示の平滑化フィルタ技法は、イントラ予測モードとブロックサイズとの組合せの関数としてビットレート歪みメトリックの統計に基づくイントラ平滑化フィルタリングモード決定(フィルタリングするかどうか)を提供する。
[0086]再度図2Bを参照すると、この図は、イントラ予測モードとPUサイズとの組合せを示し、これらの組合せは、フィルタリングおよび非フィルタリングイントラ平滑化モードの統計の間の比較に基づく、イントラ平滑化フィルタリングの候補である。たとえば、これらの統計は、垂直(モード0)および水平(モード1)予測方向が、PUサイズ32×32のためのイントラ平滑化フィルタリングの候補であり、主たる対角イントラ予測方向(モード3、6、9)が、PUサイズ32×32、16×16、8×8、および4×4のためのイントラ平滑化フィルタリングの候補であることを示す。これらの統計は、水平または垂直イントラ予測方向と、主たる対角方向との間のイントラ予測方向は、漸進的に小さくなっていくPUサイズでのイントラ平滑化フィルタリングの候補であることも示し得る。DCモードの場合、統計は、モード2、すなわちDCモードは、イントラ平滑化フィルタリングの候補ではないが、平面モード(モード34)は、いくつかのPUサイズ、たとえば8×8、16×16、および32×32でのイントラ平滑化フィルタリングの候補であることを示し得る。
[0087]統計は、どのイントラ予測モードおよびどのPUサイズがイントラ平滑化フィルタリングの候補であるかを示し得るが、コード化効率実験は、図2Bに示すイントラ平滑化フィルタリング候補割当てが、レート歪み検知において最適でないことを実証し得る。従って、図2Bのイントラ平滑化候補は、より高いコード化効率をもつ「サブセットパターン」を導出するための「テンプレートパターン」であり得る。一例では、「サブセットパターン」は、イントラ予測モードごとおよびPUサイズごとに「テンプレートパターン」から、イントラ平滑化フィルタリングのための候補を選択することによって定義され、または代替として、任意のPUサイズに対するどのイントラ平滑化フィルタリングも、特定のイントラ予測モードには対応しない。下の表4〜表7は、サブセットパターンのいくつかの例を挙げる。表4〜表7は概して、フィルタリング決定テーブルと呼ばれ得る。
[0088]表4〜表7の各々において、「1」は、イントラ平滑化フィルタリングが、対応するイントラ予測モードおよびブロックサイズに適用されることを示す。それゆえ、特定の列および行位置の「1」は、それらの列および行の位置にマッッピングされるイントラ予測モードおよびブロックサイズの場合にイントラ平滑化が適用されることをそれぞれ示す。一例では、表4は「テンプレートパターン」に対応し、表5〜表7の各々は、異なる「サブセットパターン」に対応する。別の例では、表7は「テンプレートパターン」に対応し、表4〜表6の各々は、異なる「サブセットパターン」に対応する。「テンプレートパターン」は図2Bに対応し、表4によって示され、これは、たとえば、一般化のための64×64PUサイズも示す。表5〜表7は、「サブセットパターン」を表し得る。本開示の一例では、表7は、コード化効率実験に基づいて、一般的ビデオシーケンスに適した「サブセットパターン」を表し得る。
Figure 0005587508
Figure 0005587508
Figure 0005587508
Figure 0005587508
[0089]予測ユニット41が、現在のビデオブロック(インターまたはイントラコード化された)に対する予測ブロックすなわちPUを生成した後、ビデオ符号器20は、現在のビデオブロックから予測ブロックを減算することによって、残差ビデオブロックを形成する。加算器50は、この減算演算を実行する1つまたは複数の構成要素を表す。変換ユニット52は、残差ブロックから1つまたは複数の変換ユニット(TU)を形成し得る。変換ユニット52は、離散コサイン変換(DCT:discrete cosine transform)または概念的に同様の変換などの変換をTUに適用し、残差変換係数を備えるビデオブロックを生成する。変換は、残差ブロックをピクセル領域から周波数領域などの変換領域に変換し得る。
[0090]変換ユニット52は、概念的にDCTと同様の、HMによって定義される変換などの他の変換を実行し得る。ウェーブレット変換、整数変換、サブバンド変換または他のタイプの変換をも使用することができる。いずれの場合も、変換ユニット52は、変換を残差ブロックに適用し、残差変換係数のブロックを生成する。変換は、残差情報をピクセル値領域から周波数領域などの変換領域に変換し得る。
[0091]変換ユニット52は、得られた変換係数を量子化ユニット54に送り得る。量子化ユニット54は、ビットレートをさらに低減するために変換係数を量子化する。量子化プロセスは、係数の一部または全部に関連するビット深度を低減することができる。量子化の程度は、量子化パラメータを調整することによって変更され得る。いくつかの例では、量子化ユニット54は、次いで、量子化変換係数を含む行列の走査を実行し得る。代替的に、エントロピー符号化ユニット56が走査を実行し得る。
[0092]量子化の後、エントロピーコード化ユニット56が量子化変換係数をエントロピーコード化する。たとえば、エントロピーコード化ユニット56は、コンテキスト適応型可変長コード化(CAVLC)、コンテキスト適応型2値算術コード化(CABAC)、または別のエントロピーコード化技法を実行し得る。エントロピーコード化ユニット56によるエントロピーコード化の後、符号化ビデオは、別のデバイス(たとえば、ビデオ復号器30)に送信されるか、あるいは後で送信または検索するためにアーカイブされ得る。
[0093]場合によっては、エントロピーコード化ユニット56またはビデオ符号器20の別のユニットは、エントロピーコード化に加えて他のコード化機能を実行するように構成され得る。たとえば、エントロピーコード化ユニット56はマクロブロックおよびパーティションのCBP値を判断するように構成され得る。また、場合によっては、エントロピーコード化ユニット56は、マクロブロックまたはそれのパーティション中の係数のランレングスコード化を実行し得る。特に、エントロピーコード化ユニット56は、マクロブロックまたはパーティション中の変換係数を走査するためにジグザグ走査または他の走査パターンを適用し、さらなる圧縮のためにゼロのランを符号化し得る。エントロピーコード化ユニット56はまた、符号化ビデオビットストリーム中での送信のために適切なシンタックス要素を有するヘッダ情報を構築し得る。シンタックス要素をエントロピー符号化するために、エントロピー符号化ユニット56は、CABACを実施し、コンテキストモデルに基づいてシンタックス要素を1つまたは複数のバイナリビットに2値化し得る。エントロピー符号化ユニットは、CAVLCも実施し、コンテキストに基づく確率に従って、シンタックス要素をコードワードとして符号化し得る。
[0094]本開示の技法によると、エントロピーコード化ユニット56は、イントラ予測コード化中に最も確実なフィルタ以外の平滑化フィルタが予測サンプルに適用されるという指示を符号化するように構成され得る。ブロックに対するフィルタリング決定が、最も確実なフィルタテーブル中で指定されたものと同じであるとき、ビデオ符号器20は、復号器に指示を送らない。従って、どの追加情報も符号化される必要はない。指示が必要とされるとき、たとえば、ブロックに対するフィルタリング決定が、2番目(またはそれ以降)に確実なフィルタテーブル中で指定されるとき、ビデオ符号器20は、フィルタリングに関する指示を符号化する。さらに、ビデオ符号器20は、ブロックを符号化する際に使われるイントラ予測モードを符号化し得る。エントロピーコード化ユニット56は、CABACを使って、指示(たとえば、適用可能なときは、イントラ予測モードおよびフィルタリング決定)を符号化し得る。さらに、エントロピーコード化ユニット56は、2番目(またはそれ以降)に確実なフィルタが予測サンプルに適用されるとき、CABACを実施するためのコンテキスト情報を使い、ブロックに対するイントラ予測モードと、フィルタリング情報とを示す指示を符号化し得る。
[0095]逆量子化ユニット58および逆変換ユニット60は、それぞれ逆量子化および逆変換を適用して、参照フレームの参照ブロックとして後で使用するために、ピクセル領域において残差ブロックを再構成する。動き補償ユニット44は、参照フレームストア64のフレームのうちの1つの予測ブロックに残差ブロックを加算することによって、参照ブロックを計算し得る。動き補償ユニット44はまた、再構成された残差ブロックに1つまたは複数の補間フィルタを適用して、動き推定において使用するサブ整数ピクセル値を計算し得る。加算器62は、再構成された残差ブロックを、動き補償ユニット44によって生成された動き補償予測ブロックに加算して、参照フレームストア64に記憶するための再構成されたビデオブロックを生成する。再構成されたビデオブロックは、後続のビデオフレーム中のブロックをインター予測するために動き推定ユニット42および動き補償ユニット44によって参照ブロックとして使用され得る。
[0096]図5は、符号化されたビデオシーケンスを復号するビデオ復号器30の一例を示すブロック図である。図5の例では、ビデオ復号器30は、エントロピー復号ユニット70と、予測ユニット71と、逆量子化ユニット76と、逆変換ユニット78と、参照フレームストア82と、加算器80とを含む。予測ユニット71は、動き補償ユニット72と、イントラ予測ユニット74とを含む。ビデオ復号器30は、いくつかの例では、ビデオ符号器20(図4)に関して説明した符号化パスとは概して逆の復号パスを実行し得る。予測ユニット71は、エントロピー復号ユニット70から受信された情報に基づいて予測データを生成し得る。インター予測コード化が指示されると、動き補償ユニット72は、エントロピー復号ユニット70から受信した動きベクトルに基づいて予測データを生成し得る。イントラ予測コード化が指示されると、イントラ予測ユニット74は、指示されたイントラ予測モードと、現在のフレームの前に復号されたブロックからのデータとに基づいて現在のフレームの現在のブロックについての予測データを生成し得る。
[0097]ビデオ復号器30は、符号化されたビデオビットストリームを、たとえば、ネットワーク、ブロードキャストを介して、または物理媒体から受信し得る。符号化されたビットストリームは、エントロピーコード化されたビデオデータを含み得る。ビデオ復号器30のエントロピー復号ユニット70は、量子化係数、動きベクトル、および予測データを生成するためにビットストリームをエントロピー復号する。エントロピー復号ユニット70は、予測ユニット71に動きベクトルと予測データとを転送する。
[0098]本開示の技法によると、エントロピーコード化されたビデオデータは、現在のブロックをコード化する際に使われるイントラ予測モードのエントロピーコード化された指示を含み得る。エントロピーコード化されたビデオデータは、平滑化フィルタ決定を示すフィルタリングのエントロピーコード化された指示も含み得る。一例では、フィルタリング指示は、現在のブロックのイントラ予測コード化中に、平滑化フィルタを選択するのに最も確実なフィルタテーブルが使われなかったことを示すために使うことができる。エントロピーコード化されたビデオデータがフィルタリング指示を含まないとき、現在のブロックのイントラ予測コード化中に、平滑化フィルタを選択するのに最も確実なフィルタテーブルが使われたことを含意する指示はない。エントロピーコード化されたビデオデータは、エントロピー復号ユニット70が、イントラ予測コード化されたブロックについてのフィルタリング指示をエントロピー復号するときにコンテキスト情報としてイントラ予測モードとともに使い得るブロックサイズ情報も含み得る。このようにして、エントロピー復号ユニット70は、フィルタリングの指示(たとえば、平滑化フィルタが適用されるかどうか)を復号し、指示をイントラ予測ユニット74に送ることができる。
[0099]動き補償ユニット72は、ビットストリーム中で受信した動きベクトルを使用して、参照フレームストア82中の参照フレーム中の予測ブロックを識別し得る。イントラ予測ユニット74は、ビットストリーム中で受信されたイントラ予測モードを使用して、空間的に隣接するブロックから予測ブロックを形成し得る。逆量子化ユニット76は、ビットストリームで供給され、エントロピー復号ユニット70によって復号された量子化ブロック係数を逆量子化(inverse quantize)、すなわち、逆量子化(de-quantize)する。逆量子化プロセスは、たとえば、H.264復号規格によって定義された従来のプロセスを含み得る。逆量子化プロセスは、量子化の程度を判断し、同様に、適用すべき逆量子化の程度を判断するために、各ビデオブロックまたはCUについてビデオ符号器20によって計算された量子化パラメータQPYの使用も含み得る。逆変換ユニット78は、逆変換、たとえば、逆DCT、逆整数変換、または概念的に同様の逆変換プロセスを変換係数に適用して、ピクセル領域における残差ブロックを生成する。
[0100]動き補償ユニット72はまた、補間フィルタに基づいて補間を実行し得る。動き補償ユニット72は、ビデオブロックの符号化中にビデオ符号器20によって使用された補間フィルタを使用して、参照ブロックのサブ整数ピクセルの補間値を計算し得る。動き補償ユニット72は、受信したシンタックス要素からビデオ符号器20によって使用された補間フィルタを判断し、その補間フィルタを使用して予測ブロックを生成し得る。
[0101]動き補償ユニット72は、シンタックス情報のいくつかを使用して、符号化ビデオシーケンスの(1つもしくは複数の)フレームおよび/または(1つもしくは複数の)スライスを符号化するために使用されるLCUおよびCUのサイズと、符号化ビデオシーケンスのフレームの各マクロブロックがどのように区分されるかを記述するパーティション情報と、各パーティションがどのように符号化されるかを示すモードと、各インター符号化CUのための1つまたは複数の参照フレーム(および参照フレームリスト)と、符号化ビデオシーケンスを復号するための他の情報と、を判断する。
[0102]イントラ予測ユニット74は、予測ブロックを実施するとき、予測サンプルに平滑化フィルタを適用するかどうかも判断し得る。イントラ予測ユニット74は、平滑化フィルタを適用するかどうかについての判断を、ブロックサイズおよび対応するイントラ予測モードに基づいて行う。フィルタリング指示がシグナリングされない場合、イントラ予測ユニット74は、ブロックサイズとイントラ予測モードとの組合せに対して、最も確実なフィルタテーブル(上に示した)中で何が指定されるかに基づいてフィルタリングを判断し得る。フィルタリング指示がシグナリングされる場合、イントラ予測ユニット74は、フィルタリング決定が最も確実なフィルタテーブルに基づかないと判断し、ブロックサイズとイントラ予測モードとの組合せに対して、2番目に確実なフィルタテーブル(上に示した)中で何が指定されるかに基づいてフィルタリングを判断し得る。一例では、2つ以上の追加フィルタテーブル、たとえば、2番目、3番目、またはそれ以降の確実なフィルタテーブルが提供され得る。この例では、フィルタリング指示は、どの平滑化フィルタを適用するか判断するためにどのテーブルを使用すべきかをも示し得る。フィルタテーブルは、ビデオ復号器30内のメモリユニット(図示せず)に記憶され得る。イントラ予測ユニット74は、復号中に、メモリにあるフィルタテーブルにアクセスし得る。
[0103]加算器80は、残差ブロックと、動き補償ユニット72またはイントラ予測ユニット74によって生成される対応する予測ブロックとを加算して、復号ブロックを形成する。必要があれば、ブロッキネスアーティファクトを除去するために、デブロッキングフィルタを適用して、復号ブロックをフィルタリングし得る。復号されたビデオブロックは、次いで、参照フレームストア82に記憶され、参照フレームストア82は、参照ブロックをその後の動き補償に供給し、また、ディスプレイデバイス(図1のディスプレイデバイス32など)上での提示のために復号されたビデオを生成する。
[0104]図6は、本開示の技法による、ビデオデータを符号化するための例示的な方法を示すフローチャートである。例としてビデオ符号器20(図1および図4)に関して説明するが、図6の技法は任意のビデオコード化ユニットによって実行され得ることを理解されたい。さらに、図6に示すステップは、本開示の技法から逸脱することなく、異なる順序で実施することができ、いくつかのステップは省いてもよく、追加ステップを追加してもよい。
[0105]ビデオ符号器20は、符号化されるべきビデオデータのブロック(たとえば、CU)を受信する。現在のブロックが、イントラ予測コード化を使って符号化されるべきブロックと指定されるとき、ビデオ符号器20は、予測サンプルに平滑化フィルタを適用するかどうか判断し、適用されるべきである場合、平滑化フィルタを判断する。平滑化フィルタは、いくつかの事例では、イントラ予測コード化における同じフレーム中のブロックを予測するのに使われる予測サンプルまたは予測子に適用され得る。平滑化フィルタの適用により、いくつかの場合には、より正確な予測が行われ、再構成された予測フレームにおけるブロッキネスを最小限にする。
[0106]ビデオ符号器20は、固定モード依存イントラ予測コード化、または適応モード依存イントラ予測コード化で動作するか判断し得(602)。一例では、判断は、コンテントに基づいて、またはブロックサイズに基づいて、シーケンスまたはピクチャレベルで行われる。たとえば、大きいブロックの場合、適応モード依存イントラ予測コード化が使用され、小さいブロックの場合は、固定モード依存イントラ予測コード化が使用される。その結果、大きいブロックが使われるとき、小さいブロックが使われるときよりも、ピクチャ内で符号化すべきブロックは少なく、したがってオーバーヘッド情報の量は少ない。ただし、固定モード依存イントラ予測コード化は、追加オーバーヘッド情報をほとんどまたは全く加えないが、適応モード依存イントラ予測コード化は、追加オーバーヘッド情報を必要とする。このようにして、選択されたモードは、オーバーヘッド情報と性能との間のトレードオフを与え得る。
[0107]ビデオ符号器20が、固定モード依存イントラ予測コード化において動作する場合、ビデオ符号器20は、ブロックサイズとイントラ予測モードとの組合せに基づいて選択されたフィルタテーブル、たとえば、最も確実なフィルタテーブル中で指定されたフィルタに基づいて平滑化フィルタを適用するかどうか判断し、当該指定されたフィルタを適用する(604)。
[0108]一例では、利用可能イントラ予測モード、たとえば、HMによって定義された35個のモードの各々に対して、平滑化フィルタが適用されるかどうかは、ブロックサイズに依存する。上の表3は、平滑化フィルタが適用される、ブロックサイズとイントラ予測モードとの組合せを示す。最も確実なフィルタテーブル(上に示した)は、ブロックサイズとイントラ予測モードとの組合せに基づいて生成される。テーブルのエントリの各々は、対応するインデックスに適用されるべきフィルタを指示し、インデックスは、ブロックサイズおよびイントラ予測モードに関連付けられる。テーブル中で指定されたフィルタの各々はフィルタセットにあり、フィルタセットは、ストリームごと、フレームのグループごと、フレームまたはスライスごとなどで変わり得る。簡単のために、平滑化フィルタを適用する必要がないエントリに対しては、全域通過フィルタが識別され得る。
[0109]ビデオ符号器20が、適応モード依存イントラ予測コード化において動作する場合、ビデオ符号器20は、ブロックサイズが、ブロックサイズ閾値、たとえば、64×64以上であるかどうか判断する(606)。ブロックサイズがブロックサイズ閾値未満である場合、ビデオ符号器20は、最も確実なフィルタテーブルによって指定されたフィルタを適用し、ブロックサイズおよびイントラ予測モードに基づいて平滑化フィルタを適用するかどうか判断する(604)。ブロックサイズがブロックサイズ閾値以上である場合、ビデオ符号器20は、最も確実なフィルタテーブルによるフィルタの適用が、2番目に確実なフィルタテーブルによるフィルタの適用よりも良好な結果生じるかどうか判断する(608)。従って、ビデオ符号器20は、第1のテーブルにある対応するフィルタをブロックに適用し、第2のテーブルにある対応するフィルタをブロックに適用し、これら2つのフィルタを適用した結果を、互いと比較することによって評価し、どちらがより良好な結果を生じるか判断する。
[0110]一例では、ブロックサイズとイントラ予測モードとの各組合せに対して、テーブルの1つによるフィルタの適用は、フィルタを全く適用しないこと、またはこの例では、全域通過フィルタを適用することと同じである。従って、実際には、最も確実なフィルタテーブルによるフィルタの適用と、2番目に確実なフィルタテーブルによるフィルタの適用との比較は、フィルタを適用した結果またはフィルタを適用しない結果を比較することと同じである。
[0111]最も確実なフィルタテーブルによるフィルタの適用が、より良好な結果を生じる場合、ビデオ符号器20は、現在のブロックに関連付けられたブロックサイズとイントラ予測モードとの組合せに基づいて、最も確実なフィルタテーブルによって指定されるフィルタを判断及び適用する(604)。2番目に確実なフィルタテーブルによるフィルタの適用が、より良好な結果を生じる場合、ビデオ符号器20は、現在のブロックに関連付けられたブロックサイズとイントラ予測モードとの組合せに基づいて、2番目に確実なフィルタテーブルによって指定されるフィルタを判断し及び適用する(610)。いくつかの例では、2つよりも多い最も確実なフィルタテーブル、たとえば、3番目またはそれ以降に確実なテーブルがある場合、可能フィルタすべてを適用した結果を比較することは、予測サンプルに適用する平滑化フィルタを選択するためにどのフィルタテーブルを使うかを判断するために比較される。いくつかの例では、複数のフィルタリング決定テーブル、たとえば、上の表4〜表7が使用され、上述したように、1つのテーブルは「テンプレートパターン」と見なされ、残りのテーブルは、代替テーブルまたは代替フィルタリングオプションを提供する「サブセットパターン」と見なされる。
[0112]ビデオ符号器20は次いで、選択された平滑化フィルタを予測サンプルに適用し、現在のブロックに関連付けられたイントラ予測モードによるイントラ予測コード化を実施することによって、現在のブロックを符号化する(612)。ビデオ符号器20は、イントラ予測コード化に関連付けられたシンタックス要素、たとえば、イントラ予測モードを識別する1つまたは複数のシンタックス要素を、現在のブロックとともに符号化する(614)。ブロックとともに符号化される、イントラ予測コード化に関連付けられたシンタックス要素の他の例は、ブロック、PUサイズ、TUサイズ、CBP、および量子化係数に関連付けられたパーティションタイプである。適用される平滑化フィルタの決定が、最も確実なフィルタテーブルまたは「テンプレートパターン」に基づかない場合、たとえば、フィルタリング決定が、2番目に確実なフィルタテーブルまたは他の「サブセットパターン」を使って行われた場合、ビデオ符号器20は、ブロックが固定モード依存イントラ予測コード化を使って符号化されなかったことをシグナリングするために最も確実なフィルタテーブルが使われなかったことを示すシンタックス要素を符号化する。たとえば、上の表7が「テンプレートパターン」であり、表4〜表6が「サブセットパターン」である場合、ビデオ符号器は、「テンプレートパターン」テーブルの代わりにあるテーブルが使われるとき、使われる「サブセットパターン」テーブルを示すシンタックス要素を符号化する。ビデオ符号器20は次いで、符号化されたビデオブロックを、符号化されたビデオフレームに入れて、シンタックス要素とともにビデオ復号器に送信する(616)。
[0113]図7は、本開示の技法による、ビデオデータを復号するための例示的な方法を示すフローチャートである。例としてビデオ復号器30(図1および図5)に関して説明するが、図7の技法は任意のビデオコード化ユニットによって実行され得ることを理解されたい。さらに、図7に示すステップは、本開示の技法から逸脱することなく、異なる順序で実施することができ、いくつかのステップは省いてもよく、追加ステップを追加してもよい。
[0114]ビデオ復号器30は、復号されるべきビデオデータの符号化ブロック(たとえば、CU)を受信する(702)。ビデオ復号器30は、符号化ビデオブロックおよびシンタックス要素を復号して、ブロックが、イントラ予測コード化を使って符号化されていると判断する(704)。シンタックス要素に基づいて、ビデオ復号器30は、ブロックのイントラ予測モードを判断する(706)。ビデオ復号器30は、シンタックス要素がフィルタリング指示を含むかどうか判断する(708)。
[0115]フィルタリング指示がない場合、ビデオ復号器30は、イントラ予測コード化を使ってブロックを復号し、最も確実なフィルタテーブルによって指定された平滑化フィルタオプションを適用する(710)。フィルタリング指示がある場合、ビデオ復号器30は、イントラ予測コード化を使用し、2番目に確実なフィルタテーブルによって指定された平滑化フィルタオプションを適用して、ブロックを復号する(712)。いずれの場合でも、最も確実なフィルタテーブルを使用しようとまたは2番目に確実なフィルタテーブルを使用しようと、ビデオ復号器30は、現在のブロックに関連付けられたブロックサイズとイントラ予測モードとの組合せに基づいてフィルタを判断する。いくつかの例では、複数のテーブルが、2番目(もしくはそれ以降)に確実なフィルタを定義し、または複数の「サブセットパターン」フィルタが存在し、フィルタリング指示が、最も確実なフィルタテーブルまたは「テンプレートパターン」テーブルの代わりに使われる「サブセットパターン」テーブルを示す。
[0116]このようにして、ビデオ復号器30は、どのフィルタリングオプションがより良好な結果を与えるかに関するいかなる判断も行う必要がない場合がある。符号器によって指示がシグナリングされない場合、ビデオ復号器30は、最も確実なフィルタテーブルまたは「テンプレートパターン」テーブルが使われたと仮定し、そうでない場合、どのタイプのシグナリングも、2番目に確実なフィルタテーブルが使われたことを示す。いくつかの例では、2つよりも多いフィルタテーブル、たとえば、3番目(またはそれ以降)に確実なフィルタテーブルまたは「サブセットパターン」が使われる場合、フィルタリング指示は、平滑化フィルタを選択する際に追加テーブルのうちどれが使われたかを識別し得る。
[0117]上述したように、イントラ平滑化フィルタリングは、たとえば、図2Bおよび表4で示すように、大きいPUサイズに対して使用される。イントラ平滑化フィルタリングは、真の対角方向(すなわち、+/−45および+/−135度)に対応するイントラ予測モードまたはモード3、6、9については、ほとんどのPUサイズに対しても使用することができるが、イントラ平滑化フィルタリングは、垂直(モード0)および水平(モード1)方向の場合において、より小さいPUサイズに対しては使用することができない。対角方向と、水平または垂直方向のそれぞれとの間のイントラ予測方向に対して、イントラ予測フィルタリングは、図2Bおよび表4に示したように、方向が水平または垂直方向に近いとき、小さいPUサイズに対して使用される可能性は比較的低いが、方向が対角方向に近いとき、小さいPUサイズに対して使用される可能性が比較的高い。一例では、本開示の技法による符号器および復号器は、上に示した表7によって指定される「サブセットパターン」によるイントラ平滑化フィルタリングを適用する。一例では、DCモード(モード2)の場合、イントラ平滑化フィルタリングは、どのPUサイズに対しても使用されない。また、平面モード(モード34)の場合、イントラ平滑化フィルタリングは、より大きいPUサイズとともに使用される。
[0118]符号器および復号器は、PUサイズとイントラ予測モードとの各組合せについて、イントラ平滑化フィルタリングが実施されるかどうかを指定する「テンプレートパターン」(表4)から導出される「サブセットパターン」によるイントラ平滑化フィルタリングを適用し得る。「サブセットパターン」は、イントラ予測モードごとおよびPUサイズごとに「テンプレートパターン」から、イントラ平滑化フィルタリングのための候補を選択することによって導出され、または代替として、任意のPUサイズに対するどのイントラ平滑化フィルタリングも、そのイントラ予測モードには対応しない。「テンプレートパターン」から導出される「サブセットパターン」は、たとえば、各イントラ予測モードについて、イントラ平滑化フィルタリングは複数のPUサイズのうち少なくとも1つに対しては適用されない、というような特定の特性を有し、したがって符号器は、イントラ平滑化なしでイントラ予測を実施するというオプションをもつ。「サブセットパターン」も特定の特性を有し、それは、たとえば、各イントラ予測モードについて、特定のPUサイズにおいてイントラ平滑化フィルタリングが適用されない場合、イントラ平滑化フィルタリングは、そのイントラ予測モードに対して、より小さいどのPUサイズでも適用されない、というようなものである。
[0119]イントラ予測モードとPUサイズとの各組合せについての予測サンプルの計算は、最も近い整数への切捨て、切上げ、または丸めなどのような丸め規則の対象となり得る。丸め規則は、決定論的方法で予測サンプルロケーションに基づいて、たとえば、コード化効率を高めるために、予測サンプルを異なる丸め規則でインターリーブするなどのように、イントラ予測モードおよびPUサイズに基づいて、符号器および復号器において修正し得る。イントラ予測のための参照サンプルのイントラ平滑化フィルタリングの例では、イントラ平滑化フィルタリングは、コード化効率を高めるために、いくつかの参照サンプルロケーション、たとえば、(たとえば、イントラ予測モードおよびPUサイズに基づく)決定論的方法における左上隅の参照サンプルまたは他の参照サンプルロケーションに対してはスキップされる場合がある。
[0120]一例では、符号器および/または復号器は、「サブセットパターン」をルックアップテーブル(LUT)として記憶し、このLUTにアクセスして、現在のブロックに関連付けられたPUサイズとイントラ予測モードとの組合せに対してイントラ平滑化フィルタリングを適用するかどうか判断する。別の例では、符号器および/または復号器は、入力、すなわち、PUサイズおよびイントラ予測モードに対する、イントラ平滑化フィルタリング適用するかどうか判断するのに使われる条件のセットによって「サブセットパターン」を表す。別の例では、符号器および/または復号器は、入力、すなわち、PUサイズおよびイントラ予測モードに対する、イントラ平滑化フィルタリングを適用するかどうかを計算する1つまたは複数の数式によって「サブセットパターン」を表す。別の例では、符号器および/または復号器は、LUT、条件のセット、および/または数式セットの組合せによって「サブセットパターン」を表す。
[0121]一例では、「テンプレートパターン」(たとえば、表4)または「サブセットパターン」(たとえば、表5〜表7)は、PUサイズとイントラ予測モードとの各組合せに使われ得る複数のイントラ平滑化フィルタタイプを含むように拡張され得る。たとえば、イントラ平滑化フィルタリングが適用される各組合せについて、テーブル中の番号は、使うべきフィルタのタイプを示す。一例では、2つのイントラ平滑化フィルタが定義され、それらは「1」および「2」で表される。特定の行/列の位置に対応するテーブル中のエントリは、エントリを持たない、すなわち、どのフィルタも適用されない、または「1」もしくは「2」をもち、これは、イントラ平滑化フィルタリングが適用され、および使われるイントラ平滑化フィルタ、すなわち、フィルタ「1」またはフィルタ「2」のどちらかを示す。
[0122]いくつかの例では、HEVCは、コード化ユニット(CU)ごとに様々な矩形サイズを有し得る短距離イントラ予測(SDIP:Short-Distance intra prediction)PUをサポートし得る。一例では、本開示の技法は、短距離イントラ予測(SDIP)において使われるような方形および矩形PUに適用可能である。下の表8は、SDIPのCUサイズごとの矩形PUサイズの例を(ピクセルで)示す。
Figure 0005587508
[0123]上で論じた技法に加えて、本開示の技法は、矩形SDIPパーティションへのMDISの適用を向上するための技法を含み得る。たとえば、イントラ平滑化フィルタリングの適用は、矩形SDIPパーティションの幅および/または高さに依存する。SDIPパーティションの次元を判断するための技法、または次元判断規則は、パーティションの1つの次元または複数の次元を判断するのに利用することができる。たとえば、SDIPパーティションの次元を判断するためのそのような技法は、パーティションの最小または最大次元の判断、パーティションに関連付けられた他の既知の変数に基づいてパーティションの次元を計算する数式、またはパーティションの次元を判断するための、SDIPパーティションの幅および高さに適用され得る条件チェックを含み得る。一例では、結果として判断されたパーティションの次元は、たとえば、上述したフィルタリング決定テーブルの1つを使って、イントラ平滑化フィルタリングを適用するかどうか判断するのに使用される。たとえば、これらの技法は、フィルタリングするかどうか判断するために、次元を使用する。例示的な一例において、最小次元が8ピクセルである場合、フィルタリング決定は、32×32個のブロックに関連付けられたテーブルエントリと、現在処理されているパーティションに関連付けられた適切なイントラ予測モードとに基づいて判断される。
[0124]一例では、イントラ平滑化フィルタリングの適用は、SDIPパーティションに関連付けられたイントラ予測方向および/またはSDIPパーティションの幅および/または高さに基づく。たとえば、垂直予測方向が選ばれると、上述したフィルタリング決定テーブルの1つにおいて、パーティションの高さが使用され、水平方向の場合には、上述したフィルタリング決定テーブルの1つにおいて、幅が使用される。別の例では、水平、垂直、および対角方向を別個に検討して、使われるべき次元を判断する。
[0125]一例では、SDIPパーティションに対して平面モードが使用されるとき、上述したように、次元判断技法は、SDIPパーティションの次元を判断するために使用される。判断された次元は、たとえば、上述したフィルタリング決定テーブルの1つにアクセスすることによって、イントラ平滑化フィルタリングを適用するかどうか判断するのに使用される。
[0126]図8は、本開示の技法による、ビデオデータを符号化するための別の例示的な方法を示すフローチャートである。例としてビデオ符号器20に関して説明するが、図8の技法は任意のビデオコード化ユニットによって実行され得ることを理解されたい。さらに、図8に示すステップは、本開示の技法から逸脱することなく、異なる順序で実施することができ、いくつかのステップは省いてもよく、追加ステップを追加してもよい。
[0127]ビデオ符号器20は、符号化されるべきビデオデータのブロック(たとえば、CU)を受信する。現在のブロックが、イントラ予測コード化を使って符号化されるべき現在のブロックと指定されると、ビデオ符号器20は、現在のブロックサイズと、現在のブロックを符号化するのに使われるイントラ予測モードとを判断する(802)。ビデオ符号器は次いで、上述したように、フィルタテーブル、たとえば、上の表7を使って、ブロックサイズおよびイントラ予測モードに基づいて平滑化フィルタを判断および適用する(804)。
[0128]ビデオ符号器20は次いで、選択された平滑化フィルタを予測サンプルに適用し、現在のブロックに関連付けられたイントラ予測モードによるイントラ予測コード化を実施することによって、現在のブロックを符号化する(612)。ビデオ符号器20は、イントラ予測コード化に関連付けられたシンタックス要素、たとえば、イントラ予測モードを識別する1つまたは複数のシンタックス要素を、現在のブロックとともに符号化する(614)。ブロックとともに符号化され得る、イントラ予測コード化に関連付けられたシンタックス要素の他の例は、ブロック、PUサイズ、TUサイズ、CBP、および量子化係数に関連付けられたパーティションタイプである。ビデオ符号器20は次いで、符号化されたビデオブロックを、符号化されたビデオフレーム内で、シンタックス要素とともにビデオ復号器に送信する(616)。
[0129]図9は、本開示の技法による、ビデオデータを復号するための別の例示的な方法を示すフローチャートである。例としてビデオ復号器30に関して説明するが、図9の技法は任意のビデオコード化ユニットによって実行され得ることを理解されたい。さらに、図9に示すステップは、本開示の技法から逸脱することなく、異なる順序で実施することができ、いくつかのステップは省いてもよく、追加ステップを追加してもよい。
[0130]ビデオ復号器30は、復号されるべきビデオデータの符号化ブロック(たとえば、CU)を受信する(902)。ビデオ復号器30は、符号化ビデオブロックおよびシンタックス要素を復号して、ブロックが、イントラ予測コード化を使って符号化されていると判断する(904)。シンタックス要素に基づいて、ビデオ復号器30は、ブロックのイントラ予測モードを判断する(906)。ビデオ復号器30は次いで、イントラ予測コード化を使ってブロックを復号し、符号化中に使用されたのと同じフィルタリングテーブル、たとえば、表7から、ブロックサイズおよびイントラ予測モードに基づいて、選択された平滑化フィルタを適用する(908)。このように、ビデオ復号器30は、フィルタテーブルからフィルタを選択する以外には、フィルタリングオプションに関するいかなる判断も行う必要がない。
[0131]1つまたは複数の例では、説明した機能は、ハードウェア、ソフトウェア、ファームウェア、またはそれらの任意の組合せで実装され得る。ソフトウェアで実装される場合、機能は、1つまたは複数の命令またはコードとしてコンピュータ可読媒体上に記憶されるか、あるいはコンピュータ可読媒体を介して送信され、ハードウェアベースの処理ユニットによって実行され得る。コンピュータ可読媒体は、たとえば、通信プロトコルに従って、ある場所から別の場所へのコンピュータプログラムの転送を可能にする任意の媒体を含むデータ記憶媒体または通信媒体などの有形媒体に対応するコンピュータ可読記憶媒体を含み得る。このようにして、コンピュータ可読媒体は、概して、(1)非一時的である有形コンピュータ可読記憶媒体、あるいは(2)信号または搬送波などの通信媒体に対応し得る。データ記憶媒体は、本開示で説明した技法の実装のための命令、コードおよび/またはデータ構造を取り出すために1つまたは複数のコンピュータあるいは1つまたは複数のプロセッサによってアクセスされ得る任意の利用可能な媒体であり得る。コンピュータプログラム製品はコンピュータ可読媒体を含み得る。
[0132]限定ではなく例として、そのようなコンピュータ可読記憶媒体は、RAM、ROM、EEPROM、CD−ROMまたは他の光ディスクストレージ、磁気ディスクストレージ、または他の磁気ストレージデバイス、フラッシュメモリ、あるいは命令またはデータ構造の形態の所望のプログラムコードを記憶するために使用され得、コンピュータによってアクセスされ得る、任意の他の媒体を備えることができる。さらに、いかなる接続もコンピュータ可読媒体と適切に呼ばれる。たとえば、命令が、同軸ケーブル、光ファイバーケーブル、ツイストペア、デジタル加入者回線(DSL)、または赤外線、無線、およびマイクロ波などのワイヤレス技術を使用して、ウェブサイト、サーバ、または他のリモートソースから送信される場合、同軸ケーブル、光ファイバーケーブル、ツイストペア、DSL、または赤外線、無線、およびマイクロ波などのワイヤレス技術は、媒体の定義に含まれる。ただし、コンピュータ可読記憶媒体およびデータ記憶媒体は、接続、搬送波、信号、または他の一時媒体を含まないが、代わりに非一時的有形記憶媒体を対象とすることを理解されたい。本明細書で使用するディスク(disk)およびディスク(disc)は、コンパクトディスク(disc)(CD)、レーザディスク(disc)、光ディスク(disc)、デジタル多用途ディスク(disc)(DVD)、フロッピー(登録商標)ディスク(disk)およびブルーレイ(登録商標)ディスク(disc)を含み、ディスク(disk)は、通常、データを磁気的に再生し、ディスク(disc)は、データをレーザで光学的に再生する。上記の組合せもコンピュータ可読媒体の範囲内に含めるべきである。
[0133]命令は、1つまたは複数のデジタル信号プロセッサ(DSP)などの1つまたは複数のプロセッサ、汎用マイクロプロセッサ、特定用途向け集積回路(ASIC)、フィールドプログラマブル論理アレイ(FPGA)、あるいは他の等価な集積回路またはディスクリート論理回路によって実行され得る。したがって、本明細書で使用する「プロセッサ」という用語は、前述の構造、または本明細書で説明する技法の実装に好適な他の構造のいずれかを指す。さらに、いくつかの態様では、本明細書で説明した機能は、符号化および復号のために構成された専用のハードウェアおよび/またはソフトウェアモジュール内に提供され得、あるいは複合コーデックに組み込まれ得る。また、本技法は、1つまたは複数の回路または論理要素中に十分に実装され得る。
[0134]本開示の技法は、ワイヤレスハンドセット、集積回路(IC)またはICのセット(たとえば、チップセット)を含む、多種多様なデバイスまたは装置において実施され得る。本開示では、開示する技法を実行するように構成されたデバイスの機能的態様を強調するために様々な構成要素、モジュール、またはユニットについて説明したが、それらの構成要素、モジュール、またはユニットを、必ずしも異なるハードウェアユニットによって実現する必要はない。むしろ、上記で説明したように、様々なユニットが、好適なソフトウェアおよび/またはファームウェアとともに、上記で説明したように1つまたは複数のプロセッサを含んで、コーデックハードウェアユニットにおいて組合せられるか、または相互動作ハードウェアユニットの集合によって与えられ得る。
以下に、本願出願の当初の特許請求の範囲に記載された発明を付記する。
[1]ビデオデータをコード化する方法であって、
ビデオデータの現在のブロックに関連付けられたブロックサイズを判断することと、
前記現在のブロックに関連付けられたイントラ予測コード化モードを判断することと、
前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックに適用するためにフィルタテーブルからフィルタを選択することと、
前記選択されたフィルタを使って、前記現在のブロックをイントラ予測コード化することと、を備える方法。
[2]前記フィルタを選択することは、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択することを備える、[1]に記載の方法。
[3]前記フィルタを選択することは、
前記ブロックサイズがブロックサイズ閾値よりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択することと、
前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断することと、
を備える、[1]に記載の方法。
[4]フィルタを前記第1のフィルタテーブルまたは前記第2のフィルタテーブルのどちらかから選択するか判断することは、
前記第1のフィルタテーブルからの前記フィルタを前記現在のブロックに適用することと、
前記第2のフィルタテーブルからの前記フィルタを前記現在のブロックに適用することと、
前記第1のフィルタテーブルからの前記フィルタの前記適用の第1の結果と、前記第2のフィルタテーブルからの前記フィルタの前記適用の第2の結果とを評価して、どちらがより良好な結果を得るか判断することと、
前記判断に基づいて、前記第1のフィルタテーブルまたは前記第2のフィルタテーブルから前記フィルタを選択することと、を備える[3]に記載の方法。
[5]前記選択されたフィルタが前記第2のフィルタテーブルから選択されるとき、フィルタリング指示を符号化することをさらに備える、[4]に記載の方法。
[6]前記現在のブロックをコード化することは、前記現在のブロックを復号することを備え、前記現在のブロックは、イントラ予測コード化を使って符号化されたビデオデータのブロックを備え、前記方法は、
前記符号化された現在のブロックがフィルタリング指示を含むかどうか判断することをさらに備え、
前記フィルタを選択することは、前記符号化された現在のブロックがフィルタリング指示を含まないとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択することを備え、
前記フィルタを選択することは、前記符号化された現在のブロックがフィルタリング指示を含むとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第2のフィルタテーブルから選択することを備える、[1]に記載の方法。
[7]前記フィルタテーブルは、ブロックサイズとコード化モードとの異なる複数の組合せに対応する複数のエントリを備え、前記複数のエントリのそれぞれは、フィルタセットから選択される1つのフィルタを備える、[1]に記載の方法。
[8]前記フィルタセットは少なくとも2つのフィルタを備え、前記フィルタの1つは全域通過フィルタを備える、[7]に記載の方法。
[9]フィルタリング決定テーブルを用いて、前記ブロックサイズおよび前記コード化モードに基づき前記現在のブロックにフィルタリングを適用するかどうか判断することと、
前記現在のブロックにフィルタリングが適用される場合、前記フィルタテーブルから前記フィルタを選択することと、をさらに備える、[1]に記載の方法。
[10]前記現在のブロックは、短距離イントラ予測(SDIP)に従ってコード化された予測ユニットを備える、[1]に記載の方法。
[11]前記現在のブロックに関連付けられた次元を判断することと、
次元判断規則セットを用いて、前記次元に基づき前記ブロックサイズを判断することと、
をさらに備える、[10]に記載の方法。
[12]ビデオデータをコード化するための装置であって、
ビデオデータの現在のブロックに関連付けられたブロックサイズを判断し、前記現在のブロックに関連付けられたイントラ予測コード化モードを判断し、前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックに適用するためにフィルタテーブルからフィルタを選択し、前記選択されたフィルタを使って、前記現在のブロックをイントラ予測コード化するように構成されたプロセッサを備える装置。
[13]前記フィルタを選択するために、前記プロセッサは、前記ブロックサイズおよび前記符号化モードに対応するフィルタを第1のフィルタテーブルから選択するように構成される、[12]に記載の装置。
[14]前記フィルタを選択するために、前記プロセッサは、
前記ブロックサイズがブロックサイズ閾値よりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択し、
前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断するようにさらに構成される、[12]に記載の装置。
[15]フィルタを前記第1のフィルタテーブルまたは前記第2のフィルタテーブルのどちらから選択するか判断するために、前記プロセッサは、
前記第1のフィルタテーブルからの前記フィルタを前記現在のブロックに適用し、
前記第2のフィルタテーブルからの前記フィルタを前記現在のブロックに適用し、
前記第1のフィルタテーブルからの前記フィルタの前記適用の第1の結果と、前記第2のフィルタテーブルからの前記フィルタの前記適用の第2の結果とを評価して、どちらがより良好な結果を得るか判断し、
前記判断に基づいて、前記第1のフィルタテーブルまたは前記第2のフィルタテーブルから前記フィルタを選択するようにさらに構成される、[14]に記載の装置。
[16]前記プロセッサは、前記選択されたフィルタが前記第2のフィルタテーブルから選択されたとき、フィルタリング指示を符号化するようにさらに構成される、[15]に記載の装置。
[17]前記第1のフィルタテーブルと前記第2のフィルタテーブルとを記憶するように構成されたメモリをさらに備える、[14]に記載の装置。
[18]前記装置はビデオ復号器を備え、前記現在のブロックは、イントラ予測コード化を使って符号化されたビデオデータのブロックを備え、前記プロセッサは、
前記符号化された現在のブロックがフィルタリング指示を含むかどうか判断するようにさらに構成され、
前記フィルタを選択するために、前記プロセッサは、前記符号化された現在のブロックがフィルタリング指示を含まないとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択するようにさらに構成され、
前記フィルタを選択するために、前記プロセッサは、前記符号化された現在のブロックがフィルタリング指示を含むとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第2のフィルタテーブルから選択するようにさらに構成される、
[12]に記載の装置。
[19]前記フィルタテーブルは、ブロックサイズとコード化モードの異なる複数の組合せに対応する複数のエントリを備え、前記複数のエントリのそれぞれが、フィルタセットから選択される1つのフィルタを備える、[12]に記載の装置。
[20]前記フィルタセットが少なくとも2つのフィルタを備え、前記フィルタの1つが全域通過フィルタを備える、[19]に記載の装置。
[21]前記プロセッサは、
フィルタリング決定テーブルを用いて、前記ブロックサイズおよび前記コード化モードに基づき前記現在のブロックにフィルタリングを適用するかどうか判断し、
前記現在のブロックにフィルタリングが適用される場合、前記フィルタテーブルから前記フィルタを選択するようにさらに構成される、[12]に記載の装置。
[22]前記現在のブロックは、短距離イントラ予測(SDIP)に従ってコード化された予測ユニットを備える、[12]に記載の装置。
[23]前記プロセッサは、
前記現在のブロックに関連付けられた次元を判断し、
次元判断規則セットを用いて、前記次元に基づき前記ブロックサイズを判断するようにさらに構成される、[22]に記載の装置。
[24]ビデオデータを符号化するための装置であって、
ビデオデータの現在のブロックに関連付けられたブロックサイズを判断する手段と、
前記現在のブロックに関連付けられたイントラ予測コード化モードを判断する手段と、
前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックに適用するためにフィルタテーブルからフィルタを選択する手段と、
前記選択されたフィルタを使って、前記現在のブロックをイントラ予測コード化する手段と、を備える装置。
[25]前記フィルタを選択する手段は、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択する手段を備える、[24]に記載の装置。
[26]前記フィルタを選択する手段は、
前記ブロックサイズがブロックサイズ閾値よりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択する手段と、
前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断する手段と、を備える[24]に記載の装置。
[27]前記フィルタを選択する手段は、
前記ブロックサイズがブロックサイズ閾値よりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択する手段と、
前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断する手段と、
を備える、[24]に記載の装置。
[28]フィルタを前記第1のフィルタテーブルまたは前記第2のフィルタテーブルのどちらから選択するか判断する手段は、
前記第1のフィルタテーブルからの前記フィルタを前記現在のブロックに適用する手段と、
前記第2のフィルタテーブルからの前記フィルタを前記現在のブロックに適用する手段と、
前記第1のフィルタテーブルからの前記フィルタの前記適用の第1の結果と、前記第2のフィルタテーブルからの前記フィルタの前記適用の第2の結果とを評価して、どちらがより良好な結果を得るか判断する手段と、
前記判断に基づいて、前記第1のフィルタテーブルまたは前記第2のフィルタテーブルから前記フィルタを選択する手段と、
を備える[27]に記載の装置。
[29]前記選択されたフィルタが前記第2のフィルタテーブルから選択されるとき、フィルタリング指示を符号化する手段をさらに備える、[28]に記載の装置。
[30]前記第1のフィルタテーブルと前記第2のフィルタテーブルとを記憶する手段をさらに備える、[27]に記載の装置。
[31]前記装置はビデオ復号器を備え、前記現在のブロックはイントラ予測コード化を使って符号化されたビデオデータのブロックを備え、前記装置は、
前記符号化された現在のブロックがフィルタリング指示を含むかどうか判断する手段をさらに備え、
前記フィルタを選択する手段は、前記符号化された現在のブロックがフィルタリング指示を含まないとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択する手段を備え、
前記フィルタを選択する手段は、前記符号化された現在のブロックがフィルタリング指示を含むとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第2のフィルタテーブルから選択する手段を備える、[24]に記載の装置。
[32]前記フィルタテーブルは、ブロックサイズとコード化モードとの異なる複数の組合せに対応する複数のエントリを備え、前記複数のエントリのそれぞれはフィルタセットから選択される1つのフィルタを備える、[24]に記載の装置。
[33]前記フィルタセットは少なくとも2つのフィルタを備え、前記フィルタの1つは全域通過フィルタを備える、[32]に記載の装置。
[34]フィルタリング決定テーブルを用いて、前記ブロックサイズおよび前記コード化モードに基づき前記現在のブロックにフィルタリングを適用するかどうか判断する手段と、
前記現在のブロックにフィルタリングが適用される場合、前記フィルタテーブルから前記フィルタを選択する手段と、
をさらに備える、[24]に記載の装置。
[35]前記現在のブロックは、短距離イントラ予測(SDIP)に従ってコード化された予測ユニットを備える、[24]に記載の装置。
[36]前記現在のブロックに関連付けられた次元を判断する手段と、
次元判断規則セットを用いて、前記次元に基づき前記ブロックサイズを判断する手段と、
をさらに備える、[35]に記載の装置。
[37]プロセッサで実行されると、前記プロセッサに、
ビデオデータの現在のブロックに関連付けられたブロックサイズを判断させ、
前記現在のブロックに関連付けられたイントラ予測コード化モードを判断させ、
前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックに適用するためにフィルタテーブルからフィルタを選択させ、
前記選択されたフィルタを使って、前記現在のブロックをイントラ予測コード化させる、
ビデオデータをコード化するための命令を備えるコンピュータ可読記憶媒体。
[38]前記プロセッサに前記フィルタを選択させる命令は、前記プロセッサに、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択させる命令を備える、[37]に記載のコンピュータ可読記憶媒体。
[39]前記プロセッサに前記フィルタを選択させる命令は、前記プロセッサに、
前記ブロックサイズがブロックサイズ閾値よりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択させ、
前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断させる命令を備える、[37]に記載のコンピュータ可読記憶媒体。
[40]前記プロセッサに、フィルタを前記第1のフィルタテーブルまたは前記第2のフィルタテーブルのどちらから選択するか判断させる命令は、前記プロセッサに、
前記第1のフィルタテーブルからの前記フィルタを前記現在のブロックに適用させ、
前記第2のフィルタテーブルからの前記フィルタを前記現在のブロックに適用させ、
前記第1のフィルタテーブルからの前記フィルタの前記適用の第1の結果と、前記第2のフィルタテーブルからの前記フィルタの前記適用の第2の結果とを評価させて、どちらがより良好な結果を得るか判断させ、
前記判断に基づいて、前記第1のフィルタテーブルまたは前記第2のフィルタテーブルから前記フィルタを選択させる命令を備える、[39]に記載のコンピュータ可読記憶媒体。
[41]前記プロセッサに、前記選択されたフィルタが前記第2のフィルタテーブルから選択されたとき、フィルタリング指示を符号化させる命令をさらに備える、[40]に記載のコンピュータ可読記憶媒体。
[42]前記命令は、前記プロセッサに前記現在のブロックを復号させ、前記現在のブロックは、イントラ予測コード化を使って符号化されたビデオデータのブロックを備え、前記プロセッサに、
前記符号化された現在のブロックがフィルタリング指示を含むかどうか判断させる命令をさらに備え、
前記フィルタを選択するための前記命令は、前記符号化された現在のブロックがフィルタリング指示を含まないとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択するための命令を備え、前記フィルタを選択するための命令が、前記符号化された現在のブロックがフィルタリング指示を含むとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第2のフィルタテーブルから選択するための命令を備える、[37]に記載のコンピュータ可読記憶。
[43]前記フィルタテーブルは、ブロックサイズとコード化モードとの異なる複数の組合せに対応する複数のエントリを備え、前記複数のエントリのそれぞれは、フィルタセットから選択される1つのフィルタを備える、[37]に記載のコンピュータ可読記憶媒体。
[44]前記フィルタセットは少なくとも2つのフィルタを備え、前記フィルタの1つが全域通過フィルタを備える、[43]に記載のコンピュータ可読記憶媒体。
[45]前記プロセッサに、
フィルタリング決定テーブルを用いて、前記ブロックサイズおよび前記コード化モードに基づき前記現在のブロックにフィルタリングを適用するかどうか判断させ、
前記現在のブロックにフィルタリングが適用される場合、前記フィルタテーブルから前記フィルタを選択させる命令をさらに備える、[37]に記載のコンピュータ可読記憶媒体。
[46]前記現在のブロックは、短距離イントラ予測(SDIP)に従ってコード化された予測ユニットを備える、[37]に記載のコンピュータ可読記憶媒体。
[47]前記プロセッサに、
前記現在のブロックに関連付けられた次元を判断させ、
次元判断規則セットを用いて、前記次元に基づき前記ブロックサイズを判断させる命令をさらに備える、[46]に記載のコンピュータ可読記憶媒体。

Claims (46)

  1. ビデオデータをコード化する方法であって、前記方法はプロセッサが実行し、
    ビデオデータの現在のブロックに関連付けられたブロックサイズを判断することと、前記ブロックサイズは、4×4ブロックサイズ、8×8ブロックサイズ、16×16ブロックサイズ、および32×32ブロックサイズを含む複数のブロックサイズから判断され、
    前記ビデオデータの現在のブロックに関連付けられたイントラ予測コード化モードを判断することと、前記イントラ予測コード化モードは、水平モード、垂直モード、平面モード、複数の対角モード、及びDCモードを含む複数のイントラ予測コード化モードから判断され、前記複数の対角モードは、左上対角モード及び右上対角モード、左下対角モードを含み、前記複数の対角モードは、前記垂直モードまたは前記水平モードに直接隣接する複数のモードを含み、
    前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックに適用するべきフィルタをフィルタテーブルから選択することと、前記選択に基づいて、前記4×4ブロックサイズに対してはどのフィルタリングも適用されず、前記8×8ブロックサイズに対しては、前記平面モード、前記左上対角モード、前記右上対角モード、および前記左下対角モードのみがフィルタリングされ、前記16×16ブロックサイズに対しては、前記平面モードがフィルタリングされ、および前記水平モード、前記垂直モード、前記DCモード、および前記水平モードまたは前記垂直モードに直接隣接する前記モード以外の全ての予測モードがフィルタリングされ、前記32×32ブロックサイズに対しては、前記平面モードがフィルタリングされ、および前記水平モード、前記垂直モード、及び前記DCモード以外の全ての予測モードがフィルタリングされ、
    前記現在のブロックをイントラ予測コード化することと、
    を備え、
    前記現在のブロックをイントラ予測コード化することは、前記現在のブロックを予測するために使用されるピクセルをフィルタリングするために前記選択されたフィルタを使用することを備える、方法。
  2. 前記フィルタを選択することは、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択することを備える、請求項1に記載の方法。
  3. 前記フィルタを選択することは、
    前記ブロックサイズが閾ブロックサイズよりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択することと、
    前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断することと、
    を備える、請求項1に記載の方法。
  4. フィルタを前記第1のフィルタテーブルまたは前記第2のフィルタテーブルのどちらから選択するか判断することは、
    前記現在のブロックを予測するために使用される前記ピクセルをフィルタリングするために前記第1のフィルタテーブルから前記選択されたフィルタを使用することと、
    前記現在のブロックを予測するために使用される前記ピクセルをフィルタリングするために前記第2のフィルタテーブルから前記選択されたフィルタを使用することと、
    前記第1のフィルタテーブルからの前記フィルタの前記適用の第1の結果と、前記第2のフィルタテーブルからの前記フィルタの前記適用の第2の結果とを評価して、どちらがより良好な結果を生じるか判断することと、
    前記判断に基づいて、前記第1のフィルタテーブルまたは前記第2のフィルタテーブルから前記フィルタを選択することと、を備える請求項3に記載の方法。
  5. 前記選択されたフィルタが前記第2のフィルタテーブルから選択されるとき、フィルタリング指示を符号化することをさらに備える、請求項4に記載の方法。
  6. 前記現在のブロックをコード化することは、前記現在のブロックを復号することを備え、前記現在のブロックは、イントラ予測コード化を使って符号化されたビデオデータのブロックを備え、前記方法は、
    前記符号化された現在のブロックがフィルタリング指示を含むかどうか判断することをさらに備え、
    前記フィルタを選択することは、前記符号化された現在のブロックがフィルタリング指示を含まないとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択することを備え、
    前記フィルタを選択することは、前記符号化された現在のブロックがフィルタリング指示を含むとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第2のフィルタテーブルから選択することを備える、
    請求項1に記載の方法。
  7. 前記フィルタテーブルは、ブロックサイズとコード化モードとの異なる組合せに対応する複数のエントリを備え、前記複数のエントリのそれぞれは、フィルタセットから選択される1つのフィルタを備える、請求項1に記載の方法。
  8. 前記フィルタセットは少なくとも2つのフィルタを備え、前記フィルタの1つは全域通過フィルタを備える、請求項7に記載の方法。
  9. フィルタリング決定テーブルを使い、前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックにフィルタリングを適用するかどうか判断することと、
    前記現在のブロックにフィルタリングが適用される場合、前記フィルタテーブルから前記フィルタを選択することと、
    をさらに備える、請求項1に記載の方法。
  10. 前記現在のブロックは、短距離イントラ予測(SDIP)に従ってコード化された予測ユニットを備える、請求項1に記載の方法。
  11. 前記現在のブロックに関連付けられた次元を判断することと、
    次元判断規則セットを使い、前記次元に基づいて前記ブロックサイズを判断することと、
    をさらに備える、請求項10に記載の方法。
  12. ビデオデータをコード化するための装置であって、
    ビデオデータの現在のブロックに関連付けられたブロックサイズを判断し、前記ブロックサイズは、4×4ブロックサイズ、8×8ブロックサイズ、16×16ブロックサイズ、および32×32ブロックサイズを含む複数のブロックサイズから判断され、
    前記ビデオデータの現在のブロックに関連付けられたイントラ予測コード化モードを判断し、前記イントラ予測コード化モードは、水平モード、垂直モード、平面モード、複数の対角モード、及びDCモードを含む複数のイントラ予測コード化モードから判断され、前記複数の対角モードは、左上対角モード及び右上対角モード、左下対角モードを含み、前記複数の対角モードは、前記垂直モードまたは前記水平モードに直接隣接する複数のモードを含み、
    前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックに適用するべきフィルタをフィルタテーブルから選択し、前記選択に基づいて、前記4×4ブロックサイズに対してはどのフィルタリングも適用されず、前記8×8ブロックサイズに対しては、前記平面モード、前記左上対角モード、前記右上対角モード、および前記左下対角モードのみがフィルタリングされ、前記16×16ブロックサイズに対しては、前記平面モードがフィルタリングされ、および前記水平モード、前記垂直モード、前記DCモード、および前記水平モードまたは前記垂直モードに直接隣接する前記モード以外の全ての予測モードがフィルタリングされ、前記32×32ブロックサイズに対しては、前記平面モードがフィルタリングされ、および前記水平モード、前記垂直モード、及び前記DCモード以外の全ての予測モードがフィルタリングされ、
    前記現在のブロックをイントラ予測コード化するように構成されたプロセッサを備え、
    前記現在のブロックをイントラ予測コード化することは、前記現在のブロックを予測するために使用されるピクセルをフィルタリングするために前記選択されたフィルタを使用することを備え装置。
  13. 前記フィルタを選択するために、前記プロセッサは、前記ブロックサイズおよび前記符号化モードに対応するフィルタを第1のフィルタテーブルから選択するように構成される、請求項12に記載の装置。
  14. 前記フィルタを選択するために、前記プロセッサは、
    前記ブロックサイズが閾ブロックサイズよりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択し、
    前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断するようにさらに構成される、請求項12に記載の装置。
  15. フィルタを前記第1のフィルタテーブルまたは前記第2のフィルタテーブルのどちらから選択するか判断するために、前記プロセッサは、
    前記現在のブロックを予測するために使用される前記ピクセルをフィルタリングするために前記第1のフィルタテーブルから前記選択されたフィルタを使用し、
    前記現在のブロックを予測するために使用される前記ピクセルをフィルタリングするために前記第2のフィルタテーブルから前記選択されたフィルタを使用し、
    前記第1のフィルタテーブルからの前記フィルタの前記適用の第1の結果と、前記第2のフィルタテーブルからの前記フィルタの前記適用の第2の結果とを評価して、どちらがより良好な結果を生じるか判断し、
    前記判断に基づいて、前記第1のフィルタテーブルまたは前記第2のフィルタテーブルから前記フィルタを選択するようにさらに構成される、請求項14に記載の装置。
  16. 前記プロセッサは、前記選択されたフィルタが前記第2のフィルタテーブルから選択されたとき、フィルタリング指示を符号化するようにさらに構成される、請求項15に記載の装置。
  17. 前記第1のフィルタテーブルと前記第2のフィルタテーブルとを記憶するように構成されたメモリをさらに備える、請求項14に記載の装置。
  18. 前記装置はビデオ復号器を備え、前記現在のブロックは、イントラ予測コード化を使って符号化されたビデオデータのブロックを備え、前記プロセッサは、
    前記符号化された現在のブロックがフィルタリング指示を含むかどうか判断するようにさらに構成され、
    前記フィルタを選択するために、前記プロセッサは、前記符号化された現在のブロックがフィルタリング指示を含まないとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択するようにさらに構成され、
    前記フィルタを選択するために、前記プロセッサは、前記符号化された現在のブロックがフィルタリング指示を含むとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第2のフィルタテーブルから選択するようにさらに構成される、
    請求項12に記載の装置。
  19. 前記フィルタテーブルは、ブロックサイズとコード化モードとの異なる組合せに対応する複数のエントリを備え、前記複数のエントリのそれぞれは、フィルタセットから選択される1つのフィルタを備える、請求項12に記載の装置。
  20. 前記フィルタセットが少なくとも2つのフィルタを備え、前記フィルタの1つが全域通過フィルタを備える、請求項19に記載の装置。
  21. 前記プロセッサは、
    フィルタリング決定テーブルを用いて、前記ブロックサイズおよび前記コード化モードに基づき前記現在のブロックにフィルタリングを適用するかどうか判断し、
    前記現在のブロックにフィルタリングが適用される場合、前記フィルタテーブルから前記フィルタを選択するようにさらに構成される、請求項12に記載の装置。
  22. 前記現在のブロックは、短距離イントラ予測(SDIP)に従ってコード化された予測ユニットを備える、請求項12に記載の装置。
  23. 前記プロセッサは、
    前記現在のブロックに関連付けられた次元を判断し、
    次元判断規則セットを用いて、前記次元に基づき前記ブロックサイズを判断するようにさらに構成される、請求項22に記載の装置。
  24. ビデオデータを符号化するための装置であって、
    ビデオデータの現在のブロックに関連付けられたブロックサイズを判断する手段と、前記ブロックサイズは、4×4ブロックサイズ、8×8ブロックサイズ、16×16ブロックサイズ、および32×32ブロックサイズを含む複数のブロックサイズから判断され、
    前記ビデオデータの現在のブロックに関連付けられたイントラ予測コード化モードを判断する手段と、前記イントラ予測コード化モードは、水平モード、垂直モード、平面モード、複数の対角モード、及びDCモードを含む複数のイントラ予測コード化モードから判断され、前記複数の対角モードは、左上対角モード及び右上対角モード、左下対角モードを含み、前記複数の対角モードは、前記垂直モードまたは前記水平モードに直接隣接する複数のモードを含み、
    前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックに適用するべきフィルタをフィルタテーブルから選択する手段と、前記選択に基づいて、前記4×4ブロックサイズに対してはどのフィルタリングも適用されず、前記8×8ブロックサイズに対しては、前記平面モード、前記左上対角モード、前記右上対角モード、および前記左下対角モードのみがフィルタリングされ、前記16×16ブロックサイズに対しては、前記平面モードがフィルタリングされ、および前記水平モード、前記垂直モード、前記DCモード、および前記水平モードまたは前記垂直モードに直接隣接する前記モード以外の全ての予測モードがフィルタリングされ、前記32×32ブロックサイズに対しては、前記平面モードがフィルタリングされ、および前記水平モード、前記垂直モード、及び前記DCモード以外の全ての予測モードがフィルタリングされ、
    前記現在のブロックをイントラ予測コード化する手段と、前記現在のブロックをイントラ予測コード化することは、前記現在のブロックを予測するために使用されるピクセルをフィルタリングするために前記選択されたフィルタを使用することを備える、
    を備える装置。
  25. 前記フィルタを選択する手段は、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択する手段を備える、請求項24に記載の装置。
  26. 前記フィルタを選択する手段は、
    前記ブロックサイズがブロックサイズ閾値よりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択する手段と、
    前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断する手段と、
    を備える、請求項24に記載の装置。
  27. フィルタを前記第1のフィルタテーブルまたは前記第2のフィルタテーブルのどちらから選択するか判断する手段は、
    前記現在のブロックを予測するために使用される前記ピクセルをフィルタリングするために前記第1のフィルタテーブルから前記選択されたフィルタを使用する手段と、
    前記現在のブロックを予測するために使用される前記ピクセルをフィルタリングするために前記第2のフィルタテーブルから前記選択されたフィルタを使用する手段と、
    前記第1のフィルタテーブルからの前記フィルタの前記適用の第1の結果と、前記第2のフィルタテーブルからの前記フィルタの前記適用の第2の結果とを評価して、どちらがより良好な結果を生じるか判断する手段と、
    前記判断に基づいて、前記第1のフィルタテーブルまたは前記第2のフィルタテーブルから前記フィルタを選択する手段と、
    を備える請求項24に記載の装置。
  28. 前記選択されたフィルタが前記第2のフィルタテーブルから選択されるとき、フィルタリング指示を符号化する手段をさらに備える、請求項27に記載の装置。
  29. 前記第1のフィルタテーブルと前記第2のフィルタテーブルとを記憶する手段をさらに備える、請求項24に記載の装置。
  30. 前記装置がビデオ復号器を備え、前記現在のブロックはイントラ予測コード化を使って符号化されたビデオデータのブロックを備え、前記装置は、
    前記符号化された現在のブロックがフィルタリング指示を含むかどうか判断する手段をさらに備え、
    前記フィルタを選択する手段は、前記符号化された現在のブロックがフィルタリング指示を含まないとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択する手段を備え、
    前記フィルタを選択する手段は、前記符号化された現在のブロックがフィルタリング指示を含むとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第2のフィルタテーブルから選択する手段を備える、
    請求項24に記載の装置。
  31. 前記フィルタテーブルが、ブロックサイズとコード化モードとの異なる組合せに対応する複数のエントリを備え、前記複数のエントリのそれぞれが、フィルタセットから選択される1つのフィルタを備える、請求項24に記載の装置。
  32. 前記フィルタセットは少なくとも2つのフィルタを備え、前記フィルタの1つは全域通過フィルタを備える、請求項31に記載の装置。
  33. フィルタリング決定テーブルを用いて、前記ブロックサイズおよび前記コード化モードに基づき前記現在のブロックにフィルタリングを適用するかどうか判断する手段と、
    前記現在のブロックにフィルタリングが適用される場合、前記フィルタテーブルから前記フィルタを選択する手段と、
    をさらに備える、請求項24に記載の装置。
  34. 前記現在のブロックは、短距離イントラ予測(SDIP)に従ってコード化された予測ユニットを備える、請求項24に記載の装置。
  35. 前記現在のブロックに関連付けられた次元を判断する手段と、
    次元判断規則セット使い、前記次元に基づき前記ブロックサイズを判断する手段と、
    をさらに備える、請求項34に記載の装置。
  36. プロセッサ内で実行されると、前記プロセッサに、
    ビデオデータの現在のブロックに関連付けられたブロックサイズを判断させ、前記ブロックサイズは、4×4ブロックサイズ、8×8ブロックサイズ、16×16ブロックサイズ、および32×32ブロックサイズを含む複数のブロックサイズから判断され、
    前記ビデオデータの現在のブロックに関連付けられたイントラ予測コード化モードを判断させ、前記イントラ予測コード化モードは、水平モード、垂直モード、平面モード、複数の対角モード、及びDCモードを含む複数のイントラ予測コード化モードから判断され、前記複数の対角モードは、左上対角モード及び右上対角モード、左下対角モードを含み、前記複数の対角モードは、前記垂直モードまたは前記水平モードに直接隣接する複数のモードを含み、
    前記ブロックサイズおよび前記コード化モードに基づいて、前記現在のブロックに適用するべきフィルタをフィルタテーブルから選択させ、前記選択に基づいて、前記4×4ブロックサイズに対してはどのフィルタリングも適用されず、前記8×8ブロックサイズに対しては、前記平面モード、前記左上対角モード、前記右上対角モード、および前記左下対角モードのみがフィルタリングされ、前記16×16ブロックサイズに対しては、前記平面モードがフィルタリングされ、および前記水平モード、前記垂直モード、前記DCモード、および前記水平モードまたは前記垂直モードに直接隣接する前記モード以外の全ての予測モードがフィルタリングされ、前記32×32ブロックサイズに対しては、前記平面モードがフィルタリングされ、および前記水平モード、前記垂直モード、及び前記DCモード以外の全ての予測モードがフィルタリングされ、
    前記現在のブロックをイントラ予測コード化させ、前記現在のブロックをイントラ予測コード化することは、前記現在のブロックを予測するために使用されるピクセルをフィルタリングするために前記選択されたフィルタを使用することを備える、
    ビデオデータをコード化するための命令を備えるコンピュータ可読記憶媒体。
  37. 前記プロセッサに前記フィルタを選択させる命令は、前記プロセッサに、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択させる命令を備える、請求項36に記載のコンピュータ可読記憶媒体。
  38. 前記プロセッサに前記フィルタを選択させる命令は、前記プロセッサに、
    前記ブロックサイズがブロックサイズ閾値よりも小さいとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、第1のフィルタテーブルから選択させ、
    前記ブロックサイズがブロックサイズ閾値以上のとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを、前記第1のフィルタテーブルまたは第2のフィルタテーブルのどちらから選択するか判断させる命令を備える、
    請求項36に記載のコンピュータ可読記憶媒体。
  39. 前記プロセッサに、フィルタを前記第1のフィルタテーブルまたは前記第2のフィルタテーブルのどちらから選択するか判断させる命令は、前記プロセッサに、
    前記現在のブロックを予測するために使用される前記ピクセルをフィルタリングするために前記第1のフィルタテーブルから前記選択されたフィルタを使用させ、
    前記現在のブロックを予測するために使用される前記ピクセルをフィルタリングするために前記第2のフィルタテーブルから前記選択されたフィルタを使用させ、
    前記第1のフィルタテーブルからの前記フィルタの前記適用の第1の結果と、前記第2のフィルタテーブルからの前記フィルタの前記適用の第2の結果とを評価させて、どちらがより良好な結果を生じるか判断させ、
    前記判断に基づいて、前記第1のフィルタテーブルまたは前記第2のフィルタテーブルから前記フィルタを選択させる命令を備える、
    請求項38に記載のコンピュータ可読記憶媒体。
  40. 前記プロセッサに、前記選択されたフィルタが前記第2のフィルタテーブルから選択されたとき、フィルタリング指示を符号化させる命令をさらに備える、請求項39に記載のコンピュータ可読記憶媒体。
  41. 前記命令は、前記プロセッサに前記現在のブロックを復号させ、前記現在のブロックは、イントラ予測コード化を使って符号化されたビデオデータのブロックを備え、前記プロセッサに、
    前記符号化された現在のブロックがフィルタリング指示を含むかどうか判断させる命令をさらに備え、
    前記フィルタを選択するための前記命令は、前記符号化された現在のブロックがフィルタリング指示を含まないとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第1のフィルタテーブルから選択するための命令を備え、前記フィルタを選択するための命令が、前記符号化された現在のブロックがフィルタリング指示を含むとき、前記ブロックサイズおよび前記コード化モードに対応するフィルタを第2のフィルタテーブルから選択するための命令を備える、請求項36に記載のコンピュータ可読記憶。
  42. 前記フィルタテーブルは、ブロックサイズとコード化モードとの異なる組合せに対応する複数のエントリを備え、前記複数のエントリのそれぞれは、フィルタセットから選択されるフィルタを備える、請求項36に記載のコンピュータ可読記憶媒体。
  43. 前記フィルタセットは少なくとも2つのフィルタを備え、前記フィルタの1つが全域通過フィルタを備える、請求項42に記載のコンピュータ可読記憶媒体。
  44. 前記プロセッサに、
    フィルタリング決定テーブルを用いて、前記ブロックサイズおよび前記コード化モードに基づき前記現在のブロックにフィルタリングを適用するかどうか判断させ、
    前記現在のブロックにフィルタリングが適用される場合、前記フィルタテーブルから前記フィルタを選択させる命令をさらに備える、請求項36に記載のコンピュータ可読記憶媒体。
  45. 前記現在のブロックは、短距離イントラ予測(SDIP)に従ってコード化された予測ユニットを備える、請求項36に記載のコンピュータ可読記憶媒体。
  46. 前記プロセッサに、
    前記現在のブロックに関連付けられた次元を判断させ、
    次元判断規則セット使い、前記次元に基づき前記ブロックサイズを判断させる命令をさらに備える、請求項45に記載のコンピュータ可読記憶媒体。
JP2013531897A 2010-10-01 2011-09-30 ビデオコード化のためのイントラ平滑化フィルタ Active JP5587508B2 (ja)

Applications Claiming Priority (17)

Application Number Priority Date Filing Date Title
US38917310P 2010-10-01 2010-10-01
US61/389,173 2010-10-01
US40604610P 2010-10-22 2010-10-22
US61/406,046 2010-10-22
US201061426388P 2010-12-22 2010-12-22
US61/426,388 2010-12-22
US201061426964P 2010-12-23 2010-12-23
US61/426,964 2010-12-23
US201161492335P 2011-06-01 2011-06-01
US61/492,335 2011-06-01
US201161499579P 2011-06-21 2011-06-21
US61/499,579 2011-06-21
US201161500095P 2011-06-22 2011-06-22
US61/500,095 2011-06-22
US13/248,968 2011-09-29
US13/248,968 US9008175B2 (en) 2010-10-01 2011-09-29 Intra smoothing filter for video coding
PCT/US2011/054130 WO2012044886A1 (en) 2010-10-01 2011-09-30 Intra smoothing filter for video coding

Publications (2)

Publication Number Publication Date
JP2013543315A JP2013543315A (ja) 2013-11-28
JP5587508B2 true JP5587508B2 (ja) 2014-09-10

Family

ID=45889817

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2013531897A Active JP5587508B2 (ja) 2010-10-01 2011-09-30 ビデオコード化のためのイントラ平滑化フィルタ

Country Status (19)

Country Link
US (1) US9008175B2 (ja)
EP (1) EP2622858B1 (ja)
JP (1) JP5587508B2 (ja)
KR (2) KR20130063030A (ja)
CN (1) CN103141100B (ja)
AU (1) AU2011308653B2 (ja)
BR (1) BR112013007563B1 (ja)
CA (1) CA2812307C (ja)
DK (1) DK2622858T3 (ja)
ES (1) ES2656494T3 (ja)
HK (1) HK1182249A1 (ja)
HU (1) HUE035458T2 (ja)
IL (1) IL225331A (ja)
PL (1) PL2622858T3 (ja)
PT (1) PT2622858T (ja)
RU (1) RU2543552C2 (ja)
SG (1) SG189036A1 (ja)
SI (1) SI2622858T1 (ja)
WO (1) WO2012044886A1 (ja)

Families Citing this family (72)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5544996B2 (ja) * 2010-04-09 2014-07-09 ソニー株式会社 画像処理装置および方法
KR20110113561A (ko) 2010-04-09 2011-10-17 한국전자통신연구원 적응적인 필터를 이용한 인트라 예측 부호화/복호화 방법 및 그 장치
KR20110123651A (ko) 2010-05-07 2011-11-15 한국전자통신연구원 생략 부호화를 이용한 영상 부호화 및 복호화 장치 및 그 방법
KR101663764B1 (ko) * 2010-08-26 2016-10-07 에스케이 텔레콤주식회사 인트라 예측을 이용한 부호화 및 복호화 장치와 방법
KR102427824B1 (ko) * 2010-12-08 2022-08-02 엘지전자 주식회사 인트라 예측 방법과 이를 이용한 부호화 장치 및 복호화 장치
US10142630B2 (en) * 2010-12-10 2018-11-27 Texas Instruments Incorporated Mode adaptive intra prediction smoothing in video coding
KR101824241B1 (ko) * 2011-01-11 2018-03-14 에스케이 텔레콤주식회사 인트라 부가정보 부호화/복호화 장치 및 방법
KR20120103517A (ko) 2011-03-10 2012-09-19 한국전자통신연구원 인트라 예측 방법 및 그 장치
WO2012121575A2 (ko) 2011-03-10 2012-09-13 한국전자통신연구원 인트라 예측 방법 및 그 장치
KR101215152B1 (ko) 2011-04-21 2012-12-24 한양대학교 산학협력단 인루프 필터링을 적용한 예측 방법을 이용한 영상 부호화/복호화 방법 및 장치
US9602839B2 (en) * 2011-06-15 2017-03-21 Futurewei Technologies, Inc. Mode dependent intra smoothing filter table mapping methods for non-square prediction units
CN108391135B (zh) * 2011-06-15 2022-07-19 韩国电子通信研究院 可伸缩解码方法/设备、可伸缩编码方法/设备和介质
KR20120140181A (ko) 2011-06-20 2012-12-28 한국전자통신연구원 화면내 예측 블록 경계 필터링을 이용한 부호화/복호화 방법 및 그 장치
EP2740263B1 (en) * 2011-09-16 2019-02-27 HFI Innovation Inc. Method and apparatus for prediction mode and partition mode syntax coding for coding units in hevc
US9693064B2 (en) * 2011-09-30 2017-06-27 Avago Technologies General Ip (Singapore) Pte. Ltd Video coding infrastructure using adaptive prediction complexity reduction
EP2582134A1 (en) * 2011-10-12 2013-04-17 Thomson Licensing Saliency value determination of predictively encoded video streams
GB2561487B (en) 2011-10-18 2019-01-02 Kt Corp Method for encoding image, method for decoding image, image encoder, and image decoder
US10645398B2 (en) 2011-10-25 2020-05-05 Texas Instruments Incorporated Sample-based angular intra-prediction in video coding
US9503750B2 (en) * 2011-11-04 2016-11-22 Futurewei Technologies, Inc. Binarization of prediction residuals for lossless video coding
CN104350752B (zh) * 2012-01-17 2019-07-12 华为技术有限公司 用于高性能视频编码中的无损编码模式的环内滤波的装置
WO2013109867A1 (en) * 2012-01-19 2013-07-25 Futurewei Technologies, Inc. Simplification of mode dependent intra smoothing
WO2013133627A1 (ko) * 2012-03-06 2013-09-12 엘지전자 주식회사 비디오 신호 처리 방법
US9544612B2 (en) * 2012-10-04 2017-01-10 Intel Corporation Prediction parameter inheritance for 3D video coding
US10440377B2 (en) * 2012-10-11 2019-10-08 Intel Corporation Motion estimation for video processing
JP2014131162A (ja) * 2012-12-28 2014-07-10 Nippon Telegr & Teleph Corp <Ntt> イントラ予測符号化方法、イントラ予測復号方法、イントラ予測符号化装置、イントラ予測復号装置、それらのプログラム並びにプログラムを記録した記録媒体
US20140192862A1 (en) * 2013-01-07 2014-07-10 Research In Motion Limited Methods and systems for prediction filtering in video coding
US9426473B2 (en) * 2013-02-01 2016-08-23 Qualcomm Incorporated Mode decision simplification for intra prediction
KR101468078B1 (ko) * 2013-02-06 2014-12-08 성균관대학교산학협력단 화면 내 예측 방법 및 장치
US9615086B2 (en) * 2013-02-06 2017-04-04 Research & Business Foundation Sungkyunkwan University Method and apparatus for intra prediction
US9491460B2 (en) * 2013-03-29 2016-11-08 Qualcomm Incorporated Bandwidth reduction for video coding prediction
KR102366842B1 (ko) 2013-04-08 2022-02-24 돌비 인터네셔널 에이비 Lut를 인코딩하는 방법, lut를 디코딩하는 방법 및 대응하는 장치들
EP3078194B1 (en) * 2014-01-02 2019-09-11 HFI Innovation Inc. Method and apparatus for intra prediction coding with boundary filtering control
JP6528765B2 (ja) * 2014-03-28 2019-06-12 ソニー株式会社 画像復号装置および方法
BR112016013761B1 (pt) 2014-05-23 2023-03-14 Huawei Technologies Co., Ltd Método e aparelho para reconstruir blocos de imagem utilizando predição, e meio de armazenamento legível por computador
US20160105685A1 (en) * 2014-10-08 2016-04-14 Qualcomm Incorporated Boundary filtering and cross-component prediction in video coding
US10148953B2 (en) * 2014-11-10 2018-12-04 Samsung Electronics Co., Ltd. System and method for intra prediction in video coding
US10841593B2 (en) 2015-06-18 2020-11-17 Qualcomm Incorporated Intra prediction and intra mode coding
US11463689B2 (en) 2015-06-18 2022-10-04 Qualcomm Incorporated Intra prediction and intra mode coding
KR102570911B1 (ko) * 2015-07-08 2023-08-24 인터디지털 매디슨 페턴트 홀딩스 에스에이에스 교차 평면 필터링을 이용한 향상된 크로마 코딩
WO2017043786A1 (ko) * 2015-09-10 2017-03-16 엘지전자 주식회사 비디오 코딩 시스템에서 인트라 예측 방법 및 장치
US10136131B2 (en) * 2015-09-11 2018-11-20 Beamr Imaging Ltd. Video coding apparatus and method
EP3363198B1 (en) 2015-11-17 2020-09-16 Huawei Technologies Co., Ltd. Method and apparatus of adaptive filtering of samples for video coding
CN117354536A (zh) * 2016-02-25 2024-01-05 株式会社Kt 用于处理视频信号的方法和设备
US10652575B2 (en) * 2016-09-15 2020-05-12 Qualcomm Incorporated Linear model chroma intra prediction for video coding
EP3522538A4 (en) * 2016-09-30 2020-07-29 LG Electronics Inc. -1- IMAGE PROCESSING METHOD AND DEVICE THEREFOR
EP3545681A1 (en) 2016-12-15 2019-10-02 Huawei Technologies Co., Ltd. Intra sharpening and/or de-ringing filter for video coding based on a bitstream flag
EP3545680A1 (en) 2016-12-15 2019-10-02 Huawei Technologies Co., Ltd. Intra sharpening and/or de-ringing filter for video coding
WO2018174657A1 (ko) * 2017-03-23 2018-09-27 엘지전자 주식회사 영상 코딩 시스템에서 인트라 예측에 따른 영상 디코딩 방법 및 장치
US10225578B2 (en) 2017-05-09 2019-03-05 Google Llc Intra-prediction edge filtering
US10992939B2 (en) * 2017-10-23 2021-04-27 Google Llc Directional intra-prediction coding
EP3410722A1 (en) 2017-05-31 2018-12-05 Thomson Licensing Method and apparatus for low-complexity bi-directional intra prediction in video encoding and decoding
JP6904156B2 (ja) * 2017-08-10 2021-07-14 富士通株式会社 動画像符号化装置、動画像符号化方法、及び動画像符号化プログラム
EP3454556A1 (en) * 2017-09-08 2019-03-13 Thomson Licensing Method and apparatus for video encoding and decoding using pattern-based block filtering
EP3496401A1 (en) * 2017-12-05 2019-06-12 Thomson Licensing Method and apparatus for video encoding and decoding based on block shape
US11277644B2 (en) 2018-07-02 2022-03-15 Qualcomm Incorporated Combining mode dependent intra smoothing (MDIS) with intra interpolation filter switching
US10567752B2 (en) * 2018-07-02 2020-02-18 Tencent America LLC Method and apparatus for intra prediction for non-square blocks in video compression
WO2020013735A1 (en) * 2018-07-11 2020-01-16 Huawei Technologies Co., Ltd. Method and apparatus for aspect-ratio dependent filtering for intra-prediction
US10630979B2 (en) * 2018-07-16 2020-04-21 Tencent America LLC Reference sample padding and filtering for intra prediction in video compression
US10834393B2 (en) * 2018-09-10 2020-11-10 Tencent America LLC Intra interpolation filter for multi-line intra prediction
EP3850840A1 (en) * 2018-09-13 2021-07-21 FRAUNHOFER-GESELLSCHAFT zur Förderung der angewandten Forschung e.V. Affine linear weighted intra predictions
US11303885B2 (en) * 2018-10-25 2022-04-12 Qualcomm Incorporated Wide-angle intra prediction smoothing and interpolation
WO2020085955A1 (en) * 2018-10-26 2020-04-30 Huawei Technologies Co., Ltd. Method and apparatus for reference sample filtering
WO2020140951A1 (en) 2019-01-02 2020-07-09 Beijing Bytedance Network Technology Co., Ltd. Motion vector derivation between color components
CN113261281B (zh) * 2019-01-02 2024-10-15 北京字节跳动网络技术有限公司 交织预测的使用
US10778972B1 (en) 2019-02-27 2020-09-15 Google Llc Adaptive filter intra prediction modes in image/video compression
JP2022530240A (ja) 2019-05-02 2022-06-28 北京字節跳動網絡技術有限公司 複数の参照フィルタを使用するイントラビデオコーディング
US11445174B2 (en) * 2019-05-06 2022-09-13 Tencent America LLC Method and apparatus for video coding
WO2020228761A1 (en) * 2019-05-14 2020-11-19 Beijing Bytedance Network Technology Co., Ltd. Filter selection for intra video coding
CN114424541B (zh) 2019-08-16 2024-05-31 苹果公司 压缩视频及重建压缩视频的系统、方法、及存储介质
US11297316B2 (en) * 2019-12-24 2022-04-05 Tencent America LLC Method and system for adaptive cross-component filtering
CN113766246A (zh) * 2020-06-05 2021-12-07 Oppo广东移动通信有限公司 图像编码方法、图像解码方法及相关装置
CN113965764B (zh) * 2020-07-21 2023-04-07 Oppo广东移动通信有限公司 图像编码方法、图像解码方法及相关装置

Family Cites Families (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE10158658A1 (de) 2001-11-30 2003-06-12 Bosch Gmbh Robert Verfahren zur gerichteten Prädiktion eines Bildblockes
JP4120301B2 (ja) 2002-04-25 2008-07-16 ソニー株式会社 画像処理装置およびその方法
JP2005532725A (ja) 2002-07-09 2005-10-27 ノキア コーポレイション ビデオ符号化における内挿フィルタタイプの選択方法および選択システム
US6795584B2 (en) * 2002-10-03 2004-09-21 Nokia Corporation Context-based adaptive variable length coding for adaptive block transforms
US7227901B2 (en) * 2002-11-21 2007-06-05 Ub Video Inc. Low-complexity deblocking filter
CN100584024C (zh) 2003-01-10 2010-01-20 汤姆森特许公司 为编码图像中的错误掩蔽定义内插滤波器
JP2006157481A (ja) 2004-11-30 2006-06-15 Canon Inc 画像符号化装置及びその方法
KR100657919B1 (ko) 2004-12-13 2006-12-14 삼성전자주식회사 화상 데이터의 공간상 예측 장치 및 방법과 그를 이용한부호화 장치 및 방법, 화상 데이터의 공간상 예측 보상장치 및 방법과 그를 이용한 복호화 장치 및 방법
JP2006229411A (ja) 2005-02-16 2006-08-31 Matsushita Electric Ind Co Ltd 画像復号化装置及び画像復号化方法
US7876833B2 (en) * 2005-04-11 2011-01-25 Sharp Laboratories Of America, Inc. Method and apparatus for adaptive up-scaling for spatially scalable coding
US8548064B2 (en) * 2006-01-05 2013-10-01 Nippon Telegraph And Telephone Corporation Video encoding method and decoding method by using selected parallax for parallax compensation, apparatuses therefor, programs therefor, and storage media for storing the programs
JPWO2009001793A1 (ja) * 2007-06-26 2010-08-26 株式会社東芝 画像符号化と画像復号化の方法及び装置
EP2191652B1 (en) 2007-09-02 2017-02-08 Lg Electronics Inc. A method and an apparatus for processing a video signal
JP2010081368A (ja) 2008-09-26 2010-04-08 Toshiba Corp 画像処理装置、動画像復号装置、動画像符号化装置、画像処理方法、動画像復号方法、及び、動画像符号化方法
KR101590500B1 (ko) * 2008-10-23 2016-02-01 에스케이텔레콤 주식회사 동영상 부호화/복호화 장치, 이를 위한 인트라 예측 방향에기반한 디블록킹 필터링 장치 및 필터링 방법, 및 기록 매체
KR101510108B1 (ko) * 2009-08-17 2015-04-10 삼성전자주식회사 영상의 부호화 방법 및 장치, 그 복호화 방법 및 장치
EP2559239A2 (en) 2010-04-13 2013-02-20 Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. Apparatus for intra predicting a block, apparatus for reconstructing a block of a picture, apparatus for reconstructing a block of a picture by intra prediction
CN102948151B (zh) 2010-06-17 2016-08-03 夏普株式会社 图像滤波装置、解码装置及编码装置
HUE053802T2 (hu) 2010-07-14 2021-07-28 Ntt Docomo Inc Kis komplexitású intra predikció videó kódoláshoz
KR20120012385A (ko) 2010-07-31 2012-02-09 오수미 인트라 예측 부호화 장치
HUE040604T2 (hu) 2010-08-17 2019-03-28 M&K Holdings Inc Berendezés intra predikció mód dekódolására
ES2868133T3 (es) * 2010-09-27 2021-10-21 Lg Electronics Inc Método para partición de bloque y dispositivo de decodificación
JP2012138884A (ja) 2010-12-10 2012-07-19 Sony Corp 符号化装置および符号化方法、並びに復号装置および復号方法
WO2012096150A1 (ja) 2011-01-12 2012-07-19 三菱電機株式会社 動画像符号化装置、動画像復号装置、動画像符号化方法及び動画像復号方法

Also Published As

Publication number Publication date
DK2622858T3 (en) 2018-01-15
BR112013007563B1 (pt) 2022-03-03
IL225331A0 (en) 2013-06-27
EP2622858A1 (en) 2013-08-07
IL225331A (en) 2017-01-31
ES2656494T3 (es) 2018-02-27
SG189036A1 (en) 2013-05-31
KR101626734B1 (ko) 2016-06-01
PL2622858T3 (pl) 2018-05-30
US20120082224A1 (en) 2012-04-05
AU2011308653B2 (en) 2015-11-19
KR20130063030A (ko) 2013-06-13
HK1182249A1 (zh) 2013-11-22
RU2543552C2 (ru) 2015-03-10
CN103141100A (zh) 2013-06-05
HUE035458T2 (en) 2018-05-02
SI2622858T1 (en) 2018-02-28
CA2812307C (en) 2016-06-28
JP2013543315A (ja) 2013-11-28
CN103141100B (zh) 2016-08-24
BR112013007563A2 (pt) 2016-08-02
RU2013120332A (ru) 2014-11-20
US9008175B2 (en) 2015-04-14
PT2622858T (pt) 2018-02-05
WO2012044886A1 (en) 2012-04-05
EP2622858B1 (en) 2017-11-01
AU2011308653A1 (en) 2013-05-02
CA2812307A1 (en) 2012-04-05
KR20150021113A (ko) 2015-02-27

Similar Documents

Publication Publication Date Title
JP5587508B2 (ja) ビデオコード化のためのイントラ平滑化フィルタ
US12075037B2 (en) Predicting filter coefficients from fixed filters for video coding
US10390044B2 (en) Signaling selected directional transform for video coding
JP5960309B2 (ja) マッピングされた変換と走査モードとを使用するビデオコード化
KR101632776B1 (ko) 비디오 코딩에 대한 구문 엘리먼트들의 공동 코딩
JP2017508346A (ja) ビデオコーディングのための適応的な動きベクトル分解シグナリング
JP2013539940A (ja) ビデオコーディングのためのイントラ予測モード選択の指示
KR20140016983A (ko) 비디오 코딩을 위한 런-모드 기반 계수 코딩
CN113891076B (en) Method and apparatus for filtering decoded blocks of video data and storage medium

Legal Events

Date Code Title Description
A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20140225

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20140526

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20140624

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20140723

R150 Certificate of patent or registration of utility model

Ref document number: 5587508

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250