文章目录
- ✌ 卷积神经网络手写数字图像识别
-
- 1、✌ 导入相关库
- 2、✌ 导入手写数据集
- 3、✌ 定义数据包装器
- 4、✌ 查看数据维度
- 5、✌ 定义卷积网络层
- 6、✌ 定义模型与损失函数、优化器
- 7、✌ 训练、测试函数
- 8、✌ 网络迭代训练
- 9、✌ 保存模型
- 10、✌ 加载模型
- 11、✌ 模型测试
✌ 卷积神经网络手写数字图像识别
1、✌ 导入相关库
import torch
from torch import nn,optim
from torchvision import datasets,transforms
from torch.utils.data import DataLoader
from PIL import Image
from torchvision import models
2、✌ 导入手写数据集
train_dataset = datasets.MNIST(root='./',
train=True,
transform=transforms.ToTensor(),
download=False)
test_dataset = datasets.MNIST(root='./',
train=False,
transform=transforms.ToTensor(),
download=False)
3、✌ 定义数据包装器
batch_size=64
train_loader=DataLoader(dataset=train_dataset,
batch_size=batch_size,
shuffle=True)
test_loader=DataLoader(dataset=test_dataset,
batch_size=batch_size,
shuffle=True)
4、✌ 查看数据维度
for i, data in enumerate(train_loader):
inputs, labels = data
print(inputs.shape)
print(labels.shape)
break
5、✌ 定义卷积网络层
class CNN(nn.Module):
def __init__(self):
super(CNN,self).__init__()
self.conv1=nn.Sequential(nn.Conv2d(1,64,5,1,2),nn.ReLU(),nn.MaxPool2d(2,2))
self.conv2=nn.Sequential(nn.Conv2d(64,128,5,1,2),nn.ReLU(),nn.MaxPool2d(2,2))
self.fc1=nn.Sequential(nn.Linear(128*7*7,1000),nn.Dropout(p=0.2),nn.ReLU())
self.fc2=nn.Sequential(nn.Linear(1000,10),nn.Softmax(dim=1))
def forward(self, x):
x = self.conv1(x)
x = self.conv2(x)
x = x.reshape(x.shape[0], -1)
x = self.fc1(x)
x = self.fc2(x)
return x
6、✌ 定义模型与损失函数、优化器
LR=0.0003
model=CNN()
loss_fn=nn.CrossEntropyLoss()
optimizer=optim.Adam(model.parameters(),LR)
7、✌ 训练、测试函数
def train():
model.train()
for i,data in enumerate(train_loader):
x,y=data
y_pred=model(x)
loss=loss_fn(y_pred,y)
optimizer.zero_grad()
loss.backward()
optimizer.step()
def test():
model.eval()
correct=0
for i,data in enumerate(train_loader):
x,y=data
y_pred=model(x)
_,pred=torch.max(y_pred,1)
correct+=(pred==y).sum()
print('准确率:',correct.item()/len(train_dataset))
correct = 0
for i, data in enumerate(test_loader):
x,y=data
y_pred=model(x)
_,pred=torch.max(y_pred,1)
correct+=(pred==y).sum()
print('准确率:',correct.item()/len(test_dataset))
8、✌ 网络迭代训练
for epoch in range(1,11):
print('epoch:',epoch)
train()
test()
9、✌ 保存模型
torch.save(model.state_dict(),r'D:\res.pth')
10、✌ 加载模型
model=CNN()
model.load_state_dict(torch.load(r'D:\res.pth'))
loss_fn=nn.CrossEntropyLoss()
optimizer=optim.Adam(model.parameters(),LR)
11、✌ 模型测试
transform = transforms.Compose([
transforms.ToTensor()
])
img=Image.open(r'C:\Users\HUAWEI\Desktop\7.jpg')
img=img.resize((28,28))
img=img.convert('L')
img=transform(img).unsqueeze(0)
out=model(img)
_,pred=torch.max(out,1)
print('该数字为:',pred.item())