「プログラマブルシェーダー」の版間の差分

提供: MonoBook
移動先: 案内検索
(概要)
(備考)
 
6行目: 6行目:
 
この方式は簡潔明瞭という利点と、だれが作っても似たように絵になるという欠点があった。
 
この方式は簡潔明瞭という利点と、だれが作っても似たように絵になるという欠点があった。
  
=== 第一世代 ===
+
===第一世代===
 
「だれが作っても似たように絵になる」というのが気に食わない人が現れた。
 
「だれが作っても似たように絵になる」というのが気に食わない人が現れた。
  
13行目: 13行目:
 
後に[[HLSL]]や[[GLSL]]などの[[高級言語]]などが登場したが、それでも3Dを扱う[[プログラマー]]に求められる作業量・記述量は劇的に増えた。
 
後に[[HLSL]]や[[GLSL]]などの[[高級言語]]などが登場したが、それでも3Dを扱う[[プログラマー]]に求められる作業量・記述量は劇的に増えた。
  
=== 第二世代 ===
+
===第二世代===
 
そして次に登場したのが「[[統合シェーダー]]」と呼ばれる第二世代のプログラマブルシェーダーである。これはバーテックスシェーダやピクセルシェーダーの概念をなくし、「ひとつの汎用的なシェーダー」でバーテックスシェーダとピクセルシェーダでやってた処理を実行すればいいじゃんという代物である。しかもこの定型的な2つの処理だけでなく、「パイプライン」というものに何個の処理でも詰め込めるように改良された。
 
そして次に登場したのが「[[統合シェーダー]]」と呼ばれる第二世代のプログラマブルシェーダーである。これはバーテックスシェーダやピクセルシェーダーの概念をなくし、「ひとつの汎用的なシェーダー」でバーテックスシェーダとピクセルシェーダでやってた処理を実行すればいいじゃんという代物である。しかもこの定型的な2つの処理だけでなく、「パイプライン」というものに何個の処理でも詰め込めるように改良された。
  
20行目: 20行目:
 
パイプラインの組み立てなどを考える必要性がでてきて、3Dを扱う[[プログラマー]]に求められる作業量・記述量は劇的に増えた。
 
パイプラインの組み立てなどを考える必要性がでてきて、3Dを扱う[[プログラマー]]に求められる作業量・記述量は劇的に増えた。
  
=== 備考 ===
+
===備考===
 
プログラマブルシェーダーが進化するほど3Dを扱う[[プログラマー]]に求められる作業量・記述量は劇的に増え続けた。[[プログラミング]]するのがアホらしくなるほどであった。
 
プログラマブルシェーダーが進化するほど3Dを扱う[[プログラマー]]に求められる作業量・記述量は劇的に増え続けた。[[プログラミング]]するのがアホらしくなるほどであった。
  
その結果、よほどの事がないかぎり[[固定シェーダー]]でこと足りるのにそんなアホくさいことに労力を割くのは得策ではないとして、実質固定シェーダーみたいな標準シェーダーが充実している[[Unity]]や[[Unreal Engine]]などの[[ゲームエンジン]]が爆発的に普及した。
+
その結果、自前実装は面倒くさすぎ。[[ゲームエンジン]]が用意するプログラマブルシェーダー(実質固定シェーダー)でいいじゃん。という空気になり、[[Unity]]や[[Unreal Engine]]などの[[ゲームエンジン]]が爆発的に普及した。
 +
 
 +
つまり今でも95%くらいの用途は[[ハードウェアT&L]]で十分なのでだったのであった。
  
 
==デバッグ==
 
==デバッグ==

2019年8月14日 (水) 05:28時点における最新版

プログラマブルシェーダー英語:programmable shader)とは、グラフィックカード上のシェーダーで独自のプログラム(カスタムシェーダー)を実行させられるものをいう。

概要[編集 | ソースを編集]

