aboutsummaryrefslogtreecommitdiff
path: root/src/DSP/CombFilter.cpp
diff options
context:
space:
mode:
authorDominik Kaiser2025-09-25 20:40:18 +0200
committerDominik Kaiser2025-09-25 20:40:18 +0200
commit3254981cbeb568adfca7991700e92984e0b92f12 (patch)
tree1eefc18f682e4ee0ca461647e5fe4b1e3fc533bf /src/DSP/CombFilter.cpp
parentd034708ad60f8fc3c9db9481e424d6eca5e2450d (diff)
downloadSchroederReverb-3254981cbeb568adfca7991700e92984e0b92f12.tar.gz
SchroederReverb-3254981cbeb568adfca7991700e92984e0b92f12.zip
Implement basic CombFilter
Diffstat (limited to 'src/DSP/CombFilter.cpp')
-rw-r--r--src/DSP/CombFilter.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/DSP/CombFilter.cpp b/src/DSP/CombFilter.cpp
new file mode 100644
index 0000000..f7eff21
--- /dev/null
+++ b/src/DSP/CombFilter.cpp
@@ -0,0 +1,20 @@
+#include "CombFilter.h"
+
+void CombFilter::prepare(double sampleRate, int samplesPerBlock) {
+ int maxDelayTimeMs = 100;
+ int maxDelaySamples = static_cast<int>(sampleRate * maxDelayTimeMs / 1000.0);
+
+ delayBuffer.resize(maxDelaySamples, 0.0f);
+ delayInSamples = static_cast<int>(sampleRate * 0.02);
+ delayBufferWritePos = 0;
+}
+
+void CombFilter::process(float* sample) {
+ int delayBufferLength = (int)delayBuffer.size();
+ int delayReadPos = (delayBufferWritePos - delayInSamples + delayBufferLength) % delayBufferLength;
+ float delayedSample = delayBuffer[delayReadPos];
+ float out = *sample + gain * delayedSample;
+ delayBuffer[delayBufferWritePos] = *sample;
+ *sample = out;
+ delayBufferWritePos = (delayBufferWritePos + 1) % delayBufferLength;
+}