オリジナルトレーニングスクリプト
次のPythonスクリプトのコードを持っているとしましょう。main
という関数を定義し、典型的なトレーニングループを模倣します。各エポックごとに、トレーニングおよび検証データセットに対して精度と損失が計算されます。この例の目的のために値はランダムに生成されます。
ハイパーパラメーター値を格納するための辞書 config
を定義しました。セルの最後に、モックトレーニングコードを実行するために main
関数を呼び出します。
W&B Python SDKを用いたトレーニングスクリプト
以下のコード例は、W&B Python SDKをコードに追加する方法を示しています。CLIでW&B Sweepジョブを開始する場合、CLIタブを探索したいでしょう。JupyterノートブックやPythonスクリプト内でW&B Sweepジョブを開始する場合、Python SDKタブを探索してください。- Python スクリプトまたはノートブック
- CLI
W&B Sweepを作成するために、コード例に以下を追加しました:
- Weights & Biases Python SDKをインポートします。
- キーと値のペアがスイープ設定を定義する辞書オブジェクトを作成します。次の例では、バッチサイズ (
batch_size
), エポック (epochs
), および学習率 (lr
) のハイパーパラメーターが各スイープで変化します。スイープ設定の作成方法についての詳細は、Define sweep configurationを参照してください。 - スイープ設定辞書を
wandb.sweep
に渡します。これによりスイープが初期化され、スイープID (sweep_id
) が返されます。スイープの初期化方法についての詳細は、Initialize sweepsを参照してください。 wandb.init()
APIを使用して、データを同期およびログ化しながら、バックグラウンドプロセスを生成して W&B Run として実行します。- (オプション) 固定値を定義する代わりに
wandb.config
から値を定義します。 wandb.log
を使用して最適化したいメトリクスをログします。設定で定義されたメトリクスを必ずログしてください。この例では、設定辞書 (sweep_configuration
) でval_acc
を最大化するスイープを定義しました。wandb.agent
API呼び出しを使用してスイープを開始します。スイープID、スイープが実行する関数の名前 (function=main
)、および試行する最大run数を4に設定します (count=4
)。W&B Sweepの開始方法についての詳細は、Start sweep agentsを参照してください。
メトリクスをログする際の考慮事項
スイープ設定で指定したメトリクスを明示的にW&Bにログすることを確認してください。スイープのメトリクスをサブディレクトリ内でログしないでください。 例えば、以下の擬似コードを考えてみてください。ユーザーが検証損失 ("val_loss": loss
) をログしたいとします。まず、ユーザーは辞書に値を渡しますが、wandb.log
に渡される辞書は辞書内のキーと値のペアに明示的にアクセスしていません:
wandb.log
メソッドに辞書を渡す際にキーと値のペアを指定しています:
train.py