JP2014506067A - Cabacを使用したビデオコーディングのためのイントラ予測モード選択の指示 - Google Patents

Cabacを使用したビデオコーディングのためのイントラ予測モード選択の指示 Download PDF

Info

Publication number
JP2014506067A
JP2014506067A JP2013548543A JP2013548543A JP2014506067A JP 2014506067 A JP2014506067 A JP 2014506067A JP 2013548543 A JP2013548543 A JP 2013548543A JP 2013548543 A JP2013548543 A JP 2013548543A JP 2014506067 A JP2014506067 A JP 2014506067A
Authority
JP
Japan
Prior art keywords
intra prediction
prediction mode
index
mode
codeword
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.)
Granted
Application number
JP2013548543A
Other languages
English (en)
Other versions
JP5731013B2 (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 JP2014506067A publication Critical patent/JP2014506067A/ja
Application granted granted Critical
Publication of JP5731013B2 publication Critical patent/JP5731013B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

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/13Adaptive entropy coding, e.g. adaptive variable length coding [AVLC] or context adaptive binary arithmetic coding [CABAC]
    • 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/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/136Incoming video signal characteristics or properties
    • H04N19/137Motion inside a coding unit, e.g. average field, frame or block difference
    • 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/136Incoming video signal characteristics or properties
    • H04N19/137Motion inside a coding unit, e.g. average field, frame or block difference
    • H04N19/139Analysis of motion vectors, e.g. their magnitude, direction, variance or reliability
    • 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
    • H04N19/159Prediction type, e.g. intra-frame, inter-frame or bidirectional frame prediction
    • 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/189Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the adaptation method, adaptation tool or adaptation type used for the adaptive coding
    • H04N19/196Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the adaptation method, adaptation tool or adaptation type used for the adaptive coding being specially adapted for the computation of encoding parameters, e.g. by averaging previously computed encoding parameters
    • 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
    • H04N19/463Embedding additional information in the video signal during the compression process by compressing encoding parameters before transmission

Landscapes

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

Abstract

ビデオデータのブロックについて、ビデオエンコーダは、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを使用して、ビデオデコーダへ、変更されたイントラ予測モードインデックスにマッピングされたコードワードを使用して選択されたイントラ予測モードをシグナリングすることができる。ビデオデコーダは、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行して、ビデオエンコーダによってシグナリングされたコードワードを決定し、コードワードに対応する変更されたイントラ予測モードインデックスを決定し、コンテキストに基づいて最も可能性の高いモードを決定し、変更されたイントラ予測モードインデックスを最も可能性の高いモードのモードインデックスと比較することによって、変更されたイントラ予測モードインデックスをイントラ予測モードインデックスにマッピングし、イントラ予測モードインデックスに基づいてビデオデータのブロックを符号化するために使用される選択されたイントラ予測モードを決定することができる。

Description

優先権の主張
本出願は、各々の内容全体が参照により本明細書に組み込まれる、2011年1月6日に出願された米国仮出願第61/430,520号、2011年2月24日に出願された米国仮出願第61/446,402号、および2011年3月2日に出願された米国仮出願第61/448,623号の利益を主張する。
本開示は、ビデオコーディングに関し、より詳細には、コード化されたビデオデータについてのコード化特性のシグナリングに関する。
[0003]デジタルビデオ機能は、デジタルテレビジョン、デジタルダイレクトブロードキャストシステム、ワイヤレスブロードキャストシステム、携帯情報端末(PDA)、ラップトップまたはデスクトップコンピュータ、デジタルカメラ、デジタル記録デバイス、デジタルメディアプレーヤ、ビデオゲームデバイス、ビデオゲームコンソール、セルラー電話または衛星無線電話、ビデオ遠隔会議デバイスなどを含む、広範囲にわたるデバイスに組み込まれ得る。デジタルビデオデバイスは、デジタルビデオ情報をより効率的に送信および受信するために、MPEG−2、MPEG−4、ITU−T H.263またはITU−T H.264/MPEG−4、Part 10、Advanced Video Coding(AVC)によって定義された規格、およびそのような規格の拡張に記載されているビデオ圧縮技法など、ビデオ圧縮技法を実装する。
[0004]ビデオ圧縮技法は、ビデオシーケンスに固有の冗長性を低減または除去するために空間的予測および/または時間的予測を実行する。ブロックベースのビデオコーディングの場合、ビデオフレームまたはスライスはビデオブロックに区分され得る。各ビデオブロックはさらに区分され得る。イントラコード化(I)フレームまたはスライス中のビデオブロックは、隣接ビデオブロックに対する空間的予測を使用して符号化される。インターコード化(PまたはB)フレームまたはスライス中のビデオブロックは、同じフレームまたはスライス中の隣接マクロブロックまたはコーディングユニットに関する空間的予測、あるいは他の参照フレームに関する時間的予測を使用し得る。
[0005]概して、本開示では、コード化されたビデオデータについてのコード化特性をシグナリングするための技法について説明する。本開示の技法は、ビデオデータのブロックを符号化するために使用されるイントラ予測モードのシグナリングの効率を向上させることができる。本開示の技法は、コードワードを使用したビデオデータのブロックについての符号化されたビットストリームイントラ予測モードにおけるシグナリングを含む。本技法はさらに、コンテキスト適応型バイナリ算術コーディング(CABAC:context adaptive binary arithmetic coding)プロセスを使用してコードワードをコード化することをさらに含む。このようにして、本開示の技法を使用するとき、コード化されたビットストリームについての相対的なビット節約があり得る。
[0006]一例では、ビデオデータを復号する方法は、現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定することと、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択することと、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、CABACプロセスを実行して、受信されたコードワードを決定することと、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたイントラ予測モードインデックスのうちの1つを決定することと、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択することと、選択されたイントラ予測モードは、変更されたイントラ予測モードインデックスのうちの決定された1つに対応し、選択されたイントラ予測モードを使用して、現在のブロックを復号することと、を含む。
[0007]一例では、ビデオデータを復号するための装置は、ビデオデコーダを含み、このビデオデコーダは、現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択するように構成され、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、ビデオデコーダはさらに、CABACプロセスを実行して、受信されたコードワードを決定し、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたイントラ予測モードインデックスのうちの1つを決定し、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択するように構成され、選択されたイントラ予測モードは、変更されたイントラ予測モードインデックスのうちの決定された1つに対応し、ビデオデコーダはさらに、選択されたイントラ予測モードを使用して、現在のブロックを復号するように構成される。
[0008]一例では、ビデオデータを符号化する方法は、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定することと、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択することと、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化することと、コードワードのテーブルを使用してイントラ予測モードのうちの1つに対応する変更されたイントラ予測モードインデックスのうちの1つを決定することと、CABACプロセスを実行することによって、選択されたコードワードのテーブルからコードワードを符号化することと、を含み、コードワードは変更されたイントラ予測モードインデックスのうちの1つに対応する。
[0009]一例では、ビデオデータを符号化するための装置は、ビデオエンコーダを含み、このビデオデコーダは、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択するように構成され、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、ビデオデコーダはさらに、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化し、コードワードのテーブルを使用してイントラ予測モードのうちの1つに対応する変更されたイントラ予測モードインデックスのうちの1つを決定し、CABACプロセスを実行することによって、選択されたコードワードのテーブルからコードワードを符号化するように構成され、コードワードは変更されたイントラ予測モードインデックスのうちの1つに対応する。
[0010]一例では、ビデオを復号するための装置は、現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定するための手段と、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択するための手段と、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、受信されたコードワードを決定するために、CABACプロセスを実行するための手段と、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたイントラ予測モードインデックスのうちの1つを決定するための手段と、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択するための手段と、選択されたイントラ予測モードは、変更されたイントラ予測モードインデックスのうちの決定された1つに対応し、選択されたイントラ予測モードを使用して、現在のブロックを復号するための手段と、を含む。
[0011]一例では、ビデオデータを符号化するための装置は、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定するための手段と、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択するための手段と、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化するための手段と、コードワードのテーブルを使用してイントラ予測モードのうちの1つに対応する変更されたイントラ予測モードインデックスのうちの1つを決定するための手段と、CABACプロセスを実行することによって、選択されたコードワードのテーブルからコードワードを符号化するための手段と、を含み、コードワードは変更されたイントラ予測モードインデックスのうちの1つに対応する。
[0012]一例では、実行されると、1つまたは複数のプロセッサに、現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定させ、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択させ、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、受信されたコードワードを決定するために、CABACプロセスを実行させ、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたイントラ予測モードインデックスのうちの1つを決定させ、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択させ、選択されたイントラ予測モードは、変更されたイントラ予測モードインデックスのうちの決定された1つに対応し、選択されたイントラ予測モードを使用して、現在のブロックを復号させる命令を記憶するコンピュータ可読記憶媒体。
[0013]一例では、実行されると、1つまたは複数のプロセッサに、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定させ、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択させ、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化させ、コードワードのテーブルを使用してイントラ予測モードのうちの1つに対応する変更されたイントラ予測モードインデックスのうちの1つを決定させ、CABACプロセスを実行することによって、選択されたコードワードのテーブルからコードワードを符号化させ、コードワードは変更されたイントラ予測モードインデックスのうちの1つに対応する、命令を記憶するコンピュータ可読記憶媒体。
[0014]一例では、ビデオデータを復号する方法は、現在のブロックのコンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定することと、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択することと、コードワードのテーブルは、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスはイントラ予測モードにマッピングされ、受信されたコードワードを決定するために、CABACプロセスを実行することと、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたコードワードインデックスを決定することと、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択することと、選択されたイントラ予測モードは、変更されたコードワードインデックス、第1の最も可能性の高いイントラ予測モード、および第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、選択されたイントラ予測モードを使用して、現在のブロックを復号することと、を含む。
[0015]一例では、ビデオデータを復号するための装置は、ビデオデコーダを含み、このビデオデコーダは、現在のブロックのコンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択するように構成され、コードワードのテーブルは、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスはイントラ予測モードにマッピングされる。ビデオデコーダはさらに、受信されたコードワードを決定するために、CABACプロセスを実行し、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたコードワードインデックスを決定し、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択するように構成され、選択されたイントラ予測モードは、変更されたコードワードインデックス、第1の最も可能性の高いイントラ予測モード、および第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、ビデオデコーダはさらに、選択されたイントラ予測モードを使用して、現在のブロックを復号するように構成される。
[0016]一例では、ビデオを復号するための装置は、現在のブロックのコンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定するための手段と、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択するための手段と、コードワードのテーブルは、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスはイントラ予測モードにマッピングされ、受信されたコードワードを決定するために、CABACプロセスを実行するための手段と、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたコードワードインデックスを決定するための手段と、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択するための手段と、選択されたイントラ予測モードは、変更されたコードワードインデックス、第1の最も可能性の高いイントラ予測モード、および第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、選択されたイントラ予測モードを使用して、現在のブロックを復号するための手段と、を含む。
[0017]一例では、実行されると、1つまたは複数のプロセッサに、現在のブロックのコンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定させ、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択させ、コードワードのテーブルは、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスはイントラ予測モードにマッピングされ、受信されたコードワードを決定するために、CABACプロセスを実行させ、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたコードワードインデックスを決定させ、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択させ、選択されたイントラ予測モードは、変更されたコードワードインデックス、第1の最も可能性の高いイントラ予測モード、および第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、選択されたイントラ予測モードを使用して、現在のブロックを復号させる命令を記憶するコンピュータ可読記憶媒体。
[0018]一例では、ビデオデータを符号化する方法は、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定することと、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択することと、コードワードのテーブルは、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスはイントラ予測モードにマッピングされ、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化することと、現在のブロックを符号化するために使用されるイントラ予測モードのうちの1つのコードワードインデックス、第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定することと、CABACプロセスを実行することによって、選択されたコードワードのテーブルからコードワードを符号化することと、を含み、コードワードは変更されたイントラ予測モードインデックスのうちの1つに対応する。
[0019]一例では、ビデオデータを符号化するための装置は、ビデオエンコーダを含み、このビデオエンコーダは、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択するように構成され、コードワードのテーブルは、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスはイントラ予測モードにマッピングされ、ビデオエンコーダはさらに、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化し、現在のブロックを符号化するために使用されるイントラ予測モードのうちの1つのコードワードインデックス、第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定し、CABACプロセスを実行することによって、選択されたコードワードのテーブルからコードワードを符号化するように構成され、コードワードが変更されたイントラ予測モードインデックスのうちの1つに対応する。
[0020]一例では、ビデオを符号化するための装置は、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定するための手段と、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択するための手段と、コードワードのテーブルは、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスはイントラ予測モードにマッピングされ、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化するための手段と、現在のブロックを符号化するために使用されるイントラ予測モードのうちの1つのコードワードインデックス、第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定するための手段と、CABACプロセスを実行することによって、選択されたコードワードのテーブルからコードワードを符号化するための手段と、を含み、コードワードは変更されたイントラ予測モードインデックスのうちの1つに対応する。
[0021]一例では、実行されると、1つまたは複数のプロセッサに、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定させ、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択させ、コードワードのテーブルは、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスはイントラ予測モードにマッピングされ、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化させ、現在のブロックを符号化するために使用されるイントラ予測モードのうちの1つのコードワードインデックス、第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定させ、CABACプロセスを実行することによって、選択されたコードワードのテーブルからコードワードを符号化させる命令を記憶し、コードワードは変更されたイントラ予測モードインデックスのうちの1つに対応する、コンピュータ可読記憶媒体。
[0022]1つまたは複数の例の詳細は、添付の図面および以下の説明に記載されている。他の特徴、目的、および利点は、その説明および図面、ならびに特許請求の範囲から明らかになろう。
ビデオデータのブロックについてのイントラ予測モードを表すシンタックスデータをコード化するための技法を利用し得る一例のビデオ符号化および復号システムを示すブロック図。 イントラ予測モードを示す情報をコード化するための技法を実装し得るビデオエンコーダの一例を示すブロック図。 イントラ予測モードおよび対応するモードインデックスの一例を示す図。 符号化ビデオシーケンスを復号するビデオデコーダの一例を示すブロック図。 本開示で説明する技法に従って使用され得るコンテキストベースの適応バイナリ算術符号化ユニットの一例を示すブロック図。 本開示で説明する技法に従って使用され得るコンテキストベースの適応バイナリ算術復号ユニットの一例を示すブロック図。 ビデオデータのブロックをイントラ予測符号化するための一例の方法を示すフローチャート。 コード化ブロックについてのイントラ予測モードを示すコードワードを選択するための例示的な方法を示すフローチャート。 コード化ブロックについてのイントラ予測モードを示すコードワードを選択するための例示的な方法を示すフローチャート。 ビデオデータのブロックをイントラ予測復号するための例示的な方法を示すフローチャート。 コード化ブロックについてのイントラ予測モードを示す受信されたコードワードを使用して、ブロックについてのイントラ予測モードを決定するための例示的な方法を示すフローチャート。 コード化ブロックについてのイントラ予測モードを示す受信されたコードワードを使用して、ブロックについてのイントラ予測モードを決定するための例示的な方法を示すフローチャート。 イントラ予測モードインデックステーブルと変更されたイントラ予測モードインデックステーブルとコンテキストデータとの間の関係を示す構成データの組の一例を示す概念図。
[0034]一般に、本開示は、コード化されたビデオデータについてのコード化特性をシグナリングするための技法について説明し、より詳細には、本開示は、コンテキストベースのバイナリ算術コーディング(CABAC)プロセスを使用して、ビデオデコーダにイントラ予測モードをシグナリングすることについて説明する。本開示の技法は、ビデオデータのブロックをイントラ符号化するために使用されるイントラ予測モードのシグナリングの効率を向上することができる。ビデオエンコーダは、たとえば、様々なイントラ予測モードを使用して符号化されるブロックの符号化コンテキストに基づいて、イントラ予測モードのインデックスを示す構成データを含み得る。符号化コンテキストは、たとえば、隣接する、前にコード化されたブロックについての符号化モードおよび/またはブロックサイズを含み得る。
[0035]構成データは、コンテキストごとに1つの最も可能性の高いイントラ予測モードを定義する、またはコンテキストごとに2つ以上の最も可能性の高いイントラ予測モードを定義するために使用され得る。これらの最も可能性の高いイントラ予測モードは、本開示では、時として、単に最も可能性の高いモードと呼ばれ得る。構成データは、所与のコンテキストにおいて最も可能性の高いモード以外のモード(複数可)についてのイントラ予測モードを記述するシンタックスデータの符号化に使用するために、マッピングテーブルを定義することもできる。特に、マッピングテーブルは、コードワードに対するインデックスのマッピングを含むことができる。以下でより詳細に説明するように、マッピングテーブルは、コードワードに対して変更されたイントラ予測モードインデックスをマッピングすることができる、または次いで変更されたコードワードインデックスに調整されるコードワードインデックスに対してイントラ予測モードインデックスをマッピングすることができる。
[0036]したがって、ビデオエンコーダは、あるブロックがイントラ予測モード符号化される符号化コンテキストを決定するように構成することができる。符号化コンテキストは、最も可能性の高いイントラ予測モード、ならびに他のイントラ予測モードの可能性に関連し得る。現在のブロックの符号化に使用するために、最も可能性の高いイントラ予測モードが選択されると、ビデオエンコーダは、ブロックが生じるコンテキストについて、最も可能性の高いモードで、ブロックが符号化されることを示すために、1ビットのコードワード(たとえば「1」)を選択することができる。2つ以上の最も可能性の高いイントラ予測モードが使用される例では、第1のビットは、現在のブロックの符号化に使用するために、最も可能性の高いイントラ予測モードのうちの1つが選択されるかどうかを示すことができ、最も可能性の高いイントラ予測のうちの1つが使用される場合、最も可能性の高いイントラ予測モードのうちどれが選択されるかを第2のビット(または一連のビット)が示し得る。時として、本開示全体にわたって、この第1のビットと第2のビットとの組合せは、それ自体、コードワードと呼ばれることがあり、コードワードの第1のビットは、選択されたイントラ予測モードが最も可能性の高いイントラ予測モードのうちの1つであることをシグナリングし、第2のビット(または一連のビット)は、最も可能性の高いイントラ予測モードのうちのどれかを識別する。したがって、本開示の技法によれば、選択されたモードが最も可能性の高いモードであるかどうか、および選択されたモードがどの最も可能性の高いモードであるかを示すコードワードは、本開示で説明するように、CABACプロセスを使用してコード化することができる。さらに、いくつかの例では、非最も可能性の高いモードを示すコードワードとともに、最も可能性の高いモードをシグナリングするために使用されるビットが一緒にコードワードとして扱われ、本開示で説明するように、CABACプロセスを使用してコード化され得る。
[0037]符号化コンテキストに基づいて、他のイントラ予測モード(すなわち最も可能性の高いイントラ予測モード(複数可)以外のイントラ予測モード)の各々に、変更されたインデックス値を割り当てることもできる。その上、符号化コンテキストは、イントラ予測モードのインデックスに関連するインデックス値によってインデックスを付けられる1組のコードワードを有するテーブルに、さらに対応し得る。特に、上記で説明したように、最も可能性の高いイントラ予測モード(複数可)のインデックス値に、最も可能性の高いイントラ予測モードが選択されたことを表すシングルビットの(または場合によってはより長い)コードワード以外の、別のコードワードを割り当てる必要はない。コードワードを残りの各イントラ予測モードにマッピングするために、最も可能性が高いモード(複数可)に対し最初に割り振られたものを除外するために、残りの各イントラ予測モードのインデックスが最初に変更され得る。したがって、変更されたイントラ予測モードインデックスは、最も可能性の高いモードについてのモードインデックス未満であるイントラ予測モードインデックスに等しくなり得る。一方、1つの最も可能性の高いモードを使用するとき、変更されたイントラ予測モードインデックスは、最も可能性の高いモードについてのインデックスよりも大きいイントラ予測モードインデックスについてのイントラ予測モードインデックスより1小さくなり得る。このようにして、イントラ予測モードよりも1つ少ないコードワードがあり得、符号化コンテキストに基づいて、コードワードは、イントラ予測モードにマッピングされ得る。2つ以上の最も可能性の高いイントラ予測モードを使用するとき、コードワードテーブルに、イントラ予測モードよりも2以上少ないコードワードがあり得、コードワードは、同様に、符号化コンテキストに基づいて、イントラ予測モードにマッピングされ得る。コードワードは、CABACプロセスを使用してコード化することができる。
[0038]ビデオデコーダは、たとえば、符号化されたブロックについてのイントラ予測モードを決定するとき、類似の技法を実行するように、同様に構成され得る。本開示の技法によれば、ビデオデコーダは、符号化されたブロックのデータ、ならびに符号化されたブロックの復号に使用するためのイントラ予測モードを示すコードワードを受信することができる。ビデオデコーダは、コードワードを受信し、一般に、ビデオエンコーダによって実行されるCABACプロセスの逆であるCABACプロセスを実行することによって、コードワードを復号することができる。ビデオデコーダは、ビデオエンコーダと同様の方法で、ブロックのコンテキストを決定することができる。コンテキストに基づいて、ビデオデコーダは、ブロックについての1つまたは複数の最も可能性の高いイントラ予測モードを決定することができる。1つの最も可能性の高いイントラ予測モードを使用するとき、最も可能性の高いモードが選択されるかどうかを決定するために、シングルビットが復号され得る。最も可能性の高いモードが選択されることをシングルビットが示す場合、ビデオデコーダは、最も可能性の高いイントラ予測モードを使用してブロックを復号することができる。そうでない場合、ビデオデコーダは、受信されたコードワードにマッピングされる変更されたイントラ予測モードインデックスを参照し得る。変更されたイントラ予測モードインデックスが、最も可能性の高いイントラ予測モードのモードインデックス以上である場合、ビデオデコーダは、変更されたイントラ予測モードインデックスよりも1大きいモードインデックスにマッピングされるイントラ予測モードを使用してブロックを復号し得る。変更されたイントラ予測モードインデックスが、最も可能性の高いイントラ予測モードのモードインデックス未満である場合、ビデオデコーダは、変更されたイントラ予測モードインデックスに等しいモードインデックスにマッピングされるイントラ予測モードを使用してブロックを復号し得る。
[0039]同様に、2つの最も可能性の高いイントラ予測符号化モードを使用するとき、選択されたイントラ予測モードが最も可能性の高いイントラ予測モードのうちの1つであることを第1のビットまたは一連のビットが示す場合、ビデオデコーダは、第2のビットによって識別された最も可能性の高いイントラ予測モードを使用してブロックを復号することができる。そうでない場合、ビデオデコーダは、受信されたコードワードにマッピングされる変更されたイントラ予測モードインデックスを参照し得る。変更されたイントラ予測モードインデックスが、第1の最も可能性の高いイントラ予測モードのモードインデックス未満である場合、ビデオデコーダは、変更されたイントラ予測モードインデックスに等しいモードインデックスにマッピングされるイントラ予測モードを使用してブロックを復号し得る。そうではなく、変更されたイントラ予測モードインデックス+1が、第2の最も可能性の高いイントラ予測モードのモードインデックス未満である場合、ビデオデコーダは、変更されたイントラ予測モードインデックスよりも1大きいモードインデックスにマッピングされるイントラ予測モードを使用してブロックを復号し得る。そうでない場合、ビデオデコーダは、変更されたイントラ予測モードインデックスよりも2大きいモードインデックスにマッピングされるイントラ予測モードを使用してブロックを復号し得るなど、以下同様である。
[0040]「第1の最も可能性の高い」および「第2の最も可能性の高い」という句は、本開示では、一般に、2つの別々の最も可能性の高いイントラ予測モードを指すために使用され、2つのイントラ予測モードの相対的な見込みを暗示するものではない。しかしながら、例によって後で説明するように、一般に、本開示での説明のために、第1の最も可能性の高いイントラ予測モードが第2の最も可能性の高いイントラ予測モードよりも低い対応するモードインデックス値を有すると仮定され得る。したがって、変更されたイントラ予測モードインデックス値が第1の最も可能性の高いモードのモードインデックス未満であると言われた場合、変更されたイントラ予測モードインデックス値も、第2の最も可能性の高いイントラ予測モード、第3の最も可能性の高いイントラ予測モードなどのモードインデックス未満であると仮定することができる。
[0041]本開示の技法は、3つ以上の最も可能性の高いイントラ予測モードを利用する実装に拡張することができる。たとえば、最も可能性の高いイントラ予測モードがN個あると仮定すると、第1のビットまたは一連のビットは、選択されたイントラ予測モードがN個の最も可能性の高いイントラ予測モードのうちの1つであるかどうかを示し得る。選択されたイントラ予測モードがN個の最も可能性の高いイントラ予測モードのうちの1つである場合、第2の一連のビットは、N個の最も可能性の高いイントラ予測モードのうちどれが選択されたイントラ予測モードであるかを識別することができる。たとえば、3つの最も可能性の高いモードを使用して、次のように、2ビットを使用して、選択されたイントラ予測モードが最も可能性の高いモードのうちの1つであるかどうかをシグナリングすることができる。第1の最も可能性の高いモードが使用されることを示すには、「00」をシグナリングし、第2の最も可能性の高いモードが使用されることを示すには、「01」をシグナリングし、第3の最も可能性の高いモードが使用されることを示すには、「10」をシグナリングし、3つの最も考えるモードのうちのどれも使用されないことを示すには、「11」をシグナリングする。最も可能性の高いモードのうちのどれも使用されない場合、追加のコードワードを使用して、選択さされたイントラ予測モードをシグナリングすることができる。
[0042]いくつかの例では、最も可能性の高いイントラ予測モードは、1つまたは複数のグループでシグナリングされ得、この場合、第1のビットまたは一連のビットは、選択された最も可能性の高いイントラ予測モードが第1のグループからであるかどうかをシグナリングする。選択されたイントラ予測モードが第1のグループからではない場合、後続のビットは、それが第2のグループなどからのものであるかどうかをシグナリングすることができる。
[0043]たとえば、5つの最も可能性の高いモードが使用される場合、第1のビットまたは一連のビットは、選択されたイントラ予測モードが2つの最も可能性の高いイントラ予測モードの第1のグループからのものであるかどうかをシグナリングし得る。選択されたモードが2つのうちの1つである場合、第2のビットは、2つのうちのどちらが選択されたモードであるかを識別し得る。選択されたモードが2つのうちの1つではない場合、ビットの第2グループは、選択されたモードを識別し得る。たとえば、ビットの第2グループが2ビットを含む場合、第1のビットの組合せ(たとえば00)は、選択されたモードが第3の最も可能性の高いモードであることを示し得、第2のビットの組合せ(たとえば01)は、選択されたモードが第4の最も可能性の高いモードであることを示し得、第3のビットの組合せ(たとえば10)は、選択されたモードが第5の最も可能性の高いモードであることを示し得る。選択されたモードが5つの最も可能性の高いイントラ予測モードのうちの1つである場合、デコーダは、最も可能性の高いモードを使用してブロックを復号することができる。第4のビットの組合せ(たとえば11)は、選択されたモードが5つの最も可能性の高いモードのうちの1つでないことを示し得、その場合、本開示で説明する技法に従って、第4のビットの組合せの後に、選択されたモードを識別する後続のビットが続き得る。
[0044]選択されたモードが最も可能性の高いモードではない例では、ビデオデコーダは、受信されたコードワードにマッピングされる変更されたイントラ予測モードインデックスを参照し得る。例として、第1の最も可能性の高いイントラ予測モードが第2の最も可能性の高いイントラ予測モードよりも低い対応するモードインデックス値を有する、第2が第3よりも低いインデックスを有するなどと仮定することができる。本開示の技法によれば、変更されたイントラ予測モードインデックスが、第1の最も可能性の高いイントラ予測モードのモードインデックス未満である場合、ビデオデコーダは、変更されたイントラ予測モードインデックスに等しいモードインデックスにマッピングされるイントラ予測モードを使用してブロックを復号し得る。そうではなく、変更されたイントラ予測モードインデックス+1が、第2の最も可能性の高いイントラ予測モードのモードインデックス未満である場合、ビデオデコーダは、変更されたイントラ予測モードインデックスよりも1大きいモードインデックスにマッピングされるイントラ予測モードを使用してブロックを復号し得る。そうではなく、変更されたイントラ予測モードインデックス+2が、第3の最も可能性の高いイントラ予測モードのモードインデックス未満である場合、ビデオデコーダは、変更されたイントラ予測モードインデックスよりも2大きいモードインデックスにマッピングされるイントラ予測モードを使用してブロックを復号し得るなど、以下同様である。以下でさらに詳細に説明するように、変更されたイントラ予測モードインデックスが最も可能性の高いモードのエントリを含まない場合があり、そのために、イントラ予測モードインデックスが、最も可能性の高いモードのモードインデックスに応じて、変更されたイントラ予測モードインデックス+1、変更されたイントラ予測モードインデックス+2などに、マッピングされ得る。
[0045]図1は、ビデオデータのブロックについてのイントラ予測モードを表すシンタックスデータをコード化するための技法を利用し得る例示的なビデオ符号化および復号システム10を示すブロック図である。図1に示すように、システム10は、通信チャネル16を介して符号化ビデオを宛先デバイス14に送信するソースデバイス12を含む。ソースデバイス12および宛先デバイス14は、広範囲のデバイスのいずれかを備えることができる。場合によっては、ソースデバイス12および宛先デバイス14は、いわゆるセルラー電話または衛星無線電話のワイヤレスハンドセットなどのワイヤレス通信デバイス、または通信チャネル16を介してビデオ情報を通信することができ、その場合、通信チャネル16がワイヤレスである任意のワイヤレスデバイスを備え得る。
[0046]ただし、ビデオデータのブロックについてのイントラ予測モードを表すシンタックスデータのコード化に関係する本開示の技法は、必ずしもワイヤレスアプリケーションまたは設定に限定されるとは限らない。たとえば、これらの技法は、オーバージエアテレビジョン放送、ケーブルテレビジョン送信、衛星テレビジョン送信、インターネットビデオ送信、記憶媒体上に符号化される符号化デジタルビデオ、または他のシナリオに適用し得る。したがって、通信チャネル16は、符号化ビデオデータの送信に好適なワイヤレスまたはワイヤード媒体の任意の組合せを備え得る。その上、通信チャネル16は、ビデオ符号化デバイスがビデオ復号デバイスにデータを送信し得る多くの方法のうちのただ1つを表すためのものである。たとえば、システム10の他の構成では、ソースデバイス12は、宛先デバイス14による復号のために符号化ビデオを生成し、必要に応じて、符号化ビデオが宛先デバイス14によってアクセスできるように、記憶媒体またはファイルサーバ上に符号化ビデオを記憶し得る。
[0047]図1の例では、ソースデバイス12は、ビデオソース18と、ビデオエンコーダ20と、変調器/復調器(モデム)22と、送信機24とを含む。宛先デバイス14は、受信機26と、モデム28と、ビデオデコーダ30と、ディスプレイデバイス32とを含む。本開示によれば、ソースデバイス12のビデオエンコーダ20は、ビデオデータのブロックについてのイントラ予測モードを表すシンタックスデータをコード化するための技法を適用するように構成され得る。他の例では、ソースデバイスおよび宛先デバイスは他の構成要素または構成を含み得る。たとえば、ソースデバイス12は、外部カメラなどの外部ビデオソース18からビデオデータを受信し得る。同様に、宛先デバイス14は、一体型ディスプレイデバイスを含むのではなく、外部ディスプレイデバイスとインターフェースし得る。
[0048]図1の図示のシステム10は一例にすぎない。ビデオデータのブロックについてのイントラ予測モードを表すシンタックスデータのコード化のための技法は、任意のデジタルビデオ符号化および/または復号デバイスによって実行され得る。概して、本開示の技法はビデオ符号化デバイスによって実行されるが、本技法は、一般に「コーデック」と呼ばれるビデオエンコーダ/デコーダによっても実行され得る。その上、本開示の技法はまた、ビデオプリプロセッサによって実行され得る。ソースデバイス12および宛先デバイス14は、ソースデバイス12が宛先デバイス14に送信するためのコード化されたビデオデータを発生するような、コーディングデバイスの例にすぎない。いくつかの例では、デバイス12、14の各々がビデオ符号化構成要素および復号構成要素を含むので、デバイス12、14は、実質的に対称的に動作し得る。したがって、システム10は、たとえば、ビデオストリーミング、ビデオ再生、ビデオブロードキャストまたはビデオ電話通信のためのビデオデバイス12とビデオデバイス14との間の一方向または双方向のビデオ送信をサポートすることができる。
[0049]ソースデバイス12のビデオソース18は、ビデオカメラなどのビデオキャプチャデバイス、以前にキャプチャされたビデオを含んでいるビデオアーカイブ、および/またはビデオコンテンツプロバイダからのビデオフィードを含み得る。さらなる代替として、ビデオソース18は、ソースビデオとしてのコンピュータグラフィックスベースのデータ、またはライブビデオとアーカイブビデオとコンピュータ生成ビデオとの組合せを生成し得る。場合によっては、ビデオソース18がビデオカメラである場合、ソースデバイス12および宛先デバイス14は、いわゆるカメラ付き携帯電話またはビデオ電話を形成することができる。ただし、上述のように、本開示で説明する技法は、一般にビデオコーディングに適用可能であり、ワイヤレスおよび/またはワイヤードアプリケーションに適用可能であり得る。各場合において、キャプチャされたビデオ、以前にキャプチャされたビデオまたはコンピュータ生成ビデオは、ビデオエンコーダ20によって符号化され得る。次いで、符号化ビデオ情報は、通信規格に従ってモデム22によって変調され、送信機24を介して宛先デバイス14に送信され得る。モデム22は、信号変調のために設計された様々なミキサ、フィルタ、増幅器または他の構成要素を含むことができる。送信機24は、増幅器、フィルタ、および1つまたは複数のアンテナを含む、データを送信するために設計された回路を含むことができる。
[0050]宛先デバイス14の受信機26はチャネル16を介して情報を受信し、モデム28は情報を復調する。この場合も、ビデオ符号化プロセスは、ビデオデータのブロックについてのイントラ予測モードを表すシンタックスデータをコード化するために、本明細書で説明する技法のうちの1つまたは複数を実施することができる。チャネル16を介して通信される情報は、ビデオエンコーダ20によって定義され、またビデオデコーダ30によって使用される、マクロブロックおよび他のコード化ユニット、たとえば、GOPの特性および/または処理を記述するシンタックス要素を含む、シンタックス情報を含み得る。ディスプレイデバイス32は、復号されたビデオデータをユーザに対して表示し、陰極線管(CRT)、液晶ディスプレイ(LCD)、プラズマディスプレイ、有機発光ダイオード(OLED)ディスプレイ、または別のタイプのディスプレイデバイスなど、様々なディスプレイデバイスのいずれかを備え得る。
[0051]図1の例では、通信チャネル16は、無線周波数(RF)スペクトルあるいは1つまたは複数の物理伝送ラインなど、任意のワイヤレスまたはワイヤード通信媒体、あるいはワイヤレス媒体とワイヤード媒体との任意の組合せを備え得る。通信チャネル16は、ローカルエリアネットワーク、ワイドエリアネットワーク、またはインターネットなどのグローバルネットワークなど、パケットベースネットワークの一部を形成し得る。通信チャネル16は、概して、ワイヤード媒体またはワイヤレス媒体の任意の好適な組合せを含む、ビデオデータをソースデバイス12から宛先デバイス14に送信するのに好適な任意の通信媒体、または様々な通信媒体の集合体を表す。通信チャネル16は、ソースデバイス12から宛先デバイス14への通信を可能にするのに有用であり得るルータ、スイッチ、基地局、または任意の他の機器を含み得る。
[0052]ビデオエンコーダ20およびビデオデコーダ30は、代替的にMPEG−4、Part 10、Advanced Video Coding(AVC)と呼ばれるITU−T H.264規格など、ビデオ圧縮規格に従って動作し得る。ただし、本開示の技法は、いかなる特定のコーディング規格にも限定されない。他の例には、MPEG−2およびITU−T H.263がある。図1には示されていないが、いくつかの態様では、ビデオエンコーダ20およびビデオデコーダ30は、それぞれオーディオエンコーダおよびデコーダと統合され得、適切なMUX−DEMUXユニット、または他のハードウェアおよびソフトウェアを含んで、共通のデータストリームまたは別個のデータストリーム中のオーディオとビデオの両方の符号化を処理し得る。適用可能な場合、MUX−DEMUXユニットはITU H.223マルチプレクサプロトコル、またはユーザデータグラムプロトコル(UDP)などの他のプロトコルに準拠することができる。
[0053]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規格または仕様と呼ぶ。Joint Video Team(JVT)はH.264/MPEG−4 AVCへの拡張に取り組み続けている。
[0054]ビデオエンコーダ20およびビデオデコーダ30はそれぞれ、1つまたは複数のマイクロプロセッサ、デジタル信号プロセッサ(DSP)、特定用途向け集積回路(ASIC)、フィールドプログラマブルゲートアレイ(FPGA)、ディスクリート論理、ソフトウェア、ハードウェア、ファームウェアなど、様々な好適なエンコーダ回路のいずれか、またはそれらの任意の組合せとして実装され得る。ビデオエンコーダ20およびビデオデコーダ30の各々は1つまたは複数のエンコーダまたはデコーダ中に含まれ得、そのいずれも複合エンコーダ/デコーダ(コーデック)の一部としてそれぞれのカメラ、コンピュータ、モバイルデバイス、加入者デバイス、ブロードキャストデバイス、セットトップボックス、サーバなどに統合され得る。
[0055]ビデオシーケンスは、一般に一連のビデオフレームを含む。ピクチャのグループ(GOP)は、概して、一連の1つまたは複数のビデオフレームを備える。GOPは、GOP中に含まれるいくつかのフレームを記述するシンタックスデータを、GOPのヘッダ中、GOPの1つまたは複数のフレームのヘッダ中、または他の場所に含み得る。各フレームは、それぞれのフレームのための符号化モードを記述するフレームシンタックスデータを含み得る。ビデオエンコーダ20は、一般に、ビデオデータを符号化するために、個々のビデオフレーム内のビデオブロックに対して動作する。ビデオブロックは、マクロブロックまたはマクロブロックのパーティションに対応し得る。ビデオブロックは、サイズを固定することも変更することもでき、指定のコーディング規格に応じてサイズが異なることがある。各ビデオフレームは複数のスライスを含み得る。各スライスは複数のマクロブロックを含み得、それらはサブブロックとも呼ばれるパーティションに配置され得る。
[0056]一例として、ITU−T H.264規格は、ルーマ成分については16×16、8×8、または4×4、およびクロマ成分については8×8など、様々なブロックサイズのイントラ予測をサポートし、ならびにルーマ成分については16×16、16×8、8×16、8×8、8×4、4×8および4×4、ならびにクロマ成分については対応するスケーリングされたサイズなど、様々なブロックサイズのインター予測をサポートする。本開示では、「N×N」と「N by N」は、垂直寸法および水平寸法に関するブロックのピクセル寸法、たとえば、16×16ピクセルまたは16 by 16ピクセルを指すために互換的に使用され得る。一般に、16×16ブロックは、垂直方向に16ピクセルを有し(y=16)、水平方向に16ピクセルを有する(x=16)。同様に、N×Nブロックは、一般に、垂直方向にNピクセルを有し、水平方向にNピクセルを有し、Nは、非負整数値を表す。ブロック中のピクセルは行と列に構成され得る。さらに、ブロックは、必ずしも、水平方向に垂直方向と同じ数のピクセルを有する必要はない。たとえば、ブロックは、N×Mピクセルを備え得、Mは必ずしもNに等しいとは限らない。16×16未満のブロックサイズは、ITU−T H.264では16×16のマクロブロックのパーティションと呼ばれ得る。
[0057]ビデオブロックは、ピクセル領域中のピクセルデータのブロックを備え得、あるいは、たとえば、コード化ビデオブロックと予測ビデオブロックとのピクセル差分を表す残差ビデオブロックデータへの離散コサイン変換(DCT)、整数変換、ウェーブレット変換、または概念的に同様の変換などの変換の適用後の、変換領域における変換係数のブロックを備え得る。場合によっては、ビデオブロックは、変換領域における量子化変換係数のブロックを備え得る。
[0058]小さいビデオブロックほど、より良い解像度が得られ、高い詳細レベルを含むビデオフレームのロケーションのために使用され得る。一般に、マクロブロック、およびサブブロックと呼ばれることがある様々なパーティションは、ビデオブロックと見なされ得る。さらに、スライスは、マクロブロックおよび/またはサブブロックなど、複数のビデオブロックであると見なされ得る。各スライスはビデオフレームの単独で復号可能なユニットであり得る。代替的に、フレーム自体が復号可能なユニットであり得るか、またはフレームの他の部分が復号可能なユニットとして定義され得る。「コード化ユニット」という用語は、フレーム全体、フレームのスライス、シーケンスとも呼ばれるピクチャのグループ(GOP)など、ビデオフレームの単独で復号可能な任意のユニット、または適用可能なコーディング技法に従って定義される別の単独で復号可能なユニットを指すことがある。
[0059]高効率ビデオコーディング(HEVC)と現在呼ばれる、新しいビデオコーディング規格を開発するための取り組みが現在進行中である。新興のHEVC規格はH.265と呼ばれることもあり得る。この規格化の取り組みは、HEVCテストモデル(HM:HEVC Test Model)と呼ばれるビデオコーディングデバイスのモデルに基づく。HMは、たとえば、ITU−T H.264/AVCによるデバイスに勝るビデオコーディングデバイスのいくつかの能力を仮定する。たとえば、H.264が9つのイントラ予測モードを提供するのに対して、HMは、たとえば、イントラ予測コード化されるブロックのサイズに基づいて、33ものイントラ予測モードを提供する。
[0060]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:prediction unit)、または変換ユニット(TU:transform unit)のいずれかを指すために「ブロック」という用語を使用する。
[0061]LCUは4分木データ構造に関連付けられ得る。概して、4分木データ構造はCUごとに1つのノードを含み、ルートノードはLCUに対応する。CUが4つのサブCUに分割された場合、CUに対応するノードは4つのリーフノードを含み、リーフノードの各々はサブCUのうちの1つに対応する。4分木データ構造の各ノードは、対応するCUのシンタックスデータを与え得る。たとえば、4分木のノードは、そのノードに対応するCUがサブCUに分割されるかどうかを示す分割フラグを含み得る。CUのシンタックス要素は、再帰的に定義され得、CUがサブCUに分割されるかどうかに依存し得る。
[0062]分割されないCUは、1つまたは複数の予測ユニット(PU:prediction unit)を含み得る。概して、PUは、対応するCUの全部または一部分を表し、そのPUの参照サンプルを取り出すためのデータを含む。たとえば、PUがイントラ予測モード符号化されるとき、PUは、そのPUのためのイントラ予測モードを記述するデータを含み得る。別の例として、PUがインターモード符号化されるとき、PUは、PUの動きベクトルを定義するデータを含み得る。動きベクトルを定義するデータは、たとえば、動きベクトルの水平成分、動きベクトルの垂直成分、動きベクトルの精度(たとえば、1/4ピクセル精度もしくは1/8ピクセル精度)、動きベクトルが指す参照フレーム、および/または動きベクトルの参照リスト(たとえば、リスト0もしくはリスト1)を記述し得る。また、(1つまたは複数の)PUを定義するCUについてのデータは、たとえば、1つまたは複数のPUへのCUの区分について記述し得る。区分モードは、CUがコーディングされないか、イントラ予測モード符号化されるか、またはインター予測モード符号化されるかとの間で異なり得る。
[0063]1つまたは複数のPUを有するCUは、1つまたは複数の変換ユニット(TU:transform unit)をも含み得る。PUを使用した予測の後に、ビデオエンコーダは、PUに対応するCUの部分の残差値を計算し得る。1組の残差値は、変換され、走査され、量子化されて、1組の変換係数が定義され得る。TUは、変換係数を含むデータ構造を定義する。TUは、必ずしもPUのサイズに制限されるとは限らない。したがって、TUは、同じCUの対応するPUよりも大きいことも小さいこともある。いくつかの例では、TUの最大サイズは、対応するCUのサイズに対応し得る。
[0064]本開示の技法によれば、ビデオエンコーダ20は、イントラ予測モード符号化を使用して、ビデオデータのいくつかのブロックを符号化することができ、ブロックを符号化するために使用される選択されたイントラ予測モードを示す情報を提供することができる。ビデオエンコーダ20は、イントラ予測モードを使用して、例えば、PフレームまたはPスライス、およびBフレームまたはBスライスに加えて、IフレームまたはIスライスなどの任意のタイプのフレームまたはスライスのブロックをイントラ予測符号化することができる。あるブロックがイントラ予測モード符号化されるべきであることをビデオエンコーダ20が決定したとき、ビデオエンコーダ20は、最も適切なイントラ予測モードを選択するためにレートひずみ分析を実行することができる。たとえば、ビデオエンコーダ20は、1つまたは複数のイントラ予測モードについてのレートひずみ値を計算し、受容できるレートひずみ特性を有するモードのうちの1つを選択することができる。
[0065]ビデオエンコーダ20は、ブロックの符号化コンテキストを決定するように構成することもできる。コンテキストは、たとえば、ピクセル寸法で決定され得るブロックのサイズ、たとえばHEVCの例における2N×2N、N×2N、2N×N、N×Nなどの予測ユニット(PU)タイプ、2N×N/2、N/2×2N、2N×1、1×2Nなどの短距離イントラ予測(SDIP)タイプ、H.264の例におけるマクロブロックタイプ、ブロックについてのコーディングユニット(CU)深さ、またはビデオデータのブロックについてのサイズの他の測定値など、ブロックの様々な特性を含むことができる。いくつかの例では、コンテキストは、上に隣接するブロック、左に隣接するブロック、左上に隣接するブロック、右上に隣接するブロック、または他の隣接するブロックについてのイントラ予測モードの方法のいずれかまたはすべてに対応することができる。いくつかの例では、コンテキストは、1つまたは複数のブロックについてのイントラ予測モードと、符号化されている現在のブロックのサイズ情報の両方を含むことができる。
[0066]いずれの場合にも、ビデオエンコーダ20は、ブロックのコンテキストを現在のブロックについての様々なコーディング特性にマッピングする構成データを含み得る。たとえば、ブロックのコンテキストに基づいて、構成データは、1つまたは複数の最も可能性の高いイントラ予測モード、イントラ予測モードインデックステーブル、およびマッピングテーブルを示し得る。すなわち、構成データは、複数のイントラ予測モードインデックステーブルおよびマッピングテーブル、ならびに複数のイントラ予測モードインデックステーブルのうちの1つの指示、および現在のブロックの符号化コンテキストに基づいて、現在のブロックについてのイントラ予測モードの指示の符号化に使用するためのマッピングテーブルのうちの1つの指示を含み得る。構成データは、符号化コンテキストに基づいて、現在のブロックについての1つまたは複数の最も可能性の高いモードの指示をさらに提供することができる。1つの最も可能性の高いイントラ予測モードが常に使用されるように、2つの最も可能性の高いイントラ予測モードが常に使用されるように、3つの最も可能性の高いイントラ予測モードが常に使用されるようになど、使用される最も可能性の高いイントラ予測モードの数を固定してもよく、または、代わりに、いくつかのコンテキストは、最も可能性の高いイントラ予測モードを1つ使用し、他のコンテキストは、最も可能性の高いイントラ予測モードを2つ以上使用するように、最も可能性の高いイントラ予測モードの数は、コンテキスト依存でもよい。
[0067]モードインデックステーブルは、1組のイントラ予測モード、ならびにイントラ予測モードの各々にマッピングされるインデックスを含み得る。いくつかの例では、利用可能なイントラ予測モードの数は、符号化されているブロックのサイズに依存し得、したがって、複数のイントラ予測モードインデックステーブルおよびマッピングテーブルは、たとえば、符号化されているブロックのサイズおよび/または他の要因に応じて、異なる数のエントリを有することができる。構成データにおけるマッピングテーブルとイントラ予測モードインデックステーブルとの間に1対多の関係があり得る。すなわち、1つまたは複数のイントラ予測モードインデックステーブルから選択されたイントラ予測モードを符号化するために、同じマッピングテーブルを使用することができる。このように、マッピングテーブルは、複数のイントラ予測モードインデックステーブルに再利用することができる。同様に、たとえば、2つ以上のコンテキストが同じ組のイントラ予測モード、およびそれらのコンテキストにおいてイントラ予測モードが使用される同様または同一の相対的な可能性を共有するときなど、同じイントラ予測モードインデックステーブルは、様々なコンテキストにおいて再利用することができる。その上、いくつかの場合において、同じイントラ予測モードインデックステーブルおよびマッピングテーブルは、特定のサイズのすべてのブロックに使用されてもよく、最も可能性の高いイントラ予測モードは、たとえば、特定のサイズのブロックに隣接するブロックについてのイントラ予測モードに基づいて決定することができる。
[0068]いずれの場合にも、この開示の技法によれば、ビデオエンコーダ20は、ブロックについての符号化コンテキスト、ならびにブロックについての符号化コンテキストに基づくイントラ予測モードインデックステーブルおよびマッピングテーブルに基づいて、あるブロックについての1つまたは複数の最も可能性の高いモードを決定することができる。ブロックの符号化に使用するイントラ予測モードを選択した後、ビデオエンコーダ20は、選択されたイントラ予測モードがブロックについての最も可能性の高いイントラ予測モード(複数可)のうちの1つであるかどうかを決定することができる。選択されたモードが最も可能性の高いモード(複数可)のうちの1つである場合、ビデオエンコーダ20は、シングルビットのコードワード(たとえば、「0」または「1」など)、または一連のビットからなるコードワードを使用してイントラ予測モードをシグナリングすることができる。
[0069]その上、最も可能性の高いイントラ予測モードは、ブロックの符号化コンテキストに基づいてブロックのために選択されたイントラ予測モードインデックステーブル内のインデックス値を有し得る。特に、イントラ予測モードインデックステーブルは、テーブル内のイントラ予測モードごとに一意のインデックス値を含み得る。mは最も可能性の高いイントラ予測モードのインデックスの値を表すとする。最も可能性の高いイントラ予測モードについてのコードワードは、個別にシグナリングされ得るので、マッピングテーブルは、最も可能性の高いイントラ予測モードについての追加のコードワードを含む必要はない。したがって、使用可能なイントラ予測モードの組が0からKにわたるインデックスの範囲にマッピングされるK+1個のメンバーを有する場合、マッピングテーブルは、K個のコードワードを0からK−1のインデックスに割り当てることができる。
[0070]この例示的な方式に従ってコードワードを決定するために、選択されたイントラ予測モードが最も可能性の高いイントラ予測モードでなく、jのモードインデックス値を有すると仮定する。値nはjに対応する変更されたイントラ予測モードのインデックスを表すとする。前の記述によれば、インデックスnにマッピングされたコードワードは、選択されたイントラ予測モードjを示すために、エンコーダからデコーダにシグナリングされる。選択されたイントラ予測モードについてのモードインデックス値が最も可能性の高いイントラ予測モードのモードインデックス値未満である場合、ビデオエンコーダ20は、jに対応するコードワードを使用して現在のブロックを符号化するために使用されるイントラ予測モードの指示を符号化することができる。言い換えれば、j<mである場合、n=jである。一方、選択されたイントラ予測モードについてのモードインデックス値が最も可能性の高いイントラ予測モードのモードインデックス値以上である場合、ビデオエンコーダ20は、j−1に対応するコードワードを使用して現在のブロックを符号化するために使用されるイントラ予測モードの指示を符号化することができる。言い換えれば、j≧mである場合、n=j−1である。
[0071]2つ以上の最も可能性の高いイントラ予測モードが選択される例では、ビデオエンコーダ20は、選択されたモードが第1のビット(たとえば「0」または「1」)または一連のビットを使用して決定された最も可能性の高いイントラ予測モードのうちの1つであるかどうかを、符号化されたビットストリームでシグナリングすることができる。選択されたモードが決定された最も可能性の高いイントラ予測モードのうちの1つである場合、ビデオエンコーダ20は、第2のビットを使用して最も可能性の高いイントラ予測モードのうちどれが選択されたモードであるかをシグナリングすることができる。選択されたモードが決定された最も可能性の高いイントラ予測モードのうちの1つではない場合、ビデオエンコーダ20は、マッピングテーブルからのコードワードを使用して他のイントラ予測モードのうちどれが選択されたモードであるかをシグナリングすることができる。再度、一般性の喪失なしに、選択されたモードが最も可能性の高いイントラ予測モードのうちの1つであることを示す「0」の値を第1のビットが有し、ビデオエンコーダ20が2つの最も可能性の高いイントラ予測モードを決定することを仮定すると、ビデオエンコーダ20は、2つの最も可能性の高いイントラ予測モードのうちのどちらが選択されたモードであるかを「00」または「01」の値でシグナリングすることができ、この場合、第1の0は、第1のビットを表す。選択されたモードが最も可能性の高いイントラ予測モードのうちの1つではない場合、ビデオエンコーダ20は、第1のビットの「1」と、続いてコードワードとをシグナリングすることによって、選択されたモードをシグナリングすることができる。
[0072]その上、2つの最も可能性の高いイントラ予測モードは、ブロックの符号化コンテキストに基づいてブロックのために選択されたイントラ予測モードインデックステーブル内のインデックス値を有し得る。特に、イントラ予測モードインデックステーブルは、テーブル内のイントラ予測モードごとに一意のインデックス値を含み得る。m1は、第1の最も可能性の高いイントラ予測モードのインデックスの値を表し、m2は、第2の最も可能性の高いイントラ予測モードのインデックスの値を表すとする。上記で説明したように、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードについてのコードワードが第1のビットおよび第2のビットを使用してシグナリングされ得るので、マッピングテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードについての追加のコードワードを含む必要はない。したがって、使用可能なイントラ予測モードの組が0からKにわたるインデックスの範囲にマッピングされるK+1個のメンバーを有する場合、マッピングテーブルは、K−1個のコードワードを0からK−2のインデックスに割り当てることができる。
[0073]2つの最も可能性の高いモードが識別されるこの例示的な方式に従ってコードワードを決定するために、選択されたイントラ予測モードが最も可能性の高いイントラ予測モードのうちの1つではなく、jのモードインデックス値を有すると仮定する。値nはjに対応する変更されたイントラ予測モードを表すとする。前の記述によれば、インデックスnにマッピングされたコードワードは、選択されたイントラ予測モードjを示すために、エンコーダからデコーダにシグナリングされる。選択されたイントラ予測モードについてのモードインデックス値が第1の最も可能性の高いイントラ予測モードのモードインデックス値未満である場合、ビデオエンコーダ20は、jに対応するコードワードを使用して現在のブロックを符号化するために使用されるイントラ予測モードの指示を符号化することができる。言い換えれば、j<m1である場合、n=jである。一方、選択されたイントラ予測モードについてのモードインデックス値が第1の最も可能性の高いイントラ予測モードのモードインデックス値以上であるが、第2の最も可能性の高いイントラ予測モード未満である場合、ビデオエンコーダ20は、j−1に対応するコードワードを使用して現在のブロックを符号化するために使用されるイントラ予測モードの指示を符号化することができる。言い換えれば、j≧m1かつj<m2である場合、n=j−1である。最後に、選択されたイントラ予測モードについてのモードインデックス値が第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードのモードインデックス値より大きい場合、ビデオエンコーダ20は、j−2に対応するコードワードを使用して現在のブロックを符号化するために使用されるイントラ予測モードの指示を符号化することができる。言い換えれば、j≧m1かつj≧m2である場合、n=j−2である。最も可能性の高いモードがマッピングテーブルに含まれないということを考慮するようにインデックスを再割り当てすることによって、残りのイントラ予測モードについてのマッピングテーブルをより効率的に構築することができ、これは、そうでなければ、1つまたは複数の任意抽出の最も可能性の高いモードが割り当てられたコードワードを有するとき、ビットの節約になり得る。
[0074]ビデオエンコーダ20は、いくつかの例では、コンテキストに基づいて、最も可能性の高いモードでイントラ予測モードの選択のための分析を開始するように構成され得る。最も可能性の高いモードが適切なレートひずみ特性を達成するとき、いくつかの例では、ビデオエンコーダ20は、最も可能性の高いモードを選択することができる。他の例では、ビデオエンコーダ20は、最も可能性の高いモードで選択プロセスを開始する必要はない。
[0075]予測データと残差データとを生成するためのイントラ予測コーディングまたはインター予測コーディングの後、および変換係数を生成するための(H.264/AVCで使用される4×4または8×8整数変換、あるいは離散コサイン変換DCTなどの)任意の変換の後、変換係数の量子化が実行され得る。量子化は、概して、係数を表すために使用されるデータ量をできるだけ低減するために変換係数を量子化するプロセスを指す。量子化プロセスは、係数の一部または全部に関連するビット深度を低減することができる。たとえば、量子化中にnビット値がmビット値に切り捨てられ得、nはmよりも大きい。
[0076]量子化の後に、たとえば、コンテンツ適応型可変長コーディング(CAVLC)、コンテキスト適応型バイナリ算術コーディング(CABAC)、または別のエントロピーコーディング方法に従って、量子化データのエントロピーコーディングが実行され得る。エントロピーコーディング用に構成された処理ユニットまたは別の処理ユニットは、量子化係数のゼロランレングスコーディング、および/またはコード化ブロックパターン(CBP)値、マクロブロックタイプ、コーディングモード、(フレーム、スライス、マクロブロック、またはシーケンスなどの)コード化ユニットの最大マクロブロックサイズなどのシンタックス情報の生成など、他の処理機能を実行し得る。
[0077]ビデオデコーダ30は、最終的に、たとえば、モデム28および受信機26から符号化ビデオデータを受信することができる。本開示の技法によれば、ビデオデコーダ30は、ビデオデータのブロックを符号化するために使用されるイントラ予測モードを表すコードワードを受信することができる。コードワードは、CABACプロセスを使用してビデオエンコーダ20によってコード化することができ、逆のCABACプロセスを使用してビデオデコーダ30によって復号することができる。ビデオデコーダ30は、ビデオエンコーダ20と実質的に同様の方法でブロックについてのコーディングコンテキストを決定するように構成することができる。その上、ビデオデコーダ30は、たとえば、最も可能性の高いモードの指示、イントラ予測モードインデックステーブル、およびコーディングコンテキストごとのマッピングテーブルなど、ビデオエンコーダ20と同様の構成データを含み得る。
[0078]1つの最も可能性の高いイントラ予測モードを使用するとき、ブロックを符号化するために使用されるイントラ予測モードが最も可能性の高いモードであるかどうかを示すために、シングルビットが使用され得る。選択されたモードが最も可能性の高いモードではないと決定された場合、ビデオデコーダ30は、全体的にビデオエンコーダ20とは逆の方法で、ビデオデータのブロックを符号化するために使用されるイントラ予測モードを決定することができる。
[0079]具体的には、この場合も、nは、マッピングテーブルにおける受信されたコードワードがマッピングされる変更されたイントラ予測モードのインデックスを表し、jは、コード化ブロックを復号するために使用されるイントラ予測モードのモードインデックスを表し、mは、最も可能性の高いモードのモードインデックスを表すとする。変更されたイントラ予測モードインデックスnが最も可能性の高いモードのモードインデックスm未満である場合、ビデオデコーダ30は、インデックスnを有するイントラ予測モードを使用してコード化ブロックを復号することができる。すなわち、n<mである場合、j=nである。一方、変更されたイントラ予測モードインデックスnが最も可能性の高いモードのモードインデックスm以上である場合、ビデオデコーダ30は、インデックスn+1を有するイントラ予測モードを使用してコード化ブロックを復号することができる。言い換えれば、n≧mである場合、j=n+1である。
[0080]2つ以上の最も可能性の高いイントラ予測モードを使用するとき、選択されたモードが2つの最も可能性の高いイントラ予測モードのうちの1つであることを示す第1のビットをコードワードが備える場合、ビデオデコーダ30は、2つ以上の最も可能性の高いイントラ予測モードのうちどれが選択されたモードに対応するかを識別する追加のビットに基づいて、コード化ブロックを符号化するために使用されるイントラ予測モードを決定することができる。選択されたモードが2つの最も可能性の高いイントラ予測モードのうちの1つではないことを第1のビットが示す場合、ビデオデコーダ30は、全体的にビデオエンコーダ20のものとは逆の方法で、ビデオデータのブロックを符号化するために使用されるイントラ予測モードを決定することができる。
[0081]具体的には、この場合も、nは、マッピングテーブルにおける受信されたコードワードがマッピングされる変更されたイントラ予測モードのインデックスを表し、jは、コード化ブロックを復号するために使用されるイントラ予測モードのモードインデックスを表し、m1は、第1の最も可能性の高いモードのモードインデックスを表し、m2は、第2の最も可能性の高いモードのモードインデックスを表すとする。上述のように、m1のモードインデックスがm2のモードインデックスよりも低いと仮定することができる。変更されたイントラ予測モードインデックスnが第1の最も可能性の高いモードのモードインデックスm1未満である場合、ビデオデコーダ30は、インデックスnを有するイントラ予測モードを使用してコード化ブロックを復号することができる。すなわち、n<m1である場合、j=nである。そうではなく、変更されたイントラ予測モードインデックス+1(n+1)が第2の最も可能性の高いモードのモードインデックスm2未満である場合、ビデオデコーダ30は、インデックスn+1を有するイントラ予測モードを使用してコード化ブロックを復号することができる。言い換えれば、n+1<m2である場合、j=n+1である。そうでない場合、ビデオデコーダ30は、インデックスn+2を有するイントラ予測モードを使用してコード化ブロックを復号することができる。言い換えれば、n+1≧m2である場合、j=n+2である。
[0082]2つの最も可能性の高いモードについて、ビデオエンコーダ20によって実行される、変更されたイントラ予測モードインデックスに対するモードインデックスのマッピングは、したがって、以下の擬似コードによって表すことができる。
[0083]N個の最も可能性の高いモードについて、m1が第1の最も可能性の高いモードを表し、mNがN番目の最も可能性の高いモードを表す場合、ビデオエンコーダ20によって実行される、変更されたイントラ予測モードインデックスに対するモードインデックスのマッピングは、したがって、以下の擬似コードによって表すことができる。
[0084]2つの最も可能性の高いモードについて、ビデオデコーダ30によって実行される、モードインデックスに対する変更されたイントラ予測モードインデックスのマッピングは、したがって、以下の擬似コードによって表すことができる。
[0085]N個の最も可能性の高いモードについて、ビデオデコーダ30によって実行される、モードインデックスに対する変更されたイントラ予測モードインデックスのマッピングは、したがって、以下の擬似コードによって表すことができる。
[0086]本開示の技法によれば、モードは、対応するコードワードを示すコードワードインデックスに直接マッピングすることもできる。上述した変更されたイントラ予測モードインデックスと同様の方法で、モードインデックスに対応するインデックスに関するコードワードを送る代わりに、変更されたコードワードインデックスに関するコードワードを送ることによって、ビットの節約を達成することができ、この場合、変更は、最も可能性の高いモードではないモードを示すために、最も可能性の高いモードに最初に関連付けられたコードワードインデックスを使用した結果である。上記で説明したように、最も可能性の高いモードは、最初のビットまたは一連のビットを使用してシグナリングされるので、最も可能性の高いモードは、最も可能性の高いモードのうちの1つではないモードのコードワードインデックスをシグナリングするとき、考慮から除外することができる。その結果、最も可能性の高いモードのうちの1つに最初にマッピングされたコードワードインデックスを使用して、最も可能性の高いモードのうちの1つではないモードを示すことができる。コードワードが変更されたイントラ予測モードインデックスにマッピングされるか、変更されたコードワードインデックスにマッピングされるかにかかわらず、コードワードは、CABACプロセスを使用してコード化することができる。
[0087]たとえば、上記の変更されたイントラ予測モードと同様に、2つの最も可能性の高いイントラ予測モードが使用されると仮定すると、使用可能なイントラ予測モードの組が0からKにわたるコードワードインデックスの範囲にマッピングされるK+1個のメンバーを有する場合、変更されたコードワードインデックスのテーブルは、K−1個のコードワードを0からK−2までのコードワードインデックスに割り当てることができる。
[0088]Cがコードワードインデックスを表し、Cmodが変更されたコードワードインデックスを表すと仮定する。さらに、Cm1が最も可能性の高いモードの最も低いコードワードインデックスを表し、Cm2が最も可能性の高いモードに対応する第2に低いコードワードインデックスを表し、以下同様であると仮定する。以下でより詳細に説明するように、コードワードインデックスに対するモードのマッピングは、動的でもよい。したがって、最も低いモードインデックスを有する第1の最も可能性の高いモードは、最も低いコードワードインデックスを有していない場合もある。したがって、必ずしもCm1は第1の最も可能性の高いモードに対応しているとは限らず、Cm2は第2の最も可能性の高いモードに対応しているとは限らず、以下同様であり得る。N個の最も可能性の高いモードについて、ビデオエンコーダ20によって実行される、変更されたコードワードインデックスに対するコードワードインデックスのマッピングは、したがって、以下の擬似コードによって表すことができる。
[0089]N個の最も可能性の高いモードについて、ビデオデコーダ30によって実行される、コードワードインデックスに対する変更されたコードワードインデックスのマッピングは、したがって、以下の擬似コードによって表すことができる。
[0090]ビデオエンコーダ20およびビデオデコーダ30はそれぞれ、適用可能なとき、1つまたは複数のマイクロプロセッサ、デジタル信号プロセッサ(DSP)、特定用途向け集積回路(ASIC)、フィールドプログラマブルゲートアレイ(FPGA)、ディスクリート論理回路、ソフトウェア、ハードウェア、ファームウェアなど、様々な好適なエンコーダまたはデコーダ回路のいずれか、あるいはそれらの任意の組合せとして実装され得る。ビデオエンコーダ20およびビデオデコーダ30の各々は1つまたは複数のエンコーダまたはデコーダ中に含まれ得、そのいずれも複合ビデオエンコーダ/デコーダ(コーデック)の一部として統合され得る。ビデオエンコーダ20および/またはビデオデコーダ30を含む装置は、集積回路、マイクロプロセッサ、および/またはセルラー電話などのワイヤレス通信デバイスを備え得る。
[0091]図2は、イントラ予測モードを示す情報をコード化するための技法を実装し得るビデオエンコーダ20の一例を示すブロック図である。ビデオエンコーダ20は、マクロブロックあるいはマクロブロックのパーティションまたはサブパーティションを含むビデオフレーム内のブロックのイントラコーディングおよびインターコーディングを実行し得る。イントラコーディングは、所与のビデオフレーム内のビデオの空間的冗長性を低減または除去するために空間的予測に依拠する。インターコーディングは時間的予測を利用して、ビデオシーケンスの隣接フレーム内のビデオの時間的冗長性を低減または除去する。イントラ予測(I)モードは、いくつかの空間ベースの圧縮モードのいずれかを指し、単方向予測(Pモード)または双方向予測(Bモード)などのインターモードは、いくつかの時間ベースの圧縮モードのいずれかを指し得る。図2にはインターモード符号化のための構成要素が示されているが、ビデオエンコーダ20はイントラ予測モード符号化のための構成要素をさらに含み得ることを理解されたい。ただし、簡潔および明快のために、そのような構成要素は示されていない。
[0092]図2に示すように、ビデオエンコーダ20は、符号化されるビデオフレーム内の現在のビデオブロックを受信する。図2の例では、ビデオエンコーダ20は、動き補償ユニット44と、動き推定ユニット42と、メモリ64と、加算器49と、変換モジュール52と、量子化ユニット54と、エントロピー符号化ユニット56とを含む。ビデオブロック再構成のために、ビデオエンコーダ20はまた、逆量子化ユニット58と、逆変換モジュール60と、加算器62とを含む。再構成されたビデオからブロッキネスアーティファクトを除去するためにブロック境界をフィルタ処理するデブロッキングフィルタ(図2に図示せず)も含まれ得る。所望される場合、デブロッキングフィルタは、一般に、加算器62の出力をフィルタ処理するであろう。
[0093]符号化プロセス中に、ビデオエンコーダ20はコーディングされるビデオフレームまたはスライスを受信する。フレームまたはスライスは、複数のビデオブロックに分割され得る。動き推定ユニット42および動き補償ユニット44は、時間圧縮を行うために、1つまたは複数の参照フレーム中の1つまたは複数のブロックに対する受信したビデオブロックのインター予測コーディングを実行する。イントラ予測ユニットモジュール46は、空間圧縮を行うために、コーディングされるブロックと同じフレームまたはスライス中の1つまたは複数の隣接ブロックに対する受信したビデオブロックのイントラ予測コーディングを実行し得る。
[0094]モード選択ユニット40は、たとえば、誤差結果に基づいて、およびコード化されている現在のブロックを含むフレームまたはスライスのフレームまたはスライスタイプに基づいて、コーディングモード、すなわち、イントラまたはインターのうちの1つを選択し、残差ブロックデータを生成するために、得られたイントラコード化ブロックまたはインターコード化ブロックを加算器49に供給し、参照フレームまたは参照スライス中で使用するための符号化ブロックを再構成するために、得られたイントラコード化ブロックまたはインターコード化ブロックを加算器62に供給し得る。一般に、イントラ予測は、隣接する、前にコード化されたブロックに対して現在のブロックを予測することを伴い、一方、インター予測は、現在のブロックを時間的に予測するために、動き推定および動き補償を伴う。
[0095]動き推定ユニット42および動き補償ユニット44は、ビデオエンコーダ20のインター予測要素を表す。動き推定ユニット42と動き補償ユニット44とは、高度に統合され得るが、概念的な目的のために別々に示してある。動き推定は、ビデオブロックの動きを推定する動きベクトルを生成するプロセスである。動きベクトルは、たとえば、現在のフレーム(または、他のコード化ユニット)内のコーディングされている現在のブロックに対する予測参照フレーム(または、他のコード化ユニット)内の予測ブロックの変位を示し得る。予測ブロックは、絶対値差分和(SAD:sum of absolute difference)、2乗差分和(SSD:sum of square difference)、または他の差分メトリックによって判断され得るピクセル差分に関して、コーディングされるブロックにぴったり一致することがわかるブロックである。動きベクトルはまた、マクロブロックのパーティションの変位を示し得る。動き補償は、動き推定によって決定された動きベクトルに基づいて予測ブロックをフェッチまたは生成することに関与し得る。この場合も、いくつかの例では、動き推定ユニット42と動き補償ユニット44とは機能的に統合され得る。
[0096]動き推定ユニット42は、ビデオブロックを参照フレームストア64中の参照フレームのビデオブロックと比較することによってインターコード化フレームのビデオブロックの動きベクトルを計算する。動き補償ユニット44はまた、参照フレーム、たとえば、IフレームまたはPフレームのサブ整数ピクセルを補間し得る。ITU H.264規格は、一例として、符号化されている現在のフレームよりも前の表示順序を有する参照フレームを含むリスト0、および符号化されている現在のフレームよりも後の表示順序を有する参照フレームを含むリスト1の2つのリストを記述する。したがって、参照フレームストア64に記憶されたデータは、これらのリストに従って編成され得る。
[0097]動き推定ユニット42は、参照フレームストア64からの1つまたは複数の参照フレームのブロックを現在のフレーム、たとえば、PフレームまたはBフレームの符号化すべきブロックと比較する。参照フレームストア64中の参照フレームがサブ整数ピクセルの値を含むとき、動き推定ユニット42によって計算される動きベクトルは参照フレームのサブ整数ピクセルロケーションを参照し得る。動き推定ユニット42および/または動き補償ユニット44はまた、サブ整数ピクセル位置の値が参照フレームストア64に記憶されていない場合、参照フレームストア64に記憶された参照フレームのサブ整数ピクセル位置の値を計算するように構成され得る。動き推定ユニット42は、計算された動きベクトルをエントロピー符号化ユニット56と動き補償ユニット44とに送る。動きベクトルによって識別される参照フレームブロックは予測ブロックと呼ばれることがある。動き補償ユニット44は、インター予測ブロックに基づいて予測データを計算し得る。
[0098]イントラ予測モジュール46は、上記で説明したように、動き推定ユニット42と動き補償ユニット44とによって実行されるインター予測の代替として、現在のブロックをイントラ予測し得る。特に、イントラ予測モジュール46は、現在のブロックの符号化に使用するためのイントラ予測モードを決定することができる。いくつかの例では、イントラ予測モジュール46は、たとえば、別々の符号化パスの間など、様々なイントラ予測モードを使用して、現在のブロックを符号化することができ、イントラ予測モジュール46(または、いくつかの例において、モード選択ユニット40)は、テストされたモードから使用するのに適切なイントラ予測モードを選択することができる。たとえば、イントラ予測モジュール46は、様々なテストされたイントラ予測モードのためのレートひずみ分析を使用してレートひずみ値を計算し、テストされたモードの中の最良のレートひずみ特性を有するイントラ予測モードを選択することができる。レートひずみ分析は、一般に、符号化されたブロックと、符号化されたブロックを生成するために符号化された元の符号化されていないブロックとの間のひずみ(またはエラー)の量、ならびに、符号化されたブロックを生成するために使用されたビットレート(すなわち、ビット数)を決定する。イントラ予測モジュール46は、どのイントラ予測モードがブロックについての最良のレートひずみ値を呈するかを決定するために、様々な符号化されたブロックについてのひずみおよびレートから比率を計算することができる。
[0099]いずれの場合も、あるブロックについてのイントラ予測モードを選択した後、イントラ予測ユニットモジュール46は、エントロピー符号化ユニット56にブロックについての選択されたイントラ予測モードを示す情報を提供することができる。エントロピー符号化ユニット56は、本開示の技法に従ってCABACを使用して選択されたイントラ予測モードを示す情報を符号化することができる。図2に示すように、ビデオエンコーダ20は、複数のイントラ予測モードインデックステーブルおよび複数の変更されたイントラ予測モードインデックステーブル(コードワードマッピングテーブルとも呼ばれる)と、様々なブロックの符号化コンテキストの定義と、最も可能性の高いイントラ予測モード、イントラ予測モードインデックステーブル、各コンテキストについての使用する変更されたイントラ予測モードインデックステーブルの指示とを含み得る構成データ66とを含むことができる。
[0100]以下の表1は、イントラ予測モードインデックス、対応するイントラ予測モード、およびモードのうちのどれが特定のコンテキストについて最も可能性の高いモードであるかの指示の一例を表す。表1は、この特定の例では、各モードインデックスにマッピングする変更されたイントラ予測モードインデックスも示す。表2は、表1のモードインデックスに全体的に対応する変更されたイントラ予測モードインデックスにコードワードをマッピングする例示的なマッピングテーブルを提供する。上記で説明したように、2つ以上の最も可能性の高いモードが使用されてもよいが、表1および表2の例は、最も可能性の高いモード1つのみが使用されると仮定する。最も可能性の高いモードが1つ使用されるため、表2は、表1よりも1つ少ないエントリを含む。最も可能性の高いモードは、残りのモードとは別にシグナリングされるので、モードインデックス5は、対応する変更されたイントラ予測モードインデックスを有していない。同様に、表2は、最も可能性の高いモードについてのコードワードを含む必要はない。
[0101]例として、mは表1において最も可能性の高いモードのモードインデックスを表し、nはjに対応する変更されたイントラ予測モードのインデックスを表すとする。選択されたモードが最も可能性の高いモードである場合、第1のビット(たとえば「0」)は、この例では、モードを表すために使用され、モードは、表1によって示されるように、最も可能性の高いモードとして決定される(この例では、垂直−右)。0以外の第1のビット(すなわち「1」)が送られる場合、モードは、最も可能性の高いモードではない。nはモードを表すために送られるコードワードによって示される変更されたイントラ予測モードインデックスに対応するとする。インデックスnにマッピングされたコードワードは、選択されたイントラ予測モードjを示すために、エンコーダからデコーダにシグナリングされる。選択されたイントラ予測モードについてのモードインデックス値が最も可能性の高いイントラ予測モードのモードインデックス値未満である場合、ビデオエンコーダ20は、jに対応するコードワードを使用して現在のブロックを符号化するために使用されるイントラ予測モードの指示を符号化することができる。言い換えれば、j<mである場合、n=jである。一方、選択されたイントラ予測モードについてのモードインデックス値が最も可能性の高いイントラ予測モードのモードインデックス値以上である場合、ビデオエンコーダ20は、j−1に対応するコードワードを使用して現在のブロックを符号化するために使用されるイントラ予測モードの指示を符号化することができる。言い換えれば、j≧mである場合、n=j−1である。
[0102]デコーダ、たとえばデコーダ30は、一般に、エンコーダ20の逆のマッピングを実行する。したがって、デコーダ30は、n<mである場合、モードインデックスがnに等しいことを決定することができる。一方、n≧mである場合、モードインデックスはn+1に等しい。言い換えれば、変更されたイントラ予測モードインデックス(たとえば、送られるコードワードに対応する表2からの変更されたイントラ予測モードインデックス)が(この例では、表1からの)最も可能性の高いモードのインデックス以上である場合、イントラ予測モードは、事実上、nではなく、n+1によって示される。このようにして、現在のブロックを符号化するために使用されるイントラ予測モードについてのモードインデックス(たとえば、n+1)が最も可能性の高い符号化モードのインデックス(m)よりも大きいとき、選択されたイントラ予測モードを表すために使用されるコードワードは、現在のブロックを符号化するために使用されるイントラ予測モードについてのモードインデックス(n+1)よりも1小さい変更されたイントラ予測モードインデックス(n)に対応する。
[0103]表1および表2の例に関する一例として、垂直−右の最も可能性の高いモードを示すコンテキストを有する現在のブロックについて、選択されたモードが水平−下であると仮定する。この例では、最も可能性の高いモードのインデックスmは5であり、一方、(表1による)選択されたモードについてのモードインデックスは8である。この例では、選択されたモードについてのモードインデックスは、最も可能性の高いモードについてのモードインデックスよりも大きいので、n=j−1であり、この場合、nは、変更されたイントラ予測モードのインデックスであり、7に等しい。したがって、表2では、ビデオエンコーダ20は、この例では、選択されたモードを表すために、コードワード111を使用する。コードワード111は、選択されたモードが最も可能性の高いモードではないことを示す最初のビットに続く。したがって、ビデオデコーダ30(図1および図4)は、最初のビットとコードワード111とを受信し、nの値が7であることを決定する。この例では7が5よりも大きい(すなわち、n≧m)ので、ビデオデコーダ30は、この例では、8であり、水平−下に対応する、モードインデックスn+1を有するモードを表1から取り出す。
[0104]別の例として、この場合も、表1および表2の例に関して、現在のブロックについて、選択されたモードがDCであると仮定する。同じく、この例では、最も可能性の高いモードのインデックスmは5であり、一方、(表1による)選択されたモードについてのモードインデックスは0である。この例では、選択されたモードについてのモードインデックスが最も可能性の高いモードについてのモードインデックス未満であるので、モードインデックスはnに等しく、この場合、nは、変更されたイントラ予測モードインデックスである。したがって、表2では、ビデオエンコーダ20は、この例では、選択されたモードを表すために、コードワード000を使用する。コードワード000は、選択されたモードが最も可能性の高いモードではないことを示す最初のビットに続く。したがって、ビデオデコーダ30(図1および図4)は、最初のビットとコードワード000とを受信し、nの値が0であることを決定する。この例では0が5未満(すなわち、n<m)なので、ビデオデコーダ30は、この例では、0であり、DCに対応する、モードインデックスnを有するモードを表1から取り出す。
[0105]以下の表3は、イントラ予測モードインデックス、対応するイントラ予測モード、およびモードのうちのどれが特定のコンテキストについて最も可能性の高いモードであるかの指示の一例を表す。表3は、この特定の例では、各モードインデックスにマッピングする変更されたイントラ予測モードインデックスも示す。表4は、表3のモードインデックスに全体的に対応する変更されたイントラ予測モードインデックスにコードワードをマッピングする例示的なマッピングテーブルを提供する。上記で説明したように、3つ以上の最も可能性の高いモードが使用されてもよいが、表3および表4の例は、最も可能性の高いモード2つのみが使用されると仮定する。最も可能性の高いモードが2つ使用されるため、表4は、表3よりも2つ少ないエントリを含む。
[0106]特に、m1は表3における第1の最も可能性の高いモードのモードインデックスを表し、m2は第2の最も可能性の高いモードのモードインデックスを表すとする。選択されたモードが最も可能性の高いモードのうちの1つである場合、モードが2つの最も可能性の高いモードのうちの1つであることをシグナリングするために、第1のビット(たとえば「0」)が使用される。モードが2つの最も可能性の高いモードのうちの1つである場合、第2のビットは、2つの最も可能性の高いモードのうちのどちらが選択されたモードに対応するかをシグナリングするために使用される。したがって、2つの最も可能性の高いモードは、それぞれ「00」および「01」の最初のビットシーケンスでシグナリングすることができる。「0」以外の第1のビット(すなわち「1」)が送られる場合、選択されたモードは、2つの最も可能性の高いモードのうちの1つではない。nはモードを表すために送られるコードワードによって示される変更されたイントラ予測モードインデックスに対応するとする。
[0107]ビデオエンコーダ20は、選択されたモードのモードインデックス(j)を決定し、モードインデックスを変更されたモードインデックス(n)にマッピングすることができる。j≧m2である場合、n=j−2である。そうではなく、j≧m1である場合、n=j−1である。そうでない場合、n=jである。ビデオデコーダ30は、変更されたイントラ予測モードインデックス(n)を受信し、最初にnをm1と比較することができる。n<m1である場合、モードインデックス(j)はnに等しい。nがm1以上である場合、n+1はm2と比較することができる。n+1<m2である場合、モードインデックスはn+1に等しい。そうでない場合、モードインデックスは、n+2に等しい。
[0108]表3および表4の例に関する一例として、垂直−左および斜め下/左の最も可能性の高いモードを示すコンテキストを有する現在のブロックについて、選択されたモードが水平−下であると仮定する。この例では、最も可能性の高いモードのインデックスm1およびm2は4および6であり、一方、(表3による)選択されたモードについてのモードインデックスjは8である。この例では、選択されたモードについてのモードインデックスが両方の最も可能性の高いモードについてのモードインデックスよりも大きいので、モードインデックスjはn+2に等しく、この場合、nは、表4における変更されたイントラ予測モードのインデックスに等しい。したがって、モードインデックスjが8に等しい場合、n=6である。したがって、ビデオエンコーダ20は、この例では、選択されたモードを表すために、コードワード110を使用する。したがって、ビデオデコーダ30(図1および図4)は、コードワード110を受信し、nの値が6であることを決定する。この例では、6が4以上(すなわちn≧m1)であり、6+1が6以上である(すなわち、n+1≧m2)であるので、ビデオデコーダ30は、n+2に等しいモードインデックスjを有するモードを表3から取り出し、この例では、jは8であり、水平−下に対応する。
[0109]別の例として、この場合も、表3および表4の例に関して、現在のブロックについて、選択されたモードがDCであると仮定する。この場合も、この例では、最も可能性の高いモードのインデックスm1およびm2は4および6であり、一方、(表3による)選択されたモードについてのモードインデックスjは0である。この例では、選択されたモードについてのモードインデックスが両方の最も可能性の高いモードについてのモードインデックス未満(すなわち、n<m1)なので、モードインデックスjはnに等しく、この場合、nは、表4における変更されたイントラ予測モードのインデックスに等しい。したがって、nは、0に等しい。したがって、表4に基づいて、ビデオエンコーダ20は、この例では、選択されたモードを表すために、コードワード0を使用する。コードワード000は、選択されたモードが最も可能性の高いモードではないことを示す最初のビットまたは一連のビットに続く。したがって、ビデオデコーダ30(図1および図4)は、最初のビットまたは一連のビットとコードワード000とを受信し、nの値が0であることを決定する。この例では0が4および6未満(すなわち、n<m1)なので、ビデオデコーダ30は、nに等しいモードインデックスjを有するモードを表3から取り出し、この例では、jは0であり、DCに対応する。
[0110]さらに別の例として、表3および表4の例に関して、現在のブロックについて、選択されたモードが垂直−右であると仮定する。この例では、最も可能性の高いモードのインデックスm1およびm2は4および6であり、一方、(表3による)選択されたモードについてのモードインデックスjは5である。この例では、選択されたモードについてのモードインデックスが第1の最も可能性の高いモードについてのモードインデックス以上であるが、第2の最も可能性の高いモードについてのモードインデックス未満であるので、モードインデックスjはn+1に等しく、この場合、nは、表4における変更されたイントラ予測モードのインデックスに等しい。したがって、モードインデックスjが5である場合、n=4である。したがって、ビデオエンコーダ20は、この例では、選択されたモードを表すために、コードワード110を使用する。コードワード110は、選択されたモードが最も可能性の高いモードではないことを示す最初のビットまたは一連のビットに続く。したがって、ビデオデコーダ30(図1および図4)は、最初のビットおよび一連のビットと、コードワード110とを受信し、nの値が4であることを決定する。この例では、4が4以上であり、しかし4+1が6未満(すなわち、n≧m1しかしn+1<m2)であるので、ビデオデコーダ30は、この例では、5であり、垂直−右に対応する、n+1に等しいモードインデックスjを有するモードを表3から取り出す。
[0111]表1、表2、表3、および表4は単に、最も可能性の高いモード、モードのインデックス、および様々なインデックスに割り当てられるコードワードの表の例にすぎないことを理解されたい。他の例では、たとえば、あるブロックの符号化コンテキストに基づいて、他のモードが最も可能性の高いと決定され得る。たとえば、最も可能性の高いモードは、左および上に隣接するブロックを符号化するために使用される符号化モードに基づいて決定することができる。構成データ66は、概して表1および表3の例に類似した、最も可能性の高いモードとして識別される異なる符号化モードに関連付けられた複数の異なるテーブルを含み得る。同様に、構成データ66は、インデックスをコードワードにマッピングする、たとえば表2および表4など、複数のコードワードマッピングテーブルを含み得る。
[0112]一般に、表1および表3は、モードインデックステーブルと呼ばれ得、一方、表2および表4は、変更されたイントラ予測モードインデックスマッピングテーブル、または単にマッピングテーブルと呼ばれ得る。上記のように、表1および表2は、単にモードインデックステーブルおよびマッピングテーブルの一例にすぎない。いくつかの例では、構成データ66は、複数のモードインデックステーブルおよび複数のマッピングテーブルについてのデータを含み得る。いくつかの例では、複数のコーディングコンテキストは、共通のモードインデックステーブルに対応し得る。同様に、複数のモードインデックステーブルは、共通のマッピングテーブルにマッピングされ得る。
[0113]本開示の技法によれば、モードは、変更されたイントラ予測モードインデックスではなく、コードワードインデックスにマッピングすることもできる。次いで、コードワードインデックスを、コードワードを検索するために使用される、変更されたコードワードインデックスにマッピングすることができる。以下の表5は、イントラ予測モードインデックス、およびコードワードインデックスにマッピングされたモードの一例を表す。表5は、どのモードが特定のコンテキストについての最も可能性の高いモードであるかの指示、およびこの特定の例でのコードワードインデックスに対応する変更されたコードワードインデックスも示す。
[0114]例として、Cm1は1つの最も可能性の高いモードのコードワードインデックスを表し、Cm2は別の最も可能性の高いモードのコードワードインデックスを表すとし、この場合、Cm1は、Cm2よりも低いコードワードインデックス値を有する。上記で説明したように、Cm1およびCm2は、モードインデックス値とは反対に、コードワードインデックス値に基づいて決定される。したがって、Cm1は必ずしも第1の最も可能性の高いモードに対応しているとは限らず、Cm2は必ずしも第2の最も可能性の高いモードに必ずしも対応しているとは限らない場合がある。表5の例では、たとえば、モード3(斜め下/右)は、それが最も可能性の高いモードの最も低いモードインデックスを有するので、第1の最も可能性の高いモードであり、モード6は、第2の最も可能性の高いモードである。しかしながら、第2のモードの可能性の高いモードは、第1の最も可能性の高いモードよりも低い対応するコードワードインデックスを有する。したがって、表5の例では、Cm1は第2の最も可能性の高いモードのコードワードインデックスに対応し、Cm2は第1の最も可能性の高いモードのコードワードインデックスに対応する。以下の説明では、Cm1がCm2未満であると仮定される。
[0115]選択されたモードが最も可能性の高いモードのうちの1つである場合、モードが2つの最も可能性の高いモードのうちの1つであることをシグナリングするために、第1のビット(たとえば「0」)が使用される。モードが2つの最も可能性の高いモードのうちの1つである場合、第2のビットは、2つの最も可能性の高いモードのうちのどちらが選択されたモードに対応するかをシグナリングするために使用される。したがって、2つの最も可能性の高いモードは、それぞれ「00」および「01」の最初のビットシーケンスでシグナリングすることができる。「0」以外の第1のビット(すなわち「1」)が送られる場合、選択されたモードは、2つの最も可能性の高いモードのうちの1つでなく、選択されたモードは、コードワードインデックスに対応するコードワードとして送られる。しかしながら、選択されたモードについてのコードワードインデックスに直接対応するコードワードを送る代わりに、ビデオエンコーダ20が変更されたコードワードインデックスに対応するコードワードを送ることによって、ビットの節約が達成され得る。ビデオデコーダ30は、変更されたコードワードインデックスに対応するコードワードを受信し、次いで、選択されたイントラ予測モードに対応するコードワードインデックスを決定することができる。
[0116]ビデオエンコーダ20は、選択されたモード(C)のコードワードインデックスを決定し、モードインデックスを変更されたモードインデックス(Cmod)にマッピングすることができる。C≧Cm2である場合、Cmod=C−2である。そうではなく、C≧Cm1である場合、Cmod=C−1である。そうでない場合、Cmod=Cである。ビデオデコーダ30は、変更されたイントラ予測モードインデックス(Cmod)を受信し、最初にそれをCm1と比較することができる。Cmod<Cm1である場合、モードインデックス(C)はCmodに等しい。CmodがCm1以上である場合、Cmod+1はCm2と比較することができる。Cmod+1<Cm2である場合、モードインデックスはCmod+1に等しい。そうでない場合、モードインデックスは、Cmod+2に等しい。
[0117]表5および表6の例に関する一例として、垂直−左(モードインデックス6)および斜め下/右(モードインデックス3)の最も可能性の高いモードを示すコンテキストを有する現在のブロックについて、選択されたモードが水平−下(モードインデックス8)であると仮定する。この例では、最も可能性の高いモードについてのコードワードインデックスCm1およびCm2は2および5であり、一方、(表5による)選択されたモードについてのモードインデックスは8である。表5によれば、モードインデックス3、6、および8はそれぞれ、コードワードインデックス5、2、および8にマッピングする。この例では、選択されたモードについてのコードワードインデックス(すなわちコードワードインデックス8)が両方の最も可能性の高いモードについてのコードワードインデックス(すなわちコードワードインデックス5および2)よりも大きいので、コードワードインデックスはCmod+2に等しく、この場合、Cmodは、表6におけるコードワードに対応する変更されたコードワードインデックスに等しい。したがって、選択されたモードのコードワードインデックスが8に等しい場合、Cmod=6である。したがって、ビデオエンコーダ20は、この例では、選択されたモードを表すために、コードワード110を使用する。したがって、ビデオデコーダ30(図1および図4)は、コードワード110を受信し、Cmodの値が6であることを決定する。この例では、6が2以上(すなわちCmod≧Cm1)であり、6+1が5以上である(すなわち、Cmod+1≧Cm2)であるので、ビデオデコーダ30は、この例では、8であり、水平−下に対応する、モードインデックスCmod+2を有するモードを表5から取り出す。
[0118]別の例として、この場合も、表5および表6の例に関して、現在のブロックについて、選択されたモードが垂直(モードインデックス1およびコードワードインデックス0)であると仮定する。さらに、最も可能性の高いモードのインデックスCm1およびCm2は、5および2である。この例では、選択されたモードについてのコードワードインデックスが両方の最も可能性の高いモードについてのコードワードインデックス未満(すなわちC<Cm1)であるので、変更されたコードワードインデックスCmodは、コードワードインデックスに等しい。したがって、ビデオエンコーダ20は、この例では、選択されたモードを表すために、コードワード000を使用する。コードワード000は、選択されたモードが最も可能性の高いモードではないことを示す最初のビットまたは一連のビットに続く。したがって、ビデオデコーダ30(図1および図4)は、最初のビットまたは一連のビットとコードワード000とを受信し、Cmodの値が0であることを決定する。この例では0が5および2未満(すなわち、Cmod<Cm1)なので、ビデオデコーダ30は、この例では、0であり、垂直に対応する、Cmodに等しいモードインデックスCを有するモードを表5から取り出す。
[0119]さらに別の例として、表5および表6の例に関して、現在のブロックについて、選択されたモードが水平(モードインデックス2およびコードワードインデックス4)であると仮定する。この例では、最も可能性の高いモードについてのインデックスCm1およびCm2は、2および5である。この例では、選択されたモードについてのコードワードインデックスがCm1以上であり、しかしCm2未満であるので、コードワードインデックスはCmod+1に等しく、この場合、Cmodは、変更されたコードワードインデックスである。したがって、コードワードインデックスが4である場合、Cmod=3である。したがって、ビデオエンコーダ20は、この例では、選択されたモードを表すために、コードワード011を使用する。コードワード011は、選択されたモードが最も可能性の高いモードではないことを示す最初のビットまたは一連のビットに続く。したがって、ビデオデコーダ30(図1および図4)は、最初のビットおよび一連のビットとコードワード011とを受信し、Cmodの値が3であることを決定する。この例では、3が2以上であり、3+1が5未満である(すなわち、Cmod≧Cm1であり、しかしCmod+1<Cm2)であるので、ビデオデコーダ30は、4であり、水平に対応する、Cmod+1に等しいモードインデックスを有するモードを表5から取り出す。
[0120]表1〜表6は単に、最も可能性の高いモード、モードのインデックス、コードワードインデックス、および様々なインデックスに割り当てられるコードワードの表の例にすぎないことを理解されたい。他の例では、たとえば、あるブロックの符号化コンテキストに基づいて、他のイントラ予測モードが最も可能性の高いモードと決定され得る。たとえば、最も可能性の高いモードは、左および上に隣接するブロックを符号化するために使用されるイントラ予測モードに基づいて決定することができる。構成データ66は、概して表1、表3、および表5の例に類似した、最も可能性の高いモードとして識別される異なるイントラ予測モード、ならびに識別された異なる数の最も可能性の高いモードに関連付けられた複数の異なるテーブルを含み得る。同様に、構成データ66は、残りのイントラ予測モードインデックスをコードワードにマッピングする、たとえば表2、表4、および表6など、複数のコードワードマッピングテーブルを含み得る。上記で説明したように、最も可能性の高いモードは、最初のビットまたは一連のビットを使用してシグナリングされる。そのような最初のビットまたは一連のビットは、コンテキスト依存でもよい。たとえば、異なる一連のビットは、どのイントラ予測モードが最も可能性の高いモードであると識別されるか、ならびに最も可能性の高いモードがどれくらい識別されるかに応じて、最も可能性の高いモードをシグナリングするために使用され得る。所与の例についての最も可能性の高いモードおよびコーディングテーブルは、その例で使用される隣接するブロックのイントラ予測モードの代わりに、またはそれに加えて、他のタイプのコンテキストに基づいて定義することもできる。
[0121]表1、表2、表3、表4、および表5の例は、H.264の9つのイントラ予測モードに関して提供される。しかしながら、本開示の技法を高効率ビデオコーディング(HEVC)など他の符号化標準および技法に適用することができることを理解されたい。いくつかの例では、たとえばHEVCにおいて、使用可能なイントラ予測モードの数は、コード化されているブロックのサイズ(たとえば、HEVCでの「コーディングユニット」または「CU」)に依存し得る。イントラ予測モードごとに、モードインデックスは、各イントラ予測モードの出現の可能性に基づいて割り当てることができる。図3は、HEVCで使用することができるイントラ予測モードおよび対応するモードインデックスの一例を示す。図3の矢印は、予測方向を表し、数字は、モードインデックスを表す。以下の表7は、CUのサイズと、そのサイズのCUの符号化のために利用可能なイントラ予測モードの数(number)との間の対応を示す。表7によってわかるように、8×8、16×16、および32×32のCUは、図3に示される35のイントラ予測モードを使用することができ、一方、4×4および64×64のCUはより少ない組のイントラ予測モードを使用する。
[0122]イントラ予測モードの数がブロックサイズに基づいて変わる例では、構成データ66は、異なるサイズのブロックについての異なるテーブルを含むことができる。したがって、あるブロックを符号化するために使用されるイントラ予測モードの指示を符号化するためのコンテキストは、ブロックのサイズ、ならびに隣接するブロックを符号化するために使用されるコーディングモードを含むことができる。エントロピー符号化ユニット56は、ブロックのコンテキストに基づいてブロックの符号化に使用される選択されたイントラ予測モードを表すコードワードを選択するために使用されるモードインデックステーブルおよびコードワードマッピングテーブルを選択することができる。その上、特定サイズのブロックについてのモードインデックステーブルは、そのサイズのブロックについてのイントラ予測モードの数に等しい数のエントリを有することができる。したがって、サイズ4×4のブロックについてのモードインデックステーブルは、18のエントリを有し得、サイズ8×8、16×16、および32×32のブロックについてのモードインデックステーブルは、35のエントリを有し得、サイズ64×64のブロックについてのモードインデックステーブルは、4つのエントリを有し得る。たとえば128×128など、他のサイズのブロックも、決定された数の利用可能なイントラ予測モードを有することができる。
[0123]サイズ8×8、16×16、および32×32のブロックのために利用可能なイントラ予測モードは、同じとすることができ、したがって、同じモードインデックステーブルは、サイズ8×8、16×16、および32×32のブロックに使用され得る。しかしながら、これらのサイズのブロックについて同じモードが可能であるが、特定のモードを使用してあるブロックを符号化する確率は、ブロックのサイズに基づいて変わり得る。したがって、いくつかの例では、エントロピー符号化ユニット56は、イントラ予測モードがシグナリングされることになっているブロックのサイズに基づいて、特定のモードインデックステーブルについてのコードワードマッピングテーブルを決定することができる。
[0124]例として、上記の表2、表4、および表6は、様々な符号化モードを表す例示的なテーブルにすぎない。しかしながら、他の例では、他のタイプのコードを使用することができることを理解されたい。コードワードの各々が一意に復号可能である限り、コードワードマッピングテーブル(すなわち、マッピングテーブルまたは変更されたイントラ予測モードインデックステーブル)のために、任意の組のコードワードを使用することができる。
[0125]たとえば、イントラ予測またはインター予測を使用して、現在のブロックを予測した後、ビデオエンコーダ20は、コード化されている元のビデオブロックから、動き補償ユニット44またはイントラ予測モジュール46によって計算された予測データを減算することによって残差ビデオブロックを形成し得る。加算器49は、この減算演算を実行する1つまたは複数の構成要素を表す。変換モジュール52は、離散コサイン変換(DCT)または概念的に同様の変換などの変換を残差ブロックに適用し、残差変換係数値を備えるビデオブロックを生成する。変換モジュール52は、概念的にDCTと同様である、H.264規格によって定義される変換などの他の変換を実行し得る。ウェーブレット変換、整数変換、サブバンド変換または他のタイプの変換をも使用することができる。いずれの場合も、変換モジュール52は、変換を残差ブロックに適用し、残差変換係数のブロックを生成する。変換は、残差情報をピクセル値領域から周波数領域などの変換領域に変換し得る。量子化ユニット54は、ビットレートをさらに低減するために残差変換係数を量子化する。量子化プロセスは、係数の一部または全部に関連するビット深度を低減することができる。量子化の程度は、量子化パラメータを調整することによって変更され得る。
[0126]量子化の後、エントロピー符号化ユニット56は、量子化変換係数をエントロピーコーディングする。たとえば、エントロピー符号化ユニット56は、コンテンツ適応型可変長コーディング(CAVLC)、コンテキスト適応型バイナリ算術コーディング(CABAC)、または別のエントロピーコーディング技法を実行し得る。エントロピー符号化ユニット56によるエントロピーコーディングの後に、符号化されたビデオは、別のデバイスに送信されるか、あるいは後で送信するかまたは取り出すためにアーカイブされ得る。コンテキスト適応型バイナリ算術コーディングの場合、コンテキストは隣接ブロックおよび/またはブロックサイズに基づき得る。
[0127]場合によっては、エントロピー符号化ユニット56またはビデオエンコーダ20の別のユニットは、上記で説明したように、エントロピーコーディングおよびイントラ予測モードのコーディングに加えて他のコーディング機能を実行するように構成され得る。たとえば、エントロピー符号化ユニット56はブロックのコード化ブロックパターン(CBP:coded block pattern)値およびパーティションを判断するように構成され得る。また、場合によっては、エントロピー符号化ユニット56は、マクロブロックまたはそれのパーティション中の係数のランレングスコーディングを実行し得る。特に、エントロピー符号化ユニット56は、マクロブロックまたはパーティション中の変換係数をスキャンするためにジグザグスキャンまたは他のスキャンパターンを適用し、さらなる圧縮のためにゼロのランを符号化し得る。エントロピー符号化ユニット56はまた、符号化ビデオビットストリーム中での送信のために適切なシンタックス要素を用いてヘッダ情報を構成し得る。
[0128]逆量子化ユニット58および逆変換モジュール60は、それぞれ逆量子化および逆変換を適用して、たとえば参照ブロックとして後で使用するために、ピクセル領域中で残差ブロックを再構成する。動き補償ユニット44は、残差ブロックを参照フレームストア64のフレームのうちの1つの予測ブロックに加算することによって参照ブロックを計算し得る。動き補償ユニット44はまた、再構成された残差ブロックに1つまたは複数の補間フィルタを適用して、動き推定において使用するサブ整数ピクセル値を計算し得る。加算器62は、再構成された残差ブロックを、動き補償ユニット44によって生成された動き補償予測ブロックに加算して、参照フレームストア64に記憶するための再構成されたビデオブロックを生成する。再構成されたビデオブロックは、後続のビデオフレーム中のブロックをインターコーディングするために動き推定ユニット42および動き補償ユニット44によって参照ブロックとして使用され得る。
[0129]このようにして、ビデオエンコーダ20は、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択し、コードワードのテーブルは、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化し、コードワードのテーブルを使用してイントラ予測モードのうちの1つに対応する変更されたイントラ予測モードインデックスのうちの1つを決定し、CABACプロセスを実行することによって、選択されたコードワードのテーブルから、変更されたイントラ予測モードインデックスのうちの1つに対応するコードワードを符号化するように構成されたビデオエンコーダの一例を表す。
[0130]このようにして、ビデオエンコーダ20は、現在のブロックの符号化コンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、現在のブロックのコンテキストに基づいて、コードワードインデックスに対応する複数のコードワードを備えるコードワードのテーブルを選択し、コードワードインデックスはイントラ予測モードにマッピングされ、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードのうちの1つを使用して、現在のブロックを符号化し、現在のブロックを符号化するために使用されるイントラ予測モードのうちの1つのコードワードインデックス、第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定し、CABACプロセスを実行することによって、選択されたコードワードのテーブルから、変更されたイントラ予測モードインデックスのうちの1つに対応するコードワードを符号化するように構成されたビデオエンコーダの一例も表す。
[0131]図4は、符号化されたビデオシーケンスを復号するビデオデコーダ30の一例を示すブロック図である。図4の例では、ビデオデコーダ30は、エントロピー復号ユニット70と、動き補償ユニット72と、イントラ予測モジュール74と、逆量子化ユニット76と、逆変換ユニット78と、メモリ82と、加算器80とを含む。ビデオデコーダ30は、いくつかの例では、ビデオエンコーダ20(図2)に関して説明した符号化パスとは概して逆の復号パスを実行し得る。動き補償ユニット72は、エントロピー復号ユニット70から受信した動きベクトルに基づいて予測データを生成し得る。
[0132]動き補償ユニット72は、ビットストリーム中で受信した動きベクトルを使用して、参照フレームストア82中の参照フレーム中の予測ブロックを識別し得る。イントラ予測モジュール74は、ビットストリーム中で受信されたイントラ予測モードを使用して、空間的に隣接するブロックから予測ブロックを形成し得る。特に、ビデオデコーダ30は、図4の例では、構成データ84を含む。構成データ84が、イントラ予測されたブロックのコンテキストを記述する情報と、ならびに、コンテキストごとに使用する複数のイントラ予測インデックスマッピングテーブルのうちの1つと、コンテキストごとに使用する複数の変更されたイントラ予測モードインデックス(またはコードワードマッピング)テーブルのうちの1つと、コンテキストごとの最も可能性の高いイントラ予測モードとを含むという点で、構成データ84は、図2の構成データ66と実質的に同様である。
[0133]エントロピー復号ユニット70は、ビデオデータの符号化されたブロックの復号に使用するためのイントラ予測モードを表すコードワードを受信することができる。エントロピー復号ユニット70は、たとえば、符号化されたブロックの左に隣接するブロックおよび上に隣接するブロックについてのイントラ予測モード、および/または符号化されたブロックについてのサイズに基づいて、符号化されたブロックのコンテキストを決定することができる。コンテキストに基づいて、エントロピー復号ユニット70は、ブロックの復号に使用するための1つまたは複数の最も可能性の高いイントラ予測モード、ならびにブロックの復号に使用するための実際のイントラ予測モードの決定に使用するためのイントラ予測インデックステーブルおよび変更されたイントラ予測モードインデックステーブルを決定することができる。
[0134]単一の最も可能性の高いイントラ予測モードを使用するとき、コードワードが、たとえば「0」など、第1のビットを備える場合、エントロピー復号ユニット70は、実際のイントラ予測モードが符号化されたブロックについての最も可能性の高いイントラ予測モードであることを決定することができる。そうでない場合、エントロピー復号ユニット70は、符号化されたブロックのコンテキストについての変更されたイントラ予測モードインデックステーブルに基づいて、受信されたコードワードにマッピングされる変更されたイントラ予測モードインデックスを決定することができる。nは変更されたイントラ予測モードインデックスを表し、mは最も可能性の高いイントラ予測モードについてのモードインデックスを表すとする。n<mであるとき、エントロピー復号ユニット70は、符号化されたブロックについての実際のイントラ予測モードがnのモードインデックスを有することを決定することができる。そうでない場合(すなわち、n≧m)、エントロピー復号ユニット70は、符号化されたブロックについての実際のイントラ予測モードがn+1のモードインデックスを有することを決定することができる。上記のようにnまたはn+1のいずれかに等しいモードインデックスを使用することによって、エントロピー復号ユニット70は、符号化されたブロックの復号に使用するための実際のイントラ予測モードを示す情報を取り出し、イントラ予測モジュール74にモードの指示を送ることができる。
[0135]2つの最も可能性の高いイントラ予測モードなど、2つ以上の最も可能性の高いイントラ予測モードを使用するとき、第1のビットが、たとえば「0」など、ある値を有する場合、エントロピー復号ユニット70は、実際のイントラ予測モードが符号化されたブロックについての最も可能性の高いイントラ予測モードのうちの1つであることを決定することができる。そのような場合、第2のビットまたは一連のビットに基づいて、エントロピー復号ユニット70は、最も可能性の高いイントラ予測モードのうちどれが選択されたイントラ予測モードであるかを決定することができる。そうでない場合、第1のビットの後、エントロピー復号ユニット70は、受信されたコードワードにマッピングされた変更されたイントラ予測モードインデックスを決定し、変更されたイントラ予測モードインデックスに基づいて、ブロックについての選択されたイントラ予測モードを決定することができる。一例として、nは変更されたイントラ予測モードインデックスを表し、m1およびm2は最も可能性の高いイントラ予測モードについてのモードインデックスを表すとする。n<m1である場合、エントロピー復号ユニット70は、符号化されたブロックについての選択されたイントラ予測モードがnのモードインデックスを有することを決定することができる。n+1<m2である(しかしnはm1以上である)とき、エントロピー復号ユニット70は、符号化されたブロックについての選択されたイントラ予測モードがn+1のモードインデックスを有することを決定することができる。そうではなく、n+1がm2以上であるとき、エントロピー復号ユニット70は、符号化されたブロックについての選択されたイントラ予測モードがn+2のモードインデックスを有することを決定することができる。モードインデックスを使用することによって、エントロピー復号ユニット70は、符号化されたブロックの復号に使用するための選択されたイントラ予測モードを示す情報を取り出し、イントラ予測モジュール74にモードの指示を送ることができる。
[0136]同様に、イントラ予測モードインデックスがコードワードインデックスにマッピングされ、2つ以上の最も可能性の高いモードが使用されている場合、第1のビットまたは一連のビットが、たとえば「0」など、ある値を有する場合、エントロピー復号ユニット70は、実際のイントラ予測モードが符号化されたブロックについての最も可能性の高いイントラ予測モードのうちの1つであることを決定することができる。そのような場合、第2のビットまたは一連のビットに基づいて、エントロピー復号ユニット70は、最も可能性の高いイントラ予測モードのうちどれが選択されたイントラ予測モードであるかを決定することができる。そうでない場合、第1のビットまたは一連のビットの後、エントロピー復号ユニット70は、受信されたコードワードにマッピングされた変更されたコードワードインデックスを決定し、変更されたコードワードインデックスに基づいて、ブロックについての選択されたイントラ予測モードを決定することができる。一例として、Cmodは変更されたコードワードインデックスを表し、Cm1およびCm2は最も可能性の高いイントラ予測モードについてのモードインデックスを表すとする。Cmod<Cm1である場合、エントロピー復号ユニット70は、符号化されたブロックについての実際の選択されたイントラ予測モードがCmodに等しいコードワードインデックスを有することを決定することができる。Cmod+1<Cm2である(しかしCmodはCm1以上である)とき、エントロピー復号ユニット70は、符号化されたブロックについての実際の選択されたイントラ予測モードがCmod+1のコードワードインデックスを有することを決定することができる。そうではなく、Cmod+1がCm2以上であるとき、エントロピー復号ユニット70は、符号化されたブロックについての実際の選択されたイントラ予測モードがCmod+2のモードインデックスを有することを決定することができる。コードワードインデックスを使用することによって、エントロピー復号ユニット70は、符号化されたブロックの復号に使用するための実際の選択されたイントラ予測モードを示す情報を取り出し、イントラ予測モジュール74にモードの指示を送ることができる。
[0137]イントラ予測モジュール74は、たとえば、隣接する、以前復号されたブロックのピクセルを使用して、符号化されたブロックをイントラ予測するためにイントラ予測モードの指示を使用することができる。ブロックがインター予測モード符号化される例では、動き補償ユニット72は、符号化されたブロックについての動き補償予測データを取り出すために、動きベクトルを定義する情報を受信することができる。いずれの場合も、動き補償ユニット72またはイントラ予測モジュール74は、加算器80に予測ブロックを定義する情報を提供することができる。
[0138]逆量子化ユニット76は、ビットストリーム中で供給され、エントロピー復号ユニット70によって復号された量子化ブロック係数を逆量子化(inverse quantize)、すなわち、逆量子化(de-quantize)する。逆量子化プロセスは、たとえば、H.264復号規格によって定義される、またはHEVCテストモデルによって実行されるなど、従来のプロセスを含み得る。逆量子化プロセスはまた、量子化の程度を判断し、同様に、適用する逆量子化の程度を判断するための、各マクロブロックについてエンコーダ20によって計算される量子化パラメータQPYの使用を含み得る。
[0139]逆変換モジュール58は、逆変換、たとえば、逆DCT、逆整数変換、または概念的に同様の逆変換プロセスを変換係数に適用して、ピクセル領域において残差ブロックを生成する。動き補償ユニット72は動き補償ブロックを生成し、場合によっては、補間フィルタに基づいて補間を実行する。サブピクセル精度をもつ動き推定に使用されるべき補間フィルタの識別子は、シンタックス要素中に含まれ得る。動き補償ユニット72は、ビデオブロックの符号化中にビデオエンコーダ20によって使用された補間フィルタを使用して、参照ブロックのサブ整数ピクセルの補間値を計算し得る。動き補償ユニット72は、受信されたシンタックス情報に従って、ビデオエンコーダ20によって使用された補間フィルタを判断し、その補間フィルタを使用して予測ブロックを生成し得る。
[0140]動き補償ユニット72は、シンタックス情報のいくつかを使用して、符号化ビデオシーケンスの(1つまたは複数の)フレームを符号化するために使用されるブロックのサイズと、符号化ビデオシーケンスのフレームまたはスライスの各ブロックがどのように区分されるかを記述するパーティション情報と、各パーティションがどのように符号化されるかを示すモードと、各インター符号化ブロックまたはパーティションのための1つまたは複数の参照フレーム(および参照フレームリスト)と、符号化ビデオシーケンスを復号するための他の情報と、を判断する。
[0141]加算器80は、残差ブロックを、動き補償ユニット72またはイントラ予測モジュール74によって生成される対応する予測ブロックと合計して、復号ブロックを形成する。必要に応じて、ブロッキネスアーティファクトを除去するために、デブロッキングフィルタを適用して、復号ブロックをフィルタ処理することもできる。復号されたビデオブロックは、次いで、参照フレームストア82に記憶され、参照フレームストア82は、参照ブロックをその後の動き補償に供給し、また、ディスプレイデバイス(図1のディスプレイデバイス32など)上での提示のために復号されたビデオを生成する。
[0142]このようにして、図4のビデオデコーダ30は、現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、現在のブロックのコンテキストに基づいてコードワードのテーブルを選択し、コードワードのテーブルが、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、CABACプロセスを実行して、受信されたコードワードを決定し、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたイントラ予測モードインデックスのうちの1つを決定し、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択し、選択されたイントラ予測モードは、変更されたイントラ予測モードインデックスのうちの決定された1つに対応し、選択されたイントラ予測モードを使用して、現在のブロックを復号するように構成されたビデオデコーダの一例を表す。
[0143]このようにして、図4のビデオデコーダ30は、現在のブロックのコンテキストに基づいて、ビデオデータの現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、現在のブロックのコンテキストに基づいて、コードワードのテーブルを選択し、コードワードのテーブルが、コードワードインデックスに対応する複数のコードワードを備え、コードワードインデックスがイントラ予測モードにマッピングされ、CABACプロセスを実行して、受信されたコードワードを決定し、コードワードのテーブルを使用して受信されたコードワードに対応する変更されたコードワードインデックスを決定し、コード化ブロックの復号に使用するために、第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択し、選択されたイントラ予測モードは、変更されたコードワードインデックス、第1の最も可能性の高いイントラ予測モード、および第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、選択されたイントラ予測モードを使用して、現在のブロックを復号するように構成されたビデオデコーダの一例も表す。
[0144]図5Aは、本開示で説明する技法に従って使用され得るCABAC符号化ユニット50Aの一例を示すブロック図である。CABAC符号化ユニット50Aは、値対ビンマッピングモジュール51Aと、コンテキスト割当てモジュール53Aと、適応型算術コーディングモジュール55Aとを含む。適応型算術コーディングモジュール55Aは、確率推定モジュール57Aと、コーディングエンジン59Aとを含む。CABACコーディングユニット50Aは、たとえば、図2のエントロピー符号化ユニット56の一部であることがわかる。
[0145]非バイナリ値シンタックス要素では、値対ビンマッピングモジュール51A値は、シンタックス要素の値を、1つまたは複数のビットまたは「ビン」を備え得る「ビンストリング」とも呼ばれるバイナリシーケンスに割り当てることができる。言い換えれば、値対ビンマッピングモジュール51Aは、ビンストリングを使用して値が表されるように、シンタックス要素の値を「2値化する」ことができる。任意の値のビンストリングを任意の特定の非バイナリ値シンタックス要素に割り当てることができること、および、ビンストリングが必ずしもバイナリ形態でシンタックス要素の値を表す必要があるとは限らないことに留意されたい。上記の表2、表4、および表6の例では、提供されたコードワードは、すでにバイナリ形態であり、したがって2値化のために使用され得る。シンタックス値をバイナリコードワードにマッピングすることは、シンタックス要素がビンマッピングモジュール51Aに渡される前に、シンタックス値を本質的に「2値化する」。しかしながら、バイナリシンタックス要素では、ビンマッピングモジュール51Aは、シンタックス要素を2値化することができる。
[0146]上述のように、表2、表4、および表6の各々は、すでにバイナリ値として表されている、すなわち、すでに2値化されているので、コードワードは、この2値化プロセスをバイパスすることができ、以下で説明するコンテキスト割当てモジュール53Aによって実行されるCABACのコンテキストモデリング段階に進むことができる。同様に、使用するイントラ予測モードが特定のコンテキストについての最も可能性の高いイントラ予測モードであるかどうかを示す、表1、表3、および表5を参照して上述した1つまたは複数のビンも、すでにバイナリ値として表されている可能性があり、したがって、上述と同じ理由から2値化される必要はない場合がある。他の例では、変更されたイントラ予測モードインデックス、変更されたコードワードインデックス、他のシンタックス要素、および使用されるイントラ予測モードが特定のコンテキストについての最も可能性の高いイントラ予測モードであるかどうかの指示は、2値化されていない場合があり、したがって、2値化を利用することができる。
[0147]コンテキスト割当てモジュール53Aは、シンタックス要素を表すために使用されるビンストリングの各ビンにコンテキストを割り当てる。たとえば、コンテキスト割当てモジュール53Aは、ビンストリング内の各ビンに異なるコンテキストを割り当てることができる。代わりに、コンテキスト割当てモジュール53Aは、ビンストリングの1つまたは複数のビンに共通のコンテキストを割り当てることができる。いくつかの他の場合、たとえば、CABACバイパスモードを使用してビンがコード化されるとき、明確なコンテキストは必要ではなく、コンテキスト割当てモジュール53Aは、任意のコンテキストをビンに割り当てる必要はない場合がある。いずれの場合にも、いくつかの例では、各コンテキストは、コンテキストインデックスを使用して表され得る。言い換えれば、ビンストリングの各ビンは、それぞれのビンに割り当てられる特定のコンテキストを示すコンテキストインデックスに関連付けられ得る。
[0148]コンテキスト割当てモジュール53Aは、時として「コンテキストモデリング」と呼ばれるプロセスを使用してビンストリングの各ビンへのコンテキストの割当てを実行することができる。たとえば、コンテキスト割当てモジュール53Aは、コンテキストモデルに基づいて決定されるコンテキストに、各ビンを割り当てることができる。コンテキストモデルは、所与のビンについて、特定のコンテキストがどのように計算されるかについて決定する。たとえば、コンテキストは、たとえば、ビデオデータの隣接ブロックについての対応する前に符号化されたシンタックス要素の値、またはビンストリング内のビンの相対位置など、ビンのために利用可能な情報に基づいて計算することができる。たとえば、コンテキストモデルは、現在ブロックの上部および左側にビデオデータの隣接するブロックについての変更されたイントラ予測モードインデックスの値(またはインデックスを表すために使用されるコードワード)、および/またはビンストリング内のビンの位置を使用して、コンテキストを計算することができる。
[0149]いくつかの例では、各コンテキストは、複数の「コンテキスト状態」を含み得、そこで、コンテキスト状態の各々は、所与の値、たとえば「0」または「1」を備える、コンテキストが割り当てられるビンの確率を示す確率推定値の特定の組に関連付けられる。さらに、各コンテキストは、所与の時間において特定の現在のコンテキスト状態に関連付けられていてもよく、現在のコンテキスト状態は、そのコンテキストについての最も現在の確率推定値を示す。
[0150]ビンストリングのビンは、その後、適応型算術コーディングモジュール55Aによって符号化され得る。ビンを符号化するために、適応型算術コーディングモジュール55Aの確率推定モジュール57Aは、ビンに割り当てられるコンテキスト(およびその現在の状態)に基づいてコード化されているビンの確率推定値を決定することができる。
[0151]コーディングエンジン59Aは、ビンの値、およびビンに割り当てられるコンテキスト(およびその現在の状態)に対応する確率推定値を、ビンを符号化するときの適応型算術コーディングモジュール55Aへの入力として使用することができる。上記で説明したように、割り当てられたコンテキストを使用して、確率推定モジュール57Aによって、ビンについての確率推定値が決定される。前述のように、これらの確率推定値は、一般に、「0」に等しい値または「1」に等しい値を有するビンの確率に対応する。確率推定値は、1つのコンテキストに割り当てられるビンについて同じとすることができ、コンテキストの各々の現在のコンテキスト状態によって反映されるように、コンテキスト間で異なっていてもよい。
[0152]さらに、割り当てられたコンテキストについての確率推定値は、コーディングエンジン59Aによって符号化されているビンの実効値に基づいて更新することができる。たとえば、特定のビンが「1」の値を有する場合、割り当てられたコンテキストについての「1」の確率推定値が増加する。同様に、ビンが「0」の値を有する場合、割り当てられたコンテキストについての「0」の確率推定値が増加する。上記の例では、割り当てられたコンテキストについての確率推定値は、前述のように、コンテキストについての最も現在の確率推定値を反映するためにコンテキスト状態を更新することによって更新され得る。たとえば、更新されたコンテキスト状態によって示される最も現在の確率推定値は、同じコンテキストが選択される次のビンを符号化するために使用され得る。
[0153]上記で説明した技法は、ビンストリングのビンごとに繰り返すことができる。いくつかの例では、バイパスモードは、ビンストリングの1つまたは複数のビンのために利用され得、その場合、明示的に割り当てられたコンテキストモデルの使用なしに、1つまたは複数のビンがコード化され、これは、ビンのコード化を単純化し、高速化することができる。たとえば、バイパスモードを使用してコード化される1つまたは複数のビンについて、ほぼ均等な(たとえば、値「0」および「1」を有する「0.5」)確率推定値を仮定することができる。言い換えれば、バイパスモードは、一様に分布したビンをコード化するために使用することができる。
[0154]上記のCABACプロセスは、CABACプロセスの一例を表すためのものである。上記のプロセスに対する変更、ならびに上記のものに対する代替のCABACプロセスは、本開示で説明する技法の範囲内であることが企図される。さらに、本開示の技法は、他のコンテキスト適応型エントロピーコーディングプロセス、たとえばProbability Interval Partitioning Entropy Coding(PIPE)プロセス、ならびに他のコンテキスト適応型エントロピーコーディングプロセスを使用することをさらに企図する。
[0155]図5Bは、本開示で説明する技法に従って使用され得るCABAC復号ユニット50Bの一例を示すブロック図である。CABAC復号ユニット50Bは、ビン対値マッピングモジュール51Bと、コンテキスト割当てモジュール53Bと、適応型算術復号モジュール55Bとを含む。適応型算術復号モジュール55Bは、確率推定モジュール57Bと、復号エンジン59Bを含む。CABAC復号ユニット50Bは、たとえば、図4のエントロピー復号ユニット70の一部であることがわかる。
[0156]CABAC符号化ユニット50Aに関して上記で説明したのと類似の、しかし逆の方法で、CABAC復号ユニット50Bは、1つまたは複数のビンを備える符号化されたビンストリングを復号することができる。前述のように、符号化されたビンストリングは、符号化されたバイナリ値、または非バイナリ値シンタックス要素を表し得る。
[0157]たとえば、コンテキスト割当てモジュール53Bは、ビンストリングの特定のビンに割り当てられることになっているコンテキストを決定するために、コンテキストモデリングを使用することができる。確率推定モジュール57Bは、ビンを復号するために使用される確率推定値を決定するために、割り当てられたコンテキスト(およびその現在の状態)を使用することができる。さらに、復号エンジン59Bは、確率推定値を使用してビンを復号することができる。上記で説明したのと同様の様式で、このプロセスは、ビンストリングの一部または全部のビンについて繰り返すことができ、結果的に、ビンストリングの復号がもたらされる。最後に、ビン対値マッピングモジュール51Bは、ビンストリングの復号されたビンを、非バイナリ値シンタックス要素にマッピングすることができ、または1つまたは複数の復号されたビンを「非2値化する」ことができる。
[0158]同じく、上記のCABACプロセスは、CABACプロセスの一例を表すためのものである。上記のプロセスに対する変更、ならびに上記のものに対する代替のCABACプロセスは、本開示で説明する技法の範囲内であることが企図される。さらに、本開示の技法は、他のコンテキスト適応型エントロピーコーディングプロセス、たとえばPIPEプロセス、ならびに他のコンテキスト適応型エントロピーコーディングプロセスを使用することをさらに企図する。
[0159]図6は、ビデオデータのブロックをイントラ予測符号化するための一例の方法を示すフローチャートである。図6の技法は、一般に、ハードウェア、ソフトウェア、ファームウェア、またはそれらの組合せのいずれに実装されようと、任意の処理ユニットまたはプロセッサによって実行することができ、ソフトウェアまたはファームウェアに実装されるとき、ソフトウェアまたはファームウェアのための命令を実行するために、対応するハードウェアが提供され得る。例として、図6の技法は、ビデオエンコーダ20(図1および図2)に関して説明するが、他のデバイスが同様の技法を実行するように構成され得ることを理解されたい。その上、図6に示されるステップは、本開示の技法から逸脱することなく、異なる順序でまたは並行して実行されてもよく、追加のステップが追加されたり、いくつかのステップが省略されたりしてもよい。
[0160]初めに、ビデオエンコーダ20は、ビデオデータの現在のブロックについてのイントラ予測モードを選択する(100)。たとえば、イントラ予測モジュール46は、ブロックを符号化するために使用される様々なイントラ予測モードについてのレートひずみ値を計算し、次いで、テストされたイントラ予測モードの最良のレートひずみ値を呈するイントラ予測モードを選択する。イントラ予測モジュール46は、次いで、選択されたイントラ予測モードを使用してブロックを符号化する(102)。すなわち、イントラ予測モジュール46は、選択されたイントラ予測モードに基づいてブロックについての予測ブロックを計算する。ビデオエンコーダ20は、ビデオエンコーダ20が次いで変換し、量子化することができる残差ブロックを生成するために、予測ブロックと元のブロックとの間の差をさらに計算する。
[0161]ビデオエンコーダ20は、選択されたイントラ予測モードを表す情報をさらに符号化する。すなわち、イントラ予測モジュール46は、エントロピー符号化ユニット56に選択されたイントラ予測モードの指示を送る。エントロピー符号化ユニット56、またはビデオエンコーダ20の別のユニットは、ブロックのコンテキストを決定する(104)。ブロックのコンテキストは、ブロックのサイズ、ならびに/またはたとえば上に隣接するブロックおよび/もしくは左に隣接するブロックなど、隣接するブロックのイントラ予測モードを含みえる。エントロピー符号化ユニット56は、ブロックの符号化コンテキストに基づいて、イントラ予測モードインジケータの符号化に使用するための変更されたイントラ予測モードインデックステーブルを選択することもできる(106)。エントロピー符号化ユニット56は、いくつかの例では、イントラ予測インデックステーブルをさらに選択することができ、一方、他の例では、イントラ予測モードインデックスは固定されてもよい。エントロピー符号化ユニット56は、ブロックのコンテキストにおけるブロックについての1つまたは複数の最も可能性の高いイントラ予測モードをさらに決定することができる(108)。
[0162]エントロピー符号化ユニット56は、次いで、最も可能性の高いイントラ予測モード(複数可)に基づいて、イントラ予測モードについてのコードワードを変更されたイントラ予測モードインデックステーブルから選択することができる(110)。たとえば、以下でより詳細に説明するように、エントロピー符号化ユニット56は、シングルビットまたは一連のビット(たとえば、シングルビットまたは2ビット)を使用して、選択されたイントラ予測モードが最も可能性の高いイントラ予測モードのうちの1つを備えることをシグナリングすることができる。選択されたイントラ予測モードが最も可能性の高いイントラ予測モードのうちの1つではない場合、エントロピー符号化ユニット56は、選択されたイントラ予測モードをシグナリングするために、コードワードを選択することができる。エントロピー符号化ユニット56は、次いで、コード化ブロック(たとえば、符号化された量子化変換係数)をビットストリームに出力し、CABACプロセスを使用して、選択されたコードワードをビットストリームに出力することができる(112)。
[0163]図7Aは、コード化ブロックについてのイントラ予測モードを示すコードワードを選択するための例示的な方法を示すフローチャートである。この場合も、図7Aの技法は、任意の適したプロセッサにおいて実施することができるが、図7Aの技法は、例として、ビデオエンコーダ20の例に関して説明する。図7Aは、一般に、図6のステップ110についての追加の詳細を提供する。図7Aに示される方法のステップは、本開示の技法から逸脱することなく、異なる順序でまたは並行して実行されてもよく、追加のステップが追加されたり、いくつかのステップが省略されたりしてもよい。
[0164]上記で説明したように、ビデオエンコーダ20は、現在のブロックについてのコーディングコンテキストを決定する(120)。同様に、ビデオエンコーダ20は、ブロックについてのコーディングコンテキストに基づいて、変更されたイントラ予測モードインデックステーブルを選択する(122A)。ビデオエンコーダ20の構成データは、ブロックのコンテキストについての、変更されたイントラ予測モードインデックステーブルの、および、いくつかの例では、イントラ予測モードインデックステーブルの指示を提供する。さらに、ビデオエンコーダ20は、ブロックについてのコーディングコンテキストに基づいてブロックの符号化に使用するための最も可能性の高いイントラ予測モードを決定する(124A)。この場合も、ビデオエンコーダ20の構成データは、ブロックのコンテキストについての最も可能性の高いイントラ予測モードの指示を提供することができる。
[0165]上記で説明したように、ビデオエンコーダ20は、ブロックの実際の符号化に使用するために、ブロックについてのイントラ予測モードを選択する(126A)。ビデオエンコーダ20は、選択されたイントラ予測モードが、ブロックのコンテキストに基づいて、ブロックについての最も可能性の高いイントラ予測モードと同じであるかどうかを決定する(128A)。選択されたモードが最も可能性の高いモードである場合(128Aの「YES」分岐)、ビデオエンコーダ20は、最も可能性の高いモードに基づいて、シングルビット、たとえば、「0」または「1」を使用して、ブロックの符号化に使用されるイントラ予測モードの指示を符号化する(130A)。
[0166]選択されたモードが最も可能性の高いモードでないとき(128Aの「NO」分岐)、ビデオエンコーダ20は、たとえば、イントラ予測モードインデックステーブルから、選択されたイントラ予測モードについてのモードインデックスを決定する(122A)。いくつかの例では、モードインデックスは、コンテキストに関係なく、グローバルな値でもよく、一方、他の例では、ビデオエンコーダ20の構成データは、各コンテキストを複数のイントラ予測モードインデックステーブルのうちの1つにマッピングし得る。ビデオエンコーダ20は、最も可能性の高いイントラ予測モードについてのモードインデックスをさらに決定する。次いで、ビデオエンコーダ20は、選択されたイントラ予測モードについてのモードインデックスがブロックのコンテキストにおいて最も可能性の高いイントラ予測モードについてのモードインデックス未満であるかどうかを決定する(134A)。
[0167]選択されたイントラ予測モードについてのモードインデックスが最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき(134Aの「YES」分岐)、ビデオエンコーダ20は、選択されたイントラ予測モードについてのモードインデックスに対応するブロックのコンテキストについての変更されたイントラ予測モードインデックステーブルからコードワードを決定する。より詳細には、ビデオエンコーダ20は、CABACプロセスを使用して、選択されたイントラ予測モードについてのモードインデックスに等しい変更されたイントラ予測モードインデックスにマッピングされたコードワードを出力する(136A)。
[0168]一方、選択されたイントラ予測モードについてのモードインデックスが最も可能性の高いイントラ予測モードについてのモードインデックスよりも大きいとき(134Aの「NO」分岐)、ビデオエンコーダ20は、選択されたイントラ予測モードについてのモードインデックスよりも1小さいものに対応するブロックのコンテキストについての変更されたイントラ予測モードインデックステーブルからコードワードを決定する。より詳細には、ビデオエンコーダ20は、CABACプロセスを使用して、選択されたイントラ予測モードについてのモードインデックスよりも1小さいものに等しい変更されたイントラ予測モードインデックスにマッピングされたコードワードを出力する(138A)。
[0169]最も可能性の高いイントラ予測モードが別個にシグナリングされるので、変更されたイントラ予測モードインデックステーブルは、追加のコードワードを最も可能性の高いイントラ予測モードのインデックスにマッピングする必要はない。したがって、最も可能性の高いイントラ予測モードについてのモードインデックスに等しい変更されたイントラ予測モードインデックスは、このようにして、最も可能性の高いイントラ予測モードについてのモードインデックスよりも1大きいモードインデックスにマッピングされ得る。したがって、ブロックのために利用可能なイントラ予測モードがK個ある場合、変更されたイントラ予測モードインデックステーブルは、最も可能性の高いイントラ予測モードがブロックを符号化するために使用されるかどうかを示すシングルビットのコードワード以外の、K−1個の変更されたイントラ予測モードインデックスについてのコードワードを提供するだけでよい。
[0170]図7Bは、コード化ブロックについてのイントラ予測モードを示すコードワードを選択するための例示的な方法を示すフローチャートである。この場合も、図7Bの技法は、任意の適したプロセッサにおいて実施することができるが、図7Bの技法は、例として、ビデオエンコーダ20の例に関して説明する。図7Bは、一般に、2つの最も可能性の高いモードが使用される例について、図6のステップ110の追加の詳細を提供する。図7Bに示される方法のステップは、本開示の技法から逸脱することなく、異なる順序でまたは並行して実行されてもよく、追加のステップが追加されたり、いくつかのステップが省略されたりしてもよい。
[0171]上記で説明したように、ビデオエンコーダ20は、現在のブロックについてのコーディングコンテキストを決定する(120B)。同様に、ビデオエンコーダ20は、ブロックについてのコーディングコンテキストに基づいて、変更されたイントラ予測モードインデックステーブルを選択する(122BA)。ビデオエンコーダ20の構成データは、ブロックのコンテキストについての、変更されたイントラ予測モードインデックステーブルの、および、いくつかの例では、イントラ予測モードインデックステーブルの指示を提供することができる。さらに、ビデオエンコーダ20は、ブロックについてのコーディングコンテキストに基づいてブロックの符号化に使用するための第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定する(124B)。この場合も、ビデオエンコーダ20の構成データは、ブロックのコンテキストについての最も可能性の高いイントラ予測モードの指示を提供することができる。
[0172]上記で説明したように、ビデオエンコーダ20は、ブロックの実際の符号化に使用するために、ブロックについてのイントラ予測モードを選択する(126B)。ビデオエンコーダ20は、選択されたイントラ予測モードが、ブロックのコンテキストに基づいて、ブロックについての最も可能性の高いイントラ予測モードのうちの1つと同じであるかどうかを決定する(128B)。選択されたモードが最も可能性の高いモードである場合(128Bの「YES」分岐)、ビデオエンコーダ20は、最も可能性の高いモードに基づいて、たとえば、実際のモードが最も可能性の高いモードのうちの1つであることを示す第1のビット、および最も可能性の高いモードのうちどれが実際のモードであるかを示す第2のビットを含む2ビットなど、最初の一連のビットを使用してブロックの符号化に使用されるイントラ予測モードの指示を符号化する(130B)。
[0173]選択されたモードが最も可能性の高いモードのうちの1つではないとき(128Bの「NO」分岐)、ビデオエンコーダ20は、たとえば、イントラ予測モードインデックステーブルから、選択されたイントラ予測モードのためのモードインデックスを決定する(122B)。いくつかの例では、モードインデックスは、コンテキストに関係なく、グローバルな値でもよく、一方、他の例では、ビデオエンコーダ20の構成データは、各コンテキストを複数のイントラ予測モードインデックステーブルのうちの1つにマッピングすることができる。ビデオエンコーダ20は、最も可能性の高いイントラ予測モードについてのモードインデックスをさらに決定する。次いで、ビデオエンコーダ20は、選択されたイントラ予測モードについてのモードインデックスがブロックのコンテキストにおいて第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるかどうかを決定する(134B)。
[0174]選択されたイントラ予測モードについてのモードインデックスが両方の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき(134Bの「YES」分岐)、ビデオエンコーダ20は、選択されたイントラ予測モードについてのモードインデックスに対応するブロックのコンテキストについての変更されたイントラ予測モードインデックステーブルからコードワードを決定する。より詳細には、ビデオエンコーダ20は、選択されたイントラ予測モードについてのモードインデックスに等しい変更されたイントラ予測モードインデックスにマッピングされたコードワードを使用する(136B)。
[0175]一方、選択されたイントラ予測モードについてのモードインデックスが両方の最も可能性の高いイントラ予測モードについてのモードインデックス以上であるとき(134Bの「NO」分岐)、ビデオエンコーダ20は、選択されたイントラ予測モードについてのモードインデックスが、ブロックのコンテキストにおける第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードについてのモードインデックス以上であるかどうかを決定する(138B)。選択されたイントラ予測モードについてのモードインデックスが両方の最も可能性の高いイントラ予測モードについてのモードインデックス以上であるとき(138Bの「YES」分岐)、当該ブロックのコンテキストについての変更されたイントラ予測モードインデックステーブルから、ビデオエンコーダ20は、選択されたイントラ予測モードについてのモードインデックスに対応するコードワードを決定する。より詳細には、ビデオエンコーダ20は、当該ブロックのコンテキストについての変更されたイントラ予測モードインデックステーブルから、選択されたイントラ予測モードについてのモードインデックスよりも2小さいものに対応するコードワードを決定する。より詳細には、ビデオエンコーダ20は、CABACプロセスを使用して、選択されたイントラ予測モードについてのモードインデックスよりも2小さいものに等しい変更されたイントラ予測モードインデックスにマッピングされたコードワードを出力することができる(140B)。
[0176]選択されたイントラ予測モードについてのモードインデックスが両方の最も可能性の高いイントラ予測モードについてのモードインデックス以上であるとき(134Bの「NO」分岐)、および選択されたイントラ予測モードについてのモードインデックスが両方の最も可能性の高いイントラ予測モードについてのモードインデックス以上ではないとき(138Bの「NO」分岐)、選択されたイントラ予測モードについてのモードインデックスは、第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であるが、第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満である(138Bの「NO」分岐)。選択されたイントラ予測モードについてのモードインデックスが第1の最も可能性の高いイントラ予測モードについてのモードインデック以上であるが、第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、ビデオエンコーダ20は、当該ブロックのコンテキストについての変更されたイントラ予測モードインデックステーブルから、選択されたイントラ予測モードについてのモードインデックスに対応するコードワードを決定する。より詳細には、ビデオエンコーダ20は、CABACプロセスを使用して、選択されたイントラ予測モードについてのモードインデックスよりも1小さいものに等しい変更されたイントラ予測モードインデックスにマッピングされたコードワードを出力する(142B)。
[0177]上記で説明した方法で最も可能性の高いモードをシグナリングするために第1のビットおよび第2のビットが使用されるので、変更されたイントラ予測モードインデックステーブルは、追加のコードワードを最も可能性の高いイントラ予測モードのインデックスにマッピングする必要はない。したがって、ブロックのために利用可能なイントラ予測モードがK個ある場合、変更されたイントラ予測モードインデックステーブルは、K−2個の変更されたイントラ予測モードインデックスについてのコードワードを提供するだけでよい。
[0178]図8は、ビデオデータのブロックをイントラ予測復号するための例示的な方法を示すフローチャートである。図8の技法は、一般に、ハードウェア、ソフトウェア、ファームウェア、またはそれらの組合せのいずれに実装されようと、任意の処理ユニットまたはプロセッサによって実行することができ、ソフトウェアまたはファームウェアに実装されるとき、ソフトウェアまたはファームウェアのための命令を実行するために、対応するハードウェアが提供され得る。例として、図8の技法は、ビデオデコーダ30(図1および図4)に関して説明するが、他のデバイスが同様の技法を実行するように構成され得ることを理解されたい。その上、図8に示されるステップは、本開示の技法から逸脱することなく、異なる順序でまたは並行して実行されてもよく、追加のステップが追加されたり、いくつかのステップが省略されたりしてもよい。
[0179]ビデオデコーダ30は、CABACプロセスを使用して、イントラ予測モードコード化ブロックについてのコードワードを決定する(150)。コードワードは、一般に、ブロックを符号化するために使用されるイントラ予測モードと、同様に、ブロックを復号するために使用されるイントラ予測モードとを表すことができる。ビデオデコーダ30は、たとえば、ブロックのサイズ、および/または上に隣接するブロックおよび/または左に隣接するブロックなど、隣接するブロックのイントラ予測モードに基づいて、ビデオエンコーダ20のものと同様の方法でブロックについてのコーディングコンテキストを決定する(152)。
[0180]ビデオデコーダ30は、ブロックについての決定されたコーディングコンテキストに基づいて、ブロックについての変更されたイントラ予測モードインデックステーブルをさらに選択する(154)。ビデオデコーダ30は、いくつかの例では、コンテキストに基づいてイントラ予測モードインデックステーブルを決定することができ、一方、他の例では、イントラ予測モードインデックスは、固定され、グローバルにすべてのコンテキストに適用することができる。ビデオデコーダ30は、ブロックのコンテキストについての1つまたは複数の最も可能性の高いイントラ予測モードをさらに決定する(156)。
[0181]次いで、ビデオデコーダ30は、選択されたコードワードテーブル、最も可能性の高いイントラ予測モード(複数可)、および受信されたコードワードを使用して、ブロックの復号に使用するために、実際のイントラ予測モードを決定する(158)。たとえば、選択されたモードが最も可能性の高いモードであるかどうかを示すシングルビットまたは一連のビットをコードワードが備える場合、ビデオデコーダ30は、シングルビットまたは一連のビットを使用して、最も可能性の高いイントラ予測モード(複数可)がブロックの復号に使用されるかどうかを決定する。選択されたモードが最も可能性の高いモードではないことが決定された場合、ビデオデコーダ30は、変更されたイントラ予測モードインデックステーブルを使用して、コードワードに基づいて、変更されたイントラ予測モードインデックスを決定し、変更されたイントラ予測モードインデックスに基づいて、ビデオデコーダ30は、ブロックの符号化に使用されるイントラ予測モードを決定する。
[0182]ビデオデコーダ30は、ブロックを復号するために、決定されたイントラ予測モードを使用する(160)。たとえば、ビデオデコーダ30は、決定されたイントラ予測モードを使用して、ブロックについての予測ブロックを計算する。ビデオデコーダ30は、ブロックについての残差ブロックを再構築するために、ビデオデコーダ30が復号し、逆量子化し、および逆変換し得るコード化された量子化変換係数をさらに受信する。次いで、ビデオデコーダ30は、予測ブロックおよび残差ブロックを合計して、復号されたブロックを形成する。ビデオデコーダ30は、復号されたブロックを出力し(162)、これは、復号されたビデオブロックを表示のためのディスプレイデバイスに(たとえば、フレームバッファを介して)送ることと、たとえば時間的に別々のフレームまたはスライスにおいて、ビデオデータの後続のブロックを復号するとき、参照ブロックとして使用するために、参照フレームバッファに復号されたブロックのコピーを記憶することと、のいずれかまたは両方を含み得る。
[0183]図9Aは、コード化ブロックについてのイントラ予測モードを示す受信されたコードワードを使用して、ブロックについてのイントラ予測モードを決定するための例示的な方法を示すフローチャートである。この場合も、図9Aの技法は、任意の適したプロセッサにおいて実施することができるが、図9Aの技法は、例として、および説明のために、ビデオデコーダ30の例に関して説明する。図9Aは、一般に、図8のステップ160についての追加の詳細を提供する。図9Aに示される方法のステップは、本開示の技法から逸脱することなく、異なる順序でまたは並行して実行されてもよく、追加のステップが追加されたり、いくつかのステップが省略されたりしてもよい。
[0184]ビデオデコーダ30は、CABACプロセスを使用して、イントラコード化されたブロックについてのコードワードを決定する(170A)。上記で説明したように、ビデオデコーダ30は、たとえば、ブロックのサイズ、および/または隣接するブロックのイントラ予測コード化モードに基づいて、ブロックについてのコーディングコンテキストを決定する(172A)。決定されたコンテキストに基づいて、ビデオデコーダ30は、ブロックについての変更されたイントラ予測モードインデックステーブルを選択し(174A)、ブロックについての最も可能性の高いイントラ予測モードを決定する(176A)。いくつかの例では、ビデオデコーダ30は、決定されたコンテキストに基づいてブロックについてのイントラ予測モードインデックステーブルをさらに選択することができる。
[0185]ビデオデコーダ30は、選択されたイントラ予測モードが最も可能性の高いモードであることを、コードワードにおける第1のビットが示すかどうかを決定する。選択されたイントラ予測モードが最も可能性の高いモードである場合(178Aの「YES」分岐)、ビデオデコーダ30は、最も可能性の高いイントラ予測モードを使用して、ブロックを復号する(180A)。一方、選択されたイントラ予測モードが最も可能性の高いモード以外のイントラ予測モードである場合(178Aの「NO」分岐)、ビデオデコーダ30は、選択された変更されたイントラ予測モードインデックステーブルからのコードワードに基づいて変更されたイントラ予測モード(MIPM)インデックスを決定する(182A)。
[0186]次いで、ビデオデコーダ30は、変更されたイントラ予測モードインデックスがブロックのコンテキストについての最も可能性の高いイントラ予測モードについてのモードインデックス未満であるかどうかを決定する(184A)。変更されたイントラ予測モードインデックスが、最も可能性の高いイントラ予測モードについてのモードインデックス未満である場合(184Aの「YES」分岐)、ビデオデコーダ30は、変更されたイントラ予測モードインデックスに等しいモードインデックスを有するイントラ予測モードを使用してブロックを復号する(186A)。一方、変更されたイントラ予測モードインデックスが、最も可能性の高いイントラ予測モードについてのモードインデックス以上である場合(184Aの「NO」分岐)、ビデオデコーダ30は、変更されたイントラ予測モードインデックスよりも1大きいものに等しいモードインデックスを有するイントラ予測モードを使用してブロックを復号する(188A)。
[0187]図9Bは、コード化ブロックについてのイントラ予測モードを示す受信されたコードワードを使用して、ブロックについてのイントラ予測モードを決定するための例示的な方法を示すフローチャートである。この場合も、図9Bの技法は、任意の適したプロセッサにおいて実施することができるが、図9Bの技法は、例として、および説明のために、ビデオデコーダ30の例に関して説明する。図9Bは、一般に、2つ以上の最も可能性の高いモードが使用される例について、図8のステップ160の追加の詳細を提供する。図9Bに示される方法のステップは、本開示の技法から逸脱することなく、異なる順序でまたは並行して実行されてもよく、追加のステップが追加されたり、いくつかのステップが省略されたりしてもよい。
[0188]ビデオデコーダ30は、CABACプロセスを使用して、イントラコード化されたブロックについてのコードワードを決定する(170B)。上記で説明したように、ビデオデコーダ30は、たとえば、ブロックのサイズ、および/または隣接するブロックのイントラ予測コード化モードに基づいて、ブロックについてのコーディングコンテキストを決定する(172B)。決定されたコンテキストに基づいて、ビデオデコーダ30は、ブロックについての変更されたイントラ予測モードインデックステーブルを選択し(174B)、ブロックについての最も可能性の高いイントラ予測モードを決定する(176B)。いくつかの例では、ビデオデコーダ30は、決定されたコンテキストに基づいてブロックについてのイントラ予測モードインデックステーブルをさらに選択することができる。
[0189]ビデオデコーダ30は、選択されたイントラ予測モードが最も可能性の高いモードのうちの1つであることを、コードワードにおける第1のビットまたは一連のビットが示すかどうかを決定する。選択されたモードが最も可能性の高いモードのうちの1つである場合(178Bの「はい」分岐)、ビデオデコーダ30は、最も可能性の高いイントラ予測モードを使用して、ブロックを復号する(180B)。ビデオデコーダ30は、たとえば、最も可能性の高いモードのうちのどれが選択されたモードであるかを示すために、第2のビットまたは一連のビットを受信することができる。一方、選択されたモードが最も可能性の高いモードのうちの1つではないことを第1のビットまたは一連のビットが示す場合(178Bの「NO」分岐)、ビデオデコーダ30は、選択された変更されたイントラ予測モードインデックステーブルからのコードワードに基づいて変更されたイントラ予測モード(MIPM)インデックスを決定することができる(182B)。
[0190]次いで、ビデオデコーダ30は、変更されたイントラ予測モードインデックスがブロックのコンテキストについての第1の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるかどうかを決定する(184B)。上記に説明されるように、第1の最も可能性の高いモードについてのモードインデックスが第2の最も可能性の高いモードについてのモードインデックスよりも低いと仮定される。したがって、変更されたイントラ予測モードインデックスは、第1の最も可能性の高いイントラ予測モードについてのモードインデックスよりも低い場合、第2の最も可能性の高いイントラ予測モードについてのモードインデックスよりも低い。変更されたイントラ予測モードインデックスが第1の最も可能性の高いイントラ予測モードについてのモードインデックス未満である場合(184Bの「YES」分岐)、ビデオデコーダ30は、変更されたイントラ予測モードインデックスに等しいモードインデックスを有するイントラ予測モードを使用してブロックを復号する(186B)。変更されたイントラ予測モードインデックスが第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上である場合(184Bの「NO」分岐)、ビデオデコーダ30は、変更されたイントラ予測モードインデックス+1がブロックのコンテキストについての第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるかどうかを決定する(188B)。変更されたイントラ予測モードインデックス+1がブロックのコンテキストについての第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満である場合(188Bの「YES」分岐)、ビデオデコーダ30は、変更されたイントラ予測モードインデックスよりも1大きいものに等しいモードインデックスを有するイントラ予測モードを使用してブロックを復号する(190B)。
[0191]変更されたイントラ予測モードインデックスが第2の最も可能性の高いイントラ予測モードについてのモードインデックス以上である場合(188Bの「NO」分岐)、ビデオデコーダ30は、変更されたイントラ予測モードインデックスよりも2大きいものに等しいモードインデックスを有するイントラ予測モードを使用してブロックを復号する(192B)。
[0192]図6、図7A、図7B、図8、図9A、および図9Bの方法は、モードインデックスに対して変更されたイントラ予測モードインデックスをマッピングすることに関して示されているが、表5および表6の例に関して、上記で説明した方法で、変更されたコードワードインデックスをコードワードインデックスに、またはその逆にマッピングするために、方法の基礎をなす技法を使用することもできることを理解されたい。
[0193]図10は、イントラ予測モードインデックステーブル200と変更されたイントラ予測モードインデックステーブル210とコンテキストデータ220との間の関係を示す構成データ250の組の一例を示す概念図である。構成データ250は、一般に、構成データ66(図2)または構成データ84(図4)に対応し得る。その上、コンテキスト、テーブル、および最も可能性の高いイントラ予測モードを記述する構成データは、所与のビットストリームについてのエンコーダとデコーダの両方で同じでなければならない。
[0194]図10の例では、イントラ予測モードインデックステーブル200は、1組のイントラ予測モード2021〜202K(イントラ予測モード202)と、対応するインデックス2041〜204Kとを含む。説明のために、および例として、イントラ予測モードインデックステーブル200が1つのみ示されているが、構成データ250は、イントラ予測モードインデックステーブル200に類似した複数のイントラ予測モードインデックステーブルを含み得ることを理解されたい。ブロックに利用可能なイントラ予測モードの数は、たとえば表5に関して上記で説明したように、ブロックのサイズに依存し得るので、イントラ予測モードインデックステーブルは、すべてが同じサイズを有する必要はない。インデックス204は、イントラ予測モードインデックス、または単にモードインデックスとも呼ばれ得る。
[0195]変更されたイントラ予測モードインデックステーブル210は、インデックス2121〜212K-1、ならびにコードワード2141〜214K-1を含む。このようにして、変更されたイントラ予測モードインデックステーブル210は、イントラモードインデックステーブル200(K)よりも1つ少ないエントリ(K−1)を備える。上記で説明したように、最も可能性の高いイントラ予測モードは、コードワード214のうちの1つではなく、シングルビットまたは一連のビットを使用して示され得る。したがって、最も可能性の高いイントラ予測モード以外のイントラ予測モードは、コードワード214のうちの1つによって表すことができる。この場合も、図10の例には、変更されたイントラ予測モードインデックステーブルが1つのみ示されているが、構成データ250は、複数の変更されたイントラ予測モードインデックステーブルを含むことができることを理解されたい。さらに、変更されたイントラ予測モードインデックステーブルの数は、必ずしもイントラモードインデックステーブルの数に等しい必要はない。いくつかの例では、同じモードインデックステーブルが1つまたは複数のイントラモードインデックステーブルに対応し得るように、イントラモードインデックステーブルと変更されたイントラ予測モードインデックステーブルとの間に多対1の関係があり得る。
[0196]さらに、構成データ250は、コンテキストエントリ222Aに類似した複数のコンテキストエントリを含むコンテキストデータ220を含む。この例では、コンテキストエントリ222Aは、最も可能性の高いイントラモードインジケータ224Aと、イントラ予測モードインデックステーブル識別子226Aと、変更されたイントラ予測モードインデックステーブル識別子228Aと、ブロックコンテキストデータ230Aとを含む。ブロックコンテキストデータ230Aは、コンテキストエントリ222Aが該当するブロックを示す情報を含み得る。たとえば、ブロックコンテキストデータ230Aは、コンテキストエントリ222Aが該当するブロックの1つまたは複数のサイズ、ならびにコンテキストエントリ222Aが該当するブロックの隣接するブロックについてのイントラ予測モードを記述する情報を含み得る。一例として、コンテキストエントリ222のうちの1つのブロックコンテキストデータは、コンテキストエントリが16×16のピクセルを有するブロックに対応することを示し、この場合、上に隣接するブロックは、水平のイントラ予測モードを使用して符号化され、左に隣接するブロックも、水平のイントラ予測モードを使用して符号化される。
[0197]最も可能性の高いイントラモードインジケータ224Aは、この例では、イントラ予測モード202Mを示す。いくつかの例では、構成データ250は、あるブロックが、最も可能性の高いイントラ予測モードを使用して符号化されることを表すために使用するためのシングルビットのコードワードを指定することができる。したがって、ブロックコンテキストデータ230Aに対応するコンテキストを有するブロックでは、この例では、最も可能性の高いイントラ予測モードは、イントラ予測モード202Mである。イントラ予測モード202Mはコンテキストエントリ222Aについての最も可能性の高いイントラ予測モードであるので、イントラ予測モード202Mは、変更されたイントラ予測モードインデックステーブル210におけるコードワード214のうちの1つにマッピングされる必要はなく、したがって、イントラモードインデックステーブル200におけるイントラ予測モード202よりも、変更されたイントラ予測モードインデックステーブル210に1つ少ないコードワードがあり得る。
[0198]その上、この例では、モードインデックス204M未満であるモードインデックス204、すなわち、モードインデックス2041〜204M-1は、変更されたイントラ予測モードインデックステーブル210の等しく評価された変更されたイントラ予測モードインデックス212にマッピングされる。たとえば、この例では、モードインデックス2042がモードインデックス204M未満であるため、モードインデックス2042は、変更されたイントラ予測モードインデックス2122にマッピングされる。したがって、ビデオエンコーダ20がイントラ予測モード2022を使用してブロックコンテキストデータ230Aによって定義されるコンテキストを有するブロックを符号化するとき、ビデオエンコーダ20は、コードワード2142を使用して、ブロックについてのイントラ予測モードをシグナリングすることができる。同様に、ビデオデコーダ30がブロックコンテキストデータ230Aによって定義されるコンテキストを有するブロックについてのコードワード2142を受信するとき、ビデオデコーダ30は、ブロックの符号化に使用されるイントラ予測モード(および、同様に、ブロックの復号に使用されるイントラ予測モード)がイントラ予測モード2022を備えることを決定することができる。同様に、モードインデックス204M-1が変更されたイントラ予測モードインデックス212M-1にマッピングされるため、イントラ予測モード202M-1は、コードワード214M-1にマッピングされる。
[0199]一方、モードインデックス204Mよりも大きいモードインデックス204、すなわち、この例では、モードインデックス204M-1〜204Kは、モードインデックスよりも1小さい変更されたイントラ予測モードインデックス212にマッピングされる。たとえば、この例では、モードインデックス204K-1がモードインデックス204Mよりも大きいため、モードインデックス204K-1は、変更されたイントラ予測モードインデックス212K-2にマッピングされる。したがって、ビデオエンコーダ20がイントラ予測モード202K-1を使用してブロックコンテキストデータ230Aによって定義されるコンテキストを有するブロックを符号化するとき、ビデオエンコーダ20は、コードワード214K-2を使用して、ブロックについてのイントラ予測モードをシグナリングすることができる。同様に、ビデオデコーダ30がブロックコンテキストデータ230Aによって定義されるコンテキストを有するブロックについてのコードワード214K-2を受信するとき、ビデオデコーダ30は、ブロックの符号化に使用されるイントラ予測モード(および、同様に、ブロックの復号に使用されるイントラ予測モード)がイントラ予測モード202K-1を備えることを決定することができる。同様に、モードインデックス204M+1が変更されたイントラ予測モードインデックス212Mにマッピングされるため、イントラ予測モード202M+1は、コードワード214Mにマッピングされる。
[0200]このように、モードインデックスjにマッピングされるイントラ予測モードが与えられると、ビデオエンコーダ20は、以下のステップ関数f(j)を使用して、最も可能性の高いモード以外のイントラ予測モードについてのコードワードを決定することができ、式中、mは最も可能性の高いイントラ予測モードについてのモードインデックスを表し、コードワード(n)は変更されたイントラ予測モードインデックスnに割り当てられるコードワードを表す。
[0201]同様に、最も可能性の高いモードでない選択されたイントラ予測モードについてのコードワードが与えられると、ビデオデコーダ30は、以下のステップ関数g(n)を使用して、コードワードにマッピングされるイントラ予測モードを決定することができ、式中、mは最も可能性の高いイントラ予測モードについてのモードインデックスを表し、モード(j)はモードインデックスjにマッピングされるイントラコーディングモードを指す。
[0202]これらの概念が、2つの最も可能性の高いモードが使用される例に拡張されるとき、モードインデックスjにマッピングされるイントラコーディングモードが与えられると、ビデオエンコーダ20は、以下のステップ関数f(j)を使用して、コードワードを決定することができ、式中、m1は第1の最も可能性の高いイントラ予測モードについてのモードインデックスを表し、m2は第2の最も可能性の高いイントラ予測モードについてのモードインデックスを表し、コードワード(n)は変更されたイントラ予測モードインデックスnに割り当てられるコードワードを表す。
[0203]同様に、コードワードが与えられると、ビデオデコーダ30は、以下のステップ関数g(n)を使用して、コードワードにマッピングされるイントラ予測モードを決定することができ、式中、m1は第1の最も可能性の高いイントラ予測モードについてのモードインデックスを表し、m2は第2の最も可能性の高いイントラ予測モードについてのモードインデックスを表し、モード(j)はモードインデックスjにマッピングされるイントラ予測モードを指す。
[0204]1つまたは複数の例では、説明した機能は、ハードウェア、ソフトウェア、ファームウェア、またはそれらの任意の組合せで実装され得る。ソフトウェアで実装される場合、機能は、1つまたは複数の命令またはコードとしてコンピュータ可読媒体上に記憶されるか、あるいはコンピュータ可読媒体を介して送信され、ハードウェアベースの処理ユニットによって実行され得る。コンピュータ可読媒体は、たとえば、通信プロトコルに従って、ある場所から別の場所へのコンピュータプログラムの転送を可能にする任意の媒体を含むデータ記憶媒体または通信媒体などの有形媒体に対応するコンピュータ可読記憶媒体を含み得る。このようにして、コンピュータ可読媒体は、概して、(1)非一時的(non-transitory)である有形(tangible)コンピュータ可読記憶媒体、あるいは(2)信号または搬送波などの通信媒体に対応し得る。データ記憶媒体は、本開示で説明した技法の実装のための命令、コードおよび/またはデータ構造を取り出すために1つまたは複数のコンピュータあるいは1つまたは複数のプロセッサによってアクセスされ得る任意の利用可能な媒体であり得る。コンピュータプログラム製品はコンピュータ可読媒体を含み得る。
[0205]限定ではなく例として、そのようなコンピュータ可読記憶媒体は、RAM、ROM、EEPROM、CD−ROMまたは他の光ディスクストレージ、磁気ディスクストレージ、または他の磁気ストレージデバイス、フラッシュメモリ、あるいは命令またはデータ構造の形態の所望のプログラムコードを記憶するために使用され得、コンピュータによってアクセスされ得る、任意の他の媒体を備えることができる。また、いかなる接続もコンピュータ可読媒体と適切に呼ばれる。たとえば、命令が、同軸ケーブル、光ファイバーケーブル、ツイストペア、デジタル加入者回線(DSL)、または赤外線、無線、およびマイクロ波などのワイヤレス技術を使用して、ウェブサイト、サーバ、または他のリモートソースから送信される場合、同軸ケーブル、光ファイバーケーブル、ツイストペア、DSL、または赤外線、無線、およびマイクロ波などのワイヤレス技術は、媒体の定義に含まれる。ただし、コンピュータ可読記憶媒体およびデータ記憶媒体は、接続、搬送波、信号、または他の一時的媒体を含まないが、代わりに非一時的有形記憶媒体を対象とすることを理解されたい。本明細書で使用するディスク(disk)およびディスク(disc)は、コンパクトディスク(disc)(CD)、レーザディスク(disc)、光ディスク(disc)、デジタル多用途ディスク(disc)(DVD)、フロッピー(登録商標)ディスク(disk)、およびブルーレイディスク(disc)を含み、ディスク(disk)は、通常、データを磁気的に再生し、ディスク(disc)は、データをレーザで光学的に再生する。上記の組合せもコンピュータ可読媒体の範囲内に含めるべきである。
[0206]命令は、1つまたは複数のデジタル信号プロセッサ(DSP)などの1つもしくは複数のプロセッサ、汎用マイクロプロセッサ、特定用途向け集積回路(ASIC)、フィールドプログラマブル論理アレイ(FPGA)、または他の等価な集積回路もしくはディスクリート論理回路によって実行され得る。したがって、本明細書で使用する「プロセッサ」という用語は、前述の構造、または本明細書で説明する技法の実装に好適な他の構造のいずれかを指す。さらに、いくつかの態様では、本明細書で説明した機能は、符号化および復号のために構成された専用のハードウェアおよび/またはソフトウェアモジュール内に与えられ得、あるいは複合コーデックに組み込まれ得る。また、本技法は、1つまたは複数の回路または論理要素中に十分に実装され得る。
[0207]本開示の技法は、ワイヤレスハンドセット、集積回路(IC)またはICのセット(たとえば、チップセット)を含む、多種多様なデバイスまたは装置において実施され得る。本開示では、開示する技法を実行するように構成されたデバイスの機能的態様を強調するために様々な構成要素、モジュール、またはユニットについて説明したが、それらの構成要素、モジュール、またはユニットを、必ずしも異なるハードウェアユニットによって実現する必要はない。むしろ、上記で説明したように、様々なユニットが、好適なソフトウェアおよび/またはファームウェアとともに、上記で説明した1つまたは複数のプロセッサを含めて、コーデックハードウェアユニットにおいて組み合わせられるか、または相互動作ハードウェアユニットの集合によって与えられ得る。
[0208]様々な例について説明した。これらおよび他の例は以下の特許請求の範囲内に入る。

