aboutsummaryrefslogtreecommitdiff
path: root/control/inv.c
blob: 0cff552a1201cec4eb19b0035c91433a27941bc4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/* (C) Guenter Geiger <geiger@epy.co.at> */

#include <m_pd.h>


typedef struct inv
{
    t_object x_obj;
} t_inv;

static t_class *inv_class;

static void *inv_new(void)
{
    t_inv *x = (t_inv *)pd_new(inv_class);
    outlet_new(&x->x_obj, gensym("signal"));
    return (x);
}

static t_int *inv_perform(t_int *w)    /* not static; also used in d_fft.c */
{
    float *in = *(t_float **)(w+1), *out = *(t_float **)(w+2);
    t_int n = *(t_int *)(w+3);
    while (n--)
    {	
	*out++ = 1/ *in++;
    }
    return (w + 4);
}

static void inv_dsp(t_inv *x, t_signal **sp)
{
    dsp_add(inv_perform, 3, sp[0]->s_vec, sp[1]->s_vec, sp[0]->s_n);
}

void inv_tilde_setup(void)
{
    inv_class = class_new(gensym("inv~"), (t_newmethod)inv_new, 0,
    	sizeof(t_inv), 0, 0);

    class_addcreator(inv_new,gensym("1/x~"),0);
    
    class_addmethod(inv_class, nullfn, gensym("signal"), 0);
    class_addmethod(inv_class, (t_method)inv_dsp, gensym("dsp"), 0);
}




typedef struct scalarinv
{
    t_object x_obj;
} t_scalarinv;

static t_class *scalarinv_class;

static void *scalarinv_new(void)
{
    t_scalarinv *x = (t_scalarinv *)pd_new(scalarinv_class);
    outlet_new(&x->x_obj, gensym("float"));
    return (x);
}

static void scalarinv_float(t_scalarinv *x,t_float val)
{
     outlet_float(x->x_obj.ob_outlet,1.0f/val);
     
}

void inv_setup(void)
{
    scalarinv_class = class_new(gensym("inv"), (t_newmethod)scalarinv_new, 0,
    	sizeof(t_scalarinv), 0, 0);
    class_addcreator(scalarinv_new,gensym("1/x"),0);

    class_addfloat(scalarinv_class, (t_method)scalarinv_float);
}