| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (c) 2012 The WebM project authors. All Rights Reserved. | 2 * Copyright (c) 2012 The WebM project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
| 5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
| 6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 64 double temp_in[32], temp_out[32]; | 64 double temp_in[32], temp_out[32]; |
| 65 for (int j = 0; j < 32; ++j) | 65 for (int j = 0; j < 32; ++j) |
| 66 temp_in[j] = output[j + i*32]; | 66 temp_in[j] = output[j + i*32]; |
| 67 reference_32x32_dct_1d(temp_in, temp_out, 1); | 67 reference_32x32_dct_1d(temp_in, temp_out, 1); |
| 68 // Scale by some magic number | 68 // Scale by some magic number |
| 69 for (int j = 0; j < 32; ++j) | 69 for (int j = 0; j < 32; ++j) |
| 70 output[j + i * 32] = temp_out[j] / 4; | 70 output[j + i * 32] = temp_out[j] / 4; |
| 71 } | 71 } |
| 72 } | 72 } |
| 73 | 73 |
| 74 typedef void (*fwd_txfm_t)(const int16_t *in, int16_t *out, int stride); | 74 typedef void (*FwdTxfmFunc)(const int16_t *in, int16_t *out, int stride); |
| 75 typedef void (*inv_txfm_t)(const int16_t *in, uint8_t *out, int stride); | 75 typedef void (*InvTxfmFunc)(const int16_t *in, uint8_t *out, int stride); |
| 76 | 76 |
| 77 typedef std::tr1::tuple<fwd_txfm_t, inv_txfm_t, int> trans_32x32_param_t; | 77 typedef std::tr1::tuple<FwdTxfmFunc, InvTxfmFunc, int> Trans32x32Param; |
| 78 | 78 |
| 79 class Trans32x32Test : public ::testing::TestWithParam<trans_32x32_param_t> { | 79 class Trans32x32Test : public ::testing::TestWithParam<Trans32x32Param> { |
| 80 public: | 80 public: |
| 81 virtual ~Trans32x32Test() {} | 81 virtual ~Trans32x32Test() {} |
| 82 virtual void SetUp() { | 82 virtual void SetUp() { |
| 83 fwd_txfm_ = GET_PARAM(0); | 83 fwd_txfm_ = GET_PARAM(0); |
| 84 inv_txfm_ = GET_PARAM(1); | 84 inv_txfm_ = GET_PARAM(1); |
| 85 version_ = GET_PARAM(2); // 0: high precision forward transform | 85 version_ = GET_PARAM(2); // 0: high precision forward transform |
| 86 // 1: low precision version for rd loop | 86 // 1: low precision version for rd loop |
| 87 } | 87 } |
| 88 | 88 |
| 89 virtual void TearDown() { libvpx_test::ClearSystemState(); } | 89 virtual void TearDown() { libvpx_test::ClearSystemState(); } |
| 90 | 90 |
| 91 protected: | 91 protected: |
| 92 int version_; | 92 int version_; |
| 93 fwd_txfm_t fwd_txfm_; | 93 FwdTxfmFunc fwd_txfm_; |
| 94 inv_txfm_t inv_txfm_; | 94 InvTxfmFunc inv_txfm_; |
| 95 }; | 95 }; |
| 96 | 96 |
| 97 TEST_P(Trans32x32Test, AccuracyCheck) { | 97 TEST_P(Trans32x32Test, AccuracyCheck) { |
| 98 ACMRandom rnd(ACMRandom::DeterministicSeed()); | 98 ACMRandom rnd(ACMRandom::DeterministicSeed()); |
| 99 uint32_t max_error = 0; | 99 uint32_t max_error = 0; |
| 100 int64_t total_error = 0; | 100 int64_t total_error = 0; |
| 101 const int count_test_block = 1000; | 101 const int count_test_block = 1000; |
| 102 DECLARE_ALIGNED_ARRAY(16, int16_t, test_input_block, kNumCoeffs); | 102 DECLARE_ALIGNED_ARRAY(16, int16_t, test_input_block, kNumCoeffs); |
| 103 DECLARE_ALIGNED_ARRAY(16, int16_t, test_temp_block, kNumCoeffs); | 103 DECLARE_ALIGNED_ARRAY(16, int16_t, test_temp_block, kNumCoeffs); |
| 104 DECLARE_ALIGNED_ARRAY(16, uint8_t, dst, kNumCoeffs); | 104 DECLARE_ALIGNED_ARRAY(16, uint8_t, dst, kNumCoeffs); |
| (...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 273 #if HAVE_AVX2 | 273 #if HAVE_AVX2 |
| 274 INSTANTIATE_TEST_CASE_P( | 274 INSTANTIATE_TEST_CASE_P( |
| 275 AVX2, Trans32x32Test, | 275 AVX2, Trans32x32Test, |
| 276 ::testing::Values( | 276 ::testing::Values( |
| 277 make_tuple(&vp9_fdct32x32_avx2, | 277 make_tuple(&vp9_fdct32x32_avx2, |
| 278 &vp9_idct32x32_1024_add_sse2, 0), | 278 &vp9_idct32x32_1024_add_sse2, 0), |
| 279 make_tuple(&vp9_fdct32x32_rd_avx2, | 279 make_tuple(&vp9_fdct32x32_rd_avx2, |
| 280 &vp9_idct32x32_1024_add_sse2, 1))); | 280 &vp9_idct32x32_1024_add_sse2, 1))); |
| 281 #endif | 281 #endif |
| 282 } // namespace | 282 } // namespace |
| OLD | NEW |