Jesús de Vicente Peña | c98849c | 2018-10-22 11:41:05 +0200 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2018 The WebRTC project authors. All Rights Reserved. |
| 3 | * |
| 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 |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
Per Åhgren | dc98b9b | 2018-11-06 14:46:34 +0100 | [diff] [blame] | 11 | #include "modules/audio_processing/aec3/render_reverb_model.h" |
| 12 | |
Jesús de Vicente Peña | c98849c | 2018-10-22 11:41:05 +0200 | [diff] [blame] | 13 | #include <algorithm> |
| 14 | |
| 15 | #include "api/array_view.h" |
Jesús de Vicente Peña | c98849c | 2018-10-22 11:41:05 +0200 | [diff] [blame] | 16 | #include "rtc_base/checks.h" |
| 17 | |
| 18 | namespace webrtc { |
| 19 | |
| 20 | RenderReverbModel::RenderReverbModel() { |
| 21 | Reset(); |
| 22 | } |
| 23 | |
| 24 | RenderReverbModel::~RenderReverbModel() = default; |
| 25 | |
| 26 | void RenderReverbModel::Reset() { |
| 27 | render_reverb_.Reset(); |
| 28 | } |
| 29 | |
| 30 | void RenderReverbModel::Apply(const VectorBuffer& spectrum_buffer, |
| 31 | int delay_blocks, |
| 32 | float reverb_decay, |
| 33 | rtc::ArrayView<float> reverb_power_spectrum) { |
| 34 | int idx_at_delay = |
| 35 | spectrum_buffer.OffsetIndex(spectrum_buffer.read, delay_blocks); |
| 36 | int idx_past = spectrum_buffer.IncIndex(idx_at_delay); |
| 37 | const auto& X2 = spectrum_buffer.buffer[idx_at_delay]; |
| 38 | RTC_DCHECK_EQ(X2.size(), reverb_power_spectrum.size()); |
| 39 | std::copy(X2.begin(), X2.end(), reverb_power_spectrum.begin()); |
| 40 | render_reverb_.AddReverbNoFreqShaping(spectrum_buffer.buffer[idx_past], 1.0f, |
| 41 | reverb_decay, reverb_power_spectrum); |
| 42 | } |
| 43 | |
| 44 | } // namespace webrtc |