| 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) |
|
|