blob: a9ebb8cd92b48d3df4b09a030670a01713592a42 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
/*
* 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.
*/
#include "modules/audio_processing/echo_detector/mean_variance_estimator.h"
#include <cmath>
#include "rtc_base/checks.h"
namespace webrtc {
namespace {
// Parameter controlling the adaptation speed.
constexpr float kAlpha = 0.001f;
} // namespace
void MeanVarianceEstimator::Update(float value) {
mean_ = (1.f - kAlpha) * mean_ + kAlpha * value;
variance_ =
(1.f - kAlpha) * variance_ + kAlpha * (value - mean_) * (value - mean_);
RTC_DCHECK(std::isfinite(mean_));
RTC_DCHECK(std::isfinite(variance_));
}
float MeanVarianceEstimator::std_deviation() const {
RTC_DCHECK_GE(variance_, 0.f);
return sqrtf(variance_);
}
float MeanVarianceEstimator::mean() const {
return mean_;
}
void MeanVarianceEstimator::Clear() {
mean_ = 0.f;
variance_ = 0.f;
}
} // namespace webrtc
|