Index: webrtc/modules/audio_processing/intelligibility/intelligibility_utils.cc |
diff --git a/webrtc/modules/audio_processing/intelligibility/intelligibility_utils.cc b/webrtc/modules/audio_processing/intelligibility/intelligibility_utils.cc |
index 6e641a23325984bee6daab921a67c9acc959a489..49df9c3eb6bef7fc04bd5fd261dfef982d8ac9b5 100644 |
--- a/webrtc/modules/audio_processing/intelligibility/intelligibility_utils.cc |
+++ b/webrtc/modules/audio_processing/intelligibility/intelligibility_utils.cc |
@@ -66,6 +66,29 @@ void GainApplier::Apply(const std::complex<float>* in_block, |
} |
} |
+DelayBuffer::DelayBuffer(size_t delay, size_t num_channels) |
+ : buffer_(num_channels, std::vector<float>(delay, 0.f)), read_index_(0u) {} |
+ |
+DelayBuffer::~DelayBuffer() {} |
+ |
+void DelayBuffer::Delay(float* const* data, size_t length) { |
+ for (size_t i = 0u; i < buffer_.size(); ++i) { |
+ size_t channel_index = read_index_; |
peah-webrtc
2016/09/17 21:31:30
Please consider changing this name.
To me, a chan
aluebs-webrtc
2016/09/19 19:17:14
Good point. Done.
|
+ for (size_t j = 0u; j < length; ++j) { |
+ float swap = data[i][j]; |
+ data[i][j] = buffer_[i][channel_index]; |
+ buffer_[i][channel_index] = swap; |
+ if (++channel_index == buffer_.size()) { |
+ channel_index = 0u; |
+ } |
+ } |
+ } |
+ read_index_ += length; |
+ while (read_index_ >= buffer_.size()) { |
peah-webrtc
2016/09/17 21:31:30
This part is not necessary. You have the wraparoun
aluebs-webrtc
2016/09/19 19:17:14
Good point. Done.
|
+ read_index_ -= buffer_.size(); |
+ } |
+} |
+ |
} // namespace intelligibility |
} // namespace webrtc |