gsl 1.12.108

Sign up to get free protection for your applications and to get access to all the features.
Files changed (158) hide show
  1. data/README.rdoc +29 -0
  2. data/Rakefile +54 -0
  3. data/VERSION +2 -0
  4. data/ext/MANIFEST +119 -0
  5. data/ext/alf.c +206 -0
  6. data/ext/array.c +666 -0
  7. data/ext/array_complex.c +247 -0
  8. data/ext/blas.c +29 -0
  9. data/ext/blas1.c +731 -0
  10. data/ext/blas2.c +1093 -0
  11. data/ext/blas3.c +881 -0
  12. data/ext/block.c +44 -0
  13. data/ext/block_source.c +886 -0
  14. data/ext/bspline.c +130 -0
  15. data/ext/bundle.c +3 -0
  16. data/ext/cdf.c +754 -0
  17. data/ext/cheb.c +542 -0
  18. data/ext/combination.c +283 -0
  19. data/ext/common.c +325 -0
  20. data/ext/complex.c +1004 -0
  21. data/ext/const.c +673 -0
  22. data/ext/const_additional.c +120 -0
  23. data/ext/cqp.c +283 -0
  24. data/ext/deriv.c +195 -0
  25. data/ext/dht.c +361 -0
  26. data/ext/diff.c +166 -0
  27. data/ext/dirac.c +395 -0
  28. data/ext/eigen.c +2373 -0
  29. data/ext/error.c +194 -0
  30. data/ext/extconf.rb +281 -0
  31. data/ext/fcmp.c +66 -0
  32. data/ext/fft.c +1092 -0
  33. data/ext/fit.c +205 -0
  34. data/ext/fresnel.c +312 -0
  35. data/ext/function.c +524 -0
  36. data/ext/geometry.c +139 -0
  37. data/ext/graph.c +1638 -0
  38. data/ext/gsl.c +271 -0
  39. data/ext/gsl_narray.c +653 -0
  40. data/ext/histogram.c +1995 -0
  41. data/ext/histogram2d.c +1068 -0
  42. data/ext/histogram3d.c +884 -0
  43. data/ext/histogram3d_source.c +750 -0
  44. data/ext/histogram_find.c +101 -0
  45. data/ext/histogram_oper.c +159 -0
  46. data/ext/ieee.c +98 -0
  47. data/ext/integration.c +1138 -0
  48. data/ext/interp.c +512 -0
  49. data/ext/jacobi.c +739 -0
  50. data/ext/linalg.c +4047 -0
  51. data/ext/linalg_complex.c +741 -0
  52. data/ext/math.c +725 -0
  53. data/ext/matrix.c +39 -0
  54. data/ext/matrix_complex.c +1732 -0
  55. data/ext/matrix_double.c +560 -0
  56. data/ext/matrix_int.c +256 -0
  57. data/ext/matrix_source.c +2733 -0
  58. data/ext/min.c +250 -0
  59. data/ext/monte.c +992 -0
  60. data/ext/multifit.c +1879 -0
  61. data/ext/multimin.c +808 -0
  62. data/ext/multimin_fsdf.c +156 -0
  63. data/ext/multiroots.c +955 -0
  64. data/ext/ndlinear.c +321 -0
  65. data/ext/nmf.c +167 -0
  66. data/ext/nmf_wrap.c +72 -0
  67. data/ext/ntuple.c +469 -0
  68. data/ext/odeiv.c +959 -0
  69. data/ext/ool.c +879 -0
  70. data/ext/oper_complex_source.c +253 -0
  71. data/ext/permutation.c +596 -0
  72. data/ext/poly.c +42 -0
  73. data/ext/poly2.c +265 -0
  74. data/ext/poly_source.c +1885 -0
  75. data/ext/qrng.c +171 -0
  76. data/ext/randist.c +1873 -0
  77. data/ext/rational.c +480 -0
  78. data/ext/rng.c +612 -0
  79. data/ext/root.c +408 -0
  80. data/ext/sf.c +1494 -0
  81. data/ext/sf_airy.c +200 -0
  82. data/ext/sf_bessel.c +867 -0
  83. data/ext/sf_clausen.c +28 -0
  84. data/ext/sf_coulomb.c +206 -0
  85. data/ext/sf_coupling.c +118 -0
  86. data/ext/sf_dawson.c +29 -0
  87. data/ext/sf_debye.c +157 -0
  88. data/ext/sf_dilog.c +42 -0
  89. data/ext/sf_elementary.c +44 -0
  90. data/ext/sf_ellint.c +206 -0
  91. data/ext/sf_elljac.c +29 -0
  92. data/ext/sf_erfc.c +93 -0
  93. data/ext/sf_exp.c +164 -0
  94. data/ext/sf_expint.c +211 -0
  95. data/ext/sf_fermi_dirac.c +148 -0
  96. data/ext/sf_gamma.c +344 -0
  97. data/ext/sf_gegenbauer.c +96 -0
  98. data/ext/sf_hyperg.c +197 -0
  99. data/ext/sf_laguerre.c +112 -0
  100. data/ext/sf_lambert.c +47 -0
  101. data/ext/sf_legendre.c +367 -0
  102. data/ext/sf_log.c +104 -0
  103. data/ext/sf_mathieu.c +238 -0
  104. data/ext/sf_power.c +46 -0
  105. data/ext/sf_psi.c +98 -0
  106. data/ext/sf_synchrotron.c +48 -0
  107. data/ext/sf_transport.c +76 -0
  108. data/ext/sf_trigonometric.c +207 -0
  109. data/ext/sf_zeta.c +119 -0
  110. data/ext/signal.c +310 -0
  111. data/ext/siman.c +718 -0
  112. data/ext/sort.c +208 -0
  113. data/ext/spline.c +395 -0
  114. data/ext/stats.c +799 -0
  115. data/ext/sum.c +168 -0
  116. data/ext/tamu_anova.c +56 -0
  117. data/ext/tensor.c +38 -0
  118. data/ext/tensor_source.c +1123 -0
  119. data/ext/vector.c +38 -0
  120. data/ext/vector_complex.c +2236 -0
  121. data/ext/vector_double.c +1433 -0
  122. data/ext/vector_int.c +204 -0
  123. data/ext/vector_source.c +3329 -0
  124. data/ext/wavelet.c +937 -0
  125. data/include/rb_gsl.h +151 -0
  126. data/include/rb_gsl_array.h +238 -0
  127. data/include/rb_gsl_cheb.h +21 -0
  128. data/include/rb_gsl_common.h +343 -0
  129. data/include/rb_gsl_complex.h +25 -0
  130. data/include/rb_gsl_const.h +29 -0
  131. data/include/rb_gsl_dirac.h +13 -0
  132. data/include/rb_gsl_eigen.h +17 -0
  133. data/include/rb_gsl_fft.h +62 -0
  134. data/include/rb_gsl_fit.h +25 -0
  135. data/include/rb_gsl_function.h +27 -0
  136. data/include/rb_gsl_graph.h +70 -0
  137. data/include/rb_gsl_histogram.h +63 -0
  138. data/include/rb_gsl_histogram3d.h +97 -0
  139. data/include/rb_gsl_integration.h +17 -0
  140. data/include/rb_gsl_interp.h +46 -0
  141. data/include/rb_gsl_linalg.h +25 -0
  142. data/include/rb_gsl_math.h +26 -0
  143. data/include/rb_gsl_odeiv.h +21 -0
  144. data/include/rb_gsl_poly.h +71 -0
  145. data/include/rb_gsl_rational.h +37 -0
  146. data/include/rb_gsl_rng.h +21 -0
  147. data/include/rb_gsl_root.h +22 -0
  148. data/include/rb_gsl_sf.h +119 -0
  149. data/include/rb_gsl_statistics.h +17 -0
  150. data/include/rb_gsl_tensor.h +45 -0
  151. data/include/rb_gsl_with_narray.h +22 -0
  152. data/include/templates_off.h +87 -0
  153. data/include/templates_on.h +241 -0
  154. data/lib/gsl/gnuplot.rb +41 -0
  155. data/lib/gsl/oper.rb +68 -0
  156. data/lib/ool.rb +22 -0
  157. data/lib/ool/conmin.rb +30 -0
  158. metadata +224 -0
