| | import pytest |
| | import torch |
| | from torch.autograd import gradcheck |
| |
|
| | import kornia |
| | import kornia.testing as utils |
| | from kornia.testing import assert_close |
| |
|
| |
|
| | class TestVflip: |
| | def smoke_test(self, device, dtype): |
| | f = kornia.geometry.transform.Vflip() |
| | repr = "Vflip()" |
| | assert str(f) == repr |
| |
|
| | def test_vflip(self, device, dtype): |
| |
|
| | f = kornia.geometry.transform.Vflip() |
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | expected = torch.tensor( |
| | [[0.0, 1.0, 1.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], device=device, dtype=dtype |
| | ) |
| |
|
| | assert (f(input) == expected).all() |
| |
|
| | def test_batch_vflip(self, device, dtype): |
| |
|
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | input = input.repeat(2, 1, 1) |
| |
|
| | f = kornia.geometry.transform.Vflip() |
| | expected = torch.tensor( |
| | [[[0.0, 1.0, 1.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]]], device=device, dtype=dtype |
| | ) |
| |
|
| | expected = expected.repeat(2, 1, 1) |
| |
|
| | assert (f(input) == expected).all() |
| |
|
| | @pytest.mark.skip(reason="turn off all jit for a while") |
| | def test_jit(self, device, dtype): |
| | @torch.jit.script |
| | def op_script(data: torch.Tensor) -> torch.Tensor: |
| |
|
| | return kornia.geometry.transform.vflip(data) |
| |
|
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | |
| | op_trace = torch.jit.trace(op_script, (input,)) |
| |
|
| | |
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [5.0, 5.0, 0.0]], device=device, dtype=dtype) |
| |
|
| | input = input.repeat(2, 1, 1) |
| |
|
| | expected = torch.tensor( |
| | [[[5.0, 5.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]]], device=device, dtype=dtype |
| | ) |
| |
|
| | expected = expected.repeat(2, 1, 1) |
| |
|
| | actual = op_trace(input) |
| |
|
| | assert_close(actual, expected) |
| |
|
| | def test_gradcheck(self, device, dtype): |
| |
|
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | input = utils.tensor_to_gradcheck_var(input) |
| |
|
| | assert gradcheck(kornia.geometry.transform.Vflip(), (input,), raise_exception=True) |
| |
|
| |
|
| | class TestHflip: |
| | def smoke_test(self, device, dtype): |
| | f = kornia.geometry.transform.Hflip() |
| | repr = "Hflip()" |
| | assert str(f) == repr |
| |
|
| | def test_hflip(self, device, dtype): |
| |
|
| | f = kornia.geometry.transform.Hflip() |
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | expected = torch.tensor( |
| | [[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [1.0, 1.0, 0.0]], device=device, dtype=dtype |
| | ) |
| |
|
| | assert (f(input) == expected).all() |
| |
|
| | def test_batch_hflip(self, device, dtype): |
| |
|
| | input = torch.tensor( |
| | [[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype |
| | ) |
| |
|
| | input = input.repeat(2, 1, 1) |
| |
|
| | f = kornia.geometry.transform.Hflip() |
| | expected = torch.tensor( |
| | [[[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [1.0, 1.0, 0.0]]], device=device, dtype=dtype |
| | ) |
| |
|
| | expected = expected.repeat(2, 1, 1) |
| |
|
| | assert (f(input) == expected).all() |
| |
|
| | @pytest.mark.skip(reason="turn off all jit for a while") |
| | def test_jit(self, device, dtype): |
| | @torch.jit.script |
| | def op_script(data: torch.Tensor) -> torch.Tensor: |
| |
|
| | return kornia.geometry.transform.hflip(data) |
| |
|
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | |
| | op_trace = torch.jit.trace(op_script, (input,)) |
| |
|
| | |
| | input = torch.tensor([[0.0, 0.0, 0.0], [5.0, 5.0, 0.0], [0.0, 0.0, 0.0]], device=device, dtype=dtype) |
| |
|
| | input = input.repeat(2, 1, 1) |
| |
|
| | expected = torch.tensor( |
| | [[[0.0, 0.0, 0.0], [0.0, 5.0, 5.0], [0.0, 0.0, 0.0]]], device=device, dtype=dtype |
| | ) |
| |
|
| | expected = expected.repeat(2, 1, 1) |
| |
|
| | actual = op_trace(input) |
| |
|
| | assert_close(actual, expected) |
| |
|
| | def test_gradcheck(self, device, dtype): |
| |
|
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | input = utils.tensor_to_gradcheck_var(input) |
| |
|
| | assert gradcheck(kornia.geometry.transform.Hflip(), (input,), raise_exception=True) |
| |
|
| |
|
| | class TestRot180: |
| | def smoke_test(self, device, dtype): |
| | f = kornia.geometry.transform.Rot180() |
| | repr = "Rot180()" |
| | assert str(f) == repr |
| |
|
| | def test_rot180(self, device, dtype): |
| |
|
| | f = kornia.geometry.transform.Rot180() |
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | expected = torch.tensor( |
| | [[1.0, 1.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], device=device, dtype=dtype |
| | ) |
| |
|
| | assert (f(input) == expected).all() |
| |
|
| | def test_batch_rot180(self, device, dtype): |
| |
|
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | input = input.repeat(2, 1, 1) |
| |
|
| | f = kornia.geometry.transform.Rot180() |
| | expected = torch.tensor( |
| | [[1.0, 1.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]], device=device, dtype=dtype |
| | ) |
| |
|
| | expected = expected.repeat(2, 1, 1) |
| |
|
| | assert (f(input) == expected).all() |
| |
|
| | @pytest.mark.skip(reason="turn off all jit for a while") |
| | def test_jit(self, device, dtype): |
| | @torch.jit.script |
| | def op_script(data: torch.Tensor) -> torch.Tensor: |
| |
|
| | return kornia.geometry.transform.rot180(data) |
| |
|
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | |
| | op_trace = torch.jit.trace(op_script, (input,)) |
| |
|
| | |
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [5.0, 5.0, 0.0]], device=device, dtype=dtype) |
| |
|
| | input = input.repeat(2, 1, 1) |
| |
|
| | expected = torch.tensor( |
| | [[[0.0, 5.0, 5.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]]], device=device, dtype=dtype |
| | ) |
| |
|
| | expected = expected.repeat(2, 1, 1) |
| |
|
| | actual = op_trace(input) |
| |
|
| | assert_close(actual, expected) |
| |
|
| | def test_gradcheck(self, device, dtype): |
| |
|
| | input = torch.tensor([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 1.0, 1.0]], device=device, dtype=dtype) |
| |
|
| | input = utils.tensor_to_gradcheck_var(input) |
| |
|
| | assert gradcheck(kornia.geometry.transform.Rot180(), (input,), raise_exception=True) |
| |
|