中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PyTorch怎么實現MNIST數據集手寫數字識別

發布時間:2022-09-07 09:47:24 來源:億速云 閱讀:168 作者:iii 欄目:開發技術

這篇文章主要介紹“PyTorch怎么實現MNIST數據集手寫數字識別”,在日常操作中,相信很多人在PyTorch怎么實現MNIST數據集手寫數字識別問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”PyTorch怎么實現MNIST數據集手寫數字識別”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

一、PyTorch是什么?

PyTorch 是一個 Torch7 團隊開源的 Python 優先的深度學習框架,提供兩個高級功能:

  • 強大的 GPU 加速 Tensor 計算(類似 numpy)

  • 構建基于 tape 的自動升級系統上的深度神經網絡

你可以重用你喜歡的 python 包,如 numpy、scipy 和 Cython ,在需要時擴展 PyTorch。

二、程序示例

下面案例可供運行參考

1.引入必要庫

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

2.下載數據集

這里設置download=True,將會自動下載數據集,并存儲在./data文件夾。

train_data = torchvision.datasets.MNIST(root="./data",train=True,transform=torchvision.transforms.ToTensor(),download=True)
test_data = torchvision.datasets.MNIST(root="./data",train=False,transform=torchvision.transforms.ToTensor(),download=True)

3.加載數據集

batch_size=32表示每一個batch中包含32張手寫數字圖片,shuffle=True表示打亂測試集(data和target仍一一對應)

train_loader = DataLoader(train_data,batch_size=32,shuffle=True)
test_loader = DataLoader(test_data,batch_size=32,shuffle=False)

4.搭建CNN模型并實例化

class Net(torch.nn.Module):
    def __init__(self):
        super(Net,self).__init__()
        self.con1 = torch.nn.Conv2d(1,10,kernel_size=5)
        self.con2 = torch.nn.Conv2d(10,20,kernel_size=5)
        self.pooling = torch.nn.MaxPool2d(2)
        self.fc = torch.nn.Linear(320,10)
    def forward(self,x):
        batch_size = x.size(0)
        x = F.relu(self.pooling(self.con1(x)))
        x = F.relu(self.pooling(self.con2(x)))
        x = x.view(batch_size,-1)
        x = self.fc(x)
        return x
#模型實例化        
model = Net()

5.交叉熵損失函數損失函數及SGD算法優化器

lossfun = torch.nn.CrossEntropyLoss()
opt = torch.optim.SGD(model.parameters(),lr=0.01,momentum=0.5)

6.訓練函數

def train(epoch):
    running_loss = 0.0
    for i,(inputs,targets) in enumerate(train_loader,0):
        # inputs,targets = inputs.to(device),targets.to(device)
        opt.zero_grad()
        outputs = model(inputs)
        loss = lossfun(outputs,targets)
        loss.backward()
        opt.step()

        running_loss += loss.item()
        if i % 300 == 299:
            print('[%d,%d] loss:%.3f' % (epoch+1,i+1,running_loss/300))
            running_loss = 0.0

7.測試函數

def test():
    total = 0
    correct = 0
    with torch.no_grad():
        for (inputs,targets) in test_loader:
            # inputs, targets = inputs.to(device), targets.to(device)
            outputs = model(inputs)
            _,predicted = torch.max(outputs.data,dim=1)
            total += targets.size(0)
            correct += (predicted == targets).sum().item()
    print(100*correct/total)

8.運行

if __name__ == '__main__':
    for epoch in range(20):
        train(epoch)
        test()

到此,關于“PyTorch怎么實現MNIST數據集手寫數字識別”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

京山县| 宣武区| 鄂托克旗| 霍城县| 阿克苏市| 托克托县| 常德市| 潍坊市| 枣阳市| 南召县| 衢州市| 卓尼县| 江达县| 湘阴县| 双鸭山市| 安宁市| 阜南县| 思南县| 汉寿县| 宣威市| 玛纳斯县| 交城县| 田林县| 噶尔县| 托克逊县| 灯塔市| 辽中县| 滁州市| 锦州市| 丹阳市| 仪征市| 铜陵市| 庆云县| 即墨市| 德州市| 杨浦区| 江山市| 泾阳县| 日照市| 平定县| 衡阳市|