Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(404)

Side by Side Diff: webrtc/modules/audio_processing/echo_cancellation_impl.h

Issue 1410833002: Lock scheme #4: Introduced the render sample queue for the aec and aecm (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@aec_error_report_CL
Patch Set: Merge Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #ifndef WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_ 11 #ifndef WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_
12 #define WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_ 12 #define WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_
13 13
14 #include "webrtc/base/scoped_ptr.h"
15 #include "webrtc/common_audio/swap_queue.h"
14 #include "webrtc/modules/audio_processing/include/audio_processing.h" 16 #include "webrtc/modules/audio_processing/include/audio_processing.h"
15 #include "webrtc/modules/audio_processing/processing_component.h" 17 #include "webrtc/modules/audio_processing/processing_component.h"
16 18
17 namespace webrtc { 19 namespace webrtc {
18 20
21 namespace {
22 // Functor to use when supplying a verifier function for the queue item
23 // verifcation.
24 class AecRenderQueueItemVerifier {
25 public:
26 explicit AecRenderQueueItemVerifier(size_t allowed_size_1,
27 size_t allowed_size_2)
28 : allowed_size_1_(allowed_size_1), allowed_size_2_(allowed_size_2) {}
29
30 bool operator()(const std::vector<float>& v) const {
31 return (((v.size() == allowed_size_1_) || (v.size() == allowed_size_2_)) &&
32 (v.capacity() >= std::max(allowed_size_1_, allowed_size_2_)));
kwiberg-webrtc 2015/10/27 10:43:07 Why test size in addition to capacity? The latter
peah-webrtc 2015/10/29 11:36:56 Done.
33 }
34
35 private:
36 size_t allowed_size_1_;
37 size_t allowed_size_2_;
38 };
39
40 } // namespace anonymous
41
19 class AudioBuffer; 42 class AudioBuffer;
20 class CriticalSectionWrapper; 43 class CriticalSectionWrapper;
21 44
22 class EchoCancellationImpl : public EchoCancellation, 45 class EchoCancellationImpl : public EchoCancellation,
23 public ProcessingComponent { 46 public ProcessingComponent {
24 public: 47 public:
25 EchoCancellationImpl(const AudioProcessing* apm, 48 EchoCancellationImpl(const AudioProcessing* apm,
26 CriticalSectionWrapper* crit); 49 CriticalSectionWrapper* crit);
27 virtual ~EchoCancellationImpl(); 50 virtual ~EchoCancellationImpl();
28 51
29 int ProcessRenderAudio(const AudioBuffer* audio); 52 int ProcessRenderAudio(const AudioBuffer* audio);
30 int ProcessCaptureAudio(AudioBuffer* audio); 53 int ProcessCaptureAudio(AudioBuffer* audio);
31 54
32 // EchoCancellation implementation. 55 // EchoCancellation implementation.
33 bool is_enabled() const override; 56 bool is_enabled() const override;
34 int stream_drift_samples() const override; 57 int stream_drift_samples() const override;
35 SuppressionLevel suppression_level() const override; 58 SuppressionLevel suppression_level() const override;
36 bool is_drift_compensation_enabled() const override; 59 bool is_drift_compensation_enabled() const override;
37 60
38 // ProcessingComponent implementation. 61 // ProcessingComponent implementation.
39 int Initialize() override; 62 int Initialize() override;
40 void SetExtraOptions(const Config& config) override; 63 void SetExtraOptions(const Config& config) override;
41 64
42 bool is_delay_agnostic_enabled() const; 65 bool is_delay_agnostic_enabled() const;
43 bool is_extended_filter_enabled() const; 66 bool is_extended_filter_enabled() const;
44 67
68 // Reads render side data that has been queued on the render call.
69 void ReadQueuedRenderData();
70
45 private: 71 private:
72 static const size_t kAllowedValuesOfSamplesPerFrame1 = 80;
73 static const size_t kAllowedValuesOfSamplesPerFrame2 = 160;
74 // TODO(peah): Decrease this once we properly handle hugely unbalanced
75 // reverse and forward call numbers.
76 static const size_t kMaxNumFramesToBuffer = 100;
77
46 // EchoCancellation implementation. 78 // EchoCancellation implementation.
47 int Enable(bool enable) override; 79 int Enable(bool enable) override;
48 int enable_drift_compensation(bool enable) override; 80 int enable_drift_compensation(bool enable) override;
49 void set_stream_drift_samples(int drift) override; 81 void set_stream_drift_samples(int drift) override;
50 int set_suppression_level(SuppressionLevel level) override; 82 int set_suppression_level(SuppressionLevel level) override;
51 int enable_metrics(bool enable) override; 83 int enable_metrics(bool enable) override;
52 bool are_metrics_enabled() const override; 84 bool are_metrics_enabled() const override;
53 bool stream_has_echo() const override; 85 bool stream_has_echo() const override;
54 int GetMetrics(Metrics* metrics) override; 86 int GetMetrics(Metrics* metrics) override;
55 int enable_delay_logging(bool enable) override; 87 int enable_delay_logging(bool enable) override;
56 bool is_delay_logging_enabled() const override; 88 bool is_delay_logging_enabled() const override;
57 int GetDelayMetrics(int* median, int* std) override; 89 int GetDelayMetrics(int* median, int* std) override;
58 int GetDelayMetrics(int* median, 90 int GetDelayMetrics(int* median,
59 int* std, 91 int* std,
60 float* fraction_poor_delays) override; 92 float* fraction_poor_delays) override;
61 struct AecCore* aec_core() const override; 93 struct AecCore* aec_core() const override;
62 94
63 // ProcessingComponent implementation. 95 // ProcessingComponent implementation.
64 void* CreateHandle() const override; 96 void* CreateHandle() const override;
65 int InitializeHandle(void* handle) const override; 97 int InitializeHandle(void* handle) const override;
66 int ConfigureHandle(void* handle) const override; 98 int ConfigureHandle(void* handle) const override;
67 void DestroyHandle(void* handle) const override; 99 void DestroyHandle(void* handle) const override;
68 int num_handles_required() const override; 100 int num_handles_required() const override;
69 int GetHandleError(void* handle) const override; 101 int GetHandleError(void* handle) const override;
70 102
103 void AllocateRenderQueue();
104
71 const AudioProcessing* apm_; 105 const AudioProcessing* apm_;
72 CriticalSectionWrapper* crit_; 106 CriticalSectionWrapper* crit_;
73 bool drift_compensation_enabled_; 107 bool drift_compensation_enabled_;
74 bool metrics_enabled_; 108 bool metrics_enabled_;
75 SuppressionLevel suppression_level_; 109 SuppressionLevel suppression_level_;
76 int stream_drift_samples_; 110 int stream_drift_samples_;
77 bool was_stream_drift_set_; 111 bool was_stream_drift_set_;
78 bool stream_has_echo_; 112 bool stream_has_echo_;
79 bool delay_logging_enabled_; 113 bool delay_logging_enabled_;
80 bool extended_filter_enabled_; 114 bool extended_filter_enabled_;
81 bool delay_agnostic_enabled_; 115 bool delay_agnostic_enabled_;
116
117 size_t render_queue_element_max_size_;
118 std::vector<float> render_queue_buffer_;
119 std::vector<float> capture_queue_buffer_;
120 rtc::scoped_ptr<SwapQueue<std::vector<float>, AecRenderQueueItemVerifier> >
121 render_signal_queue_;
kwiberg-webrtc 2015/10/27 10:43:07 As of C++11, you can write >> instead of > >. Als
peah-webrtc 2015/10/29 11:36:56 The thinking was that since the queue needs to be
kwiberg-webrtc 2015/10/29 12:30:22 Well... Why do you need to recreate it? Isn't this
peah-webrtc 2015/10/29 13:07:36 I need to recreate it because the maximum item siz
kwiberg-webrtc 2015/10/29 15:04:50 OK. So it isn't just a performance thing; you actu
peah-webrtc 2015/11/05 11:45:10 According to discussions in another CL, I found th
82 }; 122 };
83 123
84 } // namespace webrtc 124 } // namespace webrtc
85 125
86 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_ 126 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698