JP2011529236A - Partition-based performance analysis for graphics imaging - Google Patents

Partition-based performance analysis for graphics imaging Download PDF

Info

Publication number
JP2011529236A
JP2011529236A JP2011520245A JP2011520245A JP2011529236A JP 2011529236 A JP2011529236 A JP 2011529236A JP 2011520245 A JP2011520245 A JP 2011520245A JP 2011520245 A JP2011520245 A JP 2011520245A JP 2011529236 A JP2011529236 A JP 2011529236A
Authority
JP
Japan
Prior art keywords
graphics
partitions
displaying
computer
display
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
JP2011520245A
Other languages
Japanese (ja)
Other versions
JP5242788B2 (en
Inventor
エルミー、ババック
リッツ、ジェームズ・ピー.
ドービイ、アングス
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
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
Priority claimed from US12/507,767 external-priority patent/US20100020069A1/en
Application filed by Qualcomm Inc filed Critical Qualcomm Inc
Publication of JP2011529236A publication Critical patent/JP2011529236A/en
Application granted granted Critical
Publication of JP5242788B2 publication Critical patent/JP5242788B2/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T11/002D [Two Dimensional] image generation
    • G06T11/40Filling a planar surface by adding surface attributes, e.g. colour or texture
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T17/00Three dimensional [3D] modelling, e.g. data description of 3D objects

Abstract

一般に、この開示は、幾つかの異なるグラフィカル・パーティションを含むグラフィカル・シーンのビジュアル表現を提供するための技術に関係する。それはユーザがスクリーン分割に関連するコストに起因して低下したパフォーマンスを示すグラフィックス・シーンの部分を識別することを可能にし得る。一つの例示的なデバイスは、表示デバイス及び1又は複数のプロセッサを含む。該1又は複数のプロセッサは、グラフィカル・シーン中に1又は複数のグラフィックス・イメージを前記表示デバイス上に表示し、1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を前記表示デバイス上に表示し、前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析するように構成される。In general, this disclosure relates to techniques for providing a visual representation of a graphical scene that includes several different graphical partitions. It may allow the user to identify portions of the graphics scene that exhibit degraded performance due to the costs associated with screen splitting. One exemplary device includes a display device and one or more processors. The one or more processors are partitions that display one or more graphics images on the display device in a graphical scene, overlay the one or more graphics images, and graphically divide the scene To display on the display device and determine which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions. And configured to analyze the graphics data.

Description

(35 U.S.C. §119の下の優先権の主張)
本特許出願は、2008年7月25日付け提出され、本願の譲受人に譲渡され、参照によって本明細書に明確に組み込まれる「PARTITIONING-BASED PERFORMANCE ANALYSIS FOR GRAPHICS IMAGING」と題された米国仮出願第61/083,659号の優先権を主張する。
(Claiming priority under 35 USC §119)
This patent application is filed July 25, 2008, is assigned to the assignee of the present application, and is a US provisional application entitled “PARTITIONING-BASED PERFORMANCE ANALYSIS FOR GRAPHICS IMAGING”, which is expressly incorporated herein by reference. Claim the priority of 61 / 083,659.

(同時継続の特許出願への参照)
本特許出願は、以下の同時継続の米国特許出願に関係する:
2008年7月25日付け提出され、これと共に同時に提出され、本願の譲受人に譲渡され、参照によって本明細書に明確に組み込まれる米国特許出願第61/083,656号(Attorney Docket No. 080967P1);及び
2008年7月25日付け提出され、これと共に同時に提出され、本願の譲受人に譲渡され、参照によって本明細書に明確に組み込まれる米国特許出願第61/083,665号(Attorney Docket No. 080971P1)。
(Reference to concurrent patent applications)
This patent application is related to the following concurrent US patent applications:
US patent application Ser. No. 61 / 083,656 (Attorney Docket No. 080967P1) filed Jul. 25, 2008, filed concurrently with this, assigned to the assignee of the present application and expressly incorporated herein by reference. );as well as
US Patent Application No. 61 / 083,665 (Attorney Docket No. 080971P1), filed July 25, 2008, filed concurrently therewith, assigned to the assignee of the present application, and expressly incorporated herein by reference. ).

(技術分野)
この開示は、グラフィックス・イメージの表示に関係する。
(Technical field)
This disclosure relates to the display of graphics images.

グラフィックス・プロセッサは、例えばテレビゲーム、グラフィックス・プログラム、コンピュータ・デザイン(CAD)アプリケーション、シミュレーション及びビジュアライゼーション・ツール、及びイメージングのような様々なアプリケーションのために、二次元イメージ(2D)及び三次元イメージ(3D)をレンダリング(render)するために広く使用されている。表示プロセッサは、表示デバイスを介したユーザへの提示のために、グラフィックス・プロセッサのレンダリング出力(rendered output)を表示するのに使用されることがある。   Graphics processors are used for various applications such as video games, graphics programs, computer design (CAD) applications, simulation and visualization tools, and imaging, for example, two-dimensional images (2D) and tertiary. Widely used to render original images (3D). The display processor may be used to display the rendered output of the graphics processor for presentation to the user via the display device.

OpenGL(登録商標)(オープン・グラフィックス・ライブラリー)は、2Dグラフィックス及び3Dグラフィックスを生成するアプリケーションを記述するときに使用されることがあるAPI(アプリケーション・プログラミング・インタフェース)を定義する標準的な仕様である。例えばJava(登録商標)のような他の言語は、それら自身の標準的なプロセスを通したOpenGL APIへのバインディングを定義することがある。インタフェースは、単純なプリミティブからシーンを描画(draw)するために使用可能な複数の関数コール又は命令(instructions)を含む。グラフィックス・プロセッサ、マルチメディア・プロセッサ、そして、汎用CPUでさえ、OpenGL関数コールを使用して記述されるアプリケーションを実行することができる。OpenGL ES(組み込みシステム)は、例えばモバイル無線電話、デジタル・マルチメディア・プレイヤー、携帯情報端末(PDA)又はテレビゲーム機のような、組み込みデバイスのために設計されるOpenGLの改良型(variant)である。   OpenGL® (Open Graphics Library) is a standard that defines an API (Application Programming Interface) that may be used when writing applications that generate 2D and 3D graphics. It is a typical specification. Other languages, such as Java, for example, may define bindings to the OpenGL API through their own standard process. The interface includes a plurality of function calls or instructions that can be used to draw the scene from simple primitives. Even graphics processors, multimedia processors, and even general purpose CPUs can execute applications that are written using OpenGL function calls. OpenGL ES (Embedded System) is a variant of OpenGL designed for embedded devices such as mobile radiotelephones, digital multimedia players, personal digital assistants (PDAs) or video game consoles. is there.

グラフィックス・アプリケーション(例えば、3Dグラフィックス・アプリケーション)は、API群又は命令群を呼び出す(invoking)ことによって、シーンの内容を記述又は定義することがある。API群又は命令群は、イメージを生成するために、内在する(underlying)グラフィックス・ハードウェア(例えば、グラフィックス・デバイス中の1又は複数のプロセッサ)を使用する。グラフィックス・ハードウェアは、これらのAPIを通して実行される一連の状態遷移(state transitions)を経ることがある。各々のAPIコール(例えば、描画コール(draw call)又は命令)に関するステート(states)のフルセットは、ハードウェアにより1又は複数のグラフィックス・プリミティブ(例えば、1又は複数の三角形)からイメージがレンダリングされるプロセスを記述することがある。   A graphics application (eg, a 3D graphics application) may describe or define the contents of a scene by invoking APIs or instructions. The APIs or instructions use underlying graphics hardware (eg, one or more processors in the graphics device) to generate the image. Graphics hardware may go through a series of state transitions that are performed through these APIs. The full set of states for each API call (eg, draw call or instruction) renders the image from one or more graphics primitives (eg, one or more triangles) by hardware. May describe the processes to be performed.

さらに、ビニング・ベース(binning-based)又はパーティショニング・ベース(partitioning-based)のグラフィックス・ハードウェアは、表示デバイスのスクリーン上に表示されるイメージのシーンを分割(divide up)するために、レンダリングすることになっている個々のグラフィックス・プリミティブが、複数のビニング・パーティション又はビンにクラスタリングされるプロセスを使用して、しばしば実装されることがある。該ハードウェアは、スクリーンサイズ若しくは解像度の制約上のために又はレンダリング・オペレーションに関連するメモリの限界上のために、そうしても良い。グラフィックス・プリミティブ(それは複数のビニング・パーティションにわたることがある)は、プリミティブ・フラグメントがレンダリングされる前に、パーティションのエッジに沿って、ハードウェアにより複数のフラグメントに分割されることがある。ハードウェアは、各々のパーティションにおいて、独立して、すべてのプリミティブ・フラグメントをレンダリングすることがある。   In addition, binning-based or partitioning-based graphics hardware can be used to divide up an image scene displayed on a display device screen. The individual graphics primitives that are to be rendered are often implemented using a process that is clustered into multiple binning partitions or bins. The hardware may do so due to screen size or resolution constraints or due to memory limitations associated with rendering operations. A graphics primitive (which may span multiple binning partitions) may be divided into multiple fragments by hardware along the edges of the partition before the primitive fragment is rendered. The hardware may render all primitive fragments independently in each partition.

それゆえ、個々のプリミティブ(それは例えば2つのビニング・パーティションにわたることがある)は、2つのフラグメントに分割されることがあり、そして、これらの2つのフラグメントの各々は、独立してレンダリングされることがある。しかし、これらのフラグメントの各々により生成されるグラフィックス・イメージは、それから、表示デバイスのスクリーン上に表示される前に、イメージ・データのフレーム内で再結合(re-combined)される必要があることがある。それゆえに、複数の異なるパーティションにわたっているプリミティブ・グラフィックス・データは、独立して処理及びレンダリングされることがあり、そして、レンダリングされたイメージ・データは、最終的なイメージを形成するために再結合されることがある。   Thus, an individual primitive (which may span two binning partitions, for example) may be split into two fragments, and each of these two fragments is rendered independently There is. However, the graphics image produced by each of these fragments must then be re-combined within a frame of image data before being displayed on the screen of the display device. Sometimes. Therefore, primitive graphics data across multiple different partitions may be processed and rendered independently, and the rendered image data is recombined to form the final image May be.

一般に、この開示は、幾つかの異なるグラフィカル・パーティションを含むグラフィカル・シーンのビジュアル表現を提供するための技術に関係する。それは、ユーザが、スクリーン分割(screen partitioning)に関連し得るコストに起因して低下したパフォーマンスを示すグラフィックス・シーンの部分を識別するのを可能にし得る。グラフィックス・デバイス(例えば、モバイル・デバイス)は、グラフィックス・ドライバーによって作成されたパーティションの数及びタイプに基づいて、パーティショニング又はビニング情報を外部コンピュータ・デバイス(例えば、パーソナル・コンピュータ)へ提供しても良い。グラフィックス・デバイスはまた、グラフィックス命令及びステート情報をコンピュータ・デバイスに提供しても良い。   In general, this disclosure relates to techniques for providing a visual representation of a graphical scene that includes several different graphical partitions. It may allow the user to identify portions of the graphics scene that exhibit reduced performance due to costs that can be associated with screen partitioning. A graphics device (eg, a mobile device) provides partitioning or binning information to an external computing device (eg, a personal computer) based on the number and type of partitions created by the graphics driver. May be. The graphics device may also provide graphics instructions and state information to the computing device.

コンピュータ・デバイスは、グラフィックス命令及びステート情報に基づいて、グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示しても良い。コンピュータ・デバイスはまた、受信されたパーティショニング情報に基づいて、シーンをオーバーレイするパーティションのグラフィカル表現を表示しても良く、また、潜在的な(potential)分割コスト又はパフォーマンス・オーバーヘッドに関する解析情報を提供しても良い。アプリケーション開発者は、これらのコスト及び/又はパフォーマンス・オーバーヘッドを低減するのを支援するために、シーンの代わりのコンポジション(compositions)を調査(investigate)するために、この情報を使用しても良い。   The computing device may display one or more graphics images in the graphical scene based on the graphics instructions and state information. The computing device may also display a graphical representation of the partition overlaying the scene based on the received partitioning information and provide analysis information regarding potential partitioning costs or performance overhead You may do it. Application developers may use this information to investigate alternative compositions in the scene to help reduce these costs and / or performance overhead. .

一つの態様において、方法は、グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示することと、1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示することと、前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析することを含む。   In one aspect, a method displays a graphic image in a graphical scene and a graphical representation of a partition that overlays the graphic image and graphically divides the scene. And determining which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions. Including analyzing the data.

一つの態様において、デバイスは、表示デバイス及び1又は複数のプロセッサを含む。前記1又は複数のプロセッサは、グラフィカル・シーン中に1又は複数のグラフィックス・イメージを前記表示デバイス上に表示し、1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を前記表示デバイス上に表示し、前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析するように構成される。   In one aspect, the device includes a display device and one or more processors. The one or more processors display one or more graphics images on the display device in a graphical scene, overlay the one or more graphics images, and partition the scene graphically To display on the display device and determine which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions. And is configured to analyze the graphics data.

一つの態様において、コンピュータ読み取り可能な媒体は、1又は複数のプロセッサに、グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示させ、1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示させ、前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析させるためのコンピュータ実行可能な命令を含む。   In one aspect, a computer-readable medium causes one or more processors to display one or more graphics images in a graphical scene and overlays the one or more graphics images and the scene. Display a graphical representation of the partition that graphically divides the image and determine which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions For that purpose, it includes computer-executable instructions for causing the graphics data to be analyzed.

この開示において説明される技術は、ハードウェア、ソフトウェア、ファームウェア又はそれらの任意の組み合せにおいて実装されても良い。ソフトウェアで実装される場合には、ソフトウェアは、プロセッサで実行されても良い。プロセッサは、1又は複数のプロセッサ(例えば、マイクロプロセッサ)、特定用途向けIC(ASIC)、フィールド・プログラマブル・ゲート・アレイ(FPGA)、又はデジタルシグナルプロセッサ(DSP)、又は他の等価な集積化された若しくは個別の論理回路を指し示しても良い。本技術を実行するための命令を含むソフトウェアは、最初にコンピュータ読み取り可能な媒体に記憶されロードされ、そして、プロセッサにより実行されても良い。   The techniques described in this disclosure may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the software may be executed by a processor. The processor may be one or more processors (eg, a microprocessor), application specific integrated circuit (ASIC), field programmable gate array (FPGA), or digital signal processor (DSP), or other equivalent integrated. Alternatively, individual logic circuits may be indicated. Software containing instructions for performing the techniques may be initially stored and loaded on a computer readable medium and executed by a processor.

したがって、この開示はまた、この開示において説明される様々な技術の任意のものをプロセッサに実行させる命令を含むコンピュータ読み取り可能な媒体を意図する。場合によっては、コンピュータ読み取り可能な媒体は、製造者に販売され得る及び/又はデバイスで使用され得るコンピュータ・プログラム製品の一部を形成しても良い。コンピュータ・プログラム製品は、コンピュータ読み取り可能な媒体を含んでも良いし、場合によっては、また、パッケージ材料を含んでも良い。   Accordingly, this disclosure also contemplates computer-readable media containing instructions that cause a processor to perform any of the various techniques described in this disclosure. In some cases, computer readable media may form part of a computer program product that may be sold to a manufacturer and / or used in a device. The computer program product may include a computer readable medium and, in some cases, may also include packaging material.

添付の図面及び下記の説明において1又は複数の態様の詳細が説明される。他の特徴、目的及び利点は説明及び図面から並びにクレームから明らかである。   The details of one or more aspects are set forth in the accompanying drawings and the description below. Other features, objects, and advantages will be apparent from the description and drawings, and from the claims.

図1は、本開示の一つの態様に従って、グラフィックス命令、ステート及び/又はパフォーマンス情報及びパーティショニング情報を、アプリケーション・コンピュータ・デバイスに提供し得るグラフィックス・デバイスを示すブロック図である。FIG. 1 is a block diagram illustrating a graphics device that may provide graphics instructions, state and / or performance information and partitioning information to an application computing device in accordance with one aspect of the present disclosure. 図2は、本開示の一つの態様に従って、図1に示されるグラフィックス処理システム、グラフィックス・ドライバー及びアプリケーション・コンピュータ・デバイスの特定の詳細を示すブロック図である。FIG. 2 is a block diagram illustrating certain details of the graphics processing system, graphics driver, and application computer device shown in FIG. 1, in accordance with one aspect of the present disclosure. 図3は、本開示の一つの態様に従って、図1に示される制御プロセッサ、グラフィックス・プロセッサ、頂点プロセッサ及び表示プロセッサにより実行され得るオペレーションの更なる詳細を示すフロー・ダイアグラムである。FIG. 3 is a flow diagram illustrating further details of operations that may be performed by the control processor, graphics processor, vertex processor, and display processor shown in FIG. 1 according to one aspect of the present disclosure. 図4は、本開示の一つの態様に従って、図2に示されるグラフィックス・ドライバーの更なる詳細を示すブロック図である。FIG. 4 is a block diagram illustrating further details of the graphics driver shown in FIG. 2 in accordance with one aspect of the present disclosure. 図5Aは、本開示の一つの態様に従って、表示デバイスにより提供されるスクリーン・エリアの4つのパーティションにわたり得るグラフィックス・データの第1の例を示す概念図である。FIG. 5A is a conceptual diagram illustrating a first example of graphics data that may span four partitions of a screen area provided by a display device, according to one aspect of the present disclosure. 図5Bは、パーティション境界に沿ってスプリットされる図5Aの第1の例のグラフィックス・データを示す概念図である。FIG. 5B is a conceptual diagram illustrating the graphics data of the first example of FIG. 5A that is split along partition boundaries. 図6は、本開示の一つの態様に従って、表示デバイスにより提供されるスクリーン・エリアの8つのパーティションにわたり得るグラフィックス・データの第2の例を示す概念図である。FIG. 6 is a conceptual diagram illustrating a second example of graphics data that may span eight partitions of a screen area provided by a display device, according to one aspect of the present disclosure. 図7は、本開示の一つの態様に従って、図1に示されるアプリケーション・コンピュータ・デバイスにより実行され得る第1の方法のフローチャートである。FIG. 7 is a flowchart of a first method that may be performed by the application computing device shown in FIG. 1 according to one aspect of the present disclosure. 図8は、本開示の一つの態様に従って、図1に示されるアプリケーション・コンピュータ・デバイスにより実行され得る第2の方法のフローチャートである。FIG. 8 is a flowchart of a second method that may be performed by the application computing device shown in FIG. 1 in accordance with one aspect of the present disclosure. 図9は、本開示の一つの態様に従って、グラフィック・ウインドウ中に情報を表示するための表示デバイスに接続されるグラフィックス・デバイスの例を示す概念図である。FIG. 9 is a conceptual diagram illustrating an example of a graphics device connected to a display device for displaying information in a graphics window in accordance with one aspect of the present disclosure. 図10は、本開示の一つの態様に従って、グラフィカル・ウインドウ中に情報を表示する表示デバイスに接続されるグラフィックス・デバイスの他の例を示す概念図である。FIG. 10 is a conceptual diagram illustrating another example of a graphics device connected to a display device that displays information in a graphical window in accordance with one aspect of the present disclosure.

詳細な説明Detailed description

図1は、本開示の一つの態様に従って、グラフィックス命令30、ステート及び/又はパフォーマンス情報32及びパーティショニング情報33を、アプリケーション・コンピュータ・デバイス20に提供し得るグラフィックス・デバイス2を示すブロック図である。グラフィックス・デバイス2は、独立型デバイスであっても良いし、あるいは、より大きなシステムの一部であっても良い。例えば、グラフィックス・デバイス2は、無線通信デバイス(例えば、無線モバイル・ハンドセット)の一部を形成しても良いし、あるいは、デジタル・カメラ、ビデオ・カメラ、デジタル・マルチメディア・プレイヤー、携帯情報端末(PDA)、テレビゲーム機、他のビデオ・デバイス又は専用の視聴局(viewing station)(例えば、テレビ)の一部であっても良い。グラフィックス・デバイス2はまた、パソコン又はラップトップ・デバイスを含んでも良い。グラフィックス・デバイス2は、上で説明されたデバイスの一部又は全部において使用され得る、1又は複数の集積回路、チップ又はチップセットに含まれても良い。   FIG. 1 is a block diagram illustrating a graphics device 2 that may provide graphics instructions 30, state and / or performance information 32, and partitioning information 33 to an application computing device 20 in accordance with one aspect of the present disclosure. It is. Graphics device 2 may be a stand-alone device or may be part of a larger system. For example, the graphics device 2 may form part of a wireless communication device (eg, a wireless mobile handset), or a digital camera, video camera, digital multimedia player, portable information It may be part of a terminal (PDA), video game console, other video device or dedicated viewing station (eg, television). Graphics device 2 may also include a personal computer or laptop device. The graphics device 2 may be included in one or more integrated circuits, chips or chip sets that may be used in some or all of the devices described above.

場合によっては、グラフィックス・デバイス2は、様々なアプリケーション(例えば、グラフィックス・アプリケーション、ビデオ・アプリケーション、音声アプリケーション及び/又は他のマルチメディア・アプリケーション)を実行することができても良い。例えば、グラフィックス・デバイス2は、グラフィックス・アプリケーション、テレビゲーム・アプリケーション、ビデオ・プレイバック・アプリケーション、デジタル・カメラ・アプリケーション、インスタントメッセージング・アプリケーション、ビデオ通信会議アプリケーション、モバイル・アプリケーション又はビデオストリーミング・アプリケーションのために使用されても良い。   In some cases, graphics device 2 may be capable of running various applications (eg, graphics application, video application, audio application, and / or other multimedia application). For example, the graphics device 2 may be a graphics application, a video game application, a video playback application, a digital camera application, an instant messaging application, a video teleconferencing application, a mobile application, or a video streaming application. May be used for.

グラフィックス・デバイス2は、様々な異なるデータ・タイプ及びフォーマットを処理することができても良い。例えば、グラフィックス・デバイス2は、下で更に詳細に説明されるように、静止画データ、動画(ビデオ)データ又は他のマルチメディア・データを処理しても良い。イメージ・データは、コンピュータグラフィック・データを含んでも良い。図1の例において、グラフィックス・デバイス2は、グラフィックス処理システム4、記憶媒体8(それは、メモリを含んでも良い)及び表示デバイス6を含む。プログラム可能なプロセッサ10,12,14及び16は、グラフィックス処理システム4内に含まれても良い。プログラム可能なプロセッサ10は、制御又は汎用プロセッサである。プログラム可能なプロセッサ12は、グラフィックス・プロセッサであり、プログラム可能なプロセッサ14は、頂点プロセッサであり、プログラム可能なプロセッサ16は、表示プロセッサである。制御プロセッサ10は、グラフィックス・プロセッサ12、頂点プロセッサ14及び/又は表示プロセッサ16を制御することができても良い。一つの態様において、グラフィックス処理システム4は、他の形のマルチメディア・プロセッサを含んでも良い。   Graphics device 2 may be able to handle a variety of different data types and formats. For example, the graphics device 2 may process still image data, video (video) data, or other multimedia data, as will be described in more detail below. The image data may include computer graphic data. In the example of FIG. 1, the graphics device 2 includes a graphics processing system 4, a storage medium 8 (which may include memory) and a display device 6. Programmable processors 10, 12, 14 and 16 may be included in the graphics processing system 4. The programmable processor 10 is a control or general purpose processor. Programmable processor 12 is a graphics processor, programmable processor 14 is a vertex processor, and programmable processor 16 is a display processor. The control processor 10 may be able to control the graphics processor 12, the vertex processor 14 and / or the display processor 16. In one embodiment, graphics processing system 4 may include other forms of multimedia processors.

グラフィックス・デバイス2において、グラフィックス処理システム4は、記憶媒体8に及び表示デバイス6に接続する。記憶媒体8は、例えばシンクロナスダイナミックランダムアクセスメモリ(SDRAM)、リードオンリーメモリ(ROM)、不揮発性ランダムアクセスメモリ(NVRAM)、組み込みダイナミックランダムアクセスメモリ(eDRAM)、スタティックランダムアクセスメモリ(SRAM)又はフラッシュメモリのような、命令及び/又はデータを格納することができる任意の固定(permanent)又は揮発性メモリを含んでも良い。表示デバイス6は、例えばLCD(液晶ディスプレイ)、プラズマ・ディスプレイ・デバイス又は他のテレビ(TV)表示デバイスのような、表示目的のイメージ・データを表示することができる任意のデバイスであっても良い。   In the graphics device 2, the graphics processing system 4 is connected to the storage medium 8 and to the display device 6. The storage medium 8 is, for example, synchronous dynamic random access memory (SDRAM), read only memory (ROM), nonvolatile random access memory (NVRAM), embedded dynamic random access memory (eDRAM), static random access memory (SRAM) or flash. It may include any permanent or volatile memory that can store instructions and / or data, such as a memory. The display device 6 may be any device capable of displaying image data for display purposes, such as an LCD (liquid crystal display), plasma display device or other television (TV) display device. .

頂点プロセッサ14は、頂点情報を管理し、頂点変換を処理することができる。一つの態様において、頂点プロセッサ14は、デジタルシグナルプロセッサ(DSP)を含んでも良い。グラフィックス・プロセッサ12は、コンピュータ化されたグラフィックスをレンダリング、操作(manipulate)及び表示するために利用される専用グラフィックス・レンダリング・デバイスであっても良い。グラフィックス・プロセッサ12は、様々な複雑な(complex)グラフィックス関係アルゴリズムを実装しても良い。例えば、複雑なアルゴリズムは、2次元又は3次元コンピュータ化グラフィックスの表現(representations)に対応しても良い。グラフィックス・プロセッサ12は、ディスプレイ(例えば表示デバイス6)上の複雑な3次元イメージを作成するために、幾つかのいわゆる“プリミティブ(primitive)”グラフィックス・オペレーション(例えば、点、線及び三角形又は他のポリゴン面の形成)を実装しても良い。   The vertex processor 14 manages vertex information and can process vertex transformations. In one aspect, vertex processor 14 may include a digital signal processor (DSP). Graphics processor 12 may be a dedicated graphics rendering device that is utilized to render, manipulate, and display computerized graphics. Graphics processor 12 may implement various complex graphics related algorithms. For example, complex algorithms may correspond to representations of 2D or 3D computerized graphics. The graphics processor 12 may perform several so-called “primitive” graphics operations (eg, points, lines and triangles or the like) to create a complex three-dimensional image on a display (eg, display device 6). Another polygon surface formation) may be implemented.

グラフィックス・プロセッサ12は、記憶媒体8に記憶される命令を実行しても良い。記憶媒体8は、1又は複数のグラフィックス・ドライバー18だけでなく、アプリケーション(例えばグラフィックス又はビデオ・アプリケーション)に関するアプリケーション命令21を記憶することができる。アプリケーション命令21は、実行のために記憶媒体8からグラフィックス処理システム4へロードされても良い。例えば、制御プロセッサ10、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数が、命令21を実行しても良い。一つの態様において、アプリケーション命令21は、記憶媒体8に無線で動的にダウンロードされる1又は複数のダウンロード可能なモジュールを含んでも良い。一つの態様において、アプリケーション命令21は、アプリケーション開発者により作成されるアプリケーション・プログラミング・インタフェース(API)命令から生成又はコンパイルされるるバイナリ命令のコール・ストリームを含んでも良い。   The graphics processor 12 may execute instructions stored in the storage medium 8. The storage medium 8 can store application instructions 21 relating to applications (eg, graphics or video applications) as well as one or more graphics drivers 18. Application instructions 21 may be loaded from the storage medium 8 into the graphics processing system 4 for execution. For example, one or more of the control processor 10, graphics processor 12, and display processor 16 may execute the instruction 21. In one aspect, the application instructions 21 may include one or more downloadable modules that are dynamically downloaded to the storage medium 8 dynamically. In one aspect, application instructions 21 may include a binary instruction call stream that is generated or compiled from application programming interface (API) instructions created by an application developer.

グラフィックス・ドライバー18はまた、実行のために記憶媒体8からグラフィックス処理システム4にロードされても良い。例えば、制御プロセッサ10、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数が、グラフィックス・ドライバー18からの特定の命令を実行しても良い。一つの例示的な態様において、グラフィックス・ドライバー18は、グラフィックス・プロセッサ12によりロード及び実行される。グラフィックス・ドライバー18は、下で更に詳細に説明される。   The graphics driver 18 may also be loaded from the storage medium 8 into the graphics processing system 4 for execution. For example, one or more of the control processor 10, graphics processor 12, and display processor 16 may execute specific instructions from the graphics driver 18. In one exemplary embodiment, graphics driver 18 is loaded and executed by graphics processor 12. Graphics driver 18 is described in further detail below.

記憶媒体8はまた、グラフィックス・データ・マッピング情報23を含む。グラフィックス・データ・マッピング情報23は、アプリケーション命令21のうちの1又は複数を、アプリケーション命令21の実行の間にレンダリングされ得るグラフィックス・データにマッピングする情報を含む。グラフィックス・データ(それは記憶媒体8及び/又はバッファ15に記憶されても良い)は、1又は複数のプリミティブ(例えば、ポリゴン)を含んでも良い。グラフィックス・データ・マッピング情報23は、個々の命令に対してレンダリングされるべき個々のプリミティブのマッピングを維持しても良い。プリミティブがレンダリングされた後、マッピング情報23は、個々の命令から、グラフィックス・デバイス6上に最終的に表示される1又は複数のイメージを作成するのに使用されたオリジナルのプリミティブ・グラフィックス・データへのマッピングを可能にする。マッピング情報23は、場合によっては、デバッギング及び/又はパフォーマンス解析に役立つことがある。   The storage medium 8 also includes graphics data mapping information 23. The graphics data mapping information 23 includes information that maps one or more of the application instructions 21 to graphics data that can be rendered during execution of the application instructions 21. The graphics data (which may be stored in storage medium 8 and / or buffer 15) may include one or more primitives (eg, polygons). Graphics data mapping information 23 may maintain a mapping of individual primitives to be rendered for individual instructions. After the primitive is rendered, the mapping information 23 is the original primitive graphics used to create one or more images that are ultimately displayed on the graphics device 6 from the individual instructions. Allows mapping to data. The mapping information 23 may be useful for debugging and / or performance analysis in some cases.

また、図1に示されるように、グラフィックス処理システム4は、1又は複数のバッファ15を含む。制御プロセッサ10、グラフィックス・プロセッサ12、頂点プロセッサ14及び/又は表示プロセッサ16は、各々、バッファ15へのアクセスを有し、また、バッファ15へデータを記憶し又はバッファ15からデータを検索しても良い。バッファ15は、キャッシュメモリを含んでも良く、また、データと命令の両方を記憶することができても良い。例えば、バッファ15は、アプリケーション命令21のうちの1又は複数、又は、記憶媒体8からグラフィックス処理システム4にロードされたグラフィックス・ドライバー18からの1又は複数の命令を含んでも良い。バッファ15及び/又は記憶媒体8はまた、命令の実行の間に使用されるグラフィックス・データを含んでも良い。   As shown in FIG. 1, the graphics processing system 4 includes one or a plurality of buffers 15. Control processor 10, graphics processor 12, vertex processor 14 and / or display processor 16 each have access to buffer 15 and store data in buffer 15 or retrieve data from buffer 15. Also good. The buffer 15 may include a cache memory, and may be capable of storing both data and instructions. For example, the buffer 15 may include one or more of the application instructions 21 or one or more instructions from the graphics driver 18 loaded from the storage medium 8 into the graphics processing system 4. Buffer 15 and / or storage medium 8 may also include graphics data that is used during execution of instructions.

アプリケーション命令21は、特定のケースにおいて、グラフィックス・アプリケーション(例えば、3Dグラフィックス・アプリケーション)のための命令を含んでも良い。アプリケーション命令21は、1又は複数のグラフィックス・イメージを含むグラフィックス・シーンのコンテンツを記述又は定義する命令を含んでも良い。アプリケーション命令21がグラフィックス処理システム4によりロード及び実行されるとき、グラフィックス処理システム4は、一連の状態遷移を経ても良い。グラフィックス・ドライバー18内の1又は複数の命令はまた、アプリケーション命令21の実行の間にグラフィックス・イメージを表示デバイス6上にレンダリング又は表示するために実行されても良い。   Application instructions 21 may include instructions for graphics applications (eg, 3D graphics applications) in certain cases. Application instructions 21 may include instructions that describe or define the contents of a graphics scene that includes one or more graphics images. When the application instruction 21 is loaded and executed by the graphics processing system 4, the graphics processing system 4 may go through a series of state transitions. One or more instructions in the graphics driver 18 may also be executed to render or display a graphics image on the display device 6 during execution of the application instructions 21.

例えば描画コールのような命令に関するステートのフルセットは、イメージがグラフィックス処理システム4によりレンダリングされるプロセスを記述しても良い。しかし、アプリケーション命令21を書いたアプリケーション開発者は、定義されたシーン中のイメージを記述又はレンダリングする代わりの方法(alternate methods)によるデバッギング又は実験の目的で、これらのステートをインタラクティブに閲覧(view)又は修正する能力(ability)がしばしば制限されることがある。さらに、異なるハードウェア・プラットホームは、これらのステート及び/又は状態遷移の異なるハードウェア・デザイン及び実装を有することがある。   For example, a full set of states for instructions such as draw calls may describe the process by which an image is rendered by the graphics processing system 4. However, the application developer who wrote the application instructions 21 can interactively view these states for debugging or experimental purposes with alternative methods to describe or render an image in a defined scene. Or the ability to modify is often limited. Further, different hardware platforms may have different hardware designs and implementations of these states and / or state transitions.

