ref: 17938cf32356239d02625a3aa9b33321605aaf25
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); tWDF r1; tWDF r2; tWDF c1; tWDF c2; tWDF p1; tWDF s1; tWDF s2; tNoise noise; float gain; bool buttonState; int ratio = 2; void LEAFTest_init (float sampleRate, int blockSize) { LEAF_init(sampleRate, blockSize, &getRandomFloat); tNoise_init(&noise, WhiteNoise); //Bandpass circuit 1 // tWDF_init(&r1, Resistor, 10000.0f, NULL, NULL); // tWDF_init(&r2, Resistor, 10000.0f, NULL, NULL); // tWDF_init(&c1, Capacitor, 0.000000159154943f, NULL, NULL); // tWDF_init(&c2, Capacitor, 0.000000159154943f, NULL, NULL); // tWDF_init(&p1, ParallelAdaptor, 10000.0f, &r1, &c1); // tWDF_init(&s1, SeriesAdaptor, 0.0f, &c2, &r2); // tWDF_init(&s2, SeriesAdaptor, 0.0f, &s1, &p1); //Bandpass circuit 2 tWDF_init(&r1, Resistor, 10000.0f, NULL, NULL); tWDF_init(&c1, Capacitor, 0.000000159154943f, NULL, NULL); tWDF_init(&s1, SeriesAdaptor, 0.0f, &c1, &r1); tWDF_init(&r2, Resistor, 10000.0f, NULL, NULL); tWDF_init(&p1, ParallelAdaptor, 10000.0f, &s1, &r2); tWDF_init(&c2, Capacitor, 0.000000159154943f, NULL, NULL); tWDF_init(&s2, SeriesAdaptor, 0.0f, &c2, &p1); tWDF_setOutputPoint(&s2, &c1); leaf_pool_report(); } float LEAFTest_tick (float input) { float sample = tNoise_tick(&noise); sample = tWDF_tick(&s2, sample, 1); return sample; } bool lastState = false, lastPlayState = false; void LEAFTest_block (void) { float val = getSliderValue("mod freq"); val = 1.0f + 10000.0f * val; tWDF_setValue(&r1, val); val = getSliderValue("mod depth"); val = 1.0f + 10000.0f * val; tWDF_setValue(&r2, val); } 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); } 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(); }