CompiledLayer

CompiledLayer[func]

計算がコンパイル可能な関数 func で定義されたネット層を表す.

CompiledLayer[func,gradientfunc]

層のNetTrainでの使用を可能にする勾配伝播関数を指定する.

詳細とオプション

  • CompiledLayerは,通常,他の層では実装できないカスタム関数を計算するネット層を作成するために使われる.
  • CompiledLayer[func,Automatic]のようなCompiledLayer[func]は自動的に func を微分して勾配伝播関数を作成しようとする.CompiledLayer[func,None]は自動微分を無効にする
  • 関数 func および gradientfunc は,FunctionCompileによる処理に適した(つまり,引数指定がTypedおよびTypeSpecifierを使って行われた)有効なFunctionオブジェクトでなければならない.
  • CompiledLayerは,現行では単一の入出力ポートしかサポートしない.
  • 関数 func は層が行った計算を表すが,これはフォワードパスとしても知られるものである.
  • 関数 func は単一の配列を(層の入力を表す)入力として取らなければならず,単一の配列を(配列の出力を表す)出力として生成しなければならない.
  • 関数 gradientfunc は出力勾配から入力勾配を計算するが,これはバックワードパスとしても知られている.
  • 関数 gradientfunc は少なくとも2つの配列を層の入力を表す入力と出力勾配として取らなければならない.また,任意で,以前計算した出力を第3引数として与えることができる,関数 gradientfunc の結果は層の入力勾配を表す単一の配列である.
  • 関数 func は単一の例または例のバッチを取ると定義できる.CompiledLayer[func,"Input"]を使って2つの場合の曖昧さを解消するために(func で定義された階数と比較することで)入力の階数が指定できる.funcgradientfunc はどちらも単一の例を取るか,どちらも例のバッチを取るかしなければならない.
  • CompiledLayerは,NetGraph等で使うために次のポートを開放する.
  • "Input"配列
    "Output"配列
  • NumericArrayが入力として与えられると,出力はNumericArrayになる.
  • Options[CompiledLayer]は,層を構築するためのデフォルトオプションのリストを与える.Options[CompiledLayer[]]は,データについて層を評価するためのデフォルトオプションのリストを与える.
  • Information[CompiledLayer[]]は層についての報告を与える.
  • Information[CompiledLayer[],prop]CompiledLayer[]の特性 prop の値を与える.使用可能な特性NetGraphについてと同じである.
  • CompiledLayerはGPUアーキテクチャにコンパイルすることはできない.TargetDevice"GPU"と設定すると,訓練と推論の両方がCPU上で行われる.

例題

すべて開くすべて閉じる

  (2)

機械精度で階数3の配列を取る関数からコンパイルされた層を作る:

32ビット精度で階数2の配列を取る関数からCompiledLayerを作る:

この層を入力に適用する:

入力に対する入力の勾配を計算する:

スコープ  (3)

勾配伝播関数でCompiledLayerを作成する:

勾配伝播関数を使うと,NetTrainで層を使って勾配が計算できる:

勾配を計算する際に前に計算した値が再利用できるように勾配伝播関数の第3引数を指定する:

層を使って入力勾配を計算する:

要素のバッチに動作するCompiledLayerを作成する.階数2の配列を逆にする関数を定義する:

CompiledLayerで階数1の入力を指定する.この関数はバッチレベルで動作すると解釈されるようになった:

長さ4の単一のベクトルに動作する場合は,ベクトルは変わらない:

バッチに動作する場合は,ベクトルの順序が逆になる:

CompiledLayerは,このように使われると,通常の層では不可能なバッチ内の異なる要素を互いにインタラクトさせることができるようになる.

考えられる問題  (5)

自動微分は失敗するかもしれない:

第2引数で勾配伝播関数を指定するときは,満足しなければならない厳しい互換制約がいくつもある:

層関数が入力バッチに動作するときは,バッチ次元が保持されなければならない:

層と勾配関数で生成される出力の形状は,入力の値ではなく,入力の形状のみに依存すると期待される.出力の形状が入力値に依存する関数を作成する:

CompiledLayerは,形状を推定する間この関数をテスト入力について実行して,期待される出力の形状を入手する:

出力の形状が期待される形状と一致するなら,続く評価は成功裏に終了する:

期待されない形状が生成されるとエラーメッセージが出る:

CompiledLayerは,高速化のためにコンパイルされた関数が通常有効にするサニティチェックを無効にする.この結果,悪いコードが思わぬ動作の原因となったりカーネルがクラッシュしたりすることさえ考えられる.入力配列の領域外の要素にアクセスする関数を例に取ってみよう:

FunctionCompileが生成したCompiledCodeFunctionはエラーをスローする:

CompiledLayerは配列の境界をチェックせずに関数を実行するので,結果として未定義の動作になる:

Wolfram Research (2020), CompiledLayer, Wolfram言語関数, https://reference.wolfram.com/language/ref/CompiledLayer.html (2021年に更新).

テキスト

Wolfram Research (2020), CompiledLayer, Wolfram言語関数, https://reference.wolfram.com/language/ref/CompiledLayer.html (2021年に更新).

CMS

Wolfram Language. 2020. "CompiledLayer." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2021. https://reference.wolfram.com/language/ref/CompiledLayer.html.

APA

Wolfram Language. (2020). CompiledLayer. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/CompiledLayer.html

BibTeX

@misc{reference.wolfram_2024_compiledlayer, author="Wolfram Research", title="{CompiledLayer}", year="2021", howpublished="\url{https://reference.wolfram.com/language/ref/CompiledLayer.html}", note=[Accessed: 21-November-2024 ]}

BibLaTeX

@online{reference.wolfram_2024_compiledlayer, organization={Wolfram Research}, title={CompiledLayer}, year={2021}, url={https://reference.wolfram.com/language/ref/CompiledLayer.html}, note=[Accessed: 21-November-2024 ]}