Claims (76)

  1. ビデオデータを復号する方法であって、
    現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定することと、
    前記現在のブロックの前記コンテキストに基づいてコードワードのテーブルを選択することと、コードワードの前記テーブルは、前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、
    受信されたコードワードを決定するために、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することと、
    コードワードの前記テーブルを使用して前記受信されたコードワードに対応する前記変更されたイントラ予測モードインデックスのうちの1つを決定することと、
    前記コード化ブロックの復号に使用するために、前記第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択することと、前記選択されたイントラ予測モードは、前記変更されたイントラ予測モードインデックスのうちの前記決定された1つに対応し、
    前記選択されたイントラ予測モードを使用して、前記現在のブロックを復号することと、
    を備える方法。
  2. 前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのイントラ予測モードに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定することをさらに備える、請求項1に記載の方法。
  3. 前記コード化ブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定することをさらに備える、請求項1に記載の方法。
  4. 前記イントラ予測モードの各々がそれぞれのモードインデックスに対応する、請求項1に記載の方法。
  5. 前記変更されたイントラ予測モードインデックスのうちの前記決定された1つのモードインデックス+1が前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス以上であるとき、前記イントラ予測モードを選択することは、前記変更されたイントラ予測モードインデックスよりも2大きいモードインデックスに対応する前記イントラ予測モードを選択することを備える、請求項4に記載の方法。
  6. 前記変更されたイントラ予測モードインデックスのうちの前記決定された1つが前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス未満であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記イントラ予測モードを選択することは、前記変更されたイントラ予測モードインデックスに等しいモードインデックスを有する前記イントラ予測モードを選択することを備える、請求項4に記載の方法。
  7. 前記変更されたイントラ予測モードインデックスのうちの前記決定された1つのモードインデックス+1が前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記イントラ予測モードを選択することは、前記変更されたイントラ予測モードインデックスよりも1大きいモードインデックスに対応する前記イントラ予測モードを選択することを備える、請求項4に記載の方法。
  8. ビデオデコーダを備え、前記ビデオデコーダは、
    現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、
    前記現在のブロックのコンテキストに基づいてコードワードのテーブルを選択し、コードワードの前記テーブルは、前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、
    受信されたコードワードを決定するために、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行し、
    コードワードの前記テーブルを使用して前記受信されたコードワードに対応する前記変更されたイントラ予測モードインデックスのうちの1つを決定し、
    前記コード化ブロックの復号に使用するために、前記第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択し、前記選択されたイントラ予測モードは、前記変更されたイントラ予測モードインデックスのうちの前記決定された1つに対応し、
    前記選択されたイントラ予測モードを使用して、前記現在のブロックを復号する
    ように構成される、ビデオデータを復号するための装置。
  9. 前記ビデオデコーダは、前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのイントラ予測モードに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定するようにさらに構成される、請求項8に記載の装置。
  10. 前記ビデオデコーダは、前記コード化ブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定するようにさらに構成される、請求項8に記載の装置。
  11. 前記イントラ予測モードの各々がそれぞれのモードインデックスに対応する、請求項8に記載の装置。
  12. 前記変更されたイントラ予測モードインデックスのうちの前記決定された1つのモードインデックス+1が前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス以上であるとき、前記イントラ予測モードを選択することは、前記変更されたイントラ予測モードインデックスよりも2大きいモードインデックスに対応する前記イントラ予測モードを選択することを備える、請求項11に記載の装置。
  13. 前記変更されたイントラ予測モードインデックスのうちの前記決定された1つが前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス未満であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記ビデオデコーダは、前記変更されたイントラ予測モードインデックスに等しいモードインデックスを有する前記イントラ予測モードを選択することによって、前記イントラ予測モードを選択するようにさらに構成される、請求項11に記載の装置。
  14. 前記変更されたイントラ予測モードインデックスのうちの前記決定された1つのモードインデックス+1が前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記イントラ予測モードを選択することは、前記変更されたイントラ予測モードインデックスよりも1大きいモードインデックスに対応する前記イントラ予測モードを選択することを備える、請求項11に記載の装置。
  15. 前記装置は、
    集積回路と、
    マイクロプロセッサと、
    前記ビデオデコーダを含むワイヤレス通信デバイスと、
    のうちの少なくとも1つを備える、請求項8に記載の装置。
  16. ビデオデータを符号化する方法であって、
    現在のブロックの符号化コンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定することと、
    前記現在のブロックの前記コンテキストに基づいてコードワードのテーブルを選択することと、コードワードの前記テーブルは、前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、
    前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外の前記イントラ予測モードのうちの1つを使用して、前記現在のブロックを符号化することと、
    コードワードの前記テーブルを使用して前記イントラ予測モードのうちの前記1つに対応する前記変更されたイントラ予測モードインデックスのうちの1つを決定することと、
    コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することによって、前記選択されたコードワードのテーブルから、前記変更されたイントラ予測モードインデックスのうちの前記1つに対応するコードワードを符号化することと、
    を備える方法。
  17. 前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのモードに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定することをさらに備える、請求項16に記載の方法。
  18. 前記現在のブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定することをさらに備える、請求項16に記載の方法。
  19. 前記イントラ予測モードの各々がそれぞれのモードインデックスに対応する、請求項16に記載の方法。
  20. 前記イントラ予測モードのうちの1つについてのモードインデックスが前記第1の最も可能性の高いイントラ予測モードについてのモードインデックスよりも大きく、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックスよりも大きいとき、前記変更されたイントラ予測モードインデックスのうちの前記1つを決定することは、前記最も可能性の高いイントラ予測モードについての前記モードインデックスよりも2小さい前記変更されたイントラ予測モードインデックスのうちの1つを決定することを備える、請求項19に記載の方法。
  21. 前記イントラ予測モードのうちの1つについてのモードインデックスが前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス未満であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記変更されたイントラ予測モードインデックスのうちの前記1つを決定することは、前記最も可能性の高いイントラ予測モードについての前記モードインデックスに等しい前記変更されたイントラ予測モードインデックスのうちの1つを決定することを備える、請求項19に記載の方法。
  22. 前記イントラ予測モードのうちの1つについてのモードインデックスが前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記変更されたイントラ予測モードインデックスのうちの前記1つを決定することは、前記最も可能性の高いイントラ予測モードについての前記モードインデックスよりも1小さい前記変更されたイントラ予測モードインデックスのうちの1つを決定することを備える、請求項19に記載の方法。
  23. ビデオエンコーダを備え、前記ビデオエンコーダは、
    現在のブロックの符号化コンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、
    前記現在のブロックの前記コンテキストに基づいてコードワードのテーブルを選択し、コードワードの前記テーブルは、前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、
    前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外の前記イントラ予測モードのうちの1つを使用して、前記現在のブロックを符号化し、
    コードワードの前記テーブルを使用して前記イントラ予測モードのうちの1つに対応する前記変更されたイントラ予測モードインデックスのうちの1つを決定し、
    コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することによって、前記選択されたコードワードのテーブルからコードワードを符号化するように構成され、前記コードワードが前記変更されたイントラ予測モードインデックスのうちの前記1つに対応する、
    ビデオデータを符号化するための装置。
  24. 前記ビデオエンコーダは、前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのモードに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定するようにさらに構成される、請求項23に記載の装置。
  25. 前記ビデオエンコーダは、前記現在のブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定するようにさらに構成される、請求項23に記載の装置。
  26. 前記イントラ予測モードの各々がそれぞれのモードインデックスに対応する、請求項23に記載の装置。
  27. 前記イントラ予測モードのうちの1つについてのモードインデックスが前記第1の最も可能性の高いイントラ予測モードについてのモードインデックスよりも大きく、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックスよりも大きいとき、前記ビデオエンコーダは、前記最も可能性の高いイントラ予測モードについての前記モードインデックスよりも2小さい前記変更されたイントラ予測モードインデックスのうちの1つを決定することによって、前記変更されたイントラ予測モードインデックスのうちの前記1つを決定するようにさらに構成される、請求項26に記載の装置。
  28. 前記イントラ予測モードのうちの1つについてのモードインデックスが前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス未満であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記ビデオエンコーダは、前記最も可能性の高いイントラ予測モードについての前記モードインデックスに等しい前記変更されたイントラ予測モードインデックスのうちの1つを決定することによって、前記変更されたイントラ予測モードインデックスのうちの前記1つを決定するようにさらに構成される、請求項23に記載の装置。
  29. 前記イントラ予測モードのうちの1つについてのモードインデックスが前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記ビデオエンコーダは、前記最も可能性の高いイントラ予測モードについての前記モードインデックスよりも1小さい前記変更されたイントラ予測モードインデックスのうちの1つを決定することによって、前記変更されたイントラ予測モードインデックスのうちの前記1つを決定するようにさらに構成される、請求項23に記載の装置。
  30. 前記装置は、
    集積回路と、
    マイクロプロセッサと、
    前記ビデオデコーダを含むワイヤレス通信デバイスと、
    のうちの少なくとも1つを備える、請求項23に記載の装置。
  31. ビデオデータを復号するための装置であって、
    現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定する手段と、
    前記現在のブロックの前記コンテキストに基づいてコードワードのテーブルを選択する手段と、コードワードの前記テーブルは、前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、
    受信されたコードワードを決定するために、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行する手段と、
    コードワードの前記テーブルを使用して前記受信されたコードワードに対応する前記変更されたイントラ予測モードインデックスのうちの1つを決定する手段と、
    前記コード化ブロックの復号に使用するために、前記第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択する手段と、前記選択されたイントラ予測モードは、前記変更されたイントラ予測モードインデックスのうちの前記決定された1つに対応し、
    前記選択されたイントラ予測モードを使用して、前記現在のブロックを復号する手段と、
    を備える装置。
  32. 前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとの少なくとも1つについてのイントラ予測モードに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定する手段
    をさらに備える、請求項31に記載の装置。
  33. 前記コード化ブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定する手段
    をさらに備える、請求項31に記載の装置。
  34. ビデオデータを符号化するための装置であって、
    現在のブロックの符号化コンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定する手段と、
    前記現在のブロックの前記コンテキストに基づいてコードワードのテーブルを選択する手段と、コードワードの前記テーブルは、前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、
    前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外の前記イントラ予測モードのうちの1つを使用して、前記現在のブロックを符号化する手段と、
    コードワードの前記テーブルを使用して前記イントラ予測モードのうちの前記1つに対応する前記変更されたイントラ予測モードインデックスのうちの1つを決定する手段と、
    コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することによって、前記選択されたコードワードのテーブルからコードワードを符号化する手段と、前記コードワードは前記変更されたイントラ予測モードインデックスのうちの前記1つに対応する、
    を備える装置。
  35. 前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのモードに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定する手段
    をさらに備える、請求項34に記載の装置。
  36. 前記現在のブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定する手段
    をさらに備える、請求項34に記載の装置。
  37. 実行されると、1つまたは複数のプロセッサに、
    前記現在のブロックのコンテキストに基づいて、ビデオデータのコード化ブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定させ、
    前記現在のブロックの前記コンテキストに基づいてコードワードのテーブルを選択させ、コードワードの前記テーブルは、前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、
    受信されたコードワードを決定するために、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行させ、
    コードワードの前記テーブルを使用して前記受信されたコードワードに対応する前記変更されたイントラ予測モードインデックスのうちの1つを決定させ、
    前記コード化ブロックの復号に使用するために、前記第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択させ、前記選択されたイントラ予測モードは、前記変更されたイントラ予測モードインデックスのうちの前記決定された1つに対応し、
    前記選択されたイントラ予測モードを使用して、前記現在のブロックを復号させる
    命令を記憶するコンピュータ可読記憶媒体。
  38. 実行されると、1つまたは複数のプロセッサに、
    現在のブロックの符号化コンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定させ、
    前記現在のブロックの前記コンテキストに基づいてコードワードのテーブルを選択させ、コードワードの前記テーブルは、前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードに対応する変更されたイントラ予測モードインデックスに対応する複数のコードワードを備え、
    前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外の前記イントラ予測モードのうちの1つを使用して、前記現在のブロックを符号化させ、
    コードワードの前記テーブルを使用して前記イントラ予測モードのうちの前記1つに対応する前記変更されたイントラ予測モードインデックスのうちの1つを決定させ、
    コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することによって、前記選択されたコードワードのテーブルから、前記変更されたイントラ予測モードインデックスのうちの前記1つに対応するコードワードを符号化させる
    命令を記憶するコンピュータ可読記憶媒体。
  39. ビデオデータを復号する方法であって、
    現在のブロックのコンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定することと、
    前記現在のブロックの前記コンテキストに基づいて、コードワードのテーブルを選択することと、コードワードの前記テーブルは、コードワードインデックスに対応する複数のコードワードを備え、前記コードワードインデックスはイントラ予測モードにマッピングされ、
    受信されたコードワードを決定するために、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することと、
    コードワードの前記テーブルを使用して前記受信されたコードワードに対応する変更されたコードワードインデックスを決定することと、
    前記コード化ブロックの復号に使用するために、前記第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択することと、前記選択されたイントラ予測モードは、前記変更されたコードワードインデックス、前記第1の最も可能性の高いイントラ予測モード、および前記第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、
    前記選択されたイントラ予測モードを使用して、前記現在のブロックを復号することと、
    を備える方法。
  40. 前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのイントラ予測モードに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定することをさらに備える、請求項39に記載の方法。
  41. 前記コード化ブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定することをさらに備える、請求項39に記載の方法。
  42. 前記変更されたコードワードインデックス+1が前記第1の最も可能性の高いイントラ予測モードについてのコードワードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのコードワードインデックス以上であるとき、前記イントラ予測モードを選択することは、前記変更されたイントラ予測モードインデックスよりも2大きいコードワードインデックスに対応する前記イントラ予測モードを選択することを備える、請求項39に記載の方法。
  43. 前記変更されたコードワードインデックスが前記第1の最も可能性の高いイントラ予測モードについてのコードワードインデックス未満であり、前記第2の最も可能性の高いイントラ予測モードについてのコードワードインデックス未満であるとき、前記イントラ予測モードを選択することは、前記変更されたコードワードインデックスに等しいコードワードインデックスを有する前記イントラ予測モードを選択することを備える、請求項39に記載の方法。
  44. 前記変更されたコードワードインデックス+1が前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記イントラ予測モードを選択することは、前記変更されたイントラコードワードインデックスよりも1大きいコードワードインデックスに対応する前記イントラ予測モードを選択することを備える、請求項39に記載の方法。
  45. イントラ予測モードに対する前記コードワードインデックスのマッピングを動的に調整すること
    をさらに備える、請求項39に記載の方法。
  46. ビデオデコーダを備え、前記ビデオデコーダは、
    現在のブロックのコンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、
    前記現在のブロックの前記コンテキストに基づいて、コードワードのテーブルを選択し、コードワードの前記テーブルは、コードワードインデックスに対応する複数のコードワードを備え、前記コードワードインデックスはイントラ予測モードにマッピングされ、
    受信されたコードワードを決定するために、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行し、
    コードワードの前記テーブルを使用して前記受信されたコードワードに対応する変更されたコードワードインデックスを決定し、
    前記コード化ブロックの復号に使用するために、前記第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択し、前記選択されたイントラ予測モードは、前記変更されたコードワードインデックス、前記第1の最も可能性の高いイントラ予測モード、および前記第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、
    前記選択されたイントラ予測モードを使用して、前記現在のブロックを復号する
    ように構成される、ビデオデータを復号するための装置。
  47. 前記ビデオデコーダは、前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのイントラ予測モードに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定するようにさらに構成される、請求項46に記載の装置。
  48. 前記ビデオデコーダは、前記コード化ブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定するようにさらに構成される、請求項46に記載の装置。
  49. 前記変更されたコードワードインデックス+1が前記第1の最も可能性の高いイントラ予測モードについてのコードワードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのコードワードインデックス以上であるとき、前記イントラ予測モードを選択することは、前記変更されたイントラコードワードインデックスよりも2大きいコードワードインデックスに対応する前記イントラ予測モードを選択することを備える、請求項46に記載の装置。
  50. 前記変更されたコードワードインデックスが前記第1の最も可能性の高いイントラ予測モードについてのコードワードインデックス未満であり、前記第2の最も可能性の高いイントラ予測モードについてのコードワードインデックス未満であるとき、前記イントラ予測モードを選択することは、前記変更されたコードワードインデックスに等しいコードワードインデックスを有する前記イントラ予測モードを選択することを備える、請求項46に記載の装置。
  51. 前記変更されたコードワードインデックス+1が前記第1の最も可能性の高いイントラ予測モードについてのモードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードについてのモードインデックス未満であるとき、前記イントラ予測モードを選択することは、前記変更されたコードワードインデックスよりも1大きいコードワードインデックスに対応する前記イントラ予測モードを選択することを備える、請求項46に記載の装置。
  52. 前記ビデオデコーダは、イントラ予測モードに対する前記コードワードインデックスのマッピングを動的に調整するようにさらに構成される、請求項46に記載の装置。
  53. 前記装置は、
    集積回路と、
    マイクロプロセッサと、
    前記ビデオデコーダを含むワイヤレス通信デバイスと
    のうちの少なくとも1つを備える、請求項46に記載の装置。
  54. ビデオを復号するための装置であって、
    現在のブロックのコンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定する手段と、
    前記現在のブロックの前記コンテキストに基づいて、コードワードのテーブルを選択する手段と、コードワードの前記テーブルは、コードワードインデックスに対応する複数のコードワードを備え、前記コードワードインデックスはイントラ予測モードにマッピングされ、
    受信されたコードワードを決定するために、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行する手段と、
    コードワードの前記テーブルを使用して前記受信されたコードワードに対応する変更されたコードワードインデックスを決定するための手段と、
    前記コード化ブロックの復号に使用するために、前記第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択する手段と、前記選択されたイントラ予測モードは、前記変更されたコードワードインデックス、前記第1の最も可能性の高いイントラ予測モード、および前記第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、
    前記選択されたイントラ予測モードを使用して、前記現在のブロックを復号する手段と、
    を備える装置。
  55. 前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのイントラ予測モードに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定する手段をさらに備える、請求項54に記載の装置。
  56. 前記コード化ブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記コンテキストを決定する手段をさらに備える、請求項54に記載の装置。
  57. 実行されると、1つまたは複数のプロセッサに、
    現在のブロックのコンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定させ、
    前記現在のブロックの前記コンテキストに基づいて、コードワードのテーブルを選択させ、コードワードの前記テーブルは、コードワードインデックスに対応する複数のコードワードを備え、前記コードワードインデックスはイントラ予測モードにマッピングされ、
    受信されたコードワードを決定するために、コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行させ、
    コードワードの前記テーブルを使用して前記受信されたコードワードに対応する変更されたコードワードインデックスを決定させ、
    前記コード化ブロックの復号に使用するために、前記第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モード以外のイントラ予測モードを選択させ、前記選択されたイントラ予測モードは、前記変更されたコードワードインデックス、前記第1の最も可能性の高いイントラ予測モード、および前記第2の最も可能性の高いイントラ予測モードに基づいて選択されたコードワードインデックスに対応し、
    前記選択されたイントラ予測モードを使用して、前記現在のブロックを復号させる
    命令を記憶するコンピュータ可読記憶媒体。
  58. ビデオデータを符号化する方法であって、
    現在のブロックの符号化コンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定することと、
    前記現在のブロックの前記コンテキストに基づいて、コードワードのテーブルを選択することと、コードワードの前記テーブルは、コードワードインデックスに対応する複数のコードワードを備え、前記コードワードインデックスはイントラ予測モードにマッピングされ、
    前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外の前記イントラ予測モードのうちの1つを使用して、前記現在のブロックを符号化することと、
    前記現在のブロックを符号化するために使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックス、前記第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および前記第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定することと、
    コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することによって、前記選択されたコードワードのテーブルから、前記変更されたイントラ予測モードインデックスのうちの前記1つに対応するコードワードを符号化することと、
    を備える方法。
  59. 前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのモードに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定することをさらに備える、請求項58に記載の方法。
  60. 前記現在のブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定することをさらに備える、請求項58に記載の方法。
  61. 前記現在のブロックの符号化に使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックスが前記第1の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックスよりも大きく、前記第2の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックスよりも大きいとき、前記変更されたコードワードインデックスを決定することは、前記コードワードインデックスよりも2小さい前記変更されたコードワードインデックスを決定することを備える、請求項58に記載の方法。
  62. 前記現在のブロックの符号化に使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックスが、前記第1の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックス未満であり、前記第2の最も可能性の高いイントラ予測モードにマッピングされたモードインデックス未満であるとき、前記変更されたコードワードインデックスを決定することは、前記コードワードインデックスに等しい前記変更されたコードワードインデックスを決定することを備える、請求項58に記載の方法。
  63. 前記現在のブロックの符号化に使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックスが前記第1の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックス未満であるとき、前記変更されたコードワードインデックスを決定することは、前記コードワードインデックスよりも1小さい前記変更されたコードワードインデックスを決定することを備える、請求項58に記載の方法。
  64. イントラ予測モードに対する前記コードワードインデックスのマッピングを動的に調整すること
    をさらに備える、請求項58に記載の方法。
  65. ビデオエンコーダを備え、前記ビデオエンコーダは、
    現在のブロックの符号化コンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定し、
    前記現在のブロックの前記コンテキストに基づいて、コードワードのテーブルを選択し、コードワードの前記テーブルは、コードワードインデックスに対応する複数のコードワードを備え、前記コードワードインデックスはイントラ予測モードにマッピングされ、
    前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外の前記イントラ予測モードのうちの1つを使用して、前記現在のブロックを符号化し、
    前記現在のブロックを符号化するために使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックス、前記第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および前記第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定し、
    コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することによって、前記選択されたコードワードのテーブルから、前記変更されたイントラ予測モードインデックスのうちの前記1つに対応するコードワードを符号化するように構成される、
    ビデオデータを符号化するための装置。
  66. 前記ビデオエンコーダは、前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとの少なくとも1つについてのモードに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定するようにさらに構成される、請求項65に記載の装置。
  67. 前記ビデオエンコーダは、前記現在のブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定するようにさらに構成される、請求項65に記載の装置。
  68. 前記現在のブロックの符号化に使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックスが前記第1の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックスよりも大きく、前記第2の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックスよりも大きいとき、前記変更されたコードワードインデックスを決定することは、前記コードワードインデックスよりも2小さい前記変更されたコードワードインデックスを決定することを備える、請求項65に記載の装置。
  69. 前記現在のブロックの符号化に使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックスが、前記第1の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックス未満であり、前記第2の最も可能性の高いイントラ予測モードにマッピングされたモードインデックス未満であるとき、前記変更されたコードワードインデックスを決定することは、前記コードワードインデックスに等しい前記変更されたコードワードインデックスを決定することを備える、請求項65に記載の装置。
  70. 前記現在のブロックの符号化に使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックスが前記第1の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックス以上であり、前記第2の最も可能性の高いイントラ予測モードにマッピングされたコードワードインデックス未満であるとき、前記変更されたコードワードインデックスを決定することは前記コードワードインデックスよりも1小さい前記変更されたコードワードインデックスを決定することを備える、請求項65に記載の装置。
  71. イントラ予測モードに対する前記コードワードインデックスのマッピングを動的に調整すること
    をさらに備える、請求項65に記載の装置。
  72. 前記装置が、
    集積回路と、
    マイクロプロセッサと、
    前記ビデオデコーダを含むワイヤレス通信デバイスと
    のうちの少なくとも1つを備える、請求項65に記載の装置。
  73. ビデオを符号化するための装置であって、
    現在のブロックの符号化コンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定する手段と、
    前記現在のブロックの前記コンテキストに基づいて、コードワードのテーブルを選択する手段と、コードワードの前記テーブルは、コードワードインデックスに対応する複数のコードワードを備え、前記コードワードインデックスがイントラ予測モードにマッピングされ、
    前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外の前記イントラ予測モードのうちの1つを使用して、前記現在のブロックを符号化する手段と、
    前記現在のブロックを符号化するために使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックス、前記第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および前記第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定する手段と、
    コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することによって、前記選択されたコードワードのテーブルから、前記変更されたイントラ予測モードインデックスのうちの前記1つに対応するコードワードを符号化する手段と、
    を備える装置。
  74. 前記現在のブロックに対して左に隣接するブロックと前記現在のブロックに対して上に隣接するブロックとのうちの少なくとも1つについてのモードに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定する手段をさらに備える、請求項73に記載の装置。
  75. 前記現在のブロックのサイズに少なくとも部分的に基づいて、前記現在のブロックについての前記符号化コンテキストを決定する手段をさらに備える、請求項73に記載の装置。
  76. 実行されると、1つまたは複数のプロセッサに、
    現在のブロックの符号化コンテキストに基づいて、ビデオデータの前記現在のブロックについての第1の最も可能性の高いイントラ予測モードおよび第2の最も可能性の高いイントラ予測モードを決定させ、
    前記現在のブロックの前記コンテキストに基づいて、コードワードのテーブルを選択させ、コードワードの前記テーブルは、コードワードインデックスに対応する複数のコードワードを備え、前記コードワードインデックスはイントラ予測モードにマッピングされ、
    前記第1の最も可能性の高いイントラ予測モードおよび前記第2の最も可能性の高いイントラ予測モード以外の前記イントラ予測モードのうちの1つを使用して、前記現在のブロックを符号化させ、
    前記現在のブロックを符号化するために使用される前記イントラ予測モードのうちの前記1つの前記コードワードインデックス、前記第1の最も可能性の高いモードにマッピングされたコードワードインデックス、および前記第2の最も可能性の高いモードにマッピングされたコードワードインデックスに基づいて、変更されたコードワードインデックスを決定させ、
    コンテキストベース適応型バイナリ算術コーディング(CABAC)プロセスを実行することによって、前記選択されたコードワードのテーブルから、前記変更されたイントラ予測モードインデックスのうちの前記1つに対応するコードワードを符号化させる
    る命令を記憶するコンピュータ可読記憶媒体。
