/* * Copyright (c) 2014 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_SPLITTING_FILTER_H_ #define WEBRTC_MODULES_AUDIO_PROCESSING_SPLITTING_FILTER_H_ #include #include #include "webrtc/modules/audio_processing/three_band_filter_bank.h" #include "webrtc/system_wrappers/include/scoped_vector.h" namespace webrtc { class IFChannelBuffer; struct TwoBandsStates { TwoBandsStates() { memset(analysis_state1, 0, sizeof(analysis_state1)); memset(analysis_state2, 0, sizeof(analysis_state2)); memset(synthesis_state1, 0, sizeof(synthesis_state1)); memset(synthesis_state2, 0, sizeof(synthesis_state2)); } static const int kStateSize = 6; int analysis_state1[kStateSize]; int analysis_state2[kStateSize]; int synthesis_state1[kStateSize]; int synthesis_state2[kStateSize]; }; // Splitting filter which is able to split into and merge from 2 or 3 frequency // bands. The number of channels needs to be provided at construction time. // // For each block, Analysis() is called to split into bands and then Synthesis() // to merge these bands again. The input and output signals are contained in // IFChannelBuffers and for the different bands an array of IFChannelBuffers is // used. class SplittingFilter { public: SplittingFilter(size_t num_channels, size_t num_bands, size_t num_frames); void Analysis(const IFChannelBuffer* data, IFChannelBuffer* bands); void Synthesis(const IFChannelBuffer* bands, IFChannelBuffer* data); private: // Two-band analysis and synthesis work for 640 samples or less. void TwoBandsAnalysis(const IFChannelBuffer* data, IFChannelBuffer* bands); void TwoBandsSynthesis(const IFChannelBuffer* bands, IFChannelBuffer* data); void ThreeBandsAnalysis(const IFChannelBuffer* data, IFChannelBuffer* bands); void ThreeBandsSynthesis(const IFChannelBuffer* bands, IFChannelBuffer* data); void InitBuffers(); const size_t num_bands_; std::vector two_bands_states_; ScopedVector three_band_filter_banks_; }; } // namespace webrtc #endif // WEBRTC_MODULES_AUDIO_PROCESSING_SPLITTING_FILTER_H_