欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python中的Pytorch建模流程匯總

 更新時(shí)間:2022年03月03日 09:38:22   作者:Python學(xué)習(xí)與數(shù)據(jù)挖掘  
這篇文章主要介紹了python中的Pytorch建模流程匯總,主要幫大家?guī)椭蠹沂崂砩窠?jīng)網(wǎng)絡(luò)訓(xùn)練的架構(gòu),具有一的的參考價(jià)值,需要的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助

本節(jié)內(nèi)容學(xué)習(xí)幫助大家梳理神經(jīng)網(wǎng)絡(luò)訓(xùn)練的架構(gòu)。

一般我們訓(xùn)練神經(jīng)網(wǎng)絡(luò)有以下步驟:

  • 導(dǎo)入庫(kù)
  • 設(shè)置訓(xùn)練參數(shù)的初始值
  • 導(dǎo)入數(shù)據(jù)集并制作數(shù)據(jù)集
  • 定義神經(jīng)網(wǎng)絡(luò)架構(gòu)
  • 定義訓(xùn)練流程
  • 訓(xùn)練模型

推薦文章:

python實(shí)現(xiàn)可視化大屏

分享4款 Python 自動(dòng)數(shù)據(jù)分析神器

以下,我就將上述步驟使用代碼進(jìn)行注釋講解:

1 導(dǎo)入庫(kù)

import torch
from torch import nn
from torch.nn import functional as F
from torch import optim
from torch.utils.data import DataLoader, DataLoader
import torchvision
import torchvision.transforms as transforms

2 設(shè)置初始值

# 學(xué)習(xí)率
lr = 0.15
# 優(yōu)化算法參數(shù)
gamma = 0.8
# 每次小批次訓(xùn)練個(gè)數(shù)
bs = 128
# 整體數(shù)據(jù)循環(huán)次數(shù)
epochs = 10

3 導(dǎo)入并制作數(shù)據(jù)集

本次我們使用FashionMNIST圖像數(shù)據(jù)集,每個(gè)圖像是一個(gè)28*28的像素?cái)?shù)組,共有10個(gè)衣物類別,比如連衣裙、運(yùn)動(dòng)鞋、包等。

注:初次運(yùn)行下載需要等待較長(zhǎng)時(shí)間。

# 導(dǎo)入數(shù)據(jù)集
mnist = torchvision.datasets.FashionMNIST(
? ? root = './Datastes'
? ? , train = True
? ? , download = True
? ? , transform = transforms.ToTensor())
? ??
# 制作數(shù)據(jù)集
batchdata = DataLoader(mnist
? ? ? ? ? ? ? ? ? ? ? ?, batch_size = bs
? ? ? ? ? ? ? ? ? ? ? ?, shuffle = True
? ? ? ? ? ? ? ? ? ? ? ?, drop_last = False)

我們可以對(duì)數(shù)據(jù)進(jìn)行檢查:

for x, y in batchdata:
? ? print(x.shape)
? ? print(y.shape)
? ? break

# torch.Size([128, 1, 28, 28])
# torch.Size([128])

可以看到一個(gè)batch中有128個(gè)樣本,每個(gè)樣本的維度是1*28*28。

之后我們確定模型的輸入維度與輸出維度:

# 輸入的維度
input_ = mnist.data[0].numel()
# 784

# 輸出的維度
output_ = len(mnist.targets.unique())
# 10

4 定義神經(jīng)網(wǎng)絡(luò)架構(gòu)

先使用一個(gè)128個(gè)神經(jīng)元的全連接層,然后用relu激活函數(shù),再將其結(jié)果映射到標(biāo)簽的維度,并使用softmax進(jìn)行激活。

# 定義神經(jīng)網(wǎng)絡(luò)架構(gòu)
class Model(nn.Module):
? ? def __init__(self, in_features, out_features):
? ? ? ? super().__init__()
? ? ? ? self.linear1 = nn.Linear(in_features, 128, bias = True)
? ? ? ? self.output = nn.Linear(128, out_features, bias = True)
? ??
? ? def forward(self, x):
? ? ? ? x = x.view(-1, 28*28)
? ? ? ? sigma1 = torch.relu(self.linear1(x))
? ? ? ? sigma2 = F.log_softmax(self.output(sigma1), dim = -1)
? ? ? ? return sigma2

