Skip to content

Commit

Permalink
add HP, fix a bug (#153)
Browse files Browse the repository at this point in the history
  • Loading branch information
Andreya-Autumn authored Nov 18, 2024
1 parent 94cc27d commit 4357595
Showing 1 changed file with 25 additions and 9 deletions.
34 changes: 25 additions & 9 deletions include/sst/effects/FloatyDelay.h
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,7 @@ template <typename FXConfig> struct FloatyDelay : core::EffectTemplateBase<FXCon
fld_warp_width,
fld_pitch_warp_depth,
fld_filt_warp_depth,
fld_HP_freq,
fld_mix,
fld_num_params,
};
Expand Down Expand Up @@ -129,6 +130,9 @@ template <typename FXConfig> struct FloatyDelay : core::EffectTemplateBase<FXCon
case fld_filt_warp_depth:
return pmd().asPercent().withName("Filter Depth");

case fld_HP_freq:
return pmd().asAudibleFrequency().withDefault(-60).withName("Highpass Cutoff");

case fld_mix:
return pmd().withName("Mix").asPercent().withDefault(0.3f);
}
Expand Down Expand Up @@ -159,6 +163,7 @@ template <typename FXConfig> struct FloatyDelay : core::EffectTemplateBase<FXCon
sst::filters::CytomicSVF inputFilter;
sst::filters::CytomicSVF feedbackFilter;
sst::filters::CytomicSVF DCfilter;
sst::filters::CytomicSVF HPfilter;

sst::basic_blocks::dsp::lipol_sse<FXConfig::blockSize, false> timeLerp, modLerpL, modLerpR,
rateLerp, feedbackLerp, mixLerp;
Expand All @@ -177,8 +182,7 @@ template <typename FXConfig> struct FloatyDelay : core::EffectTemplateBase<FXCon
}

float readHeadMove{0};
int test{0};
float priorrate{1.f};
bool wasOne{true};
};

template <typename FXConfig> inline void FloatyDelay<FXConfig>::initialize()
Expand All @@ -189,6 +193,7 @@ template <typename FXConfig> inline void FloatyDelay<FXConfig>::initialize()
DCfilter.init();
DCfilter.template setCoeffForBlock<FXConfig::blockSize>(sst::filters::CytomicSVF::HP, 30.f, .5f,
sampleRateInv, 0.f);
HPfilter.init();
timeLerp.instantize();
modLerpL.instantize();
modLerpR.instantize();
Expand Down Expand Up @@ -270,6 +275,10 @@ inline void FloatyDelay<FXConfig>::processBlock(float *dataL, float *dataR)
float smooth{1.f};
float smoothWindow = 256.f;

float HPfreq = 440 * this->noteToPitchIgnoringTuning(this->floatValue(fld_HP_freq));
HPfilter.template setCoeffForBlock<FXConfig::blockSize>(sst::filters::CytomicSVF::HP, HPfreq,
.55f, sampleRateInv, 0.f);

for (int i = 0; i < FXConfig::blockSize; i++)
{
auto absrate = std::fabs(playrate[i]);
Expand Down Expand Up @@ -306,18 +315,23 @@ inline void FloatyDelay<FXConfig>::processBlock(float *dataL, float *dataR)
{
smooth = 1.f; // no smoothing needed

if (readHeadMove > 1) // but delay time will be wrong
if (!wasOne)
{
readHeadMove -= 1; // so wind the head back towards zero
if (readHeadMove > 1) // but delay time will be wrong
{
readHeadMove -= 1; // so wind the head back towards zero
}
else if (readHeadMove < 1)
{
readHeadMove += 1;
}
// (yeah yeah, not quite exactly zero maybe, but close enough)
wasOne = true;
}
else if (readHeadMove < 1)
{
readHeadMove += 1;
}
// (yeah yeah -1...1 != 0 but close enough here)
}
else
{
wasOne = false;
if (playrate[i] < 0)
{
smoothWindow = 512.f; // lengthen the window in reverse
Expand Down Expand Up @@ -354,6 +368,8 @@ inline void FloatyDelay<FXConfig>::processBlock(float *dataL, float *dataR)
delayLineR.write(toLineR);
}

HPfilter.template processBlock<FXConfig::blockSize>(dBufferL, dBufferR, dBufferL, dBufferR);

mixLerp.set_target(this->floatValue(fld_mix));
mixLerp.fade_2_blocks_inplace(dataL, dBufferL, dataR, dBufferR, this->blockSize_quad);
}
Expand Down

0 comments on commit 4357595

Please sign in to comment.