mirror of
https://git.suyu.dev/suyu/suyu
synced 2025-01-09 16:03:21 +00:00
104 lines
2.1 KiB
C++
104 lines
2.1 KiB
C++
|
#include "audio_core/delay_line.h"
|
||
|
|
||
|
namespace AudioCore {
|
||
|
DelayLineBase::DelayLineBase() = default;
|
||
|
DelayLineBase::~DelayLineBase() = default;
|
||
|
|
||
|
void DelayLineBase::Initialize(s32 _max_delay, float* src_buffer) {
|
||
|
buffer = src_buffer;
|
||
|
buffer_end = buffer + _max_delay;
|
||
|
max_delay = _max_delay;
|
||
|
output = buffer;
|
||
|
SetDelay(_max_delay);
|
||
|
Clear();
|
||
|
}
|
||
|
|
||
|
void DelayLineBase::SetDelay(s32 new_delay) {
|
||
|
if (max_delay < new_delay) {
|
||
|
return;
|
||
|
}
|
||
|
delay = new_delay;
|
||
|
input = (buffer + ((output - buffer) + new_delay) % (max_delay + 1));
|
||
|
}
|
||
|
|
||
|
s32 DelayLineBase::GetDelay() const {
|
||
|
return delay;
|
||
|
}
|
||
|
|
||
|
s32 DelayLineBase::GetMaxDelay() const {
|
||
|
return max_delay;
|
||
|
}
|
||
|
|
||
|
f32 DelayLineBase::TapOut(s32 last_sample) {
|
||
|
float* ptr = input - (last_sample + 1);
|
||
|
if (ptr < buffer) {
|
||
|
ptr += (max_delay + 1);
|
||
|
}
|
||
|
|
||
|
return *ptr;
|
||
|
}
|
||
|
|
||
|
f32 DelayLineBase::Tick(f32 sample) {
|
||
|
*(input++) = sample;
|
||
|
const auto out_sample = *(output++);
|
||
|
|
||
|
if (buffer_end < input) {
|
||
|
input = buffer;
|
||
|
}
|
||
|
|
||
|
if (buffer_end < output) {
|
||
|
output = buffer;
|
||
|
}
|
||
|
|
||
|
return out_sample;
|
||
|
}
|
||
|
|
||
|
float* DelayLineBase::GetInput() {
|
||
|
return input;
|
||
|
}
|
||
|
|
||
|
const float* DelayLineBase::GetInput() const {
|
||
|
return input;
|
||
|
}
|
||
|
|
||
|
f32 DelayLineBase::GetOutputSample() const {
|
||
|
return *output;
|
||
|
}
|
||
|
|
||
|
void DelayLineBase::Clear() {
|
||
|
std::memset(buffer, 0, sizeof(float) * max_delay);
|
||
|
}
|
||
|
|
||
|
void DelayLineBase::Reset() {
|
||
|
buffer = nullptr;
|
||
|
buffer_end = nullptr;
|
||
|
max_delay = 0;
|
||
|
input = nullptr;
|
||
|
output = nullptr;
|
||
|
delay = 0;
|
||
|
}
|
||
|
|
||
|
DelayLineAllPass::DelayLineAllPass() = default;
|
||
|
DelayLineAllPass::~DelayLineAllPass() = default;
|
||
|
|
||
|
void DelayLineAllPass::Initialize(u32 delay, float _coeffcient, f32* src_buffer) {
|
||
|
DelayLineBase::Initialize(delay, src_buffer);
|
||
|
SetCoefficient(_coeffcient);
|
||
|
}
|
||
|
|
||
|
void DelayLineAllPass::SetCoefficient(float _coeffcient) {
|
||
|
coefficient = _coeffcient;
|
||
|
}
|
||
|
|
||
|
f32 DelayLineAllPass::Tick(f32 sample) {
|
||
|
const auto temp = sample - coefficient * *output;
|
||
|
return coefficient * temp + DelayLineBase::Tick(temp);
|
||
|
}
|
||
|
|
||
|
void DelayLineAllPass::Reset() {
|
||
|
coefficient = 0.0f;
|
||
|
DelayLineBase::Reset();
|
||
|
}
|
||
|
|
||
|
} // namespace AudioCore
|