84 const auto& inputBlock =
context.getInputBlock();
85 auto& outputBlock =
context.getOutputBlock();
86 const auto numChannels = outputBlock.getNumChannels();
87 const auto numSamples = outputBlock.getNumSamples();
89 jassert (inputBlock.getNumChannels() == numChannels);
90 jassert (inputBlock.getNumChannels() == lastOutput.size());
91 jassert (inputBlock.getNumSamples() == numSamples);
95 outputBlock.copyFrom (inputBlock);
100 auto counter = updateCounter;
102 for (
size_t i = 0; i < numSamples; ++i)
109 if (counter == maxUpdateCounter)
127 auto lfo = jlimit (
static_cast<SampleType
> (0.0),
128 static_cast<SampleType
> (1.0),
132 static_cast<SampleType
> (jmin (20000.0, 0.49 * sampleRate)));
136 dryWet.pushDrySamples (inputBlock);
138 for (
size_t channel = 0; channel < numChannels; ++channel)
140 counter = updateCounter;
143 auto*
inputSamples = inputBlock .getChannelPointer (channel);
144 auto*
outputSamples = outputBlock.getChannelPointer (channel);
146 for (
size_t i = 0; i < numSamples; ++i)
149 auto output = input - lastOutput[channel];
151 if (i == 0 && counter != 0)
152 for (
int n = 0; n < numStages; ++n)
157 for (
int n = 0; n < numStages; ++n)
163 for (
int n = 0; n < numStages; ++n)
164 output = filters[n]->processSample ((
int) channel, output);
167 lastOutput[channel] = output * feedbackVolume[channel].getNextValue();
171 if (counter == maxUpdateCounter)
176 dryWet.mixWetSamples (outputBlock);
177 updateCounter = (updateCounter + (
int) numSamples) % maxUpdateCounter;
198 SampleType rate = 1.0, depth = 0.5, feedback = 0.0, mix = 0.5;