JP4505866B2 - 画像処理装置および映像信号処理方法 - Google Patents
画像処理装置および映像信号処理方法 Download PDFInfo
- Publication number
- JP4505866B2 JP4505866B2 JP05179599A JP5179599A JP4505866B2 JP 4505866 B2 JP4505866 B2 JP 4505866B2 JP 05179599 A JP05179599 A JP 05179599A JP 5179599 A JP5179599 A JP 5179599A JP 4505866 B2 JP4505866 B2 JP 4505866B2
- Authority
- JP
- Japan
- Prior art keywords
- data
- pixel data
- circuit
- processing
- data processing
- 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.)
- Expired - Lifetime
Links
- 238000012545 processing Methods 0.000 title claims description 191
- 238000003672 processing method Methods 0.000 title claims description 13
- 238000004364 calculation method Methods 0.000 claims description 180
- 238000000034 method Methods 0.000 description 38
- 230000008569 process Effects 0.000 description 34
- 238000009877 rendering Methods 0.000 description 28
- 238000002156 mixing Methods 0.000 description 21
- 238000010586 diagram Methods 0.000 description 17
- 239000000203 mixture Substances 0.000 description 14
- 238000001514 detection method Methods 0.000 description 13
- 230000009467 reduction Effects 0.000 description 9
- 239000000470 constituent Substances 0.000 description 4
- 230000006870 function Effects 0.000 description 3
- 238000013507 mapping Methods 0.000 description 3
- 238000012546 transfer Methods 0.000 description 3
- 238000011960 computer-aided design Methods 0.000 description 2
- 238000011161 development Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 230000007480 spreading Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G5/00—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
- G09G5/36—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of a graphic pattern, e.g. using an all-points-addressable [APA] memory
- G09G5/39—Control of the bit-mapped memory
- G09G5/393—Arrangements for updating the contents of the bit-mapped memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T1/00—General purpose image data processing
- G06T1/20—Processor architectures; Processor configuration, e.g. pipelining
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2330/00—Aspects of power supply; Aspects of display protection and defect management
- G09G2330/02—Details of power systems and of start or stop of display operation
- G09G2330/021—Power management, e.g. power saving
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Image Processing (AREA)
- Image Generation (AREA)
- Processing Or Creating Images (AREA)
- Ink Jet (AREA)
Description
【発明の属する技術分野】
本発明は、低消費電力化を図ることが出来る画像処理装置(映像信号処理装置)およびその方法(映像信号処理方法)に関する。
【0002】
【従来の技術】
種々のCAD(Computer Aided Design) システムや、アミューズメント装置などにおいて、コンピュータグラフィックスがしばしば用いられている。特に、近年の画像処理技術の進展に伴い、3次元コンピュータグラフィックスを用いたシステムが急速に普及している。
このような3次元コンピュータグラフィックスでは、各画素(ピクセル)に対応する色を決定するときに、各画素の色の値を計算し、この計算した色の値を、当該画素に対応するディスプレイバッファ(フレームバッファ)のアドレスに書き込むレンダリング(Rendering) 処理を行う。
レンダリング処理の手法の一つに、ポリゴン(Polygon)レンダリングがある。この手法では、立体モデルを三角形の単位図形(ポリゴン)の組み合わせて多角形として表現し、このポリゴンを単位として処理を行い、描画することで、表示画面の色を決定する。
【0003】
ポリゴンレンダリングでは、物理座標系における三角形を組み合わせた多角形の各頂点についての、座標(x,y,z)と、色データ(R,G,B,α)と、張り合わせのイメージパターンを示すテクスチャデータの同次座標(s,t)および同次項qの値とを入力とし、これらの値を三角形の内部で補間する処理が行われる。
ここで、同次項qは、簡単にいうと、拡大縮小率のようなもので、実際のテクスチャバッファのUV座標系における座標、すなわち、テクスチャ座標データ(u,v)は、同次座標(s,t)を同次項qで除算した「s/q」および「t/q」に、それぞれテクスチャサイズUSIZEおよびVSIZEを乗じたものとなる。
このような3次元コンピュータグラフィックシステムでは、例えば、ディスプレイバッファ(フレームバッファ)に描画を行う際に、画素毎に、テクスチャ座標データ(u,v)を用いてテクスチャバッファからテクスチャデータを読み出し、この読み出したテクスチャデータを、立体モデルの表面に三角形を単位として張り付けるテクスチャマッピング処理を行う。
なお、立体モデルでのテクスチャマッピング処理では、各画素毎に、張り付けを行なうテクスチャデータが示す画像の拡大縮小率が変化する。
【0004】
ところで、このような3次元コンピュータグラフィックシステムでは、例えば、所定の矩形内の8画素についての処理を並行して(同時に)行う場合がある。
また、前述したような三角形を単位図形とした多角形(ポリゴン)レンダリングでは、張り付けを行うテクスチャデータの縮小率などは、三角形を単位として決定される。
従って、並行して処理を行った8画素分の演算結果のうち、対象となる三角形の外部に位置する画素については使用しないからその演算結果は無効(無意味)になる。
具体的には、図12に示すように、三角形30について所定の演算を行って縮小率を決定し、当該縮小率に応じたテクスチャデータを用いてテクスチャマッピング処理を行っている場合を考える。
ここで、矩形31,32,33は、それぞれ並行して処理される8(2×4)画素が配置された領域であり、ポリゴンレンダリング処理において、各矩形内に属する8画素については同じテクスチャデータが用いられる。
図12に示す場合には、矩形32に属する8画素は全て三角形30内に位置するため、8画素の演算結果は全て有効「1」である。これに対して、矩形31,33にそれぞれ属する8画素は、3画素は三角形30内に位置するが、5画素は三角形30の外に位置する。従って、8画素の演算結果のうち、3画素の演算結果は有効であるが、5画素の演算結果は無効となる。
従来では、矩形内に位置する8画素の全てについて、ポリゴンレンダリング処理を無条件に行っていた。
【0005】
【発明が解決しようとする課題】
しかしながら、上述したように、三角形を単位図形としたポリゴンレンダリング処理を行なう場合に、矩形内に位置する複数の画素の全てについての処理を、対象となっている三角形の内部に位置するか否かとは無関係に実行すると、膨大な数の無効な(無意味な)演算を行うことになり、演算処理回路の消費電力に大きな影響を及ぼす。
また、3次元コンピュータグラフィックシステムでは、上述した理由の他にも、種々の要因で不要な演算を行うことがある。
また、近年、3次元コンピュータグラフィックシステムの動作クロック周波数は非常に高くなっているため、演算処理回路の電力消費が増大しており、消費電力の低下が大きな課題になっている。
【0006】
本発明は上述した従来技術の問題点に鑑みてなされ、消費電力の大幅な低下を図ることが可能な画像処理装置(映像信号処理装置)およびその方法(映像信号処理方法)を提供することを目的とする。
【0007】
【課題を解決するための手段】
本発明によれば、同時に処理を行おうとする複数の画素毎にそれぞれ設けられ、それぞれ対応する画素データを受け、相互に並列にデータ処理を行う、複数の画素データ処理回路と、前記各画素データ処理回路に入力する前記画素データの少なくとも一部として含まれる演算の有効性を示すフラグに基づいて前記画素毎のデータ処理を対応する前記画素データ処理回路が行う必要がないと論理判断した場合に対応する各画素データ処理回路の動作を停止する制御手段とを有し、
前記画素データ処理回路の各々は、システムクロック信号から生成された画素データ処理回路駆動用クロック信号に基づいて動作してパイプライン処理を行うように相互に直列接続された、複数の処理回路を有し、
前記各画素データ処理回路内の直列に接続された前記複数の処理回路は、当該各処理回路を制御する前記演算を有効性を示すフラグが転送されることにより、前記パイプライン処理および前記画素データ処理回路駆動用クロック信号の供給の制御を行い、
前記制御手段は、前記演算の有効性を示すフラグに基づいて前記画素データ処理回路のデータ処理を行う必要のない各処理回路への前記画素データ処理回路駆動用クロック信号の供給を停止する、
画像処理装置が提供される。
【0011】
また好ましくは、前記画素データ処理回路の各々は、パイプライン処理を行うように相互に直列に接続された複数の処理回路を有する。
【0012】
好ましくは、前記画素データ処理回路内の直列に接続された複数の処理回路は、各処理回路を制御するフラグが転送されることによって、前記パイプライン処理および前記画素データ処理回路駆動用クロック信号の供給の制御を行う。
【0013】
好ましくは、前記画素データ処理回路は、画素のR(赤),G(緑),B(青)の出力を決定する画素データについての処理を行う。
【0016】
本発明によれば、同時に処理を行おうとする複数の画素毎にそれぞれ設けられ、それぞれ対応する画素データを受け、相互に並列にデータ処理する複数の画素データ処理回路を用いて画像処理を行う画像処理方法において、
前記画素データ処理回路の各々は、システムクロック信号から生成された画素データ処理回路駆動用クロック信号に基づいて動作してパイプライン処理を行うように相互に直列接続された複数の処理回路を有しており、
前記各画素データ処理回路内の直列に接続された複数の処理回路は、各処理回路を制御する前記演算の有効性を示すフラグが転送されることにより、当該転送される演算の有効性を示すフラグに基づいて、前記パイプライン処理および前記画素データ処理回路駆動用クロック信号の供給の制御を行い、
前記画素データに含まれる演算の有効性を示すフラグに基づいて、前記画素毎のデータ処理を対応する前記画素データ処理回路が行う必要がないと論理判断して対応する画素データ処理回路の動作を停止させるとき、当該画素データ処理回路のデータ処理を行う必要のない処理回路への前記画素データ処理回路駆動用クロック信号の供給を停止する、
ことを特徴とする、画像処理方法が提供される。
【0018】
好ましくは、前記画素データ処理回路の各々は、直列に接続された複数の処理回路でパイプライン処理を行う。
また好ましくは、前記画素データ処理回路内の直列に接続された複数の処理回路は、各処理回路を制御するフラグが転送されることにより、前記パイプライン処理および前記画素データ処理回路駆動用クロック信号の供給の制御を行う。
好ましくは、前記画素データ処理は、画素のR(赤),G(緑),B(青)の出力を決定する画素データについての処理を行う。
【0019】
【発明の実施の形態】
本発明の映像信号処理装置(画像処理装置)と映像信号処理方法(画像処理方法)の実施の形態を述べる。
以下、本実施形態においては、家庭用ゲーム機などに適用される、任意の3次元物体モデルに対する所望の3次元画像をCRT(Cathode Ray Tube)などのディスプレイ上に高速に表示する3次元コンピュータグラフィックシステムについて説明する。
第1実施形態
図1は、本実施形態の3次元コンピュータグラフィックシステム1のシステム構成図である。
3次元コンピュータグラフィックシステム1は、立体モデルを単位図形である三角形(ポリゴン)の張り合わせとして表現し、このポリゴンを描画することで表示画面の各画素の色を決定し、ディスプレイに表示するポリゴンレンダリング処理を行うシステムである。
また、3次元コンピュータグラフィックシステム1では、平面上の位置を表現する(x,y)座標の他に、奥行きを表すz座標を用いて3次元物体を表し、この(x,y,z)の3つの座標で3次元空間の任意の一点を特定する。
【0020】
図1に示すように、3次元コンピュータグラフィックシステム1では、メインメモリ2、I/Oインタフェース回路3、メインプロセッサ4およびレンダリング回路5が、メインバス6を介して接続されている。
以下、各構成要素の機能について説明する。
メインプロセッサ4は、例えば、ゲームの進行状況などに応じて、メインメモリ2から必要なグラフィックデータを読み出し、このグラフィックデータに対してクリッピング(Clipping)処理、ライティング(Lighting)処理およびジオメトリ(Geometry)処理などを行い、ポリゴンレンダリングデータを生成する。メインプロセッサ4は、ポリゴンレンダリングデータS4を、メインバス6を介してレンダリング回路5に出力する。
I/Oインタフェース回路3は、必要に応じて、外部からポリゴンレンダリングデータを入力し、これをメインバス6を介してレンダリング回路5に出力する。
【0021】
ここで、ポリゴンレンダリングデータは、ポリゴンの各3頂点の(x,y,z,R,G,B,α,s,t,q)のデータを含んでいる。
(x,y,z)データは、ポリンゴの頂点の3次元座標を示し、(R,G,B)データは、それそれ当該3次元座標における赤、緑、青の輝度値を示している。
αデータは、これから描画する画素と、ディスプレイバッファ21に既に記憶されている画素とのR,G,Bデータのブレンド(混合)係数を示している。
(s,t,q)データのうち、(s,t)は、対応するテクスチャの同次座標を示しており、qは同次項を示している。ここで、「s/q」および「t/q」に、それぞれテクスチャサイズUSIZEおよびVSIZEを乗じてテクスチャ座標データ(u,v)が得られる。テクスチャバッファ20に記憶されたテクスチャデータへのアクセスは、テクスチャ座標データ(u,v)を用いて行われる。
すなわち、ポリゴンレンダリングデータは、多角形を構成する三角形の各頂点
の物理座標値と、それぞれの頂点の色とテクスチャデータの同次座標および同次項を示している。
【0022】
以下、レンダリング回路5について詳細に説明する。
図1に示すように、レンダリング回路5は、DDA(Digital Differential Analizer、ディジタル変分(差分)分析器) セットアップ回路10、トライアングルDDA回路11、テクスチャエンジン回路12、メモリI/F回路13、CRTコントローラ回路14、RAMDAC回路15、DRAM16およびSRAM17を有する。
DRAM16は、テクスチャバッファ20、ディスプレイバッファ21、zバッファ22およびテクスチャCLUTバッファ23として機能する。
【0023】
DDAセットアップ回路10
DDAセットアップ回路10は、後段のトライアングルDDA回路11において物理座標系上の三角形の各頂点の値を線形補間して三角形の内部の各画素の色と深さ情報を求めるのに先立ち、ポリゴンレンダリングデータS4が示す(z,R,G,B,α,s,t,q)データについて、三角形の辺と水平方向の差分(または変分)を求めるセットアップ演算を行う。
このセットアップ演算は、具体的には、開始点の値と終点の値と、開始点と終点との距離を用いて、単位長さ移動した場合における、求めようとしている値の変分を算出する。
【0024】
また、DDAセットアップ回路10は、同時に処理を行う8画素のそれぞれについて、処理対象となる三角形の内部に位置するか否かを示す1ビットの有効指示データvalを決定する。具体的には、有効指示データvalは、三角形の内部に位置する画素について「1」とし、三角形の外部に位置する画素について「0」とする。
DDAセットアップ回路10は、算出した変分データS10と、各画素の有効指示データvalとをトライアングルDDA回路11に出力する。
【0025】
トライアングルDDA回路11
トライアングルDDA回路11は、DDAセットアップ回路10から入力した変分データS10を用いて、三角形内部の各画素の線形補間された(z,R,G,B,α,s,t,q)データを算出する。
トライアングルDDA回路11は、各画素の(x,y)データと、当該(x,y)座標の画素についての(z,R,G,B,α,s,t,q,val)データとを、DDAデータ(補間データ)S11としてテクスチャエンジン回路12に出力する。
本実施形態では、トライアングルDDA回路11は、並行して処理を行う矩形内に位置する8画素分のDDAデータS11を単位としてテクスチャエンジン回路12に出力する。
【0026】
ここで、DDAデータS11の(z,R,G,B,α,s,t,q,val)データは、図2に示すように、161ビットのデータである。
具体的には、R,G,B,αデータがそれぞれ8ビットであり、z,s,t,qデータがそれぞれ32ビットであり、valデータが1ビットである。
なお、以下、並行して処理を行う8画素についての(z,R,G,B,α,s,t,q,val)データのうち、valデータをvalデータS2201 〜S2208 とし、(z,R,G,B,α,s,t,q)データを被演算データS2211 〜S2218 とする。
すなわち、トライアングルDDA回路11は、8画素分の(x,y)データと、valデータS2201 〜S2208 と、被演算データS2211 〜S2218 からなるDDAデータS11をテクスチャエンジン回路12に出力する。
【0027】
テクスチャエンジン回路12およびメモリI/F回路13
テクスチャエンジン回路12による、DDAデータS11を用いた、「s/q」および「t/q」の算出処理、テクスチャ座標データ(u,v)の算出処理、および、テクスチャバッファ20からの(R,G,B,α)データの読み出し処理と、メモリI/F回路13によるz比較処理および混合処理とを、図3に示す演算ブロック200,201,202,204,205でパイプライン方式で順に実行する。
ここで、演算ブロック200,201,202,204,205は、それぞれ8個の演算サブブロックを内蔵しており、8画素分の演算処理を並行して行う。
ここで、テクスチャエンジン回路12が演算ブロック200,201,202を内蔵し、メモリI/F回路13が演算ブロック204,205を内蔵している。
【0028】
〔演算ブロック200〕
演算ブロック200は、DDAデータS11に含まれる(s,t,q)データを用いて、sデータをqデータで除算する演算と、tデータをqデータで除算する演算とを行う。
演算ブロック200は、図3に示すように、8個の演算サブブロック20051〜2008を内蔵する。
ここで、演算サブブロック2001は、被演算データS2211およびvalデータS2201を入力し、valデータS2201が「1」、すなわち有効であることを示す場合には、「s/q」および「t/q」を算出し、その算出結果を除算結果S2001として演算ブロック201の演算サブブロック2011に
出力する。
【0029】
また、演算サブブロック2001は、valデータS2201が「0」、すなわち無効であることを示す場合には、演算は行わず、除算結果S2001を出力しないか、あるいは、所定の仮値を示す除算結果S2001を演算ブロック201の演算サブブロック2011に出力する。
また、演算サブブロック2001は、valデータS2201を後段の演算サブブロック2011に出力する。
なお、演算サブブロック2002〜2008も、それぞれ対応する画素について、演算サブブロック2001と同じ演算を行い、それぞれ除算結果S20052〜S2008およびvalデータS2202〜S2208を後段の演算ブロック201の演算サブブロック2012〜2018にそれぞれ出力する。
【0030】
図4は、演算サブブロック2001 の内部構成図である。
なお、図3に示す、全ての演算サブブロックは、基本的に、図4に示す構成をしている。
図4に示すように、演算サブブロック2001 は、クロックイネーブラ2101 、データ用フリップフロップ222、プロセッサエレメント223およびフラグ用フリップフロップ224を有する。
クロックイネーブラ2101 は、システムクロック信号S225を基準としたタイミングでvalデータS2201 を入力し、valデータS2201 のレベルを検出する。そして、クロックイネーブラ2101 は、valデータS2201 が、「1」である場合には、例えば、クロック信号S2101 にパルス発生させ、「0」である場合には、クロック信号S2101 にパルス発生させない。
【0031】
データ用フリップフロップ222は、クロック信号S2101 のパルスを検出すると、被演算データS2211 を取り込み、プロセッサエレメント223に出力する。
プロセッサエレメント223は、入力した被演算データS2211 を用いて前述した除算を行い、除算結果S2001 を演算サブブロック2011 のデータ用フリップフロップ222に出力する。
フラグ用フリップフロップ224は、システムクロック信号S225を基準としたタイミングで、valデータS2201 を取り込み、後段の演算ブロック201の演算サブブロック2011 のフラグ用フリップフロップ224に出力する。
なお、システムクロック信号S225は、図3に示す全ての演算サブブロック2001 〜2008 ,2011 〜2018 ,2021 〜2028 ,2041 〜2048 のクロックイネーブラおよびフラグ用フリップフロップ224に供給される。
すなわち、演算サブブロック2001 〜2008 ,2011 〜2018 ,2021 〜2028 ,2041 〜2048 における処理は同期して行われ、同一の演算ブロックに内蔵された8個の演算サブブロックは並行して処理を行う。
【0032】
〔演算ブロック201〕
演算ブロック201は、演算サブブロック2011 〜2018 を有し、演算ブロック200から入力した除算結果S2001 〜S2008 が示す「s/q」および「t/q」に、それぞれテクスチャサイズUSIZEおよびVSIZEを乗じて、テクスチャ座標データ(u,v)を生成する。
演算サブブロック2011 〜2018 は、それぞれクロックイネーブラ2111 〜2118 によりvalデータS2201 〜S2208 のレベル検出を行った結果、当該レベルが「1」の場合にのみ演算を行い、それぞれ演算結果であるテクスチャ座標データS2011 〜S2018 を、演算ブロック202の演算サブブロック2021 〜2028 に出力する。
【0033】
〔演算ブロック202〕
演算ブロック202は、演算サブブロック2021 〜2028 を有し、メモリI/F回路13を介して、SRAM17あるいはDRAM16に、演算ブロック201で生成したテクスチャ座標データ(u,v)を含む読み出し要求を出力し、メモリI/F回路13を介して、SRAM17あるいはテクスチャバッファ20に記憶されているテクスチャデータを読み出すことで、(u,v)データに対応したテクスチャアドレスに記憶された(R,G,B,α)データS17を得る。
なお、テクスチャバッファ20には、MIPMAP(複数解像度テクスチャ)などの複数の縮小率に対応したテクスチャデータが記憶されている。ここで、何れの縮小率のテクスチャデータを用いるかは、所定のアルゴリズムを用いて、前記三角形を単位として決定される。
また、SRAM17には、テクスチャバッファ20に記憶されているテクスチャデータのコピーが記憶されている。
演算サブブロック2021 〜2028 は、それぞれクロックイネーブラ2121 〜2128 によりvalデータS2201 〜S2208 のレベル検出を行った結果、当該レベルが「1」の場合にのみ読み出し処理を行い、それぞれ読み出した(R,G,B,α)データS17を、(R,G,B,α)データS2021 〜S2028 として、それぞれ演算ブロック203の演算サブブロック2031 〜2038 に出力する。
【0034】
なお、テクスチャエンジン回路12は、フルカラー方式の場合には、テクスチャバッファ20から読み出した(R,G,B,α)データを直接用いる。一方、テクスチャエンジン回路12は、インデックスカラー方式の場合には、予め作成したカラールックアップテーブル(CLUT)をテクスチャCLUTバッファ23から読み出して、内蔵するSRAMに転送および記憶し、このカラールックアップテーブルを用いて、テクスチャバッファ20から読み出したカラーインデックスに対応する(R,G,B)データを得る。
【0035】
〔演算ブロック203〕
演算ブロック203は、演算サブブロック2031 〜2038 を有し、演算ブロック202から入力したテクスチャデータである(R,G,B.α)データS2021 〜S2028 と、トライアングルDDA回路11からのDDAデータS11に含まれる(R,G,B)データとを、(R,G,B.α)データS2021 〜S2028 に含まれるαデータ(テクスチャα)が示す割合で混合し、(R,G,B)混合データを生成する。
そして、演算ブロック203は、生成された(R,G,B)混合データと、対応するDDAデータS11に含まれるαデータとを含む(R,G,B,α)データS2031 〜S2038 を、演算ブロック204に出力する。
演算サブブロック2031 〜2038 は、それぞれクロックイネーブラ2131 〜2138 によりvalデータS2201 〜S2208 のレベル検出を行った結果、当該レベルが「1」の場合にのみ上記混合および(R,G,B,α)データS2031 〜S2038 の出力を行う。
【0036】
〔演算ブロック204〕
演算ブロック204は、演算サブブロック2041 〜2048 を有し、入力した(R,G,B,α)データS2031 〜S2038 について、zバッファ22に記憶されたzデータの内容を用いて、z比較を行い、(R,G,B,α)データS2031 〜S2038 によって描画する画像が、前回、ディスプレイバッファ21に描画した値よりも手前(視点側)に位置する場合には、zバッファ22を更新すると共に、(R,G,B,α)データS2031 〜S2038 を、(R,G,B,α)データS2041 〜S2048 として、それぞれ演算ブロック205の演算サブブロック2051 〜2058 に出力する。
演算サブブロック2041 〜2048 は、それぞれクロックイネーブラ2141 〜2148 によりvalデータS2201 〜S2208 のレベル検出を行った結果、当該レベルが「1」の場合にのみ上述したz比較および(R,G,B,α)データS2041 〜S2048 の出力を行なう。
【0037】
〔演算ブロック205〕
演算ブロック205は、演算サブブロック2051 〜2058 を有し、入力した(R,G,B,α)データS2041 〜S2048 と、既にディスプレイバッファ21に記憶されている(R,G,B)データとを、それぞれ(R,G,B,α)データS2041 〜S2048 に含まれるαデータが示す混合値で混合し、混合後の(R,G,B)データS2051 〜S2058 をディスプレイバッファ21に書き込む(打ち込む)。
なお、メモリI/F回路13によるDRAM16に対してのアクセスは、16画素について同時に行なわれる。
演算サブブロック2051 〜2058 は、それぞれクロックイネーブラ2151 〜2158 によりvalデータS2201 〜S2208 のレベル検出を行った結果、当該レベルが「1」の場合にのみ上述した混合処理およびディスプレイバッファ21への書き込み処理を行う。
【0038】
CRTコントローラ回路14
CRTコントローラ回路14は、与えられた水平および垂直同期信号に同期して、図示しないCRTに表示するアドレスを発生し、ディスプレイバッファ21から表示データを読み出す要求をメモリI/F回路13に出力する。この要求に応じて、メモリI/F回路13は、ディスプレイバッファ21から一定の固まりで表示データを読み出す。CRTコントローラ回路14は、ディスプレイバッファ21から読み出した表示データを記憶するFIFO(First In First Out)回路を内蔵し、一定の時間間隔で、RAMDAC回路15に、RGBのインデックス値を出力する。
【0039】
RAMDAC回路15
RAMDAC回路15は、各インデックス値に対応するR,G,Bデータを記憶しており、CRTコントローラ回路14から入力したRGBのインデックス値に対応するデジタル形式のR,G,Bデータを、D/Aコンバータに転送し、アナログ形式のR,G,Bデータを生成する。RAMDAC回路15は、この生成されたR,G,BデータをCRTに出力する。
【0040】
以下、3次元コンピュータグラフィックシステム1の全体動作について説明する。
ポリゴンレンダリングデータS4が、メインバス6を介してメインプロセッサ4からDDAセットアップ回路10に出力され、DDAセットアップ回路10において、三角形の辺と水平方向の差分などを示す変分データS10が生成される。
この変分データS10は、トライアングルDDA回路11に出力され、トライアングルDDA回路11において、三角形内部の各画素における線形補間された(z,R,G,B,α,s,t,q)データが算出される。そして、この算出された(z,R,G,B,α,s,t,q)データと、三角形の各頂点の(x,y)データとが、DDAデータS11として、トライアングルDDA回路11からテクスチャエンジン回路12に出力される。
【0041】
次に、テクスチャエンジン回路12およびメモリI/F回路13において、DDAデータS11を用いて、「s/q」および「t/q」の算出処理、テクスチャ座標データ(u,v)の算出処理、テクスチャバッファ20からのデジタルデータとしての(R,G,B,α)データの読み出し処理、混合処理、および、ディスプレイバッファ21への書き込み処理が、図3に示す演算ブロック200,201,202,,203,204,205でパイプライン方式で順に実行される。
【0042】
次に、図3に示すテクスチャエンジン回路12およびメモリI/F回路13のパイプライン処理の動作について説明する。
ここでは、例えば、図6に示すような矩形31内の8画素について同時処理する場合を考える。この場合には、valデータS2201 ,S2202 ,S2203 ,S2205 ,S2206 が「0」を示し、valデータS2204 ,S2207 ,S2208 が「1」を示している。
【0043】
valデータS2201〜S2208および被演算データS2211〜S2218が、それぞれ対応する演算サブブロック2001〜2008のクロックイネーブラ2101〜2108に入力される。
そして、クロックイネーブラ2101〜2108において、それぞれvalデータS2201〜S2208のレベルが検出される。具体的には、クロックイネーブラ2104,2107,2108において「1」が検出され、クロックイネーブラ2101,2102,2103,2105,2106において「0」が検出される。
その結果、演算サブブロック2004,2007,2008においてのみ、被演算データS2214,S2217,S2218を用いて、「s/q」および「t/q」が算出され、当該除算結果S2004,S2007,S2008が演算ブロック201の演算ブロック2014,2017,2018に出力される。
一方、演算サブブロック2001,2002,2003,2005,20056では、除算は行なわれない。
また、除算結果S2004,S2007,S2008の出力と同期して、valデータS2201〜S2208が、演算ブロック201の演算サブブロック2011〜2018に出力される。
【0044】
次に、演算サブブロック2011〜2018のクロックイネーブラ2101〜21058において、それぞれvalデータS2201〜S2208のレベルが検出される。
そして、この検出結果に基づいて、演算サブブロック2014,2017,2018においてのみ、除算結果S2004,S2007,S2008が示す「s/q」および「t/q」に、それぞれテクスチャサイズUSIZEおよびVSIZEを乗じて、テクスチャ座標データS2024,S2027,S2028が生成され、
それぞれ演算ブロック202の演算サブブロック2024,2027,20258に出力される。
一方、演算サブブロック2011,2012,2013,2015,20156では、演算は行なわれない。
また、テクスチャ座標データS2024,S2027,S2028の出力と同期して、valデータS2201〜S2208が、演算ブロック202の演算サブブロック2021〜2028に出力される。
【0045】
次に、演算サブブロック2021〜2028のクロックイネーブラ2121〜2128において、それぞれvalデータS2201〜S2208のレベルが検出される。
そして、この検出結果に基づいて、演算サブブロック2024,2027,2028においてのみ、SRAM17あるいはテクスチャバッファ20に記憶されているテクスチャデータの読み出し処理が行なわれ、(s,t)データに対応したテクスチャアドレスに記憶された(R,G,B,α)データが読み出される。
そして、この読み出した(R,G,B,α)データS2024,S2027,S2028が、演算ブロック204の演算サブブロック2034,2037,2038に出力される。
一方、演算サブブロック2021,2022,2023,2025,20256では、読み出し処理は行なわれない。
また、(R,G,B,α)データS2024,S2027,S2028の出力と同期して、valデータS2201〜S2208が、演算ブロック203の演算サブブロック2031〜2038に出力される。
【0046】
次に、演算サブブロック2031 〜2038 のクロックイネーブラ2121 〜2128 において、それぞれvalデータS2201 〜S2208 のレベルが検出される。
そして、この検出結果に基づいて、演算サブブロック2034 ,2037 ,2038 においてのみ、それぞれ演算ブロック202から入力したテクスチャデータである(R,G,B.α)データS2024 ,2027 ,2028 と、トライアングルDDA回路11からのDDAデータS11に含まれる(R,G,B)データとを、(R,G,B.α)データS2024 ,2027 ,2028 に含まれるαデータ(テクスチャα)が示す割合で混合し、(R,G,B)混合データを生成する。
そして、演算サブブロック2034 ,2037 ,2038 は、生成された(R,G,B)混合データと、対応するDDAデータS11に含まれるαデータとを含む(R,G,B,α)データS2034 ,2037 ,2038 を、演算ブロック204に出力する。
一方、演算サブブロック2031 ,2032 ,2033 ,2035 ,2036 では、混合処理は行なわれない。
【0047】
次に、演算サブブロック2041 〜2048 のクロックイネーブラ2141 〜2148 において、それぞれvalデータS2201 〜S2208 のレベルが検出される。
そして、この検出結果に基づいて、演算サブブロック2044 ,2047 ,2048 においてのみ、(R,G,B,α)データS2034 ,S2037 ,S2038 について、zバッファ22に記憶されたzデータの内容を用いて、z比較が行なわれ、(R,G,B,α)データS2034 ,S2037 ,S2038 によって描画する画像が、前回、ディスプレイバッファ21に描画した値よりも手前に位置する場合には、zバッファ22が更新されると共に、(R,G,B,α)データS2034 ,S2037 ,S2038 が、それぞれ(R,G,B,α)データS2044 ,S2047 ,S2048 として、それぞれ演算サブブロック205の演算サブブロック2054 ,2057 ,2058 に出力される。
【0048】
次に、演算サブブロック2051 〜2058 のクロックイネーブラ2151 〜2158 において、それぞれvalデータS2201 〜S2208 のレベルが検出される。
そして、この検出結果に基づいて、(R,G,B,α)データS2044 ,S2047 ,S2048 の(R,G,B)データと、既にディスプレイバッファ21に記憶されている(R,G,B)データとが、αデータが示す混合値で混合され、(R,G,B)データS2054 ,S2057 ,S2058 が最終的に算出される。
そして、この混合処理された,(R,G,B)データS2054 ,S2057 ,S2058 が、ディスプレイバッファ21に書き込まれる。
一方、演算サブブロック2041 ,2042 ,2043 ,2045 ,2046 では、混合処理は行なわれない。
【0049】
すなわち、テクスチャエンジン回路12およびメモリI/F回路13では、図6に示す矩形31内の画素について同時に処理を行なう場合に、三角形30の外に位置する画素についての処理は行なわない。すなわち、図4に示す矩形31内の画素についての演算を行なっている間は、演算サブブロック2001,200
2,2003,2005,2006,2011,2012,2013,2015,2016,2021,2022,2023,2025,2026,2041,2042,2043,2045,2046,2051,2052,2053,2055,2056は停止した状態になり、これらの演算サブブロックは電力を消費しない。
【0050】
以上説明したように、3次元コンピュータグラフィックシステム1によれば、テクスチャエンジン回路12におけるパイプライン処理において、同時処理する8画素のうち、処理対象となる三角形の外部に位置する画素についての演算は行なわないようにすることができる。
そのため、テクスチャエンジン回路12における消費電力を大幅に低減できる。その結果、3次元コンピュータグラフィックシステム1の電源として、簡単かつ安価なものを用いることができる。
なお、テクスチャエンジン回路12は、図3および図4に示すように、各演算サブブロックに、クロックイネーブラおよび1ビットのフラグ用フリップフロップを組み込むことで、上述した機能を実現するが、クロックイネーブラおよび1ビットのフラグ用フリップフロップの回路規模は小さいため、テクスチャエンジン回路12の回路規模が大幅に増大することはない。
【0051】
第2実施形態
図5は、本実施形態の3次元コンピュータグラフィックシステム451のシステム構成図である。
本実施形態の3次元コンピュータグラフィックシステム451は、αブレンド処理を行うか否かを各画素毎に予め判断し、αブレンド処理を行わないと判断した場合に、αブレンド処理を行う演算サブブロックのうち対応する演算サブブロックの処理を停止させる点を除いて、前述した第1実施形態の3次元コンピュータグラフィックシステム1と同じである。
すなわち、本実施形態では、各演算サブブロックは、第1実施形態の場合と同様に、対応する画素が処理対象となる三角形の外部に位置する場合には処理を停止する。また、演算サブブロックのうちαブレンド処理を行う演算サブブロックは、対応する画素が処理対象となる三角形の外部に位置するか、あるいは対応する画素のαデータが「0」である場合に処理を停止する。
【0052】
図5に示すように、3次元コンピュータグラフィックシステム451は、メインメモリ2、I/Oインタフェース回路3、メインプロセッサ4およびレンダリング回路425がメインバス6を介して接続されている。
図5において、図1と同じ符号を付した構成要素は、第1実施形態で説明した同一符号を付した構成要素と同じである。
すなわち、メインメモリ2、I/Oインタフェース回路3、メインプロセッサ4およびメインバス6は、第1実施形態で説明したものと同じである。
【0053】
また、図5に示すように、レンダリング回路425は、DDAセットアップ回路10、トライアングルDDA回路411、テクスチャエンジン回路12、メモリI/F回路413、CRTコントローラ回路14、RAMDAC回路15、DRAM16およびSRAM17を有する。
ここで、DDAセットアップ回路10、テクスチャエンジン回路12、CRTコントローラ回路14、RAMDAC回路15、DRAM16およびSRAM17は、第1実施形態で説明したものと同じである。
【0054】
以下、トライアングルDDA回路411およびメモリI/F回路413について説明する。
トライアングルDDA回路411
トライアングルDDA回路411は、前述した第1実施形態のトライアングルDDA回路11と同様に、DDAセットアップ回路10から入力した変分データS10を用いて、三角形内部の各画素の線形補間された(z,R,G,B,α,s,t,q)データを算出する。
トライアングルDDA回路411は、各画素の(x,y)データと、当該(x,y)座標の画素についての(z,R,G,B,α,s,t,q,val)データとを、DDAデータ(補間データ)S11としてテクスチャエンジン回路12に出力する。
本実施形態では、トライアングルDDA回路411は、並行して処理を行う矩形内に位置する8画素分のDDAデータS11を単位としてテクスチャエンジン回路12に出力する。
なお、以下、並行して処理を行う8画素についての(z,R,G,B,α,s,t,q,val)データのうち、valデータをvalデータS2201 〜S2208 とし、(z,R,G,B,α,s,t,q)データを被演算データS2211 〜S2218 とする。
すなわち、トライアングルDDA回路11は、8画素分の(x,y)データと、valデータS2201 〜S2208 と、被演算データS2211 〜S2218 とからなるDDAデータS11をテクスチャエンジン回路12に出力する。
【0055】
また、トライアングルDDA回路411は、並行して処理を行う8画素について、上述したように線形補間して生成した(z,R,G,B,α,s,t,q)データのうちαデータが「0」であるか否か、すなわちαブレンド処理を行うか否かを判断する。
そして、トライアングルDDA回路411は、αデータが「0」であると判断した場合に、「0」(αブレンド処理を行わないことを)を示すvalデータ411a1 〜S411a8 をメモリI/F回路413に出力し、αデータが「0」ではないと判断した場合に、「1」(αブレンド処理を行うことを)を示すvalデータ411a1 〜S411a8 をメモリI/F回路413に出力する。
【0056】
メモリI/F回路413
図6は、テクスチャエンジン回路12およびメモリI/F回路413の構成図である。
図6に示すように、メモリI/F回路413は、演算ブロック204および演算ブロック405を有する。
なお、図6において、図3と同じ符号を付した構成要素は、第1実施形態で説明した同一符号を構成要素と同じである。
すなわち、テクスチャエンジン回路12は、第1実施形態で説明したものと同じであり、メモリI/F回路413の演算ブロック204も第1実施形態で説明したものと同じである。
【0057】
以下、メモリI/F回路413の演算ブロック405について説明する。
〔演算ブロック405〕
演算ブロック405は、演算サブブロック4051 〜4058 を有し、演算サブブロック2041 〜2048 から入力した(R,G,B,α)データS2041 〜S2048 と、既にディスプレイバッファ21に記憶されている(R,G,B)データとを、それぞれ(R,G,B,α)データS2041 〜S2048 に含まれるαデータが示す混合値で混合し、混合後の(R,G,B)データS4051 〜S4058 をディスプレイバッファ21に書き込む(打ち込む)。
このとき、演算サブブロック4051 〜4058 は、それぞれクロックイネーブラ4151 〜4158 により、それぞれ演算ブロック204からのvalデータS2201 〜S2208 および図5に示すトライアングルDDA回路411からのvalデータS411a1 〜S411a8 のレベルを検出し、双方のレベルが「1」の場合にのみαブレンド処理を行う。
ここで、双方のレベルが「1」の場合とは、当該画素が処理対象となる三角形の内部に位置し、しかも、当該画素のαデータが「0」でない(αブレンド処理を行うことを示す)場合である。
すなわち、演算サブブロック4051 〜4058 は、それぞれvalデータS2201 〜S2208 およびvalデータS411a1 〜S411a8 のうちいずれか一方が「0」の場合には、αブレンド処理を行わない。
【0058】
なお、演算サブブロック4051 〜4058 は、valデータS2201 〜S2208 のレベルが「1」であり、valデータS411a1 〜S411a8 のレベルが「0」の場合には、演算サブブロック2041 〜2048 から入力した(R,G,B,α)データS2041 〜S2048 をディスプレイバッファ21に書き込む。
【0059】
以下、3次元コンピュータグラフィックシステム451の動作について説明する。
3次元コンピュータグラフィックシステム451の全体動作は、基本的に前述した第1実施形態で説明した3次元コンピュータグラフィックシステム1の全体動作と同じである。
また、図6に示すテクスチャエンジン回路12およびメモリI/F回路413のパイプライン処理の動作は、演算ブロック200〜204の処理については、前述した第1実施形態で説明した動作と同じである。
【0060】
以下、演算ブロック405の動作について説明する。
それぞれ図6に示す演算サブブロック2041 〜2048 から演算サブブロック4151 〜4158 に、(R,G,B,α)データS2041 〜S2048 およびvalデータS2201 〜S2208 が出力される。
また、図5に示すトライアングルDDA回路411において、線形補間して生成した(z,R,G,B,α,s,t,q)データのうちαデータが「0」であるか否かが判断され、当該判断の結果を示すvalデータ411a1 〜S411a8 が図6に示す演算サブブロック4151 〜4158 にそれぞれ出力される。そして、演算サブブロック4151 〜4158 において、それぞれクロックイネーブラ4151 〜4158 により、valデータS2201 〜S2208 およびvalデータS411a1 〜S411a8 のレベルが検出され、双方のレベルが「1」の場合にのみαブレンド処理が行われる。
αブレンド処理では、(R,G,B,α)データS2041 〜S2048 と、既にディスプレイバッファ21に記憶されている(R,G,B)データとが、それぞれ(R,G,B,α)データS2041 〜S2048 に含まれるαデータが示す混合値で混合されて(R,G,B)データS4051 〜S4058 が生成される。そして、(R,G,B)データS4051 〜S4058 が、ディスプレイバッファ21に書き込まれる。
【0061】
すなわち、本実施形態では、演算サブブロック4151 〜4158 のそれぞれにおいて、valデータS2201 〜S2208 およびvalデータS411a1 〜S411a8 のうち何れか一方が「0」の場合には、αブレンド処理は行われない。
【0062】
以上説明したように、3次元コンピュータグラフィックシステム451によれば、トライアングルDDA回路411において、各画素についてαデータが「0」であるか否かを判断する。
そして、メモリI/F回路413において、同時処理する8画素のうち処理対象となる三角形の内部に位置する画素であっても、トライアングルDDA回路411による上記判断の結果に基づいて、αデータが「0」の画素についてのαブレンド処理を行わないようにすることができる。
そのため、3次元コンピュータグラフィックシステム451によれば、前述した第1実施形態の3次元コンピュータグラフィックシステム1に比べてさらに、消費電力を低減できる。
【0063】
第3実施形態
図7は、本実施形態の3次元コンピュータグラフィックシステム551のシステム構成図である。
本実施形態の3次元コンピュータグラフィックシステム551では、例えば、処理対象となっている画素のzデータとzバッファに記憶されている対応するzデータとの比較を行い、今回描画しようとする画像が前回描画した画像より奥側(視点側と反対の方向)にある場合には、当該画素についてのテクスチャ座標データ(u,v)の生成処理、テクスチャデータの読み出し処理、テクスチャαブレンド処理およびαブレンド処理を停止する。
【0064】
図7に示すように、3次元コンピュータグラフィックシステム551は、メインメモリ2、I/Oインタフェース回路3、メインプロセッサ4およびレンダリング回路525がメインバス6を介して接続されている。
図7において、図1と同じ符号を付した構成要素は、第1実施形態で説明した同一符号を付した構成要素と同じである。
すなわち、メインメモリ2、I/Oインタフェース回路3、メインプロセッサ4およびメインバス6は、第1実施形態で説明したものと同じである。
【0065】
また、図7に示すように、レンダリング回路525は、DDAセットアップ回路10、トライアングルDDA回路11、テクスチャエンジン回路512、メモリI/F回路513、CRTコントローラ回路14、RAMDAC回路15、DRAM16およびSRAM17を有する。
ここで、DDAセットアップ回路10、トライアングルDDA回路11、CRTコントローラ回路14、RAMDAC回路15、DRAM16およびSRAM17は、第1実施形態で説明したものと同じである。
【0066】
以下、テクスチャエンジン回路512およびメモリI/F回路513について説明する。
図8は、テクスチャエンジン回路512およびメモリI/F回路513の構成図である。
図8に示すように、テクスチャエンジン回路512は、演算ブロック500、501、502、503、504を有する。
また、メモリI/F回路513は、演算ブロック505を有する。
本実施形態では、演算ブロック500〜505は、それぞれ8画素についての処理を同時に行い、パイプライン処理が行われるように直列に接続されている。
ここで、演算ブロック500ではz比較処理が行われ、演算ブロック501では「s/q」および「t/q」の算出処理が行われ、演算ブロック502ではテクスチャ座標データ(u,v)の算出処理が行われ、演算ブロック503ではテクスチャバッファ20からの(R,G,B,α)データの読み出し処理が行われ、演算ブロック504ではテクスチャαブレンド処理が行われ、演算ブロック505ではαブレンド処理が行われる。
【0067】
〔演算ブロック500〕
演算ブロック500は、演算サブブロック5001 〜5008 を有し、図7に示すトライアングルDDA回路11からDDAデータS11を入力する。
演算サブブロック5001 〜5008 は、それぞれクロックイネーブラ2141 〜2148 において、DDAデータS11に含まれるvalデータS2201 〜S2208 のレベル検出を行い、その結果、当該レベルが「1」の場合(当該画素が、処理対象となる三角形の内部に位置する場合)にはz比較処理を行い、当該レベルが「1」でない場合にはz比較処理を行わない。
【0068】
演算サブブロック5001 〜5008 は、z比較処理において、DDAデータS11に含まれる被演算データS2211 〜S2218 のzデータと、zバッファ22に記憶された対応するzデータとを比較する。
そして、演算サブブロック5001 〜5008 は、被演算データS2211 〜S2218 によって描画する画像が、前回、ディスプレイバッファ21に描画した値よりも手前(視点側)に位置する場合には、それぞれ「1」を示すvalデータS500a1 〜S500a8 を演算ブロック501の演算サブブロック5011 〜5018 に出力し、それぞれ被演算データS2211 〜S2218 のzデータで、zバッファ22に記憶されている対応するzデータを書き換える。このとき、演算サブブロック5001 〜5008 は、さらに被演算データS2211 〜S2218 を演算サブブロック5011 〜5018 に出力する。
一方、演算サブブロック5001 〜5008 は、被演算データS2211 〜S2218 によって描画する画像が、前回、ディスプレイバッファ21に描画した値よりも手前(視点側)に位置しない場合には、それぞれ「0」を示すvalデータS500a1 〜S500a8 を演算ブロック501の演算サブブロック5011 〜5018 に出力し、zバッファ22に記憶されている対応するzデータを書き換えない。
【0069】
〔演算ブロック501〕
演算ブロック501は、DDAデータS11が示す(s,t,q)データを用いて、sデータをqデータで除算する演算と、tデータをqデータで除算する演算とを行う。
演算ブロック501は、図8に示すように、8個の演算サブブロック5011 〜5018 を内蔵する。
ここで、演算サブブロック5011 は、被演算データS2211 およびvalデータS2201 ,S500a1 を入力し、クロックイネーブラ5111 〜5118 により、valデータS2201 およびS500a1 の双方が「1」、すなわち有効であるか否かを判断し、双方が「1」であると判断した場合に、「s/q」および「t/q」を算出し、これを除算結果S5011 として演算ブロック502の演算サブブロック5021 に出力する。
【0070】
また、演算サブブロック5011 は、valデータS2201 およびS500a1 のいずれか一方が「0」、すなわち無効であることを示すと判断した場合には演算は行わず、除算結果S5011 を出力しないか、あるいは、所定の仮値を示す除算結果S5011 を演算ブロック502の演算サブブロック5021 に出力する。
なお、演算サブブロック5012 〜5018 も、それぞれ対応する画素について、演算サブブロック5011 と同じ演算を行い、それぞれ除算結果S5012 〜S5018 を後段の演算ブロック502の演算サブブロック5022 〜5028 にそれぞれ出力する。
【0071】
〔演算ブロック502〕
演算ブロック502は、演算サブブロック5021 〜5028 を有し、演算ブロック501から入力した除算結果S5011 〜S5018 が示す「s/q」および「t/q」に、それぞれテクスチャサイズUSIZEおよびVSIZEを乗じて、テクスチャ座標データ(u,v)を生成する。
演算サブブロック5021 は、クロックイネーブラ5121 においてvalデータS2201 およびS500a1 のレベル検出を行い、双方のレベルが「1」の場合にのみ演算を行い、それぞれ演算結果であるテクスチャ座標データS5021 を、演算ブロック503の演算サブブロック5031 に出力する。
演算サブブロック5022 〜5028 も、演算サブブロック5021 と同様に、対応するデータの処理を行う。
【0072】
〔演算ブロック503〕
演算ブロック503は、演算サブブロック5031 〜5038 を有し、メモリI/F回路13を介して、SRAM17あるいはDRAM16に、演算ブロック502で生成したテクスチャ座標データ(u,v)を含む読み出し要求を出力し、メモリI/F回路13を介して、SRAM17あるいはテクスチャバッファ20に記憶されているテクスチャデータを読み出すことで、(u,v)データに対応したテクスチャアドレスに記憶された(R,G,B,α)データS17を得る。
演算サブブロック5031 は、クロックイネーブラ5131 においてvalデータS2201 およびS500a1 のレベル検出を行い、双方のレベルが「1」の場合にのみ読み出し処理を行い、それぞれ読み出した(R,G,B,α)データS17を、(R,G,B.α)データS5031 として、演算ブロック203の演算サブブロック5041 に出力する。
演算サブブロック5032 〜5038 も、演算サブブロック5031 と同様に、対応するデータの処理を行う。
【0073】
〔演算ブロック504〕
演算ブロック504は、演算サブブロック5041 〜5048 を有し、演算ブロック503から入力したテクスチャデータである(R,G,B.α)データS5031 〜S5038 と、トライアングルDDA回路11からの対応するDDAデータS11に含まれる(R,G,B)データとを、(R,G,B.α)データS5031 〜S5038 に含まれるαデータ(テクスチャα)が示す割合で混合し、(R,G,B)混合データを生成する。
そして、演算ブロック504は、生成された(R,G,B)混合データと、対応するDDAデータS11に含まれるαデータとを含む(R,G,B,α)データS5041 〜S5048 を、演算ブロック505に出力する。
演算サブブロック5041 〜5048 は、それぞれクロックイネーブラ5141 〜5148 によりvalデータS2201 〜S2208 およびS500a1 〜S500a8 のレベル検出を行い、双方のレベルが「1」の場合にのみ上記混合処理を行う。
【0074】
〔演算ブロック505〕
演算ブロック505は、演算サブブロック5051 〜5058 を有し、入力した(R,G,B,α)データS5041 〜S5048 と、既にディスプレイバッファ21に記憶されている(R,G,B)データとを、それぞれ(R,G,B,α)データS5041 〜S5048 に含まれるαデータが示す混合値で混合し、混合後の(R,G,B)データS5051 〜S5058 をディスプレイバッファ21に書き込む(打ち込む)。
演算サブブロック5051 〜5058 は、それぞれクロックイネーブラ2151 〜2158 においてvalデータS2201 〜S2208 およびS500a1 〜S500a8 のレベルを検出し、双方のレベルが「1」の場合にのみ上記混合処理およびディスプレイバッファ21への書き込み処理を行う。
【0075】
以下、図8に示すテクスチャエンジン回路512およびメモリI/F回路513のパイプライン処理の動作について説明する。
先ず、演算サブブロック5001 〜5008 のクロックイネーブラ2141 〜2148 において、それぞれDDAデータS11に含まれるvalデータS2201 〜S2208 のレベル検出が行われ、当該レベルが「1」の場合(当該画素が、処理対象となる三角形の内部に位置する場合)にはz比較処理が行われる。そして、被演算データS2211 〜S2218 によって描画する画像が、前回、ディスプレイバッファ21に描画した値よりも手前(視点側)に位置する場合には、それぞれ「1」を示すvalデータS500a1 〜S500a8 が演算ブロック501の演算サブブロック5011 〜5018 に出力され、それぞれ被演算データS2211 〜S2218 のzデータで、zバッファ22に記憶されている対応するzデータが書き換えられる。このとき、さらに被演算データS2211 〜S2218 が、演算サブブロック5001 〜5008 から演算サブブロック5011 〜5018 に出力される。
一方、valデータS2201 〜S2208 のレベルが「1」でない場合にはz比較処理は行われず、それぞれ「0」を示すvalデータS500a1 〜S500a8 が演算ブロック501の演算サブブロック5011 〜5018 に出力される。このとき、zバッファ22に記憶されている対応するzデータは書き換えられない。
【0076】
次に、演算サブブロック5011 〜5018 のクロックイネーブラ5111 〜5118 において、valデータS2201 およびS500a1 の双方が「1」、すなわち有効であるか否かが判断され、双方が「1」であると判断された場合に、「s/q」および「t/q」が算出され、これが除算結果S5011 〜S5018 として演算ブロック502の演算サブブロック5021 〜5028 に出力される。
一方、valデータS2201 〜S2208 およびS500a1 〜S500a8 のいずれか一方が「0」、すなわち無効であることを示すと判断された場合には、それぞれ演算サブブロック5011 〜5018 では演算は行われない。
【0077】
次に、演算サブブロック5021 〜5028 のクロックイネーブラ5121 〜5128 においてvalデータS2201 〜S2208 およびS500a1 〜S500a8 のレベル検出が行われる。
そして、双方のレベルが「1」の場合にのみ、演算サブブロック5021 〜5028 において、それぞれ演算ブロック501から入力した除算結果S5011 〜S5018 が示す「s/q」および「t/q」に、それぞれテクスチャサイズUSIZEおよびVSIZEが乗算され、テクスチャ座標データ(u,v)が生成される。テクスチャ座標データ(u,v)は、それぞれ演算サブブロック5031 〜5038 に出力される。
【0078】
次に、演算サブブロック5031 〜5038 のクロックイネーブラ5131 〜5138 において、valデータS2201 〜S2208 およびS500a1 〜S500a8 のレベル検出が行われ、双方のレベルが「1」の場合にのみ、テクスチャ座標データ(u,v)を含む読み出し要求がSRAM17に出力され、メモリI/F回路13を介してテクスチャデータが読み出され、(u,v)データに対応したテクスチャアドレスに記憶された(R,G,B,α)データS17が得られる。(R,G,B,α)データS17は、(R,G,B.α)データS5031 〜S5038 として、演算サブブロック5041 〜5048 に出力される。
【0079】
次に、演算サブブロック5041 〜5048 のクロックイネーブラ5141 〜5148 によりvalデータS2201 〜S2208 およびS500a1 〜S500a8 のレベル検出が行われ、双方のレベルが「1」の場合にのみ、(R,G,B.α)データS5031 〜S5038 と、トライアングルDDA回路11からの対応するDDAデータS11に含まれる(R,G,B)データとが、(R,G,B.α)データS5031 〜S5038 に含まれるαデータ(テクスチャα)が示す割合で混合され、(R,G,B)混合データが生成される。
そして、当該生成された(R,G,B)混合データと、対応するDDAデータS11に含まれるαデータとを含む(R,G,B,α)データS5041 〜S5048 が、演算サブブロック5041 〜5048 から演算サブブロック5051 〜5058 に出力される。
【0080】
次に、演算サブブロック5051 〜5058 のクロックイネーブラ2151 〜2158 において、valデータS2201 〜S2208 およびS500a1 〜S500a8 のレベルが検出され、双方のレベルが「1」の場合にのみ、(R,G,B,α)データS5041 〜S5048 と、既にディスプレイバッファ21に記憶されている(R,G,B)データとが、それぞれ(R,G,B,α)データS5041 〜S5048 に含まれるαデータが示す混合値で混合され、混合後の(R,G,B)データS5051 〜S5058 がディスプレイバッファ21に書き込まれる。
【0081】
以上説明したように、3次元コンピュータグラフィックシステム551によれば、テクスチャエンジン回路512の初段の演算ブロック500において各画素に関するz比較処理を行い、後の処理によって生成される画像データがディスプレイバッファ21に書き込まれるものであるかを判断する。
そして、テクスチャエンジン回路512およびメモリI/F回路513において、同時処理する8画素のうち処理対象となる三角形の内部に位置する画素であっても、演算ブロック500による上記判断の結果に基づいて、ディスプレイバッファ21に書き込まない画像データに関する処理を行わないように(停止)する。
そのため、3次元コンピュータグラフィックシステム551によれば、前述した第1実施形態の3次元コンピュータグラフィックシステム1に比べてさらに、消費電力を低減できる。
【0082】
本発明は上述した実施形態には限定されない。
例えば、前述した第2実施形態では、図6に示すように、テクスチャエンジン回路12およびメモリI/F回路413の各演算ブロックで8画素のデータについて同時に処理する場合について例示したが、図9に示すように、各演算ブロックで1画素のデータの処理を行うようにしてもよい。
この場合には、処理対象となる画素の被演算データS2211 のみがテクスチャエンジン回路12に入力されるため、valデータS2201 は不要となる。すなわち、演算サブブロック2001 ,2011 ,2021 ,2031 ,2041 では常に演算が行われ、演算サブブロック4051 ではvalデータS400a1 のレベルが「1」の場合にのみαブレンド処理が行われる。
【0083】
また、前述した第3実施形態では、図8に示すように、テクスチャエンジン回路512およびメモリI/F回路513の各演算ブロックで8画素のデータについて同時に処理する場合について例示したが、図10に示すように、各演算ブロックで1画素のデータの処理を行うようにしてもよい。
この場合には、処理対象となる画素の被演算データS2211 のみがテクスチャエンジン回路512に入力されるため、valデータS2201 は不要となる。すなわち、演算サブブロック5001 ではz比較処理が常に行われ、演算サブブロック5011 ,5021 ,5031 ,5041 ,5051 では、演算サブブロック5001 で生成されたvalデータS500a1 のレベルが「1」の場合にのみ処理が行われる。
【0084】
また、例えば、上述した実施形態では、図3に示すように、テクスチャエンジン回路12およびメモリI/F回路13におけるパイプライン処理を行なう演算サブブロックについて、valデータS2201 〜S2208 を利用する場合を例示したが、例えば、図1にレンダリング回路5内のDDAセットアップ回路10、トライアングルDDA回路11、テクスチャエンジン回路12およびメモリI/F回路13における処理のうち、パイプライン処理を行なわない所定の処理について、図11に示すように、valデータS3201 〜S3208 を用いて、演算処理の実行の有無を決定するようにしてもよい。
【0085】
また、上述した実施形態では、SRAM17を用いる構成を例示したが、SRAM17を設けない構成にしてもよい。
また、テクスチャバッファ20およびテクスチャCLUTバッファ23を、DRAM16の外部に設けてもよい。
【0086】
また、上述した実施形態では、3次元画像を表示する場合を例示したが、本発明は複数画素についてのデータを同時に処理して2次元画像を表示する場合にも適用できる。
また、上述した実施形態では、図2に示すように、画像処理の対象となる(z,R,G,B,α,s,t,q)データに、有効指示データとしてのvalデータを付加したDDAデータS11を用いた場合を例示したが、(z,R,G,B,α,s,t,q)データと、valデータとを別個独立のデータとして扱うようにしてもよい。
【0087】
また、上述した実施形態では、ポリゴンレンダリングデータを生成するジオメトリ処理を、メインプロセッサ4で行なう場合を例示したが、レンダリング回路5で行なう構成にしてもよい。
【0088】
さらに、上述した実施形態では、単位図形として三角形を例示したが、単位図形は特に限定されず、例えば、矩形であってもよい。
【0089】
【発明の効果】
以上説明したように、本発明の画像処理装置およびその方法によれば、消費電力の大幅な低下を図ることができる。
そのため、本発明の画像処理装置によれば、小規模かつ簡単な構成の電源を用いることができ、小規模化が図れる。
【図面の簡単な説明】
【図1】図1は、本発明の第1実施形態の3次元コンピュータグラフィックシステムのシステム構成図である。
【図2】図1に示すトライアングルDDA回路から出力されるDDAデータのフォーマットを説明するための図である。
【図3】図3は、図1に示すテクスチャエンジン回路およびメモリI/F回路の部分構成図である。
【図4】図4は、図3に示す演算サブブロックの内部構成図である。
【図5】図5は、本発明の第2実施形態の3次元コンピュータグラフィックシステムのシステム構成図である。
【図6】図6は、図5に示すテクスチャエンジン回路およびメモリI/F回路の部分構成図である。
【図7】図7は、本発明の第3実施形態の3次元コンピュータグラフィックシステムのシステム構成図である。
【図8】図8は、図7に示すテクスチャエンジン回路およびメモリI/F回路の部分構成図である。
【図9】図9は、図5に示す3次元コンピュータグラフィックシステムの変形例の構成図である。
【図10】図10は、図7に示す3次元コンピュータグラフィックシステムの変形例の構成図である。
【図11】図11は、図1に示す3次元コンピュータグラフィックシステムにおけるクロックイネーブラーを適用した、パイプライン処理を行なっていない演算ブロックの構成図である。
【図12】図12は、従来技術の問題点を説明するための図である。
【符号の説明】
1…3次元コンピュータグラフィックシステム、2…メインメモリ、3…I/Oインタフェース回路、4…メインプロセッサ、5…レンダリング回路、10…DDAセットアップ回路、11…トライアングルDDA回路、12…テクスチャエンジン回路、13…メモリI/F回路、14…CRTコントローラ回路、15…RAMDAC回路、16…DRAM、17…SRAM、20…テクスチャバッファ、21…ディスプレイバッファ、22…Zバッファ、23…テクスチャCLUTバッファ、200〜205…演算ブロック、2001 〜2008 ,2011 〜2018 ,2021 〜2028 ,2031 〜2038 ,2041 〜2048 ,2051 〜2058 …演算サブブロック、2101 〜2108 ,2111 〜2118 ,2121 〜2128 ,2131 〜2138 ,2141 〜2148 ,2151 〜2158 …クロックイネーブラ、222…データ用フリップフロップ、223…プロセッサエレメント、224…フラグ用フリップフロップ
Claims (8)
- 同時に処理を行おうとする複数の画素毎にそれぞれ設けられ、それぞれ対応する画素データを受け、相互に並列にデータ処理を行う、複数の画素データ処理回路と、
前記各画素データ処理回路に入力する前記画素データの少なくとも一部として含まれる演算の有効性を示すフラグに基づいて前記画素毎のデータ処理を対応する前記画素データ処理回路が行う必要がないと論理判断した場合に対応する各画素データ処理回路の動作を停止する制御手段と
を有し、
前記画素データ処理回路の各々は、システムクロック信号から生成された画素データ処理回路駆動用クロック信号に基づいて動作してパイプライン処理を行うように相互に直列接続された、複数の処理回路を有し、
前記各画素データ処理回路内の直列に接続された前記複数の処理回路は、当該各処理回路を制御する前記演算を有効性を示すフラグが転送されることにより、前記パイプライン処理および前記画素データ処理回路駆動用クロック信号の供給の制御を行い、
前記制御手段は、前記演算の有効性を示すフラグに基づいて前記画素データ処理回路のデータ処理を行う必要のない各処理回路への前記画素データ処理回路駆動用クロック信号の供給を停止する、
画像処理装置。 - 前記画素データ処理回路の各々は、前記パイプライン処理を行うように相互に直列に接続された複数の処理回路を有する、
請求項1に記載の画像処理装置。 - 前記画素データ処理回路内の直列に接続された前記複数の処理回路は、当該各処理回路を制御する前記演算を有効性を示すフラグが転送されることによって、前記パイプライン処理および前記画素データ処理回路駆動用クロック信号の供給の制御を行う、
請求項2に記載の画像処理装置。 - 前記画素データ処理回路は、画素のR(赤),G(緑),B(青)の出力を決定する画素データについての処理を行う、
請求項1に記載の画像処理装置。 - 同時に処理を行おうとする複数の画素毎にそれぞれ設けられ、それぞれ対応する画素データを受け、相互に並列にデータ処理する複数の画素データ処理回路を用いて画像処理を行う画像処理方法において、
前記画素データ処理回路の各々は、システムクロック信号から生成された画素データ処理回路駆動用クロック信号に基づいて動作してパイプライン処理を行うように相互に直列接続された複数の処理回路を有しており、
前記各画素データ処理回路内の直列に接続された複数の処理回路は、各処理回路を制御する前記演算の有効性を示すフラグが転送されることにより、当該転送される演算の有効性を示すフラグに基づいて、前記パイプライン処理および前記画素データ処理回路駆動用クロック信号の供給の制御を行い、
前記画素データに含まれる演算の有効性を示すフラグに基づいて、前記画素毎のデータ処理を対応する前記画素データ処理回路が行う必要がないと論理判断して対応する画素データ処理回路の動作を停止させるとき、当該画素データ処理回路のデータ処理を行う必要のない処理回路への前記画素データ処理回路駆動用クロック信号の供給を停止する、
ことを特徴とする、画像処理方法。 - 前記画素データ処理回路の各々は、直列に接続された複数の処理回路でパイプライン処理を行う、
請求項5に記載の画像処理方法。 - 前記各画素データ処理回路内の直列に接続された複数の処理回路は、当該各処理回路を制御する演算の有効性を示すフラグが転送されることにより、当該演算の有効性を示すフラグに基づいて前記パイプライン処理および前記画素データ処理回路駆動用クロック信号の供給の制御を行う、
請求項6に記載の画像処理方法。 - 前記画素データ処理は、画素のR(赤),G(緑),B(青)の出力を決定する画素データについての処理を行う、
請求項5に記載の画像処理方法。
Priority Applications (8)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP05179599A JP4505866B2 (ja) | 1998-04-03 | 1999-02-26 | 画像処理装置および映像信号処理方法 |
US09/283,231 US7053902B1 (en) | 1998-04-03 | 1999-04-01 | Image processing apparatus and method of processing images that stops operation of pixel processing circuits when pixel data to be processed is not needed |
CA002268210A CA2268210C (en) | 1998-04-03 | 1999-04-01 | Image processing apparatus and method of the same |
KR1019990011650A KR100613747B1 (ko) | 1998-04-03 | 1999-04-02 | 화상 처리장치 및 그 방법 |
EP99400838A EP0947978A3 (en) | 1998-04-03 | 1999-04-06 | Image processing apparatus and method |
EP07123058A EP1895500A3 (en) | 1998-04-03 | 1999-04-06 | Image processing apparatus and image processing method |
EP07123061A EP1895502A3 (en) | 1998-04-03 | 1999-04-06 | Image processing apparatus and image processing method |
EP07123060A EP1895501A3 (en) | 1998-04-03 | 1999-04-06 | Image processing apparatus and image processing method |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP10-91844 | 1998-04-03 | ||
JP9184498 | 1998-04-03 | ||
JP05179599A JP4505866B2 (ja) | 1998-04-03 | 1999-02-26 | 画像処理装置および映像信号処理方法 |
Related Child Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2007281036A Division JP4333793B2 (ja) | 1998-04-03 | 2007-10-29 | 映像信号処理装置および映像信号処理方法 |
JP2007281031A Division JP4380757B2 (ja) | 1998-04-03 | 2007-10-29 | 映像信号処理装置および映像信号処理方法 |
JP2007281037A Division JP4386124B2 (ja) | 1998-04-03 | 2007-10-29 | 映像信号処理装置および映像信号処理方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH11345218A JPH11345218A (ja) | 1999-12-14 |
JP4505866B2 true JP4505866B2 (ja) | 2010-07-21 |
Family
ID=26392364
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP05179599A Expired - Lifetime JP4505866B2 (ja) | 1998-04-03 | 1999-02-26 | 画像処理装置および映像信号処理方法 |
Country Status (5)
Country | Link |
---|---|
US (1) | US7053902B1 (ja) |
EP (4) | EP1895502A3 (ja) |
JP (1) | JP4505866B2 (ja) |
KR (1) | KR100613747B1 (ja) |
CA (1) | CA2268210C (ja) |
Families Citing this family (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4581261B2 (ja) * | 2001-02-14 | 2010-11-17 | ソニー株式会社 | 演算装置、演算処理方法及び画像処理装置 |
US7383421B2 (en) | 2002-12-05 | 2008-06-03 | Brightscale, Inc. | Cellular engine for a data processing system |
JP3497499B2 (ja) * | 2002-03-14 | 2004-02-16 | 三菱電機株式会社 | 三次元グラフィック描画装置 |
TWI343020B (en) * | 2006-05-12 | 2011-06-01 | Nvidia Corp | Antialiasing using multiple display heads of a graphics processor |
SG137754A1 (en) * | 2006-05-12 | 2007-12-28 | Nvidia Corp | Antialiasing using multiple display heads of a graphics processor |
JP4697055B2 (ja) * | 2006-05-31 | 2011-06-08 | 富士ゼロックス株式会社 | 演算装置、画像処理装置及びデータ処理装置 |
US9563433B1 (en) | 2006-09-01 | 2017-02-07 | Allsearch Semi Llc | System and method for class-based execution of an instruction broadcasted to an array of processing elements |
CN103295555B (zh) * | 2012-03-01 | 2015-08-05 | 晨星软件研发(深圳)有限公司 | 影像处理系统及影像处理方法 |
US10446071B2 (en) | 2016-03-31 | 2019-10-15 | Samsung Electronics Co., Ltd. | Device and method of using slice update map |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH06164342A (ja) * | 1992-11-26 | 1994-06-10 | Matsushita Electric Ind Co Ltd | クロック信号生成回路 |
JPH06309349A (ja) * | 1993-04-26 | 1994-11-04 | Matsushita Electric Ind Co Ltd | プログラム制御のプロセッサ |
JPH08106337A (ja) * | 1994-10-03 | 1996-04-23 | Hitachi Ltd | 半導体集積回路装置 |
JPH08235130A (ja) * | 1995-02-24 | 1996-09-13 | Sony Corp | 並列プロセッサ |
WO1998006065A1 (fr) * | 1996-08-05 | 1998-02-12 | Hitachi, Ltd. | Processeur d'images tridimensionnelles |
Family Cites Families (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR930000997B1 (ko) * | 1988-06-13 | 1993-02-12 | 삼성전자 주식회사 | 화상 배열 처리장치 |
US5179638A (en) * | 1990-04-26 | 1993-01-12 | Honeywell Inc. | Method and apparatus for generating a texture mapped perspective view |
US5517603A (en) * | 1991-12-20 | 1996-05-14 | Apple Computer, Inc. | Scanline rendering device for generating pixel values for displaying three-dimensional graphical images |
JP2636695B2 (ja) * | 1993-08-03 | 1997-07-30 | 日本電気株式会社 | パイプライン処理回路 |
JP3904244B2 (ja) | 1993-09-17 | 2007-04-11 | 株式会社ルネサステクノロジ | シングル・チップ・データ処理装置 |
WO1995009390A1 (en) * | 1993-09-28 | 1995-04-06 | Namco Ltd. | Pipeline processor, clipping processor, three-dimensional simulator and pipeline processing method |
US5742796A (en) * | 1995-03-24 | 1998-04-21 | 3Dlabs Inc. Ltd. | Graphics system with color space double buffering |
US5727192A (en) | 1995-03-24 | 1998-03-10 | 3Dlabs Inc. Ltd. | Serial rendering system with auto-synchronization on frame blanking |
DE69628451D1 (de) * | 1995-07-26 | 2003-07-03 | Apple Computer | Verfahren zur zeilendarstellung durch sortieren von segmenten und untersegmenten |
JPH09130570A (ja) | 1995-10-27 | 1997-05-16 | Ricoh Co Ltd | 画像形成装置 |
-
1999
- 1999-02-26 JP JP05179599A patent/JP4505866B2/ja not_active Expired - Lifetime
- 1999-04-01 CA CA002268210A patent/CA2268210C/en not_active Expired - Lifetime
- 1999-04-01 US US09/283,231 patent/US7053902B1/en not_active Expired - Lifetime
- 1999-04-02 KR KR1019990011650A patent/KR100613747B1/ko not_active IP Right Cessation
- 1999-04-06 EP EP07123061A patent/EP1895502A3/en not_active Withdrawn
- 1999-04-06 EP EP99400838A patent/EP0947978A3/en not_active Withdrawn
- 1999-04-06 EP EP07123058A patent/EP1895500A3/en not_active Ceased
- 1999-04-06 EP EP07123060A patent/EP1895501A3/en not_active Ceased
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH06164342A (ja) * | 1992-11-26 | 1994-06-10 | Matsushita Electric Ind Co Ltd | クロック信号生成回路 |
JPH06309349A (ja) * | 1993-04-26 | 1994-11-04 | Matsushita Electric Ind Co Ltd | プログラム制御のプロセッサ |
JPH08106337A (ja) * | 1994-10-03 | 1996-04-23 | Hitachi Ltd | 半導体集積回路装置 |
JPH08235130A (ja) * | 1995-02-24 | 1996-09-13 | Sony Corp | 並列プロセッサ |
WO1998006065A1 (fr) * | 1996-08-05 | 1998-02-12 | Hitachi, Ltd. | Processeur d'images tridimensionnelles |
Also Published As
Publication number | Publication date |
---|---|
EP1895500A2 (en) | 2008-03-05 |
KR100613747B1 (ko) | 2006-08-22 |
EP0947978A2 (en) | 1999-10-06 |
EP1895502A2 (en) | 2008-03-05 |
EP1895500A3 (en) | 2010-05-19 |
CA2268210A1 (en) | 1999-10-03 |
EP1895501A3 (en) | 2010-04-28 |
EP1895501A2 (en) | 2008-03-05 |
US7053902B1 (en) | 2006-05-30 |
EP1895502A3 (en) | 2010-04-28 |
EP0947978A3 (en) | 1999-12-29 |
CA2268210C (en) | 2009-09-22 |
KR19990082898A (ko) | 1999-11-25 |
JPH11345218A (ja) | 1999-12-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3860859B2 (ja) | 高性能プリミティブ・クリッピング・プリプロセシングを有するコンピュータ・グラフィックス・システム | |
US5877769A (en) | Image processing apparatus and method | |
JP2005100177A (ja) | 画像処理装置およびその方法 | |
JP2005100176A (ja) | 画像処理装置およびその方法 | |
JP4707782B2 (ja) | 画像処理装置およびその方法 | |
JP4505866B2 (ja) | 画像処理装置および映像信号処理方法 | |
JPH096988A (ja) | 色に奥行き指示を与える装置 | |
JPH0714029A (ja) | 線描画装置及び方法 | |
JP4386124B2 (ja) | 映像信号処理装置および映像信号処理方法 | |
JP4333793B2 (ja) | 映像信号処理装置および映像信号処理方法 | |
JP4380757B2 (ja) | 映像信号処理装置および映像信号処理方法 | |
JP4069486B2 (ja) | 記憶回路制御装置およびグラフィック演算装置 | |
US20050024377A1 (en) | Programmable multiple texture combine circuit for a graphics processing system and method for use thereof | |
JPH11306366A (ja) | グラフィック演算装置およびその方法 | |
JP3741053B2 (ja) | 画像処理装置 | |
JP4042204B2 (ja) | グラフィック演算装置およびその方法 | |
JPH09319892A (ja) | 画像処理装置及びその処理方法 | |
US6460063B1 (en) | Division circuit and graphic display processing apparatus | |
JP4325038B2 (ja) | 画像処理装置 | |
JP4635379B2 (ja) | 画像処理装置 | |
JP4224887B2 (ja) | 信号処理装置および画像処理装置 | |
JP4580475B2 (ja) | 演算処理装置およびグラフィック演算装置 | |
JPH02166573A (ja) | 隠れ面処理装置 | |
JPH11288266A (ja) | 画像メモリ制御装置およびグラフィック演算装置 | |
JP2005078357A (ja) | 画像処理装置およびその方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20051208 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20070817 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20070828 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20071029 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20081224 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20090223 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20091201 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20100301 |
|
A911 | Transfer to examiner for re-examination before appeal (zenchi) |
Free format text: JAPANESE INTERMEDIATE CODE: A911 Effective date: 20100308 |
|
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: 20100406 |
|
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20100419 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130514 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130514 Year of fee payment: 3 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
EXPY | Cancellation because of completion of term |