mirror of https://github.com/probonopd/MiniDexed
parent
f9f6f71835
commit
16c45c0418
@ -0,0 +1,73 @@ |
||||
#include "fx_diffuser.h" |
||||
|
||||
#include <cmath> |
||||
#include <algorithm> |
||||
|
||||
#define TAIL , -1 |
||||
|
||||
Diffuser::Diffuser(float32_t sampling_rate) :
|
||||
FXElement(sampling_rate), |
||||
engine_(sampling_rate) |
||||
{ |
||||
this->engine_.setLFOFrequency(Engine::LFOIndex::LFO_1, 0.5f); |
||||
this->engine_.setLFOFrequency(Engine::LFOIndex::LFO_2, 0.3f); |
||||
} |
||||
|
||||
Diffuser::~Diffuser() |
||||
{ |
||||
} |
||||
|
||||
void Diffuser::reset() |
||||
{ |
||||
this->engine_.reset(); |
||||
} |
||||
|
||||
void Diffuser::processSample(float32_t inL, float32_t inR, float32_t& outL, float32_t& outR) |
||||
{ |
||||
typedef Engine::Reserve<126, |
||||
Engine::Reserve<180, |
||||
Engine::Reserve<269, |
||||
Engine::Reserve<444, |
||||
Engine::Reserve<151, |
||||
Engine::Reserve<205, |
||||
Engine::Reserve<245, |
||||
Engine::Reserve<405> > > > > > > > Memory; |
||||
Engine::DelayLine<Memory, 0> apl1; |
||||
Engine::DelayLine<Memory, 1> apl2; |
||||
Engine::DelayLine<Memory, 2> apl3; |
||||
Engine::DelayLine<Memory, 3> apl4; |
||||
Engine::DelayLine<Memory, 4> apr1; |
||||
Engine::DelayLine<Memory, 5> apr2; |
||||
Engine::DelayLine<Memory, 6> apr3; |
||||
Engine::DelayLine<Memory, 7> apr4; |
||||
Engine::Context c; |
||||
|
||||
const float32_t kap = 0.625f; |
||||
float wet = 0.0f; |
||||
|
||||
engine_.start(&c); |
||||
|
||||
c.load(inL); |
||||
c.read(apl1 TAIL, kap); |
||||
c.writeAllPass(apl1, -kap); |
||||
c.read(apl2 TAIL, kap); |
||||
c.writeAllPass(apl2, -kap); |
||||
c.read(apl3 TAIL, kap); |
||||
c.writeAllPass(apl3, -kap); |
||||
c.read(apl4 TAIL, kap); |
||||
c.writeAllPass(apl4, -kap); |
||||
c.writeAndLoad(wet, 0.0f); |
||||
outL = wet; |
||||
|
||||
c.load(inR); |
||||
c.read(apr1 TAIL, kap); |
||||
c.writeAllPass(apr1, -kap); |
||||
c.read(apr2 TAIL, kap); |
||||
c.writeAllPass(apr2, -kap); |
||||
c.read(apr3 TAIL, kap); |
||||
c.writeAllPass(apr3, -kap); |
||||
c.read(apr4 TAIL, kap); |
||||
c.writeAllPass(apr4, -kap); |
||||
c.writeAndLoad(wet, 0.0f); |
||||
outR = wet; |
||||
} |
@ -0,0 +1,45 @@ |
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 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 General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
//
|
||||
|
||||
//
|
||||
// fx_shimmer_reverb3.h
|
||||
//
|
||||
// Stereo Diffuser proposed in the context of the MiniDexed project
|
||||
// It is adapted from the Diffuser that could be found on Cloud EuroRack module from Mutable Instrruments
|
||||
//
|
||||
#pragma once |
||||
|
||||
#include "fx_components.h" |
||||
#include "fx_engine.hpp" |
||||
|
||||
#define DIFFUSER_BUFFER_SIZE 2048 |
||||
|
||||
class Diffuser : public FXElement |
||||
{ |
||||
DISALLOW_COPY_AND_ASSIGN(Diffuser); |
||||
|
||||
public: |
||||
Diffuser(float32_t sampling_rate); |
||||
virtual ~Diffuser(); |
||||
|
||||
virtual void reset() override; |
||||
virtual void processSample(float32_t inL, float32_t inR, float32_t& outL, float32_t& outR) override; |
||||
|
||||
private: |
||||
typedef FxEngine<DIFFUSER_BUFFER_SIZE, Format::FORMAT_FLOAT32, true> Engine; |
||||
Engine engine_; |
||||
|
||||
IMPLEMENT_DUMP() |
||||
IMPLEMENT_INSPECT(return 0u;) |
||||
}; |
Loading…
Reference in new issue