test_std.py 646 Bytes
Newer Older
rusty1s's avatar
typo  
rusty1s committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
from itertools import product

import pytest
import torch
from torch_scatter import scatter_std

from .utils import grad_dtypes as dtypes, devices, tensor

biass = [True, False]


@pytest.mark.parametrize('dtype,device,bias', product(dtypes, devices, biass))
def test_std(dtype, device, bias):
    src = tensor([[2, 0, 1, 4, 3], [0, 2, 1, 3, 4]], dtype, device)
    index = tensor([[0, 0, 0, 0, 0], [1, 1, 1, 1, 1]], torch.long, device)

    out = scatter_std(src, index, dim=-1, unbiased=bias)
rusty1s's avatar
rusty1s committed
18
    std = src.std(dim=-1, unbiased=bias)[0].item()
19
    expected = tensor([[std, 0], [0, std]], dtype, device)
rusty1s's avatar
rusty1s committed
20
    assert torch.allclose(out, expected)