blob: 2822b08b687493cfa2b60244e14d4abc5f3ae2ed [file] [log] [blame]
peah522d71b2017-02-23 05:16:26 -08001/*
2 * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#ifndef MODULES_AUDIO_PROCESSING_AEC3_SUBTRACTOR_OUTPUT_H_
12#define MODULES_AUDIO_PROCESSING_AEC3_SUBTRACTOR_OUTPUT_H_
peah522d71b2017-02-23 05:16:26 -080013
14#include <array>
15
Per Åhgrene4db6a12018-07-26 15:32:24 +020016#include "api/array_view.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020017#include "modules/audio_processing/aec3/aec3_common.h"
18#include "modules/audio_processing/aec3/fft_data.h"
peah522d71b2017-02-23 05:16:26 -080019
20namespace webrtc {
21
Sam Zackrisson8f736c02019-10-01 12:47:53 +020022// Stores the values being returned from the echo subtractor for a single
23// capture channel.
peah522d71b2017-02-23 05:16:26 -080024struct SubtractorOutput {
Per Åhgrene4db6a12018-07-26 15:32:24 +020025 SubtractorOutput();
26 ~SubtractorOutput();
27
peah29103572017-07-11 02:54:02 -070028 std::array<float, kBlockSize> s_main;
Per Åhgren78026752018-08-01 16:24:08 +020029 std::array<float, kBlockSize> s_shadow;
peah522d71b2017-02-23 05:16:26 -080030 std::array<float, kBlockSize> e_main;
31 std::array<float, kBlockSize> e_shadow;
32 FftData E_main;
peah522d71b2017-02-23 05:16:26 -080033 std::array<float, kFftLengthBy2Plus1> E2_main;
34 std::array<float, kFftLengthBy2Plus1> E2_shadow;
Per Åhgren78026752018-08-01 16:24:08 +020035 float s2_main = 0.f;
36 float s2_shadow = 0.f;
Per Åhgrene4db6a12018-07-26 15:32:24 +020037 float e2_main = 0.f;
38 float e2_shadow = 0.f;
39 float y2 = 0.f;
Per Åhgren3e7b7b12018-10-16 14:38:10 +020040 float s_main_max_abs = 0.f;
41 float s_shadow_max_abs = 0.f;
peah522d71b2017-02-23 05:16:26 -080042
Per Åhgrene4db6a12018-07-26 15:32:24 +020043 // Reset the struct content.
44 void Reset();
45
46 // Updates the powers of the signals.
Per Åhgren3e7b7b12018-10-16 14:38:10 +020047 void ComputeMetrics(rtc::ArrayView<const float> y);
peah522d71b2017-02-23 05:16:26 -080048};
49
50} // namespace webrtc
51
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020052#endif // MODULES_AUDIO_PROCESSING_AEC3_SUBTRACTOR_OUTPUT_H_