rb-gsl 1.16.0.5 → 1.16.0.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (612) hide show
  1. checksums.yaml +4 -4
  2. data/rb-gsl.gemspec +5 -10
  3. metadata +10 -713
  4. data/.gitignore +0 -12
  5. data/.travis.yml +0 -24
  6. data/AUTHORS +0 -12
  7. data/COPYING +0 -341
  8. data/ChangeLog +0 -621
  9. data/Gemfile +0 -4
  10. data/README.md +0 -77
  11. data/Rakefile +0 -20
  12. data/THANKS +0 -17
  13. data/examples/alf/alf.gp +0 -15
  14. data/examples/alf/alf.rb +0 -32
  15. data/examples/blas/blas.rb +0 -13
  16. data/examples/blas/dnrm2.rb +0 -16
  17. data/examples/blas/level1.rb +0 -81
  18. data/examples/blas/level2.rb +0 -11
  19. data/examples/blas/level3.rb +0 -12
  20. data/examples/bspline.rb +0 -57
  21. data/examples/cdf.rb +0 -16
  22. data/examples/cheb.rb +0 -21
  23. data/examples/combination.rb +0 -23
  24. data/examples/complex/RC-lpf.rb +0 -47
  25. data/examples/complex/add.rb +0 -36
  26. data/examples/complex/coerce.rb +0 -14
  27. data/examples/complex/complex.rb +0 -25
  28. data/examples/complex/fpmi.rb +0 -70
  29. data/examples/complex/functions.rb +0 -77
  30. data/examples/complex/michelson.rb +0 -36
  31. data/examples/complex/mul.rb +0 -28
  32. data/examples/complex/oscillator.rb +0 -17
  33. data/examples/complex/set.rb +0 -37
  34. data/examples/const/physconst.rb +0 -151
  35. data/examples/const/travel.rb +0 -45
  36. data/examples/deriv/demo.rb +0 -13
  37. data/examples/deriv/deriv.rb +0 -36
  38. data/examples/deriv/diff.rb +0 -35
  39. data/examples/dht.rb +0 -42
  40. data/examples/dirac.rb +0 -56
  41. data/examples/eigen/eigen.rb +0 -34
  42. data/examples/eigen/herm.rb +0 -22
  43. data/examples/eigen/narray.rb +0 -9
  44. data/examples/eigen/nonsymm.rb +0 -37
  45. data/examples/eigen/nonsymmv.rb +0 -43
  46. data/examples/eigen/qhoscillator.gp +0 -35
  47. data/examples/eigen/qhoscillator.rb +0 -90
  48. data/examples/eigen/vander.rb +0 -41
  49. data/examples/fft/fft.rb +0 -17
  50. data/examples/fft/fft2.rb +0 -17
  51. data/examples/fft/forward.rb +0 -25
  52. data/examples/fft/forward2.rb +0 -26
  53. data/examples/fft/radix2.rb +0 -18
  54. data/examples/fft/real-halfcomplex.rb +0 -33
  55. data/examples/fft/real-halfcomplex2.rb +0 -30
  56. data/examples/fft/realradix2.rb +0 -19
  57. data/examples/fft/sunspot.dat +0 -256
  58. data/examples/fft/sunspot.rb +0 -16
  59. data/examples/fit/expdata.dat +0 -20
  60. data/examples/fit/expfit.rb +0 -31
  61. data/examples/fit/gaussfit.rb +0 -29
  62. data/examples/fit/gaussian_2peaks.rb +0 -34
  63. data/examples/fit/hillfit.rb +0 -40
  64. data/examples/fit/lognormal.rb +0 -26
  65. data/examples/fit/lorentzfit.rb +0 -22
  66. data/examples/fit/multifit.rb +0 -72
  67. data/examples/fit/ndlinear.rb +0 -133
  68. data/examples/fit/nonlinearfit.rb +0 -89
  69. data/examples/fit/plot.gp +0 -36
  70. data/examples/fit/polyfit.rb +0 -9
  71. data/examples/fit/powerfit.rb +0 -21
  72. data/examples/fit/sigmoidfit.rb +0 -40
  73. data/examples/fit/sinfit.rb +0 -22
  74. data/examples/fit/wlinear.rb +0 -46
  75. data/examples/fresnel.rb +0 -11
  76. data/examples/function/function.rb +0 -36
  77. data/examples/function/log.rb +0 -7
  78. data/examples/function/min.rb +0 -33
  79. data/examples/function/sin.rb +0 -10
  80. data/examples/function/synchrotron.rb +0 -18
  81. data/examples/gallery/butterfly.rb +0 -7
  82. data/examples/gallery/cayley.rb +0 -12
  83. data/examples/gallery/cornu.rb +0 -23
  84. data/examples/gallery/eight.rb +0 -11
  85. data/examples/gallery/koch.rb +0 -40
  86. data/examples/gallery/lemniscate.rb +0 -11
  87. data/examples/gallery/polar.rb +0 -11
  88. data/examples/gallery/rgplot/cossin.rb +0 -35
  89. data/examples/gallery/rgplot/rgplot.replaced +0 -0
  90. data/examples/gallery/rgplot/roesller.rb +0 -55
  91. data/examples/gallery/roesller.rb +0 -39
  92. data/examples/gallery/scarabaeus.rb +0 -14
  93. data/examples/histogram/cauchy.rb +0 -27
  94. data/examples/histogram/cauchy.sh +0 -2
  95. data/examples/histogram/exponential.rb +0 -19
  96. data/examples/histogram/gauss.rb +0 -16
  97. data/examples/histogram/gsl-histogram.rb +0 -40
  98. data/examples/histogram/histo2d.rb +0 -31
  99. data/examples/histogram/histo3d.rb +0 -34
  100. data/examples/histogram/histogram-pdf.rb +0 -27
  101. data/examples/histogram/histogram.rb +0 -26
  102. data/examples/histogram/integral.rb +0 -28
  103. data/examples/histogram/poisson.rb +0 -27
  104. data/examples/histogram/power.rb +0 -25
  105. data/examples/histogram/rebin.rb +0 -17
  106. data/examples/histogram/smp.dat +0 -5
  107. data/examples/histogram/xexp.rb +0 -21
  108. data/examples/integration/ahmed.rb +0 -21
  109. data/examples/integration/cosmology.rb +0 -75
  110. data/examples/integration/friedmann.gp +0 -16
  111. data/examples/integration/friedmann.rb +0 -35
  112. data/examples/integration/gamma-zeta.rb +0 -35
  113. data/examples/integration/integration.rb +0 -22
  114. data/examples/integration/qag.rb +0 -8
  115. data/examples/integration/qag2.rb +0 -14
  116. data/examples/integration/qag3.rb +0 -8
  117. data/examples/integration/qagi.rb +0 -28
  118. data/examples/integration/qagi2.rb +0 -49
  119. data/examples/integration/qagiu.rb +0 -29
  120. data/examples/integration/qagp.rb +0 -20
  121. data/examples/integration/qags.rb +0 -14
  122. data/examples/integration/qawc.rb +0 -18
  123. data/examples/integration/qawf.rb +0 -41
  124. data/examples/integration/qawo.rb +0 -29
  125. data/examples/integration/qaws.rb +0 -30
  126. data/examples/integration/qng.rb +0 -17
  127. data/examples/interp/demo.gp +0 -20
  128. data/examples/interp/demo.rb +0 -45
  129. data/examples/interp/interp.rb +0 -37
  130. data/examples/interp/points +0 -10
  131. data/examples/interp/spline.rb +0 -20
  132. data/examples/jacobi/deriv.rb +0 -40
  133. data/examples/jacobi/integrate.rb +0 -34
  134. data/examples/jacobi/interp.rb +0 -43
  135. data/examples/jacobi/jacobi.rb +0 -11
  136. data/examples/linalg/HH.rb +0 -15
  137. data/examples/linalg/HH_narray.rb +0 -13
  138. data/examples/linalg/LQ_solve.rb +0 -73
  139. data/examples/linalg/LU.rb +0 -84
  140. data/examples/linalg/LU2.rb +0 -31
  141. data/examples/linalg/LU_narray.rb +0 -24
  142. data/examples/linalg/PTLQ.rb +0 -47
  143. data/examples/linalg/QR.rb +0 -18
  144. data/examples/linalg/QRPT.rb +0 -47
  145. data/examples/linalg/QR_solve.rb +0 -78
  146. data/examples/linalg/QR_solve_narray.rb +0 -13
  147. data/examples/linalg/SV.rb +0 -16
  148. data/examples/linalg/SV_narray.rb +0 -12
  149. data/examples/linalg/SV_solve.rb +0 -49
  150. data/examples/linalg/chol.rb +0 -29
  151. data/examples/linalg/chol_narray.rb +0 -15
  152. data/examples/linalg/complex.rb +0 -57
  153. data/examples/linalg/invert_narray.rb +0 -10
  154. data/examples/math/const.rb +0 -67
  155. data/examples/math/elementary.rb +0 -35
  156. data/examples/math/functions.rb +0 -41
  157. data/examples/math/inf_nan.rb +0 -34
  158. data/examples/math/minmax.rb +0 -22
  159. data/examples/math/power.rb +0 -18
  160. data/examples/math/test.rb +0 -31
  161. data/examples/matrix/a.dat +0 -0
  162. data/examples/matrix/add.rb +0 -45
  163. data/examples/matrix/b.dat +0 -4
  164. data/examples/matrix/cat.rb +0 -31
  165. data/examples/matrix/colvectors.rb +0 -24
  166. data/examples/matrix/complex.rb +0 -41
  167. data/examples/matrix/det.rb +0 -29
  168. data/examples/matrix/diagonal.rb +0 -23
  169. data/examples/matrix/get_all.rb +0 -159
  170. data/examples/matrix/hilbert.rb +0 -31
  171. data/examples/matrix/iterator.rb +0 -19
  172. data/examples/matrix/matrix.rb +0 -57
  173. data/examples/matrix/minmax.rb +0 -53
  174. data/examples/matrix/mul.rb +0 -39
  175. data/examples/matrix/rand.rb +0 -20
  176. data/examples/matrix/read.rb +0 -29
  177. data/examples/matrix/rowcol.rb +0 -47
  178. data/examples/matrix/set.rb +0 -41
  179. data/examples/matrix/set_all.rb +0 -100
  180. data/examples/matrix/view.rb +0 -32
  181. data/examples/matrix/view_all.rb +0 -148
  182. data/examples/matrix/write.rb +0 -23
  183. data/examples/min.rb +0 -29
  184. data/examples/monte/miser.rb +0 -47
  185. data/examples/monte/monte.rb +0 -47
  186. data/examples/monte/plain.rb +0 -47
  187. data/examples/monte/vegas.rb +0 -46
  188. data/examples/multimin/bundle.rb +0 -66
  189. data/examples/multimin/cqp.rb +0 -109
  190. data/examples/multimin/fdfminimizer.rb +0 -40
  191. data/examples/multimin/fminimizer.rb +0 -41
  192. data/examples/multiroot/demo.rb +0 -36
  193. data/examples/multiroot/fdfsolver.rb +0 -50
  194. data/examples/multiroot/fsolver.rb +0 -33
  195. data/examples/multiroot/fsolver2.rb +0 -32
  196. data/examples/multiroot/fsolver3.rb +0 -26
  197. data/examples/narray/histogram.rb +0 -14
  198. data/examples/narray/mandel.rb +0 -27
  199. data/examples/narray/narray.rb +0 -28
  200. data/examples/narray/narray2.rb +0 -44
  201. data/examples/narray/sf.rb +0 -26
  202. data/examples/ntuple/create.rb +0 -17
  203. data/examples/ntuple/project.rb +0 -31
  204. data/examples/odeiv/binarysystem.gp +0 -23
  205. data/examples/odeiv/binarysystem.rb +0 -104
  206. data/examples/odeiv/demo.gp +0 -24
  207. data/examples/odeiv/demo.rb +0 -69
  208. data/examples/odeiv/demo2.gp +0 -26
  209. data/examples/odeiv/duffing.rb +0 -45
  210. data/examples/odeiv/frei1.rb +0 -109
  211. data/examples/odeiv/frei2.rb +0 -76
  212. data/examples/odeiv/legendre.rb +0 -52
  213. data/examples/odeiv/odeiv.rb +0 -32
  214. data/examples/odeiv/odeiv2.rb +0 -45
  215. data/examples/odeiv/oscillator.rb +0 -42
  216. data/examples/odeiv/sedov.rb +0 -97
  217. data/examples/odeiv/whitedwarf.gp +0 -40
  218. data/examples/odeiv/whitedwarf.rb +0 -158
  219. data/examples/ool/conmin.rb +0 -100
  220. data/examples/ool/gencan.rb +0 -99
  221. data/examples/ool/pgrad.rb +0 -100
  222. data/examples/ool/spg.rb +0 -100
  223. data/examples/pdf/bernoulli.rb +0 -5
  224. data/examples/pdf/beta.rb +0 -7
  225. data/examples/pdf/binomiral.rb +0 -10
  226. data/examples/pdf/cauchy.rb +0 -6
  227. data/examples/pdf/chisq.rb +0 -8
  228. data/examples/pdf/exponential.rb +0 -7
  229. data/examples/pdf/exppow.rb +0 -6
  230. data/examples/pdf/fdist.rb +0 -7
  231. data/examples/pdf/flat.rb +0 -7
  232. data/examples/pdf/gamma.rb +0 -8
  233. data/examples/pdf/gauss-tail.rb +0 -5
  234. data/examples/pdf/gauss.rb +0 -6
  235. data/examples/pdf/geometric.rb +0 -5
  236. data/examples/pdf/gumbel.rb +0 -6
  237. data/examples/pdf/hypergeometric.rb +0 -11
  238. data/examples/pdf/landau.rb +0 -5
  239. data/examples/pdf/laplace.rb +0 -7
  240. data/examples/pdf/logarithmic.rb +0 -5
  241. data/examples/pdf/logistic.rb +0 -6
  242. data/examples/pdf/lognormal.rb +0 -6
  243. data/examples/pdf/neg-binomiral.rb +0 -10
  244. data/examples/pdf/pareto.rb +0 -7
  245. data/examples/pdf/pascal.rb +0 -10
  246. data/examples/pdf/poisson.rb +0 -5
  247. data/examples/pdf/rayleigh-tail.rb +0 -6
  248. data/examples/pdf/rayleigh.rb +0 -6
  249. data/examples/pdf/tdist.rb +0 -6
  250. data/examples/pdf/weibull.rb +0 -8
  251. data/examples/permutation/ex1.rb +0 -22
  252. data/examples/permutation/permutation.rb +0 -16
  253. data/examples/poly/bell.rb +0 -6
  254. data/examples/poly/bessel.rb +0 -6
  255. data/examples/poly/cheb.rb +0 -6
  256. data/examples/poly/cheb_II.rb +0 -6
  257. data/examples/poly/cubic.rb +0 -9
  258. data/examples/poly/demo.rb +0 -20
  259. data/examples/poly/eval.rb +0 -28
  260. data/examples/poly/eval_derivs.rb +0 -14
  261. data/examples/poly/fit.rb +0 -21
  262. data/examples/poly/hermite.rb +0 -6
  263. data/examples/poly/poly.rb +0 -13
  264. data/examples/poly/quadratic.rb +0 -25
  265. data/examples/random/diffusion.rb +0 -34
  266. data/examples/random/gaussian.rb +0 -9
  267. data/examples/random/generator.rb +0 -27
  268. data/examples/random/hdsobol.rb +0 -21
  269. data/examples/random/poisson.rb +0 -9
  270. data/examples/random/qrng.rb +0 -19
  271. data/examples/random/randomwalk.rb +0 -37
  272. data/examples/random/randomwalk2d.rb +0 -19
  273. data/examples/random/rayleigh.rb +0 -36
  274. data/examples/random/rng.rb +0 -33
  275. data/examples/random/rngextra.rb +0 -14
  276. data/examples/roots/bisection.rb +0 -25
  277. data/examples/roots/brent.rb +0 -43
  278. data/examples/roots/demo.rb +0 -30
  279. data/examples/roots/newton.rb +0 -46
  280. data/examples/roots/recombination.gp +0 -11
  281. data/examples/roots/recombination.rb +0 -61
  282. data/examples/roots/steffenson.rb +0 -48
  283. data/examples/sf/ShiChi.rb +0 -6
  284. data/examples/sf/SiCi.rb +0 -6
  285. data/examples/sf/airy_Ai.rb +0 -8
  286. data/examples/sf/airy_Bi.rb +0 -8
  287. data/examples/sf/bessel_IK.rb +0 -12
  288. data/examples/sf/bessel_JY.rb +0 -13
  289. data/examples/sf/beta_inc.rb +0 -9
  290. data/examples/sf/clausen.rb +0 -6
  291. data/examples/sf/dawson.rb +0 -5
  292. data/examples/sf/debye.rb +0 -9
  293. data/examples/sf/dilog.rb +0 -6
  294. data/examples/sf/ellint.rb +0 -6
  295. data/examples/sf/expint.rb +0 -8
  296. data/examples/sf/fermi.rb +0 -10
  297. data/examples/sf/gamma_inc_P.rb +0 -9
  298. data/examples/sf/gegenbauer.rb +0 -8
  299. data/examples/sf/hyperg.rb +0 -7
  300. data/examples/sf/laguerre.rb +0 -19
  301. data/examples/sf/lambertW.rb +0 -5
  302. data/examples/sf/legendre_P.rb +0 -10
  303. data/examples/sf/lngamma.rb +0 -5
  304. data/examples/sf/psi.rb +0 -54
  305. data/examples/sf/sphbessel.gp +0 -27
  306. data/examples/sf/sphbessel.rb +0 -30
  307. data/examples/sf/synchrotron.rb +0 -5
  308. data/examples/sf/transport.rb +0 -10
  309. data/examples/sf/zetam1.rb +0 -5
  310. data/examples/siman.rb +0 -44
  311. data/examples/sort/heapsort.rb +0 -23
  312. data/examples/sort/heapsort_vector_complex.rb +0 -21
  313. data/examples/sort/sort.rb +0 -23
  314. data/examples/sort/sort2.rb +0 -16
  315. data/examples/stats/mean.rb +0 -17
  316. data/examples/stats/statistics.rb +0 -18
  317. data/examples/stats/test.rb +0 -9
  318. data/examples/sum.rb +0 -34
  319. data/examples/tamu_anova.rb +0 -18
  320. data/examples/vector/a.dat +0 -0
  321. data/examples/vector/add.rb +0 -56
  322. data/examples/vector/b.dat +0 -4
  323. data/examples/vector/c.dat +0 -3
  324. data/examples/vector/collect.rb +0 -26
  325. data/examples/vector/compare.rb +0 -28
  326. data/examples/vector/complex.rb +0 -51
  327. data/examples/vector/complex_get_all.rb +0 -85
  328. data/examples/vector/complex_set_all.rb +0 -131
  329. data/examples/vector/complex_view_all.rb +0 -77
  330. data/examples/vector/connect.rb +0 -22
  331. data/examples/vector/decimate.rb +0 -38
  332. data/examples/vector/diff.rb +0 -31
  333. data/examples/vector/filescan.rb +0 -17
  334. data/examples/vector/floor.rb +0 -23
  335. data/examples/vector/get_all.rb +0 -82
  336. data/examples/vector/gnuplot.rb +0 -38
  337. data/examples/vector/graph.rb +0 -28
  338. data/examples/vector/histogram.rb +0 -22
  339. data/examples/vector/linspace.rb +0 -24
  340. data/examples/vector/log.rb +0 -17
  341. data/examples/vector/logic.rb +0 -33
  342. data/examples/vector/logspace.rb +0 -25
  343. data/examples/vector/minmax.rb +0 -47
  344. data/examples/vector/mul.rb +0 -49
  345. data/examples/vector/narray.rb +0 -46
  346. data/examples/vector/read.rb +0 -29
  347. data/examples/vector/set.rb +0 -35
  348. data/examples/vector/set_all.rb +0 -121
  349. data/examples/vector/smpv.dat +0 -15
  350. data/examples/vector/test.rb +0 -43
  351. data/examples/vector/test_gslblock.rb +0 -58
  352. data/examples/vector/vector.rb +0 -110
  353. data/examples/vector/view.rb +0 -35
  354. data/examples/vector/view_all.rb +0 -73
  355. data/examples/vector/where.rb +0 -29
  356. data/examples/vector/write.rb +0 -24
  357. data/examples/vector/zip.rb +0 -34
  358. data/examples/wavelet/ecg.dat +0 -256
  359. data/examples/wavelet/wavelet1.rb +0 -50
  360. data/ext/gsl_native/alf.c +0 -206
  361. data/ext/gsl_native/array.c +0 -553
  362. data/ext/gsl_native/array_complex.c +0 -245
  363. data/ext/gsl_native/blas.c +0 -28
  364. data/ext/gsl_native/blas1.c +0 -733
  365. data/ext/gsl_native/blas2.c +0 -1088
  366. data/ext/gsl_native/blas3.c +0 -880
  367. data/ext/gsl_native/block.c +0 -40
  368. data/ext/gsl_native/block_source.h +0 -885
  369. data/ext/gsl_native/bspline.c +0 -122
  370. data/ext/gsl_native/bundle.c +0 -3
  371. data/ext/gsl_native/cdf.c +0 -740
  372. data/ext/gsl_native/cheb.c +0 -531
  373. data/ext/gsl_native/combination.c +0 -275
  374. data/ext/gsl_native/common.c +0 -293
  375. data/ext/gsl_native/complex.c +0 -1002
  376. data/ext/gsl_native/const.c +0 -331
  377. data/ext/gsl_native/const_additional.c +0 -99
  378. data/ext/gsl_native/cqp.c +0 -283
  379. data/ext/gsl_native/deriv.c +0 -187
  380. data/ext/gsl_native/dht.c +0 -353
  381. data/ext/gsl_native/diff.c +0 -164
  382. data/ext/gsl_native/dirac.c +0 -388
  383. data/ext/gsl_native/eigen.c +0 -2322
  384. data/ext/gsl_native/error.c +0 -193
  385. data/ext/gsl_native/extconf.rb +0 -118
  386. data/ext/gsl_native/fft.c +0 -1095
  387. data/ext/gsl_native/fit.c +0 -204
  388. data/ext/gsl_native/fresnel.c +0 -312
  389. data/ext/gsl_native/function.c +0 -518
  390. data/ext/gsl_native/geometry.c +0 -139
  391. data/ext/gsl_native/graph.c +0 -1590
  392. data/ext/gsl_native/gsl.c +0 -259
  393. data/ext/gsl_native/gsl_narray.c +0 -794
  394. data/ext/gsl_native/histogram.c +0 -1964
  395. data/ext/gsl_native/histogram2d.c +0 -1042
  396. data/ext/gsl_native/histogram3d.c +0 -884
  397. data/ext/gsl_native/histogram3d_source.c +0 -749
  398. data/ext/gsl_native/histogram_find.c +0 -99
  399. data/ext/gsl_native/histogram_oper.c +0 -150
  400. data/ext/gsl_native/ieee.c +0 -88
  401. data/ext/gsl_native/include/rb_gsl.h +0 -136
  402. data/ext/gsl_native/include/rb_gsl_array.h +0 -214
  403. data/ext/gsl_native/include/rb_gsl_cheb.h +0 -19
  404. data/ext/gsl_native/include/rb_gsl_common.h +0 -348
  405. data/ext/gsl_native/include/rb_gsl_complex.h +0 -25
  406. data/ext/gsl_native/include/rb_gsl_const.h +0 -23
  407. data/ext/gsl_native/include/rb_gsl_dirac.h +0 -6
  408. data/ext/gsl_native/include/rb_gsl_eigen.h +0 -17
  409. data/ext/gsl_native/include/rb_gsl_fft.h +0 -49
  410. data/ext/gsl_native/include/rb_gsl_fit.h +0 -23
  411. data/ext/gsl_native/include/rb_gsl_function.h +0 -23
  412. data/ext/gsl_native/include/rb_gsl_graph.h +0 -68
  413. data/ext/gsl_native/include/rb_gsl_histogram.h +0 -63
  414. data/ext/gsl_native/include/rb_gsl_histogram3d.h +0 -97
  415. data/ext/gsl_native/include/rb_gsl_integration.h +0 -17
  416. data/ext/gsl_native/include/rb_gsl_interp.h +0 -41
  417. data/ext/gsl_native/include/rb_gsl_linalg.h +0 -21
  418. data/ext/gsl_native/include/rb_gsl_math.h +0 -20
  419. data/ext/gsl_native/include/rb_gsl_odeiv.h +0 -18
  420. data/ext/gsl_native/include/rb_gsl_poly.h +0 -67
  421. data/ext/gsl_native/include/rb_gsl_rational.h +0 -30
  422. data/ext/gsl_native/include/rb_gsl_rng.h +0 -20
  423. data/ext/gsl_native/include/rb_gsl_root.h +0 -22
  424. data/ext/gsl_native/include/rb_gsl_sf.h +0 -110
  425. data/ext/gsl_native/include/rb_gsl_statistics.h +0 -17
  426. data/ext/gsl_native/include/rb_gsl_tensor.h +0 -43
  427. data/ext/gsl_native/include/rb_gsl_with_narray.h +0 -31
  428. data/ext/gsl_native/include/templates_off.h +0 -87
  429. data/ext/gsl_native/include/templates_on.h +0 -241
  430. data/ext/gsl_native/integration.c +0 -1154
  431. data/ext/gsl_native/interp.c +0 -499
  432. data/ext/gsl_native/jacobi.c +0 -733
  433. data/ext/gsl_native/linalg.c +0 -3915
  434. data/ext/gsl_native/linalg_complex.c +0 -726
  435. data/ext/gsl_native/math.c +0 -706
  436. data/ext/gsl_native/matrix.c +0 -36
  437. data/ext/gsl_native/matrix_complex.c +0 -1733
  438. data/ext/gsl_native/matrix_double.c +0 -557
  439. data/ext/gsl_native/matrix_int.c +0 -255
  440. data/ext/gsl_native/matrix_source.h +0 -2708
  441. data/ext/gsl_native/min.c +0 -219
  442. data/ext/gsl_native/monte.c +0 -978
  443. data/ext/gsl_native/multifit.c +0 -1862
  444. data/ext/gsl_native/multimin.c +0 -778
  445. data/ext/gsl_native/multimin_fsdf.c +0 -156
  446. data/ext/gsl_native/multiroots.c +0 -952
  447. data/ext/gsl_native/multiset.c +0 -210
  448. data/ext/gsl_native/ndlinear.c +0 -320
  449. data/ext/gsl_native/nmf.c +0 -171
  450. data/ext/gsl_native/nmf_wrap.c +0 -75
  451. data/ext/gsl_native/ntuple.c +0 -469
  452. data/ext/gsl_native/odeiv.c +0 -947
  453. data/ext/gsl_native/ool.c +0 -879
  454. data/ext/gsl_native/permutation.c +0 -598
  455. data/ext/gsl_native/poly.c +0 -39
  456. data/ext/gsl_native/poly2.c +0 -265
  457. data/ext/gsl_native/poly_source.h +0 -1871
  458. data/ext/gsl_native/qrng.c +0 -160
  459. data/ext/gsl_native/randist.c +0 -1848
  460. data/ext/gsl_native/rational.c +0 -480
  461. data/ext/gsl_native/rng.c +0 -595
  462. data/ext/gsl_native/root.c +0 -407
  463. data/ext/gsl_native/sf.c +0 -1446
  464. data/ext/gsl_native/sf_airy.c +0 -200
  465. data/ext/gsl_native/sf_bessel.c +0 -871
  466. data/ext/gsl_native/sf_clausen.c +0 -28
  467. data/ext/gsl_native/sf_coulomb.c +0 -206
  468. data/ext/gsl_native/sf_coupling.c +0 -121
  469. data/ext/gsl_native/sf_dawson.c +0 -29
  470. data/ext/gsl_native/sf_debye.c +0 -148
  471. data/ext/gsl_native/sf_dilog.c +0 -43
  472. data/ext/gsl_native/sf_elementary.c +0 -46
  473. data/ext/gsl_native/sf_ellint.c +0 -206
  474. data/ext/gsl_native/sf_elljac.c +0 -30
  475. data/ext/gsl_native/sf_erfc.c +0 -89
  476. data/ext/gsl_native/sf_exp.c +0 -169
  477. data/ext/gsl_native/sf_expint.c +0 -201
  478. data/ext/gsl_native/sf_fermi_dirac.c +0 -148
  479. data/ext/gsl_native/sf_gamma.c +0 -343
  480. data/ext/gsl_native/sf_gegenbauer.c +0 -97
  481. data/ext/gsl_native/sf_hyperg.c +0 -203
  482. data/ext/gsl_native/sf_laguerre.c +0 -113
  483. data/ext/gsl_native/sf_lambert.c +0 -47
  484. data/ext/gsl_native/sf_legendre.c +0 -368
  485. data/ext/gsl_native/sf_log.c +0 -105
  486. data/ext/gsl_native/sf_mathieu.c +0 -235
  487. data/ext/gsl_native/sf_power.c +0 -47
  488. data/ext/gsl_native/sf_psi.c +0 -89
  489. data/ext/gsl_native/sf_synchrotron.c +0 -48
  490. data/ext/gsl_native/sf_transport.c +0 -76
  491. data/ext/gsl_native/sf_trigonometric.c +0 -210
  492. data/ext/gsl_native/sf_zeta.c +0 -115
  493. data/ext/gsl_native/signal.c +0 -303
  494. data/ext/gsl_native/siman.c +0 -713
  495. data/ext/gsl_native/sort.c +0 -207
  496. data/ext/gsl_native/spline.c +0 -377
  497. data/ext/gsl_native/stats.c +0 -787
  498. data/ext/gsl_native/sum.c +0 -168
  499. data/ext/gsl_native/tamu_anova.c +0 -56
  500. data/ext/gsl_native/tensor.c +0 -35
  501. data/ext/gsl_native/tensor_source.h +0 -1122
  502. data/ext/gsl_native/vector.c +0 -35
  503. data/ext/gsl_native/vector_complex.c +0 -2241
  504. data/ext/gsl_native/vector_double.c +0 -1433
  505. data/ext/gsl_native/vector_int.c +0 -202
  506. data/ext/gsl_native/vector_source.h +0 -3321
  507. data/ext/gsl_native/wavelet.c +0 -923
  508. data/lib/gsl.rb +0 -8
  509. data/lib/gsl/gnuplot.rb +0 -41
  510. data/lib/gsl/oper.rb +0 -43
  511. data/lib/gsl/version.rb +0 -3
  512. data/lib/ool.rb +0 -22
  513. data/lib/ool/conmin.rb +0 -30
  514. data/lib/rbgsl.rb +0 -1
  515. data/rdoc/alf.rdoc +0 -77
  516. data/rdoc/blas.rdoc +0 -269
  517. data/rdoc/bspline.rdoc +0 -42
  518. data/rdoc/changes.rdoc +0 -159
  519. data/rdoc/cheb.rdoc +0 -99
  520. data/rdoc/cholesky_complex.rdoc +0 -46
  521. data/rdoc/combi.rdoc +0 -125
  522. data/rdoc/complex.rdoc +0 -210
  523. data/rdoc/const.rdoc +0 -546
  524. data/rdoc/dht.rdoc +0 -122
  525. data/rdoc/diff.rdoc +0 -133
  526. data/rdoc/ehandling.rdoc +0 -50
  527. data/rdoc/eigen.rdoc +0 -401
  528. data/rdoc/fft.rdoc +0 -535
  529. data/rdoc/fit.rdoc +0 -284
  530. data/rdoc/function.rdoc +0 -94
  531. data/rdoc/graph.rdoc +0 -137
  532. data/rdoc/hist.rdoc +0 -409
  533. data/rdoc/hist2d.rdoc +0 -279
  534. data/rdoc/hist3d.rdoc +0 -112
  535. data/rdoc/integration.rdoc +0 -398
  536. data/rdoc/interp.rdoc +0 -231
  537. data/rdoc/intro.rdoc +0 -27
  538. data/rdoc/linalg.rdoc +0 -681
  539. data/rdoc/linalg_complex.rdoc +0 -88
  540. data/rdoc/math.rdoc +0 -276
  541. data/rdoc/matrix.rdoc +0 -1093
  542. data/rdoc/min.rdoc +0 -189
  543. data/rdoc/monte.rdoc +0 -234
  544. data/rdoc/multimin.rdoc +0 -312
  545. data/rdoc/multiroot.rdoc +0 -293
  546. data/rdoc/narray.rdoc +0 -177
  547. data/rdoc/ndlinear.rdoc +0 -250
  548. data/rdoc/nonlinearfit.rdoc +0 -348
  549. data/rdoc/ntuple.rdoc +0 -88
  550. data/rdoc/odeiv.rdoc +0 -378
  551. data/rdoc/perm.rdoc +0 -221
  552. data/rdoc/poly.rdoc +0 -335
  553. data/rdoc/qrng.rdoc +0 -90
  554. data/rdoc/randist.rdoc +0 -233
  555. data/rdoc/ref.rdoc +0 -93
  556. data/rdoc/rng.rdoc +0 -203
  557. data/rdoc/roots.rdoc +0 -305
  558. data/rdoc/sf.rdoc +0 -1622
  559. data/rdoc/siman.rdoc +0 -89
  560. data/rdoc/sort.rdoc +0 -94
  561. data/rdoc/start.rdoc +0 -16
  562. data/rdoc/stats.rdoc +0 -219
  563. data/rdoc/sum.rdoc +0 -65
  564. data/rdoc/tensor.rdoc +0 -251
  565. data/rdoc/tut.rdoc +0 -5
  566. data/rdoc/use.rdoc +0 -177
  567. data/rdoc/vector.rdoc +0 -1243
  568. data/rdoc/vector_complex.rdoc +0 -347
  569. data/rdoc/wavelet.rdoc +0 -218
  570. data/test/gsl/blas_test.rb +0 -79
  571. data/test/gsl/bspline_test.rb +0 -63
  572. data/test/gsl/cdf_test.rb +0 -1512
  573. data/test/gsl/cheb_test.rb +0 -80
  574. data/test/gsl/combination_test.rb +0 -100
  575. data/test/gsl/complex_test.rb +0 -20
  576. data/test/gsl/const_test.rb +0 -29
  577. data/test/gsl/deriv_test.rb +0 -62
  578. data/test/gsl/dht_test.rb +0 -79
  579. data/test/gsl/diff_test.rb +0 -53
  580. data/test/gsl/eigen_test.rb +0 -563
  581. data/test/gsl/err_test.rb +0 -23
  582. data/test/gsl/fit_test.rb +0 -101
  583. data/test/gsl/histo_test.rb +0 -14
  584. data/test/gsl/index_test.rb +0 -61
  585. data/test/gsl/integration_test.rb +0 -274
  586. data/test/gsl/interp_test.rb +0 -27
  587. data/test/gsl/linalg_test.rb +0 -463
  588. data/test/gsl/matrix_nmf_test.rb +0 -37
  589. data/test/gsl/matrix_test.rb +0 -98
  590. data/test/gsl/min_test.rb +0 -89
  591. data/test/gsl/monte_test.rb +0 -77
  592. data/test/gsl/multifit_test.rb +0 -753
  593. data/test/gsl/multimin_test.rb +0 -157
  594. data/test/gsl/multiroot_test.rb +0 -135
  595. data/test/gsl/multiset_test.rb +0 -52
  596. data/test/gsl/odeiv_test.rb +0 -275
  597. data/test/gsl/oper_test.rb +0 -98
  598. data/test/gsl/poly_test.rb +0 -338
  599. data/test/gsl/qrng_test.rb +0 -94
  600. data/test/gsl/quartic_test.rb +0 -28
  601. data/test/gsl/randist_test.rb +0 -122
  602. data/test/gsl/rng_test.rb +0 -303
  603. data/test/gsl/roots_test.rb +0 -78
  604. data/test/gsl/sf_test.rb +0 -2079
  605. data/test/gsl/stats_test.rb +0 -122
  606. data/test/gsl/sum_test.rb +0 -69
  607. data/test/gsl/tensor_test.rb +0 -396
  608. data/test/gsl/vector_test.rb +0 -223
  609. data/test/gsl/wavelet_test.rb +0 -130
  610. data/test/gsl_test.rb +0 -321
  611. data/test/test_helper.rb +0 -42
  612. data/uncrustify.cfg +0 -1693
