-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdata_loader.py
More file actions
77 lines (64 loc) · 2.89 KB
/
data_loader.py
File metadata and controls
77 lines (64 loc) · 2.89 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
import torch
import torchvision
import torchvision.transforms as transforms
import random
import numpy as np
from torch.utils.data import Dataset
import os
class NCaltech101(Dataset):
def __init__(self, data_path='./data/N-Caltech101/frames_number_10_split_by_number',
data_type='train', transform=True):
self.filepath = os.path.join(data_path)
self.clslist = os.listdir(self.filepath)
self.clslist.sort()
self.dvs_filelist = []
self.targets = []
self.resize = transforms.Resize(size=(48, 48), interpolation=torchvision.transforms.InterpolationMode.NEAREST)
for i, cls in enumerate(self.clslist):
file_list = os.listdir(os.path.join(self.filepath, cls))
num_file = len(file_list)
cut_idx = int(num_file * 0.9)
train_file_list = file_list[:cut_idx]
test_split_list = file_list[cut_idx:]
for file in file_list:
if data_type == 'train':
if file in train_file_list:
self.dvs_filelist.append(os.path.join(self.filepath, cls, file))
self.targets.append(i)
else:
if file in test_split_list:
self.dvs_filelist.append(os.path.join(self.filepath, cls, file))
self.targets.append(i)
self.data_num = len(self.dvs_filelist)
self.data_type = data_type
if data_type != 'train':
counts = np.unique(np.array(self.targets), return_counts=True)[1]
class_weights = counts.sum() / (counts * len(counts))
self.class_weights = torch.Tensor(class_weights)
self.classes = range(101)
self.transform = transform
self.rotate = transforms.RandomRotation(degrees=15)
self.shearx = transforms.RandomAffine(degrees=0, shear=(-15, 15))
def __getitem__(self, index):
file_pth = self.dvs_filelist[index]
label = self.targets[index]
data = torch.from_numpy(np.load(file_pth)['frames']).float()
data = self.resize(data)
if self.transform:
choices = ['roll', 'rotate', 'shear']
aug = np.random.choice(choices)
if aug == 'roll':
off1 = random.randint(-3, 3)
off2 = random.randint(-3, 3)
data = torch.roll(data, shifts=(off1, off2), dims=(2, 3))
if aug == 'rotate':
data = self.rotate(data)
if aug == 'shear':
data = self.shearx(data)
return data, label
def __len__(self):
return self.data_num
def build_ncaltech(data_path='./data/N-Caltech101/frames_number_10_split_by_number'):
train_dataset = NCaltech101(data_path=data_path, transform=True)
val_dataset = NCaltech101(data_path=data_path, data_type='test', transform=False)
return train_dataset, val_dataset