JP2013548543A 2011-01-06 2012-01-05 Cabacを使用したビデオコーディングのためのイントラ予測モード選択の指示 Active JP5731013B2 (ja)

Applications Claiming Priority (9)

Application Number Priority Date Filing Date Title
US201161430520P 2011-01-06 2011-01-06
US61/430,520 2011-01-06
US201161446402P 2011-02-24 2011-02-24
US61/446,402 2011-02-24
US201161448623P 2011-03-02 2011-03-02
US61/448,623 2011-03-02
US13/343,573 US8913662B2 (en) 2011-01-06 2012-01-04 Indicating intra-prediction mode selection for video coding using CABAC
US13/343,573 2012-01-04
PCT/US2012/020346 WO2012094506A1 (en) 2011-01-06 2012-01-05 Indicating intra-prediction mode selection for video coding using cabac

Publications (2)

Publication Number Publication Date
JP2014506067A true JP2014506067A (ja) 2014-03-06
JP5731013B2 JP5731013B2 (ja) 2015-06-10

Family

ID=46455223

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2013548543A Active JP5731013B2 (ja) 2011-01-06 2012-01-05 Cabacを使用したビデオコーディングのためのイントラ予測モード選択の指示

Country Status (17)

Country Link
US (1) US8913662B2 (ja)
EP (1) EP2661890B1 (ja)
JP (1) JP5731013B2 (ja)
KR (1) KR101518157B1 (ja)
CN (1) CN103299628B (ja)
AU (1) AU2012204302B2 (ja)
BR (1) BR112013017423B1 (ja)
CA (1) CA2823948C (ja)
DK (1) DK2661890T3 (ja)
ES (1) ES2692387T3 (ja)
HU (1) HUE039795T2 (ja)
IL (1) IL226974A (ja)
MY (1) MY164378A (ja)
RU (1) RU2554545C2 (ja)
SG (1) SG191201A1 (ja)
SI (1) SI2661890T1 (ja)
WO (1) WO2012094506A1 (ja)

