1
/******************************************************
3
* zexy - implementation file
5
* copyleft (c) IOhannes m zm�lnig
7
* 1999:forum::f�r::uml�ute:2004
9
* institute of electronic music and acoustics (iem)
11
******************************************************
13
* license: GNU General Public License v.2
15
******************************************************/
18
finally :: some of the missing binops for signals :: >~
20
1302:forum::f�r::uml�ute:2000
25
/* ------------------------ relational~ ----------------------------- */
27
/* ----------------------------- gt_tilde ----------------------------- */
28
static t_class *gt_tilde_class, *scalargt_tilde_class;
30
typedef struct _gt_tilde
36
typedef struct _scalargt_tilde
40
t_float x_g; /* inlet value */
43
static void *gt_tilde_new(t_symbol *s, int argc, t_atom *argv)
46
if (argc > 1) post(">~: extra arguments ignored");
49
t_scalargt_tilde *x = (t_scalargt_tilde *)pd_new(scalargt_tilde_class);
50
floatinlet_new(&x->x_obj, &x->x_g);
51
x->x_g = atom_getfloatarg(0, argc, argv);
52
outlet_new(&x->x_obj, &s_signal);
58
t_gt_tilde *x = (t_gt_tilde *)pd_new(gt_tilde_class);
59
inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_signal, &s_signal);
60
outlet_new(&x->x_obj, &s_signal);
66
static t_int *gt_tilde_perform(t_int *w)
68
t_sample *in1 = (t_sample *)(w[1]);
69
t_sample *in2 = (t_sample *)(w[2]);
70
t_sample *out = (t_sample *)(w[3]);
72
while (n--) *out++ = *in1++ > *in2++;
76
static t_int *gt_tilde_perf8(t_int *w)
78
t_sample *in1 = (t_sample *)(w[1]);
79
t_sample *in2 = (t_sample *)(w[2]);
80
t_sample *out = (t_sample *)(w[3]);
82
for (; n; n -= 8, in1 += 8, in2 += 8, out += 8)
84
t_sample f0 = in1[0], f1 = in1[1], f2 = in1[2], f3 = in1[3];
85
t_sample f4 = in1[4], f5 = in1[5], f6 = in1[6], f7 = in1[7];
87
t_sample g0 = in2[0], g1 = in2[1], g2 = in2[2], g3 = in2[3];
88
t_sample g4 = in2[4], g5 = in2[5], g6 = in2[6], g7 = in2[7];
90
out[0] = f0 > g0; out[1] = f1 > g1; out[2] = f2 > g2; out[3] = f3 > g3;
91
out[4] = f4 > g4; out[5] = f5 > g5; out[6] = f6 > g6; out[7] = f7 > g7;
96
static t_int *scalargt_tilde_perform(t_int *w)
98
t_sample *in = (t_sample *)(w[1]);
99
t_sample f = *(t_float *)(w[2]);
100
t_sample *out = (t_sample *)(w[3]);
102
while (n--) *out++ = *in++ > f;
106
static t_int *scalargt_tilde_perf8(t_int *w)
108
t_sample *in = (t_sample *)(w[1]);
109
t_sample g = *(t_float *)(w[2]);
110
t_sample *out = (t_sample *)(w[3]);
112
for (; n; n -= 8, in += 8, out += 8)
114
t_sample f0 = in[0], f1 = in[1], f2 = in[2], f3 = in[3];
115
t_sample f4 = in[4], f5 = in[5], f6 = in[6], f7 = in[7];
117
out[0] = f0 > g; out[1] = f1 > g; out[2] = f2 > g; out[3] = f3 > g;
118
out[4] = f4 > g; out[5] = f5 > g; out[6] = f6 > g; out[7] = f7 > g;
123
static t_int *gt_tilde_performSSE(t_int *w)
125
__m128 *in1 = (__m128 *)(w[1]);
126
__m128 *in2 = (__m128 *)(w[2]);
127
__m128 *out = (__m128 *)(w[3]);
128
int n = (int)(w[4])>>4;
129
const __m128 one = _mm_set1_ps(1.f);
133
xmm0 = _mm_cmpgt_ps(in1[0], in2[0]);
134
out[0] = _mm_and_ps (xmm0 , one);
136
xmm1 = _mm_cmpgt_ps(in1[1], in2[1]);
137
out[1] = _mm_and_ps (xmm1 , one);
139
xmm0 = _mm_cmpgt_ps(in1[2], in2[2]);
140
out[2] = _mm_and_ps (xmm0 , one);
142
xmm1 = _mm_cmpgt_ps(in1[3], in2[3]);
143
out[3] = _mm_and_ps (xmm1 , one);
152
static t_int *scalargt_tilde_performSSE(t_int *w)
154
__m128 *in = (__m128 *)(w[1]);
155
__m128 *out = (__m128 *)(w[3]);
156
float f = *(t_float *)(w[2]);
157
__m128 scalar = _mm_set1_ps(f);
158
int n = (int)(w[4])>>4;
159
const __m128 one = _mm_set1_ps(1.f);
163
xmm0 = _mm_cmpgt_ps (in[0], scalar);
164
out[0] = _mm_and_ps (xmm0, one);
166
xmm1 = _mm_cmpgt_ps (in[1], scalar);
167
out[1] = _mm_and_ps (xmm1, one);
169
xmm0 = _mm_cmpgt_ps (in[2], scalar);
170
out[2] = _mm_and_ps (xmm0, one);
172
xmm1 = _mm_cmpgt_ps (in[3], scalar);
173
out[3] = _mm_and_ps (xmm1, one);
183
static void gt_tilde_dsp(t_gt_tilde *x, t_signal **sp)
185
t_sample*in1=sp[0]->s_vec;
186
t_sample*in2=sp[1]->s_vec;
187
t_sample*out=sp[2]->s_vec;
195
Z_SIMD_CHKBLOCKSIZE(n)&&
196
Z_SIMD_CHKALIGN(in1)&&
197
Z_SIMD_CHKALIGN(in2)&&
198
Z_SIMD_CHKALIGN(out)&&
199
ZEXY_TYPE_EQUAL(t_sample, float)
202
dsp_add(gt_tilde_performSSE, 4, in1, in2, out, n);
206
dsp_add(gt_tilde_perform, 4, in1, in2, out, n);
208
dsp_add(gt_tilde_perf8, 4, in1, in2, out, n);
211
static void scalargt_tilde_dsp(t_scalargt_tilde *x, t_signal **sp)
213
t_sample*in =sp[0]->s_vec;
214
t_sample*out=sp[1]->s_vec;
219
Z_SIMD_CHKBLOCKSIZE(n)&&
220
Z_SIMD_CHKALIGN(in)&&
221
Z_SIMD_CHKALIGN(out)&&
222
ZEXY_TYPE_EQUAL(t_sample, float)
225
dsp_add(scalargt_tilde_performSSE, 4, in, &x->x_g, out, n);
229
dsp_add(scalargt_tilde_perform, 4, in, &x->x_g, out, n);
231
dsp_add(scalargt_tilde_perf8, 4, in, &x->x_g, out, n);
234
static void gt_tilde_help(t_object*x)
236
post("\n%c >~\t\t:: compare 2 signals", HEARTSYMBOL);
239
void setup_0x3e0x7e(void)
241
gt_tilde_class = class_new(gensym(">~"), (t_newmethod)gt_tilde_new, 0,
242
sizeof(t_gt_tilde), 0, A_GIMME, 0);
243
class_addmethod(gt_tilde_class, (t_method)gt_tilde_dsp, gensym("dsp"), 0);
244
CLASS_MAINSIGNALIN(gt_tilde_class, t_gt_tilde, x_f);
245
class_addmethod (gt_tilde_class, (t_method)gt_tilde_help, gensym("help"), A_NULL);
246
class_sethelpsymbol(gt_tilde_class, gensym("zigbinops"));
248
scalargt_tilde_class = class_new(gensym(">~"), 0, 0,
249
sizeof(t_scalargt_tilde), 0, 0);
250
CLASS_MAINSIGNALIN(scalargt_tilde_class, t_scalargt_tilde, x_f);
251
class_addmethod(scalargt_tilde_class, (t_method)scalargt_tilde_dsp, gensym("dsp"),
253
class_addmethod (scalargt_tilde_class, (t_method)gt_tilde_help, gensym("help"), A_NULL);
254
class_sethelpsymbol(scalargt_tilde_class, gensym("zigbinops"));