| import pytest |
| import torch |
| from torch.autograd import gradcheck |
|
|
| import kornia |
| import kornia.testing as utils |
| from kornia.testing import assert_close |
|
|
|
|
| @pytest.mark.parametrize("batch_size", [1, 2, 5]) |
| def test_get_perspective_transform(batch_size, device, dtype): |
| |
| h_max, w_max = 64, 32 |
| h = torch.ceil(h_max * torch.rand(batch_size, device=device, dtype=dtype)) |
| w = torch.ceil(w_max * torch.rand(batch_size, device=device, dtype=dtype)) |
|
|
| norm = torch.rand(batch_size, 4, 2, device=device, dtype=dtype) |
| points_src = torch.zeros_like(norm, device=device, dtype=dtype) |
| points_src[:, 1, 0] = h |
| points_src[:, 2, 1] = w |
| points_src[:, 3, 0] = h |
| points_src[:, 3, 1] = w |
| points_dst = points_src + norm |
|
|
| |
| dst_homo_src = kornia.geometry.get_perspective_transform(points_src, points_dst) |
|
|
| assert_close(kornia.geometry.transform_points(dst_homo_src, points_src), points_dst, rtol=1e-4, atol=1e-4) |
|
|
| |
| points_src = utils.tensor_to_gradcheck_var(points_src) |
| points_dst = utils.tensor_to_gradcheck_var(points_dst) |
| assert gradcheck(kornia.geometry.get_perspective_transform, (points_src, points_dst), raise_exception=True) |
|
|
|
|
| @pytest.mark.parametrize("batch_size", [1, 2, 5]) |
| def test_rotation_matrix2d(batch_size, device, dtype): |
| |
| center_base = torch.zeros(batch_size, 2, device=device, dtype=dtype) |
| angle_base = torch.ones(batch_size, device=device, dtype=dtype) |
| scale_base = torch.ones(batch_size, 2, device=device, dtype=dtype) |
|
|
| |
| center = center_base |
| angle = 90.0 * angle_base |
| scale = scale_base |
| M = kornia.geometry.get_rotation_matrix2d(center, angle, scale) |
|
|
| for i in range(batch_size): |
| assert_close(M[i, 0, 0].item(), 0.0, rtol=1e-4, atol=1e-4) |
| assert_close(M[i, 0, 1].item(), 1.0, rtol=1e-4, atol=1e-4) |
| assert_close(M[i, 1, 0].item(), -1.0, rtol=1e-4, atol=1e-4) |
| assert_close(M[i, 1, 1].item(), 0.0, rtol=1e-4, atol=1e-4) |
|
|
| |
| center = center_base |
| angle = 90.0 * angle_base |
| scale = 2.0 * scale_base |
| M = kornia.geometry.get_rotation_matrix2d(center, angle, scale) |
|
|
| for i in range(batch_size): |
| assert_close(M[i, 0, 0].item(), 0.0, rtol=1e-4, atol=1e-4) |
| assert_close(M[i, 0, 1].item(), 2.0, rtol=1e-4, atol=1e-4) |
| assert_close(M[i, 1, 0].item(), -2.0, rtol=1e-4, atol=1e-4) |
| assert_close(M[i, 1, 1].item(), 0.0, rtol=1e-4, atol=1e-4) |
|
|
| |
| center = center_base |
| angle = 45.0 * angle_base |
| scale = scale_base |
| M = kornia.geometry.get_rotation_matrix2d(center, angle, scale) |
|
|
| for i in range(batch_size): |
| assert_close(M[i, 0, 0].item(), 0.7071) |
| assert_close(M[i, 0, 1].item(), 0.7071) |
| assert_close(M[i, 1, 0].item(), -0.7071) |
| assert_close(M[i, 1, 1].item(), 0.7071) |
|
|
| |
| center = utils.tensor_to_gradcheck_var(center) |
| angle = utils.tensor_to_gradcheck_var(angle) |
| scale = utils.tensor_to_gradcheck_var(scale) |
| assert gradcheck(kornia.geometry.get_rotation_matrix2d, (center, angle, scale), raise_exception=True) |
|
|
|
|
| class TestWarpAffine: |
| def test_smoke(self, device, dtype): |
| batch_size, channels, height, width = 1, 2, 3, 4 |
| aff_ab = torch.eye(2, 3, device=device, dtype=dtype)[None] |
| img_b = torch.rand(batch_size, channels, height, width, device=device, dtype=dtype) |
| img_a = kornia.geometry.warp_affine(img_b, aff_ab, (height, width)) |
| assert_close(img_b, img_a) |
|
|
| @pytest.mark.parametrize("batch_shape", ([1, 3, 2, 5], [2, 4, 3, 4], [3, 5, 6, 2])) |
| @pytest.mark.parametrize("out_shape", ([2, 5], [3, 4], [6, 2])) |
| def test_cardinality(self, device, dtype, batch_shape, out_shape): |
| batch_size, channels, height, width = batch_shape |
| h_out, w_out = out_shape |
| aff_ab = torch.eye(2, 3, device=device, dtype=dtype).repeat(batch_size, 1, 1) |
| img_b = torch.rand(batch_size, channels, height, width, device=device, dtype=dtype) |
| img_a = kornia.geometry.warp_affine(img_b, aff_ab, (h_out, w_out)) |
| assert img_a.shape == (batch_size, channels, h_out, w_out) |
|
|
| def test_exception(self, device, dtype): |
| img = torch.rand(1, 2, 3, 4, device=device, dtype=dtype) |
| aff = torch.eye(2, 3, device=device, dtype=dtype)[None] |
| size = (4, 5) |
|
|
| with pytest.raises(TypeError): |
| assert kornia.geometry.warp_affine(0.0, aff, size) |
|
|
| with pytest.raises(TypeError): |
| assert kornia.geometry.warp_affine(img, 0.0, size) |
|
|
| with pytest.raises(ValueError): |
| img = torch.rand(2, 3, 4, device=device, dtype=dtype) |
| assert kornia.geometry.warp_affine(img, aff, size) |
|
|
| with pytest.raises(ValueError): |
| aff = torch.eye(2, 2, device=device, dtype=dtype)[None] |
| assert kornia.geometry.warp_affine(img, aff, size) |
|
|
| def test_translation(self, device, dtype): |
| offset = 1.0 |
| h, w = 3, 4 |
| aff_ab = torch.eye(2, 3, device=device, dtype=dtype)[None] |
| aff_ab[..., -1] += offset |
|
|
| img_b = torch.arange(float(h * w), device=device, dtype=dtype).view(1, 1, h, w) |
|
|
| expected = torch.zeros_like(img_b) |
| expected[..., 1:, 1:] = img_b[..., :2, :3] |
|
|
| |
| img_a = kornia.geometry.warp_affine(img_b, aff_ab, (h, w)) |
| assert_close(img_a, expected) |
|
|
| def test_rotation_inverse(self, device, dtype): |
| h, w = 4, 4 |
| img_b = torch.rand(1, 1, h, w, device=device, dtype=dtype) |
|
|
| |
| center = torch.tensor([[w - 1, h - 1]], device=device, dtype=dtype) / 2 |
| scale = torch.ones((1, 2), device=device, dtype=dtype) |
| angle = 90.0 * torch.ones(1, device=device, dtype=dtype) |
| aff_ab = kornia.geometry.get_rotation_matrix2d(center, angle, scale) |
| |
|
|
| |
| |
| img_a = kornia.geometry.warp_affine(img_b, aff_ab, (h, w)) |
|
|
| |
| aff_ba = kornia.geometry.conversions.convert_affinematrix_to_homography(aff_ab).inverse()[..., :2, :] |
| img_b_hat = kornia.geometry.warp_affine(img_a, aff_ba, (h, w)) |
| assert_close(img_b_hat, img_b, atol=1e-3, rtol=1e-3) |
|
|
| def test_jit(self, device, dtype): |
| aff_ab = torch.eye(2, 3, device=device, dtype=dtype)[None] |
| img = torch.rand(1, 2, 3, 4, device=device, dtype=dtype) |
| args = (img, aff_ab, (4, 5)) |
| op = kornia.geometry.warp_affine |
| op_jit = torch.jit.script(op) |
| assert_close(op(*args), op_jit(*args)) |
|
|
| def test_gradcheck(self, device, dtype): |
| batch_size, channels, height, width = 1, 2, 3, 4 |
| aff_ab = torch.eye(2, 3, device=device, dtype=dtype)[None] + 1e-6 |
| img_b = torch.rand(batch_size, channels, height, width, device=device, dtype=dtype) |
| aff_ab = utils.tensor_to_gradcheck_var(aff_ab) |
| img_b = utils.tensor_to_gradcheck_var(img_b) |
| assert gradcheck(kornia.geometry.warp_affine, (img_b, aff_ab, (height, width)), raise_exception=True) |
|
|
|
|
| class TestWarpPerspective: |
| def test_smoke(self, device, dtype): |
| batch_size, channels, height, width = 1, 2, 3, 4 |
| img_b = torch.rand(batch_size, channels, height, width, device=device, dtype=dtype) |
| H_ab = kornia.eye_like(3, img_b) |
| img_a = kornia.geometry.warp_perspective(img_b, H_ab, (height, width)) |
| assert_close(img_b, img_a) |
|
|
| @pytest.mark.parametrize("batch_shape", ([1, 3, 2, 5], [2, 4, 3, 4], [3, 5, 6, 2])) |
| @pytest.mark.parametrize("out_shape", ([2, 5], [3, 4], [6, 2])) |
| def test_cardinality(self, device, dtype, batch_shape, out_shape): |
| batch_size, channels, height, width = batch_shape |
| h_out, w_out = out_shape |
| img_b = torch.rand(batch_size, channels, height, width, device=device, dtype=dtype) |
| H_ab = kornia.eye_like(3, img_b) |
| img_a = kornia.geometry.warp_perspective(img_b, H_ab, (h_out, w_out)) |
| assert img_a.shape == (batch_size, channels, h_out, w_out) |
|
|
| def test_exception(self, device, dtype): |
| img = torch.rand(1, 2, 3, 4, device=device, dtype=dtype) |
| homo = torch.eye(3, device=device, dtype=dtype)[None] |
| size = (4, 5) |
|
|
| with pytest.raises(TypeError): |
| assert kornia.geometry.warp_perspective(0.0, homo, size) |
|
|
| with pytest.raises(TypeError): |
| assert kornia.geometry.warp_perspective(img, 0.0, size) |
|
|
| with pytest.raises(ValueError): |
| img = torch.rand(2, 3, 4, device=device, dtype=dtype) |
| assert kornia.geometry.warp_perspective(img, homo, size) |
|
|
| with pytest.raises(ValueError): |
| homo = torch.eye(2, 2, device=device, dtype=dtype)[None] |
| assert kornia.geometry.warp_perspective(img, homo, size) |
|
|
| def test_translation(self, device, dtype): |
| offset = 1.0 |
| h, w = 3, 4 |
|
|
| img_b = torch.arange(float(h * w), device=device, dtype=dtype).view(1, 1, h, w) |
| homo_ab = kornia.eye_like(3, img_b) |
| homo_ab[..., :2, -1] += offset |
|
|
| expected = torch.zeros_like(img_b) |
| expected[..., 1:, 1:] = img_b[..., :2, :3] |
|
|
| |
| img_a = kornia.geometry.warp_perspective(img_b, homo_ab, (h, w)) |
| assert_close(img_a, expected, atol=1e-4, rtol=1e-4) |
|
|
| def test_rotation_inverse(self, device, dtype): |
| h, w = 4, 4 |
| img_b = torch.rand(1, 1, h, w, device=device, dtype=dtype) |
|
|
| |
| center = torch.tensor([[w - 1, h - 1]], device=device, dtype=dtype) / 2 |
| scale = torch.ones((1, 2), device=device, dtype=dtype) |
| angle = 90.0 * torch.ones(1, device=device, dtype=dtype) |
| aff_ab = kornia.geometry.get_rotation_matrix2d(center, angle, scale) |
| |
|
|
| H_ab = kornia.geometry.convert_affinematrix_to_homography(aff_ab) |
|
|
| |
| |
| img_a = kornia.geometry.warp_perspective(img_b, H_ab, (h, w)) |
|
|
| |
| H_ba = torch.inverse(H_ab) |
| img_b_hat = kornia.geometry.warp_perspective(img_a, H_ba, (h, w)) |
| assert_close(img_b_hat, img_b, rtol=1e-4, atol=1e-4) |
|
|
| @pytest.mark.parametrize("batch_size", [1, 5]) |
| @pytest.mark.parametrize("channels", [1, 5]) |
| def test_crop(self, batch_size, channels, device, dtype): |
| |
| src_h, src_w = 3, 3 |
| dst_h, dst_w = 3, 3 |
|
|
| |
| |
| points_src = torch.tensor( |
| [[[0, 0], [0, src_w - 1], [src_h - 1, src_w - 1], [src_h - 1, 0]]], device=device, dtype=dtype |
| ) |
|
|
| |
| |
| points_dst = torch.tensor( |
| [[[0, 0], [0, dst_w - 1], [dst_h - 1, dst_w - 1], [dst_h - 1, 0]]], device=device, dtype=dtype |
| ) |
|
|
| |
| dst_trans_src = kornia.geometry.get_perspective_transform(points_src, points_dst).expand(batch_size, -1, -1) |
|
|
| |
| patch = torch.tensor( |
| [[[[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], [13, 14, 15, 16]]]], device=device, dtype=dtype |
| ).expand(batch_size, channels, -1, -1) |
|
|
| expected = patch[..., :3, :3] |
|
|
| |
| patch_warped = kornia.geometry.warp_perspective(patch, dst_trans_src, (dst_h, dst_w)) |
| assert_close(patch_warped, expected) |
|
|
| @pytest.mark.parametrize("batch_size", [1, 5]) |
| def test_crop_src_dst_type_mismatch(self, device, dtype, batch_size): |
| |
| src_h, src_w = 3, 3 |
| dst_h, dst_w = 3, 3 |
|
|
| |
| |
| points_src = torch.tensor( |
| [[[0, 0], [0, src_w - 1], [src_h - 1, src_w - 1], [src_h - 1, 0]]], device=device, dtype=torch.int64 |
| ) |
|
|
| |
| |
| points_dst = torch.tensor( |
| [[[0, 0], [0, dst_w - 1], [dst_h - 1, dst_w - 1], [dst_h - 1, 0]]], device=device, dtype=dtype |
| ) |
|
|
| |
| with pytest.raises(TypeError): |
| kornia.geometry.get_perspective_transform(points_src, points_dst).expand(batch_size, -1, -1) |
|
|
| def test_crop_center_resize(self, device, dtype): |
| |
| dst_h, dst_w = 4, 4 |
|
|
| |
| |
| points_src = torch.tensor([[[1, 1], [1, 2], [2, 2], [2, 1]]], device=device, dtype=dtype) |
|
|
| |
| |
| points_dst = torch.tensor( |
| [[[0, 0], [0, dst_w - 1], [dst_h - 1, dst_w - 1], [dst_h - 1, 0]]], device=device, dtype=dtype |
| ) |
|
|
| |
| dst_trans_src = kornia.geometry.get_perspective_transform(points_src, points_dst) |
|
|
| |
| patch = torch.tensor( |
| [[[[1, 2, 3, 4], [5, 6, 7, 8], [9, 10, 11, 12], [13, 14, 15, 16]]]], device=device, dtype=dtype |
| ) |
|
|
| expected = torch.tensor( |
| [ |
| [ |
| [ |
| [6.0000, 6.3333, 6.6667, 7.0000], |
| [7.3333, 7.6667, 8.0000, 8.3333], |
| [8.6667, 9.0000, 9.3333, 9.6667], |
| [10.0000, 10.3333, 10.6667, 11.0000], |
| ] |
| ] |
| ], |
| device=device, |
| dtype=dtype, |
| ) |
|
|
| |
| patch_warped = kornia.geometry.warp_perspective(patch, dst_trans_src, (dst_h, dst_w)) |
| assert_close(patch_warped, expected) |
|
|
| def test_jit(self, device, dtype): |
| img = torch.rand(1, 2, 3, 4, device=device, dtype=dtype) |
| H_ab = kornia.eye_like(3, img) |
| args = (img, H_ab, (4, 5)) |
| op = kornia.geometry.warp_perspective |
| op_jit = torch.jit.script(op) |
| assert_close(op(*args), op_jit(*args)) |
|
|
| def test_gradcheck(self, device, dtype): |
| batch_size, channels, height, width = 1, 2, 3, 4 |
| img_b = torch.rand(batch_size, channels, height, width, device=device, dtype=dtype) |
| H_ab = kornia.eye_like(3, img_b) |
| img_b = utils.tensor_to_gradcheck_var(img_b) |
| |
| H_ab = utils.tensor_to_gradcheck_var(H_ab, requires_grad=False) |
| assert gradcheck(kornia.geometry.warp_perspective, (img_b, H_ab, (height, width)), raise_exception=True) |
|
|
|
|
| class TestRemap: |
| def test_smoke(self, device, dtype): |
| height, width = 3, 4 |
| input = torch.ones(1, 1, height, width, device=device, dtype=dtype) |
| grid = kornia.utils.create_meshgrid(height, width, normalized_coordinates=False, device=device).to(dtype) |
| input_warped = kornia.geometry.remap(input, grid[..., 0], grid[..., 1], align_corners=True) |
| assert_close(input, input_warped, rtol=1e-4, atol=1e-4) |
|
|
| def test_shift(self, device, dtype): |
| height, width = 3, 4 |
| inp = torch.tensor( |
| [[[[1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0]]]], device=device, dtype=dtype |
| ) |
| expected = torch.tensor( |
| [[[[1.0, 1.0, 1.0, 0.0], [1.0, 1.0, 1.0, 0.0], [0.0, 0.0, 0.0, 0.0]]]], device=device, dtype=dtype |
| ) |
|
|
| grid = kornia.utils.create_meshgrid(height, width, normalized_coordinates=False, device=device).to(dtype) |
| grid += 1.0 |
|
|
| input_warped = kornia.geometry.remap(inp, grid[..., 0], grid[..., 1], align_corners=True) |
| assert_close(input_warped, expected, rtol=1e-4, atol=1e-4) |
|
|
| def test_shift_batch(self, device, dtype): |
| height, width = 3, 4 |
| inp = torch.tensor( |
| [[[[1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0]]]], device=device, dtype=dtype |
| ).repeat(2, 1, 1, 1) |
|
|
| expected = torch.tensor( |
| [ |
| [[[1.0, 1.0, 1.0, 0.0], [1.0, 1.0, 1.0, 0.0], [1.0, 1.0, 1.0, 0.0]]], |
| [[[1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0], [0.0, 0.0, 0.0, 0.0]]], |
| ], |
| device=device, |
| dtype=dtype, |
| ) |
|
|
| |
| grid = kornia.utils.create_meshgrid(height, width, normalized_coordinates=False, device=device).to(dtype) |
| grid = grid.repeat(2, 1, 1, 1) |
| grid[0, ..., 0] += 1.0 |
| grid[1, ..., 1] += 1.0 |
|
|
| input_warped = kornia.geometry.remap(inp, grid[..., 0], grid[..., 1], align_corners=True) |
| assert_close(input_warped, expected, rtol=1e-4, atol=1e-4) |
|
|
| def test_shift_batch_broadcast(self, device, dtype): |
| height, width = 3, 4 |
| inp = torch.tensor( |
| [[[[1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0]]]], device=device, dtype=dtype |
| ).repeat(2, 1, 1, 1) |
| expected = torch.tensor( |
| [[[[1.0, 1.0, 1.0, 0.0], [1.0, 1.0, 1.0, 0.0], [0.0, 0.0, 0.0, 0.0]]]], device=device, dtype=dtype |
| ).repeat(2, 1, 1, 1) |
|
|
| grid = kornia.utils.create_meshgrid(height, width, normalized_coordinates=False, device=device).to(dtype) |
| grid += 1.0 |
|
|
| input_warped = kornia.geometry.remap(inp, grid[..., 0], grid[..., 1], align_corners=True) |
| assert_close(input_warped, expected, rtol=1e-4, atol=1e-4) |
|
|
| def test_normalized_coordinates(self, device, dtype): |
| height, width = 3, 4 |
| normalized_coordinates = True |
| inp = torch.tensor( |
| [[[[1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0]]]], device=device, dtype=dtype |
| ).repeat(2, 1, 1, 1) |
| expected = torch.tensor( |
| [[[[1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0], [1.0, 1.0, 1.0, 1.0]]]], device=device, dtype=dtype |
| ).repeat(2, 1, 1, 1) |
|
|
| grid = kornia.utils.create_meshgrid( |
| height, width, normalized_coordinates=normalized_coordinates, device=device |
| ).to(dtype) |
|
|
| |
| input_warped = kornia.geometry.remap( |
| inp, grid[..., 0], grid[..., 1], align_corners=True, normalized_coordinates=normalized_coordinates |
| ) |
| assert_close(input_warped, expected, rtol=1e-4, atol=1e-4) |
|
|
| def test_gradcheck(self, device, dtype): |
| batch_size, channels, height, width = 1, 2, 3, 4 |
| img = torch.rand(batch_size, channels, height, width, device=device, dtype=dtype) |
| img = utils.tensor_to_gradcheck_var(img) |
|
|
| grid = kornia.utils.create_meshgrid(height, width, normalized_coordinates=False, device=device).to(dtype) |
| grid = utils.tensor_to_gradcheck_var(grid, requires_grad=False) |
|
|
| assert gradcheck( |
| kornia.geometry.remap, (img, grid[..., 0], grid[..., 1], 'bilinear', 'zeros', True), raise_exception=True |
| ) |
|
|
| def test_jit(self, device, dtype): |
| batch_size, channels, height, width = 1, 1, 3, 4 |
| img = torch.ones(batch_size, channels, height, width, device=device, dtype=dtype) |
|
|
| grid = kornia.utils.create_meshgrid(height, width, normalized_coordinates=False, device=device).to(dtype) |
| grid += 1.0 |
|
|
| op = kornia.geometry.remap |
| op_script = torch.jit.script(op) |
|
|
| inputs = (img, grid[..., 0], grid[..., 1], 'bilinear', 'zeros', True) |
| actual = op_script(*inputs) |
| expected = op(*inputs) |
| assert_close(actual, expected, rtol=1e-4, atol=1e-4) |
|
|
|
|
| class TestInvertAffineTransform: |
| def test_smoke(self, device, dtype): |
| matrix = torch.eye(2, 3, device=device, dtype=dtype)[None] |
| matrix_inv = kornia.geometry.invert_affine_transform(matrix) |
| assert_close(matrix, matrix_inv, rtol=1e-4, atol=1e-4) |
|
|
| def test_rot90(self, device, dtype): |
| angle = torch.tensor([90.0], device=device, dtype=dtype) |
| scale = torch.tensor([[1.0, 1.0]], device=device, dtype=dtype) |
| center = torch.tensor([[0.0, 0.0]], device=device, dtype=dtype) |
| expected = torch.tensor([[[0.0, -1.0, 0.0], [1.0, 0.0, 0.0]]], device=device, dtype=dtype) |
| matrix = kornia.geometry.get_rotation_matrix2d(center, angle, scale) |
| matrix_inv = kornia.geometry.invert_affine_transform(matrix) |
| assert_close(matrix_inv, expected, rtol=1e-4, atol=1e-4) |
|
|
| def test_rot90_batch(self, device, dtype): |
| angle = torch.tensor([90.0], device=device, dtype=dtype) |
| scale = torch.tensor([[1.0, 1.0]], device=device, dtype=dtype) |
| center = torch.tensor([[0.0, 0.0]], device=device, dtype=dtype) |
| expected = torch.tensor([[[0.0, -1.0, 0.0], [1.0, 0.0, 0.0]]], device=device, dtype=dtype).repeat(2, 1, 1) |
| matrix = kornia.geometry.get_rotation_matrix2d(center, angle, scale).repeat(2, 1, 1) |
| matrix_inv = kornia.geometry.invert_affine_transform(matrix) |
| assert_close(matrix_inv, expected, rtol=1e-4, atol=1e-4) |
|
|
| def test_gradcheck(self, device, dtype): |
| matrix = torch.eye(2, 3, device=device, dtype=dtype)[None] |
| matrix = utils.tensor_to_gradcheck_var(matrix) |
| assert gradcheck(kornia.geometry.invert_affine_transform, (matrix,), raise_exception=True) |
|
|
| def test_jit(self, device, dtype): |
| op = kornia.geometry.invert_affine_transform |
| op_script = torch.jit.script(op) |
|
|
| matrix = torch.eye(2, 3, device=device, dtype=dtype)[None] |
| actual = op_script(matrix) |
| expected = op(matrix) |
| assert_close(actual, expected, rtol=1e-4, atol=1e-4) |
|
|