@@ -0,0 +1,367 @@
1
+ /*
2
+ legendre.c
3
+ Ruby/GSL: Ruby extension library for GSL (GNU Scientific Library)
4
+ (C) Copyright 2001-2006 by Yoshiki Tsunesada
5
+
6
+ Ruby/GSL is free software: you can redistribute it and/or modify it
7
+ under the terms of the GNU General Public License.
8
+ This library is distributed in the hope that it will be useful, but
9
+ WITHOUT ANY WARRANTY.
10
+ */
11
+
12
+ #include "rb_gsl_sf.h"
13
+ EXTERN VALUE cgsl_vector;
14
+
15
+ static VALUE rb_gsl_sf_legendre_P1(VALUE obj, VALUE x)
16
+ {
17
+ return rb_gsl_sf_eval1(gsl_sf_legendre_P1, x);
18
+ }
19
+
20
+ static VALUE rb_gsl_sf_legendre_P1_e(VALUE obj, VALUE x)
21
+ {
22
+ return rb_gsl_sf_eval_e(gsl_sf_legendre_P1_e, x);
23
+ }
24
+
25
+ static VALUE rb_gsl_sf_legendre_P2(VALUE obj, VALUE x)
26
+ {
27
+ return rb_gsl_sf_eval1(gsl_sf_legendre_P2, x);
28
+ }
29
+
30
+ static VALUE rb_gsl_sf_legendre_P2_e(VALUE obj, VALUE x)
31
+ {
32
+ return rb_gsl_sf_eval_e(gsl_sf_legendre_P2_e, x);
33
+ }
34
+
35
+ static VALUE rb_gsl_sf_legendre_P3(VALUE obj, VALUE x)
36
+ {
37
+ return rb_gsl_sf_eval1(gsl_sf_legendre_P3, x);
38
+ }
39
+
40
+ static VALUE rb_gsl_sf_legendre_P3_e(VALUE obj, VALUE x)
41
+ {
42
+ return rb_gsl_sf_eval_e(gsl_sf_legendre_P3_e, x);
43
+ }
44
+
45
+ static VALUE rb_gsl_sf_legendre_Pl(VALUE obj, VALUE l, VALUE x)
46
+ {
47
+ return rb_gsl_sf_eval_int_double(gsl_sf_legendre_Pl, l, x);
48
+ }
49
+
50
+ static VALUE rb_gsl_sf_legendre_Pl_e(VALUE obj, VALUE l, VALUE x)
51
+ {
52
+ return rb_gsl_sf_eval_e_int_double(gsl_sf_legendre_Pl_e, l, x);
53
+ }
54
+
55
+ static VALUE rb_gsl_sf_legendre_Pl_array(VALUE obj, VALUE lmax, VALUE x)
56
+ {
57
+ gsl_vector *v = NULL;
58
+ CHECK_FIXNUM(lmax);
59
+ Need_Float(x);
60
+ v = gsl_vector_alloc(FIX2INT(lmax) + 1);
61
+ gsl_sf_legendre_Pl_array(FIX2INT(lmax), NUM2DBL(x), v->data);
62
+ return Data_Wrap_Struct(cgsl_vector, 0, gsl_vector_free, v);
63
+ }
64
+
65
+ static VALUE rb_gsl_sf_legendre_Q0(VALUE obj, VALUE x)
66
+ {
67
+ return rb_gsl_sf_eval1(gsl_sf_legendre_Q0, x);
68
+ }
69
+
70
+ static VALUE rb_gsl_sf_legendre_Q0_e(VALUE obj, VALUE x)
71
+ {
72
+ return rb_gsl_sf_eval_e(gsl_sf_legendre_Q0_e, x);
73
+ }
74
+
75
+ static VALUE rb_gsl_sf_legendre_Q1(VALUE obj, VALUE x)
76
+ {
77
+ return rb_gsl_sf_eval1(gsl_sf_legendre_Q1, x);
78
+ }
79
+
80
+ static VALUE rb_gsl_sf_legendre_Q1_e(VALUE obj, VALUE x)
81
+ {
82
+ return rb_gsl_sf_eval_e(gsl_sf_legendre_Q1_e, x);
83
+ }
84
+
85
+ static VALUE rb_gsl_sf_legendre_Ql(VALUE obj, VALUE l, VALUE x)
86
+ {
87
+ return rb_gsl_sf_eval_int_double(gsl_sf_legendre_Ql, l, x);
88
+ }
89
+
90
+ static VALUE rb_gsl_sf_legendre_Ql_e(VALUE obj, VALUE l, VALUE x)
91
+ {
92
+ return rb_gsl_sf_eval_e_int_double(gsl_sf_legendre_Ql_e, l, x);
93
+ }
94
+
95
+ static VALUE rb_gsl_sf_legendre_Plm(VALUE obj, VALUE l, VALUE m, VALUE x)
96
+ {
97
+ return rb_gsl_sf_eval_int_int_double(gsl_sf_legendre_Plm, l, m, x);
98
+ }
99
+
100
+ static VALUE rb_gsl_sf_legendre_Plm_e(VALUE obj, VALUE l, VALUE m, VALUE x)
101
+ {
102
+ gsl_sf_result *rslt = NULL;
103
+ VALUE v;
104
+ int status;
105
+ CHECK_FIXNUM(l);
106
+ CHECK_FIXNUM(m);
107
+ Need_Float(x);
108
+ v = Data_Make_Struct(cgsl_sf_result, gsl_sf_result, 0, free, rslt);
109
+ status = gsl_sf_legendre_Plm_e(FIX2INT(l), FIX2INT(m), NUM2DBL(x), rslt);
110
+ return rb_ary_new3(2, v, INT2FIX(status));
111
+ }
112
+
113
+ static VALUE rb_gsl_sf_legendre_Plm_array(VALUE obj, VALUE lmax, VALUE m, VALUE x)
114
+ {
115
+ gsl_vector *v = NULL;
116
+ int size;
117
+ int ll, mm;
118
+ CHECK_FIXNUM(lmax); CHECK_FIXNUM(m);
119
+ Need_Float(x);
120
+ ll = FIX2INT(lmax);
121
+ mm = FIX2INT(m);
122
+ size = gsl_sf_legendre_array_size(ll, mm);
123
+ v = gsl_vector_alloc(size);
124
+ gsl_sf_legendre_Plm_array(ll, mm, NUM2DBL(x), v->data);
125
+ return Data_Wrap_Struct(cgsl_vector, 0, gsl_vector_free, v);
126
+ }
127
+
128
+ static VALUE rb_gsl_sf_legendre_sphPlm(VALUE obj, VALUE l, VALUE m, VALUE x)
129
+ {
130
+ return rb_gsl_sf_eval_int_int_double(gsl_sf_legendre_sphPlm, l, m, x);
131
+ }
132
+
133
+ static VALUE rb_gsl_sf_legendre_sphPlm_e(VALUE obj, VALUE l, VALUE m, VALUE x)
134
+ {
135
+ gsl_sf_result *rslt = NULL;
136
+ VALUE v;
137
+ int status;
138
+ CHECK_FIXNUM(l); CHECK_FIXNUM(m);
139
+ Need_Float(x);
140
+ v = Data_Make_Struct(cgsl_sf_result, gsl_sf_result, 0, free, rslt);
141
+ status = gsl_sf_legendre_sphPlm_e(FIX2INT(l), FIX2INT(m), NUM2DBL(x), rslt);
142
+ return rb_ary_new3(2, v, INT2FIX(status));
143
+ }
144
+
145
+ static VALUE rb_gsl_sf_legendre_sphPlm_array(VALUE obj, VALUE lmax, VALUE m, VALUE x)
146
+ {
147
+ gsl_vector *v = NULL;
148
+ int size;
149
+ int ll, mm;
150
+ CHECK_FIXNUM(lmax); CHECK_FIXNUM(m);
151
+ Need_Float(x);
152
+ ll = FIX2INT(lmax);
153
+ mm = FIX2INT(m);
154
+ size = gsl_sf_legendre_array_size(ll, mm);
155
+ v = gsl_vector_alloc(size);
156
+ gsl_sf_legendre_sphPlm_array(ll, mm, NUM2DBL(x), v->data);
157
+ return Data_Wrap_Struct(cgsl_vector, 0, gsl_vector_free, v);
158
+ }
159
+
160
+ static VALUE rb_gsl_sf_legendre_array_size(VALUE obj, VALUE lmax, VALUE m)
161
+ {
162
+ CHECK_FIXNUM(lmax); CHECK_FIXNUM(m);
163
+ return INT2FIX(gsl_sf_legendre_array_size(FIX2INT(lmax), FIX2INT(m)));
164
+ }
165
+
166
+ static VALUE rb_gsl_sf_conicalP_half(VALUE obj, VALUE lambda, VALUE x)
167
+ {
168
+ return rb_gsl_sf_eval_double_double(gsl_sf_conicalP_half, lambda, x);
169
+ }
170
+
171
+ static VALUE rb_gsl_sf_conicalP_half_e(VALUE obj, VALUE lambda, VALUE x)
172
+ {
173
+ return rb_gsl_sf_eval_e_double2(gsl_sf_conicalP_half_e, lambda, x);
174
+ }
175
+
176
+ static VALUE rb_gsl_sf_conicalP_mhalf(VALUE obj, VALUE lambda, VALUE x)
177
+ {
178
+ return rb_gsl_sf_eval_double_double(gsl_sf_conicalP_mhalf, lambda, x);
179
+ }
180
+
181
+ static VALUE rb_gsl_sf_conicalP_mhalf_e(VALUE obj, VALUE lambda, VALUE x)
182
+ {
183
+ return rb_gsl_sf_eval_e_double2(gsl_sf_conicalP_mhalf_e, lambda, x);
184
+ }
185
+
186
+ static VALUE rb_gsl_sf_conicalP_0(VALUE obj, VALUE lambda, VALUE x)
187
+ {
188
+ return rb_gsl_sf_eval_double_double(gsl_sf_conicalP_0, lambda, x);
189
+ }
190
+
191
+ static VALUE rb_gsl_sf_conicalP_0_e(VALUE obj, VALUE lambda, VALUE x)
192
+ {
193
+ return rb_gsl_sf_eval_e_double2(gsl_sf_conicalP_0_e, lambda, x);
194
+ }
195
+
196
+ static VALUE rb_gsl_sf_conicalP_1(VALUE obj, VALUE lambda, VALUE x)
197
+ {
198
+ return rb_gsl_sf_eval_double_double(gsl_sf_conicalP_1, lambda, x);
199
+ }
200
+
201
+ static VALUE rb_gsl_sf_conicalP_1_e(VALUE obj, VALUE lambda, VALUE x)
202
+ {
203
+ return rb_gsl_sf_eval_e_double2(gsl_sf_conicalP_1_e, lambda, x);
204
+ }
205
+
206
+ static VALUE rb_gsl_sf_conicalP_sph_reg(VALUE obj, VALUE l, VALUE lambda, VALUE x)
207
+ {
208
+ return rb_gsl_sf_eval_int_double_double(gsl_sf_conicalP_sph_reg, l, lambda, x);
209
+ }
210
+
211
+ static VALUE rb_gsl_sf_conicalP_sph_reg_e(VALUE obj, VALUE l, VALUE lambda, VALUE x)
212
+ {
213
+ return rb_gsl_sf_eval_e_int_double2(gsl_sf_conicalP_sph_reg_e, l, lambda, x);
214
+ }
215
+
216
+ static VALUE rb_gsl_sf_conicalP_cyl_reg(VALUE obj, VALUE m, VALUE lambda, VALUE x)
217
+ {
218
+ return rb_gsl_sf_eval_int_double_double(gsl_sf_conicalP_cyl_reg, m, lambda, x);
219
+ }
220
+
221
+ static VALUE rb_gsl_sf_conicalP_cyl_reg_e(VALUE obj, VALUE m, VALUE lambda, VALUE x)
222
+ {
223
+ return rb_gsl_sf_eval_e_int_double2(gsl_sf_conicalP_cyl_reg_e, m, lambda, x);
224
+ }
225
+
226
+ static VALUE rb_gsl_sf_legendre_H3d_0(VALUE obj, VALUE lambda, VALUE eta)
227
+ {
228
+ Need_Float(lambda); Need_Float(eta);
229
+ return rb_float_new(gsl_sf_legendre_H3d_0(NUM2DBL(lambda), NUM2DBL(eta)));
230
+ }
231
+
232
+ static VALUE rb_gsl_sf_legendre_H3d_0_e(VALUE obj, VALUE lambda, VALUE eta)
233
+ {
234
+ return rb_gsl_sf_eval_e_double2(gsl_sf_legendre_H3d_0_e, lambda, eta);
235
+ }
236
+
237
+ static VALUE rb_gsl_sf_legendre_H3d_1(VALUE obj, VALUE lambda, VALUE eta)
238
+ {
239
+ Need_Float(lambda); Need_Float(eta);
240
+ return rb_float_new(gsl_sf_legendre_H3d_1(NUM2DBL(lambda), NUM2DBL(eta)));
241
+ }
242
+
243
+ static VALUE rb_gsl_sf_legendre_H3d_1_e(VALUE obj, VALUE lambda, VALUE eta)
244
+ {
245
+ return rb_gsl_sf_eval_e_double2(gsl_sf_legendre_H3d_1_e, lambda, eta);
246
+ }
247
+
248
+
249
+ static VALUE rb_gsl_sf_legendre_H3d(VALUE obj, VALUE l, VALUE lambda, VALUE eta)
250
+ {
251
+ return rb_float_new(gsl_sf_legendre_H3d(FIX2INT(l), NUM2DBL(lambda), NUM2DBL(eta)));
252
+ }
253
+
254
+ static VALUE rb_gsl_sf_legendre_H3d_e(VALUE obj,VALUE l, VALUE lambda, VALUE eta)
255
+ {
256
+ gsl_sf_result *rslt = NULL;
257
+ VALUE v;
258
+ int status;
259
+ CHECK_FIXNUM(l);
260
+ Need_Float(lambda);
261
+ Need_Float(eta);
262
+ v = Data_Make_Struct(cgsl_sf_result, gsl_sf_result, 0, free, rslt);
263
+ status = gsl_sf_legendre_H3d_e(FIX2INT(l), NUM2DBL(lambda), NUM2DBL(eta), rslt);
264
+ return v;
265
+ }
266
+
267
+ static VALUE rb_gsl_sf_legendre_H3d_array(VALUE obj, VALUE lmax, VALUE lambda, VALUE eta)
268
+ {
269
+ gsl_vector *v = NULL;
270
+ CHECK_FIXNUM(lmax);
271
+ Need_Float(lambda);
272
+ Need_Float(eta);
273
+ v = gsl_vector_alloc(FIX2INT(lmax) + 1);
274
+ gsl_sf_legendre_H3d_array(FIX2INT(lmax), NUM2DBL(lambda), NUM2DBL(eta), v->data);
275
+ return Data_Wrap_Struct(cgsl_vector, 0, gsl_vector_free, v);
276
+ }
277
+
278
+ void Init_gsl_sf_legendre(VALUE module)
279
+ {
280
+ VALUE mgsl_sf_leg;
281
+
282
+ rb_define_module_function(module, "legendre_P1", rb_gsl_sf_legendre_P1, 1);
283
+ rb_define_module_function(module, "legendre_P1_e", rb_gsl_sf_legendre_P1_e, 1);
284
+ rb_define_module_function(module, "legendre_P2", rb_gsl_sf_legendre_P2, 1);
285
+ rb_define_module_function(module, "legendre_P2_e", rb_gsl_sf_legendre_P2_e, 1);
286
+ rb_define_module_function(module, "legendre_P3", rb_gsl_sf_legendre_P3, 1);
287
+ rb_define_module_function(module, "legendre_P3_e", rb_gsl_sf_legendre_P3_e, 1);
288
+ rb_define_module_function(module, "legendre_Pl", rb_gsl_sf_legendre_Pl, 2);
289
+ rb_define_module_function(module, "legendre_Pl_e", rb_gsl_sf_legendre_Pl_e, 2);
290
+ rb_define_module_function(module, "legendre_Pl_array", rb_gsl_sf_legendre_Pl_array, 2);
291
+ rb_define_module_function(module, "legendre_Q0", rb_gsl_sf_legendre_Q0, 1);
292
+ rb_define_module_function(module, "legendre_Q0_e", rb_gsl_sf_legendre_Q0_e, 1);
293
+ rb_define_module_function(module, "legendre_Q1", rb_gsl_sf_legendre_Q1, 1);
294
+ rb_define_module_function(module, "legendre_Q1_e", rb_gsl_sf_legendre_Q1_e, 1);
295
+ rb_define_module_function(module, "legendre_Ql", rb_gsl_sf_legendre_Ql, 2);
296
+ rb_define_module_function(module, "legendre_Ql_e", rb_gsl_sf_legendre_Ql_e, 2);
297
+ rb_define_module_function(module, "legendre_Plm", rb_gsl_sf_legendre_Plm, 3);
298
+ rb_define_module_function(module, "legendre_Plm_e", rb_gsl_sf_legendre_Plm_e, 3);
299
+ rb_define_module_function(module, "legendre_Plm_array", rb_gsl_sf_legendre_Plm_array, 3);
300
+ rb_define_module_function(module, "legendre_sphPlm", rb_gsl_sf_legendre_sphPlm, 3);
301
+ rb_define_module_function(module, "legendre_sphPlm_e", rb_gsl_sf_legendre_sphPlm_e, 3);
302
+ rb_define_module_function(module, "legendre_sphPlm_array", rb_gsl_sf_legendre_sphPlm_array, 3);
303
+ rb_define_module_function(module, "legendre_array_size", rb_gsl_sf_legendre_array_size, 2);
304
+ rb_define_module_function(module, "conicalP_half", rb_gsl_sf_conicalP_half, 2);
305
+ rb_define_module_function(module, "conicalP_half_e", rb_gsl_sf_conicalP_half_e, 2);
306
+ rb_define_module_function(module, "conicalP_mhalf", rb_gsl_sf_conicalP_mhalf, 2);
307
+ rb_define_module_function(module, "conicalP_mhalf_e", rb_gsl_sf_conicalP_mhalf_e, 2);
308
+ rb_define_module_function(module, "conicalP_0", rb_gsl_sf_conicalP_0, 2);
309
+ rb_define_module_function(module, "conicalP_0_e", rb_gsl_sf_conicalP_0_e, 2);
310
+ rb_define_module_function(module, "conicalP_1", rb_gsl_sf_conicalP_1, 2);
311
+ rb_define_module_function(module, "conicalP_1_e", rb_gsl_sf_conicalP_1_e, 2);
312
+ rb_define_module_function(module, "conicalP_sph_reg", rb_gsl_sf_conicalP_sph_reg, 3);
313
+ rb_define_module_function(module, "conicalP_sph_reg_e", rb_gsl_sf_conicalP_sph_reg_e, 3);
314
+ rb_define_module_function(module, "conicalP_cyl_reg", rb_gsl_sf_conicalP_cyl_reg, 3);
315
+ rb_define_module_function(module, "conicalP_cyl_reg_e", rb_gsl_sf_conicalP_cyl_reg_e, 3);
316
+ rb_define_module_function(module, "legendre_H3d_0", rb_gsl_sf_legendre_H3d_0, 2);
317
+ rb_define_module_function(module, "legendre_H3d_0_e", rb_gsl_sf_legendre_H3d_0_e, 2);
318
+ rb_define_module_function(module, "legendre_H3d_1", rb_gsl_sf_legendre_H3d_1, 2);
319
+ rb_define_module_function(module, "legendre_H3d_1_e", rb_gsl_sf_legendre_H3d_1_e, 2);
320
+ rb_define_module_function(module, "legendre_H3d", rb_gsl_sf_legendre_H3d, 3);
321
+ rb_define_module_function(module, "legendre_H3d_e", rb_gsl_sf_legendre_H3d_e, 3);
322
+ rb_define_module_function(module, "legendre_H3d_array", rb_gsl_sf_legendre_H3d_array, 3);
323
+
324
+ /*****/
325
+
326
+ mgsl_sf_leg = rb_define_module_under(module, "Legendre");
327
+ rb_define_module_function(mgsl_sf_leg, "P1", rb_gsl_sf_legendre_P1, 1);
328
+ rb_define_module_function(mgsl_sf_leg, "P1_e", rb_gsl_sf_legendre_P1_e, 1);
329
+ rb_define_module_function(mgsl_sf_leg, "P2", rb_gsl_sf_legendre_P2, 1);
330
+ rb_define_module_function(mgsl_sf_leg, "P2_e", rb_gsl_sf_legendre_P2_e, 1);
331
+ rb_define_module_function(mgsl_sf_leg, "P3", rb_gsl_sf_legendre_P3, 1);
332
+ rb_define_module_function(mgsl_sf_leg, "P3_e", rb_gsl_sf_legendre_P3_e, 1);
333
+ rb_define_module_function(mgsl_sf_leg, "Pl", rb_gsl_sf_legendre_Pl, 2);
334
+ rb_define_module_function(mgsl_sf_leg, "Pl_e", rb_gsl_sf_legendre_Pl_e, 2);
335
+ rb_define_module_function(mgsl_sf_leg, "Pl_array", rb_gsl_sf_legendre_Pl_array, 2);
336
+ rb_define_module_function(mgsl_sf_leg, "Q0", rb_gsl_sf_legendre_Q0, 1);
337
+ rb_define_module_function(mgsl_sf_leg, "Q0_e", rb_gsl_sf_legendre_Q0_e, 1);
338
+ rb_define_module_function(mgsl_sf_leg, "Q1", rb_gsl_sf_legendre_Q1, 1);
339
+ rb_define_module_function(mgsl_sf_leg, "Q1_e", rb_gsl_sf_legendre_Q1_e, 1);
340
+ rb_define_module_function(mgsl_sf_leg, "Plm", rb_gsl_sf_legendre_Plm, 3);
341
+ rb_define_module_function(mgsl_sf_leg, "Plm_e", rb_gsl_sf_legendre_Plm_e, 3);
342
+ rb_define_module_function(mgsl_sf_leg, "Plm_array", rb_gsl_sf_legendre_Plm_array, 3);
343
+ rb_define_module_function(mgsl_sf_leg, "sphPlm", rb_gsl_sf_legendre_sphPlm, 3);
344
+ rb_define_module_function(mgsl_sf_leg, "sphPlm_e", rb_gsl_sf_legendre_sphPlm_e, 3);
345
+ rb_define_module_function(mgsl_sf_leg, "sphPlm_array", rb_gsl_sf_legendre_sphPlm_array, 3);
346
+ rb_define_module_function(mgsl_sf_leg, "array_size", rb_gsl_sf_legendre_array_size, 2);
347
+ rb_define_module_function(mgsl_sf_leg, "conicalP_half", rb_gsl_sf_conicalP_half, 2);
348
+ rb_define_module_function(mgsl_sf_leg, "conicalP_half_e", rb_gsl_sf_conicalP_half_e, 2);
349
+ rb_define_module_function(mgsl_sf_leg, "conicalP_mhalf", rb_gsl_sf_conicalP_mhalf, 2);
350
+ rb_define_module_function(mgsl_sf_leg, "conicalP_mhalf_e", rb_gsl_sf_conicalP_mhalf_e, 2);
351
+ rb_define_module_function(mgsl_sf_leg, "conicalP_0", rb_gsl_sf_conicalP_0, 2);
352
+ rb_define_module_function(mgsl_sf_leg, "conicalP_0_e", rb_gsl_sf_conicalP_0_e, 2);
353
+ rb_define_module_function(mgsl_sf_leg, "conicalP_1", rb_gsl_sf_conicalP_1, 2);
354
+ rb_define_module_function(mgsl_sf_leg, "conicalP_1_e", rb_gsl_sf_conicalP_1_e, 2);
355
+ rb_define_module_function(mgsl_sf_leg, "conicalP_sph_reg", rb_gsl_sf_conicalP_sph_reg, 3);
356
+ rb_define_module_function(mgsl_sf_leg, "conicalP_sph_reg_e", rb_gsl_sf_conicalP_sph_reg_e, 3);
357
+ rb_define_module_function(mgsl_sf_leg, "conicalP_cyl_reg", rb_gsl_sf_conicalP_cyl_reg, 3);
358
+ rb_define_module_function(mgsl_sf_leg, "conicalP_cyl_reg_e", rb_gsl_sf_conicalP_cyl_reg_e, 3);
359
+ rb_define_module_function(mgsl_sf_leg, "H3d_0", rb_gsl_sf_legendre_H3d_0, 2);
360
+ rb_define_module_function(mgsl_sf_leg, "H3d_0_e", rb_gsl_sf_legendre_H3d_0_e, 2);
361
+ rb_define_module_function(mgsl_sf_leg, "H3d_1", rb_gsl_sf_legendre_H3d_1, 2);
362
+ rb_define_module_function(mgsl_sf_leg, "H3d_1_e", rb_gsl_sf_legendre_H3d_1_e, 2);
363
+ rb_define_module_function(mgsl_sf_leg, "H3d", rb_gsl_sf_legendre_H3d, 3);
364
+ rb_define_module_function(mgsl_sf_leg, "H3d_e", rb_gsl_sf_legendre_H3d_e, 3);
365
+ rb_define_module_function(mgsl_sf_leg, "H3d_array", rb_gsl_sf_legendre_H3d_array, 3);
366
+
367
+ }
@@ -0,0 +1,104 @@
1
+ /*
2
+ sf_log.c
3
+ Ruby/GSL: Ruby extension library for GSL (GNU Scientific Library)
4
+ (C) Copyright 2001-2006 by Yoshiki Tsunesada
5
+
6
+ Ruby/GSL is free software: you can redistribute it and/or modify it
7
+ under the terms of the GNU General Public License.
8
+ This library is distributed in the hope that it will be useful, but
9
+ WITHOUT ANY WARRANTY.
10
+ */
11
+
12
+ #include "rb_gsl_sf.h"
13
+
14
+ static VALUE rb_gsl_sf_log(VALUE obj, VALUE x)
15
+ {
16
+ if (COMPLEX_P(x) || VECTOR_COMPLEX_P(x) || MATRIX_COMPLEX_P(x))
17
+ return rb_gsl_math_complex_eval(gsl_complex_log, x);
18
+ return rb_gsl_sf_eval1(gsl_sf_log, x);
19
+ }
20
+
21
+ static VALUE rb_gsl_sf_log10(VALUE obj, VALUE x)
22
+ {
23
+ if (COMPLEX_P(x) || VECTOR_COMPLEX_P(x) || MATRIX_COMPLEX_P(x))
24
+ return rb_gsl_math_complex_eval(gsl_complex_log10, x);
25
+ return rb_gsl_sf_eval1(log10, x);
26
+ }
27
+
28
+
29
+ static VALUE rb_gsl_sf_log_e(VALUE obj, VALUE x)
30
+ {
31
+ return rb_gsl_sf_eval_e(gsl_sf_log_e, x);
32
+ }
33
+
34
+ static VALUE rb_gsl_sf_log_abs(VALUE obj, VALUE x)
35
+ {
36
+ return rb_gsl_sf_eval1(gsl_sf_log_abs, x);
37
+ }
38
+
39
+ static VALUE rb_gsl_sf_log_abs_e(VALUE obj, VALUE x)
40
+ {
41
+ return rb_gsl_sf_eval_e(gsl_sf_log_abs_e, x);
42
+ }
43
+
44
+ static VALUE rb_gsl_sf_complex_log_e(int argc, VALUE *argv, VALUE obj)
45
+ {
46
+ gsl_sf_result *rslt1 = NULL, *rslt2 = NULL;
47
+ gsl_complex *z = NULL;
48
+ VALUE vlnr, vtheta;
49
+ double re, im;
50
+ int status;
51
+ switch (argc) {
52
+ case 1:
53
+ CHECK_COMPLEX(argv[0]);
54
+ Data_Get_Struct(argv[0], gsl_complex, z);
55
+ re = GSL_REAL(*z);
56
+ im = GSL_IMAG(*z);
57
+ break;
58
+ case 2:
59
+ Need_Float(argv[0]); Need_Float(argv[1]);
60
+ re = NUM2DBL(argv[0]);
61
+ im = NUM2DBL(argv[1]);
62
+ default:
63
+ rb_raise(rb_eArgError, "wrong number of arguments (%d for 1 or 2)", argc);
64
+ break;
65
+ }
66
+ vlnr = Data_Make_Struct(cgsl_sf_result, gsl_sf_result, 0, free, rslt1);
67
+ vtheta = Data_Make_Struct(cgsl_sf_result, gsl_sf_result, 0, free, rslt2);
68
+ status = gsl_sf_complex_log_e(re, im, rslt1, rslt2);
69
+ return rb_ary_new3(2, vlnr, vtheta);
70
+ }
71
+
72
+ static VALUE rb_gsl_sf_log_1plusx(VALUE obj, VALUE x)
73
+ {
74
+ return rb_gsl_sf_eval1(gsl_sf_log_1plusx, x);
75
+ }
76
+
77
+ static VALUE rb_gsl_sf_log_1plusx_e(VALUE obj, VALUE x)
78
+ {
79
+ return rb_gsl_sf_eval_e(gsl_sf_log_1plusx_e, x);
80
+ }
81
+
82
+ static VALUE rb_gsl_sf_log_1plusx_mx(VALUE obj, VALUE x)
83
+ {
84
+ return rb_gsl_sf_eval1(gsl_sf_log_1plusx_mx, x);
85
+ }
86
+
87
+ static VALUE rb_gsl_sf_log_1plusx_mx_e(VALUE obj, VALUE x)
88
+ {
89
+ return rb_gsl_sf_eval_e(gsl_sf_log_1plusx_mx_e, x);
90
+ }
91
+
92
+ void Init_gsl_sf_log(VALUE module)
93
+ {
94
+ rb_define_module_function(module, "log", rb_gsl_sf_log, 1);
95
+ rb_define_module_function(module, "log10", rb_gsl_sf_log10, 1);
96
+ rb_define_module_function(module, "log_e", rb_gsl_sf_log_e, 1);
97
+ rb_define_module_function(module, "log_abs", rb_gsl_sf_log_abs, 1);
98
+ rb_define_module_function(module, "log_abs_e", rb_gsl_sf_log_abs_e, 1);
99
+ rb_define_module_function(module, "complex_log_e", rb_gsl_sf_complex_log_e, -1);
100
+ rb_define_module_function(module, "log_1plusx", rb_gsl_sf_log_1plusx, 1);
101
+ rb_define_module_function(module, "log_1plusx_e", rb_gsl_sf_log_1plusx_e, 1);
102
+ rb_define_module_function(module, "log_1plusx_mx", rb_gsl_sf_log_1plusx_mx, 1);
103
+ rb_define_module_function(module, "log_1plusx_mx_e", rb_gsl_sf_log_1plusx_mx_e, 1);
104
+ }