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

Unified Diff: webrtc/modules/audio_processing/aec/aec_core.cc

Issue 1991723002: AEC: Add UMA logging of buffer re-alignment (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 years, 7 months 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webrtc/modules/audio_processing/aec/aec_core.cc
diff --git a/webrtc/modules/audio_processing/aec/aec_core.cc b/webrtc/modules/audio_processing/aec/aec_core.cc
index 2cb6dd2ce7664cfc302b388644ccd77fca44c43a..83218f3432c5e4eacb7c866676064eadc5ba445f 100644
--- a/webrtc/modules/audio_processing/aec/aec_core.cc
+++ b/webrtc/modules/audio_processing/aec/aec_core.cc
@@ -33,9 +33,37 @@ extern "C" {
#include "webrtc/modules/audio_processing/logging/apm_data_dumper.h"
#include "webrtc/modules/audio_processing/utility/delay_estimator_wrapper.h"
#include "webrtc/system_wrappers/include/cpu_features_wrapper.h"
+#include "webrtc/system_wrappers/include/metrics.h"
#include "webrtc/typedefs.h"
namespace webrtc {
+namespace {
+enum class DelaySource {
+ kSystemDelay, // The delay values come from the OS.
+ kDelayAgnostic, // The delay values come from the DA-AEC.
+};
+
+constexpr int kMinDelayLogValue = -200;
+constexpr int kMaxDelayLogValue = 200;
+constexpr int kNumDelayLogBuckets = 100;
+
+void MaybeLogDelayAdjustment(int moved_elements, DelaySource source) {
+ if (moved_elements == 0)
+ return;
+ switch (source) {
+ case DelaySource::kSystemDelay:
+ RTC_HISTOGRAM_COUNTS("WebRTC.Audio.AecDelayAdjustmentSystemValue",
+ moved_elements, kMinDelayLogValue,
+ kMaxDelayLogValue, kNumDelayLogBuckets);
+ return;
+ case DelaySource::kDelayAgnostic:
+ RTC_HISTOGRAM_COUNTS("WebRTC.Audio.AecDelayAdjustmentAgnosticValue",
+ moved_elements, kMinDelayLogValue,
+ kMaxDelayLogValue, kNumDelayLogBuckets);
+ return;
+ }
peah-webrtc 2016/05/18 08:22:11 Is a default case needed, or is it fine to use lik
hlundin-webrtc 2016/05/18 10:15:44 I believe it is fine. The compiler complains when
+}
+} // namespace
// Buffer size (samples)
static const size_t kBufSizePartitions = 250; // 1 second of audio in 16 kHz.
@@ -1785,11 +1813,13 @@ void WebRtcAec_ProcessFrames(AecCore* aec,
// rounding, like -16.
int move_elements = (aec->knownDelay - knownDelay - 32) / PART_LEN;
int moved_elements = WebRtc_MoveReadPtr(aec->far_time_buf, move_elements);
+ MaybeLogDelayAdjustment(moved_elements, DelaySource::kSystemDelay);
hlundin-webrtc 2016/05/18 08:04:30 What is the unit for moved_elements? Should probab
peah-webrtc 2016/05/18 08:22:11 For moved_elements below, each element corresponds
hlundin-webrtc 2016/05/18 10:15:44 Done.
aec->knownDelay -= moved_elements * PART_LEN;
} else {
// 2 b) Apply signal based delay correction.
int move_elements = SignalBasedDelayCorrection(aec);
int moved_elements = WebRtc_MoveReadPtr(aec->far_time_buf, move_elements);
+ MaybeLogDelayAdjustment(moved_elements, DelaySource::kDelayAgnostic);
peah-webrtc 2016/05/18 08:22:11 There is also delay adjustments being applied in e
hlundin-webrtc 2016/05/18 10:15:44 Acknowledged. We'll keep that as a separate exerci
int far_near_buffer_diff =
WebRtc_available_read(aec->far_time_buf) -
WebRtc_available_read(aec->nearFrBuf) / PART_LEN;
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698