test_max.py 1.86 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
2
3
4
5
6
7
8
import pytest
import torch
from torch.autograd import Variable
from torch_scatter import scatter_max_, scatter_max

from .utils import tensor_strs, Tensor


rusty1s's avatar
rusty1s committed
9
@pytest.mark.parametrize('str', tensor_strs)
rusty1s's avatar
rusty1s committed
10
def test_scatter_max(str):
rusty1s's avatar
rusty1s committed
11
12
13
14
15
16
    input = [[2, 0, 1, 4, 3], [0, 2, 1, 3, 4]]
    index = [[4, 5, 4, 2, 3], [0, 0, 2, 2, 1]]
    input = Tensor(str, input)
    index = torch.LongTensor(index)
    output = input.new(2, 6).fill_(0)
    expected_output = [[0, 0, 4, 3, 2, 0], [2, 4, 3, 0, 0, 0]]
rusty1s's avatar
rename  
rusty1s committed
17
    expected_arg_output = [[-1, -1, 3, 4, 0, 1], [1, 4, 3, -1, -1, -1]]
rusty1s's avatar
rusty1s committed
18

rusty1s's avatar
rename  
rusty1s committed
19
    _, arg_output = scatter_max_(output, index, input, dim=1)
rusty1s's avatar
rusty1s committed
20
    assert output.tolist() == expected_output
rusty1s's avatar
rename  
rusty1s committed
21
    assert arg_output.tolist() == expected_arg_output
rusty1s's avatar
rusty1s committed
22

rusty1s's avatar
rename  
rusty1s committed
23
    output, arg_output = scatter_max(index, input, dim=1)
rusty1s's avatar
rusty1s committed
24
    assert output.tolist() == expected_output
rusty1s's avatar
rename  
rusty1s committed
25
    assert arg_output.tolist() == expected_arg_output
rusty1s's avatar
rusty1s committed
26

rusty1s's avatar
rusty1s committed
27
28
29
30
    output = Variable(output).fill_(0)
    index = Variable(index)
    input = Variable(input, requires_grad=True)
    scatter_max_(output, index, input, dim=1)
rusty1s's avatar
rusty1s committed
31

rusty1s's avatar
rusty1s committed
32
33
34
    grad_output = [[10, 20, 30, 40, 50, 60], [15, 25, 35, 45, 55, 65]]
    grad_output = Tensor(str, grad_output)
    expected_grad_input = [[50, 60, 0, 30, 40], [0, 15, 0, 35, 25]]
rusty1s's avatar
rusty1s committed
35

rusty1s's avatar
rusty1s committed
36
37
    output.backward(grad_output)
    assert input.grad.data.tolist() == expected_grad_input
rusty1s's avatar
rusty1s committed
38
39


rusty1s's avatar
rusty1s committed
40
@pytest.mark.parametrize('str', tensor_strs)
rusty1s's avatar
rusty1s committed
41
42
43
44
45
46
47
48
49
50
51
52
53
def test_scatter_cuda_max(str):
    input = [[2, 0, 1, 4, 3], [0, 2, 1, 3, 4]]
    index = [[4, 5, 4, 2, 3], [0, 0, 2, 2, 1]]
    input = Tensor(str, input)
    index = torch.LongTensor(index)
    output = input.new(2, 6).fill_(0)
    expected_output = [[0, 0, 4, 3, 2, 0], [2, 4, 3, 0, 0, 0]]
    expected_arg_output = [[-1, -1, 3, 4, 0, 1], [1, 4, 3, -1, -1, -1]]

    output, index, input = output.cuda(), index.cuda(), input.cuda()

    _, arg_output = scatter_max_(output, index, input, dim=1)
    print(output)
rusty1s's avatar
rusty1s committed
54
    print(arg_output)