5 定義訓(xùn)練流程

在實(shí)際應(yīng)用中,我們一般會(huì)將訓(xùn)練模型部分封裝成一個(gè)函數(shù),而這個(gè)函數(shù)可以繼續(xù)細(xì)分為以下幾步:

  • 定義損失函數(shù)與優(yōu)化器
  • 完成向前傳播
  • 計(jì)算損失
  • 反向傳播
  • 梯度更新
  • 梯度清零

在此六步核心操作的基礎(chǔ)上,我們通常還需要對(duì)模型的訓(xùn)練進(jìn)度、損失值與準(zhǔn)確度進(jìn)行監(jiān)視。

注釋代碼如下:

# 封裝訓(xùn)練模型的函數(shù)
def fit(net, batchdata, lr, gamma, epochs):
# 參數(shù):模型架構(gòu)、數(shù)據(jù)、學(xué)習(xí)率、優(yōu)化算法參數(shù)、遍歷數(shù)據(jù)次數(shù)

? ? # 5.1 定義損失函數(shù)
? ? criterion = nn.NLLLoss()
? ? # 5.1 定義優(yōu)化算法
? ? opt = optim.SGD(net.parameters(), lr = lr, momentum = gamma)
? ??
? ? # 監(jiān)視進(jìn)度:循環(huán)之前,一個(gè)樣本都沒有看過
? ? samples = 0
? ? # 監(jiān)視準(zhǔn)確度:循環(huán)之前,預(yù)測(cè)正確的個(gè)數(shù)為0
? ? corrects = 0
? ??
? ? # 全數(shù)據(jù)訓(xùn)練幾次
? ? for epoch in range(epochs):
? ? ? ? # 對(duì)每個(gè)batch進(jìn)行訓(xùn)練
? ? ? ? for batch_idx, (x, y) in enumerate(batchdata):
? ? ? ? ? ? # 保險(xiǎn)起見,將標(biāo)簽轉(zhuǎn)為1維,與樣本對(duì)齊
? ? ? ? ? ? y = y.view(x.shape[0])
? ? ? ? ? ??
? ? ? ? ? ? # 5.2 正向傳播
? ? ? ? ? ? sigma = net.forward(x)
? ? ? ? ? ? # 5.3 計(jì)算損失
? ? ? ? ? ? loss = criterion(sigma, y)
? ? ? ? ? ? # 5.4 反向傳播
? ? ? ? ? ? loss.backward()
? ? ? ? ? ? # 5.5 更新梯度
? ? ? ? ? ? opt.step()
? ? ? ? ? ? # 5.6 梯度清零
? ? ? ? ? ? opt.zero_grad()
? ? ? ? ? ??
? ? ? ? ? ? # 監(jiān)視進(jìn)度:每訓(xùn)練一個(gè)batch,模型見過的數(shù)據(jù)就會(huì)增加x.shape[0]
? ? ? ? ? ? samples += x.shape[0]
? ? ? ? ? ??
? ? ? ? ? ? # 求解準(zhǔn)確度:全部判斷正確的樣本量/已經(jīng)看過的總樣本量
? ? ? ? ? ? # 得到預(yù)測(cè)標(biāo)簽
? ? ? ? ? ? yhat = torch.max(sigma, -1)[1]
? ? ? ? ? ? # 將正確的加起來
? ? ? ? ? ? corrects += torch.sum(yhat == y)
? ? ? ? ? ??
? ? ? ? ? ? # 每200個(gè)batch和最后結(jié)束時(shí),打印模型的進(jìn)度
? ? ? ? ? ? if (batch_idx + 1) % 200 == 0 or batch_idx == (len(batchdata) - 1):
? ? ? ? ? ? ? ? # 監(jiān)督模型進(jìn)度
? ? ? ? ? ? ? ? print("Epoch{}:[{}/{} {: .0f}%], Loss:{:.6f}, Accuracy:{:.6f}".format(
? ? ? ? ? ? ? ? ? ? epoch + 1
? ? ? ? ? ? ? ? ? ? , samples
? ? ? ? ? ? ? ? ? ? , epochs*len(batchdata.dataset)
? ? ? ? ? ? ? ? ? ? , 100*samples/(epochs*len(batchdata.dataset))
? ? ? ? ? ? ? ? ? ? , loss.data.item()
? ? ? ? ? ? ? ? ? ? , float(100.0*corrects/samples)))

