Разделение набора данных с помощью SubsetRandomSampler не работает
я использовал <tcode id="25719528"></tcode>разделить данные обучения на данные обучения (80%) и данные проверки (20%). Но он показывает одинаковое количество изображений для обоих после разделения (4996):
>>> print('len(train_data): ', len(train_loader.dataset))
>>> print('len(valid_data): ', len(validation_loader.dataset))
len(train_data): 4996
len(valid_data): 4996
Полный код:
import numpy as np
import torch
from torchvision import transforms
from torch.utils.data.sampler import SubsetRandomSampler
train_transforms = transforms.Compose([transforms.ToTensor(),
transforms.Normalize([0.485, 0.456, 0.406],
[0.229, 0.224, 0.225])])
dataset = datasets.ImageFolder( '/data/images/train', transform=train_transforms )
validation_split = .2
shuffle_dataset = True
random_seed= 42
batch_size = 20
dataset_size = len(dataset) #4996
indices = list(range(dataset_size))
split = int(np.floor(validation_split * dataset_size))
if shuffle_dataset :
np.random.seed(random_seed)
np.random.shuffle(indices)
train_indices, val_indices = indices[split:], indices[:split]
train_sampler = SubsetRandomSampler(train_indices)
valid_sampler = SubsetRandomSampler(val_indices)
train_loader = torch.utils.data.DataLoader(dataset, batch_size=batch_size, sampler=train_sampler)
validation_loader = torch.utils.data.DataLoader(dataset, batch_size=batch_size, sampler=valid_sampler)
1 ответ
len(train_loader.dataset)
и
len(validation_loader.dataset)
напечатайте размеры базовых наборов данных , из которых загрузчики выбирают (т.е. исходный набор данных размером 4996).
Если вы выполните итерацию по загрузчикам, вы увидите, что вы получите столько образцов (с учетом пакетной обработки), сколько вы включили в индекс для каждого сэмплера.