Pytorch框架怎样实现病虫害图像分类,代码是什么
Admin 2022-07-05 群英技术资讯 975 次浏览
这篇文章主要介绍“Pytorch框架怎样实现病虫害图像分类,代码是什么”,有一些人在Pytorch框架怎样实现病虫害图像分类,代码是什么的问题上存在疑惑,接下来小编就给大家来介绍一下相关的内容,希望对大家解答有帮助,有这个方面学习需要的朋友就继续往下看吧。PyTorch是一个开源的Python机器学习库,基于Torch,用于自然语言处理等应用程序。
2017年1月,由Facebook人工智能研究院(FAIR)基于Torch推出了PyTorch。它是一个基于Python的可续计算包,提供两个高级功能:
1、具有强大的GPU加速的张量计算(如NumPy)。
2、包含自动求导系统的深度神经网络。
两者之间区别很多,在本篇博客中只简单描述一部分。以图片的形式展现。
前者为机器学习的过程。
后者为深度学习的过程。


本次实验使用的是coco数据集中的植物病虫害数据集。分为训练文件Traindata和测试文件TestData.,
TrainData有9种分类,每一种分类有100张图片。
TestData有9中分类,每一种分类有10张图片。
在我下一篇博客中将数据集开源。
下面是我的数据集截图:

import torch from torch.utils.data import Dataset, DataLoader import numpy as np import matplotlib import os import cv2 from PIL import Image import torchvision.transforms as transforms import torch.optim as optim from torch.autograd import Variable import torch.nn as nn import torch.nn.functional as F from Test.CNN import Net import json from Test.train_data import Mydataset,pad_image
# 构建神经网络
class Net(nn.Module):#定义网络模块
def __init__(self):
super(Net, self).__init__()
# 卷积,该图片有3层,6个特征,长宽均为5*5的像素点,每隔1步跳一下
self.conv1 = nn.Conv2d(3, 6, 5)
#//(conv1): Conv2d(3, 6, kernel_size=(5, 5), stride=(1, 1))
self.pool = nn.MaxPool2d(2, 2)#最大池化
#//(pool): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)
self.conv2 = nn.Conv2d(6, 16, 5)#卷积
#//(conv2): Conv2d(6, 16, kernel_size=(5, 5), stride=(1, 1))
self.fc1 = nn.Linear(16*77*77, 120)#全连接层,图片的维度为16,
#(fc1): Linear(in_features=94864, out_features=120, bias=True)
self.fc2 = nn.Linear(120, 84)#全连接层,输入120个特征输出84个特征
self.fc3 = nn.Linear(84, 7)#全连接层,输入84个特征输出7个特征
def forward(self, x):
print("x.shape1: ", x.shape)
x = self.pool(F.relu(self.conv1(x)))
print("x.shape2: ", x.shape)
x = self.pool(F.relu(self.conv2(x)))
print("x.shape3: ", x.shape)
x = x.view(-1, 16*77*77)
print("x.shape4: ", x.shape)
x = F.relu(self.fc1(x))
print("x.shape5: ", x.shape)
x = F.relu(self.fc2(x))
print("x.shape6: ", x.shape)
x = self.fc3(x)
print("x.shape7: ", x.shape)
return x
img_path = "TestData/test_data/1/Apple2 (1).jpg" #使用相对路径
image = Image.open(img_path).convert('RGB')
image_pad = pad_image(image, (320, 320))
input = transform(image_pad).to(device).unsqueeze(0)
output = F.softmax(net(input), 1)
_, predicted = torch.max(output, 1)
score = float(output[0][predicted]*100)
print(class_map[predicted], " ", str(score)+" %")
plt.imshow(image_pad) # 显示图片



这次搭建的网络是基于深度学习框架Lenet,并自己做了一些修改完成。最终的训练的结果LOSS接近0,ACC接近100%。但是一般的识别率不会达到这么高,该模型可能会过拟合。可采取剪枝等操作减小过拟合。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在我们日常生活中,我们可以通过求集合的交集,得出重复的部分,去解决去重的问题。 python作为很好用的编程工具,是可以帮助我们解决数学问题的。本文介绍python中实现集合交集的三种方法,即使用使用&计算、使用python推导式计算和使用python集合的内置方法计算。
它的功能与linux的epoll,还是select模块,poll等类似;实现高效的I/Omultiplexing, 常用于非阻塞的socket的编程中;简单介绍一下这个模块,更多内容查看python文档:https://docs.python.org/3/library/selectors.html 1.模块定义了一个BaseSelector的抽象基类,以及它的子类,包括:Sel
这篇文章主要介绍了Python如何对图像补全并分割成多块补丁,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
针对大家在Python中常常遇到字符串拼接的问题,本文主要向大家介绍Python中常见的六种拼接方法:加号法、逗号法、直接拼接法、格式化法、join函数法、多行字符串拼接法。详情如下:
这篇文章主要为大家介绍了python 的while循环嵌套,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008