blob: 64d74f4e3f5e7eb3ab6801092460dd3872029d35 [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_RENDER_SIGNAL_ANALYZER_H_
12#define MODULES_AUDIO_PROCESSING_AEC3_RENDER_SIGNAL_ANALYZER_H_
peah522d71b2017-02-23 05:16:26 -080013
14#include <array>
15#include <memory>
16
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020017#include "api/optional.h"
18#include "modules/audio_processing/aec3/aec3_common.h"
19#include "modules/audio_processing/aec3/render_buffer.h"
20#include "rtc_base/constructormagic.h"
peah522d71b2017-02-23 05:16:26 -080021
22namespace webrtc {
23
24// Provides functionality for analyzing the properties of the render signal.
25class RenderSignalAnalyzer {
26 public:
27 RenderSignalAnalyzer();
28 ~RenderSignalAnalyzer();
29
30 // Updates the render signal analysis with the most recent render signal.
peah86afe9d2017-04-06 15:45:32 -070031 void Update(const RenderBuffer& render_buffer,
peah522d71b2017-02-23 05:16:26 -080032 const rtc::Optional<size_t>& delay_partitions);
33
34 // Returns true if the render signal is poorly exciting.
35 bool PoorSignalExcitation() const {
36 RTC_DCHECK_LT(2, narrow_band_counters_.size());
37 return std::any_of(narrow_band_counters_.begin(),
38 narrow_band_counters_.end(),
39 [](size_t a) { return a > 10; });
40 }
41
42 // Zeros the array around regions with narrow bands signal characteristics.
43 void MaskRegionsAroundNarrowBands(
44 std::array<float, kFftLengthBy2Plus1>* v) const;
45
peah14c11a42017-07-11 06:13:43 -070046 rtc::Optional<int> NarrowPeakBand() const { return narrow_peak_band_; }
47
peah522d71b2017-02-23 05:16:26 -080048 private:
49 std::array<size_t, kFftLengthBy2 - 1> narrow_band_counters_;
peah14c11a42017-07-11 06:13:43 -070050 rtc::Optional<int> narrow_peak_band_;
51 size_t narrow_peak_counter_;
peah522d71b2017-02-23 05:16:26 -080052
53 RTC_DISALLOW_COPY_AND_ASSIGN(RenderSignalAnalyzer);
54};
55
56} // namespace webrtc
57
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020058#endif // MODULES_AUDIO_PROCESSING_AEC3_RENDER_SIGNAL_ANALYZER_H_