Chromium Code Reviews| Index: webrtc/modules/audio_processing/aec3/aec3_fft.h |
| diff --git a/webrtc/modules/audio_processing/aec3/aec3_fft.h b/webrtc/modules/audio_processing/aec3/aec3_fft.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..2b5212f80a72e1ad704c10bb60b459f6124f8afa |
| --- /dev/null |
| +++ b/webrtc/modules/audio_processing/aec3/aec3_fft.h |
| @@ -0,0 +1,60 @@ |
| +/* |
| + * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved. |
| + * |
| + * Use of this source code is governed by a BSD-style license |
| + * that can be found in the LICENSE file in the root of the source |
| + * tree. An additional intellectual property rights grant can be found |
| + * in the file PATENTS. All contributing project authors may |
| + * be found in the AUTHORS file in the root of the source tree. |
| + */ |
| + |
| +#ifndef WEBRTC_MODULES_AUDIO_PROCESSING_AEC3_AEC3_FFT_H_ |
| +#define WEBRTC_MODULES_AUDIO_PROCESSING_AEC3_AEC3_FFT_H_ |
| + |
| +#include <array> |
| + |
| +#include "webrtc/base/array_view.h" |
| +#include "webrtc/base/constructormagic.h" |
| +#include "webrtc/modules/audio_processing/aec3/aec3_common.h" |
| +#include "webrtc/modules/audio_processing/aec3/fft_data.h" |
| +#include "webrtc/modules/audio_processing/utility/ooura_fft.h" |
| + |
| +namespace webrtc { |
| + |
| +// Wrapper class that provides 128 point real valued FFT functionality with the |
| +// FftData type. |
| +class Aec3Fft { |
| + public: |
| + Aec3Fft() = default; |
| + // Computes the Fft. Note that both the input and output are modified. |
|
hlundin-webrtc
2017/02/21 16:34:02
Fft -> FFT
peah-webrtc
2017/02/21 23:00:40
Done.
|
| + void Fft(std::array<float, kFftLength>* x, FftData* X) const { |
| + RTC_DCHECK(x); |
| + RTC_DCHECK(X); |
| + ooura_fft_.Fft(x->data()); |
| + X->CopyFromPackedArray(*x); |
| + } |
| + // Computes the inverse Fft. |
| + void Ifft(const FftData& X, std::array<float, kFftLength>* x) const { |
| + RTC_DCHECK(x); |
| + X.CopyToPackedArray(x); |
| + ooura_fft_.InverseFft(x->data()); |
| + } |
| + |
| + // Pads the input with kFftLengthBy2 initial zeros before computing the Fft. |
| + void ZeroPaddedFft(rtc::ArrayView<const float> x, FftData* X) const; |
| + |
| + // Concatenates the kFftLengthBy2 values long x and x_old before computing the |
| + // Fft. After that, x is copied to x_old. |
| + void PaddedFft(rtc::ArrayView<const float> x, |
| + rtc::ArrayView<float> x_old, |
| + FftData* X) const; |
| + |
| + private: |
| + const OouraFft ooura_fft_; |
| + |
| + RTC_DISALLOW_COPY_AND_ASSIGN(Aec3Fft); |
| +}; |
| + |
| +} // namespace webrtc |
| + |
| +#endif // WEBRTC_MODULES_AUDIO_PROCESSING_AEC3_AEC3_FFT_H_ |