// SPDX-License-Identifier: MIT // Copyright (c) 2024, Advanced Micro Devices, Inc. All rights reserved. #include "gtest/gtest.h" #include "profiler/profile_max_pool2d_bwd_impl.hpp" #include "test_pool_fwd_common.hpp" template class MaxPool2dBWDTest : public ::testing::Test { protected: using DOutDataType = std::tuple_element_t<0, T>; using DInDataType = std::tuple_element_t<1, T>; using IndexDataType = std::tuple_element_t<2, T>; using InDataType = DInDataType; using OutDataType = DOutDataType; static std::vector params; void Run() { for(auto param : this->params) { bool success = ck::profiler::profile_max_pool2d_bwd_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 MaxPool2dBWDTest::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}}, {{2, 2, 30, 30}, {2, 2}, {2, 2}, {1, 1}, {1, 1}, {1, 1}}}; using Max_Pool_2D_f32_types = ::testing::Types>; using Max_Pool_2D_int8_types = ::testing::Types>; using Max_Pool_2D_f16_types = ::testing::Types>; using Max_Pool_2D_bf16_types = ::testing::Types>; using Max_Pool_2D_f8_types = ::testing::Types>; template class MaxPool2D_f32 : public MaxPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_FP32) { GTEST_SKIP() << "Skipping MaxPool2D_f32 tests because CK_ENABLE_FP32 is not enabled"; } } }; template class MaxPool2D_int8 : public MaxPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_INT8) { GTEST_SKIP() << "Skipping MaxPool2D_int8 tests because CK_ENABLE_INT8 is not enabled"; } } }; template class MaxPool2D_f16 : public MaxPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_FP16) { GTEST_SKIP() << "Skipping MaxPool2D_f16 because CK_ENABLE_FP16 is not enabled"; } } }; template class MaxPool2D_bf16 : public MaxPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_BF16) { GTEST_SKIP() << "Skipping MaxPool2D_bf16 tests because CK_ENABLE_BF16 is not enabled"; } } }; template class MaxPool2D_f8 : public MaxPool2dBWDTest { 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, Max_Pool_2D_f32_types); TYPED_TEST_SUITE(MaxPool2D_int8, Max_Pool_2D_int8_types); TYPED_TEST_SUITE(MaxPool2D_f16, Max_Pool_2D_f16_types); TYPED_TEST_SUITE(MaxPool2D_bf16, Max_Pool_2D_bf16_types); TYPED_TEST_SUITE(MaxPool2D_f8, Max_Pool_2D_f8_types); TYPED_TEST(MaxPool2D_f32, MaxPool2DTest_f32) { this->Run(); } TYPED_TEST(MaxPool2D_int8, MaxPool2DTest_int8) { this->Run(); } TYPED_TEST(MaxPool2D_f16, MaxPool2DTest_f16) { this->Run(); } TYPED_TEST(MaxPool2D_bf16, MaxPool2DTest_bf16) { this->Run(); } TYPED_TEST(MaxPool2D_f8, MaxPool2DTest_f8) { this->Run(); }