Families Citing this family (56)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5732454B2 (ja) * 2009-07-06 2015-06-10 トムソン ライセンシングThomson Licensing 空間変化残差符号化を行う方法および装置
US11284072B2 (en) 2010-08-17 2022-03-22 M&K Holdings Inc. Apparatus for decoding an image
US9716886B2 (en) * 2010-08-17 2017-07-25 M&K Holdings Inc. Method for restoring an intra prediction mode
US20120163456A1 (en) * 2010-12-22 2012-06-28 Qualcomm Incorporated Using a most probable scanning order to efficiently code scanning order information for a video block in video coding
AU2011354441B2 (en) 2011-01-07 2014-07-17 Hfi Innovation Inc. Method and apparatus of improved intra luma prediction mode coding
WO2012134246A2 (ko) * 2011-04-01 2012-10-04 엘지전자 주식회사 엔트로피 디코딩 방법 및 이를 이용하는 디코딩 장치
KR101876173B1 (ko) * 2011-06-17 2018-07-09 엘지전자 주식회사 인트라 예측 모드 부호화/복호화 방법 및 장치
US8929455B2 (en) * 2011-07-01 2015-01-06 Mitsubishi Electric Research Laboratories, Inc. Method for selecting transform types from mapping table for prediction modes
WO2013039676A1 (en) 2011-09-13 2013-03-21 Mediatek Singapore Pte. Ltd. Method and apparatus for intra mode coding in hevc
KR102005468B1 (ko) * 2011-10-24 2019-10-01 (주)대가람 복원 블록을 생성하는 방법 및 장치
US9154796B2 (en) * 2011-11-04 2015-10-06 Qualcomm Incorporated Intra-mode video coding
US9088796B2 (en) * 2011-11-07 2015-07-21 Sharp Kabushiki Kaisha Video decoder with enhanced CABAC decoding
US20130114686A1 (en) * 2011-11-08 2013-05-09 Sharp Laboratories Of America, Inc. Video decoder with enhanced cabac motion vector decoding
JP2013126093A (ja) * 2011-12-14 2013-06-24 Sony Corp 画像処理装置及び画像処理方法
WO2013106986A1 (en) * 2012-01-16 2013-07-25 Mediatek Singapore Pte. Ltd. Methods and apparatuses of intra mode coding
AU2012200319B2 (en) 2012-01-19 2015-11-26 Canon Kabushiki Kaisha Method, apparatus and system for encoding and decoding the significance map for residual coefficients of a transform unit
AU2012200345B2 (en) * 2012-01-20 2014-05-01 Canon Kabushiki Kaisha Method, apparatus and system for encoding and decoding the significance map residual coefficients of a transform unit
WO2014005924A1 (en) * 2012-07-05 2014-01-09 Thomson Licensing Video coding and decoding method with adaptation of coding modes
WO2014110452A1 (en) * 2013-01-11 2014-07-17 Futurewei Technologies Co., Ltd. Method and apparatus of depth prediction mode selection
US9426473B2 (en) 2013-02-01 2016-08-23 Qualcomm Incorporated Mode decision simplification for intra prediction
US9148667B2 (en) 2013-02-06 2015-09-29 Qualcomm Incorporated Intra prediction mode decision with reduced storage
US9369708B2 (en) 2013-03-27 2016-06-14 Qualcomm Incorporated Depth coding modes signaling of depth data for 3D-HEVC
US9516306B2 (en) * 2013-03-27 2016-12-06 Qualcomm Incorporated Depth coding modes signaling of depth data for 3D-HEVC
US10904551B2 (en) * 2013-04-05 2021-01-26 Texas Instruments Incorporated Video coding using intra block copy
WO2014172387A1 (en) * 2013-04-15 2014-10-23 Huawei Technologies Co., Ltd. Method and apparatus of depth prediction mode selection
US9787989B2 (en) * 2013-06-11 2017-10-10 Blackberry Limited Intra-coding mode-dependent quantization tuning
AU2013403224B2 (en) 2013-10-14 2018-10-18 Microsoft Technology Licensing, Llc Features of intra block copy prediction mode for video and image coding and decoding
US11109036B2 (en) 2013-10-14 2021-08-31 Microsoft Technology Licensing, Llc Encoder-side options for intra block copy prediction mode for video and image coding
CN105659606B (zh) 2013-10-14 2019-06-18 微软技术许可有限责任公司 用于视频和图像编码和解码的方法、系统和介质
BR112016012009B1 (pt) 2013-11-27 2023-11-07 Hfi Innovation Inc Método de sinalização de modo de codificação incluindo um modo intrabc para uma imagem
US10390034B2 (en) 2014-01-03 2019-08-20 Microsoft Technology Licensing, Llc Innovations in block vector prediction and estimation of reconstructed sample values within an overlap area
KR102353787B1 (ko) 2014-01-03 2022-01-19 마이크로소프트 테크놀로지 라이센싱, 엘엘씨 비디오 및 이미지 코딩/디코딩에서의 블록 벡터 예측
US11284103B2 (en) 2014-01-17 2022-03-22 Microsoft Technology Licensing, Llc Intra block copy prediction with asymmetric partitions and encoder-side search patterns, search ranges and approaches to partitioning
US10542274B2 (en) 2014-02-21 2020-01-21 Microsoft Technology Licensing, Llc Dictionary encoding and decoding of screen content
KR102401946B1 (ko) 2014-03-04 2022-05-24 마이크로소프트 테크놀로지 라이센싱, 엘엘씨 인트라 블록 카피 예측에서의 스킵 모드 및 블록 플립핑
US9455743B2 (en) * 2014-05-27 2016-09-27 Qualcomm Incorporated Dedicated arithmetic encoding instruction
KR102311815B1 (ko) 2014-06-19 2021-10-13 마이크로소프트 테크놀로지 라이센싱, 엘엘씨 통합된 인트라 블록 카피 및 인터 예측 모드
US10085028B2 (en) * 2014-06-26 2018-09-25 Futurewei Technologies, Inc. Method and device for reducing a computational load in high efficiency video coding
JP2017535145A (ja) 2014-09-30 2017-11-24 マイクロソフト テクノロジー ライセンシング,エルエルシー 波面並列処理が可能にされた場合のピクチャ内予測モードに関する規則
US9591325B2 (en) 2015-01-27 2017-03-07 Microsoft Technology Licensing, Llc Special case handling for merged chroma blocks in intra block copy prediction mode
WO2016197314A1 (en) 2015-06-09 2016-12-15 Microsoft Technology Licensing, Llc Robust encoding/decoding of escape-coded pixels in palette mode
FR3051309A1 (fr) * 2016-05-10 2017-11-17 Bcom Procedes et dispositifs de codage et de decodage d'un flux de donnees representatif d'au moins une image
CN108737841B (zh) * 2017-04-21 2020-11-24 腾讯科技(深圳)有限公司 编码单元深度确定方法及装置
US10560723B2 (en) 2017-05-08 2020-02-11 Qualcomm Incorporated Context modeling for transform coefficient coding
US10630978B2 (en) * 2017-05-12 2020-04-21 Blackberry Limited Methods and devices for intra-coding in video compression
US10484695B2 (en) 2017-10-23 2019-11-19 Google Llc Refined entropy coding for level maps
US10986349B2 (en) 2017-12-29 2021-04-20 Microsoft Technology Licensing, Llc Constraints on locations of reference blocks for intra block copy prediction
US10771781B2 (en) * 2018-03-12 2020-09-08 Electronics And Telecommunications Research Institute Method and apparatus for deriving intra prediction mode
US10645381B2 (en) 2018-04-30 2020-05-05 Google Llc Intra-prediction for smooth blocks in image/video
KR20190140862A (ko) * 2018-06-12 2019-12-20 한국전자통신연구원 문맥 적응적 이진 산술 부호화 방법 및 장치
KR20210046804A (ko) * 2018-09-07 2021-04-28 주식회사 비원영상기술연구소 영상 부호화/복호화 방법 및 장치
GB2580084B (en) 2018-12-20 2022-12-28 Canon Kk Video coding and decoding
CN111010577B (zh) * 2018-12-31 2022-03-01 北京达佳互联信息技术有限公司 一种视频编码中帧内帧间联合预测的方法和设备及介质
US11172197B2 (en) * 2019-01-13 2021-11-09 Tencent America LLC Most probable mode list generation scheme
CN113661712A (zh) * 2019-03-12 2021-11-16 夏普株式会社 在视频编码中用于执行帧内预测编码的系统和方法
US11405638B2 (en) * 2019-03-17 2022-08-02 Tencent America LLC Method and apparatus for video coding by determining intra prediction direction based on coded information of neighboring blocks

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2005529527A (ja) * 2002-06-11 2005-09-29 ノキア コーポレイション イントラ符号化に基づく空間予測

