from nose.tools import assert_equal import torch from torch_scatter._ext import ffi def test_scatter_add(): input = [[2, 0, 1, 4, 3], [0, 2, 1, 3, 4]] index = [[4, 5, 4, 2, 3], [0, 0, 2, 2, 1]] input = torch.FloatTensor(input) 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]] ffi.scatter_add_Float(output, index, input, 1) assert_equal(output.tolist(), expected_output)