aboutsummaryrefslogtreecommitdiff
path: root/src/DSP
diff options
context:
space:
mode:
authorDominik Kaiser2025-10-06 21:15:10 +0200
committerDominik Kaiser2025-10-06 21:15:10 +0200
commitc52f9a8babfffef1413df3e03dc6f16d5ffa2c85 (patch)
tree4c2202b370c4c2d944de3b7af03721bcb5933110 /src/DSP
parent796c40a0dac68bd2bc9ccd676ad714f2fd3872fc (diff)
downloadSchroederReverb-c52f9a8babfffef1413df3e03dc6f16d5ffa2c85.tar.gz
SchroederReverb-c52f9a8babfffef1413df3e03dc6f16d5ffa2c85.zip
Add Pre-Delay
Diffstat (limited to 'src/DSP')
-rw-r--r--src/DSP/Delay.cpp37
-rw-r--r--src/DSP/Delay.h18
-rw-r--r--src/DSP/SchroederReverb.cpp7
-rw-r--r--src/DSP/SchroederReverb.h4
4 files changed, 66 insertions, 0 deletions
diff --git a/src/DSP/Delay.cpp b/src/DSP/Delay.cpp
new file mode 100644
index 0000000..50c310a
--- /dev/null
+++ b/src/DSP/Delay.cpp
@@ -0,0 +1,37 @@
+#include "Delay.h"
+
+void
+Delay::prepare(double sampleRate, int samplesPerBlock)
+{
+ int maxDelayTimeMs = 2000;
+ int maxDelaySamples = static_cast<int>(sampleRate * maxDelayTimeMs / 1000.0);
+
+ delayBuffer.resize(maxDelaySamples, 0.0f);
+ std::fill(delayBuffer.begin(), delayBuffer.end(), 0.0f);
+ delayBufferWritePos = 0;
+ this->sampleRate = sampleRate;
+}
+
+void
+Delay::process(float& sample)
+{
+ if (delayInSamples == 0)
+ {
+ return;
+ }
+ int delayBufferLength = (int)delayBuffer.size();
+ int delayReadPos
+ = (delayBufferWritePos - delayInSamples + delayBufferLength) % delayBufferLength;
+ float delayedSample = delayBuffer[delayReadPos];
+
+ delayBuffer[delayBufferWritePos] = sample;
+ sample = delayedSample;
+
+ delayBufferWritePos = (delayBufferWritePos + 1) % delayBufferLength;
+}
+
+void
+Delay::setDelayMs(float ms)
+{
+ delayInSamples = static_cast<int>(sampleRate * (ms / 1000.0f));
+}
diff --git a/src/DSP/Delay.h b/src/DSP/Delay.h
new file mode 100644
index 0000000..e8bd2f1
--- /dev/null
+++ b/src/DSP/Delay.h
@@ -0,0 +1,18 @@
+#pragma once
+
+#include <juce_audio_processors/juce_audio_processors.h>
+
+class Delay
+{
+ public:
+ void prepare(double sampleRate, int samplesPerBlock);
+ void reset();
+ void process(float& sample);
+ void setDelayMs(float ms);
+
+ private:
+ std::vector<float> delayBuffer;
+ int delayBufferWritePos = 0;
+ int delayInSamples = 0;
+ double sampleRate = 0.0;
+};
diff --git a/src/DSP/SchroederReverb.cpp b/src/DSP/SchroederReverb.cpp
index 1b84712..87aa3c4 100644
--- a/src/DSP/SchroederReverb.cpp
+++ b/src/DSP/SchroederReverb.cpp
@@ -19,6 +19,7 @@ SchroederReverb::process(float& sample, float dryWetMix, float decayFactor)
float in = sample;
+ preDelay.process(in);
float cf0in = in;
float cf1in = in;
@@ -36,3 +37,9 @@ SchroederReverb::process(float& sample, float dryWetMix, float decayFactor)
sample = dryWetMix * allPassIn + (1.0f - dryWetMix) * sample;
}
+
+void
+SchroederReverb::setPreDelayMs(float ms)
+{
+ preDelay.setDelayMs(ms);
+}
diff --git a/src/DSP/SchroederReverb.h b/src/DSP/SchroederReverb.h
index 2d5cd0b..5f1b7b1 100644
--- a/src/DSP/SchroederReverb.h
+++ b/src/DSP/SchroederReverb.h
@@ -2,6 +2,7 @@
#include "AllPassFilter.h"
#include "CombFilter.h"
+#include "Delay.h"
#include <juce_audio_processors/juce_audio_processors.h>
class SchroederReverb
@@ -11,7 +12,10 @@ class SchroederReverb
void reset();
void process(float& sample, float dryWetMix, float decayFactor);
+ void setPreDelayMs(float ms);
+
private:
CombFilter combFilter0, combFilter1, combFilter2, combFilter3;
AllPassFilter allPassFilter0, allPassFilter1;
+ Delay preDelay;
};