/* Copyright (C) 2003, 2004, 2005, 2006, 2008, 2009 Dean Beeler, Jerome Fisher * Copyright (C) 2011, 2012, 2013, 2014 Dean Beeler, Jerome Fisher, Sergey V. Mikayev * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 2.1 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see . */ #ifndef MT32EMU_B_REVERB_MODEL_H #define MT32EMU_B_REVERB_MODEL_H namespace MT32Emu { struct BReverbSettings { const Bit32u numberOfAllpasses; const Bit32u * const allpassSizes; const Bit32u numberOfCombs; const Bit32u * const combSizes; const Bit32u * const outLPositions; const Bit32u * const outRPositions; const Bit32u * const filterFactors; const Bit32u * const feedbackFactors; const Bit32u * const dryAmps; const Bit32u * const wetLevels; const Bit32u lpfAmp; }; class RingBuffer { protected: Sample *buffer; const Bit32u size; Bit32u index; public: RingBuffer(const Bit32u size); virtual ~RingBuffer(); Sample next(); bool isEmpty() const; void mute(); }; class AllpassFilter : public RingBuffer { public: AllpassFilter(const Bit32u size); Sample process(const Sample in); }; class CombFilter : public RingBuffer { protected: const Bit32u filterFactor; Bit32u feedbackFactor; public: CombFilter(const Bit32u size, const Bit32u useFilterFactor); virtual void process(const Sample in); Sample getOutputAt(const Bit32u outIndex) const; void setFeedbackFactor(const Bit32u useFeedbackFactor); }; class DelayWithLowPassFilter : public CombFilter { Bit32u amp; public: DelayWithLowPassFilter(const Bit32u useSize, const Bit32u useFilterFactor, const Bit32u useAmp); void process(const Sample in); void setFeedbackFactor(const Bit32u) {} }; class TapDelayCombFilter : public CombFilter { Bit32u outL; Bit32u outR; public: TapDelayCombFilter(const Bit32u useSize, const Bit32u useFilterFactor); void process(const Sample in); Sample getLeftOutput() const; Sample getRightOutput() const; void setOutputPositions(const Bit32u useOutL, const Bit32u useOutR); }; class BReverbModel { AllpassFilter **allpasses; CombFilter **combs; const BReverbSettings ¤tSettings; const bool tapDelayMode; Bit32u dryAmp; Bit32u wetLevel; static const BReverbSettings &getCM32L_LAPCSettings(const ReverbMode mode); static const BReverbSettings &getMT32Settings(const ReverbMode mode); public: BReverbModel(const ReverbMode mode, const bool mt32CompatibleModel = false); ~BReverbModel(); // After construction or a close(), open() must be called at least once before any other call (with the exception of close()). void open(); // May be called multiple times without an open() in between. void close(); void mute(); void setParameters(Bit8u time, Bit8u level); void process(const Sample *inLeft, const Sample *inRight, Sample *outLeft, Sample *outRight, unsigned long numSamples); bool isActive() const; bool isMT32Compatible(const ReverbMode mode) const; }; } #endif