さらに、ビニング・ベースのグラフィックス・ハードウェア(例えば、プロセッサ10,12,14及び16のうちの1又は複数)は、表示デバイス6のスクリーン上に表示されるイメージのシーンを分割するために、レンダリングすることになっている個々のプリミティブが、長方形の形の(rectangular-shaped)ビニング・パーティション又はビンにクラスターされるプロセスを使用して、しばしば実装されても良い。ハードウェアは、表示デバイス6のスクリーンサイズ又は解像度制約に基づいて又はオペレーションのレンダリングに関連する記憶媒体8のメモリ制限に基づいて、そうしても良い。複数のビニング・パーティションにわたり得るプリミティブは、プリミティブ・フラグメントがレンダリングされる前に、パーティションのエッジに沿って、プロセッサ10,12,14又は16のうちの1又は複数によって、複数のフラグメントに分割されても良い。各々のパーティションにおけるプリミティブ・フラグメントは、それから、別々にレンダリングされても良い。一般に、ビニング・パーティションは、ハードウェア・アーキテクチャーに応じて、総計が変化させられても良く、また、様々なサイズ及び形を有しても良い。例えば、ビニング・パーティションは、複数(例えば、4つ,8つ)の長方形の形のパーティションを含んでも良い。   Further, binning-based graphics hardware (eg, one or more of processors 10, 12, 14, and 16) may be used to divide the scene of the image displayed on the screen of display device 6. Individual primitives that are to be rendered may often be implemented using a process that is clustered into rectangular-shaped binning partitions or bins. The hardware may do so based on the screen size or resolution constraints of the display device 6 or based on the memory limitations of the storage medium 8 associated with the rendering of the operation. Primitives that can span multiple binning partitions are split into multiple fragments by one or more of processors 10, 12, 14, or 16 along the edge of the partition before the primitive fragments are rendered. Also good. The primitive fragments in each partition may then be rendered separately. In general, the binning partition may vary in aggregate depending on the hardware architecture, and may have various sizes and shapes. For example, the binning partition may include a plurality (eg, four, eight) rectangular partitions.

それゆえ、例えば2つのビニング・パーティションにわたり得る個々のプリミティブは、2つのフラグメントに分割されても良く、また、これらの2つのフラグメントの各々は、それから、独立してレンダリングされても良い。しかし、これらのフラグメントの各々によって生成されるグラフィックス・イメージは、それから、表示デバイス6のスクリーン上に表示される前に、イメージ・データのフレーム内で再結合される必要があり得る。それゆえ、複数のビニング・パーティションにわたる個々のプリミティブを分割することは、潜在的な(potential)処理オーバーヘッドを有する可能性があり、また、全体的なパフォーマンス劣化を引き起こす可能性がある。   Thus, for example, an individual primitive that may span two binning partitions may be divided into two fragments, and each of these two fragments may then be rendered independently. However, the graphics image produced by each of these fragments may then need to be recombined within a frame of image data before being displayed on the screen of the display device 6. Therefore, splitting individual primitives across multiple binning partitions can have potential processing overhead and can cause overall performance degradation.

一つの態様において、アプリケーション開発者は、シーン中のイメージを記述又はレンダリングするための代わりの方法によるデバッギング及び実験の処理を支援するために、図1に示されるように、アプリケーション・コンピュータ・デバイス20を使用しても良い。アプリケーション・コンピュータ・デバイス20は、シーンを表示すること、及び、グラフィックス・デバイス2によって実装され得るビニング・パーティションのグラフィカル表現をオーバーレイすることができても良い。アプリケーション・コンピュータ・デバイス20は、グラフィックス・デバイス2に接続される。例えば、一つの態様において、アプリケーション・コンピュータ・デバイス20は、ユニバーサルシステムバス(USB)コネクションを介して、グラフィックス・デバイス2に接続される。他の態様において、他のタイプのコネクション(例えば無線又は他の形の有線接続)が、使用されても良い。   In one aspect, an application developer may use an application computing device 20 as shown in FIG. 1 to assist in debugging and experimentation with alternative methods for describing or rendering an image in a scene. May be used. The application computing device 20 may be able to display the scene and overlay a graphical representation of the binning partition that may be implemented by the graphics device 2. The application computer device 20 is connected to the graphics device 2. For example, in one aspect, the application computer device 20 is connected to the graphics device 2 via a universal system bus (USB) connection. In other aspects, other types of connections (eg, wireless or other forms of wired connections) may be used.

アプリケーション・コンピュータ・デバイス20は、1又は複数のプロセッサ22、表示デバイス24及び記憶媒体26(それは、メモリを含んでもよい)を含む。一つの態様に従って、プロセッサ22は、制御プロセッサ、グラフィックス・プロセッサ、頂点プロセッサ及び表示プロセッサのうちの1又は複数を含んでも良い。記憶媒体26は、例えばシンクロナスダイナミックランダムアクセスメモリ(SDRAM)、リードオンリーメモリ(ROM)、不揮発性ランダムアクセスメモリ(NVRAM)、スタティックランダムアクセスメモリ(SRAM)又はフラッシュメモリ)のような、命令及び/又はデータを格納することができる任意の固定又は揮発性メモリを含んでも良い。表示デバイス24は、例えばLCD(液晶ディスプレイ)、プラズマ・ディスプレイ・デバイス又は他のテレビ(TV)表示デバイスのような、表示目的のイメージ・データを表示することができる任意のデバイスであっても良い。   Application computer device 20 includes one or more processors 22, a display device 24, and a storage medium 26 (which may include memory). In accordance with one aspect, the processor 22 may include one or more of a control processor, a graphics processor, a vertex processor, and a display processor. The storage medium 26 includes instructions and / or instructions such as, for example, synchronous dynamic random access memory (SDRAM), read only memory (ROM), non-volatile random access memory (NVRAM), static random access memory (SRAM) or flash memory). Or any fixed or volatile memory capable of storing data. Display device 24 may be any device capable of displaying image data for display purposes, such as an LCD (Liquid Crystal Display), a plasma display device or other television (TV) display device. .

アプリケーション・コンピュータ・デバイス20は、グラフィックス・デバイス2から送信される、ステート及び/又はパフォーマンス情報32とともに、グラフィックス命令30を捕捉(capturing)及び解析することができる。一つの態様において、グラフィックス・ドライバー18は、グラフィックス命令30及びステート/パフォーマンス情報32を、アプリケーション・コンピュータ・デバイス20に送信するように構成される。グラフィックス命令30は、アプリケーション命令21のうちの1又は複数を含んでも良く、ステート/パフォーマンス情報32は、グラフィックス処理システム4内でのグラフィックス命令30の実行の間に生成又は補足されても良い。   Application computer device 20 may capture and analyze graphics instructions 30 along with state and / or performance information 32 transmitted from graphics device 2. In one aspect, the graphics driver 18 is configured to send graphics instructions 30 and state / performance information 32 to the application computing device 20. Graphics instructions 30 may include one or more of application instructions 21, and state / performance information 32 may be generated or supplemented during execution of graphics instructions 30 within graphics processing system 4. good.

ステート/パフォーマンス情報32は、命令の実行の間のグラフィックス処理システム4のステート及び/又はパフォーマンスに関する情報を含んでも良く、それは下で更に詳細に説明される。ステート/パフォーマンス情報32は、グラフィックス命令30で使用され得る又はさもなければグラフィックス命令30に関連し得るグラフィックス・データ(例えば、プリミティブの及び/又はラスタライズされたグラフィックス・データ)を含んでも良い。グラフィックス処理システム4は、表示デバイス6上にイメージ又は複数のイメージからなるシーンを表示するためにグラフィックス命令30を実行しても良い。アプリケーション・コンピュータ・デバイス20は、グラフィックス・デバイス2の表示デバイス6に同様に表示されるグラフィックス・イメージ又はシーンを再作成(re-create)するために、ステート/パフォーマンス情報32とともに、グラフィックス命令30を使用することができる。   The state / performance information 32 may include information regarding the state and / or performance of the graphics processing system 4 during execution of instructions, which will be described in further detail below. State / performance information 32 may also include graphics data (eg, primitive and / or rasterized graphics data) that may be used in graphics instructions 30 or otherwise associated with graphics instructions 30. good. Graphics processing system 4 may execute graphics instructions 30 to display an image or a scene composed of a plurality of images on display device 6. Application computer device 20, along with state / performance information 32, graphics to re-create a graphics image or scene that is also displayed on display device 6 of graphics device 2. Instruction 30 can be used.

グラフィックス・デバイス2はまた、マッピング及び/又はパーティショニング情報33を、アプリケーション・コンピュータ・デバイス20に送信しても良い。一つの態様において、グラフィックス・ドライバー18が、マッピング/パーティショニング情報33を、アプリケーション・コンピュータ・デバイス20に送信するように構成される。マッピング/パーティショニング情報33は、グラフィックス・データ・マッピング情報23(それはグラフィックス命令30内の個々の命令にグラフィックス・データをマッピングする情報を含む)の1又は複数の部分を含んでも良い。例えば、マッピング/パーティショニング情報33は、グラフィックス命令30内の個々の命令に1又は複数のプリミティブ(例えば、ポリゴン)をマッピングする情報を含んでも良い。   Graphics device 2 may also send mapping and / or partitioning information 33 to application computer device 20. In one aspect, the graphics driver 18 is configured to send the mapping / partitioning information 33 to the application computing device 20. Mapping / partitioning information 33 may include one or more portions of graphics data mapping information 23 (which includes information that maps graphics data to individual instructions within graphics instruction 30). For example, the mapping / partitioning information 33 may include information that maps one or more primitives (eg, polygons) to individual instructions within the graphics instruction 30.

マッピング/パーティショニング情報33はまた、グラフィックス・デバイス2によって生成及び提供されるパーティショニング情報を含んでも良い。このパーティショニング情報は、場合によっては、プロセッサ10,12,14及び16のうちの1又は複数(例えば制御プロセッサ10)によって生成及び提供されても良い。パーティショニング情報は、1又は複数のグラフィックス・イメージ中にグラフィックス・データをレンダリングし及びそのようなイメージを表示デバイス6上に表示するためにグラフィックス処理システム4内で使用され得る、ビニング・パーティション又はビンの数、タイプ、サイズ及び/又は形状を識別する情報を含んでも良い。前に説明されたように、グラフィックス・デバイス2は、例えば、オペレーションのレンダリング中のバッファ15及び/又は記憶媒体8のメモリサイズ制限に基づいて、表示デバイス6のスクリーン・スペース又はサイズを複数のパーティションに分割しても良い。パーティショニング情報は、作成及び使用されるパーティションに関する情報を提供する。図5及び6は、そのようなパーティションの例を表す。   The mapping / partitioning information 33 may also include partitioning information generated and provided by the graphics device 2. This partitioning information may optionally be generated and provided by one or more of the processors 10, 12, 14, and 16 (eg, the control processor 10). The partitioning information may be used within the graphics processing system 4 to render graphics data in one or more graphics images and display such images on the display device 6. Information that identifies the number, type, size and / or shape of the partition or bin may be included. As previously described, the graphics device 2 may reduce the screen space or size of the display device 6 based on, for example, the buffer 15 and / or memory size limitations of the storage medium 8 during the rendering of the operation. It may be divided into partitions. Partitioning information provides information about the partitions that are created and used. Figures 5 and 6 represent examples of such partitions.

シミュレーション・アプリケーション28は、グラフィックス命令30及びステート/パフォーマンス情報32の受信に応じて、グラフィックス・イメージ又はシーンを再作成し、そして、イメージ又は複数のイメージからなるシーンを表示デバイス24上に表示するために、アプリケーション・コンピュータ・デバイス20の1又は複数のプロセッサ22によって実行されても良い。シミュレーション・アプリケーション28は、幾つかのアプリケーション命令を含むソフトウェア・モジュールを含んでも良い。シミュレーション・アプリケーション28は、記憶媒体26に記憶され、また、プロセッサ22によってロード及び実行されても良い。シミュレーション・アプリケーション28は、記憶媒体26にプリロードされても良く、また、グラフィックス・デバイス2で動作するようにカスタマイズされても良い。   The simulation application 28 recreates the graphics image or scene in response to receiving the graphics instructions 30 and the state / performance information 32 and displays the image or scene composed of multiple images on the display device 24. In order to do so, it may be executed by one or more processors 22 of the application computing device 20. The simulation application 28 may include a software module that includes several application instructions. The simulation application 28 is stored in the storage medium 26 and may be loaded and executed by the processor 22. The simulation application 28 may be preloaded on the storage medium 26 and may be customized to operate on the graphics device 2.

一つの態様において、シミュレーション・アプリケーション28は、グラフィックス・デバイス2のハードウェア・オペレーションをシミュレートする。シミュレーション・アプリケーション28の異なるバージョンが、記憶媒体26に記憶され、異なるハードウェア・デザインを有する異なるグラフィックス・デバイスのためにプロセッサ22によって実行されても良い。また、場合によっては、シミュレーション・アプリケーション28とともに使用されるソフトウェア・ライブラリが、記憶媒体26内に記憶されても良い。一つの態様において、シミュレーション・アプリケーション28は、一般アプリケーションであっても良く、また、特定のハードウェア又はグラフィックス・デバイス・シミュレーション機能性は、実行の間、シミュレーション・アプリケーション28にリンクされ得る各々の独立したライブラリ内に含まれても良い。   In one embodiment, the simulation application 28 simulates the hardware operation of the graphics device 2. Different versions of the simulation application 28 may be stored on the storage medium 26 and executed by the processor 22 for different graphics devices having different hardware designs. In some cases, a software library used with the simulation application 28 may be stored in the storage medium 26. In one aspect, the simulation application 28 may be a general application, and specific hardware or graphics device simulation functionality may be linked to the simulation application 28 during execution. It may be contained in a separate library.

一つの態様において、ステート/パフォーマンス情報32のビジュアル表現が、表示デバイス2上でアプリケーション開発者に対して表示されても良い。さらに、グラフィックス命令30のビジュアル表現が、同様に、表示されても良い。   In one aspect, a visual representation of the state / performance information 32 may be displayed to the application developer on the display device 2. Furthermore, a visual representation of the graphics instruction 30 may be displayed as well.

多くの場合、グラフィックス命令30はバイナリ命令を含むことがあるので、アプリケーション・コンピュータ・デバイス20は、表示デバイス24上でのグラフィックス命令30のビジュアル表現を生成するために、命令マッピング情報31を使用しても良い。命令マッピング情報31は、記憶媒体26内に記憶され、また、グラフィックス命令30のビジュアル表現を表示するために、プロセッサ22にロードされても良い。   In many cases, graphics instructions 30 may include binary instructions, so application computing device 20 may use instruction mapping information 31 to generate a visual representation of graphics instructions 30 on display device 24. May be used. Instruction mapping information 31 is stored in the storage medium 26 and may be loaded into the processor 22 to display a visual representation of the graphics instructions 30.

一つの態様において、命令マッピング情報31は、グラフィックス命令30を生成するときに以前コンパイルされた可能性のある対応するAPI命令へ、グラフィックス命令30をマッピングするために、例えば検索テーブル中などに、マッピング情報を含んでも良い。アプリケーション開発者は、API命令を使用するプログラムを書いても良いが、これらのAPI命令は、一般的に、グラフィックス・デバイス2上での実行のために、例えばグラフィックス命令30(それは、アプリケーション命令21内に含まれる)のようなバイナリ命令にコンパイルされる。グラフィックス命令30内の1又は複数の命令は、個々のAPI命令にマッピングされても良い。マッピングされたAPI命令は、それから、実際に実行されているグラフィックス命令30のビジュアル表現を提供するために、表示デバイス24上でアプリケーション開発者に対して表示されても良い。   In one aspect, the instruction mapping information 31 is used to map the graphics instruction 30 to a corresponding API instruction that may have been previously compiled when generating the graphics instruction 30, for example, in a search table. Mapping information may also be included. An application developer may write a program that uses API instructions, but these API instructions are typically used for execution on the graphics device 2, for example, graphics instructions 30 (which are application Is compiled into a binary instruction such as contained within instruction 21). One or more instructions within graphics instruction 30 may be mapped to individual API instructions. The mapped API instruction may then be displayed to the application developer on the display device 24 to provide a visual representation of the graphics instruction 30 that is actually being executed.

一つの態様において、ユーザ(例えばアプリケーション開発者)は、例えばそのようなパフォーマンスの変化の効果を判定するために、グラフィックス命令30のうちの1又は複数を変更することを望むことがある。この態様において、ユーザは、グラフィックス命令30のビジュアル表現を変更しても良い。マッピング情報31は、それから、下で更に詳細に説明されるように、要求された修正34内のグラフィックス・デバイス2へ提供されることができるバイナリ命令に、グラフィックス命令30のビジュアル表現中のこれらの変更をマッピングするために使用される。   In one aspect, a user (eg, an application developer) may desire to change one or more of the graphics instructions 30, for example, to determine the effect of such a performance change. In this aspect, the user may change the visual representation of the graphics instruction 30. The mapping information 31 is then in a visual representation of the graphics instruction 30 into a binary instruction that can be provided to the graphics device 2 in the requested modification 34, as described in more detail below. Used to map these changes.

先に述べたように、アプリケーション・コンピュータ・デバイス20の表示デバイス24上に表示されるグラフィックス・イメージは、グラフィックス・デバイス2上に表示されるイメージの表現であっても良い。グラフィックス・デバイス2上にイメージが提示されているときに、正確にイメージ又はシーンを再作成するために、シミュレーション・アプリケーション28は、グラフィックス命令30及びステート/パフォーマンス情報32を使用しても良いので、アプリケーション・コンピュータ・デバイス20を使用するアプリケーション開発者は、グラフィックス・アプリケーション30の実行の間の潜在的な(potential)パフォーマンス・イッシュー又はボトルネックと、そして、グラフィックス・アプリケーション30の全体的なパフォーマンスを向上させるプロトタイプ修正でさえ、速く識別することができ得る。   As described above, the graphics image displayed on the display device 24 of the application computer device 20 may be a representation of the image displayed on the graphics device 2. The simulation application 28 may use the graphics instructions 30 and the state / performance information 32 to accurately recreate the image or scene when the image is presented on the graphics device 2. Thus, an application developer using the application computing device 20 may have a potential performance issue or bottleneck during execution of the graphics application 30 and the overall graphics application 30. Even prototype modifications that improve performance can be identified quickly.

例えば、アプリケーション開発者は、アプリケーション・コンピュータ・デバイス20上のシミュレーション・アプリケーション28の実行及び表示デバイス24上の再作成されたイメージの表示の間、グラフィックス命令30及び/又はステート/パフォーマンス情報32に対して1又は複数の要求された修正34を施すことを選択しても良い。グラフィックス命令30の実行又はステート/パフォーマンス情報32の解析の間、そのような要求された修正34は、観測されたパフォーマンス・イッシュー又はボトルネックに基づいても良い。これらの要求された修正34は、それから、アプリケーション・コンピュータ・デバイス20からグラフィックス・デバイス2へ送信されても良い。そこでは、それらはグラフィックス処理システム4によって処理される。一つの態様において、グラフィックス・ドライバー18のうちの1又は複数が、要求された修正34を処理するために、グラフィックス処理システム4中で実行される。要求された修正34は、場合によっては、修正された命令を含んでも良い。場合によっては、要求された修正は、修正されたステート及び/又はパフォーマンス情報を含んでも良い。   For example, the application developer may use graphics instructions 30 and / or state / performance information 32 during execution of the simulation application 28 on the application computing device 20 and display of the recreated image on the display device 24. One may choose to make one or more required modifications 34 to it. During execution of graphics instructions 30 or analysis of state / performance information 32, such requested modifications 34 may be based on observed performance issues or bottlenecks. These requested modifications 34 may then be sent from the application computer device 20 to the graphics device 2. There, they are processed by the graphics processing system 4. In one aspect, one or more of the graphics drivers 18 are executed in the graphics processing system 4 to process the requested modifications 34. The requested modification 34 may optionally include a modified instruction. In some cases, the requested modification may include modified state and / or performance information.

要求された修正34の処理に応じて、更新された命令及び/又は情報35は、アプリケーション・コンピュータ・デバイス20へ送信される(例えばグラフィックス・ドライバー18のうちの1又は複数によって)。更新された命令/情報35は、グラフィックス・デバイス2により処理された要求された修正34に基づく実行のための更新されたグラフィックス命令を含んでも良い。更新された命令/情報35はまた、グラフィックス・デバイス2により処理された要求された修正34に基づく更新されたステート及び/又はパフォーマンス情報を含んでも良い。   In response to processing of the requested modification 34, updated instructions and / or information 35 are transmitted to the application computing device 20 (eg, by one or more of the graphics drivers 18). The updated instructions / information 35 may include updated graphics instructions for execution based on the requested modifications 34 processed by the graphics device 2. The updated instructions / information 35 may also include updated state and / or performance information based on the requested modifications 34 processed by the graphics device 2.

更新された命令/情報35は、表示デバイス24上での再作成されたイメージ情報の表示を更新するために、さらに更新された命令/情報35のビジュアル表現を、アプリケーション開発者に提供するために、シミュレーション・アプリケーション28により処理される(それは命令マッピング情報31を再び使用することを含んでも良い)。アプリケーション開発者は、それから、パフォーマンス・イッシューが解決又は軽減されたかについて判定するために、更新された命令/情報35のビジュアル表現だけでなく、表示デバイス24上の更新されたイメージ情報を閲覧しても良い。アプリケーション開発者は、グラフィックス命令30をデバッグするための反復的なプロセス、又は、全体的なパフォーマンス・グラフィックス・アプリケーション30を改善するためのプロトタイプ修正を使用しても良い。   The updated instructions / information 35 is for updating the display of the recreated image information on the display device 24 and for providing a visual representation of the updated instructions / information 35 to the application developer. Processed by the simulation application 28 (which may include using the instruction mapping information 31 again). The application developer then browses the updated image information on the display device 24 as well as a visual representation of the updated instruction / information 35 to determine whether the performance issue has been resolved or mitigated. Also good. Application developers may use an iterative process to debug graphics instructions 30 or prototype modifications to improve overall performance graphics application 30.

一つの態様において、アプリケーション・コンピュータ・デバイス20は、表示デバイス24上に表示されるグラフィックス・イメージをオーバーレイするパーティションのビジュアル・グラフィカル表現を表示するために、マッピング/パーティショニング情報23を使用する。これらのパーティションは、表示デバイス24上でこれらのイメージを含むシーンをグラフィカルに分割する。例えば、シミュレーション・アプリケーション28は、表示デバイス24のスクリーン上でこれらのパーティション(例えば、複数の長方形の形のパーティション)のグラフィックス表現を作成するために、マッピング/パーティショニング情報33を処理するパーティショニング・モジュール27を使用しても良い。   In one aspect, the application computing device 20 uses the mapping / partitioning information 23 to display a visual graphical representation of a partition that overlays a graphics image displayed on the display device 24. These partitions graphically divide the scene containing these images on the display device 24. For example, the simulation application 28 processes the mapping / partitioning information 33 to create a graphical representation of these partitions (eg, a plurality of rectangular shaped partitions) on the screen of the display device 24. -Module 27 may be used.

パーティショニング・モジュール27は、記憶媒体26からロードされ、プロセッサ22により実行されても良い。実行されるとき、パーティショニング・モジュール27はまた、グラフィックス・データのいずれの部分が該パーティションのうちの複数のものに関連するか判定するために、1又は複数のグラフィックス・イメージについて、グラフィックス・データ(それはステート/パフォーマンス情報32内に含まれても良い)を解析しても良い。例えば、パーティショニング・モジュール27は、下で更に詳細に説明されるように、表示デバイス24上での表示のためのグラフィックス・イメージを作成するために及びこれらのポリゴンのうちのいずれのポリゴンが複数のパーティションにわたり得るかについて判定するために使用される、1又は複数のポリゴンを解析しても良い。   The partitioning module 27 may be loaded from the storage medium 26 and executed by the processor 22. When executed, the partitioning module 27 also executes graphics for one or more graphics images to determine which portion of the graphics data is associated with more than one of the partitions. Data (which may be included in the state / performance information 32) may be analyzed. For example, the partitioning module 27 may create a graphics image for display on the display device 24 and any of these polygons as described in more detail below. One or more polygons used to determine whether they can span multiple partitions may be analyzed.

記憶媒体26は、ナビゲーション・モジュール29を更に含む。ナビゲーション・モジュール29はまた、プロセッサ22により実行されても良い。シミュレーション・アプリケーション28は、実行の間、表示デバイス上にナビゲーション・コントローラを表示するために、ナビゲーション・モジュール29を使用しても良い。ユーザ(例えばアプリケーション開発者)は、表示デバイス24上に表示されるシーン内のグラフィックス・イメージの修正された斜視図を閲覧するために、このナビゲーション・コントローラとインタラクトしても良い。パーティショニング・モジュール27は、それから、修正されたシーンをグラフィカルに分割するために、グラフィックス・イメージの修正された斜視図をオーバーレイするパーティションのグラフィカル表現を表示しても良い。パーティショニング・モジュール27はまた、それから、複数のポリゴンのうちのいずれのが複数のパーティションにわたり得るかについて判定するために、修正された斜視図中にグラフィックス・イメージを作成するために使用される1又は複数のポリゴンを解析しても良い。   The storage medium 26 further includes a navigation module 29. The navigation module 29 may also be executed by the processor 22. The simulation application 28 may use the navigation module 29 to display the navigation controller on the display device during execution. A user (eg, an application developer) may interact with this navigation controller to view a modified perspective view of the graphics image in the scene displayed on the display device 24. The partitioning module 27 may then display a graphical representation of the partition overlaying the modified perspective view of the graphics image to graphically divide the modified scene. Partitioning module 27 is then also used to create a graphics image in the modified perspective view to determine which of the multiple polygons can span multiple partitions. One or more polygons may be analyzed.

一つの態様に従って、図2は、本開示の一つの態様に従って、図1に示されるグラフィックス処理システム4、グラフィックス・ドライバー18及びアプリケーション・コンピュータ・デバイス20の特定の詳細を示すブロック図である。図2において、アプリケーション・コンピュータ・デバイス20は、デバイス2のグラフィックス処理システム4に接続されることが仮定される。しかし、これは説明の目的のためにだけ示される。他のシナリオでは、アプリケーション・コンピュータ・デバイス20は、多くの他の形のグラフィックス処理システム及びデバイスに接続されても良い。   In accordance with one aspect, FIG. 2 is a block diagram illustrating certain details of the graphics processing system 4, the graphics driver 18, and the application computer device 20 shown in FIG. 1, in accordance with one aspect of the present disclosure. . In FIG. 2, it is assumed that the application computer device 20 is connected to the graphics processing system 4 of device 2. However, this is shown for illustrative purposes only. In other scenarios, the application computing device 20 may be connected to many other forms of graphics processing systems and devices.

図2に示されるように、グラフィックス処理システム4は、4つのプログラム可能なプロセッサ、すなわち、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16を含む。それらは図1にも示される。制御プロセッサ10は、頂点プロセッサ14、グラフィックス・プロセッサ12又は表示プロセッサ16のうちの任意のものを制御しても良い。多くの場合に、これらのプロセッサ10,12,14及び16は、システム4内のグラフィックス処理パイプラインの一部であっても良い。   As shown in FIG. 2, the graphics processing system 4 includes four programmable processors: a control processor 10, a vertex processor 14, a graphics processor 12, and a display processor 16. They are also shown in FIG. Control processor 10 may control any of vertex processor 14, graphics processor 12, or display processor 16. In many cases, these processors 10, 12, 14 and 16 may be part of a graphics processing pipeline within system 4.

制御プロセッサ10はまた、パイプラインを通してデータ又は命令実行のフローの1又は複数の態様を制御しても良く、さらに、グラフィックス・イメージに関するジオメトリ情報を、頂点プロセッサ14に提供しても良い。頂点プロセッサ14は、グラフィックス・イメージの頂点変換又はジオメトリ処理を管理しても良い。それは、プリミティブのジオメトリ・フォームにおける複数の頂点に従って記述又は定義されても良い。頂点プロセッサ14は、その出力をグラフィックス・プロセッサ12に提供しても良い。グラフィックス・プロセッサ12は、グラフィックス・イメージに対するレンダリング又はラスタライゼーション・オペレーションを実行しても良い。グラフィックス・プロセッサ12は、表示プロセッサ16にその出力を提供しても良い。表示プロセッサ16は、表示のために、ピクセル・フォームで、グラフィックス・イメージを準備する。グラフィックス・プロセッサ12はまた、ピクセル・データに対する様々なオペレーション(例えばシェーディング又はスケーリング)を実行しても良い。   The control processor 10 may also control one or more aspects of the flow of data or instruction execution through the pipeline and may also provide geometric information regarding the graphics image to the vertex processor 14. The vertex processor 14 may manage vertex transformation or geometry processing of the graphics image. It may be described or defined according to multiple vertices in a primitive geometry form. Vertex processor 14 may provide its output to graphics processor 12. Graphics processor 12 may perform rendering or rasterization operations on the graphics image. Graphics processor 12 may provide its output to display processor 16. Display processor 16 prepares the graphics image in pixel form for display. Graphics processor 12 may also perform various operations (eg, shading or scaling) on the pixel data.

しばしば、グラフィックス・イメージ・データは、グラフィックス命令30の実行の間、この処理パイプラインで処理されても良い。グラフィックス命令30は、アプリケーション命令21(図1)の一部であっても良い。その結果、グラフィックス命令30は、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数によって実行されても良い。アプリケーション開発者は、一般的に、グラフィックス処理システム4内のいずれの特定のプロセッサがグラフィックス命令30のうちのいずれを実行するかという多くの知識又は制御を有しなくても良い。   Often, graphics image data may be processed in this processing pipeline during execution of graphics instructions 30. Graphics instruction 30 may be part of application instruction 21 (FIG. 1). As a result, graphics instruction 30 may be executed by one or more of control processor 10, vertex processor 14, graphics processor 12, and display processor 16. Application developers generally do not need much knowledge or control over which particular processor in graphics processing system 4 executes which of graphics instructions 30.

場合によっては、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数は、グラフィックス命令30の実行の間、パフォーマンス・イッシューを有する可能性があり、あるいは、処理パイプライン中の潜在的なボトルネックとして機能する可能性がある。これらの場合、グラフィックス処理システム4内の全体的なパフォーマンスが悪化する可能性があり、そして、アプリケーション開発者は、パフォーマンスを向上させるために、グラフィックス命令30の変更を行うことを望むことがある。かし、開発者がプロセッサ10,12,14又は16のいずれのプロセッサがパフォーマンス・イッシューを有するものである可能性があるかについて、必ずしも分るわけではない。これらのパフォーマンス・イッシューは、例えば、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数のためのプロセッサの使用(usage)又は利用(utilization)に関係するイッシューを含む場合がある。   In some cases, one or more of control processor 10, vertex processor 14, graphics processor 12 and display processor 16 may have a performance issue during execution of graphics instructions 30, or It can serve as a potential bottleneck in the processing pipeline. In these cases, the overall performance within the graphics processing system 4 may be degraded and the application developer may wish to make changes to the graphics instructions 30 to improve performance. is there. However, the developer does not necessarily know which processor 10, 12, 14 or 16 may have a performance issue. These performance issues are related to, for example, usage or utilization of the processor for one or more of the control processor 10, vertex processor 14, graphics processor 12 and display processor 16. May be included.

特に、ビニング・ベースのオペレーション(それにおいては、レンダリングに先立って、プリミティブ・グラフィックス・データが複数のビニング・パーティションにわたって分割される)は、しばしば、特定のパフォーマンス・イッシューを作り出すことがある。例えば、ポリゴン(例えば、図5Aの例で示される三角形146)が2つの異なるパーティション(例えば、図5Aに示されるパーティション136と138)にわたる場合に、該ポリゴンは、2つの構成フラグメント(constituent fragments)(パーティションごとに一つ)に分割され、そして、これらの2つの構成フラグメント(例えば、図5Bに示されるフラグメント146Aと146B)は、ピクセル・データを含む独立したグラフィックス・イメージに独立してレンダリングされ得る。これらの2つの独立したグラフィックス・イメージは、それから、三角形146のビジュアル表現を作成するために、表示の前に結合される必要があり得る。三角形146の2つのフラグメントのための独立したレンダリング・オペレーションは、2つの関係するグラフィックス・イメージのための結合オペレーションとともに、パフォーマンス・オーバーヘッドを引き起こす場合がある。   In particular, binning-based operations, where primitive graphics data is split across multiple binning partitions prior to rendering, can often create a specific performance issue. For example, if a polygon (eg, the triangle 146 shown in the example of FIG. 5A) spans two different partitions (eg, partitions 136 and 138 shown in FIG. 5A), the polygon will be two constituent fragments. These two constituent fragments (eg, fragments 146A and 146B shown in FIG. 5B) are rendered independently into separate graphics images that contain pixel data (one for each partition). Can be done. These two independent graphics images may then need to be combined before display to create a visual representation of triangle 146. Independent rendering operations for the two fragments of triangle 146 may cause performance overhead, as well as a combining operation for the two related graphics images.

