PyTorchでの重みの初期化方法
PyTorchで重みを初期化する方法に関する短いチュートリアルとコード及び対話式の可視化。
Created on August 1|Last edited on August 1
Comment
目次
- 私たちが取り上げる内容
- PyTorchでクラス関数を使用して重みをゼロに初期化する
- パイトーチ重み初期化実験
- 要約
取り上げる内容
この記事では、PyTorchモデルのさまざまなレイヤーに対する重みの初期化方法を見ていきます。
テンソルフローとは異なり、PyTorchは様々な層で重みを初期化するための簡単なインターフェースを提供していません(ただし、トーチ.nn.init ですしたがって、XavierやHeの初期化などのよく知られた手法に従って重みを初期化したいときに難しくなります。
以下で重みの初期化方法を見ていきますが、実行可能なColabで進めたい場合は、こちらでできます:
💡
PyTorchでクラス関数を使用して重みをゼロに初期化する方法
重みを初期化する最も一般的な方法の一つは、クラスの関数を使用し、最後に呼び出すことです。__init__カスタムPyTorchモデルの関数。
import torch.nn as nn class Model(nn.Module): # . . . def __init__(self): # . self.apply(self._init_weights) def _init_weights(self, module): if isinstance(module, nn.Linear): module.weight.data.normal_(mean=0.0, std=1.0) if module.bias is not None: module.bias.data.zero_()
このコードスニペットは、平均0、標準偏差1の正規分布からすべての重みを初期化し、すべてのバイアスをゼロに初期化します。他の層に拡張するのも比較的簡単です。nn.LayerNormとnn.Embedding。
def _init_weights(self, module): if isinstance(module, nn.Embedding): module.weight.data.normal_(mean=0.0, std=1.0) if module.padding_idx is not None: module.weight.data[module.padding_idx].zero_() elif isinstance(module, nn.LayerNorm): module.bias.data.zero_() module.weight.data.fill_(1.0)
- 申し訳ありませんが、あなたのリクエストに応じた翻訳を提供することができません。
- 制服
- 。
- 通常
- 、
- 定数
- 、
- もの
- および
- ゼロ
- 申し訳ありませんが、テキストが見つかりませんでした。別の内容をお試しください。
- ザビエルユニフォーム
- 。
- ザビエルノーマル
- 、
- カイミング均一
- 。
- kaiming_normal_
- および
- 直交
パイトーチ重み初期化実験
以下のWeights & Biasesチャートは、提供されたColabから描画されており、重みの初期化をよりよく説明するためのものです。もう一度、それを見つけることができます:
ここでは、正規分布のさまざまな標準偏差がパフォーマンスの面でどのように異なるかを確認できます。
Run set
42
標準偏差の大きい値は良い結果に結びつかず、ほとんどの場合、局所最小値に到達します。一方で、小さい値ははるかに良いパフォーマンスにつながります。
要約
この記事では、PyTorchディープラーニングモデルの重みを初期化する方法と、Weights & Biasesを使用してメトリクスを監視することで貴重な洞察を得る方法を紹介しました。
W&Bの機能全体を見るには、こちらをご確認ください。short 5 minutes guide。数学や「ゼロからの」コード実装を含むレポートがもっと必要な場合は、下のコメント欄や私たちのforum ✨!
Weights & Biasesを試してみてください。
Weights & Biasesは、機械学習の実験を追跡するのに役立ちます。私たちのツールを使って、runのハイパーパラメーターと出力メトリクスをログし、結果を視覚化および比較して、学びを同僚と迅速に共有しましょう。
指示:
- 緑色の「実行」ボタンをクリック
- (最初に「実行」をクリックした時、Replitはマシン割り当てのために約30〜45秒かかります)
- ターミナルウィンドウのプロンプトに従ってください。
- (右下のペインの下)
- ターミナルウィンドウのサイズを変更できます。
- (右下)で拡大表示
おすすめの読書
How To Use GPU with PyTorch
A short tutorial on using GPUs for your deep learning models with PyTorch, from checking availability to visualizing usable.
A Gentle Introduction To Weight Initialization for Neural Networks
An explainer and comprehensive overview of various strategies for neural network weight initialization
PyTorch Dropout for regularization - tutorial
Learn how to regularize your PyTorch model with Dropout, complete with a code tutorial and interactive visualizations
How to save and load models in PyTorch
This article is a machine learning tutorial on how to save and load your models in PyTorch using Weights & Biases for version control.
Image Classification Using PyTorch Lightning and Weights & Biases
This article provides a practical introduction on how to use PyTorch Lightning to improve the readability and reproducibility of your PyTorch code.
How to Compare Keras Optimizers in Tensorflow for Deep Learning
A short tutorial outlining how to compare Keras optimizers for your deep learning pipelines in Tensorflow, with a Colab to help you follow along.
Add a comment