@@ -1,35 +0,0 @@
1
- /*
2
- vector.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
- /*
13
- This code uses "templates_on.h" and "templates_off.h",
14
- which are provided by the GSL source.
15
- */
16
-
17
- #include "include/rb_gsl_array.h"
18
- #include "include/rb_gsl_histogram.h"
19
- #include "include/rb_gsl_complex.h"
20
- #include "include/rb_gsl_poly.h"
21
- #include "include/rb_gsl_with_narray.h"
22
-
23
- #define BASE_DOUBLE
24
- #include "include/templates_on.h"
25
- #include "vector_source.h"
26
- #include "include/templates_off.h"
27
- #undef BASE_DOUBLE
28
-
29
- #define BASE_INT
30
- #include "include/templates_on.h"
31
- #include "vector_source.h"
32
- #include "include/templates_off.h"
33
- #undef BASE_INT
34
-
35
-
@@ -1,2241 +0,0 @@
1
- /*
2
- vector_complex.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 "include/rb_gsl_array.h"
13
- #include "include/rb_gsl_complex.h"
14
-
15
- EXTERN VALUE cgsl_complex;
16
- static VALUE rb_gsl_vector_complex_inner_product(int argc, VALUE *argv, VALUE obj);
17
- static VALUE rb_gsl_vector_complex_product_to_m(int argc, VALUE *argv, VALUE obj);
18
-
19
- // From vector_source.c
20
- void get_range_beg_en_n(VALUE range, double *beg, double *en, size_t *n, int *step);
21
- //
22
- // From vector_source.c
23
- void parse_subvector_args(int argc, VALUE *argv, size_t size,
24
- size_t *offset, size_t *stride, size_t *n);
25
-
26
- // From complex.c
27
- gsl_complex rb_gsl_obj_to_gsl_complex(VALUE obj, gsl_complex *z);
28
-
29
- static VALUE rb_gsl_vector_complex_new(int argc, VALUE *argv, VALUE klass)
30
- {
31
- VALUE tmp;
32
- gsl_vector_complex *v = NULL;
33
- gsl_vector *x, *y;
34
- gsl_complex z, *z2 = NULL;
35
- size_t n, i;
36
- switch (argc) {
37
- case 1:
38
- switch (TYPE(argv[0])) {
39
- case T_FIXNUM:
40
- n = FIX2INT(argv[0]);
41
- v = gsl_vector_complex_calloc(n);
42
- if (v == NULL) rb_raise(rb_eNoMemError, "gsl_vector_complex_alloc failed");
43
- break;
44
- case T_ARRAY:
45
- n = RARRAY_LEN(argv[0]);
46
- v = gsl_vector_complex_alloc(n);
47
- if (v == NULL) rb_raise(rb_eNoMemError, "gsl_vector_complex_alloc failed");
48
- for (i = 0; i < n; i++) {
49
- z2 = &z;
50
- tmp = rb_ary_entry(argv[0], i);
51
- if (TYPE(tmp) == T_ARRAY) {
52
- GSL_SET_REAL(z2, NUM2DBL(rb_ary_entry(tmp, 0)));
53
- GSL_SET_IMAG(z2, NUM2DBL(rb_ary_entry(tmp, 1)));
54
- } else if (COMPLEX_P(tmp)) {
55
- Data_Get_Struct(tmp, gsl_complex, z2);
56
- } else {
57
- rb_raise(rb_eTypeError,
58
- "wrong argument type %s (Array or Complex expected)",
59
- rb_class2name(CLASS_OF(tmp)));
60
-
61
- }
62
- gsl_vector_complex_set(v, i, *z2);
63
- }
64
- break;
65
- default:
66
- rb_raise(rb_eTypeError,
67
- "wrong argument type %s", rb_class2name(CLASS_OF(argv[0])));
68
- break;
69
- }
70
- break;
71
- default:
72
- if (argc == 2 && (VECTOR_P(argv[0]) && VECTOR_P(argv[1]))) {
73
- Data_Get_Struct(argv[0], gsl_vector, x);
74
- Data_Get_Struct(argv[1], gsl_vector, y);
75
- n = GSL_MIN_INT(x->size, y->size);
76
- v = gsl_vector_complex_alloc(n);
77
- for (i = 0; i < n; i++) {
78
- z.dat[0] = gsl_vector_get(x, i);
79
- z.dat[1] = gsl_vector_get(y, i);
80
- gsl_vector_complex_set(v, i, z);
81
- }
82
- break;
83
- }
84
- n = argc;
85
- v = gsl_vector_complex_alloc(n);
86
- if (v == NULL) rb_raise(rb_eNoMemError, "gsl_vector_complex_alloc failed");
87
- for (i = 0; i < n; i++) {
88
- if (TYPE(argv[i]) == T_ARRAY) {
89
- GSL_SET_REAL(&z, NUM2DBL(rb_ary_entry(argv[i], 0)));
90
- GSL_SET_IMAG(&z, NUM2DBL(rb_ary_entry(argv[i], 1)));
91
- z2 = &z;
92
- } else if (COMPLEX_P(argv[i])) {
93
- Data_Get_Struct(argv[i], gsl_complex, z2);
94
- } else {
95
- rb_raise(rb_eTypeError,
96
- "wrong argument type %s (Array or Complex expected)",
97
- rb_class2name(CLASS_OF(argv[i])));
98
- }
99
- gsl_vector_complex_set(v, i, *z2);
100
- }
101
- break;
102
- }
103
- return Data_Wrap_Struct(klass, 0, gsl_vector_complex_free, v);
104
- }
105
-
106
- static VALUE rb_gsl_vector_complex_row_new(int argc, VALUE *argv, VALUE klass)
107
- {
108
- return rb_gsl_vector_complex_new(argc, argv, klass);
109
- }
110
-
111
- static VALUE rb_gsl_vector_complex_calloc(VALUE klass, VALUE nn)
112
- {
113
- gsl_vector_complex *vc = NULL;
114
- CHECK_FIXNUM(nn);
115
- vc = gsl_vector_complex_calloc(FIX2INT(nn));
116
- if (vc == NULL) rb_raise(rb_eNoMemError, "gsl_vector_complex_alloc failed");
117
- return Data_Wrap_Struct(klass, 0, gsl_vector_complex_free, vc);
118
- }
119
-
120
- static VALUE rb_gsl_vector_complex_size(VALUE obj)
121
- {
122
- gsl_vector_complex *v = NULL;
123
- Data_Get_Struct(obj, gsl_vector_complex, v);
124
- return INT2FIX(v->size);
125
- }
126
-
127
- static VALUE rb_gsl_vector_complex_stride(VALUE obj)
128
- {
129
- gsl_vector_complex *v = NULL;
130
- Data_Get_Struct(obj, gsl_vector_complex, v);
131
- return INT2FIX(v->stride);
132
- }
133
-
134
- static VALUE rb_gsl_vector_complex_owner(VALUE obj)
135
- {
136
- gsl_vector_complex *v = NULL;
137
- Data_Get_Struct(obj, gsl_vector_complex, v);
138
- return INT2FIX(v->owner);
139
- }
140
-
141
- static VALUE rb_gsl_vector_complex_ptr(VALUE obj, VALUE i)
142
- {
143
- gsl_vector_complex *v = NULL;
144
- Data_Get_Struct(obj, gsl_vector_complex, v);
145
- return Data_Wrap_Struct(cgsl_complex, 0, NULL, gsl_vector_complex_ptr(v, FIX2INT(i)));
146
- }
147
-
148
- // TODO return Data_Wrap_Struct(VECTOR_COMPLEX_ROW_COL(obj),..." where appropriate
149
- static VALUE rb_gsl_vector_complex_subvector(int argc, VALUE *argv, VALUE obj);
150
- static VALUE rb_gsl_vector_complex_get(int argc, VALUE *argv, VALUE obj)
151
- {
152
- VALUE retval = Qnil;
153
- gsl_vector_complex *v = NULL, *vnew;
154
- gsl_complex *c = NULL;
155
- gsl_index *p;
156
- int i, k;
157
- size_t index, j;
158
- // If argc is not 1 or argv[0] is a Range
159
- if( argc != 1 || rb_obj_is_kind_of(argv[0], rb_cRange)) {
160
- // Treat as call to subvector
161
- retval = rb_gsl_vector_complex_subvector(argc, argv, obj);
162
- } else {
163
- Data_Get_Struct(obj, gsl_vector_complex, v);
164
-
165
- switch (TYPE(argv[0])) {
166
- case T_FIXNUM:
167
- CHECK_FIXNUM(argv[0]);
168
- i = FIX2INT(argv[0]);
169
- if (i < 0) index = (size_t) (v->size + i);
170
- else index = (size_t) i;
171
- c = ALLOC(gsl_complex);
172
- *c = gsl_vector_complex_get(v, index);
173
- retval = Data_Wrap_Struct(cgsl_complex, 0, free, c);
174
- break;
175
- case T_ARRAY:
176
- vnew = gsl_vector_complex_alloc(RARRAY_LEN(argv[0]));
177
- for (j = 0; j < vnew->size; j++) {
178
- i = FIX2INT(rb_ary_entry(argv[0], j));
179
- if (i < 0) i = v->size + i;
180
- gsl_vector_complex_set(vnew, j, gsl_vector_complex_get(v, i));
181
- }
182
- retval = Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
183
- break;
184
- default:
185
- if (PERMUTATION_P(argv[0])) {
186
- Data_Get_Struct(argv[0], gsl_index, p);
187
- vnew = gsl_vector_complex_alloc(p->size);
188
- for (j = 0; j < p->size; j++) {
189
- k = p->data[j];
190
- if (k < 0) k = p->size + j;
191
- gsl_vector_complex_set(vnew, j, gsl_vector_complex_get(v, k));
192
- }
193
- retval = Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
194
- } else {
195
- // TODO Support Vector::Int (and even Vector?)
196
- rb_raise(rb_eTypeError, "wrong argument type %s (Array, Range, GSL::Permutation, or Fixnum expected)", rb_class2name(CLASS_OF(argv[0])));
197
- }
198
- break;
199
- }
200
- }
201
- return retval;
202
- }
203
-
204
- static VALUE rb_gsl_vector_complex_set_all(int argc, VALUE *argv, VALUE obj)
205
- {
206
- gsl_vector_complex *v = NULL;
207
- gsl_complex tmp;
208
-
209
- if (argc < 1) rb_raise(rb_eArgError, "wrong number of arguments");
210
- Data_Get_Struct(obj, gsl_vector_complex, v);
211
-
212
- switch (argc) {
213
- case 1:
214
- tmp = rb_gsl_obj_to_gsl_complex(argv[0], NULL);
215
- break;
216
- case 2:
217
- GSL_SET_COMPLEX(&tmp, NUM2DBL(argv[0]), NUM2DBL(argv[1]));
218
- break;
219
- default:
220
- rb_raise(rb_eArgError, "wrong number of arguments");
221
- break;
222
- }
223
-
224
- gsl_vector_complex_set_all(v, tmp);
225
-
226
- return obj;
227
- }
228
-
229
- void rb_gsl_vector_complex_set_subvector(int argc, VALUE *argv, gsl_vector_complex *v, VALUE other)
230
- {
231
- gsl_vector_complex *vother;
232
- gsl_vector_complex_view vv;
233
- gsl_complex tmp;
234
- int step;
235
- size_t i, offset, stride, n, nother;
236
- double beg, end;
237
-
238
- // assignment to v.subvector(...)
239
- parse_subvector_args(argc, argv, v->size, &offset, &stride, &n);
240
- vv = gsl_vector_complex_subvector_with_stride(v, offset, stride, n);
241
- if(rb_obj_is_kind_of(other, cgsl_vector_complex)) {
242
- Data_Get_Struct(other, gsl_vector_complex, vother);
243
- if(n != vother->size) {
244
- rb_raise(rb_eRangeError, "lengths do not match (%d != %d)", (int) n, (int) vother->size);
245
- }
246
- // TODO Change to gsl_vector_complex_memmove if/when GSL has such a
247
- // function because gsl_vector_memcpy does not handle overlapping regions
248
- // (e.g. Views) well.
249
- gsl_vector_complex_memcpy(&vv.vector, vother);
250
- } else if(rb_obj_is_kind_of(other, rb_cArray)) {
251
- // TODO Support other forms of Array contents as well
252
- if((int) n != RARRAY_LEN(other)) {
253
- rb_raise(rb_eRangeError, "lengths do not match (%d != %d)", (int) n, (int) RARRAY_LEN(other));
254
- }
255
- for(i = 0; i < n; i++) {
256
- tmp = rb_gsl_obj_to_gsl_complex(rb_ary_entry(other, i), NULL);
257
- gsl_vector_complex_set(&vv.vector, i, tmp);
258
- }
259
- } else if(rb_obj_is_kind_of(other, rb_cRange)) {
260
- get_range_beg_en_n(other, &beg, &end, &nother, &step);
261
- if(n != nother) {
262
- rb_raise(rb_eRangeError, "lengths do not match (%d != %d)", (int) n, (int) nother);
263
- }
264
- GSL_SET_IMAG(&tmp, 0.0);
265
- for(i = 0; i < n; i++) {
266
- GSL_SET_REAL(&tmp, beg);
267
- gsl_vector_complex_set(&vv.vector, i, tmp);
268
- beg += step;
269
- }
270
- } else {
271
- tmp = rb_gsl_obj_to_gsl_complex(argv[1], NULL);
272
- gsl_vector_complex_set_all(&vv.vector, tmp);
273
- }
274
- }
275
-
276
- static VALUE rb_gsl_vector_complex_set(int argc, VALUE *argv, VALUE obj)
277
- {
278
- gsl_vector_complex *v = NULL;
279
- gsl_complex tmp;
280
- VALUE other;
281
- int ii;
282
-
283
- if(argc < 1 || argc > 4) {
284
- rb_raise(rb_eArgError, "wrong number of arguments (%d for 1-4)", argc);
285
- }
286
- Data_Get_Struct(obj, gsl_vector_complex, v);
287
- other = argv[argc-1];
288
-
289
- if(argc == 1) {
290
- // // If assigning from another vector
291
- if(VECTOR_P(other) || VECTOR_COMPLEX_P(other)) {
292
- // treat as assignment to v.subvector(...)
293
- rb_gsl_vector_complex_set_subvector(argc-1, argv, v, other);
294
- } else {
295
- // treat as set_all
296
- rb_gsl_vector_complex_set_all(argc, argv, obj);
297
- }
298
- } else if(argc == 2 && TYPE(argv[0]) == T_FIXNUM) {
299
- // v[i] = x
300
- ii = FIX2INT(argv[0]);
301
- if(ii < 0) ii += v->size;
302
- // Get/make GSL::Complex from second arg
303
- tmp = gsl_vector_complex_get(v, ii);
304
- rb_gsl_obj_to_gsl_complex(argv[1], &tmp);
305
- gsl_vector_complex_set(v, (size_t)ii, tmp);
306
- } else {
307
- // assignment to v.subvector(...)
308
- rb_gsl_vector_complex_set_subvector(argc-1, argv, v, other);
309
- }
310
- return obj;
311
- }
312
-
313
- static VALUE rb_gsl_vector_complex_each(VALUE obj)
314
- {
315
- gsl_vector_complex *v = NULL;
316
- VALUE vz;
317
- gsl_complex * zp;
318
- size_t i;
319
- Data_Get_Struct(obj, gsl_vector_complex, v);
320
- for (i = 0; i < v->size; i++) {
321
- vz = Data_Make_Struct(cgsl_complex, gsl_complex, 0, free, zp);
322
- *zp = gsl_vector_complex_get(v, i);
323
- rb_yield(vz);
324
- }
325
- return obj;
326
- }
327
-
328
- static VALUE rb_gsl_vector_complex_reverse_each(VALUE obj)
329
- {
330
- gsl_vector_complex *v = NULL;
331
- VALUE vz;
332
- gsl_complex * zp;
333
- size_t i;
334
- Data_Get_Struct(obj, gsl_vector_complex, v);
335
- for (i = v->size-1;; i--) {
336
- vz = Data_Make_Struct(cgsl_complex, gsl_complex, 0, free, zp);
337
- *zp = gsl_vector_complex_get(v, i);
338
- rb_yield(vz);
339
- if (i == 0) break;
340
- }
341
- return obj;
342
- }
343
-
344
- static VALUE rb_gsl_vector_complex_each_index(VALUE obj)
345
- {
346
- gsl_vector_complex *v = NULL;
347
- size_t i;
348
- Data_Get_Struct(obj, gsl_vector_complex, v);
349
- for (i = 0; i < v->size; i++) rb_yield(INT2FIX(i));
350
- return obj;
351
- }
352
-
353
- static VALUE rb_gsl_vector_complex_reverse_each_index(VALUE obj)
354
- {
355
- gsl_vector_complex *v = NULL;
356
- size_t i;
357
- Data_Get_Struct(obj, gsl_vector_complex, v);
358
- for (i = v->size-1;; i--) {
359
- rb_yield(INT2FIX(i));
360
- if (i == 0) break;
361
- }
362
- return obj;
363
- }
364
-
365
- static void rb_gsl_vector_complex_collect_native(gsl_vector_complex *src, gsl_vector_complex *dst)
366
- {
367
- VALUE vz;
368
- gsl_complex * zp;
369
- size_t i;
370
- for (i = 0; i < src->size; i++) {
371
- vz = Data_Make_Struct(cgsl_complex, gsl_complex, 0, free, zp);
372
- *zp = gsl_vector_complex_get(src, i);
373
- vz = rb_yield(vz);
374
- CHECK_COMPLEX(vz);
375
- Data_Get_Struct(vz, gsl_complex, zp);
376
- gsl_vector_complex_set(dst, i, *zp);
377
- }
378
- }
379
-
380
- static VALUE rb_gsl_vector_complex_collect(VALUE obj)
381
- {
382
- gsl_vector_complex *v = NULL, *vnew;
383
- Data_Get_Struct(obj, gsl_vector_complex, v);
384
- vnew = gsl_vector_complex_alloc(v->size);
385
- rb_gsl_vector_complex_collect_native(v, vnew);
386
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
387
- }
388
-
389
- static VALUE rb_gsl_vector_complex_collect_bang(VALUE obj)
390
- {
391
- gsl_vector_complex *v = NULL;
392
- Data_Get_Struct(obj, gsl_vector_complex, v);
393
- rb_gsl_vector_complex_collect_native(v, v);
394
- return obj;
395
- }
396
-
397
- static VALUE rb_gsl_vector_complex_set_zero(VALUE obj)
398
- {
399
- gsl_vector_complex *v = NULL;
400
- Data_Get_Struct(obj, gsl_vector_complex, v);
401
- gsl_vector_complex_set_zero(v);
402
- return obj;
403
- }
404
-
405
- static VALUE rb_gsl_vector_complex_set_basis(VALUE obj, VALUE ii)
406
- {
407
- gsl_vector_complex *v = NULL;
408
- CHECK_FIXNUM(ii);
409
- Data_Get_Struct(obj, gsl_vector_complex, v);
410
- gsl_vector_complex_set_basis(v, FIX2INT(ii));
411
- return obj;
412
- }
413
-
414
- static VALUE rb_gsl_vector_complex_to_s(VALUE obj)
415
- {
416
- gsl_vector_complex *v = NULL;
417
- char buf[64];
418
- size_t i;
419
- VALUE str;
420
- gsl_complex * z;
421
-
422
- Data_Get_Struct(obj, gsl_vector_complex, v);
423
- if (v->size == 0) return rb_str_new2("[ ]");
424
- str = rb_str_new2("[ ");
425
- if (VECTOR_COMPLEX_COL_P(obj)) {
426
- for (i = 0; i < v->size; i++) {
427
- if (i != 0) {
428
- rb_str_cat(str, " ", 2);
429
- }
430
- z = GSL_COMPLEX_AT(v, i);
431
- sprintf(buf, "[%4.3e %4.3e]", GSL_REAL(*z), GSL_IMAG(*z));
432
- if (i != v->size-1) strcat(buf, "\n");
433
- rb_str_cat(str, buf, strlen(buf));
434
- if (i >= 10 && i != v->size-1) {
435
- rb_str_cat(str, " ...", 5);
436
- break;
437
- }
438
- }
439
- } else {
440
- z = GSL_COMPLEX_AT(v, 0);
441
- sprintf(buf, "[%4.3e %4.3e]", GSL_REAL(*z), GSL_IMAG(*z));
442
- rb_str_cat(str, buf, strlen(buf));
443
- for (i = 1; i < v->size; i++) {
444
- z = GSL_COMPLEX_AT(v, i);
445
- sprintf(buf, " [%4.3e %4.3e]", GSL_REAL(*z), GSL_IMAG(*z));
446
- rb_str_cat(str, buf, strlen(buf));
447
- if (i >= 10 && i != v->size-1) {
448
- rb_str_cat(str, " ...", 4);
449
- break;
450
- }
451
- }
452
- }
453
- rb_str_cat(str, " ]", 2);
454
- return str;
455
- }
456
-
457
- static VALUE rb_gsl_vector_complex_inspect(VALUE obj)
458
- {
459
- VALUE str;
460
- char buf[128];
461
- gsl_vector_complex *v;
462
-
463
- Data_Get_Struct(obj, gsl_vector_complex, v);
464
- sprintf(buf, "#<%s[%lu]:%#lx>\n", rb_class2name(CLASS_OF(obj)), v->size, NUM2ULONG(rb_obj_id(obj)));
465
- str = rb_str_new2(buf);
466
- return rb_str_concat(str, rb_gsl_vector_complex_to_s(obj));
467
- }
468
-
469
- /*static VALUE rb_gsl_vector_complex_fprintf(VALUE obj, VALUE io, VALUE format)*/
470
- static VALUE rb_gsl_vector_complex_fprintf(int argc, VALUE *argv, VALUE obj)
471
- {
472
- gsl_vector_complex *h = NULL;
473
- FILE *fp = NULL;
474
- int status, flag = 0;
475
- if (argc != 1 && argc != 2) {
476
- rb_raise(rb_eArgError, "wrong number of arguments (%d for 1 or 2)", argc);
477
- }
478
- Data_Get_Struct(obj, gsl_vector_complex, h);
479
- fp = rb_gsl_open_writefile(argv[0], &flag);
480
- if (argc == 2) {
481
- Check_Type(argv[1], T_STRING);
482
- status = gsl_vector_complex_fprintf(fp, h, STR2CSTR(argv[1]));
483
- } else {
484
- status = gsl_vector_complex_fprintf(fp, h, "%4.3e");
485
- }
486
- if (flag == 1) fclose(fp);
487
- return INT2FIX(status);
488
- }
489
-
490
- /*static VALUE rb_gsl_vector_complex_printf(VALUE obj, VALUE format)*/
491
- static VALUE rb_gsl_vector_complex_printf(int argc, VALUE *argv, VALUE obj)
492
- {
493
- gsl_vector_complex *h = NULL;
494
- int status;
495
- Data_Get_Struct(obj, gsl_vector_complex, h);
496
- if (argc == 1) {
497
- Check_Type(argv[0], T_STRING);
498
- status = gsl_vector_complex_fprintf(stdout, h, STR2CSTR(argv[0]));
499
- } else {
500
- status = gsl_vector_complex_fprintf(stdout, h, "%4.3e");
501
- }
502
- return INT2FIX(status);
503
- }
504
- /*
505
- static VALUE rb_gsl_vector_complex_print(VALUE obj);
506
- static VALUE rb_gsl_vector_complex_inspect(VALUE obj)
507
- {
508
- gsl_vector_complex *h = NULL;
509
- Data_Get_Struct(obj, gsl_vector_complex, h);
510
- printf("%s\n", rb_class2name(CLASS_OF(obj)));
511
- rb_gsl_vector_complex_print(obj);
512
- return Qtrue;
513
- }
514
- */
515
- static VALUE rb_gsl_vector_complex_print(VALUE obj)
516
- {
517
- gsl_vector_complex *h = NULL;
518
- gsl_complex *z = NULL;
519
- size_t i;
520
- Data_Get_Struct(obj, gsl_vector_complex, h);
521
- printf("[ ");
522
- if (VECTOR_COMPLEX_COL_P(obj)) {
523
- printf("\n");
524
- for (i = 0; i < h->size; i++) {
525
- z = GSL_COMPLEX_AT(h, i);
526
- printf(" [%4.3e %4.3e]\n", GSL_REAL(*z), GSL_IMAG(*z));
527
- }
528
- } else {
529
- for (i = 0; i < h->size; i++) {
530
- z = GSL_COMPLEX_AT(h, i);
531
- printf("[%4.3e %4.3e] ", GSL_REAL(*z), GSL_IMAG(*z));
532
- }
533
- }
534
- printf("]\n");
535
- return obj;
536
- }
537
-
538
- static VALUE rb_gsl_vector_complex_fwrite(VALUE obj, VALUE io)
539
- {
540
- gsl_vector_complex *h = NULL;
541
- FILE *fp = NULL;
542
- int status, flag = 0;
543
- Data_Get_Struct(obj, gsl_vector_complex, h);
544
- fp = rb_gsl_open_writefile(io, &flag);
545
- status = gsl_vector_complex_fwrite(fp, h);
546
- if (flag == 1) fclose(fp);
547
- return INT2FIX(status);
548
- }
549
-
550
- static VALUE rb_gsl_vector_complex_fread(VALUE obj, VALUE io)
551
- {
552
- gsl_vector_complex *h = NULL;
553
- FILE *f = NULL;
554
- int status, flag = 0;
555
- Data_Get_Struct(obj, gsl_vector_complex, h);
556
- f = rb_gsl_open_writefile(io, &flag);
557
- status = gsl_vector_complex_fread(f, h);
558
- if (flag == 1) fclose(f);
559
- return INT2FIX(status);
560
- }
561
-
562
- static VALUE rb_gsl_vector_complex_fscanf(VALUE obj, VALUE io)
563
- {
564
- gsl_vector_complex *h = NULL;
565
- FILE *f = NULL;
566
- int status, flag = 0;
567
- Data_Get_Struct(obj, gsl_vector_complex, h);
568
- f = rb_gsl_open_writefile(io, &flag);
569
- status = gsl_vector_complex_fscanf(f, h);
570
- if (flag == 1) fclose(f);
571
- return INT2FIX(status);
572
- }
573
-
574
- static VALUE rb_gsl_vector_complex_real(VALUE obj)
575
- {
576
- gsl_vector_complex *c = NULL;
577
- gsl_vector_view *vv = NULL;
578
- Data_Get_Struct(obj, gsl_vector_complex, c);
579
- vv = gsl_vector_view_alloc();
580
- *vv = gsl_vector_complex_real(c);
581
- if (VECTOR_COMPLEX_ROW_P(obj))
582
- return Data_Wrap_Struct(cgsl_vector_view, 0, gsl_vector_view_free, vv);
583
- else
584
- return Data_Wrap_Struct(cgsl_vector_col_view, 0, gsl_vector_view_free, vv);
585
- }
586
-
587
- static VALUE rb_gsl_vector_complex_imag(VALUE obj)
588
- {
589
- gsl_vector_complex *c = NULL;
590
- gsl_vector_view *vv = NULL;
591
- Data_Get_Struct(obj, gsl_vector_complex, c);
592
- vv = gsl_vector_view_alloc();
593
- *vv = gsl_vector_complex_imag(c);
594
- if (VECTOR_COMPLEX_ROW_P(obj))
595
- return Data_Wrap_Struct(cgsl_vector_view, 0, gsl_vector_view_free, vv);
596
- else
597
- return Data_Wrap_Struct(cgsl_vector_col_view, 0, gsl_vector_view_free, vv);
598
- }
599
-
600
- static VALUE rb_gsl_vector_complex_set_real(VALUE obj, VALUE val)
601
- {
602
- gsl_vector_complex *v = NULL;
603
- gsl_vector_view vv;
604
- double d = NUM2DBL(val);
605
- Data_Get_Struct(obj, gsl_vector_complex, v);
606
- vv = gsl_vector_complex_real(v);
607
- gsl_vector_set_all(&vv.vector, d);
608
- return obj;
609
- }
610
-
611
- static VALUE rb_gsl_vector_complex_set_imag(VALUE obj, VALUE val)
612
- {
613
- gsl_vector_complex *v = NULL;
614
- gsl_vector_view vv;
615
- double d = NUM2DBL(val);
616
- Data_Get_Struct(obj, gsl_vector_complex, v);
617
- vv = gsl_vector_complex_imag(v);
618
- gsl_vector_set_all(&vv.vector, d);
619
- return obj;
620
- }
621
-
622
- static VALUE rb_gsl_vector_complex_conj(VALUE obj)
623
- {
624
- size_t i;
625
- gsl_vector_complex *vin = NULL;
626
- gsl_vector_complex *vout = NULL;
627
- Data_Get_Struct(obj, gsl_vector_complex, vin);
628
- vout = gsl_vector_complex_alloc(vin->size);
629
- for(i = 0; i<vin->size; i++) {
630
- gsl_vector_complex_set(vout, i,
631
- gsl_complex_conjugate(
632
- gsl_vector_complex_get(vin, i)));
633
- }
634
- return Data_Wrap_Struct(VECTOR_COMPLEX_ROW_COL(obj), 0, gsl_vector_complex_free, vout);
635
- }
636
-
637
- static VALUE rb_gsl_vector_complex_conj_bang(VALUE obj)
638
- {
639
- size_t i;
640
- gsl_vector_complex *v = NULL;
641
- Data_Get_Struct(obj, gsl_vector_complex, v);
642
- for(i = 0; i<v->size; i++) {
643
- gsl_vector_complex_set(v, i,
644
- gsl_complex_conjugate(
645
- gsl_vector_complex_get(v, i)));
646
- }
647
- return obj;
648
- }
649
-
650
- static VALUE rb_gsl_vector_complex_to_a(VALUE obj)
651
- {
652
- gsl_vector_complex *c = NULL;
653
- gsl_complex *z = NULL;
654
- size_t i, j;
655
- VALUE ary;
656
- Data_Get_Struct(obj, gsl_vector_complex, c);
657
- ary = rb_ary_new2(c->size*2);
658
- for (i = 0, j = 0; i < c->size; i++, j += 2) {
659
- z = GSL_COMPLEX_AT(c, i);
660
- rb_ary_store(ary, j, rb_float_new(GSL_REAL(*z)));
661
- rb_ary_store(ary, j+1, rb_float_new(GSL_IMAG(*z)));
662
- }
663
- return ary;
664
- }
665
-
666
- static VALUE rb_gsl_vector_complex_to_a2(VALUE obj)
667
- {
668
- gsl_vector_complex *c = NULL;
669
- gsl_complex *znew = NULL, *z = NULL;
670
- size_t i;
671
- VALUE ary, vz;
672
- Data_Get_Struct(obj, gsl_vector_complex, c);
673
- ary = rb_ary_new2(c->size);
674
- for (i = 0; i < c->size; i++) {
675
- z = GSL_COMPLEX_AT(c, i);
676
- znew = make_complex(z->dat[0], z->dat[1]);
677
- vz = Data_Wrap_Struct(cgsl_complex, 0, free, znew);
678
- rb_ary_store(ary, i, vz);
679
- }
680
- return ary;
681
- }
682
-
683
- gsl_vector_complex_view* gsl_vector_complex_view_alloc()
684
- {
685
- gsl_vector_complex_view *vv = NULL;
686
- vv = ALLOC(gsl_vector_complex_view);
687
- if (vv == NULL) rb_raise(rb_eRuntimeError, "malloc failed");
688
- return vv;
689
- }
690
-
691
- void gsl_vector_complex_view_free(gsl_vector_view * vv)
692
- {
693
- free((gsl_vector_complex_view *) vv);
694
- }
695
-
696
- static VALUE rb_gsl_vector_complex_subvector(int argc, VALUE *argv, VALUE obj)
697
- {
698
- gsl_vector_complex *v = NULL;
699
- gsl_vector_complex_view *vv = NULL;
700
- size_t offset, stride, n;
701
- Data_Get_Struct(obj, gsl_vector_complex, v);
702
- parse_subvector_args(argc, argv, v->size, &offset, &stride, &n);
703
- vv = gsl_vector_complex_view_alloc();
704
- *vv = gsl_vector_complex_subvector_with_stride(v, offset, stride, n);
705
- if (VECTOR_COMPLEX_ROW_P(obj))
706
- return Data_Wrap_Struct(cgsl_vector_complex_view, 0, gsl_vector_complex_view_free, vv);
707
- else
708
- return Data_Wrap_Struct(cgsl_vector_complex_col_view, 0, gsl_vector_complex_view_free, vv);
709
- }
710
-
711
- static VALUE rb_gsl_vector_complex_subvector_with_stride(VALUE obj, VALUE o, VALUE s, VALUE nn)
712
- {
713
- gsl_vector_complex *v = NULL;
714
- gsl_vector_complex_view *vv = NULL;
715
- int offset;
716
- CHECK_FIXNUM(o); CHECK_FIXNUM(nn); CHECK_FIXNUM(s);
717
- offset = NUM2INT(o);
718
- Data_Get_Struct(obj, gsl_vector_complex, v);
719
- if(offset < 0) {
720
- offset += v->size;
721
- }
722
- vv = gsl_vector_complex_view_alloc();
723
- *vv = gsl_vector_complex_subvector_with_stride(v, (size_t)offset, FIX2INT(s), FIX2INT(nn));
724
- if (VECTOR_COMPLEX_ROW_P(obj))
725
- return Data_Wrap_Struct(cgsl_vector_complex_view, 0, gsl_vector_complex_view_free, vv);
726
- else
727
- return Data_Wrap_Struct(cgsl_vector_complex_col_view, 0, gsl_vector_complex_view_free, vv);
728
- }
729
-
730
- /* singleton */
731
- static VALUE rb_gsl_vector_complex_memcpy(VALUE obj, VALUE dst, VALUE src)
732
- {
733
- gsl_vector_complex *v = NULL, *dest = NULL;
734
- CHECK_VECTOR_COMPLEX(dst);
735
- CHECK_VECTOR_COMPLEX(src);
736
- Data_Get_Struct(dst, gsl_vector_complex, dest);
737
- Data_Get_Struct(src, gsl_vector_complex, v);
738
- gsl_vector_complex_memcpy(dest, v);
739
- return dst;
740
- }
741
-
742
- static VALUE rb_gsl_vector_complex_clone(VALUE obj)
743
- {
744
- gsl_vector_complex *v = NULL, *vnew = NULL;
745
- Data_Get_Struct(obj, gsl_vector_complex, v);
746
- vnew = gsl_vector_complex_alloc(v->size);
747
- if (vnew == NULL) rb_raise(rb_eNoMemError, "gsl_vector_complex_alloc failed");
748
- gsl_vector_complex_memcpy(vnew, v);
749
- if (VECTOR_COMPLEX_ROW_P(obj))
750
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
751
- else
752
- return Data_Wrap_Struct(cgsl_vector_complex_col, 0, gsl_vector_complex_free, vnew);
753
- }
754
-
755
- static VALUE rb_gsl_vector_complex_reverse(VALUE obj)
756
- {
757
- gsl_vector_complex *v = NULL;
758
- Data_Get_Struct(obj, gsl_vector_complex, v);
759
- gsl_vector_complex_reverse(v);
760
- return obj;
761
- }
762
-
763
- static VALUE rb_gsl_vector_complex_reverse2(VALUE obj)
764
- {
765
- gsl_vector_complex *v = NULL, *vnew = NULL;
766
- Data_Get_Struct(obj, gsl_vector_complex, v);
767
- vnew = gsl_vector_complex_alloc(v->size);
768
- gsl_vector_complex_memcpy(vnew, v);
769
- gsl_vector_complex_reverse(vnew);
770
- if (VECTOR_COMPLEX_ROW_P(obj))
771
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
772
- else
773
- return Data_Wrap_Struct(cgsl_vector_complex_col, 0, gsl_vector_complex_free, vnew);
774
- }
775
-
776
- static VALUE rb_gsl_vector_complex_swap_elements(VALUE obj, VALUE i, VALUE j)
777
- {
778
- gsl_vector_complex *v = NULL;
779
- CHECK_FIXNUM(i); CHECK_FIXNUM(j);
780
- Data_Get_Struct(obj, gsl_vector_complex, v);
781
- gsl_vector_complex_swap_elements(v, FIX2INT(i), FIX2INT(j));
782
- return obj;
783
- }
784
-
785
- static VALUE rb_gsl_vector_complex_fftshift_bang(VALUE obj)
786
- {
787
- gsl_vector_complex *v = NULL;
788
- gsl_complex tmp;
789
- size_t i, n;
790
-
791
- Data_Get_Struct(obj, gsl_vector_complex, v);
792
- n = v->size;
793
- if(n & 1) {
794
- // length is odd
795
- tmp = gsl_vector_complex_get(v,0);
796
- for(i = 0; i < n/2; i++) {
797
- gsl_vector_complex_set(v, i, gsl_vector_complex_get(v, i+n/2+1));
798
- gsl_vector_complex_set(v, i+n/2+1, gsl_vector_complex_get(v, i+1));
799
- }
800
- gsl_vector_complex_set(v, n/2, tmp);
801
- } else {
802
- // length is even
803
- for(i = 0; i < n/2; i++) {
804
- gsl_vector_complex_swap_elements(v, i, i+n/2);
805
- }
806
- }
807
- return obj;
808
- }
809
-
810
- static VALUE rb_gsl_vector_complex_fftshift(VALUE obj)
811
- {
812
- gsl_vector_complex *v, *vnew;
813
- gsl_vector_complex_view vv, vvnew;
814
- size_t n;
815
-
816
- Data_Get_Struct(obj, gsl_vector_complex, v);
817
- n = v->size;
818
- vnew = gsl_vector_complex_alloc(n);
819
- // Copy low to high
820
- vv = gsl_vector_complex_subvector(v, 0, (n+1)/2);
821
- vvnew = gsl_vector_complex_subvector(vnew, n/2, (n+1)/2);
822
- gsl_vector_complex_memcpy(&vvnew.vector, &vv.vector);
823
- // Copy high to low
824
- vv = gsl_vector_complex_subvector(v, (n+1)/2, n/2);
825
- vvnew = gsl_vector_complex_subvector(vnew, 0, n/2);
826
- gsl_vector_complex_memcpy(&vvnew.vector, &vv.vector);
827
-
828
- return Data_Wrap_Struct(VECTOR_COMPLEX_ROW_COL(obj), 0, gsl_vector_complex_free, vnew);
829
- }
830
-
831
- static VALUE rb_gsl_vector_complex_ifftshift_bang(VALUE obj)
832
- {
833
- gsl_vector_complex *v = NULL;
834
- gsl_complex tmp;
835
- size_t i, n;
836
-
837
- Data_Get_Struct(obj, gsl_vector_complex, v);
838
- n = v->size;
839
- if(n & 1) {
840
- // length is odd
841
- tmp = gsl_vector_complex_get(v,n/2);
842
- for(i = n/2; i > 0; i--) {
843
- gsl_vector_complex_set(v, i, gsl_vector_complex_get(v, i+n/2));
844
- gsl_vector_complex_set(v, i+n/2, gsl_vector_complex_get(v, i-1));
845
- }
846
- gsl_vector_complex_set(v, 0, tmp);
847
- } else {
848
- // length is even
849
- for(i = 0; i < n/2; i++) {
850
- gsl_vector_complex_swap_elements(v, i, i+n/2);
851
- }
852
- }
853
- return obj;
854
- }
855
-
856
- static VALUE rb_gsl_vector_complex_ifftshift(VALUE obj)
857
- {
858
- return rb_gsl_vector_complex_ifftshift_bang(rb_gsl_vector_complex_clone(obj));
859
- /*gsl_vector_complex *v, *vnew;
860
- gsl_vector_complex_view vv, vvnew;
861
- size_t n;
862
-
863
- Data_Get_Struct(obj, gsl_vector_complex, v);
864
- n = v->size;
865
- vnew = gsl_vector_complex_alloc(n);
866
- // Copy high to low
867
- vv = gsl_vector_complex_subvector(vnew, n/2, (n+1)/2);
868
- vvnew = gsl_vector_complex_subvector(v, 0, (n+1)/2);
869
- gsl_vector_complex_memcpy(&vvnew.vector, &vv.vector);
870
- // Copy low to high
871
- vv = gsl_vector_complex_subvector(vnew, 0, n/2);
872
- vvnew = gsl_vector_complex_subvector(v, (n+1)/2, n/2);
873
- gsl_vector_complex_memcpy(&vvnew.vector, &vv.vector);
874
-
875
- return Data_Wrap_Struct(VECTOR_COMPLEX_ROW_COL(obj), 0, gsl_vector_complex_free, vnew); */
876
- }
877
-
878
- static VALUE rb_gsl_vector_complex_isnull(VALUE obj)
879
- {
880
- gsl_vector_complex *v = NULL;
881
- Data_Get_Struct(obj, gsl_vector_complex, v);
882
- if (gsl_vector_complex_isnull(v)) return Qtrue;
883
- else return Qfalse;
884
- }
885
-
886
- static VALUE rb_gsl_vector_complex_matrix_view(int argc, VALUE *argv, VALUE obj)
887
- {
888
- gsl_vector_complex *v = NULL;
889
- gsl_matrix_complex_view *mv = NULL;
890
- Data_Get_Struct(obj, gsl_vector_complex, v);
891
- switch (argc) {
892
- case 2:
893
- mv = gsl_matrix_complex_view_alloc();
894
- *mv = gsl_matrix_complex_view_vector(v, FIX2INT(argv[0]), FIX2INT(argv[1]));
895
- break;
896
- case 3:
897
- mv = gsl_matrix_complex_view_alloc();
898
- *mv = gsl_matrix_complex_view_vector_with_tda(v, FIX2INT(argv[0]), FIX2INT(argv[1]),
899
- FIX2INT(argv[2]));
900
- break;
901
- default:
902
- rb_raise(rb_eArgError, "wrong number of arguments (%d for 2 or 3)", argc);
903
- break;
904
- }
905
- return Data_Wrap_Struct(cgsl_matrix_complex_view, 0, gsl_matrix_complex_view_free, mv);
906
- }
907
-
908
- static VALUE rb_gsl_vector_complex_matrix_view_with_tda(VALUE obj, VALUE nn1, VALUE nn2,
909
- VALUE tda)
910
- {
911
- gsl_vector_complex *v = NULL;
912
- gsl_matrix_complex_view *mv = NULL;
913
- CHECK_FIXNUM(nn1); CHECK_FIXNUM(nn2); CHECK_FIXNUM(tda);
914
- Data_Get_Struct(obj, gsl_vector_complex, v);
915
- mv = gsl_matrix_complex_view_alloc();
916
- if (mv == NULL) rb_raise(rb_eNoMemError, "gsl_matrix_complex_alloc failed");
917
- *mv = gsl_matrix_complex_view_vector_with_tda(v, FIX2INT(nn1), FIX2INT(nn2), FIX2INT(tda));
918
- return Data_Wrap_Struct(cgsl_matrix_complex_view, 0, gsl_matrix_complex_view_free, mv);
919
- }
920
-
921
- static VALUE rb_gsl_vector_complex_trans(VALUE obj)
922
- {
923
- gsl_vector_complex *v = NULL, *vnew = NULL;
924
- Data_Get_Struct(obj, gsl_vector_complex, v);
925
- vnew = make_vector_complex_clone(v);
926
- if (VECTOR_COMPLEX_ROW_P(obj))
927
- return Data_Wrap_Struct(cgsl_vector_complex_col, 0, gsl_vector_complex_free, vnew);
928
- else if (VECTOR_COMPLEX_COL_P(obj))
929
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
930
- else {
931
- rb_raise(rb_eTypeError, "wrong type");
932
- }
933
- }
934
-
935
- static VALUE rb_gsl_vector_complex_trans2(VALUE obj)
936
- {
937
- if (CLASS_OF(obj) == cgsl_vector_complex)
938
- RBGSL_SET_CLASS(obj, cgsl_vector_complex_col);
939
- else if (CLASS_OF(obj) == cgsl_vector_complex_col)
940
- RBGSL_SET_CLASS(obj, cgsl_vector_complex);
941
- else {
942
- rb_raise(rb_eRuntimeError, "method trans! for %s is forbidden",
943
- rb_class2name(CLASS_OF(obj)));
944
- }
945
- return obj;
946
- }
947
-
948
- static VALUE rb_gsl_vector_complex_to_real(VALUE obj)
949
- {
950
- gsl_vector_complex *cv = NULL;
951
- gsl_vector *v = NULL;
952
- gsl_complex z;
953
- size_t i;
954
- Data_Get_Struct(obj, gsl_vector_complex, cv);
955
- v = gsl_vector_alloc(cv->size);
956
- if (v == NULL) rb_raise(rb_eNoMemError, "gsl_vector_alloc failed");
957
- for (i = 0; i < cv->size; i++) {
958
- z = gsl_vector_complex_get(cv, i);
959
- gsl_vector_set(v, i, GSL_REAL(z));
960
- }
961
- if (VECTOR_COMPLEX_ROW_P(obj))
962
- return Data_Wrap_Struct(cgsl_vector, 0, gsl_vector_free, v);
963
- else
964
- return Data_Wrap_Struct(cgsl_vector_col, 0, gsl_vector_free, v);
965
- }
966
-
967
- enum {
968
- GSL_VECTOR_COMPLEX_ADD,
969
- GSL_VECTOR_COMPLEX_SUB,
970
- GSL_VECTOR_COMPLEX_MUL,
971
- GSL_VECTOR_COMPLEX_DIV,
972
- GSL_VECTOR_COMPLEX_ADD_BANG,
973
- GSL_VECTOR_COMPLEX_SUB_BANG,
974
- GSL_VECTOR_COMPLEX_MUL_BANG,
975
- GSL_VECTOR_COMPLEX_DIV_BANG,
976
- };
977
-
978
- static VALUE rb_gsl_vector_complex_arithmetics(int flag, VALUE obj, VALUE bb);
979
-
980
- static VALUE rb_gsl_vector_complex_arithmetics(int flag, VALUE obj, VALUE bb)
981
- {
982
- gsl_vector *b = NULL;
983
- gsl_vector_complex *cv = NULL, *cvnew = NULL, *cb = NULL;
984
- gsl_complex *c = NULL, z;
985
- Data_Get_Struct(obj, gsl_vector_complex, cv);
986
- switch (flag) {
987
- case GSL_VECTOR_COMPLEX_ADD:
988
- case GSL_VECTOR_COMPLEX_SUB:
989
- case GSL_VECTOR_COMPLEX_MUL:
990
- case GSL_VECTOR_COMPLEX_DIV:
991
- cvnew = make_vector_complex_clone(cv);
992
- obj = Data_Wrap_Struct(VECTOR_COMPLEX_ROW_COL(obj), 0, gsl_vector_complex_free, cvnew);
993
- break;
994
- case GSL_VECTOR_COMPLEX_ADD_BANG:
995
- case GSL_VECTOR_COMPLEX_SUB_BANG:
996
- case GSL_VECTOR_COMPLEX_MUL_BANG:
997
- case GSL_VECTOR_COMPLEX_DIV_BANG:
998
- cvnew = cv;
999
- break;
1000
- default:
1001
- rb_raise(rb_eRuntimeError, "unknown operation");
1002
- break;
1003
- }
1004
- switch (TYPE(bb)) {
1005
- case T_FLOAT:
1006
- case T_FIXNUM:
1007
- case T_BIGNUM:
1008
- z = gsl_complex_rect(NUM2DBL(bb), 0.0);
1009
- switch (flag) {
1010
- case GSL_VECTOR_COMPLEX_ADD:
1011
- case GSL_VECTOR_COMPLEX_ADD_BANG:
1012
- gsl_vector_complex_add_constant(cvnew, z);
1013
- break;
1014
- case GSL_VECTOR_COMPLEX_SUB:
1015
- case GSL_VECTOR_COMPLEX_SUB_BANG:
1016
- gsl_vector_complex_add_constant(cvnew, gsl_complex_negative(z));
1017
- break;
1018
- case GSL_VECTOR_COMPLEX_MUL:
1019
- case GSL_VECTOR_COMPLEX_MUL_BANG:
1020
- gsl_vector_complex_scale(cvnew, z);
1021
- break;
1022
- case GSL_VECTOR_COMPLEX_DIV:
1023
- case GSL_VECTOR_COMPLEX_DIV_BANG:
1024
- gsl_vector_complex_scale(cvnew, gsl_complex_inverse(z));
1025
- break;
1026
- }
1027
- break;
1028
- default:
1029
- if (VECTOR_P(bb)) {
1030
- Data_Get_Struct(bb, gsl_vector, b);
1031
- cb = vector_to_complex(b);
1032
- switch (flag) {
1033
- case GSL_VECTOR_COMPLEX_ADD:
1034
- case GSL_VECTOR_COMPLEX_ADD_BANG:
1035
- gsl_vector_complex_add(cvnew, cb);
1036
- break;
1037
- case GSL_VECTOR_COMPLEX_SUB:
1038
- case GSL_VECTOR_COMPLEX_SUB_BANG:
1039
- gsl_vector_complex_sub(cvnew, cb);
1040
- break;
1041
- case GSL_VECTOR_COMPLEX_MUL:
1042
- case GSL_VECTOR_COMPLEX_MUL_BANG:
1043
- gsl_vector_complex_mul(cvnew, cb);
1044
- break;
1045
- case GSL_VECTOR_COMPLEX_DIV:
1046
- case GSL_VECTOR_COMPLEX_DIV_BANG:
1047
- gsl_vector_complex_div(cvnew, cb);
1048
- break;
1049
- }
1050
- gsl_vector_complex_free(cb);
1051
- } else if (VECTOR_COMPLEX_P(bb)) {
1052
- Data_Get_Struct(bb, gsl_vector_complex, cb);
1053
- switch (flag) {
1054
- case GSL_VECTOR_COMPLEX_ADD:
1055
- case GSL_VECTOR_COMPLEX_ADD_BANG:
1056
- gsl_vector_complex_add(cvnew, cb);
1057
- break;
1058
- case GSL_VECTOR_COMPLEX_SUB:
1059
- case GSL_VECTOR_COMPLEX_SUB_BANG:
1060
- gsl_vector_complex_sub(cvnew, cb);
1061
- break;
1062
- case GSL_VECTOR_COMPLEX_MUL:
1063
- case GSL_VECTOR_COMPLEX_MUL_BANG:
1064
- gsl_vector_complex_mul(cvnew, cb);
1065
- break;
1066
- case GSL_VECTOR_COMPLEX_DIV:
1067
- case GSL_VECTOR_COMPLEX_DIV_BANG:
1068
- gsl_vector_complex_div(cvnew, cb);
1069
- break;
1070
- }
1071
- } else if (COMPLEX_P(bb)) {
1072
- Data_Get_Struct(bb, gsl_complex, c);
1073
- switch (flag) {
1074
- case GSL_VECTOR_COMPLEX_ADD:
1075
- case GSL_VECTOR_COMPLEX_ADD_BANG:
1076
- gsl_vector_complex_add_constant(cvnew, *c);
1077
- break;
1078
- case GSL_VECTOR_COMPLEX_SUB:
1079
- case GSL_VECTOR_COMPLEX_SUB_BANG:
1080
- gsl_vector_complex_add_constant(cvnew, gsl_complex_negative(*c));
1081
- break;
1082
- case GSL_VECTOR_COMPLEX_MUL:
1083
- case GSL_VECTOR_COMPLEX_MUL_BANG:
1084
- gsl_vector_complex_scale(cvnew, *c);
1085
- break;
1086
- case GSL_VECTOR_COMPLEX_DIV:
1087
- case GSL_VECTOR_COMPLEX_DIV_BANG:
1088
- gsl_vector_complex_scale(cvnew, gsl_complex_inverse(*c));
1089
- break;
1090
- }
1091
- } else {
1092
- rb_raise(rb_eTypeError, "wrong type argument %s", rb_class2name(CLASS_OF(bb)));
1093
- }
1094
- break;
1095
- }
1096
- return obj;
1097
- }
1098
-
1099
- static VALUE rb_gsl_vector_complex_add(VALUE obj, VALUE bb)
1100
- {
1101
- return rb_gsl_vector_complex_arithmetics(GSL_VECTOR_COMPLEX_ADD, obj, bb);
1102
- }
1103
-
1104
- static VALUE rb_gsl_vector_complex_sub(VALUE obj, VALUE bb)
1105
- {
1106
- return rb_gsl_vector_complex_arithmetics(GSL_VECTOR_COMPLEX_SUB, obj, bb);
1107
- }
1108
-
1109
- static VALUE rb_gsl_vector_complex_mul(VALUE obj, VALUE bb)
1110
- {
1111
- VALUE argv[2];
1112
- if (VECTOR_COMPLEX_ROW_P(obj) && VECTOR_COMPLEX_COL_P(bb)) {
1113
- argv[0] = obj;
1114
- argv[1] = bb;
1115
- return rb_gsl_vector_complex_inner_product(2, argv, CLASS_OF(obj));
1116
- }
1117
- if (VECTOR_COMPLEX_COL_P(obj) && VECTOR_COMPLEX_ROW_P(bb)) {
1118
- argv[0] = obj;
1119
- argv[1] = bb;
1120
- return rb_gsl_vector_complex_product_to_m(2, argv, CLASS_OF(obj));
1121
- }
1122
- return rb_gsl_vector_complex_arithmetics(GSL_VECTOR_COMPLEX_MUL, obj, bb);
1123
- }
1124
-
1125
- static VALUE rb_gsl_vector_complex_div(VALUE obj, VALUE bb)
1126
- {
1127
- return rb_gsl_vector_complex_arithmetics(GSL_VECTOR_COMPLEX_DIV, obj, bb);
1128
- }
1129
-
1130
- static VALUE rb_gsl_vector_complex_add_bang(VALUE obj, VALUE bb)
1131
- {
1132
- return rb_gsl_vector_complex_arithmetics(GSL_VECTOR_COMPLEX_ADD_BANG, obj, bb);
1133
- }
1134
-
1135
- static VALUE rb_gsl_vector_complex_sub_bang(VALUE obj, VALUE bb)
1136
- {
1137
- return rb_gsl_vector_complex_arithmetics(GSL_VECTOR_COMPLEX_SUB_BANG, obj, bb);
1138
- }
1139
-
1140
- static VALUE rb_gsl_vector_complex_mul_bang(VALUE obj, VALUE bb)
1141
- {
1142
- return rb_gsl_vector_complex_arithmetics(GSL_VECTOR_COMPLEX_MUL_BANG, obj, bb);
1143
- }
1144
-
1145
- static VALUE rb_gsl_vector_complex_div_bang(VALUE obj, VALUE bb)
1146
- {
1147
- return rb_gsl_vector_complex_arithmetics(GSL_VECTOR_COMPLEX_DIV_BANG, obj, bb);
1148
- }
1149
-
1150
- static VALUE rb_gsl_vector_complex_coerce(VALUE obj, VALUE other)
1151
- {
1152
- gsl_vector_complex *cv = NULL, *cb = NULL;
1153
- gsl_complex z;
1154
- VALUE vv;
1155
- Data_Get_Struct(obj, gsl_vector_complex, cv);
1156
- switch (TYPE(other)) {
1157
- case T_FLOAT:
1158
- case T_FIXNUM:
1159
- case T_BIGNUM:
1160
- z = gsl_complex_rect(NUM2DBL(other), 0.0);
1161
- cb = gsl_vector_complex_alloc(cv->size);
1162
- if (cb == NULL) rb_raise(rb_eNoMemError, "gsl_vector_complex_alloc failed");
1163
- gsl_vector_complex_set_all(cb, z);
1164
- vv = Data_Wrap_Struct(VECTOR_COMPLEX_ROW_COL(obj), 0, gsl_vector_complex_free, cb);
1165
- return rb_ary_new3(2, vv, obj);
1166
- break;
1167
- default:
1168
- rb_raise(rb_eTypeError, "GSL::Vector::Complex, operation not defined");
1169
- break;
1170
- }
1171
- }
1172
-
1173
- /* 2.Aug.2004 */
1174
- static VALUE rb_gsl_vector_complex_inner_product(int argc, VALUE *argv, VALUE obj)
1175
- {
1176
- gsl_vector_complex *v = NULL, *v2 = NULL;
1177
- gsl_complex prod, a, b, *z = NULL;
1178
- size_t i;
1179
- switch (TYPE(obj)) {
1180
- case T_MODULE:
1181
- case T_CLASS:
1182
- case T_OBJECT:
1183
- if (argc != 2) rb_raise(rb_eArgError, "wrong number of arguments (%d for 2)",
1184
- argc);
1185
- if (!VECTOR_COMPLEX_ROW_P(argv[0]))
1186
- rb_raise(rb_eTypeError, "wrong argument type %s (GSL::Vector::Complex expected)",
1187
- rb_class2name(CLASS_OF(argv[0])));
1188
- if (!VECTOR_COMPLEX_COL_P(argv[1]))
1189
- rb_raise(rb_eTypeError, "wrong argument type %s (GSL::Vector::Complex::Col expected)",
1190
- rb_class2name(CLASS_OF(argv[1])));
1191
- Data_Get_Struct(argv[0], gsl_vector_complex, v);
1192
- Data_Get_Struct(argv[1], gsl_vector_complex, v2);
1193
- break;
1194
- default:
1195
- if (argc != 1) rb_raise(rb_eArgError, "wrong number of arguments (%d for 1)",
1196
- argc);
1197
- if (!VECTOR_COMPLEX_COL_P(argv[0]))
1198
- rb_raise(rb_eTypeError, "wrong argument type %s (GSL::Vector::Complex::Col expected)",
1199
- rb_class2name(CLASS_OF(argv[0])));
1200
- Data_Get_Struct(obj, gsl_vector_complex, v);
1201
- Data_Get_Struct(argv[0], gsl_vector_complex, v2);
1202
- break;
1203
- }
1204
- if (v->size != v2->size) rb_raise(rb_eRangeError, "vector lengths are different.");
1205
- prod = gsl_complex_rect(0.0, 0.0);
1206
- for (i = 0; i < v->size; i++) {
1207
- a = gsl_vector_complex_get(v, i);
1208
- b = gsl_vector_complex_get(v2, i);
1209
- prod = gsl_complex_add(prod, gsl_complex_mul(a, b));
1210
- }
1211
- z = ALLOC(gsl_complex);
1212
- *z = prod;
1213
- return Data_Wrap_Struct(cgsl_complex, 0, free, z);
1214
- }
1215
-
1216
- static VALUE rb_gsl_vector_complex_product_to_m(int argc, VALUE *argv, VALUE obj)
1217
- {
1218
- gsl_vector_complex *v = NULL, *v2 = NULL;
1219
- gsl_matrix_complex *m = NULL;
1220
- gsl_complex a, b;
1221
- size_t i, j;
1222
- switch (TYPE(obj)) {
1223
- case T_MODULE:
1224
- case T_CLASS:
1225
- case T_OBJECT:
1226
- if (argc != 2) rb_raise(rb_eArgError, "wrong number of arguments (%d for 2)",
1227
- argc);
1228
- if (!VECTOR_COMPLEX_COL_P(argv[0]))
1229
- rb_raise(rb_eTypeError,
1230
- "wrong argument type %s (GSL::Vector::Complex::Col expected)",
1231
- rb_class2name(CLASS_OF(argv[0])));
1232
- if (!VECTOR_COMPLEX_ROW_P(argv[1]))
1233
- rb_raise(rb_eTypeError,
1234
- "wrong argument type %s (GSL::Vector::Complex expected)",
1235
- rb_class2name(CLASS_OF(argv[1])));
1236
- Data_Get_Struct(argv[0], gsl_vector_complex, v);
1237
- Data_Get_Struct(argv[1], gsl_vector_complex, v2);
1238
- break;
1239
- default:
1240
- if (argc != 1) rb_raise(rb_eArgError, "wrong number of arguments (%d for 1)",
1241
- argc);
1242
- if (!VECTOR_COMPLEX_ROW_P(argv[0]))
1243
- rb_raise(rb_eTypeError,
1244
- "wrong argument type %s (GSL::Vector::Complex expected)",
1245
- rb_class2name(CLASS_OF(argv[0])));
1246
- Data_Get_Struct(obj, gsl_vector_complex, v);
1247
- Data_Get_Struct(argv[0], gsl_vector_complex, v2);
1248
- break;
1249
- }
1250
- m = gsl_matrix_complex_alloc(v->size, v2->size);
1251
- for (i = 0; i < v->size; i++) {
1252
- for (j = 0; j < v2->size; j++) {
1253
- a = gsl_vector_complex_get(v, i);
1254
- b = gsl_vector_complex_get(v2, j);
1255
- gsl_matrix_complex_set(m, i, j, gsl_complex_mul(a, b));
1256
- }
1257
- }
1258
- return Data_Wrap_Struct(cgsl_matrix_complex, 0, gsl_matrix_complex_free, m);
1259
- }
1260
-
1261
- static VALUE rb_gsl_vector_complex_uplus(VALUE obj)
1262
- {
1263
- return obj;
1264
- }
1265
-
1266
- static VALUE rb_gsl_vector_complex_uminus(VALUE obj)
1267
- {
1268
- gsl_vector_complex *v = NULL, *vnew;
1269
- size_t i;
1270
- Data_Get_Struct(obj, gsl_vector_complex, v);
1271
- vnew = gsl_vector_complex_alloc(v->size);
1272
- for (i = 0; i < v->size; i++) {
1273
- gsl_vector_complex_set(vnew, i, gsl_complex_negative(gsl_vector_complex_get(v, i)));
1274
- }
1275
- return Data_Wrap_Struct(VECTOR_COMPLEX_ROW_COL(obj), 0, gsl_vector_complex_free, vnew);
1276
- }
1277
-
1278
- /*****/
1279
- static VALUE rb_gsl_vector_complex_XXX(VALUE obj, double (*f)(gsl_complex))
1280
- {
1281
- gsl_vector_complex *m;
1282
- gsl_vector *v;
1283
- gsl_complex c;
1284
- size_t i;
1285
- Data_Get_Struct(obj, gsl_vector_complex, m);
1286
- v = gsl_vector_alloc(m->size);
1287
- for (i = 0; i < m->size; i++) {
1288
- c = gsl_vector_complex_get(m, i);
1289
- gsl_vector_set(v, i, (*f)(c));
1290
- }
1291
- return Data_Wrap_Struct(cgsl_vector, 0, gsl_vector_free, v);
1292
- }
1293
-
1294
- static VALUE rb_gsl_vector_complex_XXXz(VALUE obj, gsl_complex (*f)(gsl_complex))
1295
- {
1296
- gsl_vector_complex *m, *v;
1297
- gsl_complex c;
1298
- size_t i;
1299
- Data_Get_Struct(obj, gsl_vector_complex, m);
1300
- v = gsl_vector_complex_alloc(m->size);
1301
- for (i = 0; i < m->size; i++) {
1302
- c = gsl_vector_complex_get(m, i);
1303
- gsl_vector_complex_set(v, i, (*f)(c));
1304
- }
1305
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, v);
1306
- }
1307
-
1308
- /* In-place version of rb_gsl_vector_complex_XXXz */
1309
- static VALUE rb_gsl_vector_complex_XXXz_bang(VALUE obj, gsl_complex (*f)(gsl_complex))
1310
- {
1311
- gsl_vector_complex *v;
1312
- gsl_complex c;
1313
- size_t i;
1314
- Data_Get_Struct(obj, gsl_vector_complex, v);
1315
- for (i = 0; i < v->size; i++) {
1316
- c = gsl_vector_complex_get(v, i);
1317
- gsl_vector_complex_set(v, i, (*f)(c));
1318
- }
1319
- return obj;
1320
- }
1321
-
1322
- static VALUE rb_gsl_vector_complex_XXXz2(VALUE obj, VALUE a,
1323
- gsl_complex (*f)(gsl_complex, gsl_complex))
1324
- {
1325
- gsl_vector_complex *m, *v;
1326
- gsl_complex c, *z;
1327
- size_t i;
1328
- CHECK_COMPLEX(a);
1329
- Data_Get_Struct(obj, gsl_vector_complex, m);
1330
- Data_Get_Struct(a, gsl_complex, z);
1331
- v = gsl_vector_complex_alloc(m->size);
1332
- for (i = 0; i < m->size; i++) {
1333
- c = gsl_vector_complex_get(m, i);
1334
- gsl_vector_complex_set(v, i, (*f)(c, *z));
1335
- }
1336
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, v);
1337
- }
1338
-
1339
- static VALUE rb_gsl_vector_complex_XXXz2_bang(VALUE obj, VALUE a,
1340
- gsl_complex (*f)(gsl_complex, gsl_complex))
1341
- {
1342
- gsl_vector_complex *v;
1343
- gsl_complex c, *z;
1344
- size_t i;
1345
- CHECK_COMPLEX(a);
1346
- Data_Get_Struct(obj, gsl_vector_complex, v);
1347
- Data_Get_Struct(a, gsl_complex, z);
1348
- for (i = 0; i < v->size; i++) {
1349
- c = gsl_vector_complex_get(v, i);
1350
- gsl_vector_complex_set(v, i, (*f)(c, *z));
1351
- }
1352
- return obj;
1353
- }
1354
-
1355
- static VALUE rb_gsl_vector_complex_abs2(VALUE obj)
1356
- {
1357
- return rb_gsl_vector_complex_XXX(obj, gsl_complex_abs2);
1358
- }
1359
-
1360
- static VALUE rb_gsl_vector_complex_abs(VALUE obj)
1361
- {
1362
- return rb_gsl_vector_complex_XXX(obj, gsl_complex_abs);
1363
- }
1364
-
1365
- static VALUE rb_gsl_vector_complex_logabs(VALUE obj)
1366
- {
1367
- return rb_gsl_vector_complex_XXX(obj, gsl_complex_logabs);
1368
- }
1369
-
1370
- static VALUE rb_gsl_vector_complex_arg(VALUE obj)
1371
- {
1372
- return rb_gsl_vector_complex_XXX(obj, gsl_complex_arg);
1373
- }
1374
-
1375
- static VALUE rb_gsl_vector_complex_sqrt(VALUE obj)
1376
- {
1377
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_sqrt);
1378
- }
1379
-
1380
- static VALUE rb_gsl_vector_complex_sqrt_bang(VALUE obj)
1381
- {
1382
- return rb_gsl_vector_complex_XXXz_bang(obj, gsl_complex_sqrt);
1383
- }
1384
-
1385
- static VALUE rb_gsl_vector_complex_exp(VALUE obj)
1386
- {
1387
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_exp);
1388
- }
1389
-
1390
- static VALUE rb_gsl_vector_complex_exp_bang(VALUE obj)
1391
- {
1392
- return rb_gsl_vector_complex_XXXz_bang(obj, gsl_complex_exp);
1393
- }
1394
-
1395
- static VALUE rb_gsl_vector_complex_pow(VALUE obj, VALUE a)
1396
- {
1397
- return rb_gsl_vector_complex_XXXz2(obj, a, gsl_complex_pow);
1398
- }
1399
-
1400
- static VALUE rb_gsl_vector_complex_pow_bang(VALUE obj, VALUE a)
1401
- {
1402
- return rb_gsl_vector_complex_XXXz2_bang(obj, a, gsl_complex_pow);
1403
- }
1404
-
1405
- static VALUE rb_gsl_vector_complex_log(VALUE obj)
1406
- {
1407
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_log);
1408
- }
1409
-
1410
- static VALUE rb_gsl_vector_complex_log_bang(VALUE obj)
1411
- {
1412
- return rb_gsl_vector_complex_XXXz_bang(obj, gsl_complex_log);
1413
- }
1414
-
1415
- static VALUE rb_gsl_vector_complex_log10(VALUE obj)
1416
- {
1417
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_log10);
1418
- }
1419
-
1420
- static VALUE rb_gsl_vector_complex_log10_bang(VALUE obj)
1421
- {
1422
- return rb_gsl_vector_complex_XXXz_bang(obj, gsl_complex_log10);
1423
- }
1424
-
1425
- static VALUE rb_gsl_vector_complex_log_b(VALUE obj, VALUE a)
1426
- {
1427
- return rb_gsl_vector_complex_XXXz2(obj, a, gsl_complex_log_b);
1428
- }
1429
-
1430
- static VALUE rb_gsl_vector_complex_log_b_bang(VALUE obj, VALUE a)
1431
- {
1432
- return rb_gsl_vector_complex_XXXz2_bang(obj, a, gsl_complex_log_b);
1433
- }
1434
-
1435
- /* gsl_vector_complex_sum */
1436
- static gsl_complex rb_gsl_vector_complex_sum_gsl(gsl_vector_complex * v)
1437
- {
1438
- size_t i;
1439
- gsl_complex z = gsl_complex_rect(0.0,0.0);
1440
-
1441
- for(i = 0; i<v->size; i++) {
1442
- z = gsl_complex_add(z, gsl_vector_complex_get(v,i));
1443
- }
1444
- return z;
1445
- }
1446
-
1447
- /* gsl_vector_complex_mean */
1448
- static gsl_complex rb_gsl_vector_complex_mean_gsl(gsl_vector_complex * v)
1449
- {
1450
- gsl_complex z = rb_gsl_vector_complex_sum_gsl(v);
1451
- return gsl_complex_div_real(z, (double)v->size);
1452
- }
1453
-
1454
- /* gsl_vector_complex_tss_m */
1455
- static double rb_gsl_vector_complex_tss_m_gsl(gsl_vector_complex * v, gsl_complex mean)
1456
- {
1457
- size_t i;
1458
- double tss = 0.0;
1459
-
1460
- for(i = 0; i<v->size; i++) {
1461
- tss += gsl_complex_abs2(gsl_complex_sub(gsl_vector_complex_get(v,i), mean));
1462
- }
1463
- return tss;
1464
- }
1465
-
1466
- /* gsl_vector_complex_variance_m */
1467
- static double rb_gsl_vector_complex_variance_m_gsl(gsl_vector_complex * v, gsl_complex mean)
1468
- {
1469
- double tss = rb_gsl_vector_complex_tss_m_gsl(v, mean);
1470
- return tss / (double)(v->size - 1);
1471
- }
1472
-
1473
- /* gsl_vector_complex_variance_with_fixed_mean */
1474
- static double rb_gsl_vector_complex_variance_fm_gsl(gsl_vector_complex * v, gsl_complex mean)
1475
- {
1476
- double tss = rb_gsl_vector_complex_tss_m_gsl(v, mean);
1477
- return tss / (double)(v->size);
1478
- }
1479
-
1480
- /* gsl_vector_complex_sd_m */
1481
- static double rb_gsl_vector_complex_sd_m_gsl(gsl_vector_complex * v, gsl_complex mean)
1482
- {
1483
- double var = rb_gsl_vector_complex_variance_m_gsl(v, mean);
1484
- return sqrt(var);
1485
- }
1486
-
1487
- /* gsl_vector_complex_sd_with_fixed_mean */
1488
- static double rb_gsl_vector_complex_sd_fm_gsl(gsl_vector_complex * v, gsl_complex mean)
1489
- {
1490
- double var = rb_gsl_vector_complex_variance_fm_gsl(v, mean);
1491
- return sqrt(var);
1492
- }
1493
-
1494
- /* gsl_vector_complex_tss */
1495
- static double rb_gsl_vector_complex_tss_gsl(gsl_vector_complex * v)
1496
- {
1497
- gsl_complex mean = rb_gsl_vector_complex_mean_gsl(v);
1498
- return rb_gsl_vector_complex_tss_m_gsl(v, mean);
1499
- }
1500
-
1501
- /* gsl_vector_complex_variance */
1502
- static double rb_gsl_vector_complex_variance_gsl(gsl_vector_complex * v)
1503
- {
1504
- double tss = rb_gsl_vector_complex_tss_gsl(v);
1505
- return tss / (double)(v->size - 1);
1506
- }
1507
-
1508
- /* gsl_vector_complex_sd */
1509
- static double rb_gsl_vector_complex_sd_gsl(gsl_vector_complex * v)
1510
- {
1511
- double var = rb_gsl_vector_complex_variance_gsl(v);
1512
- return sqrt(var);
1513
- }
1514
-
1515
- /* Wrapper around stats funcs with prototype like
1516
- * "gsl_complex func(gsl_vector_complex *v)"
1517
- * (e.g. sum and mean)
1518
- */
1519
- static VALUE rb_gsl_vector_complex_z_stats_v(VALUE obj,
1520
- gsl_complex (*func)(gsl_vector_complex*))
1521
- {
1522
- gsl_vector_complex * v;
1523
- gsl_complex * zp;
1524
- VALUE zv;
1525
-
1526
- CHECK_VECTOR_COMPLEX(obj);
1527
- Data_Get_Struct(obj, gsl_vector_complex, v);
1528
-
1529
- zv = Data_Make_Struct(cgsl_complex, gsl_complex, 0, free, zp);
1530
- *zp = func(v);
1531
-
1532
- return zv;
1533
- }
1534
-
1535
- /* Wrapper around stats funcs with prototype like
1536
- * "double func(gsl_vector_complex *v)"
1537
- * (e.g. tss, variance, sd)
1538
- */
1539
- static VALUE rb_gsl_vector_complex_d_stats_v(VALUE obj,
1540
- double (*func)(gsl_vector_complex*))
1541
- {
1542
- gsl_vector_complex * v;
1543
- double d;
1544
-
1545
- CHECK_VECTOR_COMPLEX(obj);
1546
- Data_Get_Struct(obj, gsl_vector_complex, v);
1547
-
1548
- d = func(v);
1549
-
1550
- return rb_float_new(d);
1551
- }
1552
-
1553
- /* Wrapper around stats funcs with prototype like
1554
- * "double func(gsl_vector_complex *v, gsl_complex z)"
1555
- * (e.g. tss_m, variance_m, sd_m, variance_fm, sd_fm)
1556
- */
1557
- static VALUE rb_gsl_vector_complex_d_stats_v_z(VALUE obj, VALUE arg,
1558
- double (*func)(gsl_vector_complex*, gsl_complex))
1559
- {
1560
- gsl_vector_complex * v;
1561
- gsl_complex z;
1562
- gsl_complex * zp;
1563
- double d;
1564
-
1565
- CHECK_VECTOR_COMPLEX(obj);
1566
- Data_Get_Struct(obj, gsl_vector_complex, v);
1567
-
1568
-
1569
- switch (TYPE(arg)) {
1570
- case T_FLOAT:
1571
- case T_FIXNUM:
1572
- case T_BIGNUM:
1573
- z = gsl_complex_rect(NUM2DBL(arg), 0.0);
1574
- zp = &z;
1575
- break;
1576
- default:
1577
- CHECK_COMPLEX(arg);
1578
- Data_Get_Struct(arg, gsl_complex, zp);
1579
- break;
1580
- }
1581
-
1582
- d = func(v,*zp);
1583
-
1584
- return rb_float_new(d);
1585
- }
1586
-
1587
- static VALUE rb_gsl_vector_complex_sum(VALUE obj)
1588
- {
1589
- return rb_gsl_vector_complex_z_stats_v(obj, rb_gsl_vector_complex_sum_gsl);
1590
- }
1591
-
1592
- static VALUE rb_gsl_vector_complex_mean(VALUE obj)
1593
- {
1594
- return rb_gsl_vector_complex_z_stats_v(obj, rb_gsl_vector_complex_mean_gsl);
1595
- }
1596
-
1597
- static VALUE rb_gsl_vector_complex_tss_m(VALUE obj, VALUE arg)
1598
- {
1599
- return rb_gsl_vector_complex_d_stats_v_z(obj, arg, rb_gsl_vector_complex_tss_m_gsl);
1600
- }
1601
-
1602
- static VALUE rb_gsl_vector_complex_variance_m(VALUE obj, VALUE arg)
1603
- {
1604
- return rb_gsl_vector_complex_d_stats_v_z(obj, arg, rb_gsl_vector_complex_variance_m_gsl);
1605
- }
1606
-
1607
- static VALUE rb_gsl_vector_complex_variance_fm(VALUE obj, VALUE arg)
1608
- {
1609
- return rb_gsl_vector_complex_d_stats_v_z(obj, arg, rb_gsl_vector_complex_variance_fm_gsl);
1610
- }
1611
-
1612
- static VALUE rb_gsl_vector_complex_sd_m(VALUE obj, VALUE arg)
1613
- {
1614
- return rb_gsl_vector_complex_d_stats_v_z(obj, arg, rb_gsl_vector_complex_sd_m_gsl);
1615
- }
1616
-
1617
- static VALUE rb_gsl_vector_complex_sd_fm(VALUE obj, VALUE arg)
1618
- {
1619
- return rb_gsl_vector_complex_d_stats_v_z(obj, arg, rb_gsl_vector_complex_sd_fm_gsl);
1620
- }
1621
-
1622
- static VALUE rb_gsl_vector_complex_tss(VALUE obj)
1623
- {
1624
- return rb_gsl_vector_complex_d_stats_v(obj, rb_gsl_vector_complex_tss_gsl);
1625
- }
1626
-
1627
- static VALUE rb_gsl_vector_complex_variance(VALUE obj)
1628
- {
1629
- return rb_gsl_vector_complex_d_stats_v(obj, rb_gsl_vector_complex_variance_gsl);
1630
- }
1631
-
1632
- static VALUE rb_gsl_vector_complex_sd(VALUE obj)
1633
- {
1634
- return rb_gsl_vector_complex_d_stats_v(obj, rb_gsl_vector_complex_sd_gsl);
1635
- }
1636
-
1637
- /*****/
1638
-
1639
- static VALUE rb_gsl_vector_complex_sin(VALUE obj)
1640
- {
1641
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_sin);
1642
- }
1643
-
1644
- static VALUE rb_gsl_vector_complex_cos(VALUE obj)
1645
- {
1646
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_cos);
1647
- }
1648
-
1649
- static VALUE rb_gsl_vector_complex_tan(VALUE obj)
1650
- {
1651
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_tan);
1652
- }
1653
-
1654
- static VALUE rb_gsl_vector_complex_sec(VALUE obj)
1655
- {
1656
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_sec);
1657
- }
1658
-
1659
- static VALUE rb_gsl_vector_complex_csc(VALUE obj)
1660
- {
1661
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_csc);
1662
- }
1663
- static VALUE rb_gsl_vector_complex_cot(VALUE obj)
1664
- {
1665
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_cot);
1666
- }
1667
-
1668
- static VALUE rb_gsl_vector_complex_arcsin(VALUE obj)
1669
- {
1670
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arcsin);
1671
- }
1672
-
1673
- static VALUE rb_gsl_vector_complex_arccos(VALUE obj)
1674
- {
1675
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arccos);
1676
- }
1677
-
1678
- static VALUE rb_gsl_vector_complex_arctan(VALUE obj)
1679
- {
1680
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arctan);
1681
- }
1682
-
1683
- static VALUE rb_gsl_vector_complex_arcsec(VALUE obj)
1684
- {
1685
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arcsec);
1686
- }
1687
-
1688
- static VALUE rb_gsl_vector_complex_arccsc(VALUE obj)
1689
- {
1690
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arccsc);
1691
- }
1692
-
1693
- static VALUE rb_gsl_vector_complex_arccot(VALUE obj)
1694
- {
1695
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arccot);
1696
- }
1697
-
1698
- static VALUE rb_gsl_vector_complex_sinh(VALUE obj)
1699
- {
1700
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_sinh);
1701
- }
1702
-
1703
- static VALUE rb_gsl_vector_complex_cosh(VALUE obj)
1704
- {
1705
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_cosh);
1706
- }
1707
-
1708
- static VALUE rb_gsl_vector_complex_tanh(VALUE obj)
1709
- {
1710
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_tanh);
1711
- }
1712
-
1713
- static VALUE rb_gsl_vector_complex_sech(VALUE obj)
1714
- {
1715
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_sech);
1716
- }
1717
-
1718
- static VALUE rb_gsl_vector_complex_csch(VALUE obj)
1719
- {
1720
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_csch);
1721
- }
1722
-
1723
- static VALUE rb_gsl_vector_complex_coth(VALUE obj)
1724
- {
1725
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_coth);
1726
- }
1727
-
1728
- static VALUE rb_gsl_vector_complex_arcsinh(VALUE obj)
1729
- {
1730
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arcsinh);
1731
- }
1732
-
1733
- static VALUE rb_gsl_vector_complex_arccosh(VALUE obj)
1734
- {
1735
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arccosh);
1736
- }
1737
-
1738
- static VALUE rb_gsl_vector_complex_arctanh(VALUE obj)
1739
- {
1740
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arctanh);
1741
- }
1742
-
1743
- static VALUE rb_gsl_vector_complex_arcsech(VALUE obj)
1744
- {
1745
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arcsech);
1746
- }
1747
-
1748
- static VALUE rb_gsl_vector_complex_arccsch(VALUE obj)
1749
- {
1750
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arccsch);
1751
- }
1752
-
1753
- static VALUE rb_gsl_vector_complex_arccoth(VALUE obj)
1754
- {
1755
- return rb_gsl_vector_complex_XXXz(obj, gsl_complex_arccoth);
1756
- }
1757
-
1758
- static VALUE rb_gsl_vector_complex_concat(VALUE obj, VALUE other)
1759
- {
1760
- gsl_vector_complex *v = NULL, *v2 = NULL, *vnew = NULL;
1761
- gsl_vector_complex_view vv;
1762
- gsl_complex tmp;
1763
- VALUE x;
1764
- double beg, end;
1765
- int step;
1766
- size_t i, size2;
1767
-
1768
- Data_Get_Struct(obj, gsl_vector_complex, v);
1769
-
1770
- switch(TYPE(other)) {
1771
- case T_FIXNUM:
1772
- case T_BIGNUM:
1773
- case T_FLOAT:
1774
- vnew = gsl_vector_complex_alloc(v->size + 1);
1775
- vv = gsl_vector_complex_subvector(vnew, 0, v->size);
1776
- gsl_vector_complex_memcpy(&vv.vector, v);
1777
- gsl_vector_complex_set(vnew, v->size, rb_gsl_obj_to_gsl_complex(other, NULL));
1778
- break;
1779
-
1780
- case T_ARRAY:
1781
- size2 = RARRAY_LEN(other);
1782
- vnew = gsl_vector_complex_alloc(v->size + size2);
1783
- vv = gsl_vector_complex_subvector(vnew, 0, v->size);
1784
- gsl_vector_complex_memcpy(&vv.vector, v);
1785
- for (i = 0; i < size2; i++) {
1786
- x = rb_ary_entry(other, i);
1787
- gsl_vector_complex_set(vnew, v->size + i, rb_gsl_obj_to_gsl_complex(x, NULL));
1788
- }
1789
- break;
1790
-
1791
- default:
1792
- if(rb_obj_is_kind_of(other, cgsl_complex)) {
1793
- vnew = gsl_vector_complex_alloc(v->size + 1);
1794
- vv = gsl_vector_complex_subvector(vnew, 0, v->size);
1795
- gsl_vector_complex_memcpy(&vv.vector, v);
1796
- gsl_vector_complex_set(vnew, v->size, rb_gsl_obj_to_gsl_complex(other, NULL));
1797
- } else if(rb_obj_is_kind_of(other, rb_cRange)) {
1798
- get_range_beg_en_n(other, &beg, &end, &size2, &step);
1799
- vnew = gsl_vector_complex_alloc(v->size + size2);
1800
- vv = gsl_vector_complex_subvector(vnew, 0, v->size);
1801
- gsl_vector_complex_memcpy(&vv.vector, v);
1802
- GSL_SET_COMPLEX(&tmp, beg, 0.0);
1803
- for (i = 0; i < size2; i++) {
1804
- gsl_vector_complex_set(vnew, v->size + i, tmp);
1805
- GSL_SET_REAL(&tmp, GSL_REAL(tmp) + step);
1806
- }
1807
- } else if (rb_obj_is_kind_of(other, cgsl_vector_complex)) {
1808
- Data_Get_Struct(other, gsl_vector_complex, v2);
1809
- size2 = v2->size;
1810
- vnew = gsl_vector_complex_alloc(v->size + size2);
1811
- vv = gsl_vector_complex_subvector(vnew, 0, v->size);
1812
- gsl_vector_complex_memcpy(&vv.vector, v);
1813
- vv = gsl_vector_complex_subvector(vnew, v->size, size2);
1814
- gsl_vector_complex_memcpy(&vv.vector, v2);
1815
- } else {
1816
- rb_raise(rb_eTypeError, "wrong argument type %s (Array, Numeric, Range, GSL::Complex, or %s expected)",
1817
- rb_class2name(CLASS_OF(other)), rb_class2name(cgsl_vector_complex));
1818
- }
1819
- break;
1820
- }
1821
-
1822
- return Data_Wrap_Struct(VECTOR_COMPLEX_ROW_COL(obj), 0, gsl_vector_complex_free, vnew);
1823
- }
1824
-
1825
- static VALUE rb_gsl_vector_complex_block(VALUE obj)
1826
- {
1827
- gsl_vector_complex *v = NULL;
1828
- Data_Get_Struct(obj, gsl_vector_complex, v);
1829
- return Data_Wrap_Struct(cgsl_block_complex, 0, NULL, v->block);
1830
- }
1831
-
1832
- static VALUE rb_gsl_vector_complex_indgen_bang(int argc, VALUE *argv[], VALUE obj)
1833
- {
1834
- gsl_vector_complex *v = NULL;
1835
- double start = 0.0, step = 1.0, x;
1836
- size_t i;
1837
- switch (argc) {
1838
- case 0:
1839
- break;
1840
- case 1:
1841
- start = NUM2DBL(argv[0]);
1842
- break;
1843
- case 2:
1844
- start = NUM2DBL(argv[0]);
1845
- step = NUM2DBL(argv[1]);
1846
- break;
1847
- default:
1848
- rb_raise(rb_eArgError, "Wrong number of arguments (%d for 0-2)", argc);
1849
- }
1850
- Data_Get_Struct(obj, gsl_vector_complex, v);
1851
- for (i = 0, x = start; i < v->size; i++, x += step) {
1852
- gsl_vector_complex_set(v, i, gsl_complex_rect(x,0));
1853
- }
1854
- return obj;
1855
- }
1856
-
1857
- static VALUE rb_gsl_vector_complex_indgen(int argc, VALUE *argv, VALUE obj)
1858
- {
1859
- gsl_vector_complex *v = NULL, *vnew;
1860
- double start = 0, step = 1, x;
1861
- size_t i;
1862
- switch (argc) {
1863
- case 0:
1864
- break;
1865
- case 1:
1866
- start = NUM2DBL(argv[0]);
1867
- break;
1868
- case 2:
1869
- start = NUM2DBL(argv[0]);
1870
- step = NUM2DBL(argv[1]);
1871
- break;
1872
- default:
1873
- rb_raise(rb_eArgError, "Wrong number of arguments (%d for 0-2)", argc);
1874
- }
1875
- Data_Get_Struct(obj, gsl_vector_complex, v);
1876
- vnew = gsl_vector_complex_calloc(v->size);
1877
- for (i = 0, x = start; i < vnew->size; i++, x += step) {
1878
- gsl_vector_complex_set(vnew, i, gsl_complex_rect(x,0));
1879
- }
1880
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
1881
- }
1882
-
1883
- static VALUE rb_gsl_vector_complex_indgen_singleton(int argc, VALUE *argv, VALUE obj)
1884
- {
1885
- gsl_vector_complex *vnew;
1886
- double start = 0, step = 1, x;
1887
- size_t n, i;
1888
- switch (argc) {
1889
- case 1:
1890
- n = (size_t) FIX2INT(argv[0]);
1891
- break;
1892
- case 2:
1893
- n = (size_t) FIX2INT(argv[0]);
1894
- start = NUM2DBL(argv[1]);
1895
- break;
1896
- case 3:
1897
- n = (size_t) FIX2INT(argv[0]);
1898
- start = NUM2DBL(argv[1]);
1899
- step = NUM2DBL(argv[2]);
1900
- break;
1901
- default:
1902
- rb_raise(rb_eArgError, "Wrong number of arguments (%d for 0-3)",argc);
1903
- }
1904
- vnew = gsl_vector_complex_calloc(n);
1905
- for (i = 0, x = start; i < vnew->size; i++, x += step) {
1906
- gsl_vector_complex_set(vnew, i, gsl_complex_rect(x,0));
1907
- }
1908
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
1909
- }
1910
-
1911
- static VALUE rb_gsl_vector_complex_phasor_singleton(int argc, VALUE *argv, VALUE obj)
1912
- {
1913
- gsl_vector_complex *vnew;
1914
- double start, step, theta;
1915
- size_t n, i;
1916
- switch (argc) {
1917
- case 1:
1918
- n = (size_t) FIX2INT(argv[0]);
1919
- start = 0;
1920
- step = 2 * M_PI / n;
1921
- break;
1922
- case 2:
1923
- n = (size_t) FIX2INT(argv[0]);
1924
- start = NUM2DBL(argv[1]);
1925
- step = 2 * M_PI / n;
1926
- break;
1927
- case 3:
1928
- n = (size_t) FIX2INT(argv[0]);
1929
- start = NUM2DBL(argv[1]);
1930
- step = NUM2DBL(argv[2]);
1931
- break;
1932
- default:
1933
- rb_raise(rb_eArgError, "Wrong number of arguments (%d for 0-3)",argc);
1934
- }
1935
- vnew = gsl_vector_complex_alloc(n);
1936
- for (i = 0, theta = start; i < vnew->size; i++, theta += step) {
1937
- gsl_vector_complex_set(vnew, i, gsl_complex_polar(1.0,theta));
1938
- }
1939
- return Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew);
1940
- }
1941
-
1942
- static VALUE rb_gsl_vector_complex_zip(int argc, VALUE *argv, VALUE obj)
1943
- {
1944
- gsl_vector_complex *v0, **vp, *vnew;
1945
- VALUE ary;
1946
- size_t i, j;
1947
- int argc2;
1948
- VALUE *argv2;
1949
- gsl_complex zzero = gsl_complex_rect(0, 0);
1950
- if (VECTOR_COMPLEX_P(obj)) {
1951
- Data_Get_Struct(obj, gsl_vector_complex, v0);
1952
- argc2 = argc;
1953
- argv2 = argv;
1954
- } else {
1955
- if (argc < 1) rb_raise(rb_eArgError, "Too few arguments.");
1956
- Data_Get_Struct(argv[0], gsl_vector_complex, v0);
1957
- argc2 = argc - 1;
1958
- argv2 = argv + 1;
1959
- }
1960
- for (i = 0; (int) i < argc2; i++) {
1961
- CHECK_VECTOR_COMPLEX(argv2[i]);
1962
- }
1963
- vp = (gsl_vector_complex**) malloc(sizeof(gsl_vector_complex**));
1964
- for (i = 0; (int) i < argc2; i++) {
1965
- Data_Get_Struct(argv2[i], gsl_vector_complex, vp[i]);
1966
- }
1967
- ary = rb_ary_new2(v0->size);
1968
- for (i = 0; i < v0->size; i++) {
1969
- vnew = gsl_vector_complex_alloc(argc2 + 1);
1970
- gsl_vector_complex_set(vnew, 0, gsl_vector_complex_get(v0, i));
1971
- for (j = 0; (int) j < argc2; j++) {
1972
- if (i < vp[j]->size) {
1973
- gsl_vector_complex_set(vnew, j+1, gsl_vector_complex_get(vp[j], i));
1974
- } else {
1975
- gsl_vector_complex_set(vnew, j+1, zzero);
1976
- }
1977
- }
1978
- rb_ary_store(ary, i, Data_Wrap_Struct(cgsl_vector_complex, 0, gsl_vector_complex_free, vnew));
1979
- }
1980
- free((gsl_vector_complex**) vp);
1981
- return ary;
1982
- }
1983
-
1984
- // Starting with version 1.15, GSL provides a gsl_vector_complex_equal
1985
- // function, but it only determines absolute equality (i.e. is has no epsilon
1986
- // argument).
1987
- static int gsl_vector_complex_equal_eps(const gsl_vector_complex *v1,
1988
- const gsl_vector_complex *v2, double eps)
1989
- {
1990
- gsl_complex z1, z2;
1991
- size_t i;
1992
- if (v1->size != v2->size) return 0;
1993
- for (i = 0; i < v1->size; i++) {
1994
- z1 = gsl_vector_complex_get(v1, i);
1995
- z2 = gsl_vector_complex_get(v2, i);
1996
- if (!rbgsl_complex_equal(&z1, &z2, eps)) return 0;
1997
- }
1998
- return 1;
1999
-
2000
- }
2001
-
2002
- static VALUE rb_gsl_vector_complex_equal(int argc, VALUE *argv, VALUE obj)
2003
- {
2004
- gsl_vector_complex *v1, *v2;
2005
- double eps = 1e-8;
2006
- int ret;
2007
- switch (argc) {
2008
- case 1:
2009
- eps = 1e-8;
2010
- break;
2011
- case 2:
2012
- eps = NUM2DBL(argv[1]);
2013
- break;
2014
- default:
2015
- rb_raise(rb_eArgError, "Wrong number of arguments (%d for 1 or 2)\n", argc);
2016
- }
2017
- Data_Get_Struct(obj, gsl_vector_complex, v1);
2018
- CHECK_VECTOR_COMPLEX(argv[0]);
2019
- Data_Get_Struct(argv[0], gsl_vector_complex, v2);
2020
- ret = gsl_vector_complex_equal_eps(v1, v2, eps);
2021
- if (ret == 1) return Qtrue;
2022
- else return Qfalse;
2023
- }
2024
-
2025
- static VALUE rb_gsl_vector_complex_not_equal(int argc, VALUE *argv, VALUE obj)
2026
- {
2027
- VALUE ret;
2028
- ret = rb_gsl_vector_complex_equal(argc, argv, obj);
2029
- if (ret == Qtrue) return Qfalse;
2030
- else return Qtrue;
2031
- }
2032
-
2033
- void Init_gsl_vector_complex(VALUE module)
2034
- {
2035
- rb_define_singleton_method(cgsl_vector_complex, "new", rb_gsl_vector_complex_new, -1);
2036
- rb_define_singleton_method(cgsl_vector_complex, "[]", rb_gsl_vector_complex_new, -1);
2037
- rb_define_singleton_method(cgsl_vector_complex, "alloc", rb_gsl_vector_complex_new, -1);
2038
- rb_define_singleton_method(cgsl_vector_complex, "calloc", rb_gsl_vector_complex_calloc, 1);
2039
-
2040
- rb_define_singleton_method(cgsl_vector_complex_col, "new",
2041
- rb_gsl_vector_complex_row_new, -1);
2042
-
2043
- rb_define_method(cgsl_vector_complex, "size", rb_gsl_vector_complex_size, 0);
2044
- rb_define_alias(cgsl_vector_complex, "len", "size");
2045
- rb_define_alias(cgsl_vector_complex, "length", "size");
2046
- rb_define_method(cgsl_vector_complex, "stride", rb_gsl_vector_complex_stride, 0);
2047
- rb_define_method(cgsl_vector_complex, "owner", rb_gsl_vector_complex_owner, 0);
2048
- rb_define_method(cgsl_vector_complex, "get", rb_gsl_vector_complex_get, -1);
2049
- rb_define_alias(cgsl_vector_complex, "[]", "get");
2050
- rb_define_method(cgsl_vector_complex, "ptr", rb_gsl_vector_complex_ptr, 1);
2051
-
2052
- rb_define_method(cgsl_vector_complex, "set", rb_gsl_vector_complex_set, -1);
2053
- rb_define_alias(cgsl_vector_complex, "[]=", "set");
2054
- rb_define_method(cgsl_vector_complex, "set_all", rb_gsl_vector_complex_set_all, -1);
2055
-
2056
- rb_define_method(cgsl_vector_complex, "each", rb_gsl_vector_complex_each, 0);
2057
- rb_define_method(cgsl_vector_complex, "reverse_each", rb_gsl_vector_complex_reverse_each, 0);
2058
- rb_define_method(cgsl_vector_complex, "each_index", rb_gsl_vector_complex_each_index, 0);
2059
- rb_define_method(cgsl_vector_complex, "reverse_each_index", rb_gsl_vector_complex_reverse_each_index, 0);
2060
- rb_define_method(cgsl_vector_complex, "collect", rb_gsl_vector_complex_collect, 0);
2061
- rb_define_method(cgsl_vector_complex, "collect!", rb_gsl_vector_complex_collect_bang, 0);
2062
- rb_define_alias(cgsl_vector_complex, "map", "collect");
2063
- rb_define_alias(cgsl_vector_complex, "map!", "collect!");
2064
-
2065
- rb_define_method(cgsl_vector_complex, "set_zero", rb_gsl_vector_complex_set_zero, 0);
2066
- rb_define_method(cgsl_vector_complex, "set_basis", rb_gsl_vector_complex_set_basis, 1);
2067
-
2068
- rb_define_method(cgsl_vector_complex, "to_s", rb_gsl_vector_complex_to_s, 0);
2069
- rb_define_method(cgsl_vector_complex, "fprintf", rb_gsl_vector_complex_fprintf, -1);
2070
- rb_define_method(cgsl_vector_complex, "printf", rb_gsl_vector_complex_printf, -1);
2071
- rb_define_method(cgsl_vector_complex, "print", rb_gsl_vector_complex_print, 0);
2072
- rb_define_method(cgsl_vector_complex, "inspect", rb_gsl_vector_complex_inspect, 0);
2073
- rb_define_method(cgsl_vector_complex, "fwrite", rb_gsl_vector_complex_fwrite, 1);
2074
- rb_define_method(cgsl_vector_complex, "fread", rb_gsl_vector_complex_fread, 1);
2075
- rb_define_method(cgsl_vector_complex, "fscanf", rb_gsl_vector_complex_fscanf, 1);
2076
-
2077
- rb_define_method(cgsl_vector_complex, "real", rb_gsl_vector_complex_real, 0);
2078
- rb_define_alias(cgsl_vector_complex, "re", "real");
2079
- rb_define_method(cgsl_vector_complex, "imag", rb_gsl_vector_complex_imag, 0);
2080
- rb_define_alias(cgsl_vector_complex, "im", "imag");
2081
-
2082
- rb_define_method(cgsl_vector_complex, "set_real", rb_gsl_vector_complex_set_real, 1);
2083
- rb_define_alias(cgsl_vector_complex, "real=", "set_real");
2084
- rb_define_alias(cgsl_vector_complex, "re=", "set_real");
2085
- rb_define_method(cgsl_vector_complex, "set_imag", rb_gsl_vector_complex_set_imag, 1);
2086
- rb_define_alias(cgsl_vector_complex, "imag=", "set_imag");
2087
- rb_define_alias(cgsl_vector_complex, "im=", "set_imag");
2088
-
2089
- rb_define_method(cgsl_vector_complex, "conj", rb_gsl_vector_complex_conj, 0);
2090
- rb_define_alias(cgsl_vector_complex, "conjugate", "conj");
2091
- rb_define_method(cgsl_vector_complex, "conj!", rb_gsl_vector_complex_conj_bang, 0);
2092
- rb_define_alias(cgsl_vector_complex, "conjugate!", "conj!");
2093
-
2094
- rb_define_method(cgsl_vector_complex, "to_a", rb_gsl_vector_complex_to_a, 0);
2095
- rb_define_method(cgsl_vector_complex, "to_a2", rb_gsl_vector_complex_to_a2, 0);
2096
-
2097
- rb_define_method(cgsl_vector_complex, "subvector", rb_gsl_vector_complex_subvector, -1);
2098
- rb_define_alias(cgsl_vector_complex, "view", "subvector");
2099
- rb_define_method(cgsl_vector_complex, "subvector_with_stride", rb_gsl_vector_complex_subvector_with_stride, 3);
2100
-
2101
- rb_define_singleton_method(cgsl_vector_complex, "memcpy", rb_gsl_vector_complex_memcpy, 2);
2102
- rb_define_method(cgsl_vector_complex, "clone", rb_gsl_vector_complex_clone, 0);
2103
- rb_define_alias(cgsl_vector_complex, "duplicate", "clone");
2104
- rb_define_alias(cgsl_vector_complex, "dup", "clone");
2105
- rb_define_method(cgsl_vector_complex, "reverse!", rb_gsl_vector_complex_reverse, 0);
2106
- rb_define_method(cgsl_vector_complex, "reverse", rb_gsl_vector_complex_reverse2, 0);
2107
- rb_define_method(cgsl_vector_complex, "swap_elements", rb_gsl_vector_complex_swap_elements, 2);
2108
- rb_define_method(cgsl_vector_complex, "fftshift!", rb_gsl_vector_complex_fftshift_bang, 0);
2109
- rb_define_method(cgsl_vector_complex, "fftshift", rb_gsl_vector_complex_fftshift, 0);
2110
- rb_define_method(cgsl_vector_complex, "ifftshift!", rb_gsl_vector_complex_ifftshift_bang, 0);
2111
- rb_define_method(cgsl_vector_complex, "ifftshift", rb_gsl_vector_complex_ifftshift, 0);
2112
- rb_define_method(cgsl_vector_complex, "isnull", rb_gsl_vector_complex_isnull, 0);
2113
-
2114
- rb_define_method(cgsl_vector_complex, "matrix_view", rb_gsl_vector_complex_matrix_view, -1);
2115
- rb_define_method(cgsl_vector_complex, "matrix_view_with_tda", rb_gsl_vector_complex_matrix_view_with_tda, -1);
2116
-
2117
- rb_define_method(cgsl_vector_complex, "trans", rb_gsl_vector_complex_trans, 0);
2118
- rb_define_alias(cgsl_vector_complex, "transpose", "trans");
2119
- rb_define_method(cgsl_vector_complex, "trans!", rb_gsl_vector_complex_trans2, 0);
2120
- rb_define_alias(cgsl_vector_complex, "transpose!", "trans!");
2121
-
2122
- /*****/
2123
- rb_define_alias(cgsl_vector_complex, "col", "trans");
2124
- rb_define_alias(cgsl_vector_complex, "col!", "trans!");
2125
-
2126
- rb_define_alias(cgsl_vector_complex_col, "row", "trans");
2127
- rb_define_alias(cgsl_vector_complex_col, "row!", "trans!");
2128
-
2129
- /*****/
2130
- rb_define_method(cgsl_vector_complex, "to_real", rb_gsl_vector_complex_to_real, 0);
2131
-
2132
- rb_define_method(cgsl_vector_complex, "add", rb_gsl_vector_complex_add, 1);
2133
- rb_define_method(cgsl_vector_complex, "sub", rb_gsl_vector_complex_sub, 1);
2134
- rb_define_method(cgsl_vector_complex, "mul", rb_gsl_vector_complex_mul, 1);
2135
- rb_define_method(cgsl_vector_complex, "div", rb_gsl_vector_complex_div, 1);
2136
- rb_define_method(cgsl_vector_complex, "add!", rb_gsl_vector_complex_add_bang, 1);
2137
- rb_define_method(cgsl_vector_complex, "sub!", rb_gsl_vector_complex_sub_bang, 1);
2138
- rb_define_method(cgsl_vector_complex, "mul!", rb_gsl_vector_complex_mul_bang, 1);
2139
- rb_define_method(cgsl_vector_complex, "div!", rb_gsl_vector_complex_div_bang, 1);
2140
-
2141
- rb_define_alias(cgsl_vector_complex, "+", "add");
2142
- rb_define_alias(cgsl_vector_complex, "add_constant", "add");
2143
- rb_define_alias(cgsl_vector_complex, "add_constant!", "add!");
2144
- rb_define_alias(cgsl_vector_complex, "-", "sub");
2145
- rb_define_alias(cgsl_vector_complex, "*", "mul");
2146
- rb_define_alias(cgsl_vector_complex, "scale", "mul");
2147
- rb_define_alias(cgsl_vector_complex, "scale!", "mul!");
2148
- rb_define_alias(cgsl_vector_complex, "/", "div");
2149
-
2150
- rb_define_method(cgsl_vector_complex, "coerce", rb_gsl_vector_complex_coerce, 1);
2151
-
2152
- /* 2.Aug.2004 */
2153
- rb_define_singleton_method(cgsl_vector_complex, "inner_product", rb_gsl_vector_complex_inner_product, -1);
2154
- rb_define_singleton_method(cgsl_vector_complex, "dot", rb_gsl_vector_complex_inner_product, -1);
2155
- rb_define_method(cgsl_vector_complex, "inner_product", rb_gsl_vector_complex_inner_product, -1);
2156
- /* rb_define_alias(cgsl_vector_complex, "dot", "inner_product");*/
2157
-
2158
- /*****/
2159
- rb_define_method(cgsl_vector_complex, "-@", rb_gsl_vector_complex_uminus, 0);
2160
- rb_define_method(cgsl_vector_complex, "+@", rb_gsl_vector_complex_uplus, 0);
2161
-
2162
- rb_define_method(cgsl_vector_complex, "abs2", rb_gsl_vector_complex_abs2, 0);
2163
- rb_define_alias(cgsl_vector_complex, "square", "abs2");
2164
- rb_define_method(cgsl_vector_complex, "abs", rb_gsl_vector_complex_abs, 0);
2165
- rb_define_alias(cgsl_vector_complex, "amp", "abs");
2166
- rb_define_alias(cgsl_vector_complex, "mag", "abs");
2167
- rb_define_method(cgsl_vector_complex, "arg", rb_gsl_vector_complex_arg, 0);
2168
- rb_define_alias(cgsl_vector_complex, "angle", "arg");
2169
- rb_define_alias(cgsl_vector_complex, "phase", "arg");
2170
- rb_define_method(cgsl_vector_complex, "logabs", rb_gsl_vector_complex_logabs, 0);
2171
-
2172
- rb_define_method(cgsl_vector_complex, "sqrt", rb_gsl_vector_complex_sqrt, 0);
2173
- rb_define_method(cgsl_vector_complex, "sqrt!", rb_gsl_vector_complex_sqrt_bang, 0);
2174
- rb_define_method(cgsl_vector_complex, "exp", rb_gsl_vector_complex_exp, 0);
2175
- rb_define_method(cgsl_vector_complex, "exp!", rb_gsl_vector_complex_exp_bang, 0);
2176
- rb_define_method(cgsl_vector_complex, "pow", rb_gsl_vector_complex_pow, 1);
2177
- rb_define_method(cgsl_vector_complex, "pow!", rb_gsl_vector_complex_pow_bang, 1);
2178
- rb_define_method(cgsl_vector_complex, "log", rb_gsl_vector_complex_log, 0);
2179
- rb_define_method(cgsl_vector_complex, "log!", rb_gsl_vector_complex_log_bang, 0);
2180
- rb_define_method(cgsl_vector_complex, "log10", rb_gsl_vector_complex_log10, 0);
2181
- rb_define_method(cgsl_vector_complex, "log10!", rb_gsl_vector_complex_log10_bang, 0);
2182
- rb_define_method(cgsl_vector_complex, "log_b", rb_gsl_vector_complex_log_b, 1);
2183
- rb_define_method(cgsl_vector_complex, "log_b!", rb_gsl_vector_complex_log_b_bang, 1);
2184
-
2185
- rb_define_method(cgsl_vector_complex, "sum", rb_gsl_vector_complex_sum, 0);
2186
- rb_define_method(cgsl_vector_complex, "mean", rb_gsl_vector_complex_mean, 0);
2187
- rb_define_method(cgsl_vector_complex, "tss", rb_gsl_vector_complex_tss, 0);
2188
- rb_define_method(cgsl_vector_complex, "tss_m", rb_gsl_vector_complex_tss_m, 1);
2189
- rb_define_method(cgsl_vector_complex, "variance", rb_gsl_vector_complex_variance, 0);
2190
- rb_define_method(cgsl_vector_complex, "variance_m", rb_gsl_vector_complex_variance_m, 1);
2191
- rb_define_method(cgsl_vector_complex, "variance_fm", rb_gsl_vector_complex_variance_fm, 1);
2192
- rb_define_method(cgsl_vector_complex, "sd", rb_gsl_vector_complex_sd, 0);
2193
- rb_define_method(cgsl_vector_complex, "sd_m", rb_gsl_vector_complex_sd_m, 1);
2194
- rb_define_method(cgsl_vector_complex, "sd_fm", rb_gsl_vector_complex_sd_fm, 1);
2195
-
2196
- rb_define_method(cgsl_vector_complex, "sin", rb_gsl_vector_complex_sin, 0);
2197
- rb_define_method(cgsl_vector_complex, "cos", rb_gsl_vector_complex_cos, 0);
2198
- rb_define_method(cgsl_vector_complex, "tan", rb_gsl_vector_complex_tan, 0);
2199
- rb_define_method(cgsl_vector_complex, "sec", rb_gsl_vector_complex_sec, 0);
2200
- rb_define_method(cgsl_vector_complex, "csc", rb_gsl_vector_complex_csc, 0);
2201
- rb_define_method(cgsl_vector_complex, "cot", rb_gsl_vector_complex_cot, 0);
2202
-
2203
- rb_define_method(cgsl_vector_complex, "arcsin", rb_gsl_vector_complex_arcsin, 0);
2204
- rb_define_method(cgsl_vector_complex, "arccos", rb_gsl_vector_complex_arccos, 0);
2205
- rb_define_method(cgsl_vector_complex, "arctan", rb_gsl_vector_complex_arctan, 0);
2206
- rb_define_method(cgsl_vector_complex, "arcsec", rb_gsl_vector_complex_arcsec, 0);
2207
- rb_define_method(cgsl_vector_complex, "arccsc", rb_gsl_vector_complex_arccsc, 0);
2208
- rb_define_method(cgsl_vector_complex, "arccot", rb_gsl_vector_complex_arccot, 0);
2209
-
2210
- rb_define_method(cgsl_vector_complex, "sinh", rb_gsl_vector_complex_sinh, 0);
2211
- rb_define_method(cgsl_vector_complex, "cosh", rb_gsl_vector_complex_cosh, 0);
2212
- rb_define_method(cgsl_vector_complex, "tanh", rb_gsl_vector_complex_tanh, 0);
2213
- rb_define_method(cgsl_vector_complex, "sech", rb_gsl_vector_complex_sech, 0);
2214
- rb_define_method(cgsl_vector_complex, "csch", rb_gsl_vector_complex_csch, 0);
2215
- rb_define_method(cgsl_vector_complex, "coth", rb_gsl_vector_complex_coth, 0);
2216
-
2217
- rb_define_method(cgsl_vector_complex, "arcsinh", rb_gsl_vector_complex_arcsinh, 0);
2218
- rb_define_method(cgsl_vector_complex, "arccosh", rb_gsl_vector_complex_arccosh, 0);
2219
- rb_define_method(cgsl_vector_complex, "arctanh", rb_gsl_vector_complex_arctanh, 0);
2220
- rb_define_method(cgsl_vector_complex, "arcsech", rb_gsl_vector_complex_arcsech, 0);
2221
- rb_define_method(cgsl_vector_complex, "arccsch", rb_gsl_vector_complex_arccsch, 0);
2222
- rb_define_method(cgsl_vector_complex, "arccoth", rb_gsl_vector_complex_arccoth, 0);
2223
-
2224
- /*****/
2225
- rb_define_method(cgsl_vector_complex, "concat", rb_gsl_vector_complex_concat, 1);
2226
- rb_define_method(cgsl_vector_complex, "block", rb_gsl_vector_complex_block, 0);
2227
-
2228
- rb_define_method(cgsl_vector_complex, "indgen", rb_gsl_vector_complex_indgen, -1);
2229
- rb_define_method(cgsl_vector_complex, "indgen!", rb_gsl_vector_complex_indgen_bang, -1);
2230
- rb_define_singleton_method(cgsl_vector_complex, "indgen", rb_gsl_vector_complex_indgen_singleton, -1);
2231
- rb_define_singleton_method(cgsl_vector_complex, "phasor", rb_gsl_vector_complex_phasor_singleton, -1);
2232
-
2233
- rb_define_method(cgsl_vector_complex, "zip", rb_gsl_vector_complex_zip, -1);
2234
- rb_define_singleton_method(cgsl_vector_complex, "zip", rb_gsl_vector_complex_zip, -1);
2235
-
2236
- rb_define_method(cgsl_vector_complex, "equal?", rb_gsl_vector_complex_equal, -1);
2237
- rb_define_alias(cgsl_vector_complex, "==", "equal?");
2238
- rb_define_method(cgsl_vector_complex, "not_equal?", rb_gsl_vector_complex_not_equal, -1);
2239
- rb_define_alias(cgsl_vector_complex, "!=", "not_equal?");
2240
- }
2241
-