gpt4 book ai didi

python - PyTorch:使用 torchvision.datasets.ImageFolder 和 DataLoader 进行测试

转载 作者:太空狗 更新时间:2023-10-30 00:53:13 25 4
gpt4 key购买 nike

我是一个新手,试图让这个 PyTorch CNN 与 Cats&Dogs dataset from kaggle 一起工作。由于测试图像没有目标,我手动对一些测试图像进​​行分类并将类放在文件名中,以便能够进行测试(也许应该只使用一些训练图像)。

我使用 torchvision.datasets.ImageFolder 类来加载火车和测试图像。培训似乎有效。

但是我需要做什么才能使测试例程正常工作?我不知道如何通过 test_x 和 test_y 将我的 test_data_loader 与底部的测试循环连接起来。

代码基于 this MNIST example CNN. 那里,在创建加载程序后立即使用类似这样的东西。但是我没有为我的数据集重写它:

test_x = Variable(torch.unsqueeze(test_data.test_data, dim=1), volatile=True).type(torch.FloatTensor)[:2000]/255.   # shape from (2000, 28, 28) to (2000, 1, 28, 28), value in range(0,1)
test_y = test_data.test_labels[:2000]

代码:

import os
import numpy as np
import torch
import torch.nn as nn
import torch.nn.functional as F
from torch.autograd import Variable
import torch.utils.data as data
import torchvision
from torchvision import transforms

EPOCHS = 2
BATCH_SIZE = 10
LEARNING_RATE = 0.003
TRAIN_DATA_PATH = "./train_cl/"
TEST_DATA_PATH = "./test_named_cl/"
TRANSFORM_IMG = transforms.Compose([
transforms.Resize(256),
transforms.CenterCrop(256),
transforms.ToTensor(),
transforms.Normalize(mean=[0.485, 0.456, 0.406],
std=[0.229, 0.224, 0.225] )
])

train_data = torchvision.datasets.ImageFolder(root=TRAIN_DATA_PATH, transform=TRANSFORM_IMG)
train_data_loader = data.DataLoader(train_data, batch_size=BATCH_SIZE, shuffle=True, num_workers=4)
test_data = torchvision.datasets.ImageFolder(root=TEST_DATA_PATH, transform=TRANSFORM_IMG)
test_data_loader = data.DataLoader(test_data, batch_size=BATCH_SIZE, shuffle=True, num_workers=4)

class CNN(nn.Module):
# omitted...

if __name__ == '__main__':

print("Number of train samples: ", len(train_data))
print("Number of test samples: ", len(test_data))
print("Detected Classes are: ", train_data.class_to_idx) # classes are detected by folder structure

model = CNN()
optimizer = torch.optim.Adam(model.parameters(), lr=LEARNING_RATE)
loss_func = nn.CrossEntropyLoss()

# Training and Testing
for epoch in range(EPOCHS):
for step, (x, y) in enumerate(train_data_loader):
b_x = Variable(x) # batch x (image)
b_y = Variable(y) # batch y (target)
output = model(b_x)[0]
loss = loss_func(output, b_y)
optimizer.zero_grad()
loss.backward()
optimizer.step()

# Test -> this is where I have no clue
if step % 50 == 0:
test_x = Variable(test_data_loader)
test_output, last_layer = model(test_x)
pred_y = torch.max(test_output, 1)[1].data.squeeze()
accuracy = sum(pred_y == test_y) / float(test_y.size(0))
print('Epoch: ', epoch, '| train loss: %.4f' % loss.data[0], '| test accuracy: %.2f' % accuracy)

最佳答案

查看来自 Kaggle 的数据和您的代码,似乎您的数据加载存在问题,包括训练集和测试集。首先,数据应该位于每个标签的不同文件夹中,以便默认 PyTorch ImageFolder 正确加载它。在你的例子中,由于所有的训练数据都在同一个文件夹中,PyTorch 将它作为一个类加载,因此学习似乎是有效的。您可以使用文件夹结构来更正此问题,例如 - train/dog, - train/cat, - test/dog, - test/cat 然后将train和test文件夹分别传递给train和test ImageFolder。训练代码看起来不错,只要更改文件夹结构就可以了。看看ImageFolder的官方文档其中有一个类似的例子。

关于python - PyTorch:使用 torchvision.datasets.ImageFolder 和 DataLoader 进行测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49073799/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com