使用 PyTorch 搭建网络 - predict_py篇

predict_py篇

python中采用驼峰书写法且首字母大写的变量符号一般表示类名。

学习网络步骤:看原论文+看别人对原论文的理解,学习网络结构,看损失函数计算,看数据集,看别人写的代码,复现代码。

经历以上步骤我们便可以选择合适的框架复现代码,这里使用PyTorch复现网络结构。我们用PyTorch搭建网络可以分为以下几个module,数据处理dataloader.py,网络模型model.py,训练模块train.py,工具模块utils.py,预测模块predict.py。接下来我们将以LeNet为例进行讲解。

由于LeNet使用了CIFAR10数据集,所以我们直接用内置方法生成dataset便可。

目录如下:

  • predict_py 综述
  • torch.nn.Module.load_state_dic() 方法
  • torch.softmax() 方法
  • 源码

predict_py 综述

在该模块中进行预测,我们需要创建net,并载入train_py中训练好的权重文件,配置好net的parameters。将test中图片经过dataloader_py后转成我们需要的tensor,将该tensor传入net中,进行FP传播得到最终的输出。

torch.nn.Module.load_state_dic() 方法

net = LeNet()
net.load_state_dict(torch.load("Lenet.pth"))

我们创建网络后,使用net对象的load_state_dic()torch.load()方法载入预训练权重。

torch.softmax() 方法

with torch.no_grad():
    outputs = net(im)
    predict = torch.softmax(outputs, dim = 1)
print(predict)

在全连接层的最后一层接入torch.softmax()方法进行多分裂预测。

源码

import torch
import torchvision.transforms as transforms
from PIL import Image
from model import LeNet

transforms = transforms.Compose(
    [transforms.Resize((32, 32)),
    transforms.ToTensor(), 
    transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))]
)

classes = ("plane", "car", "bird", "cat",
            "deer", "dog", "frog", "horse", "ship", "truck")

net = LeNet()
net.load_state_dict(torch.load("Lenet.pth"))

im = Image.open("1.jpg")
im = transforms(im) # [C, H, W]
im = torch.unsqueeze(im, dim=0) # [N, C, H, W]

with torch.no_grad():
    outputs = net(im)
    predict = torch.softmax(outputs, dim = 1)
print(predict)

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值