Chromium Code Reviews| 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 |