PyTorch を学ぶには?簡単すぎる

PyTorch を学ぶには?簡単すぎる

多くの友人から、PyTorch の学習方法を尋ねられました。長期間の練習を経て、初心者が知っておく必要のある概念や使用法は実際にはそれほど多くないことがわかりました。以下にまとめた簡潔なガイドを見てみましょう。

テンソルの構築

PyTorch のテンソルは、NumPy の ndarray に似た多次元配列ですが、GPU 上で実行できます。

 import torch # Create a 2x3 tensor tensor = torch.tensor([[1, 2, 3], [4, 5, 6]]) print(tensor)

動的計算グラフ

PyTorch は、操作の実行時にオンザフライで構築される動的計算グラフを使用します。これにより、実行時にグラフを変更する柔軟性が得られます。

 # Define two tensors a = torch.tensor([2.], requires_grad=True) b = torch.tensor([3.], requires_grad=True) # Compute result c = a * b c.backward() # Gradients print(a.grad) # Gradient wrt a

GPUアクセラレーション

PyTorch を使用すると、CPU と GPU を簡単に切り替えることができます。 .to(device) を使用します:

 device = "cuda" if torch.cuda.is_available() else "cpu" tensor = tensor.to(device)

Autograd: 自動微分化

PyTorch の autograd は、テンソルのすべての演算に対して自動微分を提供します。 requires_grad=True を設定すると、計算を追跡できます。

 x = torch.tensor([2.], requires_grad=True) y = x**2 y.backward() print(x.grad) # Gradient of y wrt x

モジュラーニューラルネットワーク

PyTorch は、ニューラル ネットワーク アーキテクチャを定義し、サブクラス化によってカスタム レイヤーを作成するための nn.Module クラスを提供します。

 import torch.nn as nn class SimpleNN(nn.Module): def __init__(self): super().__init__() self.fc = nn.Linear(1, 1) def forward(self, x): return self.fc(x)

定義済みのレイヤーと損失関数

PyTorch は、nn モジュールでさまざまな定義済みレイヤー、損失関数、最適化アルゴリズムを提供します。

 loss_fn = nn.CrossEntropyLoss() optimizer = torch.optim.Adam(model.parameters(), lr=0.001)

データセットとデータローダー

効率的なデータ処理とバッチ処理を実現するために、PyTorch は Dataset クラスと DataLoader クラスを提供します。

 from torch.utils.data import Dataset, DataLoader class CustomDataset(Dataset): # ... (methods to define) data_loader = DataLoader(dataset, batch_size=32, shuffle=True)

モデルのトレーニング(ループ)

通常、PyTorch のトレーニングは、順方向伝播、損失計算、逆方向パス、パラメータ更新というパターンに従います。

 for epoch in range(epochs): for data, target in data_loader: optimizer.zero_grad() output = model(data) loss = loss_fn(output, target) loss.backward() optimizer.step()

モデルのシリアル化

torch.save() と torch.load() を使用してモデルを保存および読み込みます。

 # Save torch.save(model.state_dict(), 'model_weights.pth') # Load model.load_state_dict(torch.load('model_weights.pth'))

ジット

PyTorch はデフォルトで Eager モードで実行されますが、モデルの Just-In-Time (JIT) コンパイルも提供します。

 scripted_model = torch.jit.script(model) scripted_model.save("model_jit.pt")

<<: 

>>:  中国科学院による1万語の説明:最先端の画像拡散モデルのレビュー

ブログ    
ブログ    
ブログ    

推薦する

...

...

インテリジェントな運用とメンテナンスからスマートな運用まで、Qingchuang Technologyは企業に探偵シャーロックの能力を提供します

[51CTO.com からのオリジナル記事] 運用保守作業は、初期の手動運用保守から自動化運用保守、...

...

...

鉄道欠陥検出における機械学習の実用化

【51CTO.com クイック翻訳】はじめに列車が走行しているとき、線路には大きな圧力がかかることが...

ディープラーニング、NLP、コンピュータービジョン向けのトップ 30 Python ライブラリ

[[358174]] Gregory Piatetsky による次のグラフでは、各リポジトリにカテゴ...

DJL [ディープラーニング]を正しく開く方法

[[350239]]この記事はWeChatの公開アカウント「小明野菜市場」から転載したもので、著者は...

ステップバイステップガイド: FastAPI を使用して YOLO モデルをデプロイする手順

コンピューター ビジョンの分野では、You Only Look Once (YOLO) アルゴリズム...

顔認識は簡単に破られるのでしょうか?虐待と闘う方法

未来産業研究所は、顔認識市場規模は今後5年間で平均23%の複合成長率を維持し、2024年までに市場規...

AI倫理: CIOが問うべき5つの質問

[51CTO.com クイック翻訳] 人工知能ツールを導入する IT リーダーは、責任の取り方、プラ...

ロボットは電気羊の夢を見るか?Google AI 従業員の辞職から AI 倫理について何を学ぶことができるか?

2月20日、Googleの倫理AIチームの創設者であるミッチェル氏はTwitterに「私は解雇され...

...

ディープラーニングとツリー探索によるゼロからの高速学習と低速学習

[[211446]]この記事では、ロンドン大学ユニバーシティ・カレッジ (UCL) の Thomas...