パフォーマンス・ボトルネック及び潜在的な解決を識別する問題を支援するために、図2に示されるように、グラフィックス・デバイス2のグラフィックス・ドライバー18Aは、グラフィックス処理システム4からグラフィックス命令30を捕捉又は収集しても良く、また、アプリケーション・コンピュータ・デバイス20にそれらを送っても良い。グラフィックス・ドライバー18Aは、図1に示されるグラフィックス・ドライバー18の一部である。グラフィックス・ドライバー18Aは、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数によってロード及び実行されても良い。さらに、グラフィックス・ドライバー18Aはまた、制御プロセッサ10、ベクトルプロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数からステート及び/又はパフォーマンス情報32を収集しても良く、同様に、アプリケーション・コンピュータ・デバイス20にこの情報32を送っても良い。一つの態様において、グラフィックス命令30がOpenGL ES API命令から生成又はコンパイルされた可能性のあるバイナリ命令を含むとき、グラフィックス・ドライバー18Aは、OpenGL ESドライバーを含んでも良い。   To assist in the problem of identifying performance bottlenecks and potential solutions, the graphics driver 18A of the graphics device 2, as shown in FIG. May be captured or collected, and may be sent to the application computing device 20. The graphics driver 18A is a part of the graphics driver 18 shown in FIG. Graphics driver 18 A may be loaded and executed by one or more of control processor 10, vertex processor 14, graphics processor 12, and display processor 16. Further, graphics driver 18A may also collect state and / or performance information 32 from one or more of control processor 10, vector processor 14, graphics processor 12, and display processor 16, and similarly The information 32 may be sent to the application computer device 20. In one aspect, graphics driver 18A may include an OpenGL ES driver when graphics instructions 30 include binary instructions that may have been generated or compiled from OpenGL ES API instructions.

様々な形のステート・データが、ステート/パフォーマンス情報32内に含まれても良い。例えば、ステート・データは、グラフィックス命令30の実行の間に使用される又はさもなければグラフィックス命令30に関連するグラフィックス・データを含んでも良い。ステート・データは、頂点アレイ(例えば、位置、色、座標、サイズ又は重みデータ)に関係しても良い。ステート・データは、テクスチャー状態データ(texture state data)、点状態データ(point state data)、線状態データ(line state data)、ポリゴン状態データ(polygon state data)、カリング状態データ(culling state data)、アルファ・テスト状態データ(alpha test state data)、ブレンド状態データ(blending state data)、デプス状態データ(depth state data)、ステンシル状態データ(stencil state data)又は色状態データ(color state data)を更に含んでも良い。前に説明されたように、ステート・データは、ステート情報と実際のデータの両方を含んでも良い。場合によっては、ステート・データは、1又は複数のOpenGLトークンに関連するデータを含んでも良い。   Various forms of state data may be included in the state / performance information 32. For example, the state data may include graphics data that is used during execution of the graphics instructions 30 or otherwise associated with the graphics instructions 30. The state data may relate to vertex arrays (eg, position, color, coordinates, size or weight data). State data includes texture state data, point state data, line state data, polygon state data, culling state data, Further includes alpha test state data, blending state data, depth state data, stencil state data, or color state data But it ’s okay. As previously described, the state data may include both state information and actual data. In some cases, the state data may include data associated with one or more OpenGL tokens.

様々な形のパフォーマンス・データはまた、ステート/パフォーマンス情報32内に含まれても良い。一般に、このパフォーマンス・データは、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数からのメトリック又はハードウェア・カウンタ・データを含んでも良い。パフォーマンス・データは、フレーム・レート又はサイクル・データを含んでも良い。サイクル・データは、プロファイリング、命令アレイ、頂点及びインデックス・データ、又は他のオペレーションのために使用されるサイクルに関するデータを含んでも良い。様々な態様において、様々な形のステート及びパフォーマンス・データが、グラフィックス・ドライバー18Aによりグラフィックス処理システム4から収集されるステート/パフォーマンス情報32内に含まれても良い。   Various forms of performance data may also be included in the state / performance information 32. In general, this performance data may include metric or hardware counter data from one or more of the control processor 10, vertex processor 14, graphics processor 12, and display processor 16. The performance data may include frame rate or cycle data. Cycle data may include data relating to cycles used for profiling, instruction array, vertex and index data, or other operations. In various aspects, various forms of state and performance data may be included in the state / performance information 32 collected from the graphics processing system 4 by the graphics driver 18A.

前に説明されたように、アプリケーション・コンピュータ・デバイス20は、受信されたグラフィックス命令30及びステート/パフォーマンス情報32に従って、グラフィックス・イメージの表現を表示しても良い。アプリケーション・コンピュータ・デバイス20はまた、ステート/パフォーマンス情報32のビジュアル表現を表示しても良い。再作成されたグラフィックス・イメージ及び/又はステート/パフォーマンス情報32のビジュアル表現の閲覧及びインタラクトによって、アプリケーション開発者は、グラフィックス命令30の実行の間、グラフィックス・デバイス2のグラフィックス処理システム4内のパフォーマンス・イッシューを速く識別及び解決することができ得る。例えば、アプリケーション開発者は、プロセッサ10,12,14及び/又は16のうちのいずれの特定の複数のプロセッサがパフォーマンス・イッシューを有する可能性があるかについて識別することができる場合がある。   As previously described, application computer device 20 may display a representation of a graphics image in accordance with received graphics instructions 30 and state / performance information 32. Application computer device 20 may also display a visual representation of state / performance information 32. By viewing and interacting with the recreated graphics image and / or visual representation of the state / performance information 32, the application developer can execute the graphics processing system 4 of the graphics device 2 during execution of the graphics instructions 30. It is possible to quickly identify and resolve performance issues within. For example, an application developer may be able to identify which particular multiple of processors 10, 12, 14, and / or 16 may have a performance issue.

さらに、グラフィックス・ドライバー18Aはまた、アプリケーション・コンピュータ・デバイス20にマッピング及び/又はパーティショニング情報33を提供する。図1を参照して前に説明されたように、パーティショニング・モジュール27は、シーンをグラフィカルに分割するために、シーン中でグラフィックス・イメージをオーバーレイする表示デバイス24上でのパーティションのグラフィカル表現を表示するために、受信されたマッピング/パーティショニング情報33を処理しても良い。パーティショニング・モジュール27はまた、データのいずれの部分が該パーティションのうちの複数のものに関連するかについて判定するために、グラフィックス・データ(それはステート/パフォーマンス情報32内に含まれても良い)を解析するために、マッピング/パーティショニング情報33を使用しても良い。マッピン/パーティショニング情報33は、グラフィックス・データ(それは1又は複数のグラフィックス・イメージを生成するために使用されても良い)をグラフィックス命令30中の識別された命令にマッピングするマッピング情報を含んでも良い。   In addition, the graphics driver 18A also provides mapping and / or partitioning information 33 to the application computing device 20. As previously described with reference to FIG. 1, the partitioning module 27 is a graphical representation of partitions on the display device 24 that overlays graphics images in the scene to graphically divide the scene. The received mapping / partitioning information 33 may be processed to display. The partitioning module 27 may also be included in the graphics data (which may be included in the state / performance information 32) to determine which portion of the data is associated with more than one of the partitions. ) May be used to analyze the mapping / partitioning information 33. The mapping / partitioning information 33 is mapping information that maps graphics data (which may be used to generate one or more graphics images) to the identified instruction in the graphics instruction 30. May be included.

任意の識別されたパフォーマンス・イッシューに対する回避方法(workaround)又は解決を識別する試行において、開発者は、アプリケーション・コンピュータ・デバイス20上で1又は複数の要求された修正34を開始しても良い。例えば、開発者は、要求された修正34を作成するために、再作成されたイメージ又はステート/パフォーマンス情報32の表現とインタラクトしても良い。場合によっては、開発者は、要求された修正34を生成するために、下でより詳しく説明されるように、ステート/パフォーマンス情報32を直接変更さえしても良い。特定のケースでは、要求された修正34は、グラフィックス・デバイス2のグラフィックス処理システム4におけるグラフィックス命令30のうちの1又は複数の実行を無効にする1又は複数のリクエスト、又は、1又は複数のグラフィックス命令30を修正するリクエストを含んでも良い。   In an attempt to identify a workaround or solution for any identified performance issue, the developer may initiate one or more requested modifications 34 on the application computing device 20. For example, the developer may interact with the recreated image or representation of the state / performance information 32 to create the requested modification 34. In some cases, the developer may even change the state / performance information 32 directly, as described in more detail below, to generate the required modifications 34. In certain cases, the requested modification 34 is one or more requests that invalidate execution of one or more of the graphics instructions 30 in the graphics processing system 4 of the graphics device 2, or 1 or A request to modify a plurality of graphics instructions 30 may be included.

場合によっては、ユーザは、グラフィックス・シーンの修正された斜視図が表示されるよう要求するために、表示デバイス24上に表示されるナビゲーション・コントローラとインタラクトしても良い。ナビゲーション・モジュール29は、このナビゲーション・コントローラの表示及びこのナビゲーション・コントローラとのインタラクションを管理しても良い。ユーザ・インタフェースを介してユーザにより入力される任意のリクエストは、要求された修正34とともに含まれても良い。これらのリクエストは、例えば、シーン内で1又は複数のグラフィックス・イメージを回転させるリクエスト、ズームインするリクエスト、ズームアウトするリクエスト、又は、シーン内でイメージの斜視図を変更する他の同様のリクエストを含んでも良い。   In some cases, the user may interact with a navigation controller displayed on display device 24 to request that a modified perspective view of the graphics scene be displayed. The navigation module 29 may manage the display of the navigation controller and the interaction with the navigation controller. Any request entered by the user via the user interface may be included with the requested modification 34. These requests can be, for example, requests to rotate one or more graphics images in the scene, requests to zoom in, requests to zoom out, or other similar requests to change the perspective view of an image in the scene. May be included.

要求された修正34は、アプリケーション・コンピュータ・デバイス20からグラフィックス・ドライバー18Aへ送信される。グラフィックス・ドライバー18Aは、オペレーションの間、グラフィックス・デバイス2のためのリクエストを処理する。多くの場合に、要求された修正34は、ステート情報を修正するリクエストを含んでも良い。ステート情報は、グラフィックス命令30の実行の間のグラフィックス処理システム4中のプロセッサ10,12,14又は16のうちの1又は複数の中のデータを含んでも良い。グラフィックス・ドライバー18Aは、それから、要求された修正34内に含まれるグラフィックス処理システム4の変更を実行しても良い。これらの変更は、グラフィックス命令30の実行のために、プロセッサ10,12,14及び/又は16の間で、実行のフローを変えても良い。特定のケースでは、グラフィックス命令30のうちの1又は複数は、要求された修正34に従って、グラフィックス処理システム4における実行の間、無効にされても良い。   The requested modification 34 is transmitted from the application computer device 20 to the graphics driver 18A. Graphics driver 18A processes requests for graphics device 2 during operation. In many cases, the requested modification 34 may include a request to modify state information. The state information may include data in one or more of the processors 10, 12, 14 or 16 in the graphics processing system 4 during the execution of the graphics instructions 30. The graphics driver 18A may then perform changes to the graphics processing system 4 included within the requested modification 34. These changes may change the flow of execution between the processors 10, 12, 14, and / or 16 for execution of the graphics instructions 30. In certain cases, one or more of the graphics instructions 30 may be invalidated during execution in the graphics processing system 4 in accordance with the requested modification 34.

グラフィックス・ドライバー18Aは、要求された修正34の処理に応答して、更新された命令及び/又は情報35を、アプリケーション・コンピュータ・デバイス20に送信することができる。更新された命令/情報35は、パフォーマンス情報を含む、グラフィックス・ドライバー18Aによりグラフィックス処理システム4から収集される更新されたステート情報を含んでも良い。更新された命令/情報3は、更新されたグラフィックス命令及び/又はグラフィックス・データを含んでも良い。   Graphics driver 18A may send updated instructions and / or information 35 to application computing device 20 in response to the requested modification 34 processing. The updated instruction / information 35 may include updated state information collected from the graphics processing system 4 by the graphics driver 18A, including performance information. The updated instruction / information 3 may include updated graphics instructions and / or graphics data.

アプリケーション・コンピュータ・デバイス20は、更新された命令/情報35のビジュアル表現だけでなく、グラフィックス・イメージの更新された表現を表示するために、更新された命令/情報35を使用しても良い。アプリケーション開発者は、それから、前に識別されたパフォーマンス・イッシューが解決又はさもなければ対処されたかどうかについて判断することができても良い。例えば、アプリケーション開発者は、特定のテクスチャー、ポリゴン若しくは他の特徴が最適化されたか又は他のパフォーマンス・パラメータが改善されたか判定するために、更新された命令/情報35のビジュアル表現だけでなく、更新されたイメージを解析することができても良い。   The application computing device 20 may use the updated instruction / information 35 to display an updated representation of the graphics image as well as a visual representation of the updated instruction / information 35. . The application developer may then be able to determine whether the previously identified performance issue has been resolved or otherwise addressed. For example, the application developer can determine whether a particular texture, polygon or other feature has been optimized or other performance parameters have been improved, as well as a visual representation of the updated instruction / information 35, It may be possible to analyze the updated image.

更新された命令/情報35はまた、更新されたマッピン及び/又はパーティショニング情報(例えば、命令/情報35内に同様に含まれる命令へのグラフィックス・データの更新されたマッピング)を含んでも良い。更新された命令/情報35の結果として、シーンの更新された斜視図が表示デバイス24に表示される場合には、パーティショニング・モジュール27は、修正された斜視図をオーバーレイし及び修正されたシーンをグラフィカルに分割するパーティションのグラフィカル表現を表示しても良い。パーティショニング・モジュール27はまた、グラフィックス・データのいずれの部分が該パーティションのうちの複数のものに関連するかについて判定するために、修正された斜視図(それはまた更新された命令/情報35内に含まれても良い)のためのグラフィックス・データを解析しても良い。パーティションは、グラフィックス・データに関して実行されるオペレーションのレンダリングに基づいて判定されても良い。   The updated instruction / information 35 may also include updated mapping and / or partitioning information (eg, an updated mapping of graphics data to instructions that are also included in the instruction / information 35). . If an updated perspective view of the scene is displayed on the display device 24 as a result of the updated instructions / information 35, the partitioning module 27 overlays the modified perspective view and the modified scene. You may display a graphical representation of a partition that divides the database graphically. Partitioning module 27 may also modify a modified perspective view (which may also include updated instructions / information 35) to determine which portions of graphics data are associated with more than one of the partitions. Graphics data may be analyzed). The partition may be determined based on a rendering of operations performed on the graphics data.

そのような方法において、アプリケーション開発者は、グラフィックス・デバイス2上のグラフィックス処理システム4のオペレーションをシミュレートするアプリケーション・コンピュータ・デバイス20上の環境内でグラフィックス命令30の実行を速く及び効果的にデバッグ又は解析することができても良い。開発者は、グラフィックス命令30の実行パフォーマンスを最大にするために、シーン又は複数のイメージ・フレームにおける複数のグラフィックス・イメージを解析するために、アプリケーション・コンピュータ・デバイス20上の表示されたイメージ及びステート/パフォーマンス情報と繰り返しインタラクトしても良い。アプリケーション・コンピュータ・デバイス20上のそのようなインタラクション及び表示される情報の例は、下で更に詳細に提示される。   In such a manner, the application developer can quickly and effectively execute the graphics instructions 30 within the environment on the application computer device 20 that simulates the operation of the graphics processing system 4 on the graphics device 2. It may be possible to debug or analyze automatically. Developers can view displayed images on application computer device 20 to analyze multiple graphics images in a scene or multiple image frames to maximize the execution performance of graphics instructions 30. And may interact repeatedly with state / performance information. Examples of such interaction and displayed information on the application computing device 20 are presented in more detail below.

図3は、一つの態様に従って、制御プロセッサ10、グラフィックス・プロセッサ12、頂点プロセッサ14及び表示プロセッサ16により実行され得るオペレーションの更なる詳細を示すフロー・ダイアグラムである。図3はまた、フレーム・バッファ・ストレージ100及びディスプレイ102に関するオペレーションを示す。一つの態様において、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び/又は表示プロセッサ16は、グラフィックス命令30のうちの1又は複数の実行の結果として、様々なオペレーションを実行する。   FIG. 3 is a flow diagram illustrating further details of operations that may be performed by the control processor 10, graphics processor 12, vertex processor 14, and display processor 16, according to one aspect. FIG. 3 also illustrates operations relating to the frame buffer storage 100 and the display 102. In one aspect, control processor 10, vertex processor 14, graphics processor 12 and / or display processor 16 perform various operations as a result of the execution of one or more of graphics instructions 30.

前に説明されたように、制御プロセッサ10は、グラフィックス処理パイプラインを通してデータ又は命令実行のフローの1又は複数の態様を制御しても良く、さらに、ジオメトリ情報を頂点プロセッサ14に提供しても良い。図3に示されるように、制御プロセッサ10は、90においてジオメトリ・ストレージを実行しても良い。場合によっては、1又は複数のプリミティブのためのジオメトリ情報は、制御プロセッサ10によってバッファ15(図1)に記憶されても良い。場合によっては、ジオメトリ情報は、記憶媒体8に記憶されても良い。   As previously described, the control processor 10 may control one or more aspects of the flow of data or instruction execution through the graphics processing pipeline and further provide geometry information to the vertex processor 14. Also good. As shown in FIG. 3, the control processor 10 may perform geometry storage at 90. In some cases, geometry information for one or more primitives may be stored by the control processor 10 in the buffer 15 (FIG. 1). In some cases, the geometry information may be stored in the storage medium 8.

頂点プロセッサ14は、それから、92において、制御プロセッサにより提供され及び/又は処理のためにバッファ15に記憶される所定のプリミティブのためのジオメトリ情報を取得しても良い。特定のケースでは、頂点プロセッサ14は、ジオメトリ情報の頂点変換を管理しても良い。特定のケースでは、頂点プロセッサ14は、ジオメトリ情報に関してライティング・オペレーション(lighting operations)を実行しても良い。   Vertex processor 14 may then obtain, at 92, geometry information for a given primitive provided by the control processor and / or stored in buffer 15 for processing. In certain cases, vertex processor 14 may manage the vertex transformation of geometry information. In certain cases, vertex processor 14 may perform lighting operations on the geometry information.

頂点プロセッサ14は、グラフィックス・プロセッサ12にその出力を提供しても良い。そして、グラフィックス・プロセッサ12は、94において、該データに関してレンダリング又はラスタライゼーション・オペレーションを実行しても良い。グラフィックス・プロセッサ12は、表示プロセッサ16にその出力を提供しても良い。そして、表示プロセッサ16は、表示のために、ピクセル・フォームで、1又は複数のグラフィックス・イメージを準備する。場合によっては、グラフィックス・プロセッサ12は、判定されたビニング・パーティションに基づいて、ジオメトリ(例えば1又は複数のポリゴン)のために、グラフィックス・データをスプリットしても良い。前に説明されたように、グラフィックス・デバイス2(例えばグラフィックス・プロセッサ12)内のプロセッサのうちの1又は複数は、特定の要因(例えばメモリ要求又は制限)に基づいて、ディスプレイ102の異なるスクリーン・エリアに関連する複数のビニング・パーティションを作成しても良い。特定のジオメトリ(例えば、三角形)が複数のパーティションにわたるならば、グラフィックス・プロセッサは、パーティション境界に沿ってジオメトリを複数のフラグメントにスプリットし、そして、独立して各フラグメントを生成しても良い。幾つかのケースにおいて、グラフィックス・プロセッサ12は、判定されたパーティションの数、タイプ、サイズ、形状などに基づいて、マッピング/パーティショニング情報33を、アプリケーション・コンピュータ・デバイス20に提供しても良い。   Vertex processor 14 may provide its output to graphics processor 12. Graphics processor 12 may then perform a rendering or rasterization operation on the data at 94. Graphics processor 12 may provide its output to display processor 16. The display processor 16 then prepares one or more graphics images in pixel form for display. In some cases, graphics processor 12 may split the graphics data for geometry (eg, one or more polygons) based on the determined binning partition. As previously described, one or more of the processors in graphics device 2 (eg, graphics processor 12) may vary depending on display 102 based on specific factors (eg, memory requirements or limitations). Multiple binning partitions associated with the screen area may be created. If a particular geometry (eg, triangle) spans multiple partitions, the graphics processor may split the geometry into multiple fragments along the partition boundary and generate each fragment independently. In some cases, graphics processor 12 may provide mapping / partitioning information 33 to application computer device 20 based on the determined number, type, size, shape, etc. of the partition. .

表示プロセッサ16は、98において、データの様々なフラグメントを処理するためのフラグメント処理を含む、ピクセル・データに関する様々なオペレーションを実行しても良い。特定のケースでは、これは、技術的に知られていているような、デプス・テスト、ステンシル・テスト、ブレンディング、又はテクスチャ・マッピングのうちの1又は複数を含んでも良い。グラフィックス・プロセッサ12が前に複数のジオメトリ・フラグメントをレンダリングしたならば、表示プロセッサ16のフラグメント処理98は、それから、フレーム・バッファに記憶するために、レンダリングされた複数のフラグメントを結合しても良い。テクスチャ・マッピングを実行するとき、表示プロセッサ16は、96において、テクスチャー・ストレージ及びフィルタリング情報を組み込んでも良い。場合によっては、グラフィックス・プロセッサ16は、ラスタライズされたデータに関する他のオペレーション(例えば、シェーディング又はスケーリング・オペレーション)を実行しても良い。   Display processor 16 may perform various operations on pixel data at 98, including fragment processing to process various fragments of data. In certain cases, this may include one or more of depth testing, stencil testing, blending, or texture mapping, as is known in the art. If graphics processor 12 previously rendered multiple geometric fragments, fragment processing 98 of display processor 16 may then combine the rendered multiple fragments for storage in the frame buffer. good. When performing texture mapping, display processor 16 may incorporate texture storage and filtering information at 96. In some cases, graphics processor 16 may perform other operations on the rasterized data (eg, shading or scaling operations).

表示プロセッサ16は、100において、フレーム・バッファに記憶するために、出力ピクセル情報を提供する。場合によっては、フレーム・バッファは、バッファ15(図1)内に含まれても良い。他の場合において、フレーム・バッファは、記憶媒体8内に含まれても良い。フレーム・バッファは、イメージ・データの1又は複数のフレームを記憶する。そして、それは、102において、例えば表示デバイス6上などで、表示されることができる。   Display processor 16 provides output pixel information at 100 for storage in the frame buffer. In some cases, the frame buffer may be included in buffer 15 (FIG. 1). In other cases, the frame buffer may be included in the storage medium 8. The frame buffer stores one or more frames of image data. It can then be displayed at 102, such as on display device 6.

前に説明されたように、グラフィックス命令30は、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数によって実行されても良い。アプリケーション開発者は、一般的に、グラフィックス処理システム4内のいずれの特定のプロセッサがグラフィックス命令30のうちのいずれのグラフィックス命令を実行するかという多くの知識又は制御を有しなくても良い。特定のケースでは、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数は、グラフィックス命令30の実行の間、パフォーマンス・イッシューを有する可能性があり、あるいは、処理パイプライン中の潜在的なボトルネックとして機能する可能性がある。   As previously described, graphics instruction 30 may be executed by one or more of control processor 10, vertex processor 14, graphics processor 12, and display processor 16. Application developers generally do not have much knowledge or control of which particular processor in graphics processing system 4 will execute which of the graphics instructions 30. good. In certain cases, one or more of control processor 10, vertex processor 14, graphics processor 12 and display processor 16 may have a performance issue during execution of graphics instructions 30, or , Potentially serving as a potential bottleneck in the processing pipeline.

アプリケーション開発者がボトルネックの位置又はそのようなボトルネックの影響を解決又は軽減する最も良い方法を正確に指摘することは、しばしば難しい場合がある。このように、一つの態様において、グラフィックス命令30及び/又はステート情報は、グラフィックス・デバイス2から外部コンピュータ・デバイス(例えばアプリケーション・コンピュータ・デバイス20)へ提供されても良い。ステート情報は、グラフィックス命令30の実行の間に起こる(例えば図3に示されるそれらのような)様々なオペレーションに関して、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数からのデータを含んでも良い。アプリケーション・コンピュータ・デバイス20は、効率的且つ効果的な方法でボトルネックの識別及び解決を支援するために、デバイス2上に示されるグラフィックス・イメージを作成しても良い。アプリケーション・コンピュータ・デバイス20はまた、パーティショニング情報を表示し、また、データのいずれの部分が該パーティションのうちの複数のものに関連するかについて判定するために、1又は複数のジオメトリに関するグラフィックス・データを解析しても良い。   It can often be difficult for an application developer to pinpoint the location of a bottleneck or the best way to resolve or mitigate the effects of such a bottleneck. Thus, in one aspect, graphics instructions 30 and / or state information may be provided from graphics device 2 to an external computing device (eg, application computing device 20). The state information is among the control processor 10, vertex processor 14, graphics processor 12, and display processor 16 for various operations that occur during execution of the graphics instructions 30 (such as those shown in FIG. 3). Data from one or more of the above may be included. Application computer device 20 may create the graphics image shown on device 2 to assist in identifying and resolving bottlenecks in an efficient and effective manner. The application computing device 20 also displays partitioning information and graphics for one or more geometries to determine which part of the data is associated with more than one of the partitions. -Data may be analyzed.

一つの態様に従って、図4は、本開示の一つの態様に従って、図2に示されるグラフィックス・ドライバー18Aの更なる詳細を示すブロック図である。前に説明されたように、グラフィックス・ドライバー18Aは、グラフィックス処理システム4内で(例えば、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数によって)実行されることができる命令を含んでも良く、また、グラフィックス・ドライバー18の一部であっても良い。グラフィックス・ドライバー18Aの実行は、グラフィックス処理システム4がアプリケーション・コンピュータ・デバイス20と通信するのを可能にする。一つの態様において、グラフィックス・ドライバー18Aは、グラフィックス処理システム54内で実行されることができる命令を含んでも良く、また、グラフィックス・ドライバー68の一部であっても良い。   In accordance with one aspect, FIG. 4 is a block diagram illustrating further details of the graphics driver 18A shown in FIG. 2 according to one aspect of the present disclosure. As previously described, graphics driver 18A is within graphics processing system 4 (eg, by one or more of control processor 10, vertex processor 14, graphics processor 12, and display processor 16). It may include instructions that can be executed and may be part of the graphics driver 18. Execution of graphics driver 18A enables graphics processing system 4 to communicate with application computer device 20. In one aspect, the graphics driver 18A may include instructions that can be executed within the graphics processing system 54 and may be part of the graphics driver 68.

グラフィックス・ドライバー18Aは、実行されるとき、様々な機能ブロックを含む。様々な機能ブロックは、転送インタフェース110、プロセッサ使用モジュール112、ハードウェア・カウンタ・モジュール114、他のステート及び/又はパフォーマンス・データを管理することができるステート/パフォーマンス・データ・モジュール116、APIトレース・モジュール118、及び、オーバーライド・モジュール(override module)120として図4に示される。グラフィックス・ドライバー18Aは、アプリケーション・コンピュータ・デバイス20と通信するために、転送インタフェース・モジュール110を使用する。   The graphics driver 18A includes various functional blocks when executed. The various functional blocks include a transfer interface 110, a processor usage module 112, a hardware counter module 114, a state / performance data module 116 capable of managing other state and / or performance data, an API trace module. A module 118 and an override module 120 are shown in FIG. Graphics driver 18A uses transfer interface module 110 to communicate with application computer device 20.

プロセッサ使用モジュール112は、制御プロセッサ10、頂点プロセッサ14、グラフィックス・プロセッサ12及び表示プロセッサ16のうちの1又は複数に関するプロセッサ使用情報を収集及び維持する。プロセッサ使用情報は、プロセッサ・サイクル及び/又はパフォーマンス情報を含んでも良い。サイクル・データは、プロファイリング、命令アレイ、頂点及びインデックス・データ又は、他のオペレーションのために使用されるクロックサイクルに関するデータを含んでも良い。プロセッサ使用モジュール112は、それから、転送インタフェース・モジュール110を介してそのようなプロセッサ使用情報をアプリケーション・コンピュータ・デバイス20に提供しても良い。場合によっては、プロセッサ使用モジュール112は、非同期の方法で、それがこの情報を受信しながら、該情報をデバイス20に提供する。他の場合において、プロセッサ使用モジュール112は、デバイス20からのリクエストの受信に応じて、情報を提供しても良い。   The processor usage module 112 collects and maintains processor usage information for one or more of the control processor 10, vertex processor 14, graphics processor 12, and display processor 16. The processor usage information may include processor cycle and / or performance information. Cycle data may include profiling, instruction array, vertex and index data, or data relating to clock cycles used for other operations. The processor usage module 112 may then provide such processor usage information to the application computing device 20 via the transfer interface module 110. In some cases, the processor usage module 112 provides the information to the device 20 in an asynchronous manner while it receives this information. In other cases, processor usage module 112 may provide information in response to receiving a request from device 20.

ハードウェア・カウンタ・モジュール114は、制御プロセッサ10、グラフィックス・プロセッサ12、頂点プロセッサ14又は表示プロセッサ16のうちの1又は複数による命令の実行の間、様々なハードウェア・カウンタを収集及び維持する。カウンタは、グラフィックス処理システム4内での命令実行に関して様々なステート・インジケータ及び/又はメトリックの経過を追っても良い(keep track)。ハードウェア・カウンタ・モジュール114は、非同期で又はリクエストに応じて、情報をデバイス20に提供しても良い。   The hardware counter module 114 collects and maintains various hardware counters during execution of instructions by one or more of the control processor 10, graphics processor 12, vertex processor 14 or display processor 16. . The counter may keep track of various state indicators and / or metrics for instruction execution within the graphics processing system 4. The hardware counter module 114 may provide information to the device 20 asynchronously or upon request.

ステート/パフォーマンス・データ・モジュール116は、グラフィックス処理システム4における制御プロセッサ10、グラフィックス・プロセッサ12、頂点プロセッサ14及び表示プロセッサ16のうちの1又は複数に関する他のステート及び/又はパフォーマンス・データを収集及び維持する。例えば、ステート・データは、場合によっては、グラフィックス・データを含んでも良い。ステート・データは、頂点アレイ(例えば、位置、色、座標、サイズ又は重みデータ)に関係するデータを含んでも良い。ステート・データは、テクスチャー状態データ、点状態データ、線状態データ、ポリゴン状態データ、カリング状態データ、アルファ・テスト状態データ、ブレンド状態データ、デプス状態データ、ステンシル状態データ又は色状態データを更に含んでも良い。パフォーマンス・データは、様々な他のメトリック又はサイクル・データを含んでも良い。ステート/パフォーマンス・データ・モジュール116は、非同期で又はリクエストに応じて、情報をデバイス20に提供しても良い。   The state / performance data module 116 provides other state and / or performance data for one or more of the control processor 10, graphics processor 12, vertex processor 14, and display processor 16 in the graphics processing system 4. Collect and maintain. For example, the state data may include graphics data in some cases. The state data may include data related to the vertex array (eg, position, color, coordinates, size or weight data). The state data may further include texture state data, point state data, line state data, polygon state data, culling state data, alpha test state data, blend state data, depth state data, stencil state data or color state data. good. Performance data may include a variety of other metrics or cycle data. The state / performance data module 116 may provide information to the device 20 asynchronously or upon request.

マッピング/パーティショニング・モジュール117は、制御プロセッサ10、グラフィックス・プロセッサ12、頂点プロセッサ14及び表示プロセッサ16のうちの1又は複数からマッピング及び/又はパーティショニング情報33を収集し、また、グラフィックス・データ・マッピング情報23(図1)から情報を収集しても良い。マッピング情報は、グラフィックス・データの識別された部分(それは表示のためのグラフィックス・イメージを生成するためにレンダリングされる)を、グラフィックス命令30のうちの1又は複数にマッピングする情報を含んでも良い。このマッピング情報は、個々の命令を、出力イメージをレンダリングするために使用されたオリジナルのグラフィックス・データへマッピングするのに有効であり得る。パーティショニング情報は、レンダリングに先立って別々のグラフィックス・データを構成フラグメントにスプリットするときに、グラフィックス処理システム4内で作成及び使用されるパーティションの数、タイプ、サイズ、形状などを識別する情報を含んでも良い。マッピング/パーティショニング・モジュール117は、マッピング/パーティショニング情報33をアプリケーション・コンピュータ・デバイス20に提供しても良い。   The mapping / partitioning module 117 collects mapping and / or partitioning information 33 from one or more of the control processor 10, graphics processor 12, vertex processor 14 and display processor 16, and Information may be collected from the data mapping information 23 (FIG. 1). The mapping information includes information that maps the identified portion of graphics data (which is rendered to generate a graphics image for display) to one or more of the graphics instructions 30. But it ’s good. This mapping information may be useful for mapping individual instructions to the original graphics data that was used to render the output image. Partitioning information is information that identifies the number, type, size, shape, etc. of partitions created and used in the graphics processing system 4 when splitting separate graphics data into constituent fragments prior to rendering. May be included. The mapping / partitioning module 117 may provide the mapping / partitioning information 33 to the application computing device 20.

