OLD | NEW |
---|---|
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_ |
OLD | NEW |