mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-15 23:01:21 +01:00

In this work the performance of the linear filter is estimated. The estimation aims at capture situations when the linear filter is largely over-estimating the echo. In those circumstances, the linear filter is scaled with the purpose of accelerating its convergence. Change-Id: I05ea3739d82838a6f08673432da92125c47943e0 Bug: webrtc:9466,chromium:857426 Reviewed-on: https://webrtc-review.googlesource.com/86133 Reviewed-by: Gustaf Ullberg <gustaf@webrtc.org> Commit-Queue: Jesus de Vicente Pena <devicentepena@webrtc.org> Cr-Commit-Position: refs/heads/master@{#23789}
61 lines
1.6 KiB
C++
61 lines
1.6 KiB
C++
/*
|
|
* Copyright (c) 2017 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_AEC3_SUBTRACTOR_OUTPUT_H_
|
|
#define MODULES_AUDIO_PROCESSING_AEC3_SUBTRACTOR_OUTPUT_H_
|
|
|
|
#include <array>
|
|
|
|
#include "modules/audio_processing/aec3/aec3_common.h"
|
|
#include "modules/audio_processing/aec3/fft_data.h"
|
|
|
|
namespace webrtc {
|
|
|
|
// Stores the values being returned from the echo subtractor.
|
|
struct SubtractorOutput {
|
|
std::array<float, kBlockSize> s_main;
|
|
std::array<float, kBlockSize> e_main;
|
|
std::array<float, kBlockSize> e_shadow;
|
|
FftData E_main;
|
|
std::array<float, kFftLengthBy2Plus1> E2_main;
|
|
std::array<float, kFftLengthBy2Plus1> E2_shadow;
|
|
|
|
void Reset() {
|
|
s_main.fill(0.f);
|
|
e_main.fill(0.f);
|
|
e_shadow.fill(0.f);
|
|
E_main.re.fill(0.f);
|
|
E_main.im.fill(0.f);
|
|
E2_main.fill(0.f);
|
|
E2_shadow.fill(0.f);
|
|
}
|
|
|
|
void ScaleOutputMainFilter(float factor) {
|
|
for (auto& s : s_main) {
|
|
s *= factor;
|
|
}
|
|
for (auto& e : e_main) {
|
|
e *= factor;
|
|
}
|
|
for (auto& E2 : E2_main) {
|
|
E2 *= factor * factor;
|
|
}
|
|
for (auto& re : E_main.re) {
|
|
re *= factor;
|
|
}
|
|
for (auto& im : E_main.im) {
|
|
im *= factor;
|
|
}
|
|
}
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // MODULES_AUDIO_PROCESSING_AEC3_SUBTRACTOR_OUTPUT_H_
|