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.
- checksums.yaml +4 -4
- data/rb-gsl.gemspec +5 -10
- metadata +10 -713
- data/.gitignore +0 -12
- data/.travis.yml +0 -24
- data/AUTHORS +0 -12
- data/COPYING +0 -341
- data/ChangeLog +0 -621
- data/Gemfile +0 -4
- data/README.md +0 -77
- data/Rakefile +0 -20
- data/THANKS +0 -17
- data/examples/alf/alf.gp +0 -15
- data/examples/alf/alf.rb +0 -32
- data/examples/blas/blas.rb +0 -13
- data/examples/blas/dnrm2.rb +0 -16
- data/examples/blas/level1.rb +0 -81
- data/examples/blas/level2.rb +0 -11
- data/examples/blas/level3.rb +0 -12
- data/examples/bspline.rb +0 -57
- data/examples/cdf.rb +0 -16
- data/examples/cheb.rb +0 -21
- data/examples/combination.rb +0 -23
- data/examples/complex/RC-lpf.rb +0 -47
- data/examples/complex/add.rb +0 -36
- data/examples/complex/coerce.rb +0 -14
- data/examples/complex/complex.rb +0 -25
- data/examples/complex/fpmi.rb +0 -70
- data/examples/complex/functions.rb +0 -77
- data/examples/complex/michelson.rb +0 -36
- data/examples/complex/mul.rb +0 -28
- data/examples/complex/oscillator.rb +0 -17
- data/examples/complex/set.rb +0 -37
- data/examples/const/physconst.rb +0 -151
- data/examples/const/travel.rb +0 -45
- data/examples/deriv/demo.rb +0 -13
- data/examples/deriv/deriv.rb +0 -36
- data/examples/deriv/diff.rb +0 -35
- data/examples/dht.rb +0 -42
- data/examples/dirac.rb +0 -56
- data/examples/eigen/eigen.rb +0 -34
- data/examples/eigen/herm.rb +0 -22
- data/examples/eigen/narray.rb +0 -9
- data/examples/eigen/nonsymm.rb +0 -37
- data/examples/eigen/nonsymmv.rb +0 -43
- data/examples/eigen/qhoscillator.gp +0 -35
- data/examples/eigen/qhoscillator.rb +0 -90
- data/examples/eigen/vander.rb +0 -41
- data/examples/fft/fft.rb +0 -17
- data/examples/fft/fft2.rb +0 -17
- data/examples/fft/forward.rb +0 -25
- data/examples/fft/forward2.rb +0 -26
- data/examples/fft/radix2.rb +0 -18
- data/examples/fft/real-halfcomplex.rb +0 -33
- data/examples/fft/real-halfcomplex2.rb +0 -30
- data/examples/fft/realradix2.rb +0 -19
- data/examples/fft/sunspot.dat +0 -256
- data/examples/fft/sunspot.rb +0 -16
- data/examples/fit/expdata.dat +0 -20
- data/examples/fit/expfit.rb +0 -31
- data/examples/fit/gaussfit.rb +0 -29
- data/examples/fit/gaussian_2peaks.rb +0 -34
- data/examples/fit/hillfit.rb +0 -40
- data/examples/fit/lognormal.rb +0 -26
- data/examples/fit/lorentzfit.rb +0 -22
- data/examples/fit/multifit.rb +0 -72
- data/examples/fit/ndlinear.rb +0 -133
- data/examples/fit/nonlinearfit.rb +0 -89
- data/examples/fit/plot.gp +0 -36
- data/examples/fit/polyfit.rb +0 -9
- data/examples/fit/powerfit.rb +0 -21
- data/examples/fit/sigmoidfit.rb +0 -40
- data/examples/fit/sinfit.rb +0 -22
- data/examples/fit/wlinear.rb +0 -46
- data/examples/fresnel.rb +0 -11
- data/examples/function/function.rb +0 -36
- data/examples/function/log.rb +0 -7
- data/examples/function/min.rb +0 -33
- data/examples/function/sin.rb +0 -10
- data/examples/function/synchrotron.rb +0 -18
- data/examples/gallery/butterfly.rb +0 -7
- data/examples/gallery/cayley.rb +0 -12
- data/examples/gallery/cornu.rb +0 -23
- data/examples/gallery/eight.rb +0 -11
- data/examples/gallery/koch.rb +0 -40
- data/examples/gallery/lemniscate.rb +0 -11
- data/examples/gallery/polar.rb +0 -11
- data/examples/gallery/rgplot/cossin.rb +0 -35
- data/examples/gallery/rgplot/rgplot.replaced +0 -0
- data/examples/gallery/rgplot/roesller.rb +0 -55
- data/examples/gallery/roesller.rb +0 -39
- data/examples/gallery/scarabaeus.rb +0 -14
- data/examples/histogram/cauchy.rb +0 -27
- data/examples/histogram/cauchy.sh +0 -2
- data/examples/histogram/exponential.rb +0 -19
- data/examples/histogram/gauss.rb +0 -16
- data/examples/histogram/gsl-histogram.rb +0 -40
- data/examples/histogram/histo2d.rb +0 -31
- data/examples/histogram/histo3d.rb +0 -34
- data/examples/histogram/histogram-pdf.rb +0 -27
- data/examples/histogram/histogram.rb +0 -26
- data/examples/histogram/integral.rb +0 -28
- data/examples/histogram/poisson.rb +0 -27
- data/examples/histogram/power.rb +0 -25
- data/examples/histogram/rebin.rb +0 -17
- data/examples/histogram/smp.dat +0 -5
- data/examples/histogram/xexp.rb +0 -21
- data/examples/integration/ahmed.rb +0 -21
- data/examples/integration/cosmology.rb +0 -75
- data/examples/integration/friedmann.gp +0 -16
- data/examples/integration/friedmann.rb +0 -35
- data/examples/integration/gamma-zeta.rb +0 -35
- data/examples/integration/integration.rb +0 -22
- data/examples/integration/qag.rb +0 -8
- data/examples/integration/qag2.rb +0 -14
- data/examples/integration/qag3.rb +0 -8
- data/examples/integration/qagi.rb +0 -28
- data/examples/integration/qagi2.rb +0 -49
- data/examples/integration/qagiu.rb +0 -29
- data/examples/integration/qagp.rb +0 -20
- data/examples/integration/qags.rb +0 -14
- data/examples/integration/qawc.rb +0 -18
- data/examples/integration/qawf.rb +0 -41
- data/examples/integration/qawo.rb +0 -29
- data/examples/integration/qaws.rb +0 -30
- data/examples/integration/qng.rb +0 -17
- data/examples/interp/demo.gp +0 -20
- data/examples/interp/demo.rb +0 -45
- data/examples/interp/interp.rb +0 -37
- data/examples/interp/points +0 -10
- data/examples/interp/spline.rb +0 -20
- data/examples/jacobi/deriv.rb +0 -40
- data/examples/jacobi/integrate.rb +0 -34
- data/examples/jacobi/interp.rb +0 -43
- data/examples/jacobi/jacobi.rb +0 -11
- data/examples/linalg/HH.rb +0 -15
- data/examples/linalg/HH_narray.rb +0 -13
- data/examples/linalg/LQ_solve.rb +0 -73
- data/examples/linalg/LU.rb +0 -84
- data/examples/linalg/LU2.rb +0 -31
- data/examples/linalg/LU_narray.rb +0 -24
- data/examples/linalg/PTLQ.rb +0 -47
- data/examples/linalg/QR.rb +0 -18
- data/examples/linalg/QRPT.rb +0 -47
- data/examples/linalg/QR_solve.rb +0 -78
- data/examples/linalg/QR_solve_narray.rb +0 -13
- data/examples/linalg/SV.rb +0 -16
- data/examples/linalg/SV_narray.rb +0 -12
- data/examples/linalg/SV_solve.rb +0 -49
- data/examples/linalg/chol.rb +0 -29
- data/examples/linalg/chol_narray.rb +0 -15
- data/examples/linalg/complex.rb +0 -57
- data/examples/linalg/invert_narray.rb +0 -10
- data/examples/math/const.rb +0 -67
- data/examples/math/elementary.rb +0 -35
- data/examples/math/functions.rb +0 -41
- data/examples/math/inf_nan.rb +0 -34
- data/examples/math/minmax.rb +0 -22
- data/examples/math/power.rb +0 -18
- data/examples/math/test.rb +0 -31
- data/examples/matrix/a.dat +0 -0
- data/examples/matrix/add.rb +0 -45
- data/examples/matrix/b.dat +0 -4
- data/examples/matrix/cat.rb +0 -31
- data/examples/matrix/colvectors.rb +0 -24
- data/examples/matrix/complex.rb +0 -41
- data/examples/matrix/det.rb +0 -29
- data/examples/matrix/diagonal.rb +0 -23
- data/examples/matrix/get_all.rb +0 -159
- data/examples/matrix/hilbert.rb +0 -31
- data/examples/matrix/iterator.rb +0 -19
- data/examples/matrix/matrix.rb +0 -57
- data/examples/matrix/minmax.rb +0 -53
- data/examples/matrix/mul.rb +0 -39
- data/examples/matrix/rand.rb +0 -20
- data/examples/matrix/read.rb +0 -29
- data/examples/matrix/rowcol.rb +0 -47
- data/examples/matrix/set.rb +0 -41
- data/examples/matrix/set_all.rb +0 -100
- data/examples/matrix/view.rb +0 -32
- data/examples/matrix/view_all.rb +0 -148
- data/examples/matrix/write.rb +0 -23
- data/examples/min.rb +0 -29
- data/examples/monte/miser.rb +0 -47
- data/examples/monte/monte.rb +0 -47
- data/examples/monte/plain.rb +0 -47
- data/examples/monte/vegas.rb +0 -46
- data/examples/multimin/bundle.rb +0 -66
- data/examples/multimin/cqp.rb +0 -109
- data/examples/multimin/fdfminimizer.rb +0 -40
- data/examples/multimin/fminimizer.rb +0 -41
- data/examples/multiroot/demo.rb +0 -36
- data/examples/multiroot/fdfsolver.rb +0 -50
- data/examples/multiroot/fsolver.rb +0 -33
- data/examples/multiroot/fsolver2.rb +0 -32
- data/examples/multiroot/fsolver3.rb +0 -26
- data/examples/narray/histogram.rb +0 -14
- data/examples/narray/mandel.rb +0 -27
- data/examples/narray/narray.rb +0 -28
- data/examples/narray/narray2.rb +0 -44
- data/examples/narray/sf.rb +0 -26
- data/examples/ntuple/create.rb +0 -17
- data/examples/ntuple/project.rb +0 -31
- data/examples/odeiv/binarysystem.gp +0 -23
- data/examples/odeiv/binarysystem.rb +0 -104
- data/examples/odeiv/demo.gp +0 -24
- data/examples/odeiv/demo.rb +0 -69
- data/examples/odeiv/demo2.gp +0 -26
- data/examples/odeiv/duffing.rb +0 -45
- data/examples/odeiv/frei1.rb +0 -109
- data/examples/odeiv/frei2.rb +0 -76
- data/examples/odeiv/legendre.rb +0 -52
- data/examples/odeiv/odeiv.rb +0 -32
- data/examples/odeiv/odeiv2.rb +0 -45
- data/examples/odeiv/oscillator.rb +0 -42
- data/examples/odeiv/sedov.rb +0 -97
- data/examples/odeiv/whitedwarf.gp +0 -40
- data/examples/odeiv/whitedwarf.rb +0 -158
- data/examples/ool/conmin.rb +0 -100
- data/examples/ool/gencan.rb +0 -99
- data/examples/ool/pgrad.rb +0 -100
- data/examples/ool/spg.rb +0 -100
- data/examples/pdf/bernoulli.rb +0 -5
- data/examples/pdf/beta.rb +0 -7
- data/examples/pdf/binomiral.rb +0 -10
- data/examples/pdf/cauchy.rb +0 -6
- data/examples/pdf/chisq.rb +0 -8
- data/examples/pdf/exponential.rb +0 -7
- data/examples/pdf/exppow.rb +0 -6
- data/examples/pdf/fdist.rb +0 -7
- data/examples/pdf/flat.rb +0 -7
- data/examples/pdf/gamma.rb +0 -8
- data/examples/pdf/gauss-tail.rb +0 -5
- data/examples/pdf/gauss.rb +0 -6
- data/examples/pdf/geometric.rb +0 -5
- data/examples/pdf/gumbel.rb +0 -6
- data/examples/pdf/hypergeometric.rb +0 -11
- data/examples/pdf/landau.rb +0 -5
- data/examples/pdf/laplace.rb +0 -7
- data/examples/pdf/logarithmic.rb +0 -5
- data/examples/pdf/logistic.rb +0 -6
- data/examples/pdf/lognormal.rb +0 -6
- data/examples/pdf/neg-binomiral.rb +0 -10
- data/examples/pdf/pareto.rb +0 -7
- data/examples/pdf/pascal.rb +0 -10
- data/examples/pdf/poisson.rb +0 -5
- data/examples/pdf/rayleigh-tail.rb +0 -6
- data/examples/pdf/rayleigh.rb +0 -6
- data/examples/pdf/tdist.rb +0 -6
- data/examples/pdf/weibull.rb +0 -8
- data/examples/permutation/ex1.rb +0 -22
- data/examples/permutation/permutation.rb +0 -16
- data/examples/poly/bell.rb +0 -6
- data/examples/poly/bessel.rb +0 -6
- data/examples/poly/cheb.rb +0 -6
- data/examples/poly/cheb_II.rb +0 -6
- data/examples/poly/cubic.rb +0 -9
- data/examples/poly/demo.rb +0 -20
- data/examples/poly/eval.rb +0 -28
- data/examples/poly/eval_derivs.rb +0 -14
- data/examples/poly/fit.rb +0 -21
- data/examples/poly/hermite.rb +0 -6
- data/examples/poly/poly.rb +0 -13
- data/examples/poly/quadratic.rb +0 -25
- data/examples/random/diffusion.rb +0 -34
- data/examples/random/gaussian.rb +0 -9
- data/examples/random/generator.rb +0 -27
- data/examples/random/hdsobol.rb +0 -21
- data/examples/random/poisson.rb +0 -9
- data/examples/random/qrng.rb +0 -19
- data/examples/random/randomwalk.rb +0 -37
- data/examples/random/randomwalk2d.rb +0 -19
- data/examples/random/rayleigh.rb +0 -36
- data/examples/random/rng.rb +0 -33
- data/examples/random/rngextra.rb +0 -14
- data/examples/roots/bisection.rb +0 -25
- data/examples/roots/brent.rb +0 -43
- data/examples/roots/demo.rb +0 -30
- data/examples/roots/newton.rb +0 -46
- data/examples/roots/recombination.gp +0 -11
- data/examples/roots/recombination.rb +0 -61
- data/examples/roots/steffenson.rb +0 -48
- data/examples/sf/ShiChi.rb +0 -6
- data/examples/sf/SiCi.rb +0 -6
- data/examples/sf/airy_Ai.rb +0 -8
- data/examples/sf/airy_Bi.rb +0 -8
- data/examples/sf/bessel_IK.rb +0 -12
- data/examples/sf/bessel_JY.rb +0 -13
- data/examples/sf/beta_inc.rb +0 -9
- data/examples/sf/clausen.rb +0 -6
- data/examples/sf/dawson.rb +0 -5
- data/examples/sf/debye.rb +0 -9
- data/examples/sf/dilog.rb +0 -6
- data/examples/sf/ellint.rb +0 -6
- data/examples/sf/expint.rb +0 -8
- data/examples/sf/fermi.rb +0 -10
- data/examples/sf/gamma_inc_P.rb +0 -9
- data/examples/sf/gegenbauer.rb +0 -8
- data/examples/sf/hyperg.rb +0 -7
- data/examples/sf/laguerre.rb +0 -19
- data/examples/sf/lambertW.rb +0 -5
- data/examples/sf/legendre_P.rb +0 -10
- data/examples/sf/lngamma.rb +0 -5
- data/examples/sf/psi.rb +0 -54
- data/examples/sf/sphbessel.gp +0 -27
- data/examples/sf/sphbessel.rb +0 -30
- data/examples/sf/synchrotron.rb +0 -5
- data/examples/sf/transport.rb +0 -10
- data/examples/sf/zetam1.rb +0 -5
- data/examples/siman.rb +0 -44
- data/examples/sort/heapsort.rb +0 -23
- data/examples/sort/heapsort_vector_complex.rb +0 -21
- data/examples/sort/sort.rb +0 -23
- data/examples/sort/sort2.rb +0 -16
- data/examples/stats/mean.rb +0 -17
- data/examples/stats/statistics.rb +0 -18
- data/examples/stats/test.rb +0 -9
- data/examples/sum.rb +0 -34
- data/examples/tamu_anova.rb +0 -18
- data/examples/vector/a.dat +0 -0
- data/examples/vector/add.rb +0 -56
- data/examples/vector/b.dat +0 -4
- data/examples/vector/c.dat +0 -3
- data/examples/vector/collect.rb +0 -26
- data/examples/vector/compare.rb +0 -28
- data/examples/vector/complex.rb +0 -51
- data/examples/vector/complex_get_all.rb +0 -85
- data/examples/vector/complex_set_all.rb +0 -131
- data/examples/vector/complex_view_all.rb +0 -77
- data/examples/vector/connect.rb +0 -22
- data/examples/vector/decimate.rb +0 -38
- data/examples/vector/diff.rb +0 -31
- data/examples/vector/filescan.rb +0 -17
- data/examples/vector/floor.rb +0 -23
- data/examples/vector/get_all.rb +0 -82
- data/examples/vector/gnuplot.rb +0 -38
- data/examples/vector/graph.rb +0 -28
- data/examples/vector/histogram.rb +0 -22
- data/examples/vector/linspace.rb +0 -24
- data/examples/vector/log.rb +0 -17
- data/examples/vector/logic.rb +0 -33
- data/examples/vector/logspace.rb +0 -25
- data/examples/vector/minmax.rb +0 -47
- data/examples/vector/mul.rb +0 -49
- data/examples/vector/narray.rb +0 -46
- data/examples/vector/read.rb +0 -29
- data/examples/vector/set.rb +0 -35
- data/examples/vector/set_all.rb +0 -121
- data/examples/vector/smpv.dat +0 -15
- data/examples/vector/test.rb +0 -43
- data/examples/vector/test_gslblock.rb +0 -58
- data/examples/vector/vector.rb +0 -110
- data/examples/vector/view.rb +0 -35
- data/examples/vector/view_all.rb +0 -73
- data/examples/vector/where.rb +0 -29
- data/examples/vector/write.rb +0 -24
- data/examples/vector/zip.rb +0 -34
- data/examples/wavelet/ecg.dat +0 -256
- data/examples/wavelet/wavelet1.rb +0 -50
- data/ext/gsl_native/alf.c +0 -206
- data/ext/gsl_native/array.c +0 -553
- data/ext/gsl_native/array_complex.c +0 -245
- data/ext/gsl_native/blas.c +0 -28
- data/ext/gsl_native/blas1.c +0 -733
- data/ext/gsl_native/blas2.c +0 -1088
- data/ext/gsl_native/blas3.c +0 -880
- data/ext/gsl_native/block.c +0 -40
- data/ext/gsl_native/block_source.h +0 -885
- data/ext/gsl_native/bspline.c +0 -122
- data/ext/gsl_native/bundle.c +0 -3
- data/ext/gsl_native/cdf.c +0 -740
- data/ext/gsl_native/cheb.c +0 -531
- data/ext/gsl_native/combination.c +0 -275
- data/ext/gsl_native/common.c +0 -293
- data/ext/gsl_native/complex.c +0 -1002
- data/ext/gsl_native/const.c +0 -331
- data/ext/gsl_native/const_additional.c +0 -99
- data/ext/gsl_native/cqp.c +0 -283
- data/ext/gsl_native/deriv.c +0 -187
- data/ext/gsl_native/dht.c +0 -353
- data/ext/gsl_native/diff.c +0 -164
- data/ext/gsl_native/dirac.c +0 -388
- data/ext/gsl_native/eigen.c +0 -2322
- data/ext/gsl_native/error.c +0 -193
- data/ext/gsl_native/extconf.rb +0 -118
- data/ext/gsl_native/fft.c +0 -1095
- data/ext/gsl_native/fit.c +0 -204
- data/ext/gsl_native/fresnel.c +0 -312
- data/ext/gsl_native/function.c +0 -518
- data/ext/gsl_native/geometry.c +0 -139
- data/ext/gsl_native/graph.c +0 -1590
- data/ext/gsl_native/gsl.c +0 -259
- data/ext/gsl_native/gsl_narray.c +0 -794
- data/ext/gsl_native/histogram.c +0 -1964
- data/ext/gsl_native/histogram2d.c +0 -1042
- data/ext/gsl_native/histogram3d.c +0 -884
- data/ext/gsl_native/histogram3d_source.c +0 -749
- data/ext/gsl_native/histogram_find.c +0 -99
- data/ext/gsl_native/histogram_oper.c +0 -150
- data/ext/gsl_native/ieee.c +0 -88
- data/ext/gsl_native/include/rb_gsl.h +0 -136
- data/ext/gsl_native/include/rb_gsl_array.h +0 -214
- data/ext/gsl_native/include/rb_gsl_cheb.h +0 -19
- data/ext/gsl_native/include/rb_gsl_common.h +0 -348
- data/ext/gsl_native/include/rb_gsl_complex.h +0 -25
- data/ext/gsl_native/include/rb_gsl_const.h +0 -23
- data/ext/gsl_native/include/rb_gsl_dirac.h +0 -6
- data/ext/gsl_native/include/rb_gsl_eigen.h +0 -17
- data/ext/gsl_native/include/rb_gsl_fft.h +0 -49
- data/ext/gsl_native/include/rb_gsl_fit.h +0 -23
- data/ext/gsl_native/include/rb_gsl_function.h +0 -23
- data/ext/gsl_native/include/rb_gsl_graph.h +0 -68
- data/ext/gsl_native/include/rb_gsl_histogram.h +0 -63
- data/ext/gsl_native/include/rb_gsl_histogram3d.h +0 -97
- data/ext/gsl_native/include/rb_gsl_integration.h +0 -17
- data/ext/gsl_native/include/rb_gsl_interp.h +0 -41
- data/ext/gsl_native/include/rb_gsl_linalg.h +0 -21
- data/ext/gsl_native/include/rb_gsl_math.h +0 -20
- data/ext/gsl_native/include/rb_gsl_odeiv.h +0 -18
- data/ext/gsl_native/include/rb_gsl_poly.h +0 -67
- data/ext/gsl_native/include/rb_gsl_rational.h +0 -30
- data/ext/gsl_native/include/rb_gsl_rng.h +0 -20
- data/ext/gsl_native/include/rb_gsl_root.h +0 -22
- data/ext/gsl_native/include/rb_gsl_sf.h +0 -110
- data/ext/gsl_native/include/rb_gsl_statistics.h +0 -17
- data/ext/gsl_native/include/rb_gsl_tensor.h +0 -43
- data/ext/gsl_native/include/rb_gsl_with_narray.h +0 -31
- data/ext/gsl_native/include/templates_off.h +0 -87
- data/ext/gsl_native/include/templates_on.h +0 -241
- data/ext/gsl_native/integration.c +0 -1154
- data/ext/gsl_native/interp.c +0 -499
- data/ext/gsl_native/jacobi.c +0 -733
- data/ext/gsl_native/linalg.c +0 -3915
- data/ext/gsl_native/linalg_complex.c +0 -726
- data/ext/gsl_native/math.c +0 -706
- data/ext/gsl_native/matrix.c +0 -36
- data/ext/gsl_native/matrix_complex.c +0 -1733
- data/ext/gsl_native/matrix_double.c +0 -557
- data/ext/gsl_native/matrix_int.c +0 -255
- data/ext/gsl_native/matrix_source.h +0 -2708
- data/ext/gsl_native/min.c +0 -219
- data/ext/gsl_native/monte.c +0 -978
- data/ext/gsl_native/multifit.c +0 -1862
- data/ext/gsl_native/multimin.c +0 -778
- data/ext/gsl_native/multimin_fsdf.c +0 -156
- data/ext/gsl_native/multiroots.c +0 -952
- data/ext/gsl_native/multiset.c +0 -210
- data/ext/gsl_native/ndlinear.c +0 -320
- data/ext/gsl_native/nmf.c +0 -171
- data/ext/gsl_native/nmf_wrap.c +0 -75
- data/ext/gsl_native/ntuple.c +0 -469
- data/ext/gsl_native/odeiv.c +0 -947
- data/ext/gsl_native/ool.c +0 -879
- data/ext/gsl_native/permutation.c +0 -598
- data/ext/gsl_native/poly.c +0 -39
- data/ext/gsl_native/poly2.c +0 -265
- data/ext/gsl_native/poly_source.h +0 -1871
- data/ext/gsl_native/qrng.c +0 -160
- data/ext/gsl_native/randist.c +0 -1848
- data/ext/gsl_native/rational.c +0 -480
- data/ext/gsl_native/rng.c +0 -595
- data/ext/gsl_native/root.c +0 -407
- data/ext/gsl_native/sf.c +0 -1446
- data/ext/gsl_native/sf_airy.c +0 -200
- data/ext/gsl_native/sf_bessel.c +0 -871
- data/ext/gsl_native/sf_clausen.c +0 -28
- data/ext/gsl_native/sf_coulomb.c +0 -206
- data/ext/gsl_native/sf_coupling.c +0 -121
- data/ext/gsl_native/sf_dawson.c +0 -29
- data/ext/gsl_native/sf_debye.c +0 -148
- data/ext/gsl_native/sf_dilog.c +0 -43
- data/ext/gsl_native/sf_elementary.c +0 -46
- data/ext/gsl_native/sf_ellint.c +0 -206
- data/ext/gsl_native/sf_elljac.c +0 -30
- data/ext/gsl_native/sf_erfc.c +0 -89
- data/ext/gsl_native/sf_exp.c +0 -169
- data/ext/gsl_native/sf_expint.c +0 -201
- data/ext/gsl_native/sf_fermi_dirac.c +0 -148
- data/ext/gsl_native/sf_gamma.c +0 -343
- data/ext/gsl_native/sf_gegenbauer.c +0 -97
- data/ext/gsl_native/sf_hyperg.c +0 -203
- data/ext/gsl_native/sf_laguerre.c +0 -113
- data/ext/gsl_native/sf_lambert.c +0 -47
- data/ext/gsl_native/sf_legendre.c +0 -368
- data/ext/gsl_native/sf_log.c +0 -105
- data/ext/gsl_native/sf_mathieu.c +0 -235
- data/ext/gsl_native/sf_power.c +0 -47
- data/ext/gsl_native/sf_psi.c +0 -89
- data/ext/gsl_native/sf_synchrotron.c +0 -48
- data/ext/gsl_native/sf_transport.c +0 -76
- data/ext/gsl_native/sf_trigonometric.c +0 -210
- data/ext/gsl_native/sf_zeta.c +0 -115
- data/ext/gsl_native/signal.c +0 -303
- data/ext/gsl_native/siman.c +0 -713
- data/ext/gsl_native/sort.c +0 -207
- data/ext/gsl_native/spline.c +0 -377
- data/ext/gsl_native/stats.c +0 -787
- data/ext/gsl_native/sum.c +0 -168
- data/ext/gsl_native/tamu_anova.c +0 -56
- data/ext/gsl_native/tensor.c +0 -35
- data/ext/gsl_native/tensor_source.h +0 -1122
- data/ext/gsl_native/vector.c +0 -35
- data/ext/gsl_native/vector_complex.c +0 -2241
- data/ext/gsl_native/vector_double.c +0 -1433
- data/ext/gsl_native/vector_int.c +0 -202
- data/ext/gsl_native/vector_source.h +0 -3321
- data/ext/gsl_native/wavelet.c +0 -923
- data/lib/gsl.rb +0 -8
- data/lib/gsl/gnuplot.rb +0 -41
- data/lib/gsl/oper.rb +0 -43
- data/lib/gsl/version.rb +0 -3
- data/lib/ool.rb +0 -22
- data/lib/ool/conmin.rb +0 -30
- data/lib/rbgsl.rb +0 -1
- data/rdoc/alf.rdoc +0 -77
- data/rdoc/blas.rdoc +0 -269
- data/rdoc/bspline.rdoc +0 -42
- data/rdoc/changes.rdoc +0 -159
- data/rdoc/cheb.rdoc +0 -99
- data/rdoc/cholesky_complex.rdoc +0 -46
- data/rdoc/combi.rdoc +0 -125
- data/rdoc/complex.rdoc +0 -210
- data/rdoc/const.rdoc +0 -546
- data/rdoc/dht.rdoc +0 -122
- data/rdoc/diff.rdoc +0 -133
- data/rdoc/ehandling.rdoc +0 -50
- data/rdoc/eigen.rdoc +0 -401
- data/rdoc/fft.rdoc +0 -535
- data/rdoc/fit.rdoc +0 -284
- data/rdoc/function.rdoc +0 -94
- data/rdoc/graph.rdoc +0 -137
- data/rdoc/hist.rdoc +0 -409
- data/rdoc/hist2d.rdoc +0 -279
- data/rdoc/hist3d.rdoc +0 -112
- data/rdoc/integration.rdoc +0 -398
- data/rdoc/interp.rdoc +0 -231
- data/rdoc/intro.rdoc +0 -27
- data/rdoc/linalg.rdoc +0 -681
- data/rdoc/linalg_complex.rdoc +0 -88
- data/rdoc/math.rdoc +0 -276
- data/rdoc/matrix.rdoc +0 -1093
- data/rdoc/min.rdoc +0 -189
- data/rdoc/monte.rdoc +0 -234
- data/rdoc/multimin.rdoc +0 -312
- data/rdoc/multiroot.rdoc +0 -293
- data/rdoc/narray.rdoc +0 -177
- data/rdoc/ndlinear.rdoc +0 -250
- data/rdoc/nonlinearfit.rdoc +0 -348
- data/rdoc/ntuple.rdoc +0 -88
- data/rdoc/odeiv.rdoc +0 -378
- data/rdoc/perm.rdoc +0 -221
- data/rdoc/poly.rdoc +0 -335
- data/rdoc/qrng.rdoc +0 -90
- data/rdoc/randist.rdoc +0 -233
- data/rdoc/ref.rdoc +0 -93
- data/rdoc/rng.rdoc +0 -203
- data/rdoc/roots.rdoc +0 -305
- data/rdoc/sf.rdoc +0 -1622
- data/rdoc/siman.rdoc +0 -89
- data/rdoc/sort.rdoc +0 -94
- data/rdoc/start.rdoc +0 -16
- data/rdoc/stats.rdoc +0 -219
- data/rdoc/sum.rdoc +0 -65
- data/rdoc/tensor.rdoc +0 -251
- data/rdoc/tut.rdoc +0 -5
- data/rdoc/use.rdoc +0 -177
- data/rdoc/vector.rdoc +0 -1243
- data/rdoc/vector_complex.rdoc +0 -347
- data/rdoc/wavelet.rdoc +0 -218
- data/test/gsl/blas_test.rb +0 -79
- data/test/gsl/bspline_test.rb +0 -63
- data/test/gsl/cdf_test.rb +0 -1512
- data/test/gsl/cheb_test.rb +0 -80
- data/test/gsl/combination_test.rb +0 -100
- data/test/gsl/complex_test.rb +0 -20
- data/test/gsl/const_test.rb +0 -29
- data/test/gsl/deriv_test.rb +0 -62
- data/test/gsl/dht_test.rb +0 -79
- data/test/gsl/diff_test.rb +0 -53
- data/test/gsl/eigen_test.rb +0 -563
- data/test/gsl/err_test.rb +0 -23
- data/test/gsl/fit_test.rb +0 -101
- data/test/gsl/histo_test.rb +0 -14
- data/test/gsl/index_test.rb +0 -61
- data/test/gsl/integration_test.rb +0 -274
- data/test/gsl/interp_test.rb +0 -27
- data/test/gsl/linalg_test.rb +0 -463
- data/test/gsl/matrix_nmf_test.rb +0 -37
- data/test/gsl/matrix_test.rb +0 -98
- data/test/gsl/min_test.rb +0 -89
- data/test/gsl/monte_test.rb +0 -77
- data/test/gsl/multifit_test.rb +0 -753
- data/test/gsl/multimin_test.rb +0 -157
- data/test/gsl/multiroot_test.rb +0 -135
- data/test/gsl/multiset_test.rb +0 -52
- data/test/gsl/odeiv_test.rb +0 -275
- data/test/gsl/oper_test.rb +0 -98
- data/test/gsl/poly_test.rb +0 -338
- data/test/gsl/qrng_test.rb +0 -94
- data/test/gsl/quartic_test.rb +0 -28
- data/test/gsl/randist_test.rb +0 -122
- data/test/gsl/rng_test.rb +0 -303
- data/test/gsl/roots_test.rb +0 -78
- data/test/gsl/sf_test.rb +0 -2079
- data/test/gsl/stats_test.rb +0 -122
- data/test/gsl/sum_test.rb +0 -69
- data/test/gsl/tensor_test.rb +0 -396
- data/test/gsl/vector_test.rb +0 -223
- data/test/gsl/wavelet_test.rb +0 -130
- data/test/gsl_test.rb +0 -321
- data/test/test_helper.rb +0 -42
- data/uncrustify.cfg +0 -1693
data/rdoc/ntuple.rdoc
DELETED
@@ -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
|
-
#
|
data/rdoc/odeiv.rdoc
DELETED
@@ -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
|
-
#
|