APIトレース・モジュール118は、グラフィックス処理システム4により実行され、転送インタフェース・モジュール110を介してアプリケーション・コンピュータ・デバイス20へ転送されるグラフィックス命令のフロー及び/又はトレースを管理する。前に説明されたように、グラフィックス・デバイス2は、グラフィックス命令30のコピー(それはその処理パイプラインにおいてグラフィックス処理システム4により実行される)を、デバイス20に提供する。APIトレース・モジュール118は、これらのグラフィックス命令30の捕捉及び転送を管理する。APIトレース・モジュール118はまた、グラフィックス命令30を、グラフィックス命令30のビジュアル表現にマッピングする命令マッピング情報31(図1)で使用される特定の情報(例えばグラフィックス命令30を生成するのに使用された可能性のあるAPI命令)を提供しても良い。   The API trace module 118 manages the flow and / or trace of graphics instructions executed by the graphics processing system 4 and transferred to the application computing device 20 via the transfer interface module 110. As previously described, graphics device 2 provides device 20 with a copy of graphics instruction 30 (which is executed by graphics processing system 4 in its processing pipeline). The API trace module 118 manages the capture and transfer of these graphics instructions 30. The API trace module 118 also generates specific information (eg, graphics instructions 30) used in the instruction mapping information 31 (FIG. 1) that maps the graphics instructions 30 to the visual representation of the graphics instructions 30. API instructions that may have been used).

オーバーライド・モジュール120は、グラフィックス・ドライバー18Aが、グラフィックス処理システム4内の特定の命令の実行を変更又はオーバーライドできるようにする。前に説明されたように、アプリケーション・コンピュータ・デバイス20は、1又は複数の要求された修正(例えば修正34)を、グラフィックス・デバイス2に送信しても良い。特定のケースでは、要求された修正34は、グラフィックス処理システム4におけるグラフィックス命令30のうちの1又は複数の実行を無効にする1又は複数のリクエスト、又は、グラフィックス命令30のうちの1又は複数を修正するリクエストを含んでも良い。場合によっては、要求された修正34は、ステート/パフォーマンス情報32を変更するリクエストを含んでも良い。   The override module 120 allows the graphics driver 18A to change or override the execution of certain instructions within the graphics processing system 4. As previously described, the application computing device 20 may send one or more requested modifications (eg, modification 34) to the graphics device 2. In certain cases, the requested modification 34 is one or more requests that invalidate execution of one or more of the graphics instructions 30 in the graphics processing system 4 or one of the graphics instructions 30. Alternatively, a request for correcting a plurality may be included. In some cases, the requested modification 34 may include a request to change the state / performance information 32.

オーバーライド・モジュール120は、要求された修正34を受信又は処理しても良い。例えば、オーバーライド・モジュール120は、ステート/パフォーマンス情報32を修正する任意のリクエストとともに、グラフィックス命令30のうちの1又は複数を修正するリクエストを、デバイス20から受信しても良く、また、そのようなリクエストを、グラフィックス処理システム4に送信する。制御プロセッサ10、グラフィックス・プロセッサ12、頂点プロセッサ14及び表示プロセッサ16のうちの1又は複数は、それから、これらのリクエストを処理し、また、更新された命令/情報35を生成しても良い。オーバーライド・モジュール120は、それから、前に説明されたように、更新された命令/情報35を、処理のためにアプリケーション・コンピュータ・デバイス20に送信しても良い。   The override module 120 may receive or process the requested modification 34. For example, override module 120 may receive a request from device 20 to modify one or more of graphics instructions 30 along with any request to modify state / performance information 32, and so on. Request is sent to the graphics processing system 4. One or more of the control processor 10, graphics processor 12, vertex processor 14, and display processor 16 may then process these requests and generate updated instructions / information 35. The override module 120 may then send the updated instructions / information 35 to the application computing device 20 for processing as previously described.

そのような方法において、グラフィックス・ドライバー18Aは、グラフィックス・デバイス2とアプリケーション・コンピュータ・デバイス20との間のインタフェースを提供する。グラフィックス・ドライバー18Aは、グラフィックス命令及びステート/パフォーマンス情報32をアプリケーション・コンピュータ・デバイス20に提供することができ、さらに、アプリケーション・コンピュータ・デバイス20から要求された修正34を受信することができる。そのような要求された修正34の処理の後に、グラフィックス・ドライバー18Aは、更新された命令/情報35を、アプリケーション・コンピュータ・デバイス20へ提供することができる。   In such a manner, graphics driver 18A provides an interface between graphics device 2 and application computer device 20. Graphics driver 18A may provide graphics instructions and state / performance information 32 to application computer device 20, and may receive requested modifications 34 from application computer device 20. . After processing of such requested modification 34, graphics driver 18A may provide updated instructions / information 35 to application computing device 20.

図5Aは、表示デバイス(例えば、図1中のグラフィックス・デバイス2の表示デバイス6又はアプリケーション・コンピュータ・デバイス20の表示デバイス24)により提供されるスクリーン・エリア130の4つのパーティションにわたり得るグラフィックス・データの第1の例を示す概念図である。図5Aに示されるデータは、場合によっては、表示デバイス6上に表示されても良い。一つの態様において、図5Aに示されるデータは、グラフィックス・デバイス2から受信されるステート/パフォーマンス情報32に、さらに、グラフィックス・デバイス2から受信されるマッピング/パーティショニング情報33に基づいて、アプリケーション・コンピュータ・デバイス20の表示デバイス24上にグラフィカルに表示される。ステート/パフォーマンス情報32は、ポリゴン(すなわち、ジオメトリ)140,142,144及び146のためのグラフィックス・データを含んでも良く、また、マッピング/パーティショニング情報33は、パーティション132,134,136及び138に関する情報を含んでも良い。例えば、アプリケーション・コンピュータ・デバイス20により受信されるマッピング/パーティショニング情報33は、グラフィックス・データのレンダリングのときにグラフィックス・デバイス2が4つの異なるパーティション(132,134,136及び138により表される)を使用することを指示しても良い。   FIG. 5A illustrates graphics that may span four partitions of a screen area 130 provided by a display device (eg, display device 6 of graphics device 2 in FIG. 1 or display device 24 of application computer device 20). -It is a conceptual diagram which shows the 1st example of data. The data shown in FIG. 5A may be displayed on the display device 6 in some cases. In one aspect, the data shown in FIG. 5A is based on state / performance information 32 received from graphics device 2 and mapping / partitioning information 33 received from graphics device 2. Graphically displayed on the display device 24 of the application computer device 20. State / performance information 32 may include graphics data for polygons (ie, geometries) 140, 142, 144 and 146, and mapping / partitioning information 33 includes partitions 132, 134, 136 and 138. May contain information about. For example, the mapping / partitioning information 33 received by the application computing device 20 may be represented by four different partitions (132, 134, 136 and 138) for the graphics device 2 when rendering graphics data. May be instructed to use.

図5Aの例において、4つのビニング・パーティション132,134,136及び138が実装される。これらのパーティションは、表示デバイス6又は表示デバイス24上に表示され得るスクリーン・エリア130内に4つの対応するエリアを表す。数字で分かるように、ポリゴン140及び142は、各々、完全に対応するパーティション内に位置する又は存在するように、アプリケーション命令21(図1)により定義される。ポリゴン140は、パーティション132内に位置し、ポリゴン142は、パーティション134内に位置する。グラフィックス・データのレンダリングのときに、グラフィックス・プロセッサ12は、例えば、別々に、そして、独立したレンダリング・オペレーションの間、パーティション132,134,136及び138の各々の中にデータをレンダリングしても良い。ポリゴン140は完全にパーティション132の中にあるので、それはパーティション132に関連するレンダリング・オペレーションの間の完全なジオメトリとしてレンダリングされても良い。同様に、ポリゴン142は完全にパーティション134の中にあるので、それはパーティション134に関連するレンダリング・オペレーションの間の完全なジオメトリとしてレンダリングされても良い。   In the example of FIG. 5A, four binning partitions 132, 134, 136 and 138 are implemented. These partitions represent four corresponding areas in the screen area 130 that may be displayed on the display device 6 or the display device 24. As can be seen in the figures, polygons 140 and 142 are each defined by application instruction 21 (FIG. 1) to be located or exist within a completely corresponding partition. Polygon 140 is located in partition 132 and polygon 142 is located in partition 134. When rendering graphics data, graphics processor 12 may render the data in each of partitions 132, 134, 136, and 138, for example, separately and during independent rendering operations. Also good. Since polygon 140 is completely within partition 132, it may be rendered as complete geometry during the rendering operation associated with partition 132. Similarly, since polygon 142 is entirely within partition 134, it may be rendered as a complete geometry during a rendering operation associated with partition 134.

他方、ポリゴン144及び146は、複数のパーティションにわたる。ポリゴン144は、全4つのパーティション132,134,136及び138にわたり、一方、ポリゴン146は、2つのパーティション136及び138にわたる。ポリゴン144をレンダリングするために、グラフィックス・プロセッサ12は、ポリゴン144を、4つの構成フラグメント144A,144B,144C及び144D(図5Bに示される)にスプリットしても良い。グラフィックス・プロセッサ12は、それから、独立したレンダリング・オペレーションの間に、フラグメント144A,144B,144C及び144Dを独立してレンダリングしても良い。例えば、パーティション132に関連するレンダリング・オペレーションの間に、グラフィックス・プロセッサ12がフラグメントに144Aをレンダリングしても良い;パーティション134に関連するレンダリング・オペレーションの間に、グラフィックス・プロセッサ12がフラグメント144Bをレンダリングしても良い;パーティション138に関連するレンダリング・オペレーションの間に、グラフィックス・プロセッサ12がフラグメントに144Cをレンダリングしても良い;そして、パーティション136に関連するレンダリング・オペレーションの間に、グラフィックス・プロセッサ12がフラグメントに144Dをレンダリングしても良い。   On the other hand, polygons 144 and 146 span multiple partitions. Polygon 144 spans all four partitions 132, 134, 136 and 138, while polygon 146 spans two partitions 136 and 138. To render polygon 144, graphics processor 12 may split polygon 144 into four constituent fragments 144A, 144B, 144C, and 144D (shown in FIG. 5B). Graphics processor 12 may then render fragments 144A, 144B, 144C, and 144D independently during independent rendering operations. For example, during a rendering operation associated with partition 132, graphics processor 12 may render 144A into a fragment; during a rendering operation associated with partition 134, graphics processor 12 may fragment 144B. Graphics processor 12 may render 144C into fragments during a rendering operation associated with partition 138; and graphics during a rendering operation associated with partition 136 The processor 12 may render 144D into fragments.

これらのフラグメント144A,144B,144C及び144Dが独立してレンダリングされた後、表示プロセッサ16は、ポリゴン144の正確なグラフィカル表現を表示するために、これらのフラグメントの各々のためのレンダリングされたイメージを結合する必要があり得る。これらの独立したレンダリング及び結合オペレーションは、パフォーマンス・オーバーヘッドを引き起こす場合がある。   After these fragments 144A, 144B, 144C, and 144D are rendered independently, the display processor 16 uses the rendered image for each of these fragments to display an accurate graphical representation of the polygon 144. May need to be joined. These independent rendering and combining operations can cause performance overhead.

同様に、ポリゴン146をレンダリングするために、グラフィックス・プロセッサ12は、ポリゴン146を2つの構成フラグメント146A及び146B(図5Bに示される)にスプリットしても良い。グラフィックス・プロセッサ12は、それから、独立したレンダリング・オペレーションの間に、フラグメント146A及び146Bを独立してレンダリングしても良い。例えば、パーティション138に関連するレンダリング・オペレーションの間に、グラフィックス・プロセッサ12がフラグメントに146Aをレンダリングしても良く、パーティション136に関連するレンダリング・オペレーションの間に、グラフィックス・プロセッサ12がフラグメント146Bをレンダリングしても良い。これらのフラグメント146A及び146Bが独立してレンダリングされた後、表示プロセッサ16は、ポリゴン146の正確なグラフィカル表現を表示するために、これらのフラグメントの各々のためのレンダリングされたイメージを結合しても良い。   Similarly, to render polygon 146, graphics processor 12 may split polygon 146 into two constituent fragments 146A and 146B (shown in FIG. 5B). Graphics processor 12 may then render fragments 146A and 146B independently during an independent rendering operation. For example, during a rendering operation associated with partition 138, graphics processor 12 may render 146A into a fragment, and during a rendering operation associated with partition 136, graphics processor 12 may fragment 146B. May be rendered. After these fragments 146A and 146B are rendered independently, display processor 16 may combine the rendered images for each of these fragments to display an accurate graphical representation of polygon 146. good.

図5A−5Bで示される情報は、場合によっては、アプリケーション・コンピュータ・デバイス20の表示デバイス24に表示されても良い。アプリケーション・コンピュータ・デバイス20は、表示デバイス24のスクリーン・エリア130内にポリゴン140,142,144及び146の表現(又はグラフィックス・イメージ)を表示するために、グラフィックス命令30及びステート/パフォーマンス情報32を使用しても良い。アプリケーション・コンピュータ・デバイス20はまた、グラフィックス・イメージをオーバーレイし、そして、これらのイメージのシーンをグラフィカルに分割するパーティション132,134,136及び138のグラフィカル表現を表示するために、マッピング/パーティショニング情報33を使用しても良い。アプリケーション・コンピュータ・デバイス20はまた、これらのポリゴンのうちのいずれがパーティション132,134,136及び/又は138のうちの複数のものにわたるかについて判定するために、ポリゴン140,142,144及び146のためのグラフィックス・データを解析しても良い。   The information shown in FIGS. 5A-5B may be displayed on the display device 24 of the application computer device 20 in some cases. Application computer device 20 provides graphics instructions 30 and state / performance information to display representations (or graphics images) of polygons 140, 142, 144 and 146 within screen area 130 of display device 24. 32 may be used. Application computer device 20 also overlays graphics images and displays mapping / partitioning to display graphical representations of partitions 132, 134, 136, and 138 that graphically divide the scenes of these images. Information 33 may be used. Application computer device 20 also determines polygons 140, 142, 144, and 146 to determine which of these polygons span multiple of partitions 132, 134, 136, and / or 138. Graphics data may be analyzed.

アプリケーション開発者がウインドウ130内に表示された情報を閲覧するとき、開発者は、いずれのポリゴンが(それらが複数のパーティションにわたるので)ハードウェアによりスプリットされるか、さらに、そのようなパーティションはどこに位置するかの考えを得ることができる。開発者は、シーンを定義するとき、グラフィックス・アプリケーション(例えばアプリケーション命令21(図1)を使用するアプリケーション)内の特定のグラフィックス・データの最適化された構成(configuration)又は位置(location)を判定するために、この情報を使用することができ得る。例えば、図5Aに示される情報の閲覧に応じて、開発者は、ポリゴン144及び146が複数のパーティションにわたらないように、ポリゴン144及び146を再編成(rearrange)又は再構成(reconfigure)すると判定しても良い。   When the application developer views the information displayed in the window 130, the developer determines which polygons are split by hardware (since they span multiple partitions), and where such partitions are You can get an idea of where you are. When a developer defines a scene, an optimized configuration or location of specific graphics data within a graphics application (eg, an application that uses application instructions 21 (FIG. 1)). This information can be used to determine For example, in response to viewing the information shown in FIG. 5A, the developer may decide to rearrange or reconfigure polygons 144 and 146 so that polygons 144 and 146 do not span multiple partitions. You may do it.

開発者は、ウインドウ130内にグラフィックス・イメージをオーバーレイするパーティションの表現を提示されるので(これらのパーティションはグラフィックス・デバイス2により定義される)、開発者は、ポリゴン144及び146が複数のパーティションにわたらないように、あるいは、それらが最小の数のパーティションだけにわたるように、ポリゴン144及び146を定義、構成又は位置決め(locate)の方法をより良く理解し得る。場合によっては、開発者は、レンダリングの後で表示プロセッサ16によりポリゴンが結合される必要がないように、一つのポリゴンを複数のサブ・ポリゴンとして再定義すると判定しても良い。例えば、図5Bで示すように、開発者は、アプリケーション命令21の修正版において、ポリゴン146を2つの独立したポリゴン146A及び146Bとして再定義しても良い。これらのポリゴンが当初は別々に定義されるならば、これらのポリゴンのレンダリングされたバージョンは、それから、表示に先立って結合される必要はない可能性がある。そして、それは、パフォーマンス・オーバーヘッドを低減する可能性がある。   Since the developer is presented with a representation of the partitions overlaying the graphics image in the window 130 (these partitions are defined by the graphics device 2), the developer has a plurality of polygons 144 and 146. A better understanding of how to define, configure, or locate polygons 144 and 146 so that they do not span partitions, or so that they span only a minimal number of partitions. In some cases, the developer may determine to redefine one polygon as multiple sub-polygons so that the display processor 16 does not need to combine the polygons after rendering. For example, as shown in FIG. 5B, the developer may redefine polygon 146 as two independent polygons 146A and 146B in a modified version of application instruction 21. If these polygons are initially defined separately, the rendered versions of these polygons may then not need to be combined prior to display. And it can reduce performance overhead.

図6は、表示デバイス(例えば、図1に示される(グラフィックス・デバイス2中の)表示デバイス6又は(アプリケーション・コンピュータ・デバイス20中の)表示デバイス24)により提供されるスクリーン・エリアの8つのパーティションにわたり得るグラフィックス・データの第2の例を示す概念図である。前に説明されたように、グラフィックス・デバイス2のグラフィックス処理システム4は、様々な異なる形状、サイズ及びタイプの表示デバイス6のスクリーン・エリアに関連するビニング・パーティションを作成又は使用しても良い。そして、それは、様々な要因(例えば、メモリサイズ要求又は制約のような)又は他のパフォーマンス考慮点に依存しても良い。図6の第2の例において、プロセッサ10,12,14又は16のうちの1又は複数は、(図5A及び5B中の例に示される4つのパーティションよりもむしろ)8つの独立したパーティションを作成及び使用すると判定しても良い。   FIG. 6 shows eight screen areas provided by a display device (eg, display device 6 (in graphics device 2) shown in FIG. 1 or display device 24 (in application computer device 20) shown in FIG. It is a conceptual diagram which shows the 2nd example of the graphics data which can be spread over two partitions. As previously described, the graphics processing system 4 of the graphics device 2 may create or use binning partitions associated with the screen area of the display device 6 of various different shapes, sizes and types. good. It may then depend on various factors (such as memory size requirements or constraints) or other performance considerations. In the second example of FIG. 6, one or more of the processors 10, 12, 14 or 16 creates eight independent partitions (rather than the four partitions shown in the examples in FIGS. 5A and 5B). And it may be determined to be used.

スクリーン・エリア150内で、8つのパーティションは、パーティション152,154,156,158,160,162,164及び166である。これらのパーティションの各々は、形状が長方形である。説明の目的のために、スクリーン・エリア150が実質的にスクリーン・エリア130(図5A及び5B)と同じ面積のサイズであるならば、図6に示される各々のパーティションは、図5A及び5Bに示される各々のパーティションの2分の1のサイズである。   Within the screen area 150, the eight partitions are partitions 152, 154, 156, 158, 160, 162, 164 and 166. Each of these partitions is rectangular in shape. For illustrative purposes, if the screen area 150 is substantially the same size as the screen area 130 (FIGS. 5A and 5B), each partition shown in FIG. It is half the size of each partition shown.

図6の例において、ポリゴン140,142,144及び146を作成及び/又はレンダリングするために、アプリケーション命令21が、再び、実行されても良い。図5A及び5Bにおいて、4つのパーティションだけが使用されたとき、ポリゴン140及び142は、複数のパーティションにわたらなかった。このように、グラフィックス・デバイス2が4つだけのビニング・パーティションを実装するならば、これらのポリゴンは複数のパーティションにわたらないので、アプリケーション命令21を含むグラフィックス・アプリケーションは、ポリゴン140及び142のレンダリングから引き起こされる更なるパフォーマンス・オーバーヘッドを経験しない可能性がある。しかし、図6に示されるように、グラフィックス・デバイス2が8つのビニング・パーティションを実装するならば、ポリゴン140及び142は各々2つの独立したパーティションにわたる(ポリゴン140はパーティション152及び154にわたり、一方、ポリゴン142はパーティション156及び58にわたる)。   In the example of FIG. 6, application instructions 21 may be executed again to create and / or render polygons 140, 142, 144 and 146. In FIGS. 5A and 5B, when only four partitions were used, polygons 140 and 142 did not span multiple partitions. Thus, if the graphics device 2 implements only four binning partitions, these polygons do not span multiple partitions, so the graphics application containing the application instruction 21 is polygons 140 and 142. May not experience the additional performance overhead caused by the rendering of. However, as shown in FIG. 6, if graphics device 2 implements 8 binning partitions, polygons 140 and 142 each span two independent partitions (polygon 140 spans partitions 152 and 154, while , Polygon 142 spans partitions 156 and 58).

一つの態様において、パーティション152,154,156,158,160,162,164及び166のグラフィカル表現は、表示デバイス24上でアプリケーション開発者に対して表示されても良い。グラフィックス・イメージをオーバーレイするそのようなパーティションの任意のグラフィカル表示(例えば、ポリゴン140,142,144及び146の表現)は、開発者にとって全く有用であり得る。しばしば、開発者は、任意の個々のデバイス(例えばグラフィックス・デバイス2)により作成及び使用されるパーティションの数、タイプ、形状、サイズなどについての情報又は考えをほとんど有しないであろう。シーン中のグラフィックス・イメージの上にオーバーレイされるそのようなパーティションのグラフィカル表現を閲覧することができることによって、開発者は、いずれのグラフィックス・イメージ又はプリミティブ・グラフィックス・データが、例えば、複数のパーティションにわたり得るかというより良い考えを得る可能性があり、したがって、特定のレンダリング・パフォーマンス・オーバーヘッドを有する可能性がある。その結果、開発者は、グラフィックス・アプリケーション(例えばアプリケーション命令21を含むもの)により生成及び操作されるグラフィックス・データを、再定義、再構成、リサイズ又はさもなければ変更することができ得る。   In one aspect, graphical representations of partitions 152, 154, 156, 158, 160, 162, 164 and 166 may be displayed to application developers on display device 24. Any graphical representation of such a partition overlaying a graphics image (eg, a representation of polygons 140, 142, 144 and 146) can be quite useful to the developer. Often, a developer will have little information or ideas about the number, type, shape, size, etc. of partitions created and used by any individual device (eg, graphics device 2). By being able to view a graphical representation of such a partition overlaid on a graphics image in the scene, a developer can view any graphics image or primitive graphics data, eg, multiple You might get a better idea of what you might get across your partitions, and thus have a certain rendering performance overhead. As a result, the developer may be able to redefine, reconfigure, resize or otherwise modify the graphics data generated and manipulated by the graphics application (eg, including application instructions 21).

図7は、一つの態様に従って、シミュレーション・アプリケーション28(図1)の実行を通してアプリケーション・コンピュータ・デバイス20により実行され得る方法のフローチャートである。アプリケーション・コンピュータ・デバイス20は、マッピング/パーティショニング情報33を、外部グラフィックス・デバイス(例えばグラフィックス・デバイス2)から受信しても良い(170)。アプリケーション・コンピュータ・デバイス20はまた、グラフィックス命令30をグラフィックス・デバイス2から受信しても良い(172)。グラフィックス命令30は、1又は複数のグラフィックス・イメージ(例えば3次元(3D)グラフィックス・イメージ)を表示デバイス6上に表示するために、グラフィックス・デバイス2によって実行される。一つの態様において、グラフィックス命令30は、実行されるときにグラフィックス・イメージをレンダリングするコール・ストリームを含む。一つの態様において、コール・ストリームは、アプリケーション・プログラミング・インタフェース(API)命令から生成されるバイナリ命令を含む。   FIG. 7 is a flowchart of a method that may be performed by the application computing device 20 through execution of the simulation application 28 (FIG. 1), according to one aspect. Application computer device 20 may receive mapping / partitioning information 33 from an external graphics device (eg, graphics device 2) (170). Application computer device 20 may also receive graphics instructions 30 from graphics device 2 (172). Graphics instructions 30 are executed by graphics device 2 to display one or more graphics images (eg, three-dimensional (3D) graphics images) on display device 6. In one aspect, graphics instruction 30 includes a call stream that renders a graphics image when executed. In one aspect, the call stream includes binary instructions generated from application programming interface (API) instructions.

アプリケーション・コンピュータ・デバイス20は、更に、ステート及び/又はパフォーマンス情報32を、グラフィックス・デバイス2から受信しても良い(174)。ステート/パフォーマンス情報32は、グラフィックス・デバイス2上でのグラフィックス命令30の実行に関連する。ステート/パフォーマンス情報32は、グラフィックス・デバイス2がグラフィックス・イメージをレンダリングするときの、グラフィックス・デバイス2の1又は複数のステートを指示するステート情報を含んでも良い。ステート情報は、グラフィックス命令30を実行するグラフィックス・デバイス2の1又は複数のプロセッサ(例えば制御プロセッサ10、グラフィックス・プロセッサ12、頂点プロセッサ14及び/又は表示プロセッサ16)からのステート情報を含んでも良い。場合によっては、ステート情報は、グラフィックス・データ(例えばグラフィックス・イメージ・データをレンダリングするためにグラフィックス・プロセッサ12により使用されるプリミティブ・ポリゴン・データ)を含んでも良い。   Application computer device 20 may further receive state and / or performance information 32 from graphics device 2 (174). The state / performance information 32 relates to the execution of graphics instructions 30 on the graphics device 2. The state / performance information 32 may include state information indicating one or more states of the graphics device 2 when the graphics device 2 renders a graphics image. The state information includes state information from one or more processors (eg, control processor 10, graphics processor 12, vertex processor 14 and / or display processor 16) of graphics device 2 executing graphics instructions 30. But it ’s okay. In some cases, the state information may include graphics data (eg, primitive polygon data used by graphics processor 12 to render graphics image data).

アプリケーション・コンピュータ・デバイス20は、グラフィカル・シーンにおいて、グラフィックス命令30及びステート/パフォーマンス情報32に基づいて、1又は複数のグラフィックス・イメージの表現を表示しても良い(176)。そのような方法において、アプリケーション・コンピュータ・デバイス20は、グラフィックス・デバイス2をシミュレートするシミュレーションされた環境内で、これらのグラフィックス・イメージの表現を表示することができる。シミュレーションされた環境は、アプリケーション・コンピュータ・デバイス20のプロセッサ22の上で、シミュレーション・アプリケーション28の実行を通して提供されても良い。   Application computer device 20 may display a representation of one or more graphics images based on graphics instructions 30 and state / performance information 32 in a graphical scene (176). In such a manner, the application computer device 20 can display a representation of these graphics images within a simulated environment that simulates the graphics device 2. The simulated environment may be provided through the execution of the simulation application 28 on the processor 22 of the application computing device 20.

アプリケーション・コンピュータ・デバイス20は、グラフィックス・イメージをオーバーレイし、そして、シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示しても良い(178)。例えば、一つのシナリオにおいて、アプリケーション・コンピュータ・デバイス20は、図5A及び5Bに示されるパーティションのグラフィカル表現を表示しても良い。場合によっては、パーティションは、長方形の形のパーティションを含んでも良い。アプリケーション・コンピュータ・デバイス20は、受信されたマッピング/パーティショニング情報33に基づいて、パーティションのグラフィカル表現を表示しても良い。   The application computer device 20 may overlay the graphics image and display a graphical representation of the partition that graphically divides the scene (178). For example, in one scenario, the application computing device 20 may display a graphical representation of the partitions shown in FIGS. 5A and 5B. In some cases, the partitions may include rectangular shaped partitions. The application computing device 20 may display a graphical representation of the partition based on the received mapping / partitioning information 33.

さらに、アプリケーション・コンピュータ・デバイス20は、表示されたグラフィックス・イメージのためのグラフィックス・データを解析して、いずれの部分が複数のパーティションに関連するかについて判定しても良い(180)。例えば、アプリケーション・コンピュータ・デバイス20は、グラフィックス・プリミティブ(例えば、表示グラフィックス・イメージを生成又はレンダリングするために使用されるポリゴン・データ)を解析して、いずれのポリゴン(例えば、三角形)が複数のパーティションにわたるかについて判定しても良い。   Further, application computer device 20 may analyze graphics data for the displayed graphics image to determine which portions are associated with multiple partitions (180). For example, the application computing device 20 analyzes graphics primitives (eg, polygon data used to generate or render a display graphics image) and finds which polygon (eg, triangle) A determination may be made as to whether it spans multiple partitions.

処理すべきより多くのフレームがあるならば(182)、グラフィックス命令の受信(172)、ステート情報の受信(174)、グラフィックス・イメージの表現の表示(176)、パーティションの表示(178)、及び、グラフィックス・データの解析(180)が、1又は複数のグラフィックス・イメージの複数のイメージ・フレームについて繰り返されても良い。この方法において、アプリケーション・コンピュータ・デバイス20は、静止及び動画グラフィックス・イメージの両方(3Dイメージを含む)を表示デバイス24上に表示することができ、また、イメージをオーバーレイし、そして、シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示することができる。グラフィックス・イメージが変更し、あるいは、イメージの代わりの斜視図が示されるので、アプリケーション開発者は、パーティションのイメージ及び位置に関連するグラフィックス・データ間の関係を連続的に確認することができる。   If there are more frames to process (182), receive graphics command (172), receive state information (174), display graphics image representation (176), display partition (178). And the analysis of the graphics data (180) may be repeated for a plurality of image frames of one or more graphics images. In this manner, the application computer device 20 can display both still and animated graphics images (including 3D images) on the display device 24, overlay the image, and display the scene. You can display a graphical representation of a partition that you want to split graphically. As the graphics image changes or a perspective view of the image is shown, the application developer can continuously see the relationship between the graphics data associated with the partition image and location. .

図8は、一つの態様に従って、シミュレーション・アプリケーション28(図1)の実行を通してアプリケーション・コンピュータ・デバイス20により実行され得る方法のフローチャートである。一つの態様において、プロセッサ22は、ナビゲーション・コントローラを表示デバイス24上に表示するために、シミュレーション・アプリケーション28を実行しても良い。   FIG. 8 is a flowchart of a method that may be performed by the application computing device 20 through execution of the simulation application 28 (FIG. 1), according to one aspect. In one aspect, the processor 22 may execute a simulation application 28 to display the navigation controller on the display device 24.

アプリケーション・コンピュータ・デバイス20は、マッピング/パーティショニング情報33を、外部グラフィックス・デバイス(例えばグラフィックス・デバイス2)から受信しても良い(190)。アプリケーション・コンピュータ・デバイス20はまた、1又は複数のグラフィックス・イメージの斜視図を、その表示デバイス24に表示しても良い(191)。例えば、アプリケーション・コンピュータ・デバイス20は、受信されたグラフィックス命令30及び/又はステート/パフォーマンス情報32に基づいて、グラフィックス・イメージの斜視図を表示しても良い。   Application computer device 20 may receive mapping / partitioning information 33 from an external graphics device (eg, graphics device 2) (190). The application computer device 20 may also display a perspective view of one or more graphics images on its display device 24 (191). For example, the application computing device 20 may display a perspective view of the graphics image based on the received graphics instructions 30 and / or state / performance information 32.

アプリケーション・コンピュータ・デバイス20は、受信されたマッピング/パーティショニング情報33(192)に基づいて、グラフィックス・イメージをオーバーレイするパーティションのグラフィックス表現を表示デバイス24上に表示しても良い。アプリケーション・コンピュータ・デバイス20はまた、グラフィックス・データのいずれの部分が該パーティションのうちの複数のものに関連するかについて判定するために、グラフィックス・データ(例えばステート/パフォーマンス情報32内に含まれるグラフィックス・データ)のためのグラフィックス・イメージを解析しても良い。例えば、グラフィックス・データは、複数のグラフィックス・プリミティブ(例えば三角形)を含んでも良い。アプリケーション・コンピュータ・デバイス20は、三角形のうちのいずれが該パーティションのうちの複数のものにわたるかについて判定しても良い(193)。これらの三角形は、複数のパーティションにおいて少なくとも部分的にレンダリングされた三角形を含んでも良い。   The application computing device 20 may display on the display device 24 a graphic representation of the partition overlaying the graphics image based on the received mapping / partitioning information 33 (192). Application computer device 20 also includes graphics data (eg, in state / performance information 32) to determine which portions of graphics data are associated with more than one of the partitions. Graphics image) may be analyzed. For example, the graphics data may include a plurality of graphics primitives (eg, triangles). Application computing device 20 may determine which of the triangles spans multiple of the partitions (193). These triangles may include triangles rendered at least partially in multiple partitions.

一つの態様において、アプリケーション・コンピュータ・デバイス20は、パーティションのグラフィカル表現を表示すると共に、該パーティションのうちの複数のものにわたる三角形のグラフィカル表現を表示デバイス24上に表示する。場合によっては、アプリケーション・コンピュータ・デバイス20は、複数のパーティションにわたる各々の三角形について、グラフィカル・インジケーション(例えば色)を表示しても良い(194)。   In one embodiment, application computer device 20 displays a graphical representation of a partition and displays a graphical representation of a triangle across multiple of the partitions on display device 24. In some cases, application computing device 20 may display a graphical indication (eg, color) for each triangle across multiple partitions (194).

