Files
openvino/tests/layer_tests/pytorch_tests/test_topk.py
Mikhail Ryzhov 4078bd9c19 [GHA] Speed up PyTorch Layer unit tests (#20613)
* test

* fixed tests

* typo

* fixed tests

* rest of the tests

* fixed rsub test

* tmp fix

* Revert "tmp fix"

This reverts commit b8bf1e9492e13497895da488612c9a137ef840bc.

* fixed test params

* reset thirdparty/pugixml

* Revert "fixed rsub test"

This reverts commit 9b6be34b8666936e8124b6622fcc5185b640de92.

* fixed typo

* fixed test data

* reset test_rsub

* removed unused param

* reverrted runner

* simplified call

* fixed random

* changed logical to auto mode

* Revert "fixed random"

This reverts commit 8a4f20b24641144f823a7e1f1ff92038634acf32.

* fixed test_all

* replaced random_sample with randn

* fixed rebase issue

* reverted logical splitting

* Update tests/layer_tests/pytorch_tests/test_repeat_interleave.py

Co-authored-by: Maxim Vafin <maxim.vafin@intel.com>

* Update tests/layer_tests/pytorch_tests/test_all.py

Co-authored-by: Maxim Vafin <maxim.vafin@intel.com>

* Apply suggestions from code review

Co-authored-by: Maxim Vafin <maxim.vafin@intel.com>

* fixed merge conflict

---------

Co-authored-by: Maxim Vafin <maxim.vafin@intel.com>
2023-10-26 13:10:51 +04:00

68 lines
2.0 KiB
Python

# Copyright (C) 2018-2023 Intel Corporation
# SPDX-License-Identifier: Apache-2.0
import os
import numpy as np
import pytest
from pytorch_layer_test_class import PytorchLayerTest
class TestTopK(PytorchLayerTest):
def _prepare_input(self):
return (self.input_tensor,)
def create_model(self, k, dim, largest, sort):
import torch
class aten_topk(torch.nn.Module):
def __init__(self, k, dim, largest, sort):
super(aten_topk, self).__init__()
self.k = k
self.dim = dim
self.largest = largest
self.sort = sort
def forward(self, input_tensor):
if self.dim is None:
return torch.topk(input_tensor, k=self.k, largest=self.largest, sorted=self.sort)
else:
return torch.topk(input_tensor, k=self.k, dim=self.dim, largest=self.largest, sorted=self.sort)
ref_net = None
return aten_topk(k, dim, largest, sort), ref_net, "aten::topk"
@pytest.mark.parametrize(("input_shape"), [
[7, 5, 5, 4],
[5, 6, 6, 7, 8]
])
@pytest.mark.parametrize(("k"), [
3,
1,
2,
])
@pytest.mark.parametrize(("dim"), [
0,
2,
-1,
None,
])
@pytest.mark.parametrize(("largest"), [
True,
False,
])
# For False it is hard to test because in Pytorch implementation
# there is not promise on the order of output values
@pytest.mark.parametrize(("sort"), [
True,
])
@pytest.mark.nightly
@pytest.mark.precommit
@pytest.mark.skipif(os.getenv("GITHUB_ACTIONS") == 'true', reason="Ticket - 115085")
def test_topK(self, input_shape, k, dim, largest, sort, ie_device, precision, ir_version):
self.input_tensor = np.random.randn(*input_shape).astype(np.float32)
self._test(*self.create_model(k, dim, largest, sort), ie_device, precision, ir_version)