Pytorch の最も重要な 9 つの操作! ! !

Pytorch の最も重要な 9 つの操作! ! !

今日は、pytorch についてお話します。今日は、9 つ​​の最も重要な pytorch 操作をまとめました。これにより、全体的な概念が確実に理解できるようになります。

テンソルの作成と基本操作

PyTorch テンソルは NumPy 配列に似ていますが、GPU アクセラレーションと自動微分化を提供します。テンソルは、torch.tensor を通じて、または torch.zeros や torch.ones などの関数を使用して作成できます。

 import torch # 创建张量a = torch.tensor([1, 2, 3]) b = torch.tensor([4, 5, 6]) # 张量加法c = a + b print(c)

オートグラッド

torch.autograd モジュールは自動微分化のメカニズムを提供し、操作を記録し、勾配を計算できるようにします。

 x = torch.tensor([1.0], requires_grad=True) y = x**2 y.backward() print(x.grad)

ニューラルネットワーク層 (nn.Module)

torch.nn.Module は、ニューラル ネットワークを構築するための基本コンポーネントです。線形層 (nn.Linear)、畳み込み層 (nn.Conv2d) など、さまざまな層を含めることができます。

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

オプティマイザ

オプティマイザーは、損失関数を最小化するためにモデル パラメータを調整するために使用されます。以下は、確率的勾配降下法 (SGD) オプティマイザーを使用した例です。

 import torch.optim as optim optimizer = optim.SGD(model.parameters(), lr=0.01)

損失関数

損失関数は、モデル出力とターゲット間のギャップを測定するために使用されます。たとえば、クロスエントロピー損失は分類問題に適しています。

 loss_function = nn.CrossEntropyLoss()

データの読み込みと前処理

PyTorch の torch.utils.data モジュールは、データの読み込みと前処理のための Dataset クラスと DataLoader クラスを提供します。データセット クラスは、さまざまなデータ形式やタスクに合わせてカスタマイズできます。

 from torch.utils.data import DataLoader, Dataset class CustomDataset(Dataset): # 实现数据集的初始化和__getitem__方法dataloader = DataLoader(dataset, batch_size=64, shuffle=True)

モデルの保存と読み込み

torch.save を使用してモデルの状態辞書を保存し、torch.load を使用してモデルを読み込むことができます。

 # 保存模型torch.save(model.state_dict(), 'model.pth') # 加载模型loaded_model = SimpleNN() loaded_model.load_state_dict(torch.load('model.pth'))

学習率調整

torch.optim.lr_scheduler モジュールは、学習率のスケジューリングのためのツールを提供します。たとえば、StepLR を使用して、各エポックの後に学習率を下げることができます。

 from torch.optim import lr_scheduler scheduler = lr_scheduler.StepLR(optimizer, step_size=5, gamma=0.1)

モデル評価

モデルのトレーニングが完了したら、モデルのパフォーマンスを評価する必要があります。評価するときは、モデルを評価モード (model.eval()) に切り替え、torch.no_grad() コンテキスト マネージャーを使用して勾配計算を回避する必要があります。

 model.eval() with torch.no_grad(): # 运行模型并计算性能指标

<<:  超強力なPytorchオペレーション! ! !

>>:  GitHub の年末特典: プログラミング チャットボットがすべてのユーザーに公開され、ネットユーザーはこれをゲームチェンジャーと呼ぶ

ブログ    
ブログ    

推薦する

AIは人間の編集者に代わる最初の試みに失敗した。WikipediaはCNET Mediaを信頼できる情報源とみなさなくなった

3月2日のニュースによると、数秒以内にニュース記事を生成することは、メディア業界にとって確かに非常に...

...

世界のAI支出は2024年に1100億ドルに達すると予想

人工知能(AI)への世界的な支出は、今後4年間で2020年の501億ドルから2024年には1100億...

ガートナー:金融業界はAIがもたらす変化を追求

私たちがよく話題にする金融テクノロジーとは、人工知能とデータを活用して新しいビジネス手法を見つけるも...

ビッグデータと機械学習を駆使して12星座の素顔を明らかにする!

[[201919]] 「なぜ論文が出版されないのでしょうか?私は研究に向いていないのでしょうか?」...

自然言語処理のためのディープラーニングの概要: 基本概念から最先端の研究まで

自然言語処理入門導入自然言語処理 (NLP) は、言語を処理および理解することで特定のタスクを実行で...

人工知能が誤って解釈する画像とはどのようなものでしょうか?

ウィリアム・ギブソンの2010年の小説『ゼロ・ヒストリー』では、ある登場人物が「これまでで最も醜いT...

2018 年の AI にとって重要なマイルストーンは何でしたか? 2019年に何が起こるでしょうか?

世界中で普及している人工知能は人類に利益をもたらすのでしょうか?それとも世界を破壊するのでしょうか?...

金融AIが外灘サミットでデビュー: 完全な金融知識を備え、同時に数百万人と会話し、金融アドバイスを提供可能

「こんにちは。投資したいお金があります。期待収益は 6 ~ 10 ポイントです。1 年間投資したいと...

人工知能対神: インダストリー4.0におけるグローバル社会の微妙なつながり

[[423479]]はい、タイトルの読み方は正しいです。特にインダストリー 4.0 では、AI と神...

ロボットが家事の仕事を代行:人間のデモンストレーション動画を見るだけで、10時間でコーヒーの淹れ方を学ぶ

先週、スタンフォード大学のエビ揚げロボットが爆発事故を起こした後、コーヒーを作るロボットが再び人気を...

DAMOアカデミーは、初めて半教師あり知識注入を使用して、新しい事前トレーニング済み対話モデルを立ち上げ、大幅な改善を達成しました。

ディープラーニングの急速な発展に伴い、テキスト分類、感情分析など、学術界では毎年多くの高品質な注釈付...

ChatGPTが使用する機械学習技術

著者 |ブライト・リャオ「プログラマーから見たChatGPT」の記事では、開発者のChatGPTに対...