ref: 6e8f4634b7cfc75451ab87275c4ce2b90059b193
dir: /LEAF_JUCEPlugin/Source/MyTest.cpp/
/* ============================================================================== FM.c Created: 23 Jan 2017 9:39:38am Author: Michael R Mulshine ============================================================================== */ #include "LEAFTest.h" #include "MyTest.h" static void leaf_pool_report(void); static void leaf_pool_dump(void); static void run_pool_test(void); tDattorro reverb; void LEAFTest_init (float sampleRate, int blockSize) { LEAF_init(sampleRate, blockSize, &randomNumberGenerator); tDattorro_init(&reverb); setSliderValue("mix", reverb.mix); setSliderValue("predelay", reverb.predelay / 200.0f); setSliderValue("input filter", reverb.input_filter / 20000.0f); setSliderValue("feedback filter", reverb.feedback_filter / 20000.0f); setSliderValue("feedback gain", reverb.feedback_gain); //setSliderValue("size", reverb.size / 4.0f); leaf_pool_report(); } int timer = 0; #define CLICK 0 float LEAFTest_tick (float input) { #if CLICK input = 0.0f; timer++; if (timer == (1 * leaf.sampleRate)) { timer = 0; input = 1.0f; } #endif return tDattorro_tick(&reverb, input); } void LEAFTest_block (void) { float val = getSliderValue("mix"); tDattorro_setMix(&reverb, val); val = getSliderValue("predelay"); tDattorro_setInputDelay(&reverb, val * 200.0f); val = getSliderValue("input filter"); tDattorro_setInputFilter(&reverb, val * 20000.0f); val = getSliderValue("feedback filter"); tDattorro_setFeedbackFilter(&reverb, val * 20000.0f); val = getSliderValue("feedback gain"); tDattorro_setFeedbackGain(&reverb, val); //val = getSliderValue("size"); //tDattorro_setSize(&reverb, val * 4.0f); } void LEAFTest_controllerInput (int cnum, float cval) { } void LEAFTest_pitchBendInput (int pitchBend) { } int lastNote; void LEAFTest_noteOn (int note, float velocity) { } void LEAFTest_noteOff (int note) { } void LEAFTest_end (void) { } // LEAF POOL UTILITIES void leaf_pool_report(void) { DBG(String(leaf_pool_get_used()) + " of " + String(leaf_pool_get_size())); } void leaf_pool_dump(void) { float* buff = (float*)leaf_pool_get_pool(); int siz = leaf_pool_get_size(); siz /= sizeof(float); for (int i = 0; i < siz; i++) { DBG(String(buff[i])); } } static void run_pool_test(void) { leaf_pool_report(); DBG("ALLOC BUFFER 1"); int size = 50; float* buffer; buffer = (float*) leaf_alloc(sizeof(float) * size); for (int i = 0; i < size; i++) { buffer[i] = (float)i; } leaf_pool_report(); DBG("ALLOC BUFFER 2"); size = 25; buffer = (float*) leaf_alloc(sizeof(float) * size); leaf_pool_report(); for (int i = 0; i < size; i++) { buffer[i] = (float)(i*2); } DBG("FREE BUFFER 2"); leaf_free(buffer); leaf_pool_report(); DBG("ALLOC BUFFER 3"); size = 15; buffer = (float*) leaf_alloc(sizeof(float) * size); for (int i = 0; i < size; i++) { buffer[i] = (float)(i*3); } leaf_pool_report(); leaf_pool_dump(); }