ref: 9368ed952223b1e15427cbbf8860700ae02ce8e6
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();
}