aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFranz Zotter <fzotter@users.sourceforge.net>2011-01-22 21:10:28 +0000
committerFranz Zotter <fzotter@users.sourceforge.net>2011-01-22 21:10:28 +0000
commit013f72915b3ae34bf83af73c4a55fb51545a80fe (patch)
tree60cbb324748b3f4f9b8cc37d99baddf22b79d99c
parent6c5d8416eeda3df922accbe5c8a9419a31575edb (diff)
[mtx_bessel] added, using math.h bessel functions Jn,Yn for integer n
svn path=/trunk/externals/iem/iemmatrix/; revision=14774
-rw-r--r--doc/mtx_bessel-help.pd233
-rw-r--r--src/iemmatrix_sources.c1
-rw-r--r--src/iemmatrix_sources.h1
-rw-r--r--src/mtx_bessel.c186
4 files changed, 421 insertions, 0 deletions
diff --git a/doc/mtx_bessel-help.pd b/doc/mtx_bessel-help.pd
new file mode 100644
index 0000000..2fe48e3
--- /dev/null
+++ b/doc/mtx_bessel-help.pd
@@ -0,0 +1,233 @@
+#N canvas 259 0 1021 852 10;
+#N canvas 0 0 450 300 (subpatch) 0;
+#X array j0 100 float 1;
+#A 0 0.997502 0.97014 0.913773 0.830957 0.725435 0.601943 0.465978
+0.323516 0.180722 0.0436431 -0.0820875 -0.191518 -0.28061 -0.346423
+-0.387235 -0.402599 -0.393338 -0.361468 -0.310062 -0.243063 -0.165057
+-0.0810107 0.0039997 0.0850601 0.157677 0.218004 0.263034 0.29073 0.300115
+0.291286 0.265378 0.224473 0.171447 0.109792 0.0433946 -0.0236951 -0.0874986
+-0.144338 -0.191038 -0.225099 -0.244825 -0.249399 -0.238918 -0.214359
+-0.177505 -0.130826 -0.0773149 -0.0203052 0.0367329 0.0903996 0.137563
+0.175537 0.202236 0.21628 0.217067 0.204793 0.180429 0.145645 0.102705
+0.0543173 0.00347017 -0.0467506 -0.0933476 -0.133587 -0.165158 -0.186302
+-0.195911 -0.193583 -0.179634 -0.155072 -0.121522 -0.0811275 -0.0364084
+0.00989075 0.0549676 0.0961309 0.13096 0.157444 0.174101 0.180053 0.175079
+0.159613 0.134714 0.101994 0.0635146 0.0216587 -0.021016 -0.0619319
+-0.0986478 -0.129001 -0.151236 -0.164104 -0.166933 -0.159661 -0.142834
+-0.117567 -0.0854704 -0.0485473 -0.00907192 0.0305518;
+#X coords 0 1 99 -1 200 140 1;
+#X restore 69 219 graph;
+#N canvas 0 0 450 300 (subpatch) 0;
+#X array y0 100 float 1;
+#A 0 -1.53424 -0.706535 -0.316354 -0.0479056 0.153451 0.305045 0.413856
+0.483524 0.516846 0.516798 0.486968 0.431677 0.355938 0.265312 0.16569
+0.0630412 -0.036854 -0.128667 -0.207761 -0.270399 -0.313897 -0.336727
+-0.338555 -0.320213 -0.283621 -0.23164 -0.167886 -0.0965075 -0.0219386
+0.0513577 0.11914 0.177618 0.223658 0.254939 0.270062 0.268605 0.251123
+0.219089 0.174787 0.121159 0.0616173 -0.00015986 -0.0604533 -0.115717
+-0.162784 -0.199038 -0.222562 -0.232229 -0.227755 -0.2097 -0.179415
+-0.13895 -0.0909182 -0.0383317 0.0155827 0.0675785 0.114582 0.153871
+0.183229 0.201069 0.206518 0.199455 0.180506 0.150997 0.112863 0.0685233
+0.0207323 -0.0275922 -0.0735441 -0.114401 -0.147784 -0.171796 -0.185126
+-0.187123 -0.17782 -0.157927 -0.128781 -0.0922546 -0.0506369 -0.00649494
+0.0374861 0.0786639 0.114597 0.143188 0.162805 0.172375 0.171439 0.160176
+0.139381 0.110414 0.0751093 0.0356625 -0.00550591 -0.0458994 -0.0830937
+-0.114883 -0.139409 -0.15527 -0.161599 -0.158113;
+#X coords 0 1 99 -1 200 140 1;
+#X restore 273 218 graph;
+#N canvas 0 0 450 300 (subpatch) 0;
+#X array j1 100 float 1;
+#A 0 0.0499375 0.170855 0.284007 0.384293 0.467263 0.529337 0.567981
+0.581831 0.57075 0.535821 0.479285 0.404403 0.315285 0.216661 0.113629
+0.0113882 -0.0850341 -0.17104 -0.242693 -0.296908 -0.331599 -0.345764
+-0.339517 -0.314054 -0.27156 -0.215075 -0.148301 -0.0753895 -0.000698991
+0.0714468 0.136998 0.192396 0.23476 0.26203 0.273066 0.267685 0.246652
+0.211613 0.16498 0.109778 0.0494529 -0.0123297 -0.0719058 -0.125822
+-0.171029 -0.205057 -0.226139 -0.233304 -0.226418 -0.206175 -0.174041
+-0.132152 -0.0831818 -0.0301694 0.0236621 0.0750988 0.121125 0.159097
+0.186895 0.203035 0.20675 0.198023 0.177574 0.146811 0.10773 0.0627931
+0.0147728 -0.0334153 -0.0788895 -0.11897 -0.151337 -0.174164 -0.186216
+-0.186921 -0.17639 -0.155404 -0.125358 -0.0881697 -0.04616 -0.00190804
+0.0419047 0.0826564 0.11794 0.145705 0.164375 0.172936 0.170994 0.158785
+0.137159 0.107522 0.071742 0.0320373 -0.00916389 -0.0493701 -0.0861753
+-0.117403 -0.141234 -0.156312 -0.16182 -0.157524;
+#X coords 0 1 99 -1 200 140 1;
+#X restore 69 379 graph;
+#N canvas 0 0 450 300 (subpatch) 0;
+#X array y1 100 float 1;
+#A 0 -6.45895 -2.01607 -1.2716 -0.933446 -0.70804 -0.524255 -0.359463
+-0.206701 -0.0652003 0.0631702 0.175545 0.268943 0.3408 0.389308 0.41362
+0.413955 0.391621 0.348954 0.289206 0.216367 0.134951 0.0497571 -0.0343875
+-0.112881 -0.181583 -0.237028 -0.276587 -0.298594 -0.302412 -0.288437
+-0.25805 -0.21352 -0.15785 -0.0945889 -0.0276251 0.0390485 0.101559
+0.156374 0.200491 0.231602 0.248208 0.249686 0.236306 0.209202 0.170279
+0.122094 0.0676932 0.0104206 -0.0462769 -0.0990562 -0.14487 -0.181138
+-0.205894 -0.217885 -0.216636 -0.202462 -0.176436 -0.140314 -0.0964208
+-0.0475021 0.0034438 0.0533467 0.0992479 0.138472 0.168784 0.18851
+0.196633 0.192841 0.177537 0.151802 0.117325 0.0762916 0.0312488 -0.0150529
+-0.059824 -0.100404 -0.134416 -0.15991 -0.175465 -0.180277 -0.174191
+-0.157707 -0.13194 -0.0985494 -0.0596289 -0.0175798 0.0250376 0.0656576
+0.101865 0.131534 0.152955 0.164934 0.166852 0.158704 0.141085 0.115156
+0.082562 0.045331 0.00574966 -0.0337779;
+#X coords 0 1 99 -1 200 140 1;
+#X restore 273 378 graph;
+#N canvas 0 0 450 300 (subpatch) 0;
+#X array j2 100 float 1;
+#A 0 0.00124896 0.0148923 0.0427945 0.0832583 0.133814 0.191362 0.252344
+0.312952 0.369341 0.417851 0.455214 0.478744 0.486488 0.477347 0.451132
+0.408587 0.351351 0.281865 0.203248 0.119123 0.0334192 -0.0498381 -0.12675
+-0.193753 -0.247811 -0.286581 -0.308529 -0.313014 -0.300314 -0.271604
+-0.22888 -0.174848 -0.112764 -0.0462525 0.0208965 0.0849392 0.14238
+0.190164 0.225836 0.247666 0.254739 0.246987 0.225182 0.190878 0.146306
+0.0942431 0.0378405 -0.0195609 -0.0746231 -0.124204 -0.165532 -0.196362
+-0.215094 -0.220856 -0.213544 -0.193813 -0.163034 -0.123195 -0.0767841
+-0.0266317 0.0242552 0.0728732 0.116397 0.152343 0.178707 0.194079
+0.197713 0.189567 0.170292 0.141187 0.10411 0.0613699 0.0155753 -0.0305178
+-0.0741709 -0.112825 -0.14425 -0.166671 -0.17887 -0.180248 -0.170857
+-0.151388 -0.123121 -0.0878431 -0.0477395 -0.00525628 0.0370464 0.0766475
+0.111215 0.138743 0.157664 0.166943 0.16613 0.155379 0.13544 0.107599
+0.0736033 0.0355481 -0.00424858 -0.0433882;
+#X coords 0 1 99 -1 200 140 1;
+#X restore 69 549 graph;
+#N canvas 0 0 450 300 (subpatch) 0;
+#X array y2 100 float 1;
+#A 0 -127.645 -10.9168 -3.96653 -2.17272 -1.45546 -1.09073 -0.868466
+-0.709635 -0.579683 -0.462391 -0.350305 -0.240661 -0.133398 -0.0300613
+0.0669008 0.154628 0.230226 0.291072 0.335046 0.360719 0.36747 0.355557
+0.326122 0.281146 0.223351 0.156064 0.0830362 0.00824897 -0.0643015
+-0.130815 -0.187888 -0.232692 -0.263117 -0.277876 -0.276566 -0.259671
+-0.228525 -0.185225 -0.1325 -0.0735489 -0.0118567 0.0490077 0.105594
+0.154759 0.193846 0.22082 0.234378 0.234009 0.220011 0.193459 0.156134
+0.110407 0.0590926 0.00528327 -0.0478377 -0.097179 -0.13992 -0.17367
+-0.196602 -0.207547 -0.206057 -0.192418 -0.167623 -0.133306 -0.0916342
+-0.0451764 0.00325392 0.0507668 0.0945676 0.132118 0.161283 0.180451
+0.188622 0.185462 0.171307 0.147141 0.114531 0.0755202 0.0325088 -0.0118957
+-0.0550349 -0.0943568 -0.127566 -0.152759 -0.168528 -0.174042 -0.169092
+-0.154091 -0.130047 -0.0984966 -0.0614043 -0.021046 0.0201325 0.0596627
+0.0951994 0.12466 0.146346 0.15904 0.162073 0.155361;
+#X coords 0 1 99 -1 200 140 1;
+#X restore 273 548 graph;
+#N canvas 0 0 450 300 plot 0;
+#X obj 60 19 inlet;
+#X obj 44 198 mtx;
+#X obj 58 42 t a a;
+#X obj 39 70 mtx_size;
+#X obj 39 112 until;
+#X obj 39 92 t f b;
+#X obj 68 131 + 1;
+#X obj 39 131 i;
+#X msg 82 93 1;
+#X obj 43 152 t f f;
+#X obj 152 243 outlet;
+#X obj 44 222 list prepend 0;
+#X obj 45 243 outlet;
+#X obj 152 219 - 1;
+#X msg 44 175 col \$1;
+#X connect 0 0 2 0;
+#X connect 1 0 11 0;
+#X connect 2 0 3 0;
+#X connect 2 1 1 1;
+#X connect 3 1 5 0;
+#X connect 4 0 7 0;
+#X connect 5 0 4 0;
+#X connect 5 1 8 0;
+#X connect 6 0 7 1;
+#X connect 7 0 6 0;
+#X connect 7 0 9 0;
+#X connect 8 0 7 1;
+#X connect 9 0 14 0;
+#X connect 9 1 13 0;
+#X connect 11 0 12 0;
+#X connect 13 0 10 0;
+#X connect 14 0 1 0;
+#X restore 124 112 pd plot;
+#X obj 124 160 s;
+#X msg 162 135 symbol j\$1;
+#N canvas 0 0 450 300 plot 0;
+#X obj 60 19 inlet;
+#X obj 44 198 mtx;
+#X obj 58 42 t a a;
+#X obj 39 70 mtx_size;
+#X obj 39 112 until;
+#X obj 39 92 t f b;
+#X obj 68 131 + 1;
+#X obj 39 131 i;
+#X msg 82 93 1;
+#X obj 43 152 t f f;
+#X obj 152 243 outlet;
+#X obj 44 222 list prepend 0;
+#X obj 45 243 outlet;
+#X obj 152 219 - 1;
+#X msg 44 175 col \$1;
+#X connect 0 0 2 0;
+#X connect 1 0 11 0;
+#X connect 2 0 3 0;
+#X connect 2 1 1 1;
+#X connect 3 1 5 0;
+#X connect 4 0 7 0;
+#X connect 5 0 4 0;
+#X connect 5 1 8 0;
+#X connect 6 0 7 1;
+#X connect 7 0 6 0;
+#X connect 7 0 9 0;
+#X connect 8 0 7 1;
+#X connect 9 0 14 0;
+#X connect 9 1 13 0;
+#X connect 11 0 12 0;
+#X connect 13 0 10 0;
+#X connect 14 0 1 0;
+#X restore 245 114 pd plot;
+#X obj 245 162 s;
+#X msg 283 137 symbol y\$1;
+#N canvas 0 0 450 300 (subpatch) 0;
+#X array j3 100 float 1;
+#A 0 2.08203e-05 0.000863198 0.00426674 0.0118419 0.0248787 0.0442418
+0.0702931 0.102846 0.141158 0.183953 0.229489 0.275649 0.320061 0.360241
+0.393741 0.418305 0.43201 0.433403 0.421599 0.39636 0.358132 0.308043
+0.247866 0.17994 0.107056 0.0323225 -0.040996 -0.109652 -0.170585 -0.221087
+-0.258952 -0.282594 -0.291135 -0.284462 -0.263226 -0.228818 -0.18329
+-0.129249 -0.0697136 -0.00795365 0.0526869 0.10897 0.157936 0.197066
+0.224408 0.238684 0.23935 0.226619 0.201443 0.165447 0.120837 0.0702672
+0.0166866 -0.0368286 -0.0872512 -0.131771 -0.167952 -0.193865 -0.208194
+-0.210298 -0.200245 -0.178796 -0.147357 -0.107885 -0.0627772 -0.01472
+0.033463 0.0789776 0.119221 0.151926 0.175294 0.188088 0.189701 0.180186
+0.16024 0.131164 0.0947712 0.0532857 0.0092003 -0.0348674 -0.0763307
+-0.112785 -0.142145 -0.162767 -0.173538 -0.173933 -0.164048 -0.144578
+-0.116778 -0.0823806 -0.0434883 -0.00244804 0.0382903 0.0763201 0.109418
+0.135674 0.153603 0.162225 0.161121 0.150453;
+#X coords 0 1 99 -1 200 140 1;
+#X restore 69 709 graph;
+#N canvas 0 0 450 300 (subpatch) 0;
+#X array y3 100 float 1;
+#A 0 -5099.33 -123.861 -25.4478 -9.40414 -4.64486 -2.74506 -1.83722
+-1.34584 -1.05214 -0.859669 -0.720975 -0.6108 -0.515016 -0.425639 -0.338379
+-0.25134 -0.164261 -0.0780219 0.00571318 0.0847881 0.156805 0.219352
+0.270202 0.307487 0.32985 0.336549 0.327533 0.303471 0.265738 0.216364
+0.157937 0.0934828 0.0263055 -0.0401754 -0.102605 -0.15787 -0.203256
+-0.236598 -0.256385 -0.261841 -0.252962 -0.23051 -0.195965 -0.151438
+-0.0995561 -0.0433047 0.014132 0.0695525 0.119913 0.162495 0.195053
+0.215934 0.224162 0.219488 0.202391 0.174046 0.136248 0.0913008 0.0418862
+-0.0090994 -0.0587086 -0.104113 -0.142764 -0.172534 -0.191834 -0.1997
+-0.195839 -0.18064 -0.15514 -0.120963 -0.0802127 -0.03535 0.0109558
+0.055985 0.0971239 0.132017 0.158701 0.175716 0.182183 0.17785 0.163102
+0.138928 0.106861 0.0688772 0.0272817 -0.0154349 -0.0567419 -0.0942188
+-0.125697 -0.149382 -0.163959 -0.168664 -0.163323 -0.148355 -0.124748
+-0.0939876 -0.0579688 -0.018879 0.0209329 0.0590982;
+#X coords 0 1 99 -1 200 140 1;
+#X restore 273 708 graph;
+#X obj 363 54 hsl 128 15 1 300 0 0 empty empty empty -2 -8 0 10 -262144
+-1 -1 1000 1;
+#X msg 124 42 0.1 \$1 100;
+#X obj 125 63 mtx_linspace;
+#X obj 125 87 mtx_bessel H 3;
+#X connect 6 0 7 0;
+#X connect 6 1 8 0;
+#X connect 8 0 7 1;
+#X connect 9 0 10 0;
+#X connect 9 1 11 0;
+#X connect 11 0 10 1;
+#X connect 14 0 15 0;
+#X connect 15 0 16 0;
+#X connect 16 0 17 0;
+#X connect 17 0 6 0;
+#X connect 17 1 9 0;
diff --git a/src/iemmatrix_sources.c b/src/iemmatrix_sources.c
index 2e6b4f4..d6e3431 100644
--- a/src/iemmatrix_sources.c
+++ b/src/iemmatrix_sources.c
@@ -12,6 +12,7 @@ void iemmatrix_sources_setup(void)
iemtx_add_setup(); /* mtx_add.c */
iemtx_and_setup(); /* mtx_and.c */
iemtx_atan_setup(); /* mtx_atan.c */
+ iemtx_bessel_setup(); /* mtx_bessel.c */
iemtx_bitand_setup(); /* mtx_bitand.c */
iemtx_bitleft_setup(); /* mtx_bitleft.c */
iemtx_bitor_setup(); /* mtx_bitor.c */
diff --git a/src/iemmatrix_sources.h b/src/iemmatrix_sources.h
index df6dc7b..cd1e9ab 100644
--- a/src/iemmatrix_sources.h
+++ b/src/iemmatrix_sources.h
@@ -10,6 +10,7 @@ void iemtx_abs_setup(void); /* mtx_abs.c */
void iemtx_add_setup(void); /* mtx_add.c */
void iemtx_and_setup(void); /* mtx_and.c */
void iemtx_atan_setup(void); /* mtx_atan.c */
+void iemtx_bessel_setup(void); /* mtx_bessel.c */
void iemtx_bitand_setup(void); /* mtx_bitand.c */
void iemtx_bitleft_setup(void); /* mtx_bitleft.c */
void iemtx_bitor_setup(void); /* mtx_bitor.c */
diff --git a/src/mtx_bessel.c b/src/mtx_bessel.c
new file mode 100644
index 0000000..77ac9ea
--- /dev/null
+++ b/src/mtx_bessel.c
@@ -0,0 +1,186 @@
+/*
+ * 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 "math.h"
+#include <stdlib.h>
+
+static t_class *mtx_bessel_class;
+
+typedef struct _MTXBessel_ MTXBessel;
+struct _MTXBessel_
+{
+ t_object x_obj;
+ t_outlet *list_h_re_out;
+ t_outlet *list_h_im_out;
+ t_atom *list_h_re;
+ t_atom *list_h_im;
+ double *kr;
+ double *h_re;
+ double *h_im;
+ size_t nmax;
+ size_t l;
+};
+
+static void allocMTXBesseldata (MTXBessel *x)
+{
+ x->kr=(double*)calloc(x->l,sizeof(double));
+ if (x->list_h_re_out!=0) {
+ x->list_h_re=(t_atom*)calloc(x->l*(x->nmax+1)+2,sizeof(t_atom));
+ x->h_re=(double*)calloc(x->l*(x->nmax+1),sizeof(double));
+ }
+ if (x->list_h_im_out!=0) {
+ x->list_h_im=(t_atom*)calloc(x->l*(x->nmax+1)+2,sizeof(t_atom));
+ x->h_im=(double*)calloc(x->l*(x->nmax+1),sizeof(double));
+ }
+}
+
+static void deleteMTXBesseldata (MTXBessel *x)
+{
+ if (x->kr!=0)
+ free(x->kr);
+ if (x->h_re!=0)
+ free(x->h_re);
+ if (x->h_im!=0)
+ free(x->h_im);
+ if (x->list_h_re!=0)
+ free(x->list_h_re);
+ if (x->list_h_im!=0)
+ free(x->list_h_im);
+ x->list_h_re=0;
+ x->list_h_im=0;
+ x->h_re=0;
+ x->h_im=0;
+ x->kr=0;
+}
+
+static void *newMTXBessel (t_symbol *s, int argc, t_atom *argv)
+{
+ int nmax;
+ char whichfunction = 'j';
+ t_symbol *fsym;
+ MTXBessel *x = (MTXBessel *) pd_new (mtx_bessel_class);
+ x->list_h_re = 0;
+ x->list_h_im = 0;
+ x->list_h_im_out = 0;
+ x->list_h_re_out = 0;
+ x->kr = 0;
+ x->h_re = 0;
+ x->h_im = 0;
+ x->l=0;
+ fsym=atom_getsymbol(argv);
+ if (fsym->s_name!=0)
+ whichfunction=fsym->s_name[0];
+ switch (whichfunction) {
+ default:
+ case 'J':
+ x->list_h_re_out = outlet_new (&x->x_obj, gensym("matrix"));
+ break;
+ case 'H':
+ x->list_h_re_out = outlet_new (&x->x_obj, gensym("matrix"));
+ case 'Y':
+ x->list_h_im_out = outlet_new (&x->x_obj, gensym("matrix"));
+ }
+ nmax=(int) atom_getfloat(argv+1);
+ if (nmax<0)
+ nmax=0;
+ x->nmax=nmax;
+
+ return ((void *) x);
+}
+
+static void mTXBesselBang (MTXBessel *x)
+{
+ if (x->list_h_im!=0) {
+ outlet_anything(x->list_h_im_out, gensym("matrix"), x->l*(x->nmax+1)+2, x->list_h_im);
+ }
+ if (x->list_h_re!=0) {
+ outlet_anything(x->list_h_re_out, gensym("matrix"), x->l*(x->nmax+1)+2, x->list_h_re);
+ }
+}
+
+static void mTXBesselMatrix (MTXBessel *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,m,ofs;
+
+
+ /* size check */
+ if (!size)
+ post("mtx_bessel: invalid dimensions");
+ else if (in_size<size)
+ post("mtx_bessel: sparse matrix not yet supported: use \"mtx_check\"");
+ else if ((rows!=1)||(columns<1))
+ post("mtx_bessel: 1 X L matrix expected with kr and h vector, but got more rows/no entries");
+ else {
+ if (x->l!=columns) {
+ deleteMTXBesseldata(x);
+ x->l=columns;
+ allocMTXBesseldata(x);
+ }
+ for (n=0;n<x->l;n++) {
+ x->kr[n]=(double) atom_getfloat(argv+n);
+ }
+
+ if (x->h_re!=0)
+ for (m=0;m<x->l;m++)
+ for (n=0;n<x->nmax+1;n++)
+ x->h_re[n+m*(x->nmax+1)]=jnf(n,x->kr[m]);
+
+ if (x->h_im!=0)
+ for (m=0;m<x->l;m++)
+ for (n=0;n<x->nmax+1;n++)
+ x->h_im[n+m*(x->nmax+1)]=ynf(n,x->kr[m]);
+
+
+ if (x->h_re!=0) {
+ SETFLOAT(x->list_h_re+1,(float)(x->nmax+1));
+ SETFLOAT(x->list_h_re,(float)x->l);
+ for (n=0;n<x->l*(x->nmax+1);n++)
+ SETFLOAT(x->list_h_re+n+2,(float)x->h_re[n]);
+ }
+
+ if (x->h_im!=0) {
+ SETFLOAT(x->list_h_im+1,(float)(x->nmax+1));
+ SETFLOAT(x->list_h_im,(float)x->l);
+ for (n=0;n<x->l*(x->nmax+1);n++)
+ SETFLOAT(x->list_h_im+n+2,(float)x->h_im[n]);
+ }
+
+ mTXBesselBang(x);
+ }
+}
+
+void mtx_bessel_setup (void)
+{
+ mtx_bessel_class = class_new
+ (gensym("mtx_bessel"),
+ (t_newmethod) newMTXBessel,
+ (t_method) deleteMTXBesseldata,
+ sizeof (MTXBessel),
+ CLASS_DEFAULT, A_GIMME, 0);
+ class_addbang (mtx_bessel_class, (t_method) mTXBesselBang);
+ class_addmethod (mtx_bessel_class, (t_method) mTXBesselMatrix, gensym("matrix"), A_GIMME,0);
+}
+
+void iemtx_bessel_setup(void){
+ mtx_bessel_setup();
+}
+
+