IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 完整的模型验证套路————PyTorch(完结) -> 正文阅读

[人工智能]完整的模型验证套路————PyTorch(完结)

哔哩大学的PyTorch深度学习快速入门教程(绝对通俗易懂!)【小土堆】
的P32讲介绍了利用上几节的模型,从网上找了一张狗的图片进行验证。

所用图片为:
在这里插入图片描述
上几节的CIFAR10模型的每个序列对应的真实类别如图:
在这里插入图片描述
若结果为第5个类别的概率最大,则验证成功!

代码注释为:

其中tudui_0.pth为上几节保存的文件,这个代码要用最开始cpu训练的模型。

import torch
import torchvision
from PIL import Image
from torch import nn

image_path = "imgs/dog.png"
image = Image.open(image_path)
print(image)
image = image.convert('RGB')
# 因为png格式为四个通道,除了RGB三个通道外,还有一个透明度通道。所以调用此语句保留其颜色通道。


transform = torchvision.transforms.Compose([torchvision.transforms.Resize((32, 32)),
                                            torchvision.transforms.ToTensor()])
# 这个照片size=258x208,因为模型为32×32,所以改一下
image = transform(image)
print(image.shape)

# 加载网络模型
class Tudui(nn.Module):
    def __init__(self):
        super(Tudui, self).__init__()
        # 为了避免上下两个def都写一整串,将整个网络放到序列当中,前边有讲过,注释了很多代码有老乡的那一篇
        self.model = nn.Sequential(
            nn.Conv2d(3, 32, 5, 1, 2),   #  卷积
            nn.MaxPool2d(2),             #  池化
            nn.Conv2d(32, 32, 5, 1, 2),
            nn.MaxPool2d(2),
            nn.Conv2d(32, 64, 5, 1, 2),
            nn.MaxPool2d(2),
            nn.Flatten(),
            nn.Linear(64*4*4, 64),   # 最后两步的展平
            nn.Linear(64, 10)

        )


    def forward(self, x):
        x = self.model(x)
        return x

model = torch.load("tudui_0.pth")
print(model)

# img输入到这个模型中
# 这里一开始用的gpu的模型,会报错,换成cpu的"tudui_0.pth"模型就行了
image = torch.reshape(image, (1, 3, 32, 32))
model.eval()
with torch.no_grad():
    output = model(image)
print(output)

print(output.argmax(1))

结果如图:
在这里插入图片描述
很遗憾,没有验证对,识别成了青蛙。这是因为训练了10次,次数不够。我们用GPU进行30次训练再试一次。
还是这个代码,有一个细节的修改,在!!!处注释了。这次用的30次训练后的gpu模型

import torch
import torchvision
from PIL import Image
from torch import nn

image_path = "imgs/dog.png"
image = Image.open(image_path)
print(image)
image = image.convert('RGB')
# 因为png格式为四个通道,除了RGB三个通道外,还有一个透明度通道。所以调用此语句保留其颜色通道。


transform = torchvision.transforms.Compose([torchvision.transforms.Resize((32, 32)),
                                            torchvision.transforms.ToTensor()])
# 这个照片size=258x208,因为模型为32×32,所以改一下
image = transform(image)
print(image.shape)

# 加载网络模型
class Tudui(nn.Module):
    def __init__(self):
        super(Tudui, self).__init__()
        # 为了避免上下两个def都写一整串,将整个网络放到序列当中,前边有讲过,注释了很多代码有老乡的那一篇
        self.model = nn.Sequential(
            nn.Conv2d(3, 32, 5, 1, 2),   #  卷积
            nn.MaxPool2d(2),             #  池化
            nn.Conv2d(32, 32, 5, 1, 2),
            nn.MaxPool2d(2),
            nn.Conv2d(32, 64, 5, 1, 2),
            nn.MaxPool2d(2),
            nn.Flatten(),
            nn.Linear(64*4*4, 64),   # 最后两步的展平
            nn.Linear(64, 10)

        )


    def forward(self, x):
        x = self.model(x)
        return x

# model = torch.load("tudui_0.pth")   # 这里一开始用的gpu的模型,会报错,换成cpu的"tudui_0.pth"模型就行了
model = torch.load("tudui_29_gpu.pth", map_location=torch.device('cpu'))
# gpu的训练模型的话,上边这个指令代替上边的上边那个指令
# !!!!!!!!!!!!!!!!!!!
print(model)

# img输入到这个模型中
image = torch.reshape(image, (1, 3, 32, 32))
model.eval()
with torch.no_grad():
    output = model(image)
print(output)

print(output.argmax(1))

结果如图:
在这里插入图片描述
识别成了鹿🦌,还是不对!!!!!!!

人工智障!!!!!!!!!!!!!!!

但是,up主的图片识别出来了,
我们换个图片再试一遍。换个飞机?,如图:
在这里插入图片描述
这次算对啦!
在这里插入图片描述
CIFAR10模型第0个是飞机:正确!!!!
再来个,房子:

在这里插入图片描述
结果如图:
在这里插入图片描述
第7个是房子:正确!!!

我还试了猫的图片,可惜算成了dog,实验了卡车和房子都正确。
up说这个模型的正确率为60%

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-10-23 12:29:25  更:2021-10-23 12:32:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/27 8:25:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码