Family Cites Families (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR0155784B1 (ko) 1993-12-16 1998-12-15 김광호 영상데이타의 적응형 가변장 부호화/복호화방법
KR970009408B1 (ko) 1994-01-18 1997-06-13 대우전자 주식회사 인터/인트라 테이블 선택 회로
US6765964B1 (en) 2000-12-06 2004-07-20 Realnetworks, Inc. System and method for intracoding video data
CN100481955C (zh) * 2000-12-06 2009-04-22 真实网络公司 对视频数据进行内编码的方法和设备
WO2003084241A2 (en) 2002-03-22 2003-10-09 Realnetworks, Inc. Context-adaptive macroblock type encoding/decoding methods and apparatuses
JP4130780B2 (ja) * 2002-04-15 2008-08-06 松下電器産業株式会社 画像符号化方法および画像復号化方法
US7170937B2 (en) 2002-05-01 2007-01-30 Texas Instruments Incorporated Complexity-scalable intra-frame prediction technique
US7289674B2 (en) * 2002-06-11 2007-10-30 Nokia Corporation Spatial prediction based intra coding
US7194137B2 (en) 2003-05-16 2007-03-20 Cisco Technology, Inc. Variable length coding method and apparatus for video compression
JP2007043651A (ja) * 2005-07-05 2007-02-15 Ntt Docomo Inc 動画像符号化装置、動画像符号化方法、動画像符号化プログラム、動画像復号装置、動画像復号方法及び動画像復号プログラム
US7778472B2 (en) * 2006-03-27 2010-08-17 Qualcomm Incorporated Methods and systems for significance coefficient coding in video compression
US8565314B2 (en) 2006-10-12 2013-10-22 Qualcomm Incorporated Variable length coding table selection based on block type statistics for refinement coefficient coding
JP2008199100A (ja) 2007-02-08 2008-08-28 Toshiba Corp 可変長符号復号装置
US7535387B1 (en) * 2007-09-10 2009-05-19 Xilinx, Inc. Methods and systems for implementing context adaptive binary arithmetic coding
BRPI0818444A2 (pt) 2007-10-12 2016-10-11 Qualcomm Inc codificação adaptativa de informação de cabeçalho de bloco de vídeo
NO328295B1 (no) * 2007-12-20 2010-01-25 Tandberg Telecom As VLC-fremgangsmate og -innretning
US8891615B2 (en) * 2008-01-08 2014-11-18 Qualcomm Incorporated Quantization based on rate-distortion modeling for CABAC coders
JP5189172B2 (ja) * 2008-01-22 2013-04-24 ドルビー ラボラトリーズ ライセンシング コーポレイション 適応性動き情報コスト推定
US8761253B2 (en) 2008-05-28 2014-06-24 Nvidia Corporation Intra prediction mode search scheme
US7932843B2 (en) * 2008-10-17 2011-04-26 Texas Instruments Incorporated Parallel CABAC decoding for video decompression
KR101507344B1 (ko) * 2009-08-21 2015-03-31 에스케이 텔레콤주식회사 가변 길이 부호를 이용한 인트라 예측모드 부호화 방법과 장치, 및 이를 위한기록 매체
CA2784517A1 (en) * 2009-12-17 2011-06-23 Telefonaktiebolaget L M Ericsson (Publ) Method and arrangement for video coding
KR101789634B1 (ko) * 2010-04-09 2017-10-25 엘지전자 주식회사 비디오 데이터 처리 방법 및 장치
US20120106640A1 (en) * 2010-10-31 2012-05-03 Broadcom Corporation Decoding side intra-prediction derivation for video coding

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2005529527A (ja) * 2002-06-11 2005-09-29 ノキア コーポレイション イントラ符号化に基づく空間予測

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
JPN6014027864; Yu-Wen Huang(外11名): 'A Technical Description of MediaTek's Proposal to the JCT-VC CfP' Joint Collaborative Team on Video Coding (JCT-VC) of ITU-T SG16 WP3 and ISO/IEC JTC1/SC29/WG11 JCTVC , 20100423, p.1-41, ITU-T *
JPN6014027872; Kemal Ugur(外2名): 'Appendix to Description of video coding technology proposal by Tandberg Nokia Ericsson' Joint Collaborative Team on Video Coding (JCT-VC) of ITU-T SG16 WP3 and ISO/IEC JTC1/SC29/WG11 JCTVC , 20100423, p.1-33, ITU-T *
JPN6014027877; Gisle Bjontegaard: 'Definition of the new coding elements from Telenor' ITU - Telecommunications Standardization Sector STUDY GROUP 16 Video Coding Experts Group (Question , 20000518, p.1-25, ITU-T *
JPN6014027880; Marta Karczewicz(外2名): 'Improvements on VLC' Joint Collaborative Team on Video Coding (JCT-VC) of ITU-T SG16 WP3 and ISO/IEC JTC1/SC29/WG11 JCTVC , 20101015, p.1-5, ITU-T *

Also Published As

Publication number Publication date
AU2012204302B2 (en) 2015-05-28
KR20130121932A (ko) 2013-11-06
CN103299628A (zh) 2013-09-11
SI2661890T1 (sl) 2018-10-30
KR101518157B1 (ko) 2015-05-06
BR112013017423B1 (pt) 2022-06-07
RU2554545C2 (ru) 2015-06-27
ES2692387T3 (es) 2018-12-03
CA2823948C (en) 2015-09-29
DK2661890T3 (en) 2018-11-19
EP2661890A1 (en) 2013-11-13
SG191201A1 (en) 2013-07-31
MY164378A (en) 2017-12-15
US20120177118A1 (en) 2012-07-12
AU2012204302A1 (en) 2013-07-18
EP2661890B1 (en) 2018-07-25
US8913662B2 (en) 2014-12-16
JP5731013B2 (ja) 2015-06-10
BR112013017423A2 (pt) 2020-09-01
CN103299628B (zh) 2016-10-05
CA2823948A1 (en) 2012-07-12
IL226974A (en) 2017-05-29
RU2013136381A (ru) 2015-02-20
HUE039795T2 (hu) 2019-02-28
WO2012094506A1 (en) 2012-07-12

Similar Documents

Publication Publication Date Title
JP5731013B2 (ja) Cabacを使用したビデオコーディングのためのイントラ予測モード選択の指示
JP5788520B2 (ja) ビデオコーディングのためのシンタックス要素のジョイントコーディング
US9497472B2 (en) Parallel context calculation in video coding
EP2622864B1 (en) Indicating intra-prediction mode selection for video coding
JP6165798B2 (ja) イントラ予測を使用したビデオ符号化
JP5805861B2 (ja) 隣接モードを使用したビデオコーディングのための拡張イントラ予測モードシグナリング
JP5587508B2 (ja) ビデオコード化のためのイントラ平滑化フィルタ
JP5937205B2 (ja) ビデオコーディングのためのランモードベース係数コーディング
WO2011160010A1 (en) Joint coding of partition information in video coding
EP2636219A1 (en) Joint coding of syntax elements for video coding

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20140606

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20140708

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20141008

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20141118

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20150218

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: 20150310

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20150408

R150 Certificate of patent or registration of utility model

Ref document number: 5731013

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