| /* | 
 |  * 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 |