/* * Copyright (c) 2018, Alliance for Open Media. All rights reserved * * This source code is subject to the terms of the BSD 2 Clause License and * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License * was not distributed with this source code in the LICENSE file, you can * obtain it at www.aomedia.org/license/software. If the Alliance for Open * Media Patent License 1.0 was not distributed with this source code in the * PATENTS file, you can obtain it at www.aomedia.org/license/patent. */ #include "test/comp_avg_pred_test.h" using libaom_test::ACMRandom; using libaom_test::AV1DISTWTDCOMPAVG::AV1DISTWTDCOMPAVGTest; using libaom_test::AV1DISTWTDCOMPAVG::DistWtdCompAvgParam; GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(AV1DISTWTDCOMPAVGTest); using libaom_test::AV1DISTWTDCOMPAVG::AV1DISTWTDCOMPAVGUPSAMPLEDTest; GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(AV1DISTWTDCOMPAVGUPSAMPLEDTest); using libaom_test::AV1DISTWTDCOMPAVG::DistWtdCompAvgTest; GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(DistWtdCompAvgTest); #if CONFIG_AV1_HIGHBITDEPTH using libaom_test::AV1DISTWTDCOMPAVG::AV1HighBDDISTWTDCOMPAVGTest; GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(AV1HighBDDISTWTDCOMPAVGTest); using libaom_test::AV1DISTWTDCOMPAVG::AV1HighBDDISTWTDCOMPAVGUPSAMPLEDTest; GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST( AV1HighBDDISTWTDCOMPAVGUPSAMPLEDTest); #endif using std::make_tuple; using std::tuple; uint8_t *DistWtdCompAvgTest::reference_data_ = nullptr; uint8_t *DistWtdCompAvgTest::second_pred_ = nullptr; uint8_t *DistWtdCompAvgTest::comp_pred_ = nullptr; uint8_t *DistWtdCompAvgTest::comp_pred_test_ = nullptr; uint8_t *DistWtdCompAvgTest::reference_data8_ = nullptr; uint8_t *DistWtdCompAvgTest::second_pred8_ = nullptr; uint8_t *DistWtdCompAvgTest::comp_pred8_ = nullptr; uint8_t *DistWtdCompAvgTest::comp_pred8_test_ = nullptr; uint16_t *DistWtdCompAvgTest::reference_data16_ = nullptr; uint16_t *DistWtdCompAvgTest::second_pred16_ = nullptr; uint16_t *DistWtdCompAvgTest::comp_pred16_ = nullptr; uint16_t *DistWtdCompAvgTest::comp_pred16_test_ = nullptr; namespace { TEST_P(AV1DISTWTDCOMPAVGTest, DISABLED_Speed) { RunSpeedTest(GET_PARAM(0)); } TEST_P(AV1DISTWTDCOMPAVGTest, CheckOutput) { RunCheckOutput(GET_PARAM(0)); } #if HAVE_SSSE3 INSTANTIATE_TEST_SUITE_P(SSSE3, AV1DISTWTDCOMPAVGTest, libaom_test::AV1DISTWTDCOMPAVG::BuildParams( aom_dist_wtd_comp_avg_pred_ssse3)); #endif TEST_P(AV1DISTWTDCOMPAVGUPSAMPLEDTest, DISABLED_Speed) { RunSpeedTest(GET_PARAM(0)); } TEST_P(AV1DISTWTDCOMPAVGUPSAMPLEDTest, CheckOutput) { RunCheckOutput(GET_PARAM(0)); } #if HAVE_SSSE3 INSTANTIATE_TEST_SUITE_P(SSSE3, AV1DISTWTDCOMPAVGUPSAMPLEDTest, libaom_test::AV1DISTWTDCOMPAVG::BuildParams( aom_dist_wtd_comp_avg_upsampled_pred_ssse3)); #endif #if HAVE_NEON INSTANTIATE_TEST_SUITE_P(NEON, AV1DISTWTDCOMPAVGUPSAMPLEDTest, libaom_test::AV1DISTWTDCOMPAVG::BuildParams( aom_dist_wtd_comp_avg_upsampled_pred_neon)); #endif // HAVE_NEON TEST_P(DistWtdCompAvgTest, MaxRef) { FillConstant(reference_data_, reference_stride_, mask_); FillConstant(second_pred_, width_, 0); CheckCompAvg(); } TEST_P(DistWtdCompAvgTest, MaxSecondPred) { FillConstant(reference_data_, reference_stride_, 0); FillConstant(second_pred_, width_, mask_); CheckCompAvg(); } TEST_P(DistWtdCompAvgTest, ShortRef) { const int tmp_stride = reference_stride_; reference_stride_ >>= 1; FillRandom(reference_data_, reference_stride_); FillRandom(second_pred_, width_); CheckCompAvg(); reference_stride_ = tmp_stride; } TEST_P(DistWtdCompAvgTest, UnalignedRef) { // The reference frame, but not the source frame, may be unaligned for // certain types of searches. const int tmp_stride = reference_stride_; reference_stride_ -= 1; FillRandom(reference_data_, reference_stride_); FillRandom(second_pred_, width_); CheckCompAvg(); reference_stride_ = tmp_stride; } // TODO(chengchen): add highbd tests const DistWtdCompAvgParam dist_wtd_comp_avg_c_tests[] = { make_tuple(128, 128, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(128, 64, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(64, 128, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(64, 64, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(64, 32, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(32, 64, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(32, 32, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(32, 16, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(16, 32, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(16, 16, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(16, 8, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(8, 16, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(8, 8, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(8, 4, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(4, 8, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(4, 4, &aom_dist_wtd_comp_avg_pred_c, -1), #if !CONFIG_REALTIME_ONLY make_tuple(64, 16, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(16, 64, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(32, 8, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(8, 32, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(16, 4, &aom_dist_wtd_comp_avg_pred_c, -1), make_tuple(4, 16, &aom_dist_wtd_comp_avg_pred_c, -1), #endif }; INSTANTIATE_TEST_SUITE_P(C, DistWtdCompAvgTest, ::testing::ValuesIn(dist_wtd_comp_avg_c_tests)); #if HAVE_SSSE3 const DistWtdCompAvgParam dist_wtd_comp_avg_ssse3_tests[] = { make_tuple(128, 128, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(128, 64, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(64, 128, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(64, 64, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(64, 32, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(32, 64, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(32, 32, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(32, 16, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(16, 32, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(16, 16, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(16, 8, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(8, 16, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(8, 8, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(8, 4, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(4, 8, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(4, 4, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(16, 16, &aom_dist_wtd_comp_avg_pred_ssse3, -1), #if !CONFIG_REALTIME_ONLY make_tuple(64, 16, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(16, 64, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(32, 8, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(8, 32, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(16, 4, &aom_dist_wtd_comp_avg_pred_ssse3, -1), make_tuple(4, 16, &aom_dist_wtd_comp_avg_pred_ssse3, -1), #endif }; INSTANTIATE_TEST_SUITE_P(SSSE3, DistWtdCompAvgTest, ::testing::ValuesIn(dist_wtd_comp_avg_ssse3_tests)); #endif // HAVE_SSSE3 #if HAVE_NEON const DistWtdCompAvgParam dist_wtd_comp_avg_neon_tests[] = { make_tuple(128, 128, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(128, 64, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(64, 128, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(64, 64, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(64, 32, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(32, 64, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(32, 32, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(32, 16, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(16, 32, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(16, 16, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(16, 8, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(8, 16, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(8, 8, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(8, 4, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(4, 8, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(4, 4, &aom_dist_wtd_comp_avg_pred_neon, -1), #if !CONFIG_REALTIME_ONLY make_tuple(64, 16, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(16, 64, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(32, 8, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(8, 32, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(16, 4, &aom_dist_wtd_comp_avg_pred_neon, -1), make_tuple(4, 16, &aom_dist_wtd_comp_avg_pred_neon, -1), #endif // !CONFIG_REALTIME_ONLY }; INSTANTIATE_TEST_SUITE_P(NEON, DistWtdCompAvgTest, ::testing::ValuesIn(dist_wtd_comp_avg_neon_tests)); #endif // HAVE_NEON #if CONFIG_AV1_HIGHBITDEPTH TEST_P(AV1HighBDDISTWTDCOMPAVGTest, DISABLED_Speed) { RunSpeedTest(GET_PARAM(1)); } TEST_P(AV1HighBDDISTWTDCOMPAVGTest, CheckOutput) { RunCheckOutput(GET_PARAM(1)); } #if HAVE_SSE2 INSTANTIATE_TEST_SUITE_P(SSE2, AV1HighBDDISTWTDCOMPAVGTest, libaom_test::AV1DISTWTDCOMPAVG::BuildParams( aom_highbd_dist_wtd_comp_avg_pred_sse2, 1)); #endif #if HAVE_NEON INSTANTIATE_TEST_SUITE_P(NEON, AV1HighBDDISTWTDCOMPAVGTest, libaom_test::AV1DISTWTDCOMPAVG::BuildParams( aom_highbd_dist_wtd_comp_avg_pred_neon, 1)); #endif TEST_P(AV1HighBDDISTWTDCOMPAVGUPSAMPLEDTest, DISABLED_Speed) { RunSpeedTest(GET_PARAM(1)); } TEST_P(AV1HighBDDISTWTDCOMPAVGUPSAMPLEDTest, CheckOutput) { RunCheckOutput(GET_PARAM(1)); } #if HAVE_SSE2 INSTANTIATE_TEST_SUITE_P(SSE2, AV1HighBDDISTWTDCOMPAVGUPSAMPLEDTest, libaom_test::AV1DISTWTDCOMPAVG::BuildParams( aom_highbd_dist_wtd_comp_avg_upsampled_pred_sse2)); #endif #if HAVE_NEON INSTANTIATE_TEST_SUITE_P(NEON, AV1HighBDDISTWTDCOMPAVGUPSAMPLEDTest, libaom_test::AV1DISTWTDCOMPAVG::BuildParams( aom_highbd_dist_wtd_comp_avg_upsampled_pred_neon)); #endif #endif // CONFIG_AV1_HIGHBITDEPTH } // namespace