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
|
import torch
def target_transform(labels):
count_labels = torch.zeros(60)
for shape_index in range(len(labels)):
count_labels[int(shape_index * 10 + labels[shape_index])] = 1
return count_labels
def loss_function(output, target):
a = torch.tensor(range(10)).repeat(6 * target.shape[0]).reshape(target.shape)
errors = a - target
return torch.sum(output * errors ** 2) / output.shape[0]
def count_correct(output, target):
print('output shape', output.shape)
print('target shape', target.shape)
output = output.reshape(output.shape[0], 6, 10)
target = target.reshape(target.shape[0], 6, 10)
target = torch.argmax(target, dim=2)
predictions = torch.argmax(output, dim=2)
correct = torch.min(predictions.reshape(target.shape) == target, dim=1).values
return torch.sum(correct).tolist()
def finalizer(x):
x = x.reshape(x.shape[0], 6, 10)
x = torch.softmax(x, 1)
return x.reshape(x.shape[0], 60)
outputs = 60
|