例えば、アプリケーション・コンピュータ・デバイス20は、一つの態様において、三角形の“ヒートマップ(heat map)”表現を表示デバイス24上に表示しても良い。ここで、各々の三角形は、関連するグラフィカル・インジケータ(例えば色)を有する。色に加えて、他の形のグラフィカル・インジケータ(例えば、ダッシュ線、点滅インジケータ、ハイライト・インジケータ)が、三角形を互いから区別する特定のシナリオにおいて使用されても良い。複数のパーティションにわたらない三角形は、第1の色(例えば、青)で表示されても良い。複数のパーティション(例えば、2〜3のパーティション)にわたる三角形は、第2の色(例えば、紫)で表示されても良い。3を超えるパーティションにわたる三角形は、第3の色(例えば、赤)で顕著に表示されても良い。このように、この例では、アプリケーション開発者は、いずれの三角形が複数のパーティションにわたるか、及び、いずれの三角形が他よりも多くのパーティションにわたるかについて、速く判定することができる。開発者は、パフォーマンス(例えば、レンダリング)オーバーヘッドを低減するために、複数のパーティションにわたる三角形を再構成、再定義又はさもなければ再構築(restructure)構成する方法について判定するために、この情報を使用することができ得る。   For example, the application computer device 20 may display a triangular “heat map” representation on the display device 24 in one aspect. Here, each triangle has an associated graphical indicator (eg, color). In addition to color, other forms of graphical indicators (eg, dash lines, blinking indicators, highlight indicators) may be used in certain scenarios that distinguish triangles from each other. Triangles that do not span multiple partitions may be displayed in a first color (eg, blue). Triangles that span multiple partitions (eg, 2-3 partitions) may be displayed in a second color (eg, purple). Triangles that span more than three partitions may be displayed prominently in a third color (eg, red). Thus, in this example, the application developer can quickly determine which triangles span multiple partitions and which triangles span more partitions than others. Developers use this information to determine how to reconstruct, redefine, or otherwise restructure triangles across multiple partitions to reduce performance (eg, rendering) overhead You can get.

アプリケーション・コンピュータ・デバイス20は、表示デバイス24上に表示されるユーザ・インタフェース内にナビゲーション・コントローラを表示するために、ナビゲーション・モジュール29(図1)を使用しても良い。例えば、ナビゲーション・コントローラは、3Dカメラ・コントローラを含んでも良い。アプリケーション開発者は、表示デバイス24上に表示されるグラフィックス・イメージのシーンをナビゲートするために、ナビゲーション・コントローラとインタラクトしても良い。アプリケーション・コンピュータ・デバイス20は、イメージの斜視図を修正するために、ナビゲーション・コントローラを介して開発者からのユーザ入力を受信しても良い(195)。   The application computer device 20 may use the navigation module 29 (FIG. 1) to display the navigation controller in the user interface displayed on the display device 24. For example, the navigation controller may include a 3D camera controller. The application developer may interact with the navigation controller to navigate the scene of the graphics image displayed on the display device 24. The application computing device 20 may receive user input from the developer via the navigation controller to modify the perspective view of the image (195).

アプリケーション・コンピュータ・デバイス20は、それから、ナビゲーション・コントローラに入力されるユーザに基づいて、修正されたグラフィックス・シーンにおけるグラフィックス・イメージの修正された斜視図を表示しても良い。例えば、開発者は、イメージのシーンを回転するために、シーンをズームイン又はズームアウトするために、又はさもなければ、シーンの斜視図を変更するために、ナビゲーション・コントローラとインタラクトしても良い。そして、それは、それから、新しいイメージを含む、修正されたシーン内のイメージの修正された斜視図を表示しても良い。ナビゲーション・コントローラに提供されるユーザ入力は、要求された修正34としてグラフィックス・デバイス2へ送信されても良く、そして、更新された斜視図の表示は、グラフィックス・デバイス2により元のアプリケーション・コンピュータ・デバイス20へ提供される更新された命令/情報35に基づいても良い。一つの態様において、要求された修正34は、グラフィックス・デバイス2上のグラフィックス命令30のうちの1又は複数の実行を無効にするリクエスト、グラフィックス・デバイス2上のグラフィックス命令30のうちの1又は複数を修正するリクエスト及びグラフィックス・デバイス2に関するステート/パフォーマンス情報32を修正するリクエストのうちの少なくとも一つを含んでも良い。   The application computing device 20 may then display a modified perspective view of the graphics image in the modified graphics scene based on the user input to the navigation controller. For example, the developer may interact with the navigation controller to rotate the scene of the image, zoom in or out of the scene, or otherwise change the perspective view of the scene. It may then display a modified perspective view of the image in the modified scene, including the new image. The user input provided to the navigation controller may be sent to the graphics device 2 as the requested modification 34 and the updated perspective view display is displayed by the graphics device 2 on the original application. It may be based on updated instructions / information 35 provided to the computer device 20. In one aspect, the requested modification 34 is a request to invalidate execution of one or more of the graphics instructions 30 on the graphics device 2, of the graphics instructions 30 on the graphics device 2. And / or a request to modify state / performance information 32 relating to graphics device 2 may be included.

一つの態様において、アプリケーション・コンピュータ・デバイス20はまた、グラフィックス・イメージの修正された斜視図をオーバーレイし、そして、修正されたシーンをグラフィカルに分割したパーティションのグラフィカル表現を表示しても良い。アプリケーション・コンピュータ・デバイス20は、グラフィックス・データのいずれの部分が該パーティションのうちの複数のものに関連するかについて判定するために、グラフィックス・イメージの修正された斜視図のためのグラフィックス・データを解析しても良い。   In one embodiment, the application computing device 20 may also overlay a modified perspective view of the graphics image and display a graphical representation of the partition that graphically divides the modified scene. The application computing device 20 may use graphics for a modified perspective view of a graphics image to determine which portion of graphics data is associated with more than one of the partitions. -Data may be analyzed.

(1又は複数の)グラフィックス・イメージの斜視図を表示すること(191)、その(1又は複数の)グラフィックス・イメージをオーバーレイするパーティションを表示すること(192)、いずれの(1又は複数の)プリミティブ三角形が複数のパーティションにわたるかについて判定すること(193)、各々の判定された三角形についてグラフィカル・インジケーションを表示すること(194)及びシーンの斜視図を修正するためにナビゲーション・コントローラを介してユーザ入力を受信すること(195)は、シーンの複数の斜視図について繰り返されても良い(196)。グラフィックス・イメージが変更するので、あるいは、イメージの代わりの斜視図が表示されるので、アプリケーション開発者は、パーティションのイメージ及び位置に関連するグラフィックス・データ間の関係を連続的に確認することができる。   Displaying a perspective view of the graphics image (s) (191), displaying a partition over which the graphics image (s) is overlaid (192), any (one or more) Determining (193) whether a primitive triangle spans multiple partitions, displaying a graphical indication for each determined triangle (194), and modifying the navigation controller to modify the perspective view of the scene Receiving user input via (195) may be repeated for multiple perspective views of the scene (196). As the graphics image changes or a perspective view of the image is displayed, the application developer should continuously check the relationship between the graphics data related to the partition image and location. Can do.

図9は、一つの態様に従って、グラフィック・ウインドウ203中に情報を表示するための表示デバイス201に接続されるグラフィックス・デバイス200の例を示す概念図である。例えば、グラフィックス・デバイス200がグラフィックス・デバイス2(図1)の一部であるならば、表示デバイス201は、アプリケーション・コンピュータ・デバイス20のグラフィックス・デバイス24の一部であっても良い。グラフィックス・デバイス200は、3Dグラフィックス・イメージ202を表示することができる。表示デバイス201は、グラフィックス・デバイス200から送信されるグラフィックス命令及びステート/パフォーマンス情報に基づいて、ウインドウ203中に、3Dグラフィックス・イメージ210(それはグラフィックス・イメージ202の改造(re-creation)である)を表示することができる。開発者がグラフィックス・イメージ210又はグラフィックス・イメージ210を含む全体のシーンを修正するために、これらの命令及びステート/パフォーマンス情報を変更し得るように、表示デバイス201はまた、これらの命令及びステート/パフォーマンス情報のビジュアル表現を表示することができる。表示デバイス201は、グラフィックス・デバイス200に接続された任意のタイプのコンピュータ・デバイス(図示せず)中に含まれても良く、また、グラフィックス・デバイス200からそのような命令及びステート/パフォーマンス情報を受信することができる。(簡単にするために、表示デバイス201を含むコンピュータ・デバイスは、図10に示される概念図から省略された。)
前に説明されたように、グラフィックス・デバイス200は、3Dグラフィックス・イメージ202(それは図9の例における立方体である)の表示ができる。図9の例において、グラフィックス・デバイス200はまた、キーパッド204を有する。ユーザは、グラフィックス・デバイス200を操作するために、キーパッド204とインタラクトしても良い。キーパッド204は、幾つかのキー及び/又はボタンを含んでも良い。グラフィックス・デバイス200は、コネクタ206を介して、グラフィックス・デバイス201を含むデバイス(例えば、アプリケーション・コンピュータ・デバイス20)に、グラフィックス命令及びステート/パフォーマンス情報を送信することができる。一つの態様において、コネクタ206は、ユニバーサルシステムバス(USB)コネクタを含む。他の態様において、異なる形のコネクタが、使用されても良い。幾つかの態様において、無線通信がコネクタ206を置き換えても良い。
FIG. 9 is a conceptual diagram illustrating an example of a graphics device 200 connected to a display device 201 for displaying information in a graphics window 203, according to one aspect. For example, if graphics device 200 is part of graphics device 2 (FIG. 1), display device 201 may be part of graphics device 24 of application computer device 20. . Graphics device 200 can display 3D graphics image 202. Based on the graphics instructions and state / performance information sent from the graphics device 200, the display device 201 can generate a 3D graphics image 210 (which is a re-creation of the graphics image 202) in the window 203. ) Can be displayed. The display device 201 also allows these instructions and state / performance information to be changed by the developer to modify the graphics image 210 or the entire scene containing the graphics image 210. A visual representation of state / performance information can be displayed. The display device 201 may be included in any type of computer device (not shown) connected to the graphics device 200, and from the graphics device 200 such instructions and states / performances. Information can be received. (For simplicity, the computing device including the display device 201 has been omitted from the conceptual diagram shown in FIG. 10.)
As previously described, graphics device 200 is capable of displaying a 3D graphics image 202 (which is the cube in the example of FIG. 9). In the example of FIG. 9, graphics device 200 also has a keypad 204. A user may interact with the keypad 204 to operate the graphics device 200. The keypad 204 may include a number of keys and / or buttons. Graphics device 200 may send graphics instructions and state / performance information via connector 206 to devices including graphics device 201 (eg, application computer device 20). In one aspect, the connector 206 includes a universal system bus (USB) connector. In other aspects, different shaped connectors may be used. In some aspects, wireless communication may replace connector 206.

図9の例において示されるように、表示デバイス201は、グラフィカル・ユーザ・インタフェース内に様々なタイプの情報を表示しても良い。この例では、表示デバイス201は、グラフィカル・ユーザ・インタフェース内にグラフィカル・ウインドウ203を表示する。ウインドウ203は、表示エリア211、グラフィックス命令エリア208及びステート/パフォーマンス情報エリア214を含む。表示エリア211は、3Dグラフィックス・イメージ210を含む。そして、それは、前に説明されたように、3Dグラフィックス・イメージ202の改造(re-creation)である。この例において、3Dグラフィックス・イメージは、立方体を含む。一つの態様に従って、表示デバイス201に表示される情報は、デバッギング及びテストの目的のために、グラフィックス・デバイス202上に表示される情報の表現又はシミュレーションを含む。   As shown in the example of FIG. 9, display device 201 may display various types of information in a graphical user interface. In this example, the display device 201 displays a graphical window 203 in the graphical user interface. Window 203 includes a display area 211, a graphics instruction area 208 and a state / performance information area 214. The display area 211 includes a 3D graphics image 210. And it is a re-creation of the 3D graphics image 202 as previously described. In this example, the 3D graphics image includes a cube. In accordance with one aspect, the information displayed on display device 201 includes a representation or simulation of the information displayed on graphics device 202 for debugging and testing purposes.

グラフィックス命令エリア208は、グラフィックス・デバイス200から受信された1又は複数のグラフィックス命令のビジュアル表現を含む。前に説明されたように、そのような命令のビジュアル表現は、そのような命令の表現を含んでも良い。例えば、グラフィックス・デバイス200がバイナリのグラフィックス命令を送信するならば、表示デバイス201は、他の形(例えば、よりハイレベルなアプリケーション・プログラミング・インタフェース(API)命令(例えば、OpenGL命令))で、そのようなバイナリ命令の表現を表示しても良い。マッピング情報(例えば、図1に示されるマッピング情報31)は、受信されたバイナリ命令を、グラフィックス命令エリア208NAIに表示され得る他のフォーマットにマッピングするために、使用されても良い。   Graphics instruction area 208 includes a visual representation of one or more graphics instructions received from graphics device 200. As explained previously, the visual representation of such instructions may include a representation of such instructions. For example, if graphics device 200 sends binary graphics instructions, display device 201 may take other forms (eg, higher level application programming interface (API) instructions (eg, OpenGL instructions)). Such a binary instruction representation may be displayed. Mapping information (eg, mapping information 31 shown in FIG. 1) may be used to map received binary instructions to other formats that may be displayed in graphics instruction area 208 NAI.

ステート/パフォーマンス情報エリア214は、グラフィックス・デバイス200から受信されたステート及び/又はパフォーマンス情報のビジュアル表現を含む。受信されたグラフィックス命令及びステート/パフォーマンス情報は、表示エリア内に3Dグラフィックス・イメージ210を表示するために使用されても良い。一つの態様において、グラフィックス・デバイス200は、様々なステート及び/又はパフォーマンス・データを提供するために、ステート/パフォーマンス・データ・モジュール(例えば、図4に示されるステート/パフォーマンス・データ・モジュール116)を実装するグラフィックス・ドライバーを利用しても良い。受信されたステート/パフォーマンス情報は、グラフィックス・データ(例えば、プリミティブ・データ及び/又はラスタライズされたデータ)を含んでも良い。   State / performance information area 214 includes a visual representation of state and / or performance information received from graphics device 200. The received graphics instructions and state / performance information may be used to display the 3D graphics image 210 in the display area. In one aspect, graphics device 200 may provide a state / performance data module (eg, state / performance data module 116 shown in FIG. 4) to provide various state and / or performance data. ) May be used. The received state / performance information may include graphics data (eg, primitive data and / or rasterized data).

ウインドウ203又は、1又は複数のセレクター212A〜212Nを含む。ユーザは、これらのセレクター212A〜212Nの任意のものを選択しても良い。各々のセレクター212A〜212Nは、下で更に詳細に説明されるように、異なる機能(例えば統計及びナビゲーション機能)に関連し得る。ウインドウ203は、セレクター216A〜216N及び218A〜218Nを更に含む。そして、それぞれは、ユーザにより選択されても良い。各々のセレクター216A〜216N及び218A〜218Nはまた、図10を参照して下で更に詳細に説明されるように、異なる機能(例えば、メトリック機能、、オーバーライド機能及び/又はテクスチャー機能)に関連し得る。   The window 203 or one or a plurality of selectors 212A to 212N is included. The user may select any of these selectors 212A to 212N. Each selector 212A-212N may be associated with a different function (eg, statistics and navigation functions), as described in more detail below. Window 203 further includes selectors 216A-216N and 218A-218N. And each may be selected by the user. Each selector 216A-216N and 218A-218N is also associated with a different function (eg, a metric function, an override function and / or a texture function), as described in more detail below with reference to FIG. obtain.

ユーザ(例えばアプリケーション開発者)は、ウインドウ203内に表示される情報を変更しても良い。例えば、ユーザは、グラフィックス命令エリア208内に表示される命令のうちの1又は複数、又は、ステート/パフォーマンス情報エリア214内のステート/パフォーマンス情報の任意のものを修正しても良い。   A user (for example, an application developer) may change information displayed in the window 203. For example, the user may modify one or more of the instructions displayed in the graphics instruction area 208 or any of the state / performance information in the state / performance information area 214.

ウインドウ203内でユーザにより開始される任意の変更は、それから、要求された修正としてグラフィックス・デバイス200へ送信されても良い。グラフィックス・デバイス200は、それから、これらの修正を処理しても良く、また、それからグラフィックス命令エリア208及び/又はステート/パフォーマンス情報エリア214内に表示され得る更新された命令及び/又は情報を提供しても良い。更新された命令及び/又は情報はまた、表示エリア211内に3Dグラフィックス・イメージ210の修正版を表示するために使用されても良い。   Any changes initiated by the user within the window 203 may then be sent to the graphics device 200 as a requested modification. Graphics device 200 may then process these modifications and may then display updated instructions and / or information that may be displayed in graphics instruction area 208 and / or state / performance information area 214. May be provided. The updated instructions and / or information may also be used to display a modified version of the 3D graphics image 210 in the display area 211.

一つの態様において、エリア214内に表示され得るステート及び/又はパフォーマンス情報は、グラフィックス・デバイス200上でのグラフィックス命令の実行の間、潜在的なボトルネックを識別するために、表示デバイス201(例えば、図1に示されるアプリケーション・コンピュータ・デバイス20)を含むコンピュータ・デバイスにより解析されても良い。最終的に、ユーザ(例えばアプリケーション開発者)は、グラフィックス・デバイス200上でのグラフィックス命令の実行を最適化するために、デバッギング・プロセスの間に、ウインドウ203中に提示される情報の閲覧を望む場合がある。前に説明されたように、ボトルネックは、グラフィックス・デバイス200中のグラフィックス処理パイプライン内のどこにでも、もたらされる可能性があり、アプリケーション開発者がパフォーマンス最適化のためにそのようなボトルネックを分離することは難しい場合がある。ステート及び/又はパフォーマンス情報の解析を通して、潜在的なボトルネック及び考えられる回避方法は、ウインドウ203中に、例えば1又は複数のサブウインドウ又はポップアップウインドウ内に、又は、ウインドウ203のエリア214内に、表示されることができる。   In one aspect, state and / or performance information that may be displayed in area 214 may be displayed on display device 201 to identify potential bottlenecks during execution of graphics instructions on graphics device 200. It may be analyzed by a computer device including (for example, the application computer device 20 shown in FIG. 1). Finally, a user (eg, an application developer) can view information presented in window 203 during the debugging process to optimize the execution of graphics instructions on graphics device 200. May want. As previously described, bottlenecks can be introduced anywhere in the graphics processing pipeline in graphics device 200, and such bottles can be used by application developers to optimize performance. It may be difficult to separate the necks. Through analysis of state and / or performance information, potential bottlenecks and possible workarounds can be found in window 203, for example in one or more subwindows or pop-up windows, or in area 214 of window 203. Can be displayed.

一つの態様において、ウインドウ203は、グラフィックス・デバイス200から受信されるグラフィックス命令のコール・ストリームにおいて発生されるボトルネックに関するレポートを表示しても良く、さらに、考えられる回避方法を表示しても良い。場合によっては、これらの考えられる回避方法は、“仮定の(what-if)”シナリオとしてユーザへ提示されても良い。例えば、コール・ストリームにおける最適化されていない三角形のリストのレンダリングが、第1の可能性があるシナリオとして提示されても良く、一方、三角形−細片の最適化フレームワーク(triangle-strip optimization framework)を通してリストアップする前処理が、第2の可能性があるシナリオとして提示されても良い。ユーザは、これらの可能性がある回避方法シナリオの任意のものを要求された修正として選択しても良く、そして、要求された修正は、それから、グラフィックス・デバイス200へ送信される(そこでパフォーマンスが測定されても良い)。グラフィックス・デバイス200は、それから、更新された命令/情報を送信する。そして、それは、グラフィックス命令エリア208及び/又はステート/パフォーマンス情報エリア214内に提示されても良い。ユーザは、それから、その結果を閲覧することができ、そして、最適の解決を識別するために、様々な異なる潜在的な回避方法に関する結果を比較することができる。ユーザは、それらのアプリケーションからボトルネックを取り除くために、取ることができる一連のステップを速く識別するために、このプロセスを使用することができる。   In one aspect, the window 203 may display a report regarding bottlenecks that occur in the call stream of graphics instructions received from the graphics device 200, and further display possible workarounds. Also good. In some cases, these possible workarounds may be presented to the user as a “what-if” scenario. For example, rendering a list of unoptimized triangles in a call stream may be presented as a first possible scenario, while a triangle-strip optimization framework The pre-processing listed through) may be presented as a second possible scenario. The user may select any of these possible workaround scenarios as a requested fix, and the requested fix is then sent to the graphics device 200 (where performance May be measured). Graphics device 200 then sends updated instructions / information. It may then be presented in graphics instruction area 208 and / or state / performance information area 214. The user can then view the results and compare the results for a variety of different potential workarounds to identify the optimal solution. Users can use this process to quickly identify a series of steps that can be taken to remove bottlenecks from their applications.

ユーザは、実験又は試行/エラー・デバッギングの目的のために、ウインドウ203内での調整を行うことを繰り返し継続しても良い。ユーザは、表示エリア211内に表示されるイメージ又はシーンの変化を識別するために、グラフィックス命令及びステート/パフォーマンス情報の様々な異なる形又は組み合せで実験しても良い。ユーザは、グラフィックス・デバイス200上でソース・コードの再コンパイル及びコンパイルされたコードの再実行の必要なしに、グラフィックス命令(それはコール・ストリームの一部であっても良い)及びグラフィックス・デバイス200により提供されるステートをインタラクティブに閲覧及び修正するために、ウインドウ203の内容により提供されるシミュレーション環境を使用することができる。   The user may continue to make adjustments in the window 203 repeatedly for experimental or trial / error debugging purposes. The user may experiment with various different forms or combinations of graphics instructions and state / performance information to identify changes in the image or scene displayed in the display area 211. The user can add graphics instructions (which may be part of the call stream) and graphics without the need to recompile the source code and re-execute the compiled code on the graphics device 200. The simulation environment provided by the contents of window 203 can be used to interactively view and modify the state provided by device 200.

場合によっては、ユーザは、グラフィックス・イメージ210の斜視図を修正するために、グラフィカル・ナビゲーション・コントローラ(例えば、グラフィカル・カメラ)を操作するために、ボタン212A〜212Nのうちの1又は複数を操作しても良い。そのような操作は、それから元のグラフィックス・デバイス200へ送信される要求された修正として捕捉されても良い。グラフィックス・デバイス200により提供される更新された命令/情報は、それから、グラフィックス・イメージ210の斜視図を修正するために使用される。   In some cases, the user presses one or more of buttons 212A-212N to operate a graphical navigation controller (eg, a graphical camera) to modify the perspective view of graphics image 210. You may operate. Such an operation may then be captured as a requested modification that is sent to the original graphics device 200. The updated instructions / information provided by the graphics device 200 is then used to modify the perspective view of the graphics image 210.

場合によっては、様々なテクスチャー及び/又はステート情報は、修正可能な実体としてウインドウ203のエリア214中に提供されても良い。さらに、グラフィックス命令エリア208内の1又は複数の対応する命令が識別されるように、ユーザは、例えば、表示エリア211内のグラフィックス・イメージ210のピクセルの選択さえ行っても良い。この方法において、ユーザは、そのピクセル又はグラフィックス・イメージ210の他の部分をレンダリングするために使用されたレンダリング命令又はコールに後退して効果的にドリル(drill)することができる。正確にそれがグラフィックス・デバイス200上で提示されているときに、グラフィックス・デバイス201がウインドウ203中でイメージ210を再作成する可能性があるので、ユーザは、それらのアプリケーション(それはグラフィックス命令エリア208中に表示される様々なグラフィックス命令に基づいても良い)におけるイッシューを速く分離させ、新たな影響をプロトタイピングするために、ステート/パフォーマンス・エリア214内の任意のステートを修正することができる。   In some cases, various texture and / or state information may be provided in area 214 of window 203 as a modifiable entity. Furthermore, the user may even select, for example, a pixel of the graphics image 210 in the display area 211 so that one or more corresponding instructions in the graphics instruction area 208 are identified. In this manner, the user can effectively drill back to the rendering instructions or calls used to render that pixel or other portion of the graphics image 210. Because the graphics device 201 may recreate the image 210 in the window 203 when it is being presented exactly on the graphics device 200, the user can use those applications (which are graphics Modify any state in the state / performance area 214 to quickly separate issues and prototyping new effects (which may be based on various graphics instructions displayed in the instruction area 208). be able to.

一つの態様において、表示デバイス201はまた、複数のパーティションにわたり得るポリゴン・データだけでなく、パーティショニング情報を表示することができる。例えば、アプリケーション開発者は、表示デバイス201に、イメージ210をオーバーレイさせ、そして、表示エリア211中のシーンをグラフィカルに分割するパーティション(例えば、長方形の形のパーティション)のグラフィカル表現を表示させるために、ボタン(例えば、ボタン212A〜212Nのうちの1つ)を選択しても良い。場合によっては、デバイス200がグラフィックス・デバイス2の一部であるとき、表示されたパーティションは、受信されたマッピング/パーティショニング情報33(図1)に基づいても良い。表示デバイス201を含むデバイスはまた、グラフィックス・データのいずれの部分が該パーティションのうちの複数のものに関連するかについて判定するために、グラフィックス・イメージ210のためのグラフィックス・データ(例えば、ポリゴン・データ)を解析しても良い。例えば、複数のポリゴンがグラフィックス・イメージ210をレンダリングするために使用されるならば、デバイスは、これらのポリゴンのいずれが複数のパーティションにわたるかについて判定するためにポリゴンを解析しても良い。   In one aspect, the display device 201 can also display partitioning information as well as polygon data that may span multiple partitions. For example, the application developer may cause display device 201 to overlay image 210 and display a graphical representation of a partition (eg, a rectangular shaped partition) that graphically divides the scene in display area 211. A button (eg, one of buttons 212A-212N) may be selected. In some cases, when device 200 is part of graphics device 2, the displayed partition may be based on received mapping / partitioning information 33 (FIG. 1). Devices including display device 201 may also include graphics data (eg, for graphics image 210) to determine which portions of graphics data are associated with multiple of the partitions. , Polygon data) may be analyzed. For example, if multiple polygons are used to render graphics image 210, the device may analyze the polygons to determine which of these polygons span multiple partitions.

図10は、一つの態様に従って、グラフィカル・ウインドウ220中に情報を表示する表示デバイス201に接続されるグラフィックス・デバイス200の他の例を示す概念図である。この態様において、ウインドウ220は、メトリック情報だけでなく、様々な命令情報を含む。   FIG. 10 is a conceptual diagram illustrating another example of a graphics device 200 connected to a display device 201 that displays information in a graphical window 220 according to one aspect. In this aspect, the window 220 includes various instruction information as well as metric information.

例えば、グラフィックス命令エリア208内に、様々なグラフィックス命令242が示される。グラフィックス命令242は、グラフィックス・デバイス200により提供されるグラフィックス命令のサブセットであっても良い。例えば、グラフィックス・デバイス200がグラフィックス・デバイス2の一部であるならば、グラフィックス命令242はグラフィックス命令30のサブセットであっても良い。場合によっては、マッピング情報(例えば、図1に示されるマッピング情報31)は、グラフィックス・デバイス200から受信される到来命令(incoming instructions)を、グラフィックス命令エリア208内に表示される命令242として実体化される、これらの命令のビジュアル表現にマッピングするために使用されても良い。例えば、受信された命令がバイナリ形式であるならば、命令242はバイナリ形式の命令を生成するために使用されたAPI命令を含んでも良い。   For example, various graphics instructions 242 are shown in the graphics instruction area 208. Graphics instructions 242 may be a subset of graphics instructions provided by graphics device 200. For example, if graphics device 200 is part of graphics device 2, graphics instructions 242 may be a subset of graphics instructions 30. In some cases, the mapping information (e.g., mapping information 31 shown in FIG. 1) may cause incoming instructions received from graphics device 200 as instructions 242 displayed in graphics instruction area 208. It may be used to map to visual representations of these instructions that are materialized. For example, if the received instruction is in binary format, the instruction 242 may include an API instruction that was used to generate the binary instruction.

