/* For information on usage and redistribution, and for a DISCLAIMER OF ALL * WARRANTIES, see the file, "LICENSE.txt," in this distribution. iem_matrix written by Thomas Musil, Copyright (c) IEM KUG Graz Austria 2000 - 2007 */ #include "m_pd.h" #include "iemlib.h" /* ---------- matrix_diag_mul_stat~ - signal matrix multiplication object with message matrix-coeff. ----------- */ typedef struct matrix_diag_mul_stat_tilde { t_object x_obj; t_float *x_matbuf; t_float **x_io; t_float *x_buf; int x_bufsize; int x_n_io; t_float x_msi; } t_matrix_diag_mul_stat_tilde; t_class *matrix_diag_mul_stat_tilde_class; static void matrix_diag_mul_stat_tilde_list(t_matrix_diag_mul_stat_tilde *x, t_symbol *s, int argc, t_atom *argv) { int i, n=x->x_n_io; t_float *matrix = x->x_matbuf; if(argc < n) { post("matrix_diag_mul_stat~ : dimensions do not match !!"); return; } for(i=0; ix_n_io; t_float *matrix = x->x_matbuf; if(argc == 2) { i = (int)(atom_getint(argv)); argv++; if((i >= 1) && (i <= n)) matrix[i-1] = atom_getfloat(argv); } else if(argc == 3) { i = (int)(atom_getint(argv)); argv++; j = (int)(atom_getint(argv)); argv++; if((i >= 1) && (i <= n) && (i == j)) matrix[i-1] = atom_getfloat(argv); } } /* the dsp thing */ static t_int *matrix_diag_mul_stat_tilde_perform(t_int *w) { t_matrix_diag_mul_stat_tilde *x = (t_matrix_diag_mul_stat_tilde *)(w[1]); int n = (int)(w[2]); t_float **io = x->x_io; t_float *buf = x->x_buf; t_float *mat = x->x_matbuf; int n_io = x->x_n_io; t_float *in, *out, mul; int i, j; for(j=0; jx_buf; for(j=0; jx_io; t_float *buf = x->x_buf; t_float *mat = x->x_matbuf; int n_io = x->x_n_io; t_float *in, *out, mul; int i, j; for(j=0; jx_buf; for(j=0; js_n; int bufsize = sp[0]->s_n*x->x_n_io; if(!x->x_buf) { x->x_bufsize = bufsize; x->x_buf = (t_float *)getbytes(x->x_bufsize * sizeof(t_float)); } else if(x->x_bufsize != bufsize) { x->x_buf = (t_float *)resizebytes(x->x_buf, x->x_bufsize*sizeof(t_float), bufsize*sizeof(t_float)); x->x_bufsize = bufsize; } n = 2 * x->x_n_io; for(i=0; ix_io[i] = sp[i]->s_vec; // post("iovec_addr = %d", (unsigned int)x->x_io[i]); } n = sp[0]->s_n; if(n&7) dsp_add(matrix_diag_mul_stat_tilde_perform, 2, x, n); else dsp_add(matrix_diag_mul_stat_tilde_perf8, 2, x, n); } /* setup/setdown things */ static void matrix_diag_mul_stat_tilde_free(t_matrix_diag_mul_stat_tilde *x) { freebytes(x->x_matbuf, x->x_n_io * sizeof(t_float)); freebytes(x->x_io, 2 * x->x_n_io * sizeof(t_float *)); if(x->x_buf) freebytes(x->x_buf, x->x_bufsize * sizeof(t_float)); } static void *matrix_diag_mul_stat_tilde_new(t_symbol *s, int argc, t_atom *argv) { t_matrix_diag_mul_stat_tilde *x = (t_matrix_diag_mul_stat_tilde *)pd_new(matrix_diag_mul_stat_tilde_class); int i; switch (argc) { case 0: x->x_n_io = 1; break; default: x->x_n_io = (int)atom_getint(argv); break; } if(x->x_n_io < 1) x->x_n_io = 1; i = x->x_n_io - 1; while(i--) inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_signal, &s_signal); i = x->x_n_io; while(i--) outlet_new(&x->x_obj, &s_signal); x->x_msi = 0; x->x_buf = (t_float *)0; x->x_bufsize = 0; x->x_matbuf = (t_float *)getbytes(x->x_n_io * sizeof(t_float)); i = x->x_n_io; while(i--) x->x_matbuf[i] = 0.0f; x->x_io = (t_float **)getbytes(2 * x->x_n_io * sizeof(t_float *)); return(x); } void matrix_diag_mul_stat_tilde_setup(void) { matrix_diag_mul_stat_tilde_class = class_new(gensym("matrix_diag_mul_stat~"), (t_newmethod)matrix_diag_mul_stat_tilde_new, (t_method)matrix_diag_mul_stat_tilde_free, sizeof(t_matrix_diag_mul_stat_tilde), 0, A_GIMME, 0); CLASS_MAINSIGNALIN(matrix_diag_mul_stat_tilde_class, t_matrix_diag_mul_stat_tilde, x_msi); class_addmethod(matrix_diag_mul_stat_tilde_class, (t_method)matrix_diag_mul_stat_tilde_dsp, gensym("dsp"), 0); class_addmethod(matrix_diag_mul_stat_tilde_class, (t_method)matrix_diag_mul_stat_tilde_diag, gensym("diag"), A_GIMME, 0); class_addmethod(matrix_diag_mul_stat_tilde_class, (t_method)matrix_diag_mul_stat_tilde_element, gensym("element"), A_GIMME, 0); class_addlist(matrix_diag_mul_stat_tilde_class, (t_method)matrix_diag_mul_stat_tilde_list); // class_sethelpsymbol(matrix_diag_mul_stat_tilde_class, gensym("iemhelp2/matrix_diag_mul_stat~-help")); }