mirror of
https://github.com/danog/libtgvoip.git
synced 2025-01-09 14:18:24 +01:00
48 lines
1.4 KiB
C++
48 lines
1.4 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 "rtc_base/checks.h"
|
||
|
|
||
|
namespace webrtc {
|
||
|
|
||
|
BlockDelayBuffer::BlockDelayBuffer(size_t num_bands,
|
||
|
size_t frame_length,
|
||
|
size_t delay_samples)
|
||
|
: frame_length_(frame_length),
|
||
|
delay_(delay_samples),
|
||
|
buf_(num_bands, std::vector<float>(delay_, 0.f)) {}
|
||
|
|
||
|
BlockDelayBuffer::~BlockDelayBuffer() = default;
|
||
|
|
||
|
void BlockDelayBuffer::DelaySignal(AudioBuffer* frame) {
|
||
|
RTC_DCHECK_EQ(1, frame->num_channels());
|
||
|
RTC_DCHECK_EQ(buf_.size(), frame->num_bands());
|
||
|
if (delay_ == 0) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
const size_t i_start = last_insert_;
|
||
|
size_t i = 0;
|
||
|
for (size_t j = 0; j < buf_.size(); ++j) {
|
||
|
i = i_start;
|
||
|
for (size_t k = 0; k < frame_length_; ++k) {
|
||
|
const float tmp = buf_[j][i];
|
||
|
buf_[j][i] = frame->split_bands_f(0)[j][k];
|
||
|
frame->split_bands_f(0)[j][k] = tmp;
|
||
|
i = i < buf_[0].size() - 1 ? i + 1 : 0;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
last_insert_ = i;
|
||
|
}
|
||
|
|
||
|
} // namespace webrtc
|