/* * Copyright (c) 2019 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_NS_QUANTILE_NOISE_ESTIMATOR_H_ #define MODULES_AUDIO_PROCESSING_NS_QUANTILE_NOISE_ESTIMATOR_H_ #include #include #include "api/array_view.h" #include "modules/audio_processing/ns/ns_common.h" namespace webrtc { constexpr int kSimult = 3; // For quantile noise estimation. class QuantileNoiseEstimator { public: QuantileNoiseEstimator(); QuantileNoiseEstimator(const QuantileNoiseEstimator&) = delete; QuantileNoiseEstimator& operator=(const QuantileNoiseEstimator&) = delete; // Estimate noise. void Estimate(rtc::ArrayView signal_spectrum, rtc::ArrayView noise_spectrum); private: std::array density_; std::array log_quantile_; std::array quantile_; std::array counter_; int num_updates_ = 1; }; } // namespace webrtc #endif // MODULES_AUDIO_PROCESSING_NS_QUANTILE_NOISE_ESTIMATOR_H_