From 8423f31f1be983f96860b3baabe72af91da7583f Mon Sep 17 00:00:00 2001 From: bszmelcz Date: Fri, 16 Dec 2022 17:27:00 +0100 Subject: [PATCH 1/2] update aten::adaptive_max_pool2d --- .../pytorch/src/op/adaptive_max_pool2d.cpp | 9 +--- .../test_adaptive_max_pool_2d.py | 52 +++++++++++++++++++ 2 files changed, 54 insertions(+), 7 deletions(-) create mode 100644 tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py diff --git a/src/frontends/pytorch/src/op/adaptive_max_pool2d.cpp b/src/frontends/pytorch/src/op/adaptive_max_pool2d.cpp index 77e6b41ecef4de..134434330cca28 100644 --- a/src/frontends/pytorch/src/op/adaptive_max_pool2d.cpp +++ b/src/frontends/pytorch/src/op/adaptive_max_pool2d.cpp @@ -14,13 +14,8 @@ namespace op { OutputVector translate_adaptive_max_pool2d(NodeContext& context) { auto x = context.get_input(0); auto y = context.get_input(1); - auto adaptive_max_pool = context.mark_node(std::make_shared(x, y)); - auto return_indices = context.const_input(2); - OutputVector res{adaptive_max_pool->output(0)}; - if (return_indices) { - res.push_back(adaptive_max_pool->output(1)); - } - return res; + auto adaptive_max_pool = context.mark_node(std::make_shared(x, y, ov::element::i32)); + return {adaptive_max_pool->output(0), adaptive_max_pool->output(1)}; }; } // namespace op diff --git a/tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py b/tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py new file mode 100644 index 00000000000000..367e9a84449aca --- /dev/null +++ b/tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py @@ -0,0 +1,52 @@ +# Copyright (C) 2018-2022 Intel Corporation +# SPDX-License-Identifier: Apache-2.0 + +import pytest +from pytorch_layer_test_class import PytorchLayerTest +import numpy as np +import torch +import torch.nn as nn +import torch.nn.functional as F + + +class TestAdaptiveMaxPool2D(PytorchLayerTest): + + def _prepare_input(self): + return (self.input_tensor,) + + def create_model(self, output_size=None, return_indices=False): + + class aten_adaptive_max_pool2d(torch.nn.Module): + + def __init__(self, output_size=None, return_indices=False) -> None: + super().__init__() + self.output_size = output_size + self.return_indices = return_indices + + def forward(self, input_tensor): + if self.return_indices: + output, indices = F.adaptive_max_pool2d(input_tensor, self.output_size, True) + return output + return F.adaptive_max_pool2d(input_tensor, self.output_size, False) + + ref_net = None + + return aten_adaptive_max_pool2d(output_size, return_indices), ref_net, "aten::adaptive_max_pool2d" + + @pytest.mark.parametrize('input_tensor', ([ + np.random.randn(1, 1, 4, 4).astype(np.float32), + np.random.randn(1, 3, 32, 32).astype(np.float32) + ])) + @pytest.mark.parametrize('output_size', ([ + [2, 2], + [4, 4], + ])) + @pytest.mark.parametrize('return_indices', ([ + False, + True, + ])) + @pytest.mark.nightly + def test_adaptive_max_pool2d(self, ie_device, precision, ir_version, input_tensor, output_size, return_indices): + if ie_device == "CPU": + self.input_tensor = input_tensor + self._test(*self.create_model(output_size, return_indices), ie_device, precision, ir_version) From 3a77c897b43242b49b586a0893ed63446c45be2d Mon Sep 17 00:00:00 2001 From: bszmelcz Date: Fri, 16 Dec 2022 17:37:03 +0100 Subject: [PATCH 2/2] fix style --- tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py b/tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py index 367e9a84449aca..31030fb17a367e 100644 --- a/tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py +++ b/tests/layer_tests/pytorch_tests/test_adaptive_max_pool_2d.py @@ -47,6 +47,5 @@ def forward(self, input_tensor): ])) @pytest.mark.nightly def test_adaptive_max_pool2d(self, ie_device, precision, ir_version, input_tensor, output_size, return_indices): - if ie_device == "CPU": - self.input_tensor = input_tensor - self._test(*self.create_model(output_size, return_indices), ie_device, precision, ir_version) + self.input_tensor = input_tensor + self._test(*self.create_model(output_size, return_indices), ie_device, precision, ir_version)