forked from len0rd/rockbox
		
	git-svn-id: svn://svn.rockbox.org/rockbox/trunk@21626 a1c6a512-1295-4272-9138-f99709370657
		
			
				
	
	
		
			94 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <m_pd.h>
 | |
| #include <m_fixed.h>
 | |
| 
 | |
| typedef struct lopctl
 | |
| {
 | |
|     t_sample c_x;
 | |
|     t_sample c_coef;
 | |
| } t_lopctl;
 | |
| 
 | |
| typedef struct siglop
 | |
| {
 | |
|     t_object x_obj;
 | |
|     float x_sr;
 | |
|     float x_hz;
 | |
|     t_lopctl x_cspace;
 | |
|     t_lopctl *x_ctl;
 | |
|     float x_f;
 | |
| } t_siglop;
 | |
| 
 | |
| t_class *siglop_class;
 | |
| 
 | |
| static void siglop_ft1(t_siglop *x, t_floatarg f);
 | |
| 
 | |
| static void *siglop_new(t_floatarg f)
 | |
| {
 | |
|     t_siglop *x = (t_siglop *)pd_new(siglop_class);
 | |
|     inlet_new(&x->x_obj, &x->x_obj.ob_pd, gensym("float"), gensym("ft1"));
 | |
|     outlet_new(&x->x_obj, gensym("signal"));
 | |
|     x->x_sr = 44100;
 | |
|     x->x_ctl = &x->x_cspace;
 | |
|     x->x_cspace.c_x = 0;
 | |
|     siglop_ft1(x, f);
 | |
|     x->x_f = 0;
 | |
|     return (x);
 | |
| }
 | |
| 
 | |
| static void siglop_ft1(t_siglop *x, t_floatarg f)
 | |
| {
 | |
|      t_float coeff;
 | |
|     if (f < 0.001) f = 10;
 | |
|     x->x_hz = f;
 | |
|     coeff = f * (2 * 3.14159) / x->x_sr;
 | |
|     if (coeff > 1) coeff = 1;
 | |
|     x->x_ctl->c_coef = ftofix(coeff);
 | |
| }
 | |
| 
 | |
| static void siglop_clear(t_siglop *x, t_floatarg q)
 | |
| {
 | |
| #ifdef ROCKBOX
 | |
|     (void) q;
 | |
| #endif
 | |
|     x->x_cspace.c_x = 0;
 | |
| }
 | |
| 
 | |
| 
 | |
| static t_int *siglop_perform(t_int *w)
 | |
| {
 | |
|     t_sample *in = (t_sample *)(w[1]);
 | |
|     t_sample *out = (t_sample *)(w[2]);
 | |
|     t_lopctl *c = (t_lopctl *)(w[3]);
 | |
|     int n = (t_int)(w[4]);
 | |
|     int i;
 | |
|     t_sample last = c->c_x;
 | |
|     t_sample coef = c->c_coef;
 | |
|     t_sample feedback = ftofix(1) - coef;
 | |
|     for (i = 0; i < n; i++)
 | |
| 	last = *out++ = mult(coef, *in++) + mult(feedback,last);
 | |
|     if (PD_BADFLOAT(last))
 | |
|     	last = 0;
 | |
|     c->c_x = last;
 | |
|     return (w+5);
 | |
| }
 | |
| 
 | |
| static void siglop_dsp(t_siglop *x, t_signal **sp)
 | |
| {
 | |
|     x->x_sr = sp[0]->s_sr;
 | |
|     siglop_ft1(x,  x->x_hz);
 | |
|     dsp_add(siglop_perform, 4,
 | |
| 	sp[0]->s_vec, sp[1]->s_vec, 
 | |
| 	    x->x_ctl, sp[0]->s_n);
 | |
| 
 | |
| }
 | |
| 
 | |
| void lop_tilde_setup(void)
 | |
| {
 | |
|     siglop_class = class_new(gensym("lop~"), (t_newmethod)siglop_new, 0,
 | |
| 	sizeof(t_siglop), 0, A_DEFFLOAT, 0);
 | |
|     CLASS_MAINSIGNALIN(siglop_class, t_siglop, x_f);
 | |
|     class_addmethod(siglop_class, (t_method)siglop_dsp, gensym("dsp"), 0);
 | |
|     class_addmethod(siglop_class, (t_method)siglop_ft1,
 | |
|     	gensym("ft1"), A_FLOAT, 0);
 | |
|     class_addmethod(siglop_class, (t_method)siglop_clear, gensym("clear"), 0);
 | |
| }
 | |
| 
 |