初期のシェーダーは「ハードウェアT&L(最近では対義語的に固定シェーダーと呼ばれることが多い)」などと呼ばれ、いわゆるAPI的な感じで「ライティングをする」などの固定機能がGPUに用意されていた。これはプログラマーは何も考えずポリゴンモデルやテクスチャや座標など3DデータをGPUに送信すると表示用の2D画像が返ってくるというものであった。

この方式は簡潔明瞭という利点と、だれが作っても似たように絵になるという欠点があった。

第一世代[編集 | ソースを編集]

「だれが作っても似たように絵になる」というのが気に食わない人が現れた。

そういう奇人のためにバーテックスシェーダピクセルシェーダでの処理をアセンブラのようなプログラミング言語で自前で記述できるようにしたのが第一世代のプログラマブルシェーダーである。

後にHLSLGLSLなどの高級言語などが登場したが、それでも3Dを扱うプログラマーに求められる作業量・記述量は劇的に増えた。

第二世代[編集 | ソースを編集]

そして次に登場したのが「統合シェーダー」と呼ばれる第二世代のプログラマブルシェーダーである。これはバーテックスシェーダやピクセルシェーダーの概念をなくし、「ひとつの汎用的なシェーダー」でバーテックスシェーダとピクセルシェーダでやってた処理を実行すればいいじゃんという代物である。しかもこの定型的な2つの処理だけでなく、「パイプライン」というものに何個の処理でも詰め込めるように改良された。

これにより「1回目のピクセルシェーダーで普通に描画して、2回目のピクセルシェーダーで画面全体を1枚のテクスチャに見立ててアンチエイリアシング」などといった技法も登場した。

パイプラインの組み立てなどを考える必要性がでてきて、3Dを扱うプログラマーに求められる作業量・記述量は劇的に増えた。

備考[編集 | ソースを編集]

プログラマブルシェーダーが進化するほど3Dを扱うプログラマーに求められる作業量・記述量は劇的に増え続けた。プログラミングするのがアホらしくなるほどであった。

その結果、自前実装は面倒くさすぎ。ゲームエンジンが用意するプログラマブルシェーダー(実質固定シェーダー)でいいじゃん。という空気になり、UnityUnreal Engineなどのゲームエンジンが爆発的に普及した。

つまり今でも95%くらいの用途はハードウェアT&Lで十分なのでだったのであった。

デバッグ[編集 | ソースを編集]

HLSL[編集 | ソースを編集]

Visual Studio Graphics Analyzerで行う。

  • 「デバッグ」→「グラフィックス」→「グラフィックス デバッグの開始」
  • フレームキャプチャを行う
  • サムネイルの上にあるフレーム番号をクリックする
  • Visual Studio Graphics Analyzerが起動する

Metal[編集 | ソースを編集]

Xcodeで行う。

  • 普通にデバッグ実行する
  • 中段ツールバー(ステップ実行などがあるところ)のカメラアイコンをクリックする
    • Xcode-metal-shader-debug-1.png
    • 右側デバッグナビゲーターに「GPU」が追加され、メインウインドウが切り替わる
    • 中段ツールバーも入れ替わり、ゴキブリアイコンが登場する
  • 中段ツールバーのゴキブリアイコンをクリックする
    • Xcode-metal-shader-debug-2.png
    • バーテックスシェーダか、フラグメントシェーダかを選ぶダイアログが表示される
      • 上部のタブでバーテックスシェーダとフラグメントシェーダを切り替え
      • 中段のメインウインドウでポリゴンやピクセルを選ぶ
      • 下部の「DEBUG」ボタンを押すとステップ実行やウォッチ変数の表示が開始される

GLSL[編集 | ソースを編集]

目視。ひたらす目視。OpenGL系にステップ実行やウォッチ変数など求めてはいけない。

関連項目[編集 | ソースを編集]

  • CUDA = 最先端、NVIDIA製品でしか動かない
  • HLSL = CUDAから実験的な機能を排除したもの。唯一まともなデバッガがある。
  • GLSL = OpenGLValkanなどで使われている。
  • Metal = Apple製品はOpenGLが禁止されこれ一本になった