ShanghaiTech
import sys
sys.path.append('..')
from pysauron.datasets import ShanghaiTech
from pysauron.transforms import RandomAnomalyInject, ChangeDirection, FrameDrop
import matplotlib.pyplot as plt
from IPython.display import clear_output
train_dataset = ShanghaiTech(root='../data/ShanghaiTech/', test_mode=False, _debug=True)
test_dataset = ShanghaiTech(root='../data/ShanghaiTech/', test_mode=True, _debug=True)
print('# Train samples: ', len(train_dataset))
print('# Test samples: ', len(test_dataset))
sample = test_dataset[125]
for i in range(sample[0].shape[0]):
plt.imshow(sample[0][i])
plt.title(f'Label: {sample[2][i]}')
clear_output(True)
plt.show()
print('Sample temporal labels: ', sample[2])
Frame drop augmentation¤
sample = test_dataset[125]
video, label, temporal_l = FrameDrop(k=5, always_apply=True)(video=sample[0], label=sample[1], temporal_label=sample[2])
for i in range(video.shape[0]):
plt.imshow(video[i])
plt.title(f'Label: {temporal_l[i]}')
clear_output(True)
plt.show()
print('Sample temporal labels after transform: ', temporal_l)
Direction change augmentation¤
sample = test_dataset[125]
video, label, temporal_l = ChangeDirection(always_apply=True)(video=sample[0], label=sample[1], temporal_label=sample[2])
for i in range(video.shape[0]):
plt.imshow(video[i])
plt.title(f'Label: {temporal_l[i]}')
clear_output(True)
plt.show()
print('Sample temporal labels after transform: ', temporal_l)
Randomg injection augmentation¤
sample = test_dataset[125]
video, label, temporal_l = RandomAnomalyInject(
anomaly_folder='/Users/bogdanivanyuk/Desktop/PySauron/pysauron/transforms/assets/anomalies/animals',
always_apply=True)(video=sample[0], label=sample[1], temporal_label=sample[2])
for i in range(video.shape[0]):
plt.imshow(video[i])
plt.title(f'Label: {temporal_l[i]}')
clear_output(True)
plt.show()
print('Sample temporal labels after transform: ', temporal_l)