// SPDX-License-Identifier: MIT // Copyright (c) 2024, Advanced Micro Devices, Inc. All rights reserved. #include "gtest/gtest.h" #include "profiler/profile_pool2d_fwd_impl.hpp" #include "test_pool_fwd_common.hpp" template class TestMaxPool2dFwd : public ::testing::Test { protected: using InDataType = std::tuple_element_t<0, Tuple>; using OutDataType = std::tuple_element_t<1, Tuple>; using ComputeDataType = std::tuple_element_t<2, Tuple>; using IndexDataType = std::tuple_element_t<3, Tuple>; static constexpr bool ReturnIndex = std::tuple_element_t<4, Tuple>::value; static std::vector params; void Run() { for(auto param : params) { // max pool bool success = ck::profiler::profile_pool2d_fwd_impl(true, 2, false, false, param.length_, param.window_spatial_lengths_, param.window_strides_, param.window_dilations_, param.input_left_pads_, param.input_right_pads_); EXPECT_TRUE(success); } } }; template std::vector TestMaxPool2dFwd::params = { {{{1, 1, 1, 1}, {1, 1}, {1, 1}, {1, 1}, {0, 0}, {0, 0}}, {{2, 16, 64, 64}, {64, 64}, {1, 1}, {1, 1}, {0, 0}, {0, 0}}, {{2, 16, 64, 64}, {4, 4}, {4, 4}, {2, 2}, {0, 0}, {0, 0}}, {{2, 32, 30, 30}, {2, 2}, {2, 2}, {1, 1}, {1, 1}, {1, 1}}}}; using true_t = std::integral_constant; using false_t = std::integral_constant; using MaxPool2D_F32_Types = ::testing::Types, std::tuple>; using MaxPool2D_F16_Types = ::testing::Types, std::tuple>; using MaxPool2D_BF16_Types = ::testing::Types, std::tuple>; using MaxPool2D_I8_Types = ::testing::Types, std::tuple>; using MaxPool2D_F8_Types = ::testing::Types, std::tuple>; template class MaxPool2D_F32 : public TestMaxPool2dFwd { protected: void SetUp() override { if(!CK_ENABLE_FP32) { GTEST_SKIP() << "Skipping MaxPool2D_F32 tests because CK_ENABLE_FP32 is " "not enabled"; } } }; template class MaxPool2D_F16 : public TestMaxPool2dFwd { protected: void SetUp() override { if(!CK_ENABLE_FP16) { GTEST_SKIP() << "Skipping MaxPool2D_F16 tests because CK_ENABLE_FP16 is " "not enabled"; } } }; template class MaxPool2D_BF16 : public TestMaxPool2dFwd { protected: void SetUp() override { if(!CK_ENABLE_BF16) { GTEST_SKIP() << "Skipping MaxPool2D_BF16 tests because CK_ENABLE_BF16 is " "not enabled"; } } }; template class MaxPool2D_I8 : public TestMaxPool2dFwd { protected: void SetUp() override { if(!CK_ENABLE_INT8) { GTEST_SKIP() << "Skipping MaxPool2D_I8 tests because CK_ENABLE_INT8 is " "not enabled"; } } }; template class MaxPool2D_F8 : public TestMaxPool2dFwd { protected: void SetUp() override { if(!CK_ENABLE_FP8) { GTEST_SKIP() << "Skipping MaxPool2D_F8 tests because CK_ENABLE_FP8 is " "not enabled"; } } }; TYPED_TEST_SUITE(MaxPool2D_F32, MaxPool2D_F32_Types); TYPED_TEST_SUITE(MaxPool2D_F16, MaxPool2D_F16_Types); TYPED_TEST_SUITE(MaxPool2D_BF16, MaxPool2D_BF16_Types); TYPED_TEST_SUITE(MaxPool2D_I8, MaxPool2D_I8_Types); TYPED_TEST_SUITE(MaxPool2D_F8, MaxPool2D_F8_Types); TYPED_TEST(MaxPool2D_F32, MaxPool2D_F32_Test) { this->Run(); } TYPED_TEST(MaxPool2D_F16, MaxPool2D_F16_Test) { this->Run(); } TYPED_TEST(MaxPool2D_BF16, MaxPool2D_BF16_Test) { this->Run(); } TYPED_TEST(MaxPool2D_I8, MaxPool2D_I8_Test) { this->Run(); } TYPED_TEST(MaxPool2D_F8, MaxPool2D_F8_Test) { this->Run(); }