図10の例に示されるように、グラフィックス命令242は、ハイレベル命令及びローレベル命令の両方を含む。ユーザ(例えばアプリケーション開発者)は、命令242のフルセットを閲覧するために、スクロールバー244を使用しても良い。特定のハイレベル命令は、1又は複数のローレベル命令(例えば、より低いレベルのAPI命令)を含んでも良い。アプリケーション開発者は、場合によっては、関連するハイレベル命令の一部である又は関連するハイレベル命令により実行される、任意のローレベル命令を閲覧するために、特定のハイレベル命令の上で(例えば、クリックすることなどによって)選択しても良い。前に説明されたように、受信されたグラフィックス命令(例えば命令242)は、グラフィックス・イメージ202の表現を生成するために使用される。そして、それは、ウインドウ220の表示エリア211中に示されるグラフィックス・イメージ210を含む。   As shown in the example of FIG. 10, graphics instruction 242 includes both a high level instruction and a low level instruction. A user (eg, an application developer) may use scroll bar 244 to view the full set of instructions 242. Certain high level instructions may include one or more low level instructions (eg, lower level API instructions). An application developer may optionally be on a particular high-level instruction to view any low-level instruction that is part of or executed by the associated high-level instruction ( (E.g., by clicking). As previously described, received graphics instructions (eg, instructions 242) are used to generate a representation of graphics image 202. It then includes a graphics image 210 shown in the display area 211 of the window 220.

様々な選択ボタンは、図10中のステート/パフォーマンス情報エリア214の下に示される。これらの選択ボタンは、テクスチャー・ボタン236、オーバーライド・ボタン238及びメトリック・ボタン240を含む。図10の例において、アプリケーション開発者は、メトリック・ボタン240を選択した。このボタンの選択に応じて、様々なメトリック・オプションが示されても良い。例えば、1又は複数のメトリック・ボタン234A〜234Nが、ステート/パフォーマンス・エリア214より上に示されても良い。各々のメトリック・ボタン234A〜234Nは、特定のメトリックに関連しても良い。場合によっては、これらのメトリックのうちの1又は複数は予め定義又は予め構成されたメトリック・タイプであっても良く、また、場合によっては、アプリケーション開発者が、メトリックのうちの1又は複数を選択又はカスタマイズしても良い。例示的なメトリックは、例えば、以下のうちの任意の1又は複数を含んでも良い:フレーム毎秒、%ビジー(1又は複数のプロセッサについて)、バス・ビジー、メモリ・ビジー、頂点ビジー、頂点毎秒、三角形毎秒、ピクセル・クロック毎秒、フラグメント毎秒、その他。アプリケーション開発者は、選択されたメトリックに関して更なる詳細を閲覧するために、メトリック・ボタン234A〜234Nのうちの任意のものを選択しても良い。   Various selection buttons are shown below the state / performance information area 214 in FIG. These selection buttons include a texture button 236, an override button 238 and a metric button 240. In the example of FIG. 10, the application developer has selected the metric button 240. Depending on the selection of this button, various metric options may be presented. For example, one or more metric buttons 234A-234N may be shown above the state / performance area 214. Each metric button 234A-234N may be associated with a particular metric. In some cases, one or more of these metrics may be a predefined or pre-configured metric type, and in some cases, the application developer selects one or more of the metrics. Or you may customize. Exemplary metrics may include, for example, any one or more of the following: frames per second,% busy (for one or more processors), bus busy, memory busy, vertex busy, vertex per second, Triangle per second, pixel clock per second, fragment per second, etc. The application developer may select any of the metric buttons 234A-234N to view further details regarding the selected metric.

例えば、メトリック・ボタン234Aがフレーム毎秒の数に関連するならば、アプリケーション開発者は、グラフィックス・イメージ210について(パフォーマンスに関係する)フレーム毎秒の数に関する更なる詳細を閲覧するために、メトリック・ボタン234Aを選択しても良く、又は、グラフィックス・イメージ210の部分を選択しても良い。開発者は、場合によっては、メトリック・ボタン234Aを選択しても良く、または、メトリック・ボタン234Aをステート/パフォーマンス情報エリア214にドラッグしても良い。フレーム毎秒の数に関する詳細な情報は、ステート/パフォーマンス情報エリア214内に表示されても良い。開発者はまた、メトリック・ボタン234Aを表示エリア211にドラッグしても良く、又は、メトリック・ボタン234Aのアプリケーションのためのグラフィックス・イメージ210の部分を選択しても良い。例えば、開発者は、メトリック・ボタン234Aの選択の後にグラフィックス・イメージ210の部分を選択しても良く、そして、その選択された部分に対するフレーム毎秒の数に関する詳細な情報が、ステート/パフォーマンス情報エリア214内に表示されても良い。そのような方法において、開発者は、メトリック・ボタン234A〜234Nのうちの1又は複数の選択に基づいて、そして、グラフィックス・イメージ210(又はその部分)の可能性がある選択にさえ基づいて、任意の数の異なるメトリック・タイプのためのパフォーマンス・データを閲覧しても良い。   For example, if the metric button 234A is related to the number of frames per second, the application developer can view the metrics image 210 to see further details regarding the number of frames per second (related to performance). Button 234A may be selected, or a portion of graphics image 210 may be selected. The developer may select the metric button 234A or drag the metric button 234A to the state / performance information area 214 as the case may be. Detailed information regarding the number of frames per second may be displayed in the state / performance information area 214. The developer may also drag the metric button 234A to the display area 211 or select a portion of the graphics image 210 for the application of the metric button 234A. For example, the developer may select a portion of graphics image 210 after selection of metric button 234A, and detailed information regarding the number of frames per second for that selected portion is state / performance information. It may be displayed in the area 214. In such a method, the developer may be based on a selection of one or more of the metric buttons 234A-234N and even based on a possible selection of the graphics image 210 (or portion thereof). The performance data for any number of different metric types may be viewed.

一つの態様において、ウインドウ220内に表示され得るメトリック・データは、グラフィックス・デバイス200のグラフィックス・ドライバー(例えば、図4に示されるグラフィックス・ドライバー18)により提供されても良い。このグラフィックス・ドライバーは、それからウインドウ220内にメトリック・データとして表示され得る様々なデータを提供するために、ハードウェア・カウンタ・モジュール(例えば、図4のハードウェア・カウンタ・モジュール114)及び/又はプロセッサ使用モジュール(例えば、図4のプロセッサ使用モジュール112)を実装しても良い。   In one aspect, the metric data that may be displayed in the window 220 may be provided by the graphics driver of the graphics device 200 (eg, the graphics driver 18 shown in FIG. 4). The graphics driver then provides a hardware counter module (eg, hardware counter module 114 of FIG. 4) and / or to provide various data that can be displayed as metric data in window 220. Alternatively, a processor use module (for example, the processor use module 112 in FIG. 4) may be mounted.

開発者はまた、場合によっては、テクスチャー・ボタン236を選択しても良い。選択に応じて、グラフィックス・イメージ210に関係する様々な形のテクスチャー情報が、グラフィックス・デバイス201により表示されても良い。例えば、テクスチャー情報は、ウインドウ220内に(例えばステート/パフォーマンス情報エリア214内などに)表示されても良い。場合によっては、テクスチャー情報は、更なる(例えば、ポップアップ)ウインドウ(図示せず)内に表示されても良い。開発者は、表示されたテクスチャー情報を閲覧しても良いが、また、場合によっては、テクスチャー情報を修正しても良い。これらの場合、テクスチャー情報に対する任意の修正が、要求された修正として、グラフィックス・デバイス200へ伝播されても良い。グラフィックス・デバイス200からの更新された命令/情報の受信に応じて、グラフィックス・イメージ210に対する変更が、表示エリア211内に表示されても良い。図11は、テクスチャー・ボタン236の選択に応じて表示され得る特定のテクスチャー情報を含む。   The developer may also select the texture button 236 in some cases. Depending on the selection, various forms of texture information related to the graphics image 210 may be displayed by the graphics device 201. For example, the texture information may be displayed in the window 220 (eg, in the state / performance information area 214). In some cases, the texture information may be displayed in a further (eg, pop-up) window (not shown). The developer may browse the displayed texture information, but may correct the texture information in some cases. In these cases, any modification to the texture information may be propagated to the graphics device 200 as the requested modification. Changes to the graphics image 210 may be displayed in the display area 211 in response to receiving updated instructions / information from the graphics device 200. FIG. 11 includes specific texture information that may be displayed in response to selection of the texture button 236.

開発者はまた、場合によっては、オーバーライド・ボタン238を選択しても良い。オーバーライド・ボタン238の選択の後、特定の情報(命令及び/又はステート)が、(例えば、ウインドウ220又は他のウインドウ内に)表示されても良い。そして、それは、開発者によって、修正又はオーバーライドされても良い。任意の修正又はオーバーライドは、グラフィックス・デバイス200に送信される1又は複数の要求された修正の中に含まれても良い。一つの態様において、グラフィックス・デバイス200は、任意の要求された修正を処理するために、グラフィックス・ドライバー(例えばグラフィックス・ドライバー18A(図4))を実装しても良い。例えば、グラフィックス・デバイス200は、1又は複数のオーバーライドを含むそのような要求された修正を処理するために、オーバーライド・モジュール120を使用しても良い。   The developer may also select an override button 238 in some cases. After selection of the override button 238, specific information (command and / or state) may be displayed (eg, in window 220 or other window). It may then be modified or overridden by the developer. Any modifications or overrides may be included in one or more requested modifications sent to the graphics device 200. In one aspect, graphics device 200 may implement a graphics driver (eg, graphics driver 18A (FIG. 4)) to handle any required modifications. For example, graphics device 200 may use override module 120 to handle such requested modifications that include one or more overrides.

場合によっては、開発者は、グラフィックス命令エリア208内に示されるグラフィックス命令242上の1又は複数をオーバーライドしても良い。これらの場合、開発者は、グラフィックス命令242のうちの1又は複数を修正又はオーバーライドするために、グラフィックス命令エリア208内に情報をタイプ又は入力しても良い。これらの修正は、それから、グラフィックス・デバイス200に送信されても良い。そして、それは、表示エリア211内のグラフィックス・イメージ210の表示を更新するために、更新された命令/情報を提供するであろう。開発者は、命令242により提供される1又は複数の機能をオーバーライドするために、例えば、グラフィックス命令242のパラメータ、順序付け、タイプなどを変更しても良い。一つの態様において、マッピング情報31(図1)は、それから、グラフィックス命令242に対する変更を、グラフィックス・デバイス200に提供され得る他のフォーマット(例えば、バイナリ命令)の対応する命令に、マッピング又は変換するために使用されても良い。   In some cases, the developer may override one or more of the graphics instructions 242 shown in the graphics instruction area 208. In these cases, the developer may type or enter information in the graphics instruction area 208 to modify or override one or more of the graphics instructions 242. These modifications may then be sent to the graphics device 200. It will then provide updated instructions / information to update the display of graphics image 210 in display area 211. The developer may change, for example, the parameters, ordering, type, etc. of the graphics instruction 242 to override one or more functions provided by the instruction 242. In one aspect, the mapping information 31 (FIG. 1) may then map changes to the graphics instructions 242 to corresponding instructions in other formats (eg, binary instructions) that may be provided to the graphics device 200. It may be used to convert.

場合によっては、開発者はまた、グラフィックス・デバイス200により実装される処理パイプラインに関連する1又は複数の機能をオーバーライドするオーバーライド・ボタン238を選択しても良い。図12は、オーバーライド・ボタン238の選択に応じて、開発者に対して表示され得るオーバーライド・スクリーンの例を表す。   In some cases, the developer may also select an override button 238 that overrides one or more functions associated with the processing pipeline implemented by the graphics device 200. FIG. 12 illustrates an example of an override screen that may be displayed to the developer in response to selection of the override button 238.

ウインドウ220は、選択ボタン231及び232を更に含む。選択ボタン231は、パーティション・ボタンであり、選択ボタン232は、ナビゲーション・ボタンである。開発者は、グラフィックス・イメージ210をオーバーレイし、そして、表示エリア211中に表示されるシーンをグラフィカルに分割するパーティション(例えば長方形の形のパーティション)のグラフィカル表現を閲覧するためのパーティション・ボタン231を選択しても良い。パーティション・ボタン231のユーザ選択に応じて、グラフィカル・パーティションが、表示エリア211中に表示されても良い。   Window 220 further includes selection buttons 231 and 232. The selection button 231 is a partition button, and the selection button 232 is a navigation button. The developer overlays graphics image 210 and partitions button 231 for viewing a graphical representation of a partition (eg, a rectangular shaped partition) that graphically divides the scene displayed in display area 211. May be selected. Depending on the user selection of the partition button 231, a graphical partition may be displayed in the display area 211.

表示エリア211、又は独立した表示エリア又はウインドウはまた、データのいずれの部分が複数のパーティションに関連するかについて判定するグラフィックス・イメージ210のためのグラフィックス・データの解析に基づいて、情報を表示しても良い。例えば、表示エリア211、又は独立した表示エリア又はウインドウは、パーティションのグラフィカル表現とともに、いずれのポリゴン(それはグラフィックス・イメージ210をレンダリングするために使用される)が複数のパーティションにわたるかについて、表示しても良い。場合によっては、グラフィカル・インジケーション(例えば色)が、複数のパーティションにわたるポリゴン(例えば、三角形)ごとに表示されても良い。   Display area 211, or a separate display area or window, also provides information based on the analysis of graphics data for graphics image 210 that determines which portions of the data are associated with multiple partitions. It may be displayed. For example, display area 211, or a separate display area or window, displays a graphical representation of the partition, as well as which polygon (which is used to render graphics image 210) spans multiple partitions. May be. In some cases, a graphical indication (eg, color) may be displayed for each polygon (eg, triangle) across multiple partitions.

例えば、一つの態様において、“ヒートマップ(heat map)”が表示されても良い。ここで、各々の三角形は特定の色で表示される。複数のパーティションにわたらない三角形は、第1の色(例えば、青)で表示されても良い。複数のパーティション(例えば、2〜3のパーティション)にわたる三角形は、第2の色(例えば、紫)で表示されても良い。3を超えるパーティションにわたる三角形は、第3の色(例えば、赤)で顕著に表示されても良い。このように、この例では、アプリケーション開発者は、いずれの三角形が複数のパーティションにわたるか、及び、いずれの三角形が他より多くのパーティションにわたるかについて、速く判定することができる。開発者は、グラフィックス・イメージ210を生成するときのパフォーマンス(例えば、レンダリング)オーバーヘッドを低減するために、複数のパーティションにわたる三角形を再構成、再定義又はさもなければ再構成する方法について判定するために、この情報を使用することができ得る。   For example, in one embodiment, a “heat map” may be displayed. Here, each triangle is displayed in a specific color. Triangles that do not span multiple partitions may be displayed in a first color (eg, blue). Triangles that span multiple partitions (eg, 2-3 partitions) may be displayed in a second color (eg, purple). Triangles that span more than three partitions may be displayed prominently in a third color (eg, red). Thus, in this example, the application developer can quickly determine which triangles span multiple partitions and which triangles span more partitions than others. To determine how to reconstruct, redefine, or otherwise reconstruct triangles across multiple partitions to reduce performance (eg, rendering) overhead when generating graphics image 210 In the meantime, this information can be used.

開発者はまた、表示エリア211内でナビゲートするために、そして、表示エリア211内のグラフィックス・イメージ210の斜視図の変更さえ可能にする、ナビゲーション・ボタン232を選択しても良い。例えば、ナビゲーション・ボタン232の選択に応じて、3Dグラフィカル・カメラ又はナビゲーション・コントローラが、表示されても良い。開発者は、表示エリア211内の任意のエリアに対してナビゲートするために、コントローラとインタラクトしても良い。開発者はまた、グラフィックス・イメージ210の斜視図を(例えばグラフィックス・イメージ210の回転又はズームイン/ズームアウトなどによって)変更するために、コントローラを使用しても良い。   The developer may also select a navigation button 232 to navigate within the display area 211 and even allow the perspective view of the graphics image 210 within the display area 211 to be changed. For example, in response to selection of the navigation button 232, a 3D graphical camera or navigation controller may be displayed. The developer may interact with the controller to navigate to any area within the display area 211. Developers may also use the controller to change the perspective view of the graphics image 210 (eg, by rotating the graphics image 210 or zooming in / out, etc.).

一つの態様において、ナビゲーション・ボタン232の選択を通した任意の開発者起動(developer-initiated)の変更及びグラフィカル・ナビゲーション・コントローラに対するインタラクションは、要求された修正(例えば、図1に示される要求された修正84の一部)として、グラフィックス・デバイス200へ伝播されても良い。それからグラフィックス・デバイス200により提供される更新された命令/情報は、それから、グラフィックス・イメージ210の表示(例えば、斜視図)を更新するために使用されても良い。さらに、更新された命令は、グラフィックス命令エリア208内に表示されても良い。更新されたステート/パフォーマンス情報は、ステート/パフォーマンス情報エリア214内に表示されても良い。   In one aspect, any developer-initiated change through the selection of the navigation button 232 and interaction with the graphical navigation controller may be requested modification (eg, as shown in FIG. 1). As part of the modification 84) may be propagated to the graphics device 200. The updated instructions / information provided by the graphics device 200 may then be used to update the display (eg, perspective view) of the graphics image 210. Further, the updated instruction may be displayed in the graphics instruction area 208. The updated state / performance information may be displayed in the state / performance information area 214.

一つの態様において、グラフィカル・パーティションが、グラフィックス・イメージ210の修正された斜視図の上に表示又はオーバーレイされても良い。さらに、グラフィックス・イメージ210の修正された斜視図のための更新された命令/情報の中に含まれるグラフィックス・データは、データのいずれの部分が複数のパーティションに関連するかについて判定するために解析されても良い。   In one aspect, the graphical partition may be displayed or overlaid on the modified perspective view of the graphics image 210. Further, the graphics data included in the updated instructions / information for the modified perspective view of the graphics image 210 is to determine which portion of the data is associated with multiple partitions. May be analyzed.

その結果、開発者は、グラフィックス・イメージ210をレンダリング又は表示するための代わりの展望、方針、ビュー、その他が、グラフィックス・デバイス200のパフォーマンス及びステートにどのように影響を及ぼし得るかについて効果的且つ効率的に判定し得る。これは、表示デバイス201上に表示されたシミュレーション環境においてグラフィックス・イメージ210及び効果的にグラフィックス・デバイス200上に表示されるグラフィックス・イメージ202を作成及びレンダリングするために使用されるグラフィックス命令242を最適化する際に、開発者にとって非常に有用であり得る。一つの態様において、ウインドウ220内の開発者起動の選択及び制御に基づくグラフィックス・イメージ210の位置、奥行き、方向、その他の任意の変更はまた、テスティング・プロセスの間にグラフィックス・デバイス200に表示され得るグラフィックス・イメージ202のための変更とみなされても良い。   As a result, the developer has an effect on how alternative perspectives, policies, views, etc. for rendering or displaying the graphics image 210 can affect the performance and state of the graphics device 200. Can be determined efficiently and efficiently. This is the graphics used to create and render the graphics image 210 and the graphics image 202 that is effectively displayed on the graphics device 200 in the simulation environment displayed on the display device 201. It can be very useful for developers in optimizing instructions 242. In one aspect, the position, depth, orientation, and any other changes of the graphics image 210 based on developer-initiated selection and control within the window 220 are also changed during the testing process. May be considered a change for the graphics image 202 that may be displayed.

グラフィカル・ユーザ・インタフェース内のグラフィカル・ウインドウ220とのインタラクションを通して、アプリケーション開発者は、グラフィックス命令242の実行の間、パフォーマンス・イッシュー及び/又はボトルネックを識別しようとすることができる。そして、それは、グラフィックス・イメージ202を作成するために、グラフィックス・デバイス200により実行されるグラフィックス命令のビジュアル表現である。グラフィックス・イメージ202(すなわち、グラフィックス・イメージ210)の表現は、グラフィックス・デバイス200により受信されるグラフィックス命令242及びステート/パフォーマンス・データに基づいて、表示エリア211内に表示される。グラフィックス命令242、グラフィックス・イメージ210及びステート/パフォーマンス情報と、これらのうちの1又は複数に対するユーザ起動(user-initiated)の修正に基づく影響とを閲覧することによって、アプリケーション開発者は、グラフィックス・デバイス200上での命令の実行を最適化するための、そして、命令実行の間の任意のパフォーマンス・イッシュー(例えば、ボトルネック)を除去又は軽減するためのプロセスを、試行錯誤又はデバッギングすることに、インタラクティブに動的に従事することができる。   Through interaction with the graphical window 220 in the graphical user interface, the application developer can attempt to identify performance issues and / or bottlenecks during execution of the graphics instructions 242. It is then a visual representation of the graphics instructions that are executed by the graphics device 200 to create the graphics image 202. A representation of graphics image 202 (ie, graphics image 210) is displayed in display area 211 based on graphics instructions 242 and state / performance data received by graphics device 200. By viewing graphics instructions 242, graphics image 210 and state / performance information and the impact based on user-initiated modifications to one or more of these, application developers can Trial and error debugging processes for optimizing instruction execution on the device 200 and for eliminating or mitigating any performance issues (eg, bottlenecks) during instruction execution In particular, you can engage interactively and dynamically.

さらに、幾つかの異なるグラフィカル・パーティションを含むグラフィカル・シーンの視覚の表現は、開発者が、スクリーン・パーティションに関連し得るコストに起因する低下したパフォーマンスを示すグラフィカル・シーンの部分を識別することができるようにしても良い。開発者は、これらのコスト及び/又は関係するパフォーマンス・オーバーヘッドを低減するのは支援するために、シーンの代わりのコンポジションを調査するために、パーティション及び関連する解析情報をレビューしても良い。   In addition, a visual representation of a graphical scene that includes several different graphical partitions allows developers to identify portions of the graphical scene that exhibit degraded performance due to the costs that can be associated with screen partitions. You may be able to do it. Developers may review partitions and associated analysis information to investigate alternative compositions of the scene to help reduce these costs and / or related performance overhead.

この開示において説明される技術は、汎用マイクロプロセッサ、デジタルシグナルプロセッサ(DSP)、特定用途向けIC(ASIC)、フィールド・プログラマブル・ゲート・アレイ(FPGA)又は他の均等な論理デバイスの中に実装されても良い。したがって、本明細書で使用される用語“プロセッサ(processor)”又は“コントローラ(controller)”は、本明細書で説明される技術の実装に適した前述の構造のうちの任意のもの又は他の任意の構造を指し示しても良い。   The techniques described in this disclosure are implemented in a general purpose microprocessor, digital signal processor (DSP), application specific IC (ASIC), field programmable gate array (FPGA), or other equivalent logic device. May be. Accordingly, as used herein, the term “processor” or “controller” refers to any of the previously described structures suitable for implementation of the technology described herein, or other Any structure may be indicated.

本明細書で説明される様々なコンポーネントは、ハードウェア、ソフトウェア、ファームウェアの適切な組み合わせ、又はそれらの任意の組み合わせにより実現されても良い。図において、様々なコンポーネントは、独立したユニット又はモジュールとして示される。しかし、これらの図を参照して説明される様々なコンポーネントの全て又は幾つかは、共通のハードウェア及び/又はソフトウェア内の複合のユニット又はモジュールに集積されても良い。したがって、コンポーネント、ユニット又はモジュールとしての特徴の表現は、説明を簡略化するために、特定の機能的な特徴を強調することを目的とされ、また、独立したハードウェア又はソフトウェア・コンポーネントによるそのような特徴の実現を必ずしも必要とするわけではない。場合によっては、様々なユニットは、1又は複数のプロセッサにより実行されるプログラム可能なプロセスとして実装されても良い。   The various components described herein may be implemented by any suitable combination of hardware, software, firmware, or any combination thereof. In the figure, the various components are shown as independent units or modules. However, all or some of the various components described with reference to these figures may be integrated into a complex unit or module within common hardware and / or software. Thus, the representation of features as components, units, or modules is intended to highlight specific functional features for ease of explanation, and as such by independent hardware or software components. It is not always necessary to realize such features. In some cases, the various units may be implemented as programmable processes that are executed by one or more processors.

モジュール群、デバイス群又はコンポーネント群(グラフィックス・デバイス100及び/又はその構成要素群を含む)として本明細書で説明されるいずれの機能群も、集積化された論理デバイスに一緒に又は別々であるが適時情報交換ができる(interoperable)複数の論理デバイスとして独立して実装されても良い。様々な態様において、そのようなコンポーネント群は、1又は複数の集積回路デバイスとして少なくとも部分的に形成されても良い。そして、それらは集積回路デバイス(例えば集積回路チップ又はチップセット)として集合的に指し示されても良い。そのような回路は、単一の集積回路チップ・デバイスで又は複数の適時情報交換ができる集積回路チップ・デバイスで提供されても良く、また、様々なイメージ、ディスプレイ、オーディオ又は他のマルチメディアのアプリケーション及びデバイスの任意のものにおいて使用されても良い。幾つかの態様において、例えば、そのようなコンポーネントは、モバイル・デバイス(例えば無線通信デバイス・ハンドセット)の一部を形成しても良い。   Any of the functional groups described herein as modules, devices, or components (including graphics device 100 and / or its components) may be combined together or separately in an integrated logic device. However, it may be independently implemented as a plurality of logical devices that can exchange information in a timely manner (interoperable). In various aspects, such components may be formed at least partially as one or more integrated circuit devices. They may then be collectively referred to as integrated circuit devices (eg, integrated circuit chips or chip sets). Such circuitry may be provided in a single integrated circuit chip device or in an integrated circuit chip device capable of exchanging information in a timely manner, and for various images, displays, audio or other multimedia. It may be used in any of the applications and devices. In some aspects, for example, such components may form part of a mobile device (eg, a wireless communication device handset).

ソフトウェアで実装されるならば、本技術は、1又は複数のプロセッサにより実行されるときに上で説明された方法のうちの1又は複数を実行する命令をもつコードを含むコンピュータ読み取り可能な媒体によって少なくとも部分的に実現されても良い。コンピュータ読み取り可能な媒体は、コンピュータ・プログラム製品(それはパッケージ材料を含んでもよい)の一部を形成しても良い。コンピュータ読み取り可能な媒体は、ランダムアクセスメモリ(RAM)(例えばシンクロナスダイナミックランダムアクセスメモリ(SDRAM))、リードオンリーメモリ(ROM)、不揮発性ランダムアクセスメモリ(NVRAM)、電気的消去可能PROM(EEPROM)、組み込み形ダイナミックランダムアクセスメモリ(eDRAM)、スタティックランダムアクセスメモリ(SRAM)、フラッシュメモリ、磁気又は光学データ記憶媒体を含んでも良い。   If implemented in software, the techniques may be performed by a computer-readable medium containing code having instructions that, when executed by one or more processors, perform one or more of the methods described above. It may be realized at least partially. The computer readable medium may form part of a computer program product (which may include packaging material). Computer readable media include random access memory (RAM) (eg, synchronous dynamic random access memory (SDRAM)), read only memory (ROM), non-volatile random access memory (NVRAM), electrically erasable PROM (EEPROM) Embedded dynamic random access memory (eDRAM), static random access memory (SRAM), flash memory, magnetic or optical data storage media.

加えて又は代わりに、本技術は、命令又はデータ構造の形でコードを運ぶか又は伝え且つ1又は複数のプロセッサによりアクセス、リード及び/又は実行されることができるコンピュータ読み取り可能な通信媒体に少なくとも部分的によって実現されても良い。いずれのコネクションも、コンピュータ読み取り可能な媒体と適切に呼ばれることができる。例えば、ソフトウェアが、同軸ケーブル、光ファイバーケーブル、ツイスト・ペア、デジタル加入者回線(DSL)又は無線技術(例えば、赤外線、無線及びマイクロ波)を使用するウェブサイト、サーバ又は他のリモート・ソースから送信されるならば、該同軸ケーブル、光ファイバーケーブル、ツイスト・ペア、DSL又は無線技術(例えば、赤外線、無線及び電子レンジ)は、媒体の定義に含まれる。上記の組み合せはまた、コンピュータ読み取り可能な媒体の範囲内に含まれるべきである。利用されるいずれのソフトウェアも、1又は複数のプロセッサ(例えば、1又は複数のDSP、汎用マイクロプロセッサ、複数のASIC、複数のFPGA又は他の均等な集積化された又は個別の論理回路)によって実行されても良い。   In addition or alternatively, the present technology provides at least a computer-readable communication medium that carries or conveys code in the form of instructions or data structures and that can be accessed, read and / or executed by one or more processors. It may be realized partially. Either connection can be appropriately referred to as a computer-readable medium. For example, software sends from a web site, server, or other remote source that uses coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technology (eg, infrared, wireless, and microwave) If so, the coaxial cable, fiber optic cable, twisted pair, DSL or wireless technology (eg, infrared, wireless and microwave) are included in the definition of the medium. Combinations of the above should also be included within the scope of computer-readable media. Any software utilized is executed by one or more processors (eg, one or more DSPs, general purpose microprocessors, multiple ASICs, multiple FPGAs, or other equivalent integrated or separate logic circuits). May be.

様々な態様が本明細書で説明された。これら及び他の態様は以下のクレームの範囲内である。   Various aspects have been described herein. These and other aspects are within the scope of the following claims.

