/* * Copyright (c) 2012 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 MODULES_AUDIO_CODING_NETEQ_PREEMPTIVE_EXPAND_H_ #define MODULES_AUDIO_CODING_NETEQ_PREEMPTIVE_EXPAND_H_ #include #include #include "modules/audio_coding/neteq/time_stretch.h" namespace webrtc { class AudioMultiVector; class BackgroundNoise; // This class implements the PreemptiveExpand operation. Most of the work is // done in the base class TimeStretch, which is shared with the Accelerate // operation. In the PreemptiveExpand class, the operations that are specific to // PreemptiveExpand are implemented. class PreemptiveExpand : public TimeStretch { public: PreemptiveExpand(int sample_rate_hz, size_t num_channels, const BackgroundNoise& background_noise, size_t overlap_samples) : TimeStretch(sample_rate_hz, num_channels, background_noise), old_data_length_per_channel_(0), overlap_samples_(overlap_samples) {} PreemptiveExpand(const PreemptiveExpand&) = delete; PreemptiveExpand& operator=(const PreemptiveExpand&) = delete; // This method performs the actual PreemptiveExpand operation. The samples are // read from `input`, of length `input_length` elements, and are written to // `output`. The number of samples added through time-stretching is // is provided in the output `length_change_samples`. The method returns // the outcome of the operation as an enumerator value. ReturnCodes Process(const int16_t* pw16_decoded, size_t len, size_t old_data_len, AudioMultiVector* output, size_t* length_change_samples); protected: // Sets the parameters `best_correlation` and `peak_index` to suitable // values when the signal contains no active speech. void SetParametersForPassiveSpeech(size_t input_length, int16_t* best_correlation, size_t* peak_index) const override; // Checks the criteria for performing the time-stretching operation and, // if possible, performs the time-stretching. ReturnCodes CheckCriteriaAndStretch(const int16_t* input, size_t input_length, size_t peak_index, int16_t best_correlation, bool active_speech, bool /*fast_mode*/, AudioMultiVector* output) const override; private: size_t old_data_length_per_channel_; size_t overlap_samples_; }; struct PreemptiveExpandFactory { PreemptiveExpandFactory() {} virtual ~PreemptiveExpandFactory() {} virtual PreemptiveExpand* Create(int sample_rate_hz, size_t num_channels, const BackgroundNoise& background_noise, size_t overlap_samples) const; }; } // namespace webrtc #endif // MODULES_AUDIO_CODING_NETEQ_PREEMPTIVE_EXPAND_H_