aboutsummaryrefslogtreecommitdiff
path: root/src/audio_core/delay_line.h
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2021-02-14 20:09:15 -0800
committerGitHub <noreply@github.com>2021-02-14 20:09:15 -0800
commit8378b8a61feb971fc4b8af8468938e4691c2cfb7 (patch)
tree6df36c0a553a72ad4ec5dca2a5134b44d0f31849 /src/audio_core/delay_line.h
parentb0a39153512b1efc031f31e80924e6c14068f4a1 (diff)
parent7ad63ea542c69b4d7d495a38aa247b4958989ee7 (diff)
Merge pull request #5909 from ogniK5377/I3dl2Reverb
audren: Implement I3dl2Reverb
Diffstat (limited to 'src/audio_core/delay_line.h')
-rw-r--r--src/audio_core/delay_line.h46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/audio_core/delay_line.h b/src/audio_core/delay_line.h
new file mode 100644
index 000000000..cafddd432
--- /dev/null
+++ b/src/audio_core/delay_line.h
@@ -0,0 +1,46 @@
+#pragma once
+
+#include "common/common_types.h"
+
+namespace AudioCore {
+
+class DelayLineBase {
+public:
+ DelayLineBase();
+ ~DelayLineBase();
+
+ void Initialize(s32 max_delay_, float* src_buffer);
+ void SetDelay(s32 new_delay);
+ s32 GetDelay() const;
+ s32 GetMaxDelay() const;
+ f32 TapOut(s32 last_sample);
+ f32 Tick(f32 sample);
+ float* GetInput();
+ const float* GetInput() const;
+ f32 GetOutputSample() const;
+ void Clear();
+ void Reset();
+
+protected:
+ float* buffer{nullptr};
+ float* buffer_end{nullptr};
+ s32 max_delay{};
+ float* input{nullptr};
+ float* output{nullptr};
+ s32 delay{};
+};
+
+class DelayLineAllPass final : public DelayLineBase {
+public:
+ DelayLineAllPass();
+ ~DelayLineAllPass();
+
+ void Initialize(u32 delay, float coeffcient_, f32* src_buffer);
+ void SetCoefficient(float coeffcient_);
+ f32 Tick(f32 sample);
+ void Reset();
+
+private:
+ float coefficient{};
+};
+} // namespace AudioCore