mirror of https://github.com/probonopd/MiniDexed
parent
a48a1008c6
commit
2f8f3cc737
@ -0,0 +1,96 @@ |
||||
#include "fx_pitch_shifter.h" |
||||
|
||||
#include <cmath> |
||||
#include <algorithm> |
||||
|
||||
#define ONE_POLE(out, in, coefficient) out += (coefficient) * ((in) - out); |
||||
|
||||
#define TAIL , -1 |
||||
|
||||
PitchShifter::PitchShifter(float32_t sampling_rate) :
|
||||
FXElement(sampling_rate), |
||||
engine_(sampling_rate), |
||||
phase_(0.0f), |
||||
ratio_(0.0f), |
||||
size_(-1.0f), |
||||
sample_size_(0.0f) |
||||
{ |
||||
this->setRatio(0.5f); |
||||
this->setSize(0.5f); |
||||
} |
||||
|
||||
PitchShifter::~PitchShifter() |
||||
{ |
||||
} |
||||
|
||||
void PitchShifter::reset() |
||||
{ |
||||
this->engine_.reset(); |
||||
} |
||||
|
||||
void PitchShifter::processSample(float32_t inL, float32_t inR, float32_t& outL, float32_t& outR) |
||||
{ |
||||
typedef Engine::Reserve<2047, Engine::Reserve<2047> > Memory; |
||||
Engine::DelayLine<Memory, 0> left; |
||||
Engine::DelayLine<Memory, 1> right; |
||||
Engine::Context c; |
||||
|
||||
this->engine_.start(&c); |
||||
|
||||
this->phase_ += (1.0f - this->ratio_) / this->sample_size_; |
||||
if(this->phase_ >= 1.0f) |
||||
{ |
||||
phase_ -= 1.0f; |
||||
} |
||||
if(this->phase_ <= 0.0f) |
||||
{ |
||||
this->phase_ += 1.0f; |
||||
} |
||||
|
||||
float tri = 2.0f * (this->phase_ >= 0.5f ? 1.0f - phase_ : phase_); |
||||
float phase = this->phase_ * this->sample_size_; |
||||
float half = phase + this->sample_size_ * 0.5f; |
||||
if(half >= this->sample_size_) |
||||
{ |
||||
half -= this->sample_size_; |
||||
} |
||||
|
||||
c.load(inL); |
||||
c.writeAndLoad(left, 0.0f); |
||||
c.interpolate(left, phase, tri); |
||||
c.interpolate(left, half, 1.0f - tri); |
||||
c.writeAndLoad(outL, 0.0f); |
||||
|
||||
c.load(inR); |
||||
c.writeAndLoad(right, 0.0f); |
||||
c.interpolate(right, phase, tri); |
||||
c.interpolate(right, half, 1.0f - tri); |
||||
c.writeAndLoad(outR, 0.0f); |
||||
} |
||||
|
||||
void PitchShifter::setRatio(float32_t ratio) |
||||
{ |
||||
this->ratio_ = constrain(ratio, 0.0f, 1.0f); |
||||
} |
||||
|
||||
float32_t PitchShifter::getRatio() const |
||||
{ |
||||
return this->ratio_; |
||||
} |
||||
|
||||
void PitchShifter::setSize(float32_t size) |
||||
{ |
||||
size = constrain(size, 0.0f, 1.0f); |
||||
if(size != this->size_) |
||||
{ |
||||
this->size_ = size; |
||||
|
||||
float32_t target_size = 128.0f + (2047.0f - 128.0f) * size * size * size; |
||||
ONE_POLE(this->sample_size_, target_size, 0.05f); |
||||
} |
||||
} |
||||
|
||||
float32_t PitchShifter::getSize() const |
||||
{ |
||||
return this->size_; |
||||
} |
@ -0,0 +1,56 @@ |
||||
// 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 Pitch Shifter proposed in the context of the MiniDexed project
|
||||
// It is adapted from the Pitch Shifter that could be found on Cloud EuroRack module from Mutable Instrruments
|
||||
//
|
||||
#pragma once |
||||
|
||||
#include "fx_components.h" |
||||
#include "fx_engine.hpp" |
||||
|
||||
#define PITCH_SHIFTER_BUFFER_SIZE 4096 |
||||
|
||||
class PitchShifter : public FXElement |
||||
{ |
||||
DISALLOW_COPY_AND_ASSIGN(PitchShifter); |
||||
|
||||
public: |
||||
PitchShifter(float32_t sampling_rate); |
||||
virtual ~PitchShifter(); |
||||
|
||||
virtual void reset() override; |
||||
virtual void processSample(float32_t inL, float32_t inR, float32_t& outL, float32_t& outR) override; |
||||
|
||||
void setRatio(float32_t ratio); |
||||
float32_t getRatio() const; |
||||
|
||||
void setSize(float32_t size); |
||||
float32_t getSize() const; |
||||
|
||||
private: |
||||
typedef FxEngine<PITCH_SHIFTER_BUFFER_SIZE, Format::FORMAT_FLOAT32, false> Engine; |
||||
Engine engine_; |
||||
|
||||
float32_t phase_; |
||||
float32_t ratio_; |
||||
float32_t size_; |
||||
float32_t sample_size_; |
||||
|
||||
IMPLEMENT_DUMP() |
||||
IMPLEMENT_INSPECT(return 0u;) |
||||
}; |
Loading…
Reference in new issue