70 lines
2.3 KiB
C++
70 lines
2.3 KiB
C++
|
/*
|
||
|
* Copyright (c) 2018 The WebRTC project authors. All Rights Reserved.
|
||
|
*
|
||
|
* Use of this source code is governed by a BSD-style license
|
||
|
* that can be found in the LICENSE file in the root of the source
|
||
|
* tree. An additional intellectual property rights grant can be found
|
||
|
* in the file PATENTS. All contributing project authors may
|
||
|
* be found in the AUTHORS file in the root of the source tree.
|
||
|
*/
|
||
|
#include "modules/audio_processing/aec3/block_delay_buffer.h"
|
||
|
|
||
|
#include "api/array_view.h"
|
||
|
#include "rtc_base/checks.h"
|
||
|
|
||
|
namespace webrtc {
|
||
|
|
||
|
BlockDelayBuffer::BlockDelayBuffer(size_t num_channels,
|
||
|
size_t num_bands,
|
||
|
size_t frame_length,
|
||
|
size_t delay_samples)
|
||
|
: frame_length_(frame_length),
|
||
|
delay_(delay_samples),
|
||
|
buf_(num_channels,
|
||
|
std::vector<std::vector<float>>(num_bands,
|
||
|
std::vector<float>(delay_, 0.f))) {}
|
||
|
|
||
|
BlockDelayBuffer::~BlockDelayBuffer() = default;
|
||
|
|
||
|
void BlockDelayBuffer::DelaySignal(AudioBuffer* frame) {
|
||
|
RTC_DCHECK_EQ(buf_.size(), frame->num_channels());
|
||
|
if (delay_ == 0) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
const size_t num_bands = buf_[0].size();
|
||
|
const size_t num_channels = buf_.size();
|
||
|
|
||
|
const size_t i_start = last_insert_;
|
||
|
size_t i = 0;
|
||
|
for (size_t ch = 0; ch < num_channels; ++ch) {
|
||
|
RTC_DCHECK_EQ(buf_[ch].size(), frame->num_bands());
|
||
|
RTC_DCHECK_EQ(buf_[ch].size(), num_bands);
|
||
|
rtc::ArrayView<float* const> frame_ch(frame->split_bands(ch), num_bands);
|
||
|
const size_t delay = delay_;
|
||
|
|
||
|
for (size_t band = 0; band < num_bands; ++band) {
|
||
|
RTC_DCHECK_EQ(delay_, buf_[ch][band].size());
|
||
|
i = i_start;
|
||
|
|
||
|
// Offloading these pointers and class variables to local variables allows
|
||
|
// the compiler to optimize the below loop when compiling with
|
||
|
// '-fno-strict-aliasing'.
|
||
|
float* buf_ch_band = buf_[ch][band].data();
|
||
|
float* frame_ch_band = frame_ch[band];
|
||
|
|
||
|
for (size_t k = 0, frame_length = frame_length_; k < frame_length; ++k) {
|
||
|
const float tmp = buf_ch_band[i];
|
||
|
buf_ch_band[i] = frame_ch_band[k];
|
||
|
frame_ch_band[k] = tmp;
|
||
|
|
||
|
i = i < delay - 1 ? i + 1 : 0;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
last_insert_ = i;
|
||
|
}
|
||
|
|
||
|
} // namespace webrtc
|