aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/iemmatrix_sources.c1
-rw-r--r--src/iemmatrix_sources.h1
-rw-r--r--src/mtx_sh_new.c186
3 files changed, 2 insertions, 186 deletions
diff --git a/src/iemmatrix_sources.c b/src/iemmatrix_sources.c
index a649643..d9e1b87 100644
--- a/src/iemmatrix_sources.c
+++ b/src/iemmatrix_sources.c
@@ -34,6 +34,7 @@ void iemmatrix_sources_setup(void)
iemtx_dispersive_dline_setup(); /* mtx_dispersive_dline.c */
iemtx_distance2_setup(); /* mtx_distance2.c */
iemtx_egg_setup(); /* mtx_egg.c */
+ iemtx_eig_setup(); /* mtx_eig.c */
iemtx_element_setup(); /* mtx_element.c */
iemtx_eq_setup(); /* mtx_eq.c */
iemtx_exp_setup(); /* mtx_exp.c */
diff --git a/src/iemmatrix_sources.h b/src/iemmatrix_sources.h
index f79babc..194cc21 100644
--- a/src/iemmatrix_sources.h
+++ b/src/iemmatrix_sources.h
@@ -32,6 +32,7 @@ void iemtx_diff_setup(void); /* mtx_diff.c */
void iemtx_dispersive_dline_setup(void); /* mtx_dispersive_dline.c */
void iemtx_distance2_setup(void); /* mtx_distance2.c */
void iemtx_egg_setup(void); /* mtx_egg.c */
+void iemtx_eig_setup(void); /* mtx_eig.c */
void iemtx_element_setup(void); /* mtx_element.c */
void iemtx_eq_setup(void); /* mtx_eq.c */
void iemtx_exp_setup(void); /* mtx_exp.c */
diff --git a/src/mtx_sh_new.c b/src/mtx_sh_new.c
deleted file mode 100644
index c046a73..0000000
--- a/src/mtx_sh_new.c
+++ /dev/null
@@ -1,186 +0,0 @@
-/*
- * iemmatrix
- *
- * objects for manipulating simple matrices
- * mostly refering to matlab/octave matrix functions
- * this functions depends on the GNU scientific library
- *
- * Copyright (c) 2009, Franz Zotter
- * IEM, Graz, Austria
- *
- * For information on usage and redistribution, and for a DISCLAIMER OF ALL
- * WARRANTIES, see the file, "LICENSE.txt," in this distribution.
- *
- */
-
-#include "iemmatrix.h"
-#include <stdlib.h>
-
-#ifdef HAVE_LIBGSL
-#include <gsl/gsl_linalg.h>
-#endif
-
-static t_class *mtx_svd_class;
-
-typedef struct _MTXSvd_ MTXSvd;
-struct _MTXSvd_
-{
- t_object x_obj;
-#ifdef HAVE_LIBGSL
- gsl_matrix *u;
- gsl_vector *s;
- gsl_matrix *v;
- gsl_vector *w;
-#endif
- t_outlet *list_u_out;
- t_outlet *list_s_out;
- t_outlet *list_v_out;
- t_atom *list_u;
- t_atom *list_s;
- t_atom *list_v;
- int rows;
- int columns;
-};
-
-#ifdef HAVE_LIBGSL
-static void allocMTXusvw (MTXSvd *x)
-{
- x->u=(gsl_matrix*)gsl_matrix_alloc(x->rows,x->columns);
- x->s=(gsl_vector*)gsl_vector_alloc(x->columns);
- x->v=(gsl_matrix*)gsl_matrix_alloc(x->columns,x->columns);
- x->w=(gsl_vector*)gsl_vector_alloc(x->columns);
-
- x->list_u=(t_atom*)calloc(sizeof(t_atom),x->rows*x->columns+2);
- x->list_s=(t_atom*)calloc(sizeof(t_atom),x->columns);
- x->list_v=(t_atom*)calloc(sizeof(t_atom),x->columns*x->columns+2);
-}
-
-static void deleteMTXusvw (MTXSvd *x)
-{
- if (x->list_u!=0)
- free(x->list_u);
- if (x->list_s!=0)
- free(x->list_s);
- if (x->list_v!=0)
- free(x->list_v);
-
- x->list_u = x->list_s = x->list_v = 0;
-
- if (x->u!=0)
- gsl_matrix_free(x->u);
- if (x->s!=0)
- gsl_vector_free(x->s);
- if (x->v!=0)
- gsl_matrix_free(x->v);
- if (x->w!=0)
- gsl_vector_free(x->w);
-
- x->u = 0;
- x->s = 0;
- x->v = 0;
- x->w = 0;
-}
-#endif
-
-static void deleteMTXSvd (MTXSvd *x)
-{
-#ifdef HAVE_LIBGSL
- deleteMTXSvd(x);
-#endif
-}
-
-static void *newMTXSvd (t_symbol *s, int argc, t_atom *argv)
-{
- MTXSvd *x = (MTXSvd *) pd_new (mtx_svd_class);
- x->list_u_out = outlet_new (&x->x_obj, gensym("matrix"));
- x->list_s_out = outlet_new (&x->x_obj, gensym("list"));
- x->list_v_out = outlet_new (&x->x_obj, gensym("matrix"));
- x->list_u = 0;
- x->list_s = 0;
- x->list_v = 0;
-#ifdef HAVE_LIBGSL
- x->u=0;
- x->s=0;
- x->v=0;
- x->w=0;
-#endif
-
- return ((void *) x);
-}
-
-static void mTXSvdBang (MTXSvd *x)
-{
- if (x->list_u) {
- outlet_anything(x->list_v_out, gensym("matrix"), x->columns*x->columns+2, x->list_v);
- outlet_anything(x->list_s_out, gensym("list"), x->columns, x->list_s);
- outlet_anything(x->list_u_out, gensym("matrix"), x->rows*x->columns+2, x->list_u);
- }
-}
-
-static void mTXSvdMatrix (MTXSvd *x, t_symbol *s,
- int argc, t_atom *argv)
-{
- int rows = atom_getint (argv++);
- int columns = atom_getint (argv++);
- int size = rows * columns;
- int in_size = argc-2;
- int n;
-
-
-#ifdef HAVE_LIBGSL
- /* size check */
- if (!size)
- post("mtx_svd: invalid dimensions");
- else if (in_size<size)
- post("mtx_svd: sparse matrix not yet supported: use \"mtx_check\"");
- else if (rows<columns)
- post("mtx_svd: gsl_linalg_SVD_decomp does not support M<N");
- else {
- x->rows=rows;
- x->columns=columns;
-
- deleteMTXusvw(x);
- allocMTXusvw(x);
-
- for (n=0;n<in_size;n++)
- x->u->data[n]=(double) atom_getfloat(argv++);
-
- gsl_linalg_SV_decomp(x->u,x->v,x->s,x->w);
-
- SETFLOAT((x->list_u),(float) x->rows);
- SETFLOAT((x->list_u+1),(float) x->columns);
- for (n=0;n<in_size;n++)
- SETFLOAT((x->list_u+2+n), (float) x->u->data[n]);
-
- for (n=0;n<x->columns;n++)
- SETFLOAT((x->list_s+n),(float) x->s->data[n]);
-
- SETFLOAT((x->list_v),(float) x->columns);
- SETFLOAT((x->list_v+1),(float) x->columns);
- in_size=x->columns*x->columns;
- for (n=0;n<in_size;n++)
- SETFLOAT((x->list_v+n+2), (float) x->v->data[n]);
-
- mTXSvdBang(x);
- }
-#else
- post("mtx_svd: implementation requires gsl");
-#endif
-
-}
-
-void mtx_svd_setup (void)
-{
- mtx_svd_class = class_new
- (gensym("mtx_svd"),
- (t_newmethod) newMTXSvd,
- (t_method) deleteMTXSvd,
- sizeof (MTXSvd),
- CLASS_DEFAULT, A_GIMME, 0);
- class_addbang (mtx_svd_class, (t_method) mTXSvdBang);
- class_addmethod (mtx_svd_class, (t_method) mTXSvdMatrix, gensym("matrix"), A_GIMME,0);
-}
-
-void iemtx_svd_setup(void){
- mtx_svd_setup();
-}