blob: 755444aad4359de089749dbe1d5602143407b74d [file] [log] [blame]
peahd0263542017-01-03 04:20:34 -08001/*
2 * Copyright (c) 2016 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_BLOCK_PROCESSOR_H_
12#define MODULES_AUDIO_PROCESSING_AEC3_BLOCK_PROCESSOR_H_
peahd0263542017-01-03 04:20:34 -080013
Yves Gerey988cc082018-10-23 12:03:01 +020014#include <stddef.h>
Jonas Olssona4d87372019-07-05 19:08:33 +020015
peahd0263542017-01-03 04:20:34 -080016#include <memory>
17#include <vector>
18
Yves Gerey988cc082018-10-23 12:03:01 +020019#include "api/audio/echo_canceller3_config.h"
20#include "api/audio/echo_control.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020021#include "modules/audio_processing/aec3/echo_remover.h"
22#include "modules/audio_processing/aec3/render_delay_buffer.h"
23#include "modules/audio_processing/aec3/render_delay_controller.h"
peahd0263542017-01-03 04:20:34 -080024
25namespace webrtc {
26
27// Class for performing echo cancellation on 64 sample blocks of audio data.
28class BlockProcessor {
29 public:
Gustaf Ullbergbd83b912017-10-18 12:32:42 +020030 static BlockProcessor* Create(const EchoCanceller3Config& config,
Per Åhgrence202a02019-09-02 17:01:19 +020031 int sample_rate_hz,
32 size_t num_render_channels,
33 size_t num_capture_channels);
peah69221db2017-01-27 03:28:19 -080034 // Only used for testing purposes.
35 static BlockProcessor* Create(
Gustaf Ullbergbd83b912017-10-18 12:32:42 +020036 const EchoCanceller3Config& config,
peah69221db2017-01-27 03:28:19 -080037 int sample_rate_hz,
Per Åhgrence202a02019-09-02 17:01:19 +020038 size_t num_render_channels,
39 size_t num_capture_channels,
peah69221db2017-01-27 03:28:19 -080040 std::unique_ptr<RenderDelayBuffer> render_buffer);
41 static BlockProcessor* Create(
Gustaf Ullbergbd83b912017-10-18 12:32:42 +020042 const EchoCanceller3Config& config,
peah69221db2017-01-27 03:28:19 -080043 int sample_rate_hz,
Per Åhgrence202a02019-09-02 17:01:19 +020044 size_t num_render_channels,
45 size_t num_capture_channels,
peah69221db2017-01-27 03:28:19 -080046 std::unique_ptr<RenderDelayBuffer> render_buffer,
47 std::unique_ptr<RenderDelayController> delay_controller,
48 std::unique_ptr<EchoRemover> echo_remover);
49
peahd0263542017-01-03 04:20:34 -080050 virtual ~BlockProcessor() = default;
51
Gustaf Ullberg332150d2017-11-22 14:17:39 +010052 // Get current metrics.
53 virtual void GetMetrics(EchoControl::Metrics* metrics) const = 0;
54
Per Åhgrend0fa8202018-04-18 09:35:13 +020055 // Provides an optional external estimate of the audio buffer delay.
Gustaf Ullberg3cb61042019-10-24 15:52:10 +020056 virtual void SetAudioBufferDelay(int delay_ms) = 0;
Per Åhgrend0fa8202018-04-18 09:35:13 +020057
peahd0263542017-01-03 04:20:34 -080058 // Processes a block of capture data.
59 virtual void ProcessCapture(
peah69221db2017-01-27 03:28:19 -080060 bool echo_path_gain_change,
61 bool capture_signal_saturation,
Per Åhgrence202a02019-09-02 17:01:19 +020062 std::vector<std::vector<std::vector<float>>>* capture_block) = 0;
peahd0263542017-01-03 04:20:34 -080063
peahcf02cf12017-04-05 14:18:07 -070064 // Buffers a block of render data supplied by a FrameBlocker object.
65 virtual void BufferRender(
Per Åhgrence202a02019-09-02 17:01:19 +020066 const std::vector<std::vector<std::vector<float>>>& render_block) = 0;
peahd0263542017-01-03 04:20:34 -080067
68 // Reports whether echo leakage has been detected in the echo canceller
69 // output.
peah69221db2017-01-27 03:28:19 -080070 virtual void UpdateEchoLeakageStatus(bool leakage_detected) = 0;
peahd0263542017-01-03 04:20:34 -080071};
72
73} // namespace webrtc
74
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020075#endif // MODULES_AUDIO_PROCESSING_AEC3_BLOCK_PROCESSOR_H_