rb-gsl 1.16.0.5 → 1.16.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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,88 +0,0 @@
1
- #
2
- # = N-tuples
3
- # This chapter describes functions for creating and manipulating ntuples,
4
- # sets of values associated with events. The ntuples are stored in files.
5
- # Their values can be extracted in any combination and booked in a histogram using
6
- # a selection function.
7
- #
8
- # The values to be stored are held in a {GSL::Vector}[link:rdoc/vector_rdoc.html] or
9
- # a {GSL::Matrix}[link:rdoc/matrix_rdoc.html] object,
10
- # and an ntuple is created associating this object with a file.
11
- # The values are then written to the file (normally inside a loop) using
12
- # the ntuple functions described below.
13
- #
14
- # A histogram can be created from ntuple data by providing a selection function
15
- # and a value function. The selection function specifies whether an event should
16
- # be included in the subset to be analyzed or not. The value function computes
17
- # the entry to be added to the histogram for each event.
18
- #
19
- # == The <tt>Ntuple</tt> class
20
- # ---
21
- # * GSL::Ntuple.create(filename, v)
22
- # * GSL::Ntuple.alloc(filename, v)
23
- #
24
- # These create a new write-only ntuple file <tt>filename</tt> for ntuples.
25
- # Any existing file with the same name is truncated to zero length and overwritten.
26
- # A preexisting <tt>Vector</tt> object <tt>v</tt> for the current ntuple data must be supplied:
27
- # this is used to copy ntuples in and out of the file.
28
- #
29
- # ---
30
- # * GSL::Ntuple.open(filename, v)
31
- #
32
- # This opens an existing ntuple file <tt>filename</tt> for reading. A preexisting
33
- # <tt>Vector</tt> object <tt>v</tt> for the current ntuple data must be supplied.
34
- #
35
- # == Writing and reading ntuples
36
- # ---
37
- # * GSL::Ntuple#write
38
- # * GSL::Ntuple#bookdata
39
- #
40
- # This method writes the current ntuple data to the corresponding file.
41
- #
42
- # ---
43
- # * GSL::Ntuple#read
44
- #
45
- # This method reads the current row of the ntuple file.
46
- #
47
- # == Histogramming ntuple values
48
- # Once an ntuple has been created its contents can be histogrammed in various ways using
49
- # the function gsl_ntuple_project. Two user-defined functions must be provided, a function
50
- # to select events and a function to compute scalar values. The selection function and the
51
- # value function both accept the ntuple row as a first argument and other parameters as a
52
- # second argument.
53
- #
54
- # ---
55
- # * GSL::Ntuple::SelectFn.alloc {block}
56
- # * GSL::Ntuple::SelectFn.alloc(proc)
57
- # * GSL::Ntuple::ValueFn.alloc {block}
58
- # * GSL::Ntuple::ValueFn.alloc(proc)
59
- #
60
- # Constructors for selection functions and value functions.
61
- # The selection function shoud return a non-zero value for each ntuple row that
62
- # is to be included in the histogram. The value function should return the value to
63
- # be added to the histogram for the ntuple row.
64
- #
65
- # ---
66
- # * GSL::Ntuple::SelectFn#set_params(params)
67
- # * GSL::Ntuple::ValueFn#set_params(params)
68
- #
69
- # Set the parameters of the functions, by an array <tt>params</tt>.
70
- #
71
- # ---
72
- # * GSL::Ntuple.project(h, n, valfn, selfn)
73
- #
74
- # These methods updates the histogram <tt>h</tt> from the ntuple <tt>n</tt> using
75
- # the functions <tt>valfn</tt> and <tt>selfn</tt>. For each ntuple row where the selection
76
- # function <tt>selen</tt> is non-zero the corresponding value of that row is computed
77
- # using the function value_func<tt>valfn</tt> and added to the histogram <tt>h</tt>.
78
- # Those ntuple rows where <tt>selfn</tt> returns zero are ignored. New entries are added
79
- # to the histogram, so subsequent calls can be used to accumulate further data in the
80
- # same histogram.
81
- #
82
- # {prev}[link:rdoc/hist2d_rdoc.html]
83
- # {next}[link:rdoc/monte_rdoc.html]
84
- #
85
- # {Reference index}[link:rdoc/ref_rdoc.html]
86
- # {top}[link:index.html]
87
- #
88
- #
@@ -1,378 +0,0 @@
1
- #
2
- # = Ordinary Differential Equations
3
- # This chapter describes functions for solving ordinary differential equation
4
- # (ODE) initial value problems. The library provides a variety of low-level
5
- # methods, such as Runge-Kutta and Bulirsch-Stoer routines, and higher-level
6
- # components for adaptive step-size control. The components can be combined
7
- # by the user to achieve the desired solution, with full access to any
8
- # intermediate steps.
9
- #
10
- #
11
- # Contents:
12
- # 1. {Classes for ODE solver}[link:rdoc/odeiv_rdoc.html#label-Classes+for+ODE+solver]
13
- # 1. {Class Descriptions}[link:rdoc/odeiv_rdoc.html#label-Class+Descriptions]
14
- # 1. {GSL::Odeiv::System : Defining the ODE System}[link:rdoc/odeiv_rdoc.html#label-System]
15
- # 1. {GSL::Odeiv::Step : Stepping Algorithms}[link:rdoc/odeiv_rdoc.html#label-Step]
16
- # 1. {GSL::Odeiv::Control : Adaptive Step-size Control}[link:rdoc/odeiv_rdoc.html#label-Control]
17
- # 1. {GSL::Odeiv::Evolve : Evolution}[link:rdoc/odeiv_rdoc.html#label-Evolve]
18
- # 1. {GSL::Odeiv::Solver : Higher level interface}[link:rdoc/odeiv_rdoc.html#label-Solver]
19
- # 1. {Examples}[link:rdoc/odeiv_rdoc.html#label-Example]
20
- #
21
- # == Classes for ODE solver
22
- #
23
- # ---
24
- # * GSL::Odeiv::System
25
- # * GSL::Odeiv::Step
26
- # * GSL::Odeiv::Control
27
- # * GSL::Odeiv::Evolve
28
- #
29
- # These are GSL structure wrappers.
30
- #
31
- # ---
32
- # * GSL::Odeiv::Solver
33
- #
34
- # Another higher-level interface to ODE system classes.
35
- #
36
- # == Class Descriptions
37
- #
38
- # === System
39
- # ---
40
- # * GSL::Odeiv::System.alloc(func, jac, dim)
41
- # * GSL::Odeiv::System.alloc(func, dim)
42
- #
43
- # Constructor. This defines a general ODE system with the dimension <tt>dim</tt>.
44
- #
45
- # # t: variable (scalar)
46
- # # y: vector
47
- # # dydt: vector
48
- # # params: scalar or an array
49
- #
50
- # func = Proc.new { |t, y, dydt, params|
51
- # mu = params
52
- # dydt[0] = y[1]
53
- # dydt[1] = -y[0] - mu*y[1]*(y[0]*y[0] - 1.0)
54
- # }
55
- #
56
- # # t: scalar
57
- # # y: vector
58
- # # dfdy: matrix, jacobian
59
- # # dfdt: vector
60
- # # params: scalar of an array
61
- # jac = Proc.new { |t, y, dfdy, dfdt, params|
62
- # mu = params
63
- # dfdy.set(0, 0, 0.0)
64
- # dfdy.set(0, 1, 1.0)
65
- # dfdy.set(1, 0, -2*mu*y[0]*y[1] - 1.0)
66
- # dfdy.set(1, 1, -mu*(y[0]*y[0] - 1.0))
67
- # dfdt[0] = 0.0
68
- # dfdt[1] = 0.0
69
- # }
70
- #
71
- # sys = GSL:Odeiv::System.alloc(func, jac, dim) # for "BSIMP" algorithm
72
- #
73
- # Note that some of the simpler solver algorithms do not make use of the
74
- # Jacobian matrix, so it is not always strictly necessary to provide it.
75
- # Thus the constructor is as
76
- # sys = GSL:Odeiv::System.alloc(func, nil, dim) # for others, replaced by nil
77
- # sys = GSL:Odeiv::System.alloc(func, dim) # or omit
78
- #
79
- # ---
80
- # * GSL::Odeiv::System#set(func, jac, parameters...)
81
- #
82
- # This method sets or resets the procedures to evaluate the function and jacobian,
83
- # and the constant parameters.
84
- #
85
- # ---
86
- # * GSL::Odeiv::System#set_params(...)
87
- #
88
- # Set the constant parameters of the function.
89
- # ---
90
- # * GSL::Odeiv::System#function
91
- # * GSL::Odeiv::System#func
92
- # * GSL::Odeiv::System#jacobian
93
- # * GSL::Odeiv::System#jac
94
- #
95
- # Return Proc objects
96
- #
97
- # ---
98
- # * GSL::Odeiv::System#dimension
99
- # * GSL::Odeiv::System#dim
100
- #
101
- #
102
- # === Step
103
- # The lowest level components are the stepping functions which advance a solution from time <tt>t</tt> to <tt>t+h</tt> for a fixed step-size <tt>h</tt> and estimate the resulting local error.
104
- #
105
- # ---
106
- # * GSL::Odeiv::Step.alloc(T, dim)
107
- #
108
- # Constructor for a stepping function of an algorithm type <tt>T</tt> for a system of
109
- # dimension <tt>dim</tt>. The algorithms are specified by one of the constants under the
110
- # <tt>GSL::Odeiv::Step</tt> class, as
111
- #
112
- # 1. <tt>GSL::Odeiv::Step::RK2</tt>, Embedded 2nd order Runge-Kutta with 3rd order error estimate.
113
- # 1. <tt>GSL::Odeiv::Step::RK4</tt>, 4th order (classical) Runge-Kutta.
114
- # 1. <tt>GSL::Odeiv::Step::RKF45</tt>, Embedded 4th order Runge-Kutta-Fehlberg method with 5th order error estimate. This method is a good general-purpose integrator.
115
- # 1. <tt>GSL::Odeiv::Step::RKCK</tt>, Embedded 4th order Runge-Kutta Cash-Karp method with 5th order error estimate.
116
- # 1. <tt>GSL::Odeiv::Step::RK8PD</tt>, Embedded 8th order Runge-Kutta Prince-Dormand method with 9th order error estimate.
117
- # 1. <tt>GSL::Odeiv::Step::RK2IMP</tt>, Implicit 2nd order Runge-Kutta at Gaussian points
118
- # 1. <tt>GSL::Odeiv::Step::RK4IMP</tt>, Implicit 4th order Runge-Kutta at Gaussian points
119
- # 1. <tt>GSL::Odeiv::Step::BSIMP</tt>, Implicit Bulirsch-Stoer method of Bader and Deuflhard. This algorithm requires the Jacobian.
120
- # 1. <tt>GSL::Odeiv::Step::GEAR1</tt>, M=1 implicit Gear method
121
- # 1. <tt>GSL::Odeiv::Step::GEAR2</tt>, M=2 implicit Gear method
122
- # 1. <tt>GSL::Odeiv::Step::RK2SIMP</tt> (GSL-1.6)
123
- #
124
- # * Ex:
125
- # step = Odeiv::Step.alloc(Odeiv::Step::RKF45, 2)
126
- #
127
- # The algorithm types can also be given by a String, same as the C struct name,
128
- #
129
- # 1. "<tt>rk2</tt>" or "<tt>gsl_odeiv_step_rk2</tt>"
130
- # 1. "<tt>rk4</tt>" or "<tt>gsl_odeiv_step_rk4</tt>"
131
- # 1. "<tt>rkf45</tt>" or "<tt>gsl_odeiv_step_rkf45</tt>"
132
- # 1. "<tt>rkck</tt>" or "<tt>gsl_odeiv_step_rkck</tt>"
133
- # 1. "<tt>rk8pd</tt>" or "<tt>gsl_odeiv_step_rk8pd</tt>"
134
- # 1. "<tt>rk2imp</tt>" or "<tt>gsl_odeiv_step_rk2imp</tt>"
135
- # 1. "<tt>rk4imp</tt>" or "<tt>gsl_odeiv_step_rk4imp</tt>"
136
- # 1. "<tt>bsimp</tt>" or "<tt>gsl_odeiv_step_bsimp</tt>"
137
- # 1. "<tt>gear1</tt>" or "<tt>gsl_odeiv_step_gear1</tt>"
138
- # 1. "<tt>gear2</tt>" or "<tt>gsl_odeiv_step_gear2</tt>"
139
- # 1. "<tt>rk2simp</tt>" or "<tt>gsl_odeiv_step_rk2simp</tt>" (GSL-1.6)
140
- #
141
- # * Ex:
142
- # step = Odeiv::Step.alloc("bsimp", 4)
143
- # step2 = Odeiv::Step.alloc("gsl_odeiv_step_rkck", 3)
144
- #
145
- # ---
146
- # * GSL::Odeiv::Step#reset
147
- #
148
- # This method resets the stepper. It should be used whenever the next use
149
- # of s will not be a continuation of a previous step.
150
- #
151
- # ---
152
- # * GSL::Odeiv::Step#name
153
- #
154
- # Returns the name of the stepper as a String. For example,
155
- #
156
- # require("gsl")
157
- # include Odeiv
158
- # s = Step.alloc(Step::RK4, 2)
159
- # printf("step method is '%s'\n", s.name)
160
- #
161
- # would print something like step method is 'rk4'.
162
- #
163
- # ---
164
- # * GSL::Odeiv::Step#order
165
- #
166
- # Returns the order of the stepper on the previous step.
167
- # This order can vary if the stepper itself is adaptive.
168
- #
169
- # ---
170
- # * GSL::Odeiv::Step#apply(t, h, y, yerr, dydt_in, dydt_out, sys)
171
- # * GSL::Odeiv::Step#apply(t, h, y, yerr, dydt_in, sys)
172
- # * GSL::Odeiv::Step#apply(t, h, y, yerr, sys)
173
- #
174
- # This method applies the stepper to the system of equations defined by
175
- # <tt>dydt</tt>, using the step size <tt>h</tt> to advance the system from time
176
- # <tt>t</tt> and state <tt>y</tt> to time <tt>t+h</tt>. The new state of the system
177
- # is stored in <tt>y</tt> on output, with an estimate of the absolute error in
178
- # each component stored in <tt>yerr</tt>. If the argument <tt>dydt_in</tt> is not
179
- # <tt>nil</tt> it should be a {GSL::Vector}[link:rdoc/vector_rdoc.html] object
180
- # containing the derivatives for the system at time <tt>t</tt> on input.
181
- # This is optional as the derivatives will be computed internally if they
182
- # are not provided, but allows the reuse of existing derivative information.
183
- # On output the new derivatives of the system at time <tt>t+h</tt> will be
184
- # stored in <tt>dydt_out</tt> if it is not nil.
185
- #
186
- # === Control
187
- # ---
188
- # * GSL::Odeiv::Control.standard_new(epsabs, epsrel, a_y, a_dydt)
189
- # * GSL::Odeiv::Control.alloc(epsabs, epsrel, a_y, a_dydt)
190
- #
191
- # The standard control object is a four parameter heuristic based on
192
- # absolute and relative errors <tt>epsabs</tt> and <tt>epsrel</tt>, and
193
- # scaling factors <tt>a_y</tt> and <tt>a_dydt</tt> for the system state
194
- # <tt>y(t)</tt> and derivatives <tt>y'(t)</tt> respectively.
195
- #
196
- # ---
197
- # * GSL::Odeiv::Control.y_new(epsabs, epsrel)
198
- #
199
- # This method creates a new control object which will keep the local error
200
- # on each step within an absolute error of <tt>epsabs</tt> and relative error
201
- # of <tt>epsrel</tt> with respect to the solution <tt>y_i(t)</tt>.
202
- # This is equivalent to the standard control object with <tt>a_y=1</tt>
203
- # and <tt>a_dydt=0</tt>.
204
- #
205
- # ---
206
- # * GSL::Odeiv::Control.yp_new(epsabs, epsrel)
207
- #
208
- # This method creates a new control object which will keep the local
209
- # error on each step within an absolute error of <tt>epsabs</tt> and
210
- # relative error of <tt>epsrel</tt> with respect to the derivatives of the
211
- # solution <tt>y'_i(t)</tt>.
212
- # This is equivalent to the standard control object with <tt>a_y=0</tt>
213
- # and <tt>a_dydt=1</tt>.
214
- #
215
- # ---
216
- # * GSL::Odeiv::Control.alloc(epsabs, epsrel, a_y, a_dydt, vscale, dim)
217
- #
218
- # This creates a new control object which uses the same algorithm as
219
- # <tt>GSL::Odeiv::Control.standard_new</tt> but with an absolute error which
220
- # is scaled for each component by the <tt>GSL::Vector</tt> object <tt>vscale</tt>.
221
- #
222
- # ---
223
- # * GSL::Odeiv::Control#init(epsabs, epsrel, a_y, a_dydt)
224
- #
225
- # This method initializes the controler with the parameters <tt>epsabs</tt>
226
- # (absolute error), <tt>epsrel</tt> (relative error), <tt>a_y</tt>
227
- # (scaling factor for y) and <tt>a_dydt</tt> (scaling factor for derivatives).
228
- #
229
- # ---
230
- # * GSL::Odeiv::Control#name
231
- # * GSL::Odeiv::Control#hadjust(step, y0, yerr, dydt, h)
232
- #
233
- # This method adjusts the step-size <tt>h</tt> using the control function
234
- # object, and the current values of <tt>y</tt>, <tt>yerr</tt> and <tt>dydt</tt>.
235
- # The stepping function <tt>step</tt> is also needed to determine the order
236
- # of the method. On output, an array of two elements [<tt>hadj, status</tt>]
237
- # is returned: If the error in the y-values <tt>yerr</tt> is found to be
238
- # too large then the step-size <tt>h</tt> is reduced and the method returns
239
- # [<tt>hadj, status</tt>=<tt>GSL::ODEIV::HADJ_DEC</tt>].
240
- # If the error is sufficiently small then
241
- # <tt>h</tt> may be increased and [<tt>hadj, status</tt>=<tt>GSL::ODEIV::HADJ_INC</tt>]
242
- # is returned.
243
- # The method returns [<tt>hadj, status</tt>=<tt>GSL::ODEIV::HADJ_NIL</tt>] if the step-size is
244
- # unchanged. The goal of the method is to estimate the largest step-size
245
- # which satisfies the user-specified accuracy requirements for the current
246
- # point.
247
- #
248
- # === Evolve
249
- # The higher level of the system is the <tt>GSL::Evolve</tt> class which combines the
250
- # results of a stepper and controler to reliably advance the solution forward
251
- # over an interval <tt>(t_0, t_1)</tt>. If the controler signals that the step-size
252
- # should be decreased the <tt>GSL::Evolve</tt> object backs out of the current step and
253
- # tries the proposed smaller step-size. This process is continued until an
254
- # acceptable step-size is found.
255
- #
256
- # ---
257
- # * GSL::Odeiv::Evolve.alloc(dim)
258
- #
259
- # These create a <tt>GSL::Evolve</tt> object for a system of <tt>dim</tt> dimensions.
260
- #
261
- # ---
262
- # * GSL::Odeiv::Evolve#reset
263
- #
264
- # This method resets the GSL::Evolve object. It should be used whenever
265
- # the next use of e will not be a continuation of a previous step.
266
- #
267
- # ---
268
- # * GSL::Odeiv::Evolve#apply(evolve, control, step, sys, t, t1, h, y)
269
- #
270
- # This method advances the system <tt>sys</tt> from time <tt>t</tt> and position
271
- # <tt>y</tt> using the stepping function <tt>step</tt>. The initial step-size is
272
- # taken as <tt>h</tt>. The maximum time <tt>t1</tt> is guaranteed not to be exceeded by
273
- # the time-step. On output, an array of three elements is returned,
274
- # [<tt>tnext, hnext, status</tt>], where <tt>tnext</tt> is the time advanced,
275
- # <tt>hnext</tt> is the step-size
276
- # for the next step, and <tt>status</tt> is an error code retunred by <tt>gsl_odeiv_evolve_apply()</tt> function.
277
- # On the final time-step the value of <tt>tnext</tt> will be set to
278
- # <tt>t1</tt> exactly.
279
- #
280
- # ---
281
- # * GSL::Odeiv::Evolve#count
282
- #
283
- #
284
- # === Solver
285
- # This is the highest level interface to solve ODE system,
286
- # which contains System, Step, Control, and Evolve classes.
287
- #
288
- # ---
289
- # * GSL::Odeiv::Solver.alloc(T, cary, fac, dim)
290
- #
291
- # This creates a ODE solver with the algorithm type <tt>T</tt> for the system of dimention <tt>dim</tt>. Here <tt>cary</tt> is an array as an argument for the <tt>GSL::Odeive:Control</tt> constructor.
292
- #
293
- # * Ex1
294
- # solver = Odeiv::Solver.alloc(Odeiv::Step::RKF45, [1e-6, 0.0], func, dim)
295
- #
296
- # * Type: RKF45,
297
- # * Control: epsabs = 1e-6, epsrel = 0.0, a_y = 1, a_dydt = 0
298
- # * System: function = <tt>func</tt>, jacobian = <tt>nil</tt>
299
- # * Dimension: dim
300
- #
301
- # * Ex2:
302
- # solver = Odeiv::Solver.alloc(Odeiv::Step::BSIMP, [1e-6, 0.0, 1, 0], func, jac, dim)
303
- #
304
- # * Type: BSIMP,
305
- # * Control: epsabs = 1e-6, epsrel = 0.0, a_y = 1, a_dydt = 0
306
- # * System: function = <tt>func</tt>, jacobian = <tt>jac</tt>
307
- # * Dimension: dim
308
- #
309
- # ---
310
- # * GSL::Odeiv:::Solver#reset
311
- #
312
- # Reset the solver elements (step, evolve)
313
- #
314
- # ---
315
- # * GSL::Odeiv:::Solver#step
316
- # * GSL::Odeiv:::Solver#control
317
- # * GSL::Odeiv:::Solver#evolve
318
- # * GSL::Odeiv:::Solver#system
319
- #
320
- # Access to the solver elements.
321
- #
322
- # ---
323
- # * GSL::Odeiv::System#set_params(...)
324
- #
325
- # Set the constant parameters of the function to solve.
326
- #
327
- # ---
328
- # * GSL::Odeiv:::Solver#apply(t, t1, h, y)
329
- #
330
- # This method advances the system from time <tt>t</tt> and position <tt>y</tt> (<tt>GSL::Vector</tt> object) using the stepping function. On output, the new time and position are returned as an array [<tt>tnext, hnext, status</tt>], i.e. <tt>t, y</tt> themselves are not modified by this method. The maximum time <tt>t1</tt> is guaranteed not to be exceeded by the time-step. On the final time-step the value of <tt>tnext</tt> will be set to <tt>t1</tt> exactly.
331
- #
332
- # == Example
333
- #
334
- # The following program solves the second-order nonlinear Van der Pol oscillator equation,
335
- # as found in the GSL manual, x"(t) + \mu x'(t) (x(t)^2 - 1) + x(t) = 0,
336
- #
337
- # This can be converted into a first order system suitable for use with the routines described in this chapter by introducing a separate variable for the velocity, y = x'(t),
338
- #
339
- # * x' = y
340
- # * y' = -x + \mu y (1-x^2)
341
- #
342
- # require("gsl")
343
- # include Odeiv
344
- #
345
- # dim = 2 # dimension of the system
346
- #
347
- # # Proc object to calculate the derivatives
348
- # func = Proc.new { |t, y, dydt, mu|
349
- # dydt[0] = y[1]
350
- # dydt[1] = -y[0] - mu*y[1]*(y[0]*y[0] - 1.0)
351
- # }
352
- #
353
- # # Create the solver
354
- # solver = Solver.alloc(Step::RKF45, [1e-6, 0.0], func, dim)
355
- # mu = 10.0
356
- # solver.set_params(mu)
357
- #
358
- # t = 0.0 # initial time
359
- # t1 = 100.0 # end time
360
- # h = 1e-6 # initial step
361
- # y = Vector.alloc([1.0, 0.0]) # initial value
362
- #
363
- # while t < t1
364
- # t, h, status = solver.apply(t, t1, h, y)
365
- #
366
- # break if status != GSL::SUCCESS
367
- #
368
- # printf("%.5e %.5e %.5e %.5e\n", t, y[0], y[1], h)
369
- # end
370
- #
371
- #
372
- # {prev}[link:rdoc/siman_rdoc.html]
373
- # {next}[link:rdoc/interp_rdoc.html]
374
- #
375
- # {Reference index}[link:rdoc/ref_rdoc.html]
376
- # {top}[link:index.html]
377
- #
378
- #