andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. |
| 3 | * |
| 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 |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
| 11 | #include "webrtc/common_audio/real_fourier.h" |
| 12 | |
| 13 | #include <stdlib.h> |
| 14 | |
| 15 | #include "testing/gtest/include/gtest/gtest.h" |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 16 | #include "webrtc/base/scoped_ptr.h" |
| 17 | #include "webrtc/common_audio/real_fourier_openmax.h" |
| 18 | #include "webrtc/common_audio/real_fourier_ooura.h" |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 19 | |
| 20 | namespace webrtc { |
| 21 | |
| 22 | using std::complex; |
| 23 | |
| 24 | TEST(RealFourierStaticsTest, AllocatorAlignment) { |
| 25 | { |
| 26 | RealFourier::fft_real_scoper real; |
| 27 | real = RealFourier::AllocRealBuffer(3); |
| 28 | ASSERT_TRUE(real.get() != nullptr); |
| 29 | int64_t ptr_value = reinterpret_cast<int64_t>(real.get()); |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 30 | EXPECT_EQ(ptr_value % RealFourier::kFftBufferAlignment, 0); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 31 | } |
| 32 | { |
| 33 | RealFourier::fft_cplx_scoper cplx; |
| 34 | cplx = RealFourier::AllocCplxBuffer(3); |
| 35 | ASSERT_TRUE(cplx.get() != nullptr); |
| 36 | int64_t ptr_value = reinterpret_cast<int64_t>(cplx.get()); |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 37 | EXPECT_EQ(ptr_value % RealFourier::kFftBufferAlignment, 0); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 38 | } |
| 39 | } |
| 40 | |
| 41 | TEST(RealFourierStaticsTest, OrderComputation) { |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 42 | EXPECT_EQ(RealFourier::FftOrder(13), 4); |
| 43 | EXPECT_EQ(RealFourier::FftOrder(32), 5); |
| 44 | EXPECT_EQ(RealFourier::FftOrder(2), 1); |
| 45 | EXPECT_EQ(RealFourier::FftOrder(1), 0); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 46 | } |
| 47 | |
| 48 | TEST(RealFourierStaticsTest, ComplexLengthComputation) { |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 49 | EXPECT_EQ(RealFourier::ComplexLength(1), 2); |
| 50 | EXPECT_EQ(RealFourier::ComplexLength(2), 3); |
| 51 | EXPECT_EQ(RealFourier::ComplexLength(3), 5); |
| 52 | EXPECT_EQ(RealFourier::ComplexLength(4), 9); |
| 53 | EXPECT_EQ(RealFourier::ComplexLength(5), 17); |
| 54 | EXPECT_EQ(RealFourier::ComplexLength(7), 65); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 55 | } |
| 56 | |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 57 | template <typename T> |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 58 | class RealFourierTest : public ::testing::Test { |
| 59 | protected: |
| 60 | RealFourierTest() |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 61 | : rf_(2), |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 62 | real_buffer_(RealFourier::AllocRealBuffer(4)), |
| 63 | cplx_buffer_(RealFourier::AllocCplxBuffer(3)) {} |
| 64 | |
| 65 | ~RealFourierTest() { |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 66 | } |
| 67 | |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 68 | T rf_; |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 69 | const RealFourier::fft_real_scoper real_buffer_; |
| 70 | const RealFourier::fft_cplx_scoper cplx_buffer_; |
| 71 | }; |
| 72 | |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 73 | using FftTypes = ::testing::Types< |
| 74 | #if defined(RTC_USE_OPENMAX_DL) |
| 75 | RealFourierOpenmax, |
| 76 | #endif |
| 77 | RealFourierOoura>; |
| 78 | TYPED_TEST_CASE(RealFourierTest, FftTypes); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 79 | |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 80 | TYPED_TEST(RealFourierTest, SimpleForwardTransform) { |
| 81 | this->real_buffer_[0] = 1.0f; |
| 82 | this->real_buffer_[1] = 2.0f; |
| 83 | this->real_buffer_[2] = 3.0f; |
| 84 | this->real_buffer_[3] = 4.0f; |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 85 | |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 86 | this->rf_.Forward(this->real_buffer_.get(), this->cplx_buffer_.get()); |
| 87 | |
| 88 | EXPECT_NEAR(this->cplx_buffer_[0].real(), 10.0f, 1e-8f); |
| 89 | EXPECT_NEAR(this->cplx_buffer_[0].imag(), 0.0f, 1e-8f); |
| 90 | EXPECT_NEAR(this->cplx_buffer_[1].real(), -2.0f, 1e-8f); |
| 91 | EXPECT_NEAR(this->cplx_buffer_[1].imag(), 2.0f, 1e-8f); |
| 92 | EXPECT_NEAR(this->cplx_buffer_[2].real(), -2.0f, 1e-8f); |
| 93 | EXPECT_NEAR(this->cplx_buffer_[2].imag(), 0.0f, 1e-8f); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 94 | } |
| 95 | |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 96 | TYPED_TEST(RealFourierTest, SimpleBackwardTransform) { |
| 97 | this->cplx_buffer_[0] = complex<float>(10.0f, 0.0f); |
| 98 | this->cplx_buffer_[1] = complex<float>(-2.0f, 2.0f); |
| 99 | this->cplx_buffer_[2] = complex<float>(-2.0f, 0.0f); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 100 | |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 101 | this->rf_.Inverse(this->cplx_buffer_.get(), this->real_buffer_.get()); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 102 | |
andrew@webrtc.org | 04c5098 | 2015-03-19 20:06:29 +0000 | [diff] [blame^] | 103 | EXPECT_NEAR(this->real_buffer_[0], 1.0f, 1e-8f); |
| 104 | EXPECT_NEAR(this->real_buffer_[1], 2.0f, 1e-8f); |
| 105 | EXPECT_NEAR(this->real_buffer_[2], 3.0f, 1e-8f); |
| 106 | EXPECT_NEAR(this->real_buffer_[3], 4.0f, 1e-8f); |
andrew@webrtc.org | 325cff0 | 2014-10-01 17:42:18 +0000 | [diff] [blame] | 107 | } |
| 108 | |
| 109 | } // namespace webrtc |
| 110 | |