様々な態様が本明細書で説明された。これら及び他の態様は以下のクレームの範囲内である
以下に、本願出願の当初の特許請求の範囲に記載された各請求項に対応する発明を付記する。
[1]グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示することと、1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示することと、前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析することを含む方法。
[2]前記1又は複数のグラフィックス・イメージの表示、複数のパーティションのグラフィカル表現の表示及び前記1又は複数のグラフィックス・イメージの前記複数のフレームに関するグラフィックス・データの解析を、繰り返し行うことを更に含む[1]の方法。
[3]前記1又は複数のグラフィックス・イメージのうちの少なくとも一つは、3次元グラフィックス・イメージを含む[1]の方法。
[4]前記複数のパーティションの前記グラフィカル表現を表示することは、前記1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割する複数の長方形の形状のパーティションのグラフィカル表現を表示することを含む[1]の方法。
[5]前記グラフィックス・データは、前記1又は複数のグラフィックス・イメージをレンダーするために使用される複数のグラフィックス・プリミティブを含む[1]の方法。
[6]前記複数のグラフィックス・プリミティブは、複数の三角形を含む[5]の方法。
[7]前記グラフィックス・データを解析することは、前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定することを含む[6]の方法。
[8]前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定することは、前記三角形のうちのいずれの三角形が少なくとも部分的に前記パーティションのうちの複数のものにおいてレンダリングされたか判定することを含む[7]の方法。
[9]前記パーティションのうちの複数のものにわたる前記三角形のグラフィカル表現を表示することを更に含む[7]の方法。
[10]前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示することは、前記パーティションの前記グラフィカル表現を表示することと共に、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示することを含む[9]の方法。
[11]前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示することは、各々の三角形に関するグラフィカル・インジケーションを表示することを含み、前記グラフィカル・インジケーションは、各々の対応する三角形によりわたられるパーティションの数のビジュアル・インジケーションを提供する[9]の方法。
[12]各々の対応する三角形に関する前記グラフィカル・インジケーションは、色を含む[11]の方法。
[13]各々の三角形に関する前記グラフィカル・インジケーションを表示することは、他の三角形より多くのパーティションにわたるそれらの三角形に関する前記グラフィカル・インジケーションを顕著に表示することを含む[11]の方法。
[14]前記複数のパーティションの前記グラフィカル表現を表示することは、外部グラフィックス・デバイスからパーティショニング情報を受信することと、前記受信されたパーティショニング情報に基づいて、前記複数のパーティションの前記グラフィカル表現を表示することを含む[1]の方法。
[15]ナビゲーション・コントローラを表示することと、前記ナビゲーション・コントローラとインタラクトするためのユーザ入力を受信することと、前記ナビゲーション・コントローラに対する前記ユーザ入力に基づいて、修正されたグラフィックス・シーン中の前記1又は複数のグラフィックス・イメージの修正された斜視図を表示することを更に含む[1]の方法。
[16]前記複数のパーティションの前記グラフィカル表現を表示することは、前記1又は複数のグラフィカル・イメージの前記修正された斜視図をオーバーレイし且つ前記修正されたシーンをグラフィカルに分割する前記複数のパーティションの前記グラフィカル表現を表示することを含み、前記グラフィックス・データを解析することは、前記グラフィックス・データのうちのいずれの部分が前記複数のパーティションのうちの前記複数のパーティションに関連するかについて判定するために、前記1又は複数のグラフィックス・イメージの前記修正された斜視図に関するグラフィックス・データを解析することを含む[15]の方法。
[17]外部グラフィックス・デバイスからグラフィックス命令を受信することと、前記外部グラフィックス・デバイスからステート情報(該ステート情報は、前記外部グラフィックス・デバイス上での前記グラフィックス命令の実行に関連する)を受信することを含み、前記グラフィカル・シーン中に前記1又は複数のグラフィックス・イメージを表示することは、前記グラフィックス命令及び前記ステート情報に基づいて、前記1又は複数のグラフィックス・イメージを表示することを含む[1]の方法。
[18]前記ステート情報は、前記1又は複数のグラフィックス・イメージに関する前記グラフィックス・データを含む[17]の方法。
[19]前記グラフィックス・データを前記グラフィックス命令にマッピングする前記外部グラフィックス・デバイスからのマッピング情報を受信することを更に含む[17]の方法。
[20]前記パーティションは、前記グラフィックス・データ上で実行されるオペレーションのレンダリングに基づいて判定される[1]の方法。
[21]1又は複数のプロセッサに、グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示させ、1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示させ、前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析させるためのコンピュータ実行可能な命令を含むコンピュータ読み取り可能な媒体。
[22]前記1又は複数のプロセッサに、前記1又は複数のグラフィックス・イメージの表示、複数のパーティションのグラフィカル表現の表示及び前記1又は複数のグラフィックス・イメージの前記複数のフレームに関するグラフィックス・データの解析を、繰り返し行わせるためのコンピュータ実行可能な命令を更に含む[21]のコンピュータ読み取り可能な媒体。
[23]前記1又は複数のグラフィックス・イメージのうちの少なくとも一つは、3次元グラフィックス・イメージを含む[21]のコンピュータ読み取り可能な媒体。
[24]前記1又は複数のプロセッサに前記複数のパーティションの前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割する複数の長方形の形状のパーティションのグラフィカル表現を表示させるためのコンピュータ実行可能な命令を含む[21]のコンピュータ読み取り可能な媒体。
[25]前記グラフィックス・データは、前記1又は複数のグラフィックス・イメージをレンダリングするために使用される複数のグラフィックス・プリミティブを含む[21]のコンピュータ読み取り可能な媒体。
[26]前記複数のグラフィックス・プリミティブは、複数の三角形を含む[25]のコンピュータ読み取り可能な媒体。
[27]前記1又は複数のプロセッサに前記グラフィックス・データを解析させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定させるためのコンピュータ実行可能な命令を含む[2]のコンピュータ読み取り可能な媒体。
[28]前記1又は複数のプロセッサに前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記三角形のうちのいずれの三角形が少なくとも部分的に前記パーティションのうちの複数のものにおいてレンダリングされたか判定させるためのコンピュータ実行可能な命令を含む[27]のコンピュータ読み取り可能な媒体。
[29]前記1又は複数のプロセッサに前記パーティションのうちの複数のものにわたる前記三角形のグラフィカル表現を表示させるための前記コンピュータ実行可能な命令を更に含む[27]のコンピュータ読み取り可能な媒体。
[30]前記1又は複数のプロセッサに前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記パーティションの前記グラフィカル表現を表示させると共に、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示させるためのコンピュータ実行可能な命令を含む[29]のコンピュータ読み取り可能な媒体。
[31]前記1又は複数のプロセッサに前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに各々の三角形に関するグラフィカル・インジケーションを表示させるためのコンピュータ実行可能な命令を含み、前記グラフィカル・インジケーションは、各々の対応する三角形によりわたられるパーティションの数のビジュアル・インジケーションを提供する[29]のコンピュータ読み取り可能な媒体。
[32]各々の対応する三角形に関する前記グラフィカル・インジケーションは、色を含む[31]のコンピュータ読み取り可能な媒体。
[33]前記1又は複数のプロセッサに各々の三角形に関する前記グラフィカル・インジケーションを表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに他の三角形より多くのパーティションにわたるそれらの三角形に関する前記グラフィカル・インジケーションを顕著に表示させるためのコンピュータ実行可能な命令を含む[31]のコンピュータ読み取り可能な媒体。
[34]前記1又は複数のプロセッサに前記複数のパーティションの前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに、外部グラフィックス・デバイスからパーティショニング情報を受信させ、前記受信されたパーティショニング情報に基づいて、前記複数のパーティションの前記グラフィカル表現を表示させるためのコンピュータ実行可能な命令を含む[21]のコンピュータ読み取り可能な媒体。
[35]前記1又は複数のプロセッサに、ナビゲーション・コントローラを表示させ、前記ナビゲーション・コントローラとインタラクトするためのユーザ入力を受信させ、前記ナビゲーション・コントローラに対する前記ユーザ入力に基づいて、修正されたグラフィックス・シーン中の前記1又は複数のグラフィックス・イメージの修正された斜視図を表示させるためのコンピュータ実行可能な命令を更に含む[21]のコンピュータ読み取り可能な媒体。
[36]前記1又は複数のプロセッサに前記複数のパーティションの前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記1又は複数のグラフィカル・イメージの前記修正された斜視図をオーバーレイし且つ前記修正されたシーンをグラフィカルに分割する前記複数のパーティションの前記グラフィカル表現を表示させるためのコンピュータ実行可能な命令を含み、前記1又は複数のプロセッサに前記グラフィックス・データを解析させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記グラフィックス・データのうちのいずれの部分が前記複数のパーティションのうちの前記複数のパーティションに関連するかについて判定するために、前記1又は複数のグラフィックス・イメージの前記修正された斜視図に関するグラフィックス・データを解析させるためのコンピュータ実行可能な命令を含む[35]のコンピュータ読み取り可能な媒体。
[37]前記1又は複数のプロセッサに、外部グラフィックス・デバイスからグラフィックス命令を受信させ、前記外部グラフィックス・デバイスからステート情報(該ステート情報は、前記外部グラフィックス・デバイス上での前記グラフィックス命令の実行に関連する)を受信させるためのコンピュータ実行可能な命令を更に含み、前記1又は複数のプロセッサに前記グラフィカル・シーン中に前記1又は複数のグラフィックス・イメージを表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記グラフィックス命令及び前記ステート情報に基づいて、前記1又は複数のグラフィックス・イメージを表示させるためのコンピュータ実行可能な命令を含む[21]のコンピュータ読み取り可能な媒体。
[38]前記ステート情報は、前記1又は複数のグラフィックス・イメージに関する前記グラフィックス・データを含む[37]のコンピュータ読み取り可能な媒体。
[39]前記1又は複数のプロセッサに前記グラフィックス・データを前記グラフィックス命令にマッピングする前記外部グラフィックス・デバイスからのマッピング情報を受信させるためのコンピュータ実行可能な命令を更に含む[37]のコンピュータ読み取り可能な媒体。
[40]前記パーティションは、前記グラフィックス・データ上で実行されるオペレーションのレンダリングに基づいて判定される[2]のコンピュータ読み取り可能な媒体。
[41]表示デバイスと、グラフィカル・シーン中に1又は複数のグラフィックス・イメージを前記表示デバイス上に表示し、1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を前記表示デバイス上に表示し、前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析するように構成される1又は複数のプロセッサとを含むデバイス。
[42]前記1又は複数のプロセッサは、前記1又は複数のグラフィックス・イメージの表示、複数のパーティションのグラフィカル表現の表示及び前記1又は複数のグラフィックス・イメージの前記複数のフレームに関するグラフィックス・データの解析を、繰り返し行うように更に構成される[41]のデバイス。
[43]前記1又は複数のグラフィックス・イメージのうちの少なくとも一つは、3次元グラフィックス・イメージを含む[41]のデバイス。
[44]前記1又は複数のプロセッサは、前記1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割する複数の長方形の形状のパーティションのグラフィカル表現を表示することに少なくともよって、前記複数のパーティションの前記グラフィカル表現を表示するように構成された[41]のデバイス。
[45]前記グラフィックス・データは、前記1又は複数のグラフィックス・イメージをレンダリングするために使用される複数のグラフィックス・プリミティブを含む[41]のデバイス。
[46]前記複数のグラフィックス・プリミティブは、複数の三角形を含む[45]のデバイス。
[47]前記1又は複数のプロセッサは、前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定することに少なくともよって、前記グラフィックス・データを解析するように構成された[46]のデバイス。
[48]前記1又は複数のプロセッサは、前記三角形のうちのいずれの三角形が少なくとも部分的に前記パーティションのうちの複数のものにおいてレンダリングされたか判定することに少なくともよって、前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定するように構成された[47]のデバイス。
[49]前記1又は複数のプロセッサは、前記パーティションのうちの複数のものにわたる前記三角形のグラフィカル表現を表示するように更に構成された[47]のデバイス。
[50]前記1又は複数のプロセッサは、前記パーティションの前記グラフィカル表現を表示することと共に、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示することに少なくともよって、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示するように構成された[49]のデバイス。
[51]前記1又は複数のプロセッサは、各々の三角形に関するグラフィカル・インジケーションを表示することに少なくともよって、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示し、前記グラフィカル・インジケーションは、各々の対応する三角形によりわたられるパーティションの数のビジュアル・インジケーションを提供する[49]のデバイス。
[52]各々の対応する三角形に関する前記グラフィカル・インジケーションは、色を含む[51]のデバイス。
[53]前記1又は複数のプロセッサは、他の三角形より多くのパーティションにわたるそれらの三角形に関する前記グラフィカル・インジケーションを顕著に表示することに少なくともよって、各々の三角形に関する前記グラフィカル・インジケーションを表示するように構成された[51]のデバイス。
[54]前記1又は複数のプロセッサは、外部グラフィックス・デバイスからパーティショニング情報を受信し、前記受信されたパーティショニング情報に基づいて、前記複数のパーティションの前記グラフィカル表現を表示することに少なくともよって、前記複数のパーティションの前記グラフィカル表現を表示するように構成された[41]のデバイス。
[55]前記1又は複数のプロセッサは、前記ナビゲーション・コントローラとインタラクトするためのユーザ入力を受信することと、前記ナビゲーション・コントローラに対する前記ユーザ入力に基づいて、修正されたグラフィックス・シーン中の前記1又は複数のグラフィックス・イメージの修正された斜視図を表示することに少なくともよって、ナビゲーション・コントローラを表示するように更に構成された[41]のデバイス。
[56]前記1又は複数のプロセッサは、前記1又は複数のグラフィカル・イメージの前記修正された斜視図をオーバーレイし且つ前記修正されたシーンをグラフィカルに分割する前記複数のパーティションの前記グラフィカル表現を表示することに少なくともよって、前記複数のパーティションの前記グラフィカル表現を表示するように構成され、前記1又は複数のプロセッサは、前記グラフィックス・データのうちのいずれの部分が前記複数のパーティションのうちの前記複数のパーティションに関連するかについて判定するために、前記1又は複数のグラフィックス・イメージの前記修正された斜視図に関するグラフィックス・データを解析することに少なくともよって、前記グラフィックス・データを解析するように構成された[55]のデバイス。
[57]前記1又は複数のプロセッサは、外部グラフィックス・デバイスからグラフィックス命令を受信し、前記外部グラフィックス・デバイスからステート情報(該ステート情報は、前記外部グラフィックス・デバイス上での前記グラフィックス命令の実行に関連する)を受信するように更に構成され、前記1又は複数のプロセッサは、前記グラフィックス命令及び前記ステート情報に基づいて、前記1又は複数のグラフィックス・イメージを表示することに少なくともよって、前記グラフィカル・シーン中に前記1又は複数のグラフィックス・イメージを表示するように構成された[41]のデバイス。
[58]前記ステート情報は、前記1又は複数のグラフィックス・イメージに関する前記グラフィックス・データを含む[57]のデバイス。
[59]前記1又は複数のプロセッサは、前記グラフィックス・データを前記グラフィックス命令にマッピングする前記外部グラフィックス・デバイスからのマッピング情報を受信するように更に構成された[57]のデバイス。
[60]前記パーティションは、前記グラフィックス・データ上で実行されるオペレーションのレンダリングに基づいて判定される[41]のデバイス。
[61]グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示するための手段と、1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示するための手段と、前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析するための手段とを含むデバイス。
[62]前記1又は複数のグラフィックス・イメージの表示、複数のパーティションのグラフィカル表現の表示及び前記1又は複数のグラフィックス・イメージの前記複数のフレームに関するグラフィックス・データの解析を、繰り返し行うための手段を更に含む[61]のデバイス。
[63]前記1又は複数のグラフィックス・イメージのうちの少なくとも1つは、3次元グラフィックス・イメージを含む[61]のデバイス。
[64]前記複数のパーティションの前記グラフィカル表現を表示するための前記手段は、前記1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割する複数の長方形の形状のパーティションのグラフィカル表現を表示するための手段を含む[61]のデバイス。
[65]前記グラフィックス・データは、前記1又は複数のグラフィックス・イメージをレンダリングするために使用される複数のグラフィックス・プリミティブを含む[61]のデバイス。
[66]前記複数のグラフィックス・プリミティブは、複数の三角形を含む[65]のデバイス。
[67]前記グラフィックス・データを解析するための前記手段は、前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定するための手段を含む[66]のデバイス。
[68]前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定するための前記手段は、前記三角形のうちのいずれの三角形が少なくとも部分的に前記パーティションのうちの複数のものにおいてレンダリングされたか判定するための手段を含む[67]のデバイス。
[69]前記パーティションのうちの複数のものにわたる前記三角形のグラフィカル表現を表示するための手段を更に含む[67]のデバイス。
[70]前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示するための前記手段は、前記パーティションの前記グラフィカル表現を表示することと共に、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示するための手段を含む[69]のデバイス。
[71]前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示するための前記手段は、各々の三角形に関するグラフィカル・インジケーションを表示するための手段を含み、前記グラフィカル・インジケーションは、各々の対応する三角形によりわたられるパーティションの数のビジュアル・インジケーションを提供する[69]のデバイス。
[72]各々の対応する三角形に関する前記グラフィカル・インジケーションは、色を含む[71]のデバイス。
[73]各々の三角形に関する前記グラフィカル・インジケーションを表示するための前記手段は、他の三角形より多くのパーティションにわたるそれらの三角形に関する前記グラフィカル・インジケーションを顕著に表示するための手段を含む[71]のデバイス。
[74]前記複数のパーティションの前記グラフィカル表現を表示するための前記手段は、外部グラフィックス・デバイスからパーティショニング情報を受信するための手段と、前記受信されたパーティショニング情報に基づいて、前記複数のパーティションの前記グラフィカル表現を表示するための手段とを含む[61]のデバイス。
[75]ナビゲーション・コントローラを表示するための手段と、前記ナビゲーション・コントローラとインタラクトするためのユーザ入力を受信するための手段と、前記ナビゲーション・コントローラに対する前記ユーザ入力に基づいて、修正されたグラフィックス・シーン中の前記1又は複数のグラフィックス・イメージの修正された斜視図を表示するための手段とを更に含む[61]のデバイス。
[76]前記複数のパーティションの前記グラフィカル表現を表示するための前記手段は、前記1又は複数のグラフィカル・イメージの前記修正された斜視図をオーバーレイし且つ前記修正されたシーンをグラフィカルに分割する前記複数のパーティションの前記グラフィカル表現を表示するための手段を含み、前記グラフィックス・データを解析するための前記手段は、前記グラフィックス・データのうちのいずれの部分が前記複数のパーティションのうちの前記複数のパーティションに関連するかについて判定するために、前記1又は複数のグラフィックス・イメージの前記修正された斜視図に関するグラフィックス・データを解析するための手段を含む[75]のデバイス。
[77]外部グラフィックス・デバイスからグラフィックス命令を受信するための手段と、前記外部グラフィックス・デバイスからステート情報(該ステート情報は、前記外部グラフィックス・デバイス上での前記グラフィックス命令の実行に関連する)を受信するための手段とを更に含み、前記グラフィカル・シーン中に前記1又は複数のグラフィックス・イメージを表示するための前記手段は、前記グラフィックス命令及び前記ステート情報に基づいて、前記1又は複数のグラフィックス・イメージを表示するための手段を含む[61]のデバイス。
[78]前記ステート情報は、前記1又は複数のグラフィックス・イメージに関する前記グラフィックス・データを含む[77]のデバイス。
[79]前記グラフィックス・データを前記グラフィックス命令にマッピングする前記外部グラフィックス・デバイスからのマッピング情報を受信するための手段を更に含む[77]のデバイス。
[80]前記パーティションは、前記グラフィックス・データ上で実行されるオペレーションのレンダリングに基づいて判定される[61]のデバイス。
  Various aspects have been described herein. These and other aspects are within the scope of the following claims.  
  Below, the invention corresponding to each claim described in the scope of claims of the present application is appended.  
  [1] displaying one or more graphics images in a graphical scene, and displaying a graphical representation of a partition that overlays the one or more graphics images and graphically divides the scene. Analyzing the graphics data to determine which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions. Including methods.  
  [2] repeatedly displaying the one or more graphics images, displaying a graphical representation of a plurality of partitions, and analyzing the graphics data for the plurality of frames of the one or more graphics images. The method according to [1], further comprising:  
  [3] The method according to [1], wherein at least one of the one or more graphics images includes a three-dimensional graphics image.  
  [4] Displaying the graphical representation of the plurality of partitions displays a graphical representation of a plurality of rectangular shaped partitions overlaying the one or more graphics images and graphically dividing the scene. [1] The method of including.  
  [5] The method of [1], wherein the graphics data includes a plurality of graphics primitives used to render the one or more graphics images.  
  [6] The method according to [5], wherein the plurality of graphics primitives include a plurality of triangles.  
  [7] The method of [6], wherein analyzing the graphics data includes determining which of the triangles spans a plurality of the partitions.  
  [8] Determining which of the triangles spans more than one of the partitions is determining which of the triangles are at least partially rendered in the more of the partitions. The method of [7], comprising determining whether or not it has been done.  
  [9] The method of [7], further comprising displaying a graphical representation of the triangle over a plurality of the partitions.  
  [10] Displaying the graphical representation of the triangle over a plurality of the partitions together with displaying the graphical representation of the partition and the graphical representation of the triangle over the plurality of the partitions [9] The method including displaying an expression.  
  [11] Displaying the graphical representation of the triangle over a plurality of the partitions includes displaying a graphical indication for each triangle, the graphical indication corresponding to each [9] The method of [9], which provides a visual indication of the number of partitions spanned by a triangle.  
  [12] The method of [11], wherein the graphical indication for each corresponding triangle includes a color.  
  [13] The method of [11], wherein displaying the graphical indication for each triangle includes notably displaying the graphical indication for those triangles over more partitions than the other triangles.  
  [14] Displaying the graphical representation of the plurality of partitions includes receiving partitioning information from an external graphics device, and based on the received partitioning information, the graphical representation of the plurality of partitions. The method of [1], including displaying an expression.  
  [15] displaying a navigation controller; receiving user input for interacting with the navigation controller; and in a modified graphics scene based on the user input to the navigation controller The method of [1], further comprising displaying a modified perspective view of the one or more graphics images.  
  [16] Displaying the graphical representation of the plurality of partitions overlays the modified perspective view of the one or more graphical images and graphically divides the modified scene. Displaying the graphical representation of, wherein analyzing the graphics data is related to which portion of the graphics data is associated with the plurality of partitions of the plurality of partitions. The method of [15], comprising analyzing graphics data relating to the modified perspective view of the one or more graphics images to determine.  
  [17] Receiving graphics instructions from an external graphics device and state information from the external graphics device (the state information relates to execution of the graphics instructions on the external graphics device) And displaying the one or more graphics images in the graphical scene based on the graphics instructions and the state information. [1] The method including displaying an image.  
  [18] The method according to [17], wherein the state information includes the graphics data relating to the one or more graphics images.  
  [19] The method of [17], further comprising receiving mapping information from the external graphics device that maps the graphics data to the graphics instructions.  
  [20] The method of [1], wherein the partition is determined based on a rendering of an operation performed on the graphics data.  
  [21] Graphical representation of a partition that causes one or more processors to display one or more graphics images in a graphical scene, overlays the one or more graphics images, and graphically divides the scene To determine which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions. A computer-readable medium containing computer-executable instructions for analysis.  
  [22] Displaying the one or more graphics images, displaying a graphical representation of a plurality of partitions, and graphics relating to the plurality of frames of the one or more graphics images on the one or more processors. [21] The computer-readable medium according to [21], further including computer-executable instructions for repeatedly performing data analysis.  
  [23] The computer-readable medium according to [21], wherein at least one of the one or more graphics images includes a three-dimensional graphics image.  
  [24] The computer-executable instructions for causing the one or more processors to display the graphical representation of the plurality of partitions overlay the one or more graphics images on the one or more processors. [21] The computer readable medium of [21] comprising computer executable instructions for displaying a graphical representation of a plurality of rectangular shaped partitions that graphically divide the scene.  
  [25] The computer-readable medium of [21], wherein the graphics data includes a plurality of graphics primitives used to render the one or more graphics images.  
  [26] The computer readable medium of [25], wherein the plurality of graphics primitives include a plurality of triangles.  
  [27] The computer-executable instructions for causing the one or more processors to analyze the graphics data are such that any one of the triangles is a plurality of the partitions. [2] The computer-readable medium including computer-executable instructions for determining whether or not the program is over.  
  [28] The computer-executable instructions for causing the one or more processors to determine which triangles of the triangles span a plurality of the partitions are the one or more processors, the triangle [27] The computer-readable medium of [27] comprising computer-executable instructions for determining which triangles of at least partially rendered in a plurality of said partitions.  
  [29] The computer-readable medium of [27], further comprising the computer-executable instructions for causing the one or more processors to display a graphical representation of the triangle across a plurality of the partitions.  
  [30] The computer-executable instructions for causing the one or more processors to display the graphical representation of the triangle across a plurality of the partitions are for causing the one or more processors to display the graphical of the partition. [29] The computer-readable medium of [29] comprising computer-executable instructions for displaying a representation and displaying the graphical representation of the triangle across a plurality of the partitions.  
  [31] The computer-executable instructions for causing the one or more processors to display the graphical representation of the triangles over a plurality of the partitions are graphically related to each triangle by the one or more processors. [29] computer readable including computer-executable instructions for displaying indications, wherein the graphical indication provides a visual indication of the number of partitions spanned by each corresponding triangle Medium.  
  [32] The computer-readable medium of [31], wherein the graphical indication for each corresponding triangle includes a color.  
  [33] The computer-executable instructions for causing the one or more processors to display the graphical indications for each triangle are those triangles that span more partitions than the other triangles. [31] The computer-readable medium comprising computer-executable instructions for prominently displaying the graphical indication regarding.  
  [34] The computer-executable instructions for causing the one or more processors to display the graphical representation of the plurality of partitions receive partitioning information from an external graphics device to the one or more processors. And [21] a computer-readable medium comprising computer-executable instructions for displaying the graphical representation of the plurality of partitions based on the received partitioning information.  
  [35] causing the one or more processors to display a navigation controller, receive user input for interacting with the navigation controller, and modify graphics based on the user input to the navigation controller The computer-readable medium of [21], further comprising computer-executable instructions for displaying a modified perspective view of the one or more graphics images in the scene.  
  [36] The computer-executable instructions for causing the one or more processors to display the graphical representation of the plurality of partitions are the modified one or more of the one or more graphical images to the one or more processors. Computer-executable instructions for displaying the graphical representation of the plurality of partitions that overlays a perspective view and graphically divides the modified scene, the graphics data to the one or more processors The computer-executable instructions for analyzing the one or more processors determine which portion of the graphics data is associated with the plurality of partitions of the plurality of partitions. In order to The computer-readable medium of [35] comprising computer executable instructions for causing the analysis graphics data for the modified perspective view of a plurality of graphics images.  
  [37] Cause the one or more processors to receive graphics instructions from an external graphics device, and state information from the external graphics device (the state information is the graphics on the external graphics device). Computer-executable instructions for causing said one or more processors to display said one or more graphics images in said graphical scene. Computer-executable instructions include computer-executable instructions for causing the one or more processors to display the one or more graphics images based on the graphics instructions and the state information [21]. Computer readable media.  
  [38] The computer-readable medium according to [37], wherein the state information includes the graphics data relating to the one or more graphics images.  
  [39] The computer-executable instructions for causing the one or more processors to receive mapping information from the external graphics device that maps the graphics data to the graphics instructions. Computer readable medium.  
  [40] The computer-readable medium of [2], wherein the partition is determined based on a rendering of an operation performed on the graphics data.  
  [41] A display device and a partition for displaying one or more graphics images on the display device in a graphical scene, overlaying the one or more graphics images and graphically dividing the scene Displaying a graphical representation on the display device to determine which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions; And one or more processors configured to analyze the graphics data.  
  [42] The one or more processors may display the one or more graphics images, display a graphical representation of a plurality of partitions, and graphics for the plurality of frames of the one or more graphics images. The device of [41], further configured to repeatedly perform data analysis.  
  [43] The device of [41], wherein at least one of the one or more graphics images includes a three-dimensional graphics image.  
  [44] The one or more processors at least by displaying a graphical representation of a plurality of rectangular shaped partitions overlaying the one or more graphics images and graphically dividing the scene. [41] The device configured to display the graphical representation of a plurality of partitions.  
  [45] The device of [41], wherein the graphics data includes a plurality of graphics primitives used to render the one or more graphics images.  
  [46] The device of [45], wherein the plurality of graphics primitives include a plurality of triangles.  
  [47] The one or more processors are configured to analyze the graphics data at least by determining which of the triangles spans more than one of the partitions. [46] The device.  
  [48] The one or more processors may determine which one of the triangles at least by determining which one of the triangles has been rendered at least partially in the plurality of the partitions. [47] The device configured to determine whether a triangle spans a plurality of the partitions.
  [49] The device of [47], wherein the one or more processors are further configured to display a graphical representation of the triangle across a plurality of the partitions.  
  [50] The one or more processors are configured to display the graphical representation of the partition and at least by displaying the graphical representation of the triangle across the plurality of the partitions. The device of [49], configured to display the graphical representation of the triangle across a plurality of.  
  [51] The one or more processors display the graphical representation of the triangles over a plurality of the partitions, at least by displaying a graphical indication for each triangle, and the graphical indicators. Provides a visual indication of the number of partitions spanned by each corresponding triangle [49].  
  [52] The device of [51], wherein the graphical indication for each corresponding triangle includes a color.  
  [53] The one or more processors display the graphical indication for each triangle at least by prominently displaying the graphical indication for those triangles across more partitions than the other triangles. [51] The device configured as follows.  
  [54] At least by the one or more processors receiving partitioning information from an external graphics device and displaying the graphical representation of the plurality of partitions based on the received partitioning information. The device of [41], configured to display the graphical representation of the plurality of partitions.  
  [55] The one or more processors receive user input for interacting with the navigation controller and based on the user input to the navigation controller, in the modified graphics scene [41] The device of [41], further configured to display a navigation controller, at least by displaying a modified perspective view of the one or more graphics images.  
  [56] The one or more processors overlay the modified perspective view of the one or more graphical images and display the graphical representation of the plurality of partitions that graphically divides the modified scene At least by being configured to display the graphical representation of the plurality of partitions, wherein the one or more processors are configured such that any portion of the graphics data is the portion of the plurality of partitions. Analyzing the graphics data at least by analyzing graphics data relating to the modified perspective view of the one or more graphics images to determine whether they are associated with multiple partitions. [5 Device].  
  [57] The one or more processors receive graphics instructions from an external graphics device, and state information from the external graphics device (the state information is the graphics on the external graphics device). And wherein the one or more processors display the one or more graphics images based on the graphics instructions and the state information. [41] The device of [41], configured to display at least one of the one or more graphics images in the graphical scene.  
  [58] The device of [57], wherein the state information includes the graphics data relating to the one or more graphics images.  
  [59] The device of [57], wherein the one or more processors are further configured to receive mapping information from the external graphics device that maps the graphics data to the graphics instructions.  
  [60] The device of [41], wherein the partition is determined based on a rendering of an operation performed on the graphics data.  
  [61] A means for displaying one or more graphics images in a graphical scene and a graphical representation of a partition that overlays the one or more graphics images and graphically divides the scene And means for determining which portion of the graphics data relating to the one or more graphics images is associated with a plurality of the partitions. And a device including means for analyzing the device.  
  [62] To repeatedly display one or more graphics images, display a graphical representation of a plurality of partitions, and analyze graphics data relating to the plurality of frames of the one or more graphics images. [61] The device according to [61].  
  [63] The device of [61], wherein at least one of the one or more graphics images includes a three-dimensional graphics image.  
  [64] The means for displaying the graphical representation of the plurality of partitions overlays the one or more graphics images and graphically represents a plurality of rectangular shaped partitions that graphically divide the scene. [61] The device of [61] comprising means for displaying  
  [65] The device of [61], wherein the graphics data includes a plurality of graphics primitives used to render the one or more graphics images.  
  [66] The device of [65], wherein the plurality of graphics primitives include a plurality of triangles.  
  [67] The device of [66], wherein the means for analyzing the graphics data includes means for determining which of the triangles spans a plurality of the partitions.  
  [68] The means for determining which triangles of the triangles span a plurality of the partitions, wherein the triangles of the triangles are at least partially of the partitions of the partitions. [67] The device of [67], comprising means for determining whether it has been rendered in the object.  
  [69] The device of [67], further comprising means for displaying a graphical representation of the triangle across a plurality of the partitions.  
  [70] The means for displaying the graphical representation of the triangle over a plurality of the partitions, and displaying the graphical representation of the partition and the triangle over the plurality of the partitions. [69] The device of [69] comprising means for displaying said graphical representation of  
  [71] The means for displaying the graphical representation of the triangle across a plurality of the partitions includes means for displaying a graphical indication for each triangle, the graphical indication comprising: [69] The device of [69], which provides visual indication of the number of partitions spanned by each corresponding triangle.  
  [72] The device of [71], wherein the graphical indication for each corresponding triangle includes a color.  
  [73] The means for displaying the graphical indication for each triangle includes means for prominently displaying the graphical indication for those triangles across more partitions than other triangles. ] Device.  
  [74] The means for displaying the graphical representation of the plurality of partitions is based on the received partitioning information and means for receiving partitioning information from an external graphics device. Means for displaying the graphical representation of the partition of [61].  
  [75] Means for displaying a navigation controller, means for receiving user input for interacting with the navigation controller, and modified graphics based on the user input to the navigation controller [61] The device of [61], further comprising means for displaying a modified perspective view of the one or more graphics images in the scene.  
  [76] The means for displaying the graphical representation of the plurality of partitions overlays the modified perspective view of the one or more graphical images and graphically divides the modified scene. Means for displaying the graphical representation of a plurality of partitions, the means for analyzing the graphics data wherein any portion of the graphics data is the portion of the plurality of partitions. [75] The device of [75], comprising means for analyzing graphics data relating to the modified perspective view of the one or more graphics images to determine whether they are associated with a plurality of partitions.  
  [77] Means for receiving graphics instructions from an external graphics device and state information from the external graphics device (the state information is the execution of the graphics instructions on the external graphics device) And means for displaying the one or more graphics images in the graphical scene based on the graphics instructions and the state information. [61] The device of [61] comprising means for displaying said one or more graphics images.  
  [78] The device of [77], wherein the state information includes the graphics data relating to the one or more graphics images.  
  [79] The device of [77], further comprising means for receiving mapping information from the external graphics device that maps the graphics data to the graphics instructions.  
  [80] The device of [61], wherein the partition is determined based on a rendering of an operation performed on the graphics data.

開発者はまた、場合によっては、テクスチャー・ボタン236を選択しても良い。選択に応じて、グラフィックス・イメージ210に関係する様々な形のテクスチャー情報が、グラフィックス・デバイス201により表示されても良い。例えば、テクスチャー情報は、ウインドウ220内に(例えばステート/パフォーマンス情報エリア214内などに)表示されても良い。場合によっては、テクスチャー情報は、更なる(例えば、ポップアップ)ウインドウ(図示せず)内に表示されても良い。開発者は、表示されたテクスチャー情報を閲覧しても良いが、また、場合によっては、テクスチャー情報を修正しても良い。これらの場合、テクスチャー情報に対する任意の修正が、要求された修正として、グラフィックス・デバイス200へ伝播されても良い。グラフィックス・デバイス200からの更新された命令/情報の受信に応じて、グラフィックス・イメージ210に対する変更が、表示エリア211内に表示されても良い。テクスチャー・ボタン236の選択に応じて、特定のテクスチャー情報が表示されても良い。 The developer may also select the texture button 236 in some cases. Depending on the selection, various forms of texture information related to the graphics image 210 may be displayed by the graphics device 201. For example, the texture information may be displayed in the window 220 (eg, in the state / performance information area 214). In some cases, the texture information may be displayed in a further (eg, pop-up) window (not shown). The developer may browse the displayed texture information, but may correct the texture information in some cases. In these cases, any modification to the texture information may be propagated to the graphics device 200 as the requested modification. Changes to the graphics image 210 may be displayed in the display area 211 in response to receiving updated instructions / information from the graphics device 200 . Depending on the choice of Te Kusucha button 236, specific texture information may be displayed.

場合によっては、開発者はまた、グラフィックス・デバイス200により実装される処理パイプラインに関連する1又は複数の機能をオーバーライドするオーバーライド・ボタン238を選択しても良い。オーバーライド・ボタン238の選択に応じて、オーバーライド・スクリーンが開発者に対して表示されても良い。 In some cases, the developer may also select an override button 238 that overrides one or more functions associated with the processing pipeline implemented by the graphics device 200 . Depending on the choice of overriding button 238, override screen may be displayed to the developers.

Claims (80)

グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示することと、
1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示することと、
前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析することを含む方法。
Displaying one or more graphics images in a graphical scene;
Displaying a graphical representation of a partition overlaying one or more graphics images and graphically dividing the scene;
Analyzing the graphics data to determine which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions. Including methods.
前記1又は複数のグラフィックス・イメージの表示、複数のパーティションのグラフィカル表現の表示及び前記1又は複数のグラフィックス・イメージの前記複数のフレームに関するグラフィックス・データの解析を、繰り返し行うことを更に含む請求項1の方法。   It further includes iteratively displaying the one or more graphics images, displaying a graphical representation of a plurality of partitions, and analyzing the graphics data for the plurality of frames of the one or more graphics images. The method of claim 1. 前記1又は複数のグラフィックス・イメージのうちの少なくとも一つは、3次元グラフィックス・イメージを含む請求項1の方法。   The method of claim 1, wherein at least one of the one or more graphics images comprises a three-dimensional graphics image. 前記複数のパーティションの前記グラフィカル表現を表示することは、前記1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割する複数の長方形の形状のパーティションのグラフィカル表現を表示することを含む請求項1の方法。   Displaying the graphical representation of the plurality of partitions includes displaying a graphical representation of a plurality of rectangular shaped partitions that overlay the one or more graphics images and graphically divide the scene. The method of claim 1. 前記グラフィックス・データは、前記1又は複数のグラフィックス・イメージをレンダーするために使用される複数のグラフィックス・プリミティブを含む請求項1の方法。   The method of claim 1, wherein the graphics data includes a plurality of graphics primitives used to render the one or more graphics images. 前記複数のグラフィックス・プリミティブは、複数の三角形を含む請求項5の方法。   The method of claim 5, wherein the plurality of graphics primitives include a plurality of triangles. 前記グラフィックス・データを解析することは、前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定することを含む請求項6の方法。   7. The method of claim 6, wherein analyzing the graphics data includes determining which triangles of the triangles span multiple ones of the partitions. 前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定することは、前記三角形のうちのいずれの三角形が少なくとも部分的に前記パーティションのうちの複数のものにおいてレンダリングされたか判定することを含む請求項7の方法。   Determining which of the triangles spans multiple of the partitions is determining which of the triangles are at least partially rendered in multiple of the partitions The method of claim 7 comprising: 前記パーティションのうちの複数のものにわたる前記三角形のグラフィカル表現を表示することを更に含む請求項7の方法。   8. The method of claim 7, further comprising displaying a graphical representation of the triangle over a plurality of the partitions. 前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示することは、前記パーティションの前記グラフィカル表現を表示することと共に、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示することを含む請求項9の方法。   Displaying the graphical representation of the triangle over a plurality of the partitions displays the graphical representation of the triangle over a plurality of the partitions along with displaying the graphical representation of the partitions 10. The method of claim 9, comprising: 前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示することは、各々の三角形に関するグラフィカル・インジケーションを表示することを含み、
前記グラフィカル・インジケーションは、各々の対応する三角形によりわたられるパーティションの数のビジュアル・インジケーションを提供する請求項9の方法。
Displaying the graphical representation of the triangles over a plurality of the partitions includes displaying a graphical indication for each triangle;
The method of claim 9, wherein the graphical indication provides a visual indication of the number of partitions spanned by each corresponding triangle.
各々の対応する三角形に関する前記グラフィカル・インジケーションは、色を含む請求項11の方法。   The method of claim 11, wherein the graphical indication for each corresponding triangle includes a color. 各々の三角形に関する前記グラフィカル・インジケーションを表示することは、他の三角形より多くのパーティションにわたるそれらの三角形に関する前記グラフィカル・インジケーションを顕著に表示することを含む請求項11の方法。   12. The method of claim 11, wherein displaying the graphical indication for each triangle includes notably displaying the graphical indication for those triangles across more partitions than other triangles. 前記複数のパーティションの前記グラフィカル表現を表示することは、
外部グラフィックス・デバイスからパーティショニング情報を受信することと、
前記受信されたパーティショニング情報に基づいて、前記複数のパーティションの前記グラフィカル表現を表示することを含む請求項1の方法。
Displaying the graphical representation of the plurality of partitions comprises:
Receiving partitioning information from an external graphics device;
The method of claim 1, comprising displaying the graphical representation of the plurality of partitions based on the received partitioning information.
ナビゲーション・コントローラを表示することと、
前記ナビゲーション・コントローラとインタラクトするためのユーザ入力を受信することと、
前記ナビゲーション・コントローラに対する前記ユーザ入力に基づいて、修正されたグラフィックス・シーン中の前記1又は複数のグラフィックス・イメージの修正された斜視図を表示することを更に含む請求項1の方法。
Displaying a navigation controller;
Receiving user input to interact with the navigation controller;
The method of claim 1, further comprising displaying a modified perspective view of the one or more graphics images in a modified graphics scene based on the user input to the navigation controller.
前記複数のパーティションの前記グラフィカル表現を表示することは、前記1又は複数のグラフィカル・イメージの前記修正された斜視図をオーバーレイし且つ前記修正されたシーンをグラフィカルに分割する前記複数のパーティションの前記グラフィカル表現を表示することを含み、
前記グラフィックス・データを解析することは、前記グラフィックス・データのうちのいずれの部分が前記複数のパーティションのうちの前記複数のパーティションに関連するかについて判定するために、前記1又は複数のグラフィックス・イメージの前記修正された斜視図に関するグラフィックス・データを解析することを含む請求項15の方法。
Displaying the graphical representation of the plurality of partitions overlays the modified perspective view of the one or more graphical images and graphically divides the modified scene of the plurality of partitions. Including displaying a representation,
Analyzing the graphics data may include determining the portion of the graphics data that is associated with the plurality of partitions of the plurality of partitions. 16. The method of claim 15, comprising analyzing graphics data relating to the modified perspective view of a scanned image.
外部グラフィックス・デバイスからグラフィックス命令を受信することと、
前記外部グラフィックス・デバイスからステート情報(該ステート情報は、前記外部グラフィックス・デバイス上での前記グラフィックス命令の実行に関連する)を受信することを含み、
前記グラフィカル・シーン中に前記1又は複数のグラフィックス・イメージを表示することは、前記グラフィックス命令及び前記ステート情報に基づいて、前記1又は複数のグラフィックス・イメージを表示することを含む請求項1の方法。
Receiving graphics instructions from an external graphics device;
Receiving state information from the external graphics device, the state information relating to execution of the graphics instructions on the external graphics device;
The displaying of the one or more graphics images in the graphical scene includes displaying the one or more graphics images based on the graphics instructions and the state information. 1 method.
前記ステート情報は、前記1又は複数のグラフィックス・イメージに関する前記グラフィックス・データを含む請求項17の方法。   The method of claim 17, wherein the state information includes the graphics data for the one or more graphics images. 前記グラフィックス・データを前記グラフィックス命令にマッピングする前記外部グラフィックス・デバイスからのマッピング情報を受信することを更に含む請求項17の方法。   18. The method of claim 17, further comprising receiving mapping information from the external graphics device that maps the graphics data to the graphics instructions. 前記パーティションは、前記グラフィックス・データ上で実行されるオペレーションのレンダリングに基づいて判定される請求項1の方法。   The method of claim 1, wherein the partition is determined based on a rendering of an operation performed on the graphics data. 1又は複数のプロセッサに、
グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示させ、
1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示させ、
前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析させるためのコンピュータ実行可能な命令を含むコンピュータ読み取り可能な媒体。
One or more processors,
Display one or more graphics images in a graphical scene,
Displaying a graphical representation of a partition that overlays one or more graphics images and graphically divides the scene;
For analyzing the graphics data to determine which portions of the graphics data for the one or more graphics images are associated with a plurality of the partitions. A computer-readable medium containing computer-executable instructions.
前記1又は複数のプロセッサに、
前記1又は複数のグラフィックス・イメージの表示、複数のパーティションのグラフィカル表現の表示及び前記1又は複数のグラフィックス・イメージの前記複数のフレームに関するグラフィックス・データの解析を、繰り返し行わせるためのコンピュータ実行可能な命令を更に含む請求項21のコンピュータ読み取り可能な媒体。
The one or more processors;
A computer for repeatedly performing display of the one or more graphics images, display of a graphical representation of a plurality of partitions, and analysis of graphics data relating to the plurality of frames of the one or more graphics images The computer-readable medium of claim 21, further comprising executable instructions.
前記1又は複数のグラフィックス・イメージのうちの少なくとも一つは、3次元グラフィックス・イメージを含む請求項21のコンピュータ読み取り可能な媒体。   The computer-readable medium of claim 21, wherein at least one of the one or more graphics images comprises a three-dimensional graphics image. 前記1又は複数のプロセッサに前記複数のパーティションの前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割する複数の長方形の形状のパーティションのグラフィカル表現を表示させるためのコンピュータ実行可能な命令を含む請求項21のコンピュータ読み取り可能な媒体。   The computer-executable instructions for causing the one or more processors to display the graphical representation of the plurality of partitions overlay the one or more graphics images on the one or more processors and the scene. 24. The computer-readable medium of claim 21, comprising computer-executable instructions for displaying a graphical representation of a plurality of rectangular shaped partitions that graphically divide. 前記グラフィックス・データは、前記1又は複数のグラフィックス・イメージをレンダリングするために使用される複数のグラフィックス・プリミティブを含む請求項21のコンピュータ読み取り可能な媒体。   The computer-readable medium of claim 21, wherein the graphics data includes a plurality of graphics primitives used to render the one or more graphics images. 前記複数のグラフィックス・プリミティブは、複数の三角形を含む請求項25のコンピュータ読み取り可能な媒体。   26. The computer readable medium of claim 25, wherein the plurality of graphics primitives include a plurality of triangles. 前記1又は複数のプロセッサに前記グラフィックス・データを解析させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定させるためのコンピュータ実行可能な命令を含む請求項2ののコンピュータ読み取り可能な媒体。   The computer-executable instructions for causing the one or more processors to analyze the graphics data are such that any one of the triangles spans a plurality of the partitions. The computer-readable medium of claim 2, comprising computer-executable instructions for determining whether or not. 前記1又は複数のプロセッサに前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記三角形のうちのいずれの三角形が少なくとも部分的に前記パーティションのうちの複数のものにおいてレンダリングされたか判定させるためのコンピュータ実行可能な命令を含む請求項27のコンピュータ読み取り可能な媒体。   The computer-executable instructions for causing the one or more processors to determine which triangles of the triangles span multiple of the partitions are the one or more processors of the triangles. 28. The computer-readable medium of claim 27, comprising computer-executable instructions for determining which triangles have been rendered at least partially in a plurality of the partitions. 前記1又は複数のプロセッサに前記パーティションのうちの複数のものにわたる前記三角形のグラフィカル表現を表示させるための前記コンピュータ実行可能な命令を更に含む請求項27のコンピュータ読み取り可能な媒体。   28. The computer-readable medium of claim 27, further comprising the computer-executable instructions for causing the one or more processors to display a graphical representation of the triangle across a plurality of the partitions. 前記1又は複数のプロセッサに前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記パーティションの前記グラフィカル表現を表示させると共に、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示させるためのコンピュータ実行可能な命令を含む請求項29のコンピュータ読み取り可能な媒体。   The computer-executable instructions for causing the one or more processors to display the graphical representation of the triangle across a plurality of the partitions display the graphical representation of the partition on the one or more processors. 30. The computer-readable medium of claim 29, comprising: computer-executable instructions for displaying the graphical representation of the triangle across a plurality of the partitions. 前記1又は複数のプロセッサに前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに各々の三角形に関するグラフィカル・インジケーションを表示させるためのコンピュータ実行可能な命令を含み、
前記グラフィカル・インジケーションは、各々の対応する三角形によりわたられるパーティションの数のビジュアル・インジケーションを提供する請求項29のコンピュータ読み取り可能な媒体。
The computer-executable instructions for causing the one or more processors to display the graphical representation of the triangles across a plurality of the partitions are graphical indications for each triangle on the one or more processors. Including computer-executable instructions for displaying
30. The computer readable medium of claim 29, wherein the graphical indication provides a visual indication of the number of partitions spanned by each corresponding triangle.
各々の対応する三角形に関する前記グラフィカル・インジケーションは、色を含む請求項31のコンピュータ読み取り可能な媒体。   32. The computer readable medium of claim 31, wherein the graphical indication for each corresponding triangle includes a color. 前記1又は複数のプロセッサに各々の三角形に関する前記グラフィカル・インジケーションを表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに他の三角形より多くのパーティションにわたるそれらの三角形に関する前記グラフィカル・インジケーションを顕著に表示させるためのコンピュータ実行可能な命令を含む請求項31のコンピュータ読み取り可能な媒体。   The computer-executable instructions for causing the one or more processors to display the graphical indication for each triangle are the graphical for those triangles that span more partitions than the other triangles for the one or more processors. 32. The computer-readable medium of claim 31, comprising computer-executable instructions for prominently displaying an indication. 前記1又は複数のプロセッサに前記複数のパーティションの前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、
前記1又は複数のプロセッサに、
外部グラフィックス・デバイスからパーティショニング情報を受信させ、
前記受信されたパーティショニング情報に基づいて、前記複数のパーティションの前記グラフィカル表現を表示させるためのコンピュータ実行可能な命令を含む請求項21のコンピュータ読み取り可能な媒体。
The computer-executable instructions for causing the one or more processors to display the graphical representation of the plurality of partitions are:
The one or more processors;
Receive partitioning information from an external graphics device,
The computer-readable medium of claim 21, comprising computer-executable instructions for displaying the graphical representation of the plurality of partitions based on the received partitioning information.
前記1又は複数のプロセッサに、
ナビゲーション・コントローラを表示させ、
前記ナビゲーション・コントローラとインタラクトするためのユーザ入力を受信させ、
前記ナビゲーション・コントローラに対する前記ユーザ入力に基づいて、修正されたグラフィックス・シーン中の前記1又は複数のグラフィックス・イメージの修正された斜視図を表示させるためのコンピュータ実行可能な命令を更に含む請求項21のコンピュータ読み取り可能な媒体。
The one or more processors;
Display the navigation controller,
Receiving user input to interact with the navigation controller;
Computer-executable instructions for displaying a modified perspective view of the one or more graphics images in a modified graphics scene based on the user input to the navigation controller. Item 21. The computer-readable medium according to Item 21.
前記1又は複数のプロセッサに前記複数のパーティションの前記グラフィカル表現を表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記1又は複数のグラフィカル・イメージの前記修正された斜視図をオーバーレイし且つ前記修正されたシーンをグラフィカルに分割する前記複数のパーティションの前記グラフィカル表現を表示させるためのコンピュータ実行可能な命令を含み、
前記1又は複数のプロセッサに前記グラフィックス・データを解析させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記グラフィックス・データのうちのいずれの部分が前記複数のパーティションのうちの前記複数のパーティションに関連するかについて判定するために、前記1又は複数のグラフィックス・イメージの前記修正された斜視図に関するグラフィックス・データを解析させるためのコンピュータ実行可能な命令を含む請求項35のコンピュータ読み取り可能な媒体。
The computer-executable instructions for causing the one or more processors to display the graphical representation of the plurality of partitions are the modified perspective view of the one or more graphical images on the one or more processors. Including computer-executable instructions for displaying the graphical representation of the plurality of partitions overlaying and graphically dividing the modified scene;
The computer-executable instructions for causing the one or more processors to analyze the graphics data are such that any part of the graphics data is included in the plurality of partitions. A computer-executable instruction for causing the graphics data relating to the modified perspective view of the one or more graphics images to be analyzed to determine whether the plurality of partitions are associated with the plurality of partitions. 35 computer-readable media.
前記1又は複数のプロセッサに、
外部グラフィックス・デバイスからグラフィックス命令を受信させ、
前記外部グラフィックス・デバイスからステート情報(該ステート情報は、前記外部グラフィックス・デバイス上での前記グラフィックス命令の実行に関連する)を受信させるためのコンピュータ実行可能な命令を更に含み、
前記1又は複数のプロセッサに前記グラフィカル・シーン中に前記1又は複数のグラフィックス・イメージを表示させるための前記コンピュータ実行可能な命令は、前記1又は複数のプロセッサに前記グラフィックス命令及び前記ステート情報に基づいて、前記1又は複数のグラフィックス・イメージを表示させるためのコンピュータ実行可能な命令を含む請求項21のコンピュータ読み取り可能な媒体。
The one or more processors;
Receive graphics instructions from an external graphics device,
Computer-executable instructions for causing the external graphics device to receive state information (the state information relating to execution of the graphics instructions on the external graphics device);
The computer-executable instructions for causing the one or more processors to display the one or more graphics images in the graphical scene include the graphics instructions and the state information to the one or more processors. 23. The computer-readable medium of claim 21, comprising computer-executable instructions for displaying the one or more graphics images based on:
前記ステート情報は、前記1又は複数のグラフィックス・イメージに関する前記グラフィックス・データを含む請求項37のコンピュータ読み取り可能な媒体。   38. The computer readable medium of claim 37, wherein the state information includes the graphics data relating to the one or more graphics images. 前記1又は複数のプロセッサに前記グラフィックス・データを前記グラフィックス命令にマッピングする前記外部グラフィックス・デバイスからのマッピング情報を受信させるためのコンピュータ実行可能な命令を更に含む請求項37のコンピュータ読み取り可能な媒体。   38. The computer-readable instructions of claim 37, further comprising computer-executable instructions for causing the one or more processors to receive mapping information from the external graphics device that maps the graphics data to the graphics instructions. Medium. 前記パーティションは、前記グラフィックス・データ上で実行されるオペレーションのレンダリングに基づいて判定される請求項2のコンピュータ読み取り可能な媒体。   The computer-readable medium of claim 2, wherein the partition is determined based on a rendering of an operation performed on the graphics data. 表示デバイスと、
グラフィカル・シーン中に1又は複数のグラフィックス・イメージを前記表示デバイス上に表示し、
1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を前記表示デバイス上に表示し、
前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析するように構成される1又は複数のプロセッサとを含むデバイス。
A display device;
Displaying one or more graphics images on the display device during a graphical scene;
Displaying on the display device a graphical representation of a partition overlaying one or more graphics images and graphically dividing the scene;
Analyzing the graphics data to determine which portions of the graphics data for the one or more graphics images are associated with a plurality of the partitions. A device comprising one or more configured processors.
前記1又は複数のプロセッサは、前記1又は複数のグラフィックス・イメージの表示、複数のパーティションのグラフィカル表現の表示及び前記1又は複数のグラフィックス・イメージの前記複数のフレームに関するグラフィックス・データの解析を、繰り返し行うように更に構成される請求項41のデバイス。   The one or more processors display the one or more graphics images, display a graphical representation of a plurality of partitions, and analyze graphics data for the plurality of frames of the one or more graphics images. 42. The device of claim 41, further configured to repeat. 前記1又は複数のグラフィックス・イメージのうちの少なくとも一つは、3次元グラフィックス・イメージを含む請求項41のデバイス。   42. The device of claim 41, wherein at least one of the one or more graphics images comprises a three-dimensional graphics image. 前記1又は複数のプロセッサは、前記1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割する複数の長方形の形状のパーティションのグラフィカル表現を表示することに少なくともよって、前記複数のパーティションの前記グラフィカル表現を表示するように構成された請求項41のデバイス。   The one or more processors at least by displaying the graphical representation of a plurality of rectangular shaped partitions overlaying the one or more graphics images and graphically dividing the scene. 42. The device of claim 41, configured to display the graphical representation of: 前記グラフィックス・データは、前記1又は複数のグラフィックス・イメージをレンダリングするために使用される複数のグラフィックス・プリミティブを含む請求項41のデバイス。   42. The device of claim 41, wherein the graphics data includes a plurality of graphics primitives used to render the one or more graphics images. 前記複数のグラフィックス・プリミティブは、複数の三角形を含む請求項45のデバイス。   46. The device of claim 45, wherein the plurality of graphics primitives include a plurality of triangles. 前記1又は複数のプロセッサは、前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定することに少なくともよって、前記グラフィックス・データを解析するように構成された請求項46のデバイス。   47. The one or more processors are configured to analyze the graphics data at least by determining which of the triangles spans more than one of the partitions. Devices. 前記1又は複数のプロセッサは、前記三角形のうちのいずれの三角形が少なくとも部分的に前記パーティションのうちの複数のものにおいてレンダリングされたか判定することに少なくともよって、前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定するように構成された請求項47のデバイス。   The one or more processors at least determine which triangles of the triangles have been rendered at least partially in the plurality of partitions, so that any of the triangles is the 48. The device of claim 47, configured to determine whether a plurality of partitions are spanned. 前記1又は複数のプロセッサは、前記パーティションのうちの複数のものにわたる前記三角形のグラフィカル表現を表示するように更に構成された請求項47のデバイス。   48. The device of claim 47, wherein the one or more processors are further configured to display a graphical representation of the triangle across a plurality of the partitions. 前記1又は複数のプロセッサは、前記パーティションの前記グラフィカル表現を表示することと共に、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示することに少なくともよって、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示するように構成された請求項49のデバイス。   The one or more processors display the graphical representation of the partition and at least by displaying the graphical representation of the triangle across the plurality of the partitions. 50. The device of claim 49, configured to display the graphical representation of the triangle over a range. 前記1又は複数のプロセッサは、各々の三角形に関するグラフィカル・インジケーションを表示するすることに少なくともよって、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示し、
前記グラフィカル・インジケーションは、各々の対応する三角形によりわたられるパーティションの数のビジュアル・インジケーションを提供する請求項49のデバイス。
The one or more processors display the graphical representation of the triangles across a plurality of the partitions by at least displaying graphical indications for each triangle;
50. The device of claim 49, wherein the graphical indication provides a visual indication of the number of partitions spanned by each corresponding triangle.
各々の対応する三角形に関する前記グラフィカル・インジケーションは、色を含む請求項51のデバイス。   52. The device of claim 51, wherein the graphical indication for each corresponding triangle includes a color. 前記1又は複数のプロセッサは、他の三角形より多くのパーティションにわたるそれらの三角形に関する前記グラフィカル・インジケーションを顕著に表示することに少なくともよって、各々の三角形に関する前記グラフィカル・インジケーションを表示するように構成された請求項51のデバイス。   The one or more processors are configured to display the graphical indication for each triangle at least by prominently displaying the graphical indication for those triangles across more partitions than the other triangles 52. The device of claim 51, wherein: 前記1又は複数のプロセッサは、
外部グラフィックス・デバイスからパーティショニング情報を受信し、
前記受信されたパーティショニング情報に基づいて、前記複数のパーティションの前記グラフィカル表現を表示することに少なくともよって、
前記複数のパーティションの前記グラフィカル表現を表示するように構成された請求項41のデバイス。
The one or more processors are:
Receive partitioning information from an external graphics device,
At least by displaying the graphical representation of the plurality of partitions based on the received partitioning information.
42. The device of claim 41, configured to display the graphical representation of the plurality of partitions.
前記1又は複数のプロセッサは、
前記ナビゲーション・コントローラとインタラクトするためのユーザ入力を受信することと、
前記ナビゲーション・コントローラに対する前記ユーザ入力に基づいて、修正されたグラフィックス・シーン中の前記1又は複数のグラフィックス・イメージの修正された斜視図を表示することに少なくともよって、
ナビゲーション・コントローラを表示するように更に構成された請求項41のデバイス。
The one or more processors are:
Receiving user input to interact with the navigation controller;
At least by displaying a modified perspective view of the one or more graphics images in a modified graphics scene based on the user input to the navigation controller.
42. The device of claim 41, further configured to display a navigation controller.
前記1又は複数のプロセッサは、前記1又は複数のグラフィカル・イメージの前記修正された斜視図をオーバーレイし且つ前記修正されたシーンをグラフィカルに分割する前記複数のパーティションの前記グラフィカル表現を表示することに少なくともよって、前記複数のパーティションの前記グラフィカル表現を表示するように構成され、
前記1又は複数のプロセッサは、前記グラフィックス・データのうちのいずれの部分が前記複数のパーティションのうちの前記複数のパーティションに関連するかについて判定するために、前記1又は複数のグラフィックス・イメージの前記修正された斜視図に関するグラフィックス・データを解析することに少なくともよって、前記グラフィックス・データを解析するように構成された請求項55のデバイス。
The one or more processors displaying the graphical representation of the plurality of partitions overlaying the modified perspective view of the one or more graphical images and graphically dividing the modified scene; At least according to, configured to display the graphical representation of the plurality of partitions;
The one or more processors may determine the one or more graphics images to determine which portion of the graphics data is associated with the plurality of partitions of the plurality of partitions. 56. The device of claim 55, configured to analyze the graphics data at least by analyzing graphics data relating to the modified perspective view.
前記1又は複数のプロセッサは、
外部グラフィックス・デバイスからグラフィックス命令を受信し、
前記外部グラフィックス・デバイスからステート情報(該ステート情報は、前記外部グラフィックス・デバイス上での前記グラフィックス命令の実行に関連する)を受信するように更に構成され、
前記1又は複数のプロセッサは、前記グラフィックス命令及び前記ステート情報に基づいて、前記1又は複数のグラフィックス・イメージを表示することに少なくともよって、前記グラフィカル・シーン中に前記1又は複数のグラフィックス・イメージを表示するように構成された請求項41のデバイス。
The one or more processors are:
Receive graphics instructions from an external graphics device,
Further configured to receive state information from the external graphics device, the state information relating to execution of the graphics instructions on the external graphics device;
The one or more processors are configured to display the one or more graphics images in the graphical scene based at least on displaying the one or more graphics images based on the graphics instructions and the state information. 42. The device of claim 41, configured to display an image.
前記ステート情報は、前記1又は複数のグラフィックス・イメージに関する前記グラフィックス・データを含む請求項57のデバイス。   58. The device of claim 57, wherein the state information includes the graphics data for the one or more graphics images. 前記1又は複数のプロセッサは、前記グラフィックス・データを前記グラフィックス命令にマッピングする前記外部グラフィックス・デバイスからのマッピング情報を受信するように更に構成された請求項57のデバイス。   58. The device of claim 57, wherein the one or more processors are further configured to receive mapping information from the external graphics device that maps the graphics data to the graphics instructions. 前記パーティションは、前記グラフィックス・データ上で実行されるオペレーションのレンダリングに基づいて判定される請求項41のデバイス。   42. The device of claim 41, wherein the partition is determined based on a rendering of an operation performed on the graphics data. グラフィカル・シーン中に1又は複数のグラフィックス・イメージを表示するための手段と、
1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割するパーティションのグラフィカル表現を表示するための手段と、
前記1又は複数のグラフィックス・イメージに関するグラフィックス・データのうちのいずれの部分が前記パーティションのうちの複数のものに関連しているかについて判定するために、該グラフィックス・データを解析するための手段とを含むデバイス。
Means for displaying one or more graphics images in a graphical scene;
Means for displaying a graphical representation of a partition that overlays one or more graphics images and graphically divides the scene;
Analyzing the graphics data to determine which portion of the graphics data for the one or more graphics images is associated with a plurality of the partitions. A device comprising means.
前記1又は複数のグラフィックス・イメージの表示、複数のパーティションのグラフィカル表現の表示及び前記1又は複数のグラフィックス・イメージの前記複数のフレームに関するグラフィックス・データの解析を、繰り返し行うための手段を更に含む請求項61のデバイス。   Means for repeatedly displaying said one or more graphics images, displaying a graphical representation of a plurality of partitions, and analyzing graphics data for said plurality of frames of said one or more graphics images. 62. The device of claim 61, further comprising: 前記1又は複数のグラフィックス・イメージのうちの少なくとも1つは、3次元グラフィックス・イメージを含む請求項61のデバイス。   64. The device of claim 61, wherein at least one of the one or more graphics images comprises a three-dimensional graphics image. 前記複数のパーティションの前記グラフィカル表現を表示するための前記手段は、前記1又は複数のグラフィックス・イメージをオーバーレイし且つ前記シーンをグラフィカルに分割する複数の長方形の形状のパーティションのグラフィカル表現を表示するための手段を含む請求項61のデバイス。   The means for displaying the graphical representation of the plurality of partitions displays a graphical representation of a plurality of rectangular shaped partitions that overlay the one or more graphics images and graphically divide the scene. 62. The device of claim 61, comprising means for: 前記グラフィックス・データは、前記1又は複数のグラフィックス・イメージをレンダリングするために使用される複数のグラフィックス・プリミティブを含む請求項61のデバイス。   64. The device of claim 61, wherein the graphics data includes a plurality of graphics primitives used to render the one or more graphics images. 前記複数のグラフィックス・プリミティブは、複数の三角形を含む請求項65のデバイス。   66. The device of claim 65, wherein the plurality of graphics primitives include a plurality of triangles. 前記グラフィックス・データを解析するための前記手段は、前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定するための手段を含む請求項66のデバイス。   68. The device of claim 66, wherein the means for analyzing the graphics data includes means for determining which triangles of the triangles span multiple ones of the partitions. 前記三角形のうちのいずれの三角形が前記パーティションのうちの複数のものにわたるか判定するための前記手段は、前記三角形のうちのいずれの三角形が少なくとも部分的に前記パーティションのうちの複数のものにおいてレンダリングされたか判定するための手段を含む請求項67のデバイス。   The means for determining which one of the triangles spans a plurality of the partitions is the rendering of which one of the triangles is at least partially in the plurality of the partitions. 68. The device of claim 67, comprising means for determining whether it has been done. 前記パーティションのうちの複数のものにわたる前記三角形のグラフィカル表現を表示するための手段を更に含む請求項67のデバイス。   68. The device of claim 67, further comprising means for displaying a graphical representation of the triangle across a plurality of the partitions. 前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示するための前記手段は、前記パーティションの前記グラフィカル表現を表示することと共に、前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示するための手段を含む請求項69のデバイス。   The means for displaying the graphical representation of the triangle over a plurality of the partitions is displayed with the graphical representation of the triangle over the plurality of the partitions. 70. The device of claim 69, comprising means for displaying the representation. 前記パーティションのうちの複数のものにわたる前記三角形の前記グラフィカル表現を表示するための前記手段は、各々の三角形に関するグラフィカル・インジケーションを表示するための手段を含み、
前記グラフィカル・インジケーションは、各々の対応する三角形によりわたられるパーティションの数のビジュアル・インジケーションを提供する請求項69のデバイス。
The means for displaying the graphical representation of the triangle across a plurality of the partitions includes means for displaying a graphical indication for each triangle;
70. The device of claim 69, wherein the graphical indication provides a visual indication of the number of partitions spanned by each corresponding triangle.
各々の対応する三角形に関する前記グラフィカル・インジケーションは、色を含む請求項71のデバイス。   72. The device of claim 71, wherein the graphical indication for each corresponding triangle includes a color. 各々の三角形に関する前記グラフィカル・インジケーションを表示するための前記手段は、他の三角形より多くのパーティションにわたるそれらの三角形に関する前記グラフィカル・インジケーションを顕著に表示するするための手段を含む請求項71の方法。   72. The means for displaying the graphical indications for each triangle includes means for prominently displaying the graphical indications for those triangles across more partitions than other triangles. Method. 前記複数のパーティションの前記グラフィカル表現を表示するための前記手段は、
外部グラフィックス・デバイスからパーティショニング情報を受信するための手段と、
前記受信されたパーティショニング情報に基づいて、前記複数のパーティションの前記グラフィカル表現を表示するための手段とを含む請求項61のデバイス。
The means for displaying the graphical representation of the plurality of partitions comprises:
Means for receiving partitioning information from an external graphics device;
62. The device of claim 61, comprising: means for displaying the graphical representation of the plurality of partitions based on the received partitioning information.
ナビゲーション・コントローラを表示するための手段と、
前記ナビゲーション・コントローラとインタラクトするためのユーザ入力を受信するための手段と、
前記ナビゲーション・コントローラに対する前記ユーザ入力に基づいて、修正されたグラフィックス・シーン中の前記1又は複数のグラフィックス・イメージの修正された斜視図を表示するための手段とを更に含む請求項61のデバイス。
Means for displaying a navigation controller;
Means for receiving user input for interacting with the navigation controller;
62. means for displaying a modified perspective view of the one or more graphics images in a modified graphics scene based on the user input to the navigation controller. device.
前記複数のパーティションの前記グラフィカル表現を表示するための前記手段は、前記1又は複数のグラフィカル・イメージの前記修正された斜視図をオーバーレイし且つ前記修正されたシーンをグラフィカルに分割する前記複数のパーティションの前記グラフィカル表現を表示するための手段を含み、
前記グラフィックス・データを解析するための前記手段は、前記グラフィックス・データのうちのいずれの部分が前記複数のパーティションのうちの前記複数のパーティションに関連するかについて判定するために、前記1又は複数のグラフィックス・イメージの前記修正された斜視図に関するグラフィックス・データを解析するための手段を含む請求項75のデバイス。
The means for displaying the graphical representation of the plurality of partitions overlays the modified perspective view of the one or more graphical images and graphically divides the modified scene. Means for displaying said graphical representation of
The means for analyzing the graphics data is to determine which portion of the graphics data is associated with the plurality of partitions of the plurality of partitions. 76. The device of claim 75, comprising means for analyzing graphics data relating to the modified perspective view of a plurality of graphics images.
外部グラフィックス・デバイスからグラフィックス命令を受信するための手段と、
前記外部グラフィックス・デバイスからステート情報(該ステート情報は、前記外部グラフィックス・デバイス上での前記グラフィックス命令の実行に関連する)を受信するための手段とを更に含み、
前記グラフィカル・シーン中に前記1又は複数のグラフィックス・イメージを表示するための前記手段は、前記グラフィックス命令及び前記ステート情報に基づいて、前記1又は複数のグラフィックス・イメージを表示するための手段を含む請求項61のデバイス。
Means for receiving graphics instructions from an external graphics device;
Means for receiving state information from said external graphics device, said state information relating to execution of said graphics instructions on said external graphics device;
The means for displaying the one or more graphics images in the graphical scene is for displaying the one or more graphics images based on the graphics instructions and the state information. 62. The device of claim 61, comprising means.
前記ステート情報は、前記1又は複数のグラフィックス・イメージに関する前記グラフィックス・データを含む請求項77のデバイス。   78. The device of claim 77, wherein the state information includes the graphics data relating to the one or more graphics images. 前記グラフィックス・データを前記グラフィックス命令にマッピングする前記外部グラフィックス・デバイスからのマッピング情報を受信するための手段を更に含む請求項77のデバイス。   78. The device of claim 77, further comprising means for receiving mapping information from the external graphics device that maps the graphics data to the graphics instructions. 前記パーティションは、前記グラフィックス・データ上で実行されるオペレーションのレンダリングに基づいて判定される請求項61のデバイス。   62. The device of claim 61, wherein the partition is determined based on a rendering of an operation performed on the graphics data.
JP2011520245A 2008-07-25 2009-07-24 Partition-based performance analysis for graphics imaging Expired - Fee Related JP5242788B2 (en)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US8365908P 2008-07-25 2008-07-25
US61/083,659 2008-07-25
US12/507,767 2009-07-22
US12/507,767 US20100020069A1 (en) 2008-07-25 2009-07-22 Partitioning-based performance analysis for graphics imaging
PCT/US2009/051772 WO2010011980A1 (en) 2008-07-25 2009-07-24 Partitioning-based performance analysis for graphics imaging

Publications (2)

Publication Number Publication Date
JP2011529236A true JP2011529236A (en) 2011-12-01
JP5242788B2 JP5242788B2 (en) 2013-07-24

Family

ID=41268228

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2011520245A Expired - Fee Related JP5242788B2 (en) 2008-07-25 2009-07-24 Partition-based performance analysis for graphics imaging

Country Status (7)

Country Link
EP (1) EP2319015A1 (en)
JP (1) JP5242788B2 (en)
KR (1) KR101286938B1 (en)
CN (1) CN102089784A (en)
CA (1) CA2730298A1 (en)
TW (1) TW201015483A (en)
WO (1) WO2010011980A1 (en)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2745892B1 (en) * 2012-12-21 2018-12-12 Dassault Systèmes Partition of a 3D scene into a plurality of zones processed by a computing resource
JP6392370B2 (en) 2014-04-05 2018-09-19 ソニー インタラクティブ エンタテインメント アメリカ リミテッド ライアビリテイ カンパニー An efficient re-rendering method for objects to change the viewport under various rendering and rasterization parameters
CN109656106B (en) * 2019-01-25 2020-12-04 墨研计算科学(南京)有限公司 Processing method and device for mask in computational lithography
CN110221715A (en) * 2019-06-19 2019-09-10 南京孜博汇信息科技有限公司 A kind of multi-interface displaying method and system of motion track information

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5701405A (en) * 1995-06-21 1997-12-23 Apple Computer, Inc. Method and apparatus for directly evaluating a parameter interpolation function used in rendering images in a graphics system that uses screen partitioning
JPH10111815A (en) * 1996-08-13 1998-04-28 Nec Corp Debugging system
WO2005031640A2 (en) * 2003-09-26 2005-04-07 Rensselaer Polytechnic Institute System and method of computing and displaying property-encoded surface translator descriptors
US20050285850A1 (en) * 2004-06-29 2005-12-29 Heim Oliver A Methods and apparatuses for a polygon binning process for rendering
WO2007002952A2 (en) * 2005-06-29 2007-01-04 Qualcomm Incorporated Visual debugging system for 3d user interface program
JP2008500625A (en) * 2004-05-24 2008-01-10 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ Tile-based graphic rendering

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030156131A1 (en) * 2002-02-21 2003-08-21 Samir Khazaka Method and apparatus for emulating a mobile device
US7095416B1 (en) * 2003-09-22 2006-08-22 Microsoft Corporation Facilitating performance analysis for processing
DE102006014902B4 (en) * 2006-03-30 2009-07-23 Siemens Ag Image processing device for the extended display of three-dimensional image data sets

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5701405A (en) * 1995-06-21 1997-12-23 Apple Computer, Inc. Method and apparatus for directly evaluating a parameter interpolation function used in rendering images in a graphics system that uses screen partitioning
JPH10111815A (en) * 1996-08-13 1998-04-28 Nec Corp Debugging system
WO2005031640A2 (en) * 2003-09-26 2005-04-07 Rensselaer Polytechnic Institute System and method of computing and displaying property-encoded surface translator descriptors
JP2008500625A (en) * 2004-05-24 2008-01-10 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ Tile-based graphic rendering
US20050285850A1 (en) * 2004-06-29 2005-12-29 Heim Oliver A Methods and apparatuses for a polygon binning process for rendering
WO2007002952A2 (en) * 2005-06-29 2007-01-04 Qualcomm Incorporated Visual debugging system for 3d user interface program

Also Published As

Publication number Publication date
WO2010011980A1 (en) 2010-01-28
JP5242788B2 (en) 2013-07-24
CA2730298A1 (en) 2010-01-28
EP2319015A1 (en) 2011-05-11
CN102089784A (en) 2011-06-08
KR101286938B1 (en) 2013-07-23
KR20110036947A (en) 2011-04-12
TW201015483A (en) 2010-04-16

Similar Documents

Publication Publication Date Title
JP5242789B2 (en) Mapping of graphics instructions to related graphics data in performance analysis
JP5437485B2 (en) Display a visual representation of performance metrics for rendered graphics elements
US20100020069A1 (en) Partitioning-based performance analysis for graphics imaging
TWI584223B (en) Method and system of graphics processing enhancement by tracking object and/or primitive identifiers,graphics processing unit and non-transitory computer readable medium
JP6230076B2 (en) Virtual surface assignment
JP5450624B2 (en) Performance analysis in visual creation of graphics images
JP2011008789A (en) Graphic analysis technique
US20210366176A1 (en) Shadow culling
JP5242788B2 (en) Partition-based performance analysis for graphics imaging
Kelleher Pixelvision architecture
Renhart Fast Map Rendering for Mobile Devices

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20120723

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20120821

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20121113

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20121120

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130121

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20130403

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20160412

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

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

LAPS Cancellation because of no payment of annual fees