From 23d245ab8840d5518a691835e243eba705a6838b Mon Sep 17 00:00:00 2001 From: David Robillard Date: Mon, 22 Feb 2010 21:32:24 +0000 Subject: Merge with upstream r8. git-svn-id: http://svn.drobilla.net/lad/trunk/mda-lv2@2474 a436a847-0d15-0410-975c-d299462d15a1 --- src/mdaDetune.cpp | 88 +++++++++++++++++++++++++++++++++---------------------- 1 file changed, 53 insertions(+), 35 deletions(-) (limited to 'src/mdaDetune.cpp') diff --git a/src/mdaDetune.cpp b/src/mdaDetune.cpp index 21274f5..8fe7704 100644 --- a/src/mdaDetune.cpp +++ b/src/mdaDetune.cpp @@ -28,9 +28,6 @@ mdaDetune::mdaDetune(audioMasterCallback audioMaster): AudioEffectX(audioMaster, DECLARE_LVZ_DEPRECATED(canMono) (); canProcessReplacing(); - ///initialise... - buflen=0; - programs[0].param[0] = 0.20f; //fine programs[0].param[1] = 0.90f; //mix programs[0].param[2] = 0.50f; //output @@ -47,43 +44,32 @@ mdaDetune::mdaDetune(audioMasterCallback audioMaster): AudioEffectX(audioMaster, programs[2].param[3] = 0.50f; strcpy(programs[2].name,"Out Of Tune"); - setProgram(0); + ///initialise... + curProgram=0; suspend(); -} - - -void mdaDetune::resume() ///update internal parameters... -{ - float * param = programs[curProgram].param; - - semi = 3.0f * param[0] * param[0] * param[0]; + + semi = 3.0f * 0.20f * 0.20f * 0.20f; dpos2 = (float)pow(1.0594631f, semi); dpos1 = 1.0f / dpos2; - - wet = (float)pow(10.0f, 2.0f * param[2] - 1.0f); - dry = wet - wet * param[1] * param[1]; - wet = (wet + wet - wet * param[1]) * param[1]; - - LvzInt32 tmp = 1 << (8 + (LvzInt32)(4.9f * param[3])); - - if(tmp!=buflen) //recalculate crossfade window - { - buflen = tmp; - if (buflen > BUFMAX) buflen = BUFMAX; - bufres = 1000.0f * (float)buflen / getSampleRate(); - - LvzInt32 i; //hanning half-overlap-and-add - double p=0.0, dp=6.28318530718/buflen; - for(i=0;i BUFMAX) buflen = BUFMAX; + bufres = 1000.0f * (float)buflen / getSampleRate(); + + LvzInt32 i; //hanning half-overlap-and-add + double p=0.0, dp=6.28318530718/buflen; + for(i=0;i BUFMAX) buflen = BUFMAX; + bufres = 1000.0f * (float)buflen / getSampleRate(); + + LvzInt32 i; //hanning half-overlap-and-add + double p=0.0, dp=6.28318530718/buflen; + for(i=0;i