/* ============================================================================== This file is part of the JUCETICE project - Copyright 2008 by Lucio Asnaghi. JUCETICE is based around the JUCE library - "Jules' Utility Class Extensions" Copyright 2008 by Julian Storer. ------------------------------------------------------------------------------ JUCE and JUCETICE can be redistributed and/or modified under the terms of the GNU Lesser General Public License, as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. JUCE and JUCETICE are distributed in the hope that they will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with JUCE and JUCETICE; if not, visit www.gnu.org/licenses or write to Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ============================================================================== @author rockhardbuns @tweaker Lucio Asnaghi @tweaker falkTX ============================================================================== */ #ifndef DISTRHO_VEX_DELAY_HEADER_INCLUDED #define DISTRHO_VEX_DELAY_HEADER_INCLUDED #ifndef CARLA_EXPORT #define CARLA_EXPORT #endif #ifdef CARLA_EXPORT #include "juce_audio_basics.h" #else #include "../StandardHeader.h" #endif class VexDelay { public: VexDelay(const float* const p) : parameters(p), sampleRate(0.0f), bufferSize(0), iRead(0), iWrite(0), buffer(2, 0) { buffer.clear(); setSampleRate(44100.0f); } void updateParameterPtr(const float* const p) { parameters = p; } void setSampleRate(const float s) { if (sampleRate == s) return; sampleRate = s; bufferSize = sampleRate * 2; iRead = 0; iWrite = 0; buffer.setSize(2, bufferSize, false, false, true); buffer.clear(); } void processBlock(AudioSampleBuffer* const outBuffer, double bpm) { processBlock(outBuffer->getSampleData(0, 0), outBuffer->getSampleData(1, 0), outBuffer->getNumSamples(), bpm); } void processBlock(float* const outBufferL, float* const outBufferR, const int numSamples, double bpm) { bpm = jlimit(10.0, 500.0, bpm); const int delay = jmin(int(parameters[73] * 8.0f) * int(((60.0 / bpm) * sampleRate) / 4.0), 44100); const float feedback = parameters[74]; float* const bufferL = buffer.getSampleData(0, 0); float* const bufferR = buffer.getSampleData(1, 0); for (int i = 0; i < numSamples; ++i) { iRead = iWrite - delay; if (iRead < 0) iRead += (int)sampleRate; bufferL[iWrite] = outBufferL[i]; bufferR[iWrite] = outBufferR[i]; bufferR[iWrite] += bufferL[iRead] * feedback; bufferL[iWrite] += bufferR[iRead] * feedback; jassert(i < numSamples); jassert(iRead < bufferSize); jassert(iWrite < bufferSize); outBufferL[i] = bufferL[iRead]; outBufferR[i] = bufferR[iRead]; if (++iWrite == sampleRate) iWrite = 0; } } private: const float* parameters; float sampleRate; int bufferSize, iRead, iWrite; AudioSampleBuffer buffer; JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(VexDelay) }; #endif // DISTRHO_VEX_DELAY_HEADER_INCLUDED