3
/*--------------- vlavg -----------------------*/
4
/* leaky average of each element in a list */
5
/* arguments: [halfdecay] */
7
static t_class *vlavg_class;
19
static void vlavg_perform(t_vlavg *x, t_symbol *s, int argc, t_atom *argv)
33
freebytes(x->m_avg,x->m_n);
34
x->m_avg=(float*)getbytes(argc*sizeof(float));
41
ap = (t_atom *)getbytes(sizeof(t_atom)*argc);
43
for (i = 0; i < argc; i++)
45
float f=atom_getfloat(argv++);
46
*fp = *fp * m_c_leak + f * m_leak;
51
outlet_list(x->x_obj.ob_outlet,gensym("list"),argc,ap);
55
static void vlavg_setHalfDecay(t_vlavg *x, t_floatarg halfDecayTime)
57
x->m_c_leak=(float)powf(.5,(1.0f/halfDecayTime));
58
x->m_leak=1.0f-x->m_c_leak;
61
static void *vlavg_new(t_float halfDecayTime)
63
t_vlavg *x=(t_vlavg *)pd_new(vlavg_class);
64
outlet_new(&x->x_obj, gensym("list"));
65
vlavg_setHalfDecay(x, halfDecayTime);
71
static void vlavg_free(t_vlavg *x)
73
freebytes(x->m_avg,x->m_n);
76
void vlavg_setup(void)
78
vlavg_class = class_new(gensym("vlavg"),
79
(t_newmethod)vlavg_new, (t_method)vlavg_free,
83
class_addmethod(vlavg_class, (t_method)vlavg_setHalfDecay,
84
gensym("decay"), A_DEFFLOAT, NULL);
85
class_addlist(vlavg_class, (t_method)vlavg_perform);