// SPDX-License-Identifier: MIT // Copyright (c) 2024, Advanced Micro Devices, Inc. All rights reserved. #include "gtest/gtest.h" #include "profiler/profile_avg_pool2d_bwd_impl.hpp" #include "test_pool_fwd_common.hpp" template class AvgPool2dBWDTest : public ::testing::Test { protected: using InDataType = std::tuple_element_t<0, T>; using OutDataType = std::tuple_element_t<1, T>; static std::vector params; void Run() { for(auto param : this->params) { bool success = ck::profiler::profile_avg_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 AvgPool2dBWDTest::params = { {{1, 1, 1, 1}, {1, 1}, {1, 1}, {1, 1}, {0, 0}, {0, 0}}, {{1, 1, 64, 64}, {64, 64}, {1, 1}, {1, 1}, {0, 0}, {0, 0}}, {{1, 5, 7, 7}, {2, 2}, {2, 2}, {1, 1}, {2, 2}, {0, 0}}, {{1, 1, 8, 8}, {2, 2}, {2, 2}, {1, 1}, {2, 2}, {0, 0}}, {{1, 1, 8, 8}, {2, 2}, {1, 1}, {1, 1}, {1, 1}, {0, 0}}, {{2, 32, 30, 30}, {2, 2}, {2, 2}, {1, 1}, {1, 1}, {1, 1}}, {{1, 2, 30, 30}, {2, 2}, {2, 2}, {1, 1}, {0, 0}, {0, 0}}}; using Avg_Pool_2D_f32_types = ::testing::Types>; using Avg_Pool_2D_int8_types = ::testing::Types>; using Avg_Pool_2D_f16_types = ::testing::Types>; using Avg_Pool_2D_bf16_types = ::testing::Types>; using Avg_Pool_2D_f8_types = ::testing::Types>; template class AvgPool2D_f32 : public AvgPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_FP32) { GTEST_SKIP() << "Skipping AvgPool2D_f32 tests because CK_ENABLE_FP32 is not enabled"; } } }; template class AvgPool2D_int8 : public AvgPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_INT8) { GTEST_SKIP() << "Skipping AvgPool2D_int8 tests because CK_ENABLE_INT8 is not enabled"; } } }; template class AvgPool2D_f16 : public AvgPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_FP16) { GTEST_SKIP() << "Skipping AvgPool2D_f16 because CK_ENABLE_FP16 is not enabled"; } } }; template class AvgPool2D_bf16 : public AvgPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_BF16) { GTEST_SKIP() << "Skipping AvgPool2D_bf16 tests because CK_ENABLE_BF16 is not enabled"; } } }; template class AvgPool2D_f8 : public AvgPool2dBWDTest { protected: void SetUp() override { if(!CK_ENABLE_FP8) { GTEST_SKIP() << "Skipping AvgPool2D_f8 tests because CK_ENABLE_FP8 is not enabled"; } } }; TYPED_TEST_SUITE(AvgPool2D_f32, Avg_Pool_2D_f32_types); TYPED_TEST_SUITE(AvgPool2D_int8, Avg_Pool_2D_int8_types); TYPED_TEST_SUITE(AvgPool2D_f16, Avg_Pool_2D_f16_types); TYPED_TEST_SUITE(AvgPool2D_bf16, Avg_Pool_2D_bf16_types); TYPED_TEST_SUITE(AvgPool2D_f8, Avg_Pool_2D_f8_types); TYPED_TEST(AvgPool2D_f32, AvgPool2DTest_f32) { this->Run(); } TYPED_TEST(AvgPool2D_int8, AvgPool2DTest_int8) { this->Run(); } TYPED_TEST(AvgPool2D_f16, AvgPool2DTest_f16) { this->Run(); } TYPED_TEST(AvgPool2D_bf16, AvgPool2DTest_bf16) { this->Run(); } TYPED_TEST(AvgPool2D_f8, AvgPool2DTest_f8) { this->Run(); }