|  | /* | 
|  | *  Copyright (c) 2016 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_PROCESSING_RESIDUAL_ECHO_DETECTOR_H_ | 
|  | #define MODULES_AUDIO_PROCESSING_RESIDUAL_ECHO_DETECTOR_H_ | 
|  |  | 
|  | #include <atomic> | 
|  | #include <cstddef> | 
|  | #include <memory> | 
|  | #include <vector> | 
|  |  | 
|  | #include "api/array_view.h" | 
|  | #include "api/audio/audio_processing.h" | 
|  | #include "modules/audio_processing/echo_detector/circular_buffer.h" | 
|  | #include "modules/audio_processing/echo_detector/mean_variance_estimator.h" | 
|  | #include "modules/audio_processing/echo_detector/moving_max.h" | 
|  | #include "modules/audio_processing/echo_detector/normalized_covariance_estimator.h" | 
|  |  | 
|  | namespace webrtc { | 
|  |  | 
|  | class ApmDataDumper; | 
|  | class AudioBuffer; | 
|  |  | 
|  | class ResidualEchoDetector : public EchoDetector { | 
|  | public: | 
|  | ResidualEchoDetector(); | 
|  | ~ResidualEchoDetector() override; | 
|  |  | 
|  | // This function should be called while holding the render lock. | 
|  | void AnalyzeRenderAudio(ArrayView<const float> render_audio) override; | 
|  |  | 
|  | // This function should be called while holding the capture lock. | 
|  | void AnalyzeCaptureAudio(ArrayView<const float> capture_audio) override; | 
|  |  | 
|  | // This function should be called while holding the capture lock. | 
|  | void Initialize(int capture_sample_rate_hz, | 
|  | int num_capture_channels, | 
|  | int render_sample_rate_hz, | 
|  | int num_render_channels) override; | 
|  |  | 
|  | // This function is for testing purposes only. | 
|  | void SetReliabilityForTest(float value) { reliability_ = value; } | 
|  |  | 
|  | // This function should be called while holding the capture lock. | 
|  | EchoDetector::Metrics GetMetrics() const override; | 
|  |  | 
|  | private: | 
|  | static std::atomic<int> instance_count_; | 
|  | std::unique_ptr<ApmDataDumper> data_dumper_; | 
|  | // Keep track if the `Process` function has been previously called. | 
|  | bool first_process_call_ = true; | 
|  | // Buffer for storing the power of incoming farend buffers. This is needed for | 
|  | // cases where calls to BufferFarend and Process are jittery. | 
|  | CircularBuffer render_buffer_; | 
|  | // Count how long ago it was that the size of `render_buffer_` was zero. This | 
|  | // value is also reset to zero when clock drift is detected and a value from | 
|  | // the renderbuffer is discarded, even though the buffer is not actually zero | 
|  | // at that point. This is done to avoid repeatedly removing elements in this | 
|  | // situation. | 
|  | size_t frames_since_zero_buffer_size_ = 0; | 
|  |  | 
|  | // Circular buffers containing delayed versions of the power, mean and | 
|  | // standard deviation, for calculating the delayed covariance values. | 
|  | std::vector<float> render_power_; | 
|  | std::vector<float> render_power_mean_; | 
|  | std::vector<float> render_power_std_dev_; | 
|  | // Covariance estimates for different delay values. | 
|  | std::vector<NormalizedCovarianceEstimator> covariances_; | 
|  | // Index where next element should be inserted in all of the above circular | 
|  | // buffers. | 
|  | size_t next_insertion_index_ = 0; | 
|  |  | 
|  | MeanVarianceEstimator render_statistics_; | 
|  | MeanVarianceEstimator capture_statistics_; | 
|  | // Current echo likelihood. | 
|  | float echo_likelihood_ = 0.f; | 
|  | // Reliability of the current likelihood. | 
|  | float reliability_ = 0.f; | 
|  | MovingMax recent_likelihood_max_; | 
|  |  | 
|  | int log_counter_ = 0; | 
|  | }; | 
|  |  | 
|  | }  // namespace webrtc | 
|  |  | 
|  | #endif  // MODULES_AUDIO_PROCESSING_RESIDUAL_ECHO_DETECTOR_H_ |