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

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

▶ エーティーアイ・テクノロジーズ・ユーエルシーの特許一覧

特許7561936パレットテーブル導出への適用による並列ヒストグラム計算
<>
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図1
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図2
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図3
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図4
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図5
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図6
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図7
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図8
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図9
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図10
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図11
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図12
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図13
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図14
  • 特許-パレットテーブル導出への適用による並列ヒストグラム計算 図15
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-09-26
(45)【発行日】2024-10-04
(54)【発明の名称】パレットテーブル導出への適用による並列ヒストグラム計算
(51)【国際特許分類】
   H04N 19/593 20140101AFI20240927BHJP
【FI】
H04N19/593
【請求項の数】 20
(21)【出願番号】P 2023132810
(22)【出願日】2023-08-17
(62)【分割の表示】P 2022515817の分割
【原出願日】2020-09-30
(65)【公開番号】P2023156452
(43)【公開日】2023-10-24
【審査請求日】2023-08-17
(31)【優先権主張番号】16/588,772
(32)【優先日】2019-09-30
(33)【優先権主張国・地域又は機関】US
(73)【特許権者】
【識別番号】508301087
【氏名又は名称】エーティーアイ・テクノロジーズ・ユーエルシー
【氏名又は名称原語表記】ATI TECHNOLOGIES ULC
【住所又は居所原語表記】One Commerce Valley Drive East, Markham, Ontario, L3T 7X6 Canada
(74)【代理人】
【識別番号】100108833
【弁理士】
【氏名又は名称】早川 裕司
(74)【代理人】
【識別番号】100111615
【弁理士】
【氏名又は名称】佐野 良太
(74)【代理人】
【識別番号】100162156
【弁理士】
【氏名又は名称】村雨 圭介
(72)【発明者】
【氏名】フェン パン
(72)【発明者】
【氏名】ウェイ ガオ
(72)【発明者】
【氏名】ヤン リウ
(72)【発明者】
【氏名】クリスタル ヨンーピャン ソウ
(72)【発明者】
【氏名】ハイボー リウ
(72)【発明者】
【氏名】エドワード エイ. ハロルド
(72)【発明者】
【氏名】イン ルオ
(72)【発明者】
【氏名】イハブ アメール
(72)【発明者】
【氏名】ガボール シネス
【審査官】白川 瑞樹
(56)【参考文献】
【文献】特開2005-354643(JP,A)
【文献】特表2017-535169(JP,A)
【文献】特表2017-513321(JP,A)
(58)【調査した分野】(Int.Cl.,DB名)
H04N19/00-19/98
(57)【特許請求の範囲】
【請求項1】
エンコーダ回路であって、
メモリに結合されるように構成されたインタフェースと、
回路と、を備え、
前記回路は、
各ピクセルコンポーネント値の第1のビット数に基づいて、ピクセルコンポーネント値の第1の分布を決定することと、
ピクセルコンポーネント値の全てのビットが評価されていないと判別したことに応じて、各ピクセルコンポーネント値の第2のビット数に基づいて、ピクセルコンポーネント値の第2の分布を決定することと、
ピクセルコンポーネント値の全てのビットが評価されたと判別したことに応じて、パレットテーブルを生成することと、
を行うように構成されている、
エンコーダ回路。
【請求項2】
前記回路は、選択された数のピクセルコンポーネント値を前記パレットテーブルのエントリにマッピングするカラーインデックスマップを生成するように構成されている、
請求項1のエンコーダ回路。
【請求項3】
複数のピクセルは、フレームのブロックのピクセルである、
請求項1のエンコーダ回路。
【請求項4】
前記回路は、前記ピクセルコンポーネント値の全てのビットが評価されるまで、前記ピクセルコンポーネント値の分布を繰り返し決定するように構成されている、
請求項1のエンコーダ回路。
【請求項5】
前記回路は、複数のピクセルにおけるピクセルコンポーネント値のカウントに基づいて、前記ピクセルコンポーネント値の数を選択するように構成されている、
請求項1のエンコーダ回路。
【請求項6】
前記回路は、前記第1の分布に基づいて第1のヒストグラムを決定するように構成されている、
請求項1のエンコーダ回路。
【請求項7】
前記回路は、前記第2の分布に基づいて第2のヒストグラムを決定するように構成されている、
請求項6のエンコーダ回路。
【請求項8】
方法であって、
エンコーダが、各ピクセルコンポーネント値の第1のビット数に基づいて、ピクセルコンポーネント値の第1の分布を決定することと、
前記エンコーダが、ピクセルコンポーネント値の全てのビットが評価されていないと判別したことに応じて、各ピクセルコンポーネント値の第2のビット数に基づいて、ピクセルコンポーネント値の第2の分布を決定することと、
前記エンコーダが、ピクセルコンポーネント値の全てのビットが評価されたと判別したことに応じて、パレットテーブルを生成することと、を含む、
方法。
【請求項9】
前記エンコーダが、選択された数のピクセルコンポーネント値を前記パレットテーブルのエントリにマッピングするカラーインデックスマップを生成することを含む、
請求項8の方法。
【請求項10】
複数のピクセルは、フレームのブロックのピクセルである、
請求項8の方法。
【請求項11】
前記ピクセルコンポーネント値の第1の分布を複数のビンに分割することを含む、
請求項8の方法。
【請求項12】
前記エンコーダが、複数のピクセルにおけるピクセルコンポーネント値のカウントに基づいて、前記ピクセルコンポーネント値の数を選択することを含む、
請求項8の方法。
【請求項13】
前記エンコーダが、前記ピクセルコンポーネント値の第1のビット数に基づいて第1のヒストグラムを計算することを含む、
請求項12の方法。
【請求項14】
前記エンコーダが、前記ピクセルコンポーネント値の第2のビット数に基づいて第2のヒストグラムを計算することを含む、
請求項13の方法。
【請求項15】
システムであって、
ピクセルデータを記憶するように構成されたメモリと、
エンコーダと、を備え、
前記エンコーダは、
各ピクセルコンポーネント値の第1のビット数に基づいて、ピクセルコンポーネント値の第1の分布を決定することと、
ピクセルコンポーネント値の全てのビットが評価されていないと判別したことに応じて、各ピクセルコンポーネント値の第2のビット数に基づいて、ピクセルコンポーネント値の第2の分布を決定することと、
ピクセルコンポーネント値の全てのビットが評価されたと判別したことに応じて、パレットテーブルを生成することと、
を行うように構成されている、
システム。
【請求項16】
前記エンコーダは、前記パレットテーブルを用いて前記ピクセルコンポーネント値を符号化するように構成されている、
請求項15のシステム。
【請求項17】
複数のピクセルは、フレームのブロックのピクセルである、
請求項15のシステム。
【請求項18】
前記エンコーダは、前記ピクセルコンポーネント値の全てのビットが評価されるまで、前記ピクセルコンポーネント値の分布を繰り返し決定するように構成されている、
請求項15のシステム。
【請求項19】
前記エンコーダは、複数のピクセルにおけるピクセルコンポーネント値のカウントに基づいて、前記ピクセルコンポーネント値の数を選択するように構成されている、
請求項15のシステム。
【請求項20】
前記エンコーダは、前記ピクセルコンポーネント値の総ビット数よりも少ない前記ピクセルコンポーネント値の第1のビット数に基づいて、第1のヒストグラムを計算するように構成されている、
請求項19のシステム。
【発明の詳細な説明】
【背景技術】
【0001】
ビデオデータの圧縮性を高めるために、いくつかのビデオ圧縮標準技術(例えば、HEVC(high efficiency video coding)標準技術、AV1(Alliance for Open Media video 1)コーディング標準技術)においてパレットコーディングが使用される。パレットコーディングは、候補パレットレベルを判定するようにヒストグラムを計算及び分類することを含む。パレットテーブル導出のためにヒストグラム計算に必要な記憶のサイズは、画素ビット深度と共に指数関数的に高まる。本明細書で使用される「パレットテーブル」という用語は、複数のエントリを記憶したデータ構造として定義され、各エントリは、画素成分値にマッピングするインデックスを記憶する。8ビット、10ビット及び12ビットのビデオについて、ヒストグラムビン(histogram bins)の必要とされる数は、従来のパレットコーディング技術に対して、256、1024及び4096である。
【発明の概要】
【0002】
添付図面と共に以下の説明を参照することによって、本明細書で説明する方法及びメカニズムの利点をより良好に理解することができる。
【図面の簡単な説明】
【0003】
図1】コンピューティングシステムの一実施形態のブロック図である。
図2】画像及び対応するピクセル分布の図である。
図3】コンピュータ生成されたスクリーンコンテンツ画像及び対応するピクセル分布の図である。
図4】メモリに結合されたエンコーダの一実施形態のブロック図である。
図5】一実施形態による、所与のブロックのサンプルヒストグラムを示す図である。
図6】一実施形態による、第1のパス後の所与のブロックのためのデシメート(decimated)されたサンプルヒストグラムを示す図である。
図7】一実施形態による、上位のデシメートされた候補ビンの選択を示す図である。
図8】一実施形態による、第2のパスヒストグラムを示す図である。
図9】ピクセルコンポーネントのビットの一実施形態を示す図である。
図10】パレットテーブル導出のため二重パスヒストグラムを生成するプロセスの一実施形態のブロック図である。
図11】パレットテーブル導出のためマルチパスヒストグラムを生成する方法の一実施形態を示す一般化されたフロー図である。
図12】パレットテーブル導出の一部として複数のヒストグラムパスを生成する方法の一実施形態を示す一般化されたフロー図である。
図13】パレットテーブル導出のため複数のヒストグラムパスを生成する方法の一実施形態を示す一般化されたフロー図である。
図14】パレットテーブル導出のためマルチパスヒストグラムを計算する方法の一実施形態を示す一般化されたフロー図である。
図15】パレットテーブルを使用してビデオ/画像ブロックを符号化する方法の一実施形態を示す一般化されたフロー図である。
【発明を実施するための形態】
【0004】
以下の説明では、本明細書で提示される方法及びメカニズムの十分な理解を提供するために、多数の詳細が示される。しかしながら、当業者は、それらの特定の詳細無しに様々な実施形態が実施されてもよいことを認識すべきである。いくつかの例では、本明細書で説明するアプローチを曖昧にすることを回避するために、周知の構造、構成要素、信号、コンピュータプログラム命令、及び、技術が詳細に示されていない。説明を簡潔及び明確にするために、図に示す要素は、必ずしも同じ縮尺で描かれていない。例えば、いくつかの要素の寸法は、他の要素に対して誇張されてもよい。
【0005】
パレットテーブル導出のための階層的技術を実装するための様々なシステム、装置及び方法が本明細書に開示される。一実施形態では、エンコーダは、ビデオフレームのピクセルコンポーネント値(すなわち、色値)の最上位ビット(MSB)の第1の部分の第1のパスヒストグラムを計算する。次に、エンコーダは、第1のパスヒストグラムから最もピクセル数が多いビンの所与の数を選択する。本明細書で使用される「ビン」という用語は、1つ以上の値を指定する間隔として定義される。ビンは、典型的には、連続した、重なり合わない間隔の変数として指定される。この場合、変数は、ピクセルコンポーネント値であり、各ビンは、範囲のサイズがMSBの第1の部分から外れるピクセルコンポーネント値ビットの数によって決定された値の範囲を指定する。
【0006】
第1のパスヒストグラムから最もピクセル数が多いビンの所与の数を選択した後、エンコーダは、ピクセルコンポーネント値から1つ以上の追加のビットを評価することによって、これらの選択された最もピクセル数が多いビンの粒度を増大させる。次に、第2のパスヒストグラムが、ピクセルコンポーネント値及び1つ以上の追加のビットのMSBの元の第1の部分の連結に対して計算され、最もピクセル数の多いビンが、第2のパスヒストグラムから選択される。パレットテーブルが、第2のパスヒストグラムからこれらの最もピクセル数が多いビンに基づいて導出され、ビデオフレームが、パレットテーブルを使用して符号化される。マルチパスヒストグラムアプローチを使用することによって、メモリ要求が、従来のパレットテーブル導出技術と比較して低減される。
【0007】
一実施形態では、ピクセルビットは、「m」個の最上位ビット(MBS)で始まり、残りのビットに「n1」ビット、「n2ビット」等を追加することによって拡大する、階層的動作のためのいくつかのグループに分割される。第1のヒストグラムは、「m」個のMSBに対して計算され、この第1のヒストグラムからの上位ビンが選択される。これらの上位ビンは、増大されて「n1」ビットを含み、次に、第2のヒストグラムがこれらの増大されたビンに対して計算される。第2のヒストグラムから上位ビンが選択され、これらのビンが増大された、「N2」ビットを含む。一実施形態では、このプロセスは、ピクセルコンポーネント値ビットの全てが評価されるまで続く。この説明のため、「m」、「n1」及び「n2」は、正の整数であると仮定される。「m」、「n1」及び「n2」の値、選択された上位ビンの数、及び、実施されるパスの数は柔軟であり、実施形態によって変化し得る。これらの値は、単純なハードウェア実装と性能との間のトレードオフに基づいて調整される。
【0008】
図1を参照すると、コンピューティングシステム100の一実施形態のブロック図が示されている。一実施形態では、コンピューティングシステム100は、少なくともエンコーダ105と、プロセッサ(複数可)110と、入力/出力(I/O)インタフェース120と、バス125と、メモリデバイス(複数可)130と、を含む。他の実施形態では、コンピューティングシステム100は、他のコンポーネントを含んでもよく、及び/又は、コンピューティングシステム100は、異なる構成とすることができる。一実施形態では、エンコーダ105は、ビデオコーデックを実装するロジックを含む。ビデオコーデックは、非圧縮ビデオストリームを符号化し、及び/又は、圧縮されたビデオストリームを復号する。一実施形態では、ビデオコーデックは、1つ以上のビデオ圧縮規格に従って動作する。本明細書で使用される「エンコーダ」及び「ビデオコーデック」という用語は、ビデオ/画像デコーダ、ビデオ/画像エンコーダ、又は、ビデオコーデックを指すことができることに留意されたい。エンコーダ105は、ハードウェア及び/又はソフトウェアの任意の適切な組み合わせを表す。エンコーダ105が、プロセッサ(複数可)110とは異なる別のユニットとして示されているが、エンコーダ105の一部又は全体がプロセッサ(複数可)110上で実行されてもよいし、プロセッサ(複数可)110上に実装されてもよいことを理解されたい。
【0009】
プロセッサ(複数可)110は、任意の数及びタイプの処理ユニット(例えば、中央処理ユニット(CPU)、グラフィック処理ユニット(GPU)、デジタル信号プロセッサ(DSP)、フィールドプログラマブルゲートアレイ(FPGA)、特定用途向け集積回路(ASIC))を表す。一実施形態では、エンコーダ105に関連する処理の一部は、プロセッサ(複数可)110によって実施される。メモリデバイス(複数可)130は、任意の数及びタイプのメモリデバイスを表す。例えば、メモリデバイス(複数可)130におけるメモリのタイプは、ダイナミックランダムアクセスメモリ(DRAM)、スタティックランダムアクセスメモリ(SRAM)、NANDフラッシュメモリ、NORフラッシュメモリ、又は、強誘電体ランダムアクセスメモリ(FeRAM)等を含んでもよい。メモリデバイス(複数可)130は、エンコーダ105及びプロセッサ(複数可)110によってアクセス可能である。I/Oインタフェース120は、任意の数及びタイプのI/Oインタフェース(例えば、ペリフェラルコンポーネントインターコネクト(PCI)バス、PCI-X(PCI-Extended)、PCIE(PCI Express)バス、ギガビットイーサネット(登録商標)(GBE)バス、ユニバーサルシリアルバス(USB))を表す。様々なタイプの周辺機器がI/Oインタフェース120に結合されてもよい。そのような周辺装置は、ディスプレイ、キーボード、マウス、プリンタ、スキャナ、ジョイスティック又は他のタイプのゲームコントローラ、メディア記録デバイス、外部記憶装置、及び、ネットワークインタフェースカード等を含むが、これらに限定されない。
【0010】
様々な実施形態において、コンピューティングシステム100は、コンピュータ、ラップトップ、モバイルデバイス、ゲームコンソール、サーバ、ストリーミングデバイス、ウェアラブルデバイス、又は、他の様々なタイプの任意のコンピューティングシステム若しくはデバイスである。コンピューティングシステム100のコンポーネントの数は、実施形態毎に異なることに留意されたい。例えば、他の実施形態では、図1に示す数よりも多い又は少ない各コンポーネントが存在する。また、他の実施形態では、コンピューティングシステム100は、図1に示されていない他のコンポーネントを含むことに留意されたい。さらに、他の実施形態では、コンピューティングシステム100は、図1に示す以外の方法で構成されている。
【0011】
図2を参照すると、画像205及び対応するピクセル分布210の図が示されている。図2に示す画像205は、画像処理において試験画像として広く使用される周知のレナ画像である。この64×64のレナ画像205に対するピクセル分布210が、図2の下部に示されている。ピクセル分布210は、画像205内のピクセルが異なるピクセル値にわたってどのように分布するかを示す。ピクセル分布210に示すような連続した色調を有することは、カメラによってキャプチャされた自然画像又はビデオフレームに対して一般的である。
【0012】
図3を参照すると、コンピュータ生成されたスクリーンコンテンツ画像305及び対応するピクセル分布310の図が示されている。画像305は、コンピュータ生成されたスクリーンショットの一例であり、ピクセル分布310は、比較的少ない数のピクセルコンポーネント値にわたってピクセルの狭い分布がどのように存在するかを示す。ピクセル分布に示すように、画像305には、限られたいくつかの異なる色が含まれる。これは、コンピュータ生成されたスクリーンショット及びコンピュータ生成された画像において一般的なタイプの分布であり、パレットコーディングは、高圧縮比を達成するためにこれらの画像を符号化する効率的な方法である。コンピュータ生成されたスクリーンショット以外の他のタイプの画像もパレットコーディングによる利点があり得る。
【0013】
図4を参照すると、メモリ430に結合されたエンコーダ405の一実施形態のブロック図が示されている。一実施形態では、エンコーダ405は、ビニングコントローラ415と、選択ユニット420と、パレットテーブル生成ユニット425と、を有する制御ロジック410を含む。別の実施形態では、エンコーダ405は、プログラム命令を実行するプロセッサによって実装されており、この実施形態では、ビニングコントローラ415と、選択ユニット420と、パレットテーブル生成ユニット425とは、制御ロジックではなくプログラム命令によって実装される。他の実施形態では、ビニングコントローラ415と、選択ユニット420と、パレットテーブル生成ユニット425とは、ハードウェア及びソフトウェアの組み合わせを使用して実装される。
【0014】
エンコーダ405は、任意の数及びタイプのメモリデバイスを表すメモリ430に結合されている。一実施形態では、メモリ430は、エンコーダ405によって符号化されるビデオフレームを記憶する。ビデオブロック435は、このビデオフレームの1つのブロックを表す。ビデオブロック435を符号化するために使用される技術は、ビデオフレームの他のブロック及びビデオシーケンス内の他のビデオフレームに使用されてもよい。或いは、ビデオブロック435は、画像の単一のブロックであってもよい。一実施形態では、ビデオブロック435は、複数のピクセルコンポーネント値としてメモリ430に記憶される。符号化プロセスの一部として、ビニングコントローラ415は、ビデオブロック435のピクセルコンポーネント値から第1のパスヒストグラム440Aを生成する。一実施形態では、ビニングコントローラ415は、個別のピクセルコンポーネント(例えば、赤、緑、青)毎に個別の第1のパスヒストグラム440Aを生成する。第1のパスヒストグラム440Aを生成するためにビニングコントローラ415によって実施される第1のステップは、ピクセルコンポーネント値の全体の範囲を一連の間隔に分割することである。また、この第1のステップは、値の範囲を「ビニング」すると呼ばれ、各間隔は「ビン」と呼ばれる。ビンは、典型的には、連続した、重なり合わない値の範囲の間隔として指定される。次に、ビニングコントローラ415は、ビデオブロック435からのピクセルコンポーネント値が各間隔にいくつ含まれるかをカウントする。例えば、一実施形態では、ビニングコントローラ415は、ビデオブロック435のピクセルコンポーネント値を抽出し、次に、ビニングコントローラ415は、各ピクセルコンポーネント値を対応するビンに割り当てる。一実施形態では、各ビンは、ピクセルが各々のビンに割り当てられる毎にインクリメントされるカウンタを使用して実装される。
【0015】
一実施形態では、第1のパスヒストグラム440Aの各ビンは、所与の数のMSBに対応するピクセルコンポーネント値の範囲を表す。所与の数のMSBは、実施形態に応じて変化し得る。例えば、一実施形態では、第1のパスヒストグラム440Aの各ビンは、ピクセルコンポーネント値毎に合計8ビットのうち6つのMSBに対応する範囲を表す。総数未満のビットを使用して第1のパスヒストグラム440Aのビンを生成することによって、第1のパスヒストグラム440Aをメモリ430に記憶するためのストレージ要求を低減する。例えば、8ビットのうち6つのMSBを使用して第1のパスヒストグラム440Aを生成する場合、8ビット全てが使用される場合の256のビンと比べて64ビットのみが生成される。この例では、各ピクセルコンポーネント値は、値の6つのMSBに基づいて、ビニングコントローラ415によってその各々のビンに割り当てられる。他の実施形態では、より高いビット深度のビデオ(例えば、サンプル当たり12ビット、サンプル当たり16ビット)について、及び/又は、より多くのピクセルコンポーネント値ビットがビンの分類から除外される場合、大量のストレージの節約を達成することができる。
【0016】
第1のパスヒストグラム440Aが生成され、メモリ430に記憶された後、第1のパスヒストグラム440Aのビンは、選択ユニット420によって分類される。例えば、ビンは、いくつのピクセル値が各ビンに含まれるかに基づいて、最も高いものから最も低いものへ分類される。次に、選択ユニット420は、最大ピクセル値を有する所与の数のビンを選択する。例えば、一実施形態では、選択ユニット420は、最大ピクセル値を有する8つのビンを選択する。他の実施形態では、選択ユニット420は、第1のパスヒストグラム440A内の全てのビンの中で最もピクセル数が多い(すなわち、最も高い数のピクセル値)他の数のビンを選択する。次に、評価されるビットの数は、これらの選択されたビン用に増大され、増大されたビンについて第2のパスヒストグラム440Bが生成される。例えば、上位8つのビンが選択ユニット420によって選択され、これらのビンが2ビットで増大される場合、第2のパスヒストグラム440Bは合計32個のビンを有することになる。次に、これらのビンは、各ビンにいくつのピクセル値が含まれるかに従って分類される。次に、ピクセル値の数に応じて上位ビンが選択される。選択される上位ビンの数は、実施形態に応じて変化する。
【0017】
一実施形態では、第2のパスヒストグラム440Bから選択される上位ビンは、パレットテーブル生成ユニット425によって使用され、ビデオブロック435を符号化して符号化ブロック455を生成するために使用されるパレットテーブル450を導出する。或いは、ピクセルコンポーネント値について評価されるビットの数を増大することによってより多くのヒストグラムを生成するために、1つ以上の追加のパスを実施することもできる。場合によっては、エンコーダ405は、自然な(すなわち、コンピュータ生成されてない)ビデオフレームに通常見られるように、ピクセル値の分布が多くのビンにわたって広がる場合に、ビデオブロック435に対してパレットモード符号化を使用しないことを決定することができる。一実施形態では、パレットモード符号化を使用しないという決定は、第1のパスヒストグラム440Aが生成された後に行われる。第1のパスヒストグラム440Aの分析により、パレットモード符号化がビデオブロック435に適しているかどうかを判定することができる。パレットモード符号化が使用されない場合、様々な他のタイプの従来の符号化技術の何れかを使用して、ビデオブロック435を符号化することができる。
【0018】
上記のプロセスは、ビデオフレームの全体又はその一部に対して実施できることに留意されたい。また、ビデオフレーム全体に対して生成されたパレットテーブルは、ビデオストリーム内の後続のビデオフレームを符号化するために使用されてもよい。別の実施形態では、ビデオブロック435は、画像のブロックであってもよいことに留意されたい。制御ロジック410をビニングコントローラ415、選択ユニット420及びパレットテーブル生成ユニット425に区画化することは、一実施形態を示すに過ぎないことを理解されたい。別の実施形態では、単一の制御ユニットが、ビニングコントローラ415、選択ユニット420及びパレットテーブル生成ユニット425の機能を実施してもよい。他の実施形態では、制御ロジック410を個別のユニットに区画化する他の方法が展開されてもよい。
【0019】
一実施形態では、符号化されたブロック455は、符号化されたバージョンのパレットテーブル450と、パレットテーブル450にビデオブロック435のピクセルをマッピングするインデックス値を有するカラーインデックスマップと、を含む。パレットテーブル450は、ビデオブロック435のピクセルコンポーネントを符号化するための任意の数のパレットテーブルを表す。例えば、一実施形態では、パレットテーブル450は、赤成分に対する第1のテーブルと、緑成分に対する第2のテーブルと、青成分に対する第3のテーブルと、を含む。別の実施形態では、パレットテーブル450は、異なるピクセルコンポーネントの組み合わせを表す単一のテーブルである。生成されたカラーインデックスマップは、任意の適切な符号化技術を使用して符号化されてもよい。例えば、個々のインデックス値は、一実施形態では、ランレングス符号化技術を使用して符号化される。個々のインデックス値を符号化する他の方法が可能であり、考慮される。
【0020】
図5を参照すると、所与のブロックに対するサンプルヒストグラム500の一実施形態が示されている。ヒストグラム500は、64個の取り得るピクセルレベルに対応する64個の異なるビンを有するヒストグラムの一例である。本明細書で使用される「ヒストグラム」という用語は、画像/フレームの所与のブロックに対する各ピクセルコンポーネント値の発生頻度として定義される。ブロックは、より一般的には「コーディングユニット」と呼ばれてもよく、コーディングユニットのサイズは、実施形態に応じて変化することに留意されたい。一実施形態では、コーディングユニットは、8×8ブロックのピクセルである。別の実施形態では、コーディングユニットは、画像/フレーム全体である。他の実施形態では、コーディングユニットは、ピクセルの他のサイズ及び/又は配置であってもよい。ヒストグラム500の例示的な分布は、説明のために示されている。Y軸は、対応するピクセルレベルを有する所与のブロック内のピクセルの数を測定する。この説明のために、所与のブロックが複数のピクセルを有し、各ピクセルが1つ以上のチャネル(例えば、赤、緑、青)の各々に対する数値を有すると仮定する。
【0021】
ヒストグラム500を生成するために、64個の別個のビンに対するストレージが必要である。ピクセルコンポーネント毎に他の数のビットを有する他のヒストグラムの場合、取り得るピクセルレベル毎にヒストグラムを生成する場合に他の数のビンが必要である。例えば、10ビットピクセルコンポーネントの場合、1024個のストレージビンが必要である。12ビットピクセルコンポーネントの場合、4096個のストレージビンが必要である。ピクセルコンポーネントレベル当たりのビットの数が増大すると、ストレージ要求が指数関数的に増大する。
【0022】
図6を参照すると、第1のパス後の所与のブロックに対するデシメートされたサンプルヒストグラム600の一実施形態の図が示されている。図6の説明は、図5のヒストグラム500の説明の続きである。各ビンが複数のピクセルコンポーネントレベルを包含することを除いて、ヒストグラム600は、ヒストグラム500に示したものと同様のピクセルコンポーネントレベルにわたる同じピクセルの分布を含む。したがって、ヒストグラム600は、各ピクセルのビットのサブセットのみを評価することによって、ビンの数が低減される。
【0023】
ヒストグラム600に示すように、各矩形は、4つのビンの集合である中間ビンである。この例では、ヒストグラム600は、ピクセルコンポーネント値の4つの最上位ビット(MSB)を評価する。4つのMSBのみを使用することは、合計16ビンに対応する。これにより、(図5のヒストグラム500の場合に)64個のビンのストレージ要求をヒストグラム600に対する16個のビンに減らすことに役立つ。他の実施形態では、第1のパスヒストグラムは、他の数のMSBを評価することができる。
【0024】
図7を参照すると、サンプルヒストグラムからの上位デシメートされた候補ビンの選択の一実施形態の図が示されている。図7の説明は、図6のヒストグラム600の説明の続きである。ヒストグラム600に示すように、ピクセルMSBのサブセットに基づいて候補ビンを生成した後に、最もピクセル数が多い上位4つの候補ビンが選択される。これらの4つの選択されたデシメートされた候補ビン705A~705Dが、ヒストグラム700において縦方向の長方形として示されている。上位4つのデシメートされた候補ビン705A~705Dの選択は、一実施形態を示しているに過ぎないことを理解されたい。他の実施形態では、上位デシメートされた候補ビンの別の数(例えば、2、8)が、デシメートされたヒストグラムから選択されてもよい。
【0025】
図8を参照すると、第2のパスヒストグラム800の一実施形態の図が示されている。図8の説明は、図7のヒストグラム700の説明の続きである。ヒストグラム700に示すように、上位4つの候補ビン705A~705Dを選択した後に、ヒストグラム800は、評価されるピクセルコンポーネントビットに2つの追加のビットを加えることによって微細化される。これにより、ビンの数が4から16に増える。一実施形態では、8ビット画像又はビデオフレームの場合、マルチパスヒストグラムプロセスがこの時点で停止し、パレットテーブルがこれら16個のビンのうち上位8つのビンから導出される。ピクセルコンポーネント当たり8ビットよりも多い画像の場合、プロセスは、上位候補ビンを選択し、次に追加の2ビットによってこれらのビンを増大することによって、別のパスで継続する。選択される候補ビンの数は、実施形態に応じて変化し得る。
【0026】
図9を参照すると、ピクセルコンポーネント900のビットの一実施形態の図が示されている。ピクセルコンポーネント900は、ソース画像又はビデオフレームの特定の色空間に対する異なる色値のうち何れかを記憶する任意の数のビットを表す。例えば、一実施形態では、ピクセルコンポーネント900の3つの個別のインスタンスを使用して、赤、緑及び青(RGB)色空間内の画像の各ピクセルの赤、緑及び青を符号化する。或いは、別の実施形態では、ピクセルコンポーネント900の3つの個別のインスタンスは、(YUV)色空間内の各ピクセルに対するルミナンス値及びクロミナンス値を符号化する。他の実施形態では、ピクセルコンポーネント900は、他のタイプの色空間内のピクセルの各ピクセルコンポーネントを記憶することができる。より一般的には、ピクセルコンポーネント900は、色空間へのインデックスと呼ばれてもよい。
【0027】
一実施形態では、第1のパスヒストグラムは、ピクセルコンポーネント900の他の最下位ビット(LSB)を排除しながら、ピクセルコンポーネント900の「m」グループの1ビットを使用して画像/フレームのブロックに対して計算される。図示したように、「m」は6に等しいが、これは、一実施形態を示すに過ぎないことを理解されたい。上位「p1」候補ビンは、実施形態に応じて変化する「p1」の値を有する第1のパスヒストグラムに対する候補ビンから選択される。次に、第2のパスヒストグラムが、「p1」候補ビンを増大してヒストグラム計算に「n1」グループの2ビットを含むことによって、これらの「p1」候補ビンに対して計算される。図示したように、「n1」は2に等しいが、これは、一実施形態を示すに過ぎないことを理解されたい。上位「p2」候補ビンは、実施形態に応じて変化する「p2」の値を有する第2のパスヒストグラムから選択される。追加のパスが、「n2」グループの3ビット及び「n3」グループの4ビットに対して実施され得る。一実施形態では、ピクセルコンポーネント900の全てのビットが評価された後、パレットテーブルが、最終セットのビンからの上位ビンを使用して導出される。
【0028】
図10を参照すると、パレットテーブル導出のための二重パスヒストグラムを生成するプロセス1000の一実施形態のブロック図が示されている。プロセス1000の第1のステップでは、第1のヒストグラムを生成する際に評価されるビット数を低減する。これにより、各ビンに含まれるピクセルコンポーネント値の数が増大する。例えば、2ビットが除外される場合、4つの潜在的なピクセルコンポーネント値が各ビンに含まれる。これは、プロセス1000の上部に示される例である。第1のスキャンでは、ヒストグラムは、6つのMSBに対応する64個のビン(B0~B63)のみを有する。次に、ビンB0~B63の中から上位16個のビン(T0~T15)が選択される。上位16個のビンは、処理中のブロックのうち最大ピクセルコンポーネント値を有するビンである。
【0029】
図10においてT0~T15と示されている上位16個のビンが選択された後、各ビンは、第2のスキャンのためにピクセルコンポーネント値からさらに2つのLSBを評価することによって4つのビンに増大される。これらのビンは、T0の場合、B’(0、0)、B’(0、1)、B’(0、2)及びB’(0、3)として図示されている。T1の場合、ビンは、第2のスキャンに対してB’(1、0)、B’(1、1)、B’(1、2)及びB’(1、3)である。第2のスキャンの他のビンは、第1のスキャンの他の上位ビンT2~T15と同じパターンに従う。第2のスキャンの結果として、上位16個のビンが64個のビンに増大される。これらの64個のビンが分類され、次いで、上位8個のビン(T’0~T’7)が選択される。第2のスキャンから選択された上位ビンの特定の数は、単に一実施形態を表しているに過ぎないことに留意されたい。同様に、プロセス1000に対して使用される他の値は、1つの特定の実施形態を表しているに過ぎない。他の実施形態は、他の値を使用してもよい。
【0030】
図11を参照すると、パレットテーブル導出のためのマルチパスヒストグラムを生成する方法1100の一実施形態が示されている。説明のために、この実施形態におけるステップ及び図12図15のステップが順番に示されている。しかしながら、説明する方法の様々な実施形態では、説明する要素のうち1つ以上は、同時に実行されてもよいし、図示した順序とは異なる順序で実行されてもよいし、完全に省略されてもよいことに留意されたい。他の追加の要素も必要に応じて実行される。本明細書に記載された様々なシステム又は装置の何れかは、方法1100を実施するように構成されている。方法1100は、(図10の)プロセス1000に対応することを意図していることに留意されたい。
【0031】
方法1100が開始されると、エンコーダは、各ピクセルコンポーネント値の上位6つのMSBを使用する(ブロック1105)。次に、エンコーダは、ピクセルコンポーネント値の上位6つのMSBについて、64個のビンを有するヒストグラムを収集する(ブロック1110)。次いで、エンコーダは、64個のビンを降順に分類し、これら64個のビンから上位16個のビンを選択する(ブロック1115)。次に、エンコーダは、6つのMSBを2つのLSBと組み合わせることによって、上位16個のビンを64個のビンに増大させ、次いで、エンコーダは、これら64個のビンを有するヒストグラムを収集する(ブロック1120)。エンコーダは、64個のビン降順に分類し、64個のビンから上位8個のビンを選択する(ブロック1125)。ブロック1125の後に、方法1100は終了する。次に、対応するブロックを符号化する場合に、これらの選択された8個のビンは、パレットテーブル導出のためにエンコーダによって使用される。
【0032】
図12を参照すると、パレットテーブル導出の一環として複数のヒストグラムパスを生成する方法1200の一実施形態が示されている。エンコーダは、画像のブロックの所与のピクセルコンポーネントのNビットのピクセルコンポーネント値を受け取る(ブロック1205)。ブロックは、より一般的には「コーディングユニット」と呼ばれてもよく、画像はビデオフレームであってもよいことに留意されたい。コーディングユニットのサイズ(例えば、8×8ブロック)は、実施形態に応じて変化し得る。別の実施形態では、コーディングユニットは、画像又はビデオフレーム全体である。他の実施形態では、コーディングユニットは、画像の様々な他の部分の何れかであり、コーディングユニットは、複数の画像(例えば、ビデオシーケンスのビデオフレーム)に対応することができる。この説明のために、「N」は正の整数であると仮定される。Nの値は、実施形態に応じて変化し得る。例えば、8ビット、10ビット、12ビットのピクセルコンポーネントは、通常、様々な実施形態で使用される値である。ピクセルコンポーネント当たりの他のビット数も可能である。一実施形態では、所与のピクセルコンポーネントは、RGB色空間の赤、緑又は青の何れかである。別の実施形態では、所与のピクセルコンポーネントは、YUV又はYCbCr色空間のためのルミナンス値又はクロミナンス値を表す。他のタイプのピクセルコンポーネントが他の実施形態で使用されてもよい。
【0033】
次に、エンコーダは、ピクセルコンポーネント値を、N個のピクセルコンポーネント値ビットの第1の部分に基づいて、第1の複数のビンにグループ分けする(ブロック1210)。第1の複数のビンは、ブロックのピクセル値のヒストグラムを集合的に表す。各ビンは、ビンに割り当てられた第1の部分のビットに一致するこれらのピクセルコンポーネント値を含む。例えば、一実施形態では、Nは8であり、第1の部分は6ビットであり、第1のビンは、ビット「111111」が割り当てられ、第2のビンは、ビット「111110」が割り当てられる等である。「11111111」、「11111110」、「11111101」、「11111100」のピクセルコンポーネント値が第1のビンに割り当てられ、「11111011」、「11111010」、「11111001」、「11111000」のピクセルコンポーネント値が第2のビンに割り当てられる等である。他の実施形態では、Nは他の数であり、及び/又は、第1の部分は別のビット数を含む。
【0034】
次に、エンコーダは、第1の複数のビンの中でピクセル数が最も多い第1のセットのビンを選択する(ブロック1215)。例えば、一実施形態では、エンコーダは、ブロック1215において、ピクセル数が最も多い8個のビンを選択する。別の実施形態では、エンコーダは、ブロック1215において、ピクセル数が最も多い16個のビンを選択する。他の実施形態では、エンコーダは、ピクセル数が最も多い他の数のビンを選択する。
【0035】
次に、エンコーダは、第1のセットのビンからのピクセルコンポーネント値を、ピクセルコンポーネント値ビットの第2の部分(第1の部分よりも大きい)に基づいて、第2の複数のビンにグループ分けする(ブロック1220)。言い換えれば、ブロック1220では、エンコーダは、ピクセルコンポーネント値をビンに分類するために使用されるビット数を増加することによって、第1のセットのビンを第2の複数のビンに増大させる。しかし、第2の複数のビンは、第1のセットのビン内に全て含まれるので、ビット数の増加は、第1のセットのビンにグループ分けされたこれらのピクセルコンポーネント値にのみ適用される。一実施形態では、第2の部分は、第1の部分よりも2ビットだけ大きい。他の実施形態では、第2の部分は、第1の部分よりも他のビット数だけ大きい。
【0036】
次に、エンコーダは、第2の複数のビンの中でピクセル数が最も多い第2のセットのビンを選択する(ブロック1225)。第2のセットのビンの数は、実施形態に応じて変化する。次に、エンコーダは、第2のセットのビンに割り当てられたピクセルコンポーネント値からパレットテーブルを導出する(ブロック1230)。次いで、エンコーダは、パレットテーブルに基づいて、ブロックのピクセルの所与のピクセルコンポーネントを符号化する(ブロック1235)。ブロック1235の後に、方法1200は終了する。方法1200を使用することにより、従来の技術が使用された場合に他の方法で計算されるよりもより小さい数のビンが計算されるので、パレットテーブル符号化のためのヒストグラムを生成するストレージ要求が低減される。方法1200は、ブロックの各ピクセルコンポーネントに対して実施され得ることに留意されたい。後続の画像のブロックは、同様に符号化することができ、パレットテーブルは、他のブロックに対して再使用され得る。
【0037】
図13を参照すると、パレットテーブル導出のための複数のヒストグラムパスを生成する方法1300の一実施形態が示されている。エンコーダは、各ビンが複数の潜在的なピクセル値に対応する第1のグループのビンに対する第1のヒストグラムを生成する(ブロック1305)。ビン当たりの潜在的なピクセル値の数は、第1のヒストグラムに対して評価されなかったビット数に依存することに留意されたい。例えば、ビデオフレームがピクセル当たり12ビットを有し、6個のMSBだけが第1のヒストグラムで評価される場合、6個のLSBが残され、ビン当たり64個の潜在的なピクセル値が存在することを意味する。他の実施形態では、第1のヒストグラムの後、ビン当たり他の数の潜在的なピクセル値がある。
【0038】
次に、エンコーダは、第1のグループのビンからピクセル数が最も多い第1の所与の数のビンを選択する(ブロック1310)。第1の所与の数は、実施形態に応じて変化し得る。次いで、エンコーダは、別のヒストグラムが生成されるかどうかを判定する(条件付きブロック1315)。例えば、一実施形態では、ピクセルコンポーネント値に評価されていない多くのビットがある場合、エンコーダは、別のヒストグラムを生成することを決定し得る。
【0039】
エンコーダが、別のヒストグラムが生成される必要があると判定した場合(条件付きブロック1315:「はい」)、エンコーダは、N番目のグループのビンを生成するために、(N-1)番目のグループのビンから評価されるピクセル値のビット数を増大させる(ブロック1320)。N番目のグループは、第2のグループ、第3のグループ、第4のグループ等を指し、ヒストグラムが既に生成された数による。そうではなく、エンコーダが、別のヒストグラムが生成される必要がないと判定した場合(条件付きブロック1315:「いいえ」)、エンコーダは、選択されたビンの数に基づいて、ビデオフレームの所与のブロックを符号化するパレットテーブルを導出する(ブロック1335)。
【0040】
ブロック1320の後で、エンコーダは、N番目のグループのビンに対する別の(すなわち、N番目の)ヒストグラムを生成する(ブロック1325)。次に、エンコーダは、N番目のグループのビンからピクセル数が最も多い所与の数のビンを選択する(ブロック1330)。所与の数は、実施形態及び/又は生成されるヒストグラムの特定の階層的レベルに応じて変化し得る。ブロック1330の後、方法1300は、条件付きブロック1315に戻る。
【0041】
図14を参照すると、パレットテーブル導出のためにマルチパスヒストグラムを計算する方法1400の別の実施形態が示されている。エンコーダは、ピクセルコンポーネント値の6つの最上位ビット(MSB)のヒストグラムを計算する(ブロック1405)。ヒストグラムは、複数のビンを含み、各ビンは、ビンに対応する同じ6つのMSBを有するピクセルコンポーネント値を有するピクセル数の計算を含むことに留意されたい。次に、エンコーダは、ピクセルコンポーネント値に残りのビットがあるかどうかを判定する(条件付きブロック1410)。例えば、ブロック1405の後に、ピクセルコンポーネント値が8ビットを有する場合、6つのMSBの後にさらに2ビットあるので、条件付きブロック1410は、「はい」と評価される。
【0042】
ピクセルコンポーネント値に残りのビットがある場合(条件付きブロック1410:「はい」)、エンコーダは、ヒストグラムから複数のビンのうち上位16個のビンを選択する(ブロック1415)。他の実施形態では、エンコーダは、最も多いピクセルを有するいくつかの他の数のビンを選択する。そうではなく、ピクセルコンポーネント値に残りのビットがない場合(条件付きブロック1410:「いいえ」)、エンコーダは、ヒストグラムから複数のビンのうち上位8個のビンを選択する(ブロック1420)。これら上記8個のビンは、ブロック内で最も目立つ色に対応する。ブロック1420の後に、上位8個のビンは、パレットテーブル導出のために使用され(ブロック1430)、方法1400は終了する。ブロック1415の後、エンコーダは、さらに2ビットを追加することによってヒストグラムを計算する(ブロック1425)。ブロック1425の後、方法1400は、条件付きブロック1410に戻る。方法1400で指定されたビット数及びビン数は、1つの特定の実施形態を示していることに留意されたい。他の実施形態では、これらの数は変化し得る。
【0043】
図15を参照すると、パレットテーブルを使用してビデオ/画像ブロックを符号化する方法1500の一実施形態が示されている。エンコーダは、マルチレベル階層的ヒストグラム生成プロセスを使用して、ブロック内で最も頻繁に発生するピクセルコンポーネント値の所与の数を識別する(ブロック1505)。マルチレベル階層ヒストグラム生成プロセスを使用して、ブロック内で最も頻繁に発生するピクセルコンポーネント値(すなわち、最も目立つ色)の所与の数を識別する様々な例が、(図11~14の)方法1100,1200,1300,1400に記載されている。これらの方法のうち何れか又は他の同様の方法を使用して、ブロック1505を実施することができる。所与の数は、実施形態に応じて値が変化する任意の適切な整数値(例えば、8、16、32)であってもよい。
【0044】
次に、エンコーダは、最も頻繁に発生するピクセルコンポーネント値の所与の数に基づいて、パレットテーブルを選択する(ブロック1510)。一実施形態では、パレットテーブルは、テーブルへのインデックスが3ビットで符号化されることを可能にし、パレットテーブル内の何れの値にもマッピングされないエスケープピクセルに使用される8番目のインデックスを有する、7つの最も頻繁に発生するピクセルコンポーネント値を含む。他の実施形態では、パレットテーブルは、最も頻繁に発生するピクセルコンポーネント値の他の数に対する他の数のエントリを有する。一実施形態では、各ピクセルコンポーネント(例えば、ルミナンス、クロミナンス)は、それ自身のパレットテーブルを有する。別の実施形態では、単一のパレットテーブルは、個別のピクセルコンポーネントの組み合わせを表すものとして生成される。さらなる実施形態では、パレットテーブルは、単一のピクセルコンポーネント(例えば、赤)に対して選択され、次いで、他のピクセルコンポーネント(例えば、青、緑)と共に使用されるように共有及び/又は修正される。上記の代替案が可能であり、企図される。
【0045】
次に、ブロックのピクセルをパレットテーブル内のエントリにマッピングするインデックス値を使用して、カラーインデックスマップが生成される(ブロック1515)。例えば、ブロック内の各ピクセルは、パレットテーブルへのインデックスに変換され、カラーインデックスマップは、ブロック内の各ピクセルのインデックスを含む。ピクセルがパレットテーブル内に含まれていない値を有する場合、ピクセルは、エスケープピクセルとして符号化され、ピクセルの実際の値は、カラーインデックスマップ又は別の構造に含まれることが可能である。次に、パレットテーブル及びカラーインデックスマップが、ブロックの表現(representation)として符号化される(ブロック1520)。パレットテーブルを符号化するための、及び、カラーインデックスマップを符号化するための様々な符号化技術のうち何れかを使用することができる。次に、符号化されたパレットテーブル及びカラーインデックスマップが記憶され及び/又はレシーバに伝達される(ブロック1525)。ブロック1525の後に、方法1500は終了する。方法1500は、画像/フレームのブロックだけでなく、画像又はビデオフレーム全体を符号化するために使用可能であることを理解されたい。
【0046】
符号化されたパレットテーブル及びカラーインデックスマップをレシーバに送信することを含む実施形態の場合、レシーバは、符号化されたパレットテーブル及びカラーインデックスマップからブロックを再生成するために上記のステップを逆にするデコーダを含む。次に、再生成されたブロックは、ディスプレイに送られてもよい。一実施形態では、このプロセスは、ビデオシーケンスの各ビデオフレームのブロックに対して繰り返すことができる。或いは、符号化されたパレットテーブルは、最初のビデオフレーム全体に対して送信され、その後、いくつかの後続のビデオフレームがこのパレットテーブルを再利用することができる。後続のビデオフレームでは、ビデオフレームのカラーインデックスマップのみがレシーバに送信される。さらなる実施形態では、フレームのブロックに対して生成された、符号化されたパレットテーブルは、フレームの他のブロック及び/又は他のフレームのブロックのために再利用される。場合によっては、所与のブロックのパレットテーブルは、別のブロックに対応するパレットテーブルから導出される。例えば、一実施形態では、デルタパレットテーブル(つまり、差分パレットテーブル)が、隣接するブロックのパレットテーブルに適用され、所与のブロックに対するパレットテーブルが生成される。以前に使用されたパレットテーブルから新しいパレットテーブルを導出する他の方法が可能であり、企図される。
【0047】
様々な実施形態では、ソフトウェアアプリケーションのプログラム命令を使用して、本明細書で説明する方法及び/又はメカニズムを実施する。例えば、汎用プロセッサ又は専用プロセッサによって実行可能なプログラム命令が考えられる。様々な実施形態では、そのようなプログラム命令は、高水準プログラミング言語によって表される。他の実施形態では、プログラム命令は、高水準プログラミング言語からバイナリ形式、中間形式又は他の形式にコンパイルされる。或いは、プログラム命令は、ハードウェアの動作又は設計を記述するように書き込まれる。そのようなプログラム命令は、C言語等の高水準プログラミング言語によって表される。或いは、Verilog等のハードウェア設計言語(HDL)が使用される。様々な実施形態では、プログラム命令は、様々な非一時的なコンピュータ可読記憶媒体の何れかに記憶される。記憶媒体は、プログラム実行のためにプログラム命令をコンピューティングシステムに提供するために、使用中にコンピューティングシステムによってアクセス可能である。一般的に、そのようなコンピューティングシステムは、少なくとも1つ以上のメモリと、プログラム命令を実行するように構成された1つ以上のプロセッサと、を含む。
【0048】
上述した実施形態は、実施形態の非限定的な例示に過ぎないことを強調しておきたい。上記の開示が十分に理解されれば、多くの変形及び修正が当業者に明らかになる。以下の特許請求の範囲は、このような変形及び修正の全てを包含すると解釈されることが意図されている。
図1
図2
図3
図4
図5
図6
図7
図8
図9
図10
図11
図12
図13
図14
図15