test_add.py 1.01 KB
Newer Older
rusty1s's avatar
rusty1s committed
1
import pytest
rusty1s's avatar
rusty1s committed
2
import torch
rusty1s's avatar
rusty1s committed
3
from torch.autograd import Variable
rusty1s's avatar
rusty1s committed
4
from torch_scatter import scatter_add_, scatter_add
rusty1s's avatar
rusty1s committed
5

rusty1s's avatar
rusty1s committed
6
7
from .utils import tensor_strs, Tensor

rusty1s's avatar
rusty1s committed
8

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

rusty1s's avatar
rusty1s committed
18
    scatter_add_(output, index, input, dim=1)
rusty1s's avatar
rusty1s committed
19
    assert output.tolist() == expected_output
rusty1s's avatar
rusty1s committed
20
21

    output = scatter_add(index, input, dim=1)
rusty1s's avatar
bugfix  
rusty1s committed
22
    assert output.tolist() == expected_output
rusty1s's avatar
rusty1s committed
23

rusty1s's avatar
rusty1s committed
24
    output = Variable(output).fill_(0)
rusty1s's avatar
rusty1s committed
25
26
    index = Variable(index)
    input = Variable(input, requires_grad=True)
rusty1s's avatar
rusty1s committed
27
    scatter_add_(output, index, input, dim=1)
rusty1s's avatar
rusty1s committed
28

rusty1s's avatar
rusty1s committed
29
    grad_output = [[0, 1, 2, 3, 4, 5], [0, 1, 2, 3, 4, 5]]
rusty1s's avatar
rusty1s committed
30
    grad_output = Tensor(str, grad_output)
rusty1s's avatar
rusty1s committed
31

rusty1s's avatar
rusty1s committed
32
    output.backward(grad_output)
rusty1s's avatar
rusty1s committed
33
    assert index.data.tolist() == input.grad.data.tolist()