6 訓(xùn)練模型

# 設(shè)置隨機(jī)種子
torch.manual_seed(51)

# 實(shí)例化模型
net = Model(input_, output_)

# 訓(xùn)練模型
fit(net, batchdata, lr, gamma, epochs)
# Epoch1:[25600/600000 ?4%], Loss:0.524430, Accuracy:69.570312
# Epoch1:[51200/600000 ?9%], Loss:0.363422, Accuracy:74.984375
# ......
# Epoch10:[600000/600000 ?100%], Loss:0.284664, Accuracy:85.771835

現(xiàn)在我們已經(jīng)用Pytorch訓(xùn)練了最基礎(chǔ)的神經(jīng)網(wǎng)絡(luò),并且可以查看其訓(xùn)練成果。大家可以將代碼復(fù)制進(jìn)行運(yùn)行!

雖然沒有用到復(fù)雜的模型,但是我們?cè)诿看谓r(shí)的基本思想都是一致的

到此這篇關(guān)于python中的Pytorch建模流程匯總的文章就介紹到這了,更多相關(guān)Pytorch建模流程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決python調(diào)用自己文件函數(shù)/執(zhí)行函數(shù)找不到包問題

    解決python調(diào)用自己文件函數(shù)/執(zhí)行函數(shù)找不到包問題

    這篇文章主要介紹了解決python調(diào)用自己文件函數(shù)/執(zhí)行函數(shù)找不到包問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • Python+Opencv實(shí)現(xiàn)圖像模板匹配詳解

    Python+Opencv實(shí)現(xiàn)圖像模板匹配詳解

    模板匹配可以看作是對(duì)象檢測(cè)的一種非?;镜男问健J褂媚0迤ヅ?,我們可以使用包含要檢測(cè)對(duì)象的“模板”來檢測(cè)輸入圖像中的對(duì)象。本文為大家介紹了圖像模板匹配的實(shí)現(xiàn)方法,需要的可以參考一下
    2022-09-09
  • Python接口自動(dòng)化之接口依賴

    Python接口自動(dòng)化之接口依賴

    這篇文章主要介紹了python接口自動(dòng)化測(cè)試之接口數(shù)據(jù)依賴的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2021-08-08
  • jupyter 實(shí)現(xiàn)notebook中顯示完整的行和列

    jupyter 實(shí)現(xiàn)notebook中顯示完整的行和列

    這篇文章主要介紹了jupyter 實(shí)現(xiàn)notebook中顯示完整的行和列,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 在Python程序中實(shí)現(xiàn)分布式進(jìn)程的教程

    在Python程序中實(shí)現(xiàn)分布式進(jìn)程的教程

    這篇文章主要介紹了在Python程序中實(shí)現(xiàn)分布式進(jìn)程的教程,在多進(jìn)程編程中十分有用,示例代碼基于Python2.x版本,需要的朋友可以參考下
    2015-04-04
  • Python利用request庫(kù)實(shí)現(xiàn)翻譯接口

    Python利用request庫(kù)實(shí)現(xiàn)翻譯接口

    這篇文章主要為大家詳細(xì)介紹了Python如何利用request庫(kù)打造自己的翻譯接口,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-04-04
  • opencv 分類白天與夜景視頻的方法

    opencv 分類白天與夜景視頻的方法

    最近有個(gè)數(shù)據(jù)需要分類處理,是一批含有白天跟夜晚的視頻數(shù)據(jù),需要進(jìn)行區(qū)分開來,本文就來實(shí)現(xiàn),感興趣的可以了解一下
    2021-06-06
  • python編譯pyc文件的過程解析

    python編譯pyc文件的過程解析

    pyc是一種二進(jìn)制文件,是由py文件經(jīng)過編譯后,生成的文件,是一種byte code,這篇文章主要介紹了python編譯pyc文件,需要的朋友可以參考下
    2021-09-09
  • Python sort 自定義函數(shù)排序問題

    Python sort 自定義函數(shù)排序問題

    這篇文章主要介紹了Python sort 自定義函數(shù)排序問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 解決tensorflow添加ptb庫(kù)的問題

    解決tensorflow添加ptb庫(kù)的問題

    今天小編就為大家分享一篇解決tensorflow添加ptb庫(kù)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02

最新評(píng)論