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/ext/gsl_native/sum.c
DELETED
@@ -1,168 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
sum.c
|
3
|
-
Ruby/GSL: Ruby extension library for GSL (GNU Scientific Library)
|
4
|
-
(C) Copyright 2001-2006 by Yoshiki Tsunesada
|
5
|
-
|
6
|
-
Ruby/GSL is free software: you can redistribute it and/or modify it
|
7
|
-
under the terms of the GNU General Public License.
|
8
|
-
This library is distributed in the hope that it will be useful, but
|
9
|
-
WITHOUT ANY WARRANTY.
|
10
|
-
*/
|
11
|
-
|
12
|
-
#include "include/rb_gsl_array.h"
|
13
|
-
#include <gsl/gsl_sum.h>
|
14
|
-
|
15
|
-
static VALUE rb_gsl_sum_accel(VALUE obj)
|
16
|
-
{
|
17
|
-
gsl_sum_levin_u_workspace *w = NULL;
|
18
|
-
double sum, err, sum_plain, *ptr;
|
19
|
-
size_t terms_used, n, stride;
|
20
|
-
ptr = get_vector_ptr(obj, &stride, &n);
|
21
|
-
w = gsl_sum_levin_u_alloc(n);
|
22
|
-
gsl_sum_levin_u_accel(ptr, n, w, &sum, &err);
|
23
|
-
sum_plain = w->sum_plain;
|
24
|
-
terms_used = w->terms_used;
|
25
|
-
gsl_sum_levin_u_free(w);
|
26
|
-
return rb_ary_new3(4, rb_float_new(sum), rb_float_new(err),
|
27
|
-
rb_float_new(sum_plain), INT2FIX(terms_used));
|
28
|
-
}
|
29
|
-
|
30
|
-
static VALUE rb_gsl_utrunc_accel(VALUE obj)
|
31
|
-
{
|
32
|
-
gsl_sum_levin_utrunc_workspace *w = NULL;
|
33
|
-
double sum, err, sum_plain, *ptr;
|
34
|
-
size_t terms_used, n, stride;
|
35
|
-
ptr = get_vector_ptr(obj, &stride, &n);
|
36
|
-
w = gsl_sum_levin_utrunc_alloc(n);
|
37
|
-
gsl_sum_levin_utrunc_accel(ptr, n, w, &sum, &err);
|
38
|
-
sum_plain = w->sum_plain;
|
39
|
-
terms_used = w->terms_used;
|
40
|
-
gsl_sum_levin_utrunc_free(w);
|
41
|
-
return rb_ary_new3(4, rb_float_new(sum), rb_float_new(err),
|
42
|
-
rb_float_new(sum_plain), INT2FIX(terms_used));
|
43
|
-
}
|
44
|
-
|
45
|
-
static VALUE rb_gsl_sum_levin_u_new(VALUE klass, VALUE nn)
|
46
|
-
{
|
47
|
-
gsl_sum_levin_u_workspace *w = NULL;
|
48
|
-
CHECK_FIXNUM(nn);
|
49
|
-
w = gsl_sum_levin_u_alloc(FIX2INT(nn));
|
50
|
-
return Data_Wrap_Struct(klass, 0, gsl_sum_levin_u_free, w);
|
51
|
-
}
|
52
|
-
|
53
|
-
static VALUE rb_gsl_sum_levin_utrunc_new(VALUE klass, VALUE nn)
|
54
|
-
{
|
55
|
-
gsl_sum_levin_utrunc_workspace *w = NULL;
|
56
|
-
CHECK_FIXNUM(nn);
|
57
|
-
w = gsl_sum_levin_utrunc_alloc(FIX2INT(nn));
|
58
|
-
return Data_Wrap_Struct(klass, 0, gsl_sum_levin_utrunc_free, w);
|
59
|
-
}
|
60
|
-
|
61
|
-
/* singleton */
|
62
|
-
static VALUE rb_gsl_sum_levin_u_accel2(VALUE obj, VALUE vv)
|
63
|
-
{
|
64
|
-
gsl_sum_levin_u_workspace *w = NULL;
|
65
|
-
double sum, err, sum_plain;
|
66
|
-
size_t terms_used, n, stride;
|
67
|
-
double *ptr;
|
68
|
-
ptr = get_vector_ptr(vv, &stride, &n);
|
69
|
-
w = gsl_sum_levin_u_alloc(n);
|
70
|
-
gsl_sum_levin_u_accel(ptr, n, w, &sum, &err);
|
71
|
-
sum_plain = w->sum_plain;
|
72
|
-
terms_used = w->terms_used;
|
73
|
-
gsl_sum_levin_u_free(w);
|
74
|
-
return rb_ary_new3(4, rb_float_new(sum), rb_float_new(err),
|
75
|
-
rb_float_new(sum_plain), INT2FIX(terms_used));
|
76
|
-
}
|
77
|
-
|
78
|
-
static VALUE rb_gsl_sum_levin_utrunc_accel2(VALUE obj, VALUE vv)
|
79
|
-
{
|
80
|
-
gsl_sum_levin_utrunc_workspace *w = NULL;
|
81
|
-
double sum, err, sum_plain;
|
82
|
-
size_t terms_used, n, stride;
|
83
|
-
double *ptr;
|
84
|
-
ptr = get_vector_ptr(vv, &stride, &n);
|
85
|
-
w = gsl_sum_levin_utrunc_alloc(n);
|
86
|
-
gsl_sum_levin_utrunc_accel(ptr, n, w, &sum, &err);
|
87
|
-
sum_plain = w->sum_plain;
|
88
|
-
terms_used = w->terms_used;
|
89
|
-
gsl_sum_levin_utrunc_free(w);
|
90
|
-
return rb_ary_new3(4, rb_float_new(sum), rb_float_new(err),
|
91
|
-
rb_float_new(sum_plain), INT2FIX(terms_used));
|
92
|
-
}
|
93
|
-
|
94
|
-
static VALUE rb_gsl_sum_levin_u_sum_plain(VALUE obj)
|
95
|
-
{
|
96
|
-
gsl_sum_levin_u_workspace *w = NULL;
|
97
|
-
Data_Get_Struct(obj, gsl_sum_levin_u_workspace, w);
|
98
|
-
return rb_float_new(w->sum_plain);
|
99
|
-
}
|
100
|
-
|
101
|
-
static VALUE rb_gsl_sum_levin_u_terms_used(VALUE obj)
|
102
|
-
{
|
103
|
-
gsl_sum_levin_u_workspace *w = NULL;
|
104
|
-
Data_Get_Struct(obj, gsl_sum_levin_u_workspace, w);
|
105
|
-
return INT2FIX(w->terms_used);
|
106
|
-
}
|
107
|
-
|
108
|
-
static VALUE rb_gsl_sum_levin_utrunc_sum_plain(VALUE obj)
|
109
|
-
{
|
110
|
-
gsl_sum_levin_utrunc_workspace *w = NULL;
|
111
|
-
Data_Get_Struct(obj, gsl_sum_levin_utrunc_workspace, w);
|
112
|
-
return rb_float_new(w->sum_plain);
|
113
|
-
}
|
114
|
-
|
115
|
-
static VALUE rb_gsl_sum_levin_utrunc_terms_used(VALUE obj)
|
116
|
-
{
|
117
|
-
gsl_sum_levin_utrunc_workspace *w = NULL;
|
118
|
-
Data_Get_Struct(obj, gsl_sum_levin_utrunc_workspace, w);
|
119
|
-
return INT2FIX(w->terms_used);
|
120
|
-
}
|
121
|
-
|
122
|
-
void Init_gsl_sum(VALUE module)
|
123
|
-
{
|
124
|
-
VALUE mgsl_sum;
|
125
|
-
VALUE cgsl_sum_levin_u, cgsl_sum_levin_utrunc;
|
126
|
-
|
127
|
-
mgsl_sum = rb_define_module_under(module, "Sum");
|
128
|
-
cgsl_sum_levin_u = rb_define_class_under(mgsl_sum,
|
129
|
-
"Levin_u", cGSL_Object);
|
130
|
-
cgsl_sum_levin_utrunc = rb_define_class_under(mgsl_sum,
|
131
|
-
"Levin_utrunc", cGSL_Object);
|
132
|
-
|
133
|
-
rb_define_singleton_method(cgsl_sum_levin_u, "new", rb_gsl_sum_levin_u_new, 1);
|
134
|
-
rb_define_singleton_method(cgsl_sum_levin_u, "alloc", rb_gsl_sum_levin_u_new, 1);
|
135
|
-
rb_define_singleton_method(cgsl_sum_levin_utrunc, "new",
|
136
|
-
rb_gsl_sum_levin_utrunc_new, 1);
|
137
|
-
rb_define_singleton_method(cgsl_sum_levin_utrunc, "alloc",
|
138
|
-
rb_gsl_sum_levin_utrunc_new, 1);
|
139
|
-
rb_define_singleton_method(cgsl_sum_levin_u, "accel",
|
140
|
-
rb_gsl_sum_levin_u_accel2, 1);
|
141
|
-
|
142
|
-
rb_define_singleton_method(cgsl_sum_levin_utrunc, "accel",
|
143
|
-
rb_gsl_sum_levin_utrunc_accel2, 1);
|
144
|
-
rb_define_method(cgsl_sum_levin_u, "accel", rb_gsl_sum_levin_u_accel2, 1);
|
145
|
-
rb_define_method(cgsl_sum_levin_utrunc, "accel",
|
146
|
-
rb_gsl_sum_levin_utrunc_accel2, 1);
|
147
|
-
|
148
|
-
rb_define_method(cgsl_sum_levin_u, "sum_plain", rb_gsl_sum_levin_u_sum_plain, 0);
|
149
|
-
rb_define_method(cgsl_sum_levin_u, "terms_used",
|
150
|
-
rb_gsl_sum_levin_u_terms_used, 0);
|
151
|
-
rb_define_method(cgsl_sum_levin_utrunc, "sum_plain",
|
152
|
-
rb_gsl_sum_levin_utrunc_sum_plain, 0);
|
153
|
-
rb_define_method(cgsl_sum_levin_utrunc, "terms_used",
|
154
|
-
rb_gsl_sum_levin_utrunc_terms_used, 0);
|
155
|
-
/***/
|
156
|
-
|
157
|
-
rb_define_method(cgsl_vector, "accel_sum", rb_gsl_sum_accel, 0);
|
158
|
-
rb_define_alias(cgsl_vector, "accel", "accel_sum");
|
159
|
-
rb_define_alias(cgsl_vector, "sum_accel", "accel_sum");
|
160
|
-
rb_define_method(cgsl_vector, "utrunc_accel", rb_gsl_utrunc_accel, 0);
|
161
|
-
|
162
|
-
#ifdef HAVE_NARRAY_H
|
163
|
-
rb_define_method(cNArray, "accel_sum", rb_gsl_sum_accel, 0);
|
164
|
-
rb_define_alias(cNArray, "accel", "accel_sum");
|
165
|
-
rb_define_alias(cNArray, "sum_accel", "accel_sum");
|
166
|
-
rb_define_method(cNArray, "utrunc_accel", rb_gsl_utrunc_accel, 0);
|
167
|
-
#endif
|
168
|
-
}
|
data/ext/gsl_native/tamu_anova.c
DELETED
@@ -1,56 +0,0 @@
|
|
1
|
-
#include "include/rb_gsl.h"
|
2
|
-
|
3
|
-
#ifdef HAVE_TAMU_ANOVA_TAMU_ANOVA_H
|
4
|
-
VALUE rb_tamu_anova_alloc(int argc, VALUE *argv, VALUE klass)
|
5
|
-
{
|
6
|
-
gsl_vector *data;
|
7
|
-
gsl_vector_long *factor;
|
8
|
-
long I, J;
|
9
|
-
struct tamu_anova_table *table;
|
10
|
-
switch (argc) {
|
11
|
-
case 3:
|
12
|
-
case 4:
|
13
|
-
Data_Get_Struct(argv[0], gsl_vector, data);
|
14
|
-
Data_Get_Struct(argv[1], gsl_vector_long, factor);
|
15
|
-
if (argc == 3) {
|
16
|
-
I = data->size;
|
17
|
-
J = NUM2INT(argv[2]);
|
18
|
-
} else {
|
19
|
-
I = NUM2INT(argv[2]);
|
20
|
-
J = NUM2INT(argv[3]);
|
21
|
-
}
|
22
|
-
table = (struct tamu_anova_table *) malloc(sizeof(struct tamu_anova_table));
|
23
|
-
*table = tamu_anova(data->data, factor->data, I, J);
|
24
|
-
break;
|
25
|
-
default:
|
26
|
-
rb_raise(rb_eArgError, "Wrong number of arguments (%d for 3 or 4)", argc);
|
27
|
-
break;
|
28
|
-
}
|
29
|
-
return Data_Wrap_Struct(klass, 0, free, table);
|
30
|
-
}
|
31
|
-
|
32
|
-
VALUE rb_tamu_anova_printtable(VALUE *vTable)
|
33
|
-
{
|
34
|
-
struct tamu_anova_table *table;
|
35
|
-
Data_Get_Struct(vTable, struct tamu_anova_table, table);
|
36
|
-
tamu_anova_printtable(*table);
|
37
|
-
return Qtrue;
|
38
|
-
}
|
39
|
-
|
40
|
-
#endif
|
41
|
-
|
42
|
-
void Init_tamu_anova(VALUE module)
|
43
|
-
{
|
44
|
-
#ifdef HAVE_TAMU_ANOVA_TAMU_ANOVA_H
|
45
|
-
VALUE mTAMU_ANOVA;
|
46
|
-
VALUE cTable;
|
47
|
-
|
48
|
-
mTAMU_ANOVA = rb_define_module_under(module, "TAMU_ANOVA");
|
49
|
-
cTable = rb_define_class_under(mTAMU_ANOVA, "Table", cGSL_Object);
|
50
|
-
|
51
|
-
rb_define_singleton_method(cTable, "alloc", rb_tamu_anova_alloc, -1);
|
52
|
-
rb_define_singleton_method(cTable, "oneway", rb_tamu_anova_alloc, -1);
|
53
|
-
|
54
|
-
rb_define_method(cTable, "print", rb_tamu_anova_printtable, 0);
|
55
|
-
#endif
|
56
|
-
}
|
data/ext/gsl_native/tensor.c
DELETED
@@ -1,35 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
tensor.c
|
3
|
-
Ruby/GSL: Ruby extension library for GSL (GNU Scientific Library)
|
4
|
-
(C) Copyright 2004 by Yoshiki Tsunesada
|
5
|
-
|
6
|
-
Ruby/GSL is free software: you can redistribute it and/or modify it
|
7
|
-
under the terms of the GNU General Public License.
|
8
|
-
This library is distributed in the hope that it will be useful, but
|
9
|
-
WITHOUT ANY WARRANTY.
|
10
|
-
*/
|
11
|
-
|
12
|
-
/*
|
13
|
-
The gsl_tensor package is developed by J.Burguet, and
|
14
|
-
distributed separately as an add-on package.
|
15
|
-
*/
|
16
|
-
|
17
|
-
#ifdef HAVE_TENSOR_TENSOR_H
|
18
|
-
|
19
|
-
#include "include/rb_gsl_tensor.h"
|
20
|
-
|
21
|
-
#include "include/rb_gsl_with_narray.h"
|
22
|
-
|
23
|
-
#define BASE_DOUBLE
|
24
|
-
#include "include/templates_on.h"
|
25
|
-
#include "tensor_source.h"
|
26
|
-
#include "include/templates_off.h"
|
27
|
-
#undef BASE_DOUBLE
|
28
|
-
|
29
|
-
#define BASE_INT
|
30
|
-
#include "include/templates_on.h"
|
31
|
-
#include "tensor_source.h"
|
32
|
-
#include "include/templates_off.h"
|
33
|
-
#undef BASE_INT
|
34
|
-
|
35
|
-
#endif
|
@@ -1,1122 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
tensor_source.c
|
3
|
-
Ruby/GSL: Ruby extension library for GSL (GNU Scientific Library)
|
4
|
-
(C) Copyright 2004 by Yoshiki Tsunesada
|
5
|
-
|
6
|
-
Ruby/GSL is free software: you can redistribute it and/or modify it
|
7
|
-
under the terms of the GNU General Public License.
|
8
|
-
This library is distributed in the hope that it will be useful, but
|
9
|
-
WITHOUT ANY WARRANTY.
|
10
|
-
*/
|
11
|
-
|
12
|
-
/*
|
13
|
-
The tensor package is developed by Jordi Burguet-Caltell, and
|
14
|
-
distributed separately as an add-on package.
|
15
|
-
http://savannah.nongnu.org/projects/tensor/
|
16
|
-
*/
|
17
|
-
|
18
|
-
#ifdef HAVE_TENSOR_TENSOR_H
|
19
|
-
|
20
|
-
#include "include/rb_gsl_tensor.h"
|
21
|
-
#include "include/rb_gsl_common.h"
|
22
|
-
|
23
|
-
#ifdef BASE_DOUBLE
|
24
|
-
VALUE cgsl_tensor, cgsl_tensor_int;
|
25
|
-
VALUE cgsl_tensor_view, cgsl_tensor_int_view;
|
26
|
-
#define NUMCONV(x) NUM2DBL(x)
|
27
|
-
#define C_TO_VALUE(x) rb_float_new(x)
|
28
|
-
#define CHECK_TEN(x) CHECK_TENSOR(x)
|
29
|
-
#define TEN_P(x) TENSOR_P(x)
|
30
|
-
#define VEC_P(x) VECTOR_P(x)
|
31
|
-
#define MAT_P(x) MATRIX_P(x)
|
32
|
-
#else defined(BASE_INT)
|
33
|
-
#define NUMCONV(x) FIX2INT(x)
|
34
|
-
#define C_TO_VALUE(x) INT2FIX(x)
|
35
|
-
#define CHECK_TEN(x) CHECK_TENSOR_INT(x)
|
36
|
-
#define TEN_P(x) TENSOR_INT_P(x)
|
37
|
-
#define VEC_P(x) VECTOR_INT_P(x)
|
38
|
-
#define MAT_P(x) MATRIX_INT_P(x)
|
39
|
-
#endif
|
40
|
-
|
41
|
-
GSL_TYPE(rbgsl_tensor)* FUNCTION(rbgsl_tensor,alloc)(const unsigned int rank,
|
42
|
-
const size_t dimension)
|
43
|
-
{
|
44
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
45
|
-
t = ALLOC(GSL_TYPE(rbgsl_tensor));
|
46
|
-
t->tensor = FUNCTION(tensor,alloc)(rank, dimension);
|
47
|
-
if (rank == 0)
|
48
|
-
t->indices = gsl_permutation_alloc(1);
|
49
|
-
else
|
50
|
-
t->indices = gsl_permutation_alloc(rank);
|
51
|
-
return t;
|
52
|
-
}
|
53
|
-
|
54
|
-
GSL_TYPE(rbgsl_tensor)* FUNCTION(rbgsl_tensor,calloc)(const unsigned int rank,
|
55
|
-
const size_t dimension)
|
56
|
-
{
|
57
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
58
|
-
t = ALLOC(GSL_TYPE(rbgsl_tensor));
|
59
|
-
t->tensor = FUNCTION(tensor,calloc)(rank, dimension);
|
60
|
-
if (rank == 0)
|
61
|
-
t->indices = gsl_permutation_alloc(1);
|
62
|
-
else
|
63
|
-
t->indices = gsl_permutation_alloc(rank);
|
64
|
-
return t;
|
65
|
-
}
|
66
|
-
|
67
|
-
GSL_TYPE(rbgsl_tensor)* FUNCTION(rbgsl_tensor,copy)(const GSL_TYPE(rbgsl_tensor) *t)
|
68
|
-
{
|
69
|
-
GSL_TYPE(rbgsl_tensor) *tnew;
|
70
|
-
tnew = ALLOC(GSL_TYPE(rbgsl_tensor));
|
71
|
-
if (t->tensor->rank == 0)
|
72
|
-
tnew->indices = gsl_permutation_alloc(1);
|
73
|
-
else
|
74
|
-
tnew->indices = gsl_permutation_alloc(t->tensor->rank);
|
75
|
-
tnew->tensor = FUNCTION(tensor,copy)(t->tensor);
|
76
|
-
return tnew;
|
77
|
-
}
|
78
|
-
|
79
|
-
void FUNCTION(rbgsl_tensor,free)(GSL_TYPE(rbgsl_tensor) *t)
|
80
|
-
{
|
81
|
-
gsl_permutation_free(t->indices);
|
82
|
-
FUNCTION(tensor,free)(t->tensor);
|
83
|
-
free((GSL_TYPE(rbgsl_tensor) *)t);
|
84
|
-
}
|
85
|
-
|
86
|
-
void FUNCTION(rbgsl_tensor,free2)(GSL_TYPE(rbgsl_tensor) *t)
|
87
|
-
{
|
88
|
-
gsl_permutation_free(t->indices);
|
89
|
-
free((GSL_TYPE(tensor)*)t->tensor);
|
90
|
-
free((GSL_TYPE(rbgsl_tensor) *)t);
|
91
|
-
}
|
92
|
-
|
93
|
-
/* singleton methods */
|
94
|
-
static VALUE FUNCTION(rb_tensor,new)(int argc, VALUE *argv, VALUE klass)
|
95
|
-
{
|
96
|
-
unsigned int rank;
|
97
|
-
size_t dim;
|
98
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
99
|
-
switch (argc) {
|
100
|
-
case 2:
|
101
|
-
rank = FIX2UINT(argv[0]);
|
102
|
-
dim = (size_t) FIX2UINT(argv[1]);
|
103
|
-
t = FUNCTION(rbgsl_tensor,alloc)(rank, dim);
|
104
|
-
break;
|
105
|
-
default:
|
106
|
-
rb_raise(rb_eArgError, "wrong number of arguments (%d for 2, rank and dimension)",
|
107
|
-
argc);
|
108
|
-
break;
|
109
|
-
}
|
110
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), t);
|
111
|
-
}
|
112
|
-
|
113
|
-
static VALUE FUNCTION(rb_tensor,calloc)(VALUE klass, VALUE r, VALUE s)
|
114
|
-
{
|
115
|
-
unsigned int rank;
|
116
|
-
size_t dim;
|
117
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
118
|
-
rank = FIX2UINT(r);
|
119
|
-
dim = (size_t) FIX2UINT(s);
|
120
|
-
t = FUNCTION(rbgsl_tensor,calloc)(rank, dim);
|
121
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), t);
|
122
|
-
}
|
123
|
-
|
124
|
-
static VALUE FUNCTION(rb_tensor,copy_singleton)(VALUE klass, VALUE obj)
|
125
|
-
{
|
126
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL, *tnew = NULL;
|
127
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
128
|
-
tnew = FUNCTION(rbgsl_tensor,copy(t));
|
129
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), tnew);
|
130
|
-
}
|
131
|
-
|
132
|
-
static VALUE FUNCTION(rb_tensor,memcpy_singleton)(VALUE klass, VALUE a, VALUE b)
|
133
|
-
{
|
134
|
-
GSL_TYPE(rbgsl_tensor) *dst, *src;
|
135
|
-
CHECK_TEN(b);
|
136
|
-
Data_Get_Struct(a, GSL_TYPE(rbgsl_tensor), dst);
|
137
|
-
Data_Get_Struct(b, GSL_TYPE(rbgsl_tensor), src);
|
138
|
-
return INT2FIX(FUNCTION(tensor,memcpy)(dst->tensor, src->tensor));
|
139
|
-
}
|
140
|
-
|
141
|
-
static VALUE FUNCTION(rb_tensor,swap_singleton)(VALUE klass, VALUE a, VALUE b)
|
142
|
-
{
|
143
|
-
GSL_TYPE(rbgsl_tensor) *t1, *t2;
|
144
|
-
CHECK_TEN(b);
|
145
|
-
Data_Get_Struct(a, GSL_TYPE(rbgsl_tensor), t1);
|
146
|
-
Data_Get_Struct(b, GSL_TYPE(rbgsl_tensor), t2);
|
147
|
-
return INT2FIX(FUNCTION(tensor,swap)(t1->tensor, t2->tensor));
|
148
|
-
}
|
149
|
-
|
150
|
-
/*****/
|
151
|
-
static VALUE FUNCTION(rb_tensor,copy)(VALUE obj)
|
152
|
-
{
|
153
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL, *tnew = NULL;
|
154
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
155
|
-
tnew = FUNCTION(rbgsl_tensor,copy)(t);
|
156
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), tnew);
|
157
|
-
}
|
158
|
-
|
159
|
-
static VALUE FUNCTION(rb_tensor,set_zero)(VALUE obj)
|
160
|
-
{
|
161
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
162
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
163
|
-
FUNCTION(tensor,set_zero)(t->tensor);
|
164
|
-
return obj;
|
165
|
-
}
|
166
|
-
|
167
|
-
static VALUE FUNCTION(rb_tensor,set_all)(VALUE obj, VALUE xx)
|
168
|
-
{
|
169
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
170
|
-
BASE x;
|
171
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
172
|
-
x = NUMCONV(xx);
|
173
|
-
FUNCTION(tensor,set_all)(t->tensor, x);
|
174
|
-
return obj;
|
175
|
-
}
|
176
|
-
|
177
|
-
static void rb_tensor_get_indices_array(tensor_indices *v, VALUE ary);
|
178
|
-
static void rbgsl_tensor_get_indices(int argc, VALUE *argv, tensor_indices *indices,
|
179
|
-
size_t *n);
|
180
|
-
#ifdef BASE_DOUBLE
|
181
|
-
static void rb_tensor_get_indices_array(tensor_indices *v, VALUE ary)
|
182
|
-
{
|
183
|
-
size_t i, nn;
|
184
|
-
// nn = (size_t) GSL_MIN_INT((int) v->size, (int) RARRAY(ary)->len);
|
185
|
-
nn = (size_t) GSL_MIN_INT((int) v->size, (int) RARRAY_LEN(ary));
|
186
|
-
for (i = 0; i < nn; i++)
|
187
|
-
v->data[i] = FIX2UINT(rb_ary_entry(ary, i));
|
188
|
-
}
|
189
|
-
|
190
|
-
static void rbgsl_tensor_get_indices(int argc, VALUE *argv,
|
191
|
-
tensor_indices *indices, size_t *n)
|
192
|
-
{
|
193
|
-
size_t i;
|
194
|
-
for (i = 0; i < indices->size; i++) indices->data[i] = 0;
|
195
|
-
switch (argc) {
|
196
|
-
case 1:
|
197
|
-
switch (TYPE(argv[0])) {
|
198
|
-
case T_ARRAY:
|
199
|
-
// *n = (size_t) GSL_MIN_INT((int) indices->size, (int) RARRAY(argv[0])->len);
|
200
|
-
*n = (size_t) GSL_MIN_INT((int) indices->size, (int) RARRAY_LEN(argv[0]));
|
201
|
-
rb_tensor_get_indices_array(indices, argv[0]);
|
202
|
-
break;
|
203
|
-
case T_FIXNUM:
|
204
|
-
*n = 1;
|
205
|
-
indices->data[0] = FIX2INT(argv[0]);
|
206
|
-
break;
|
207
|
-
default:
|
208
|
-
rb_raise(rb_eTypeError, "wrong argument type %s (Array expected)",
|
209
|
-
rb_class2name(CLASS_OF(argv[0])));
|
210
|
-
break;
|
211
|
-
}
|
212
|
-
break;
|
213
|
-
default:
|
214
|
-
*n = (size_t) GSL_MIN_INT(argc, (int) indices->size);
|
215
|
-
for (i = 0; i < *n; i++) {
|
216
|
-
CHECK_FIXNUM(argv[i]);
|
217
|
-
indices->data[i] = FIX2INT(argv[i]);
|
218
|
-
}
|
219
|
-
break;
|
220
|
-
}
|
221
|
-
}
|
222
|
-
#endif
|
223
|
-
|
224
|
-
size_t FUNCTION(tensor,position)(const size_t * indices,
|
225
|
-
const GSL_TYPE(tensor) * t);
|
226
|
-
static VALUE FUNCTION(rb_tensor,position)(int argc, VALUE *argv, VALUE obj)
|
227
|
-
{
|
228
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
229
|
-
size_t n, position;
|
230
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
231
|
-
rbgsl_tensor_get_indices(argc, argv, t->indices, &n);
|
232
|
-
position = (size_t) FUNCTION(tensor,position)(t->indices->data,t->tensor);
|
233
|
-
return INT2FIX(position);
|
234
|
-
}
|
235
|
-
static VALUE FUNCTION(rb_tensor,subtensor)(int argc, VALUE *argv, VALUE obj);
|
236
|
-
static VALUE FUNCTION(rb_tensor,get)(int argc, VALUE *argv, VALUE obj)
|
237
|
-
{
|
238
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
239
|
-
BASE x;
|
240
|
-
size_t n;
|
241
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
242
|
-
rbgsl_tensor_get_indices(argc, argv, t->indices, &n);
|
243
|
-
if (n < t->tensor->rank) {
|
244
|
-
return FUNCTION(rb_tensor,subtensor)(argc, argv, obj);
|
245
|
-
} else {
|
246
|
-
x = FUNCTION(tensor,get)(t->tensor, t->indices->data);
|
247
|
-
return C_TO_VALUE(x);
|
248
|
-
}
|
249
|
-
return Qnil;
|
250
|
-
}
|
251
|
-
|
252
|
-
static VALUE FUNCTION(rb_tensor,set)(int argc, VALUE *argv, VALUE obj)
|
253
|
-
{
|
254
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
255
|
-
size_t n;
|
256
|
-
BASE x;
|
257
|
-
if (argc < 2)
|
258
|
-
rb_raise(rb_eArgError, "wrong number of arguments (%d for >= 2)", argc);
|
259
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
260
|
-
rbgsl_tensor_get_indices(argc-1, argv, t->indices, &n);
|
261
|
-
x = NUMCONV(argv[argc-1]);
|
262
|
-
FUNCTION(tensor,set)(t->tensor, t->indices->data, x);
|
263
|
-
return obj;
|
264
|
-
}
|
265
|
-
|
266
|
-
static VALUE FUNCTION(rb_tensor,fread)(VALUE obj, VALUE io)
|
267
|
-
{
|
268
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
269
|
-
FILE *f = NULL;
|
270
|
-
int status, flag = 0;
|
271
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
272
|
-
f = rb_gsl_open_readfile(io, &flag);
|
273
|
-
status = FUNCTION(tensor,fread)(f, t->tensor);
|
274
|
-
if (flag == 1) fclose(f);
|
275
|
-
return INT2FIX(status);
|
276
|
-
}
|
277
|
-
|
278
|
-
static VALUE FUNCTION(rb_tensor,fwrite)(VALUE obj, VALUE io)
|
279
|
-
{
|
280
|
-
GSL_TYPE(rbgsl_tensor) *t = NULL;
|
281
|
-
FILE *f = NULL;
|
282
|
-
int status, flag = 0;
|
283
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
284
|
-
f = rb_gsl_open_writefile(io, &flag);
|
285
|
-
status = FUNCTION(tensor,fwrite)(f, t->tensor);
|
286
|
-
if (flag == 1) fclose(f);
|
287
|
-
return INT2FIX(status);
|
288
|
-
}
|
289
|
-
|
290
|
-
static VALUE FUNCTION(rb_tensor,fprintf)(int argc, VALUE *argv, VALUE obj)
|
291
|
-
{
|
292
|
-
GSL_TYPE(rbgsl_tensor) *h = NULL;
|
293
|
-
FILE *fp = NULL;
|
294
|
-
int status, flag = 0;
|
295
|
-
if (argc != 1 && argc != 2)
|
296
|
-
rb_raise(rb_eArgError, "wrong number of arguments (%d for 1 or 2)", argc);
|
297
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), h);
|
298
|
-
fp = rb_gsl_open_writefile(argv[0], &flag);
|
299
|
-
switch (argc) {
|
300
|
-
case 2:
|
301
|
-
if (TYPE(argv[1]) == T_STRING)
|
302
|
-
status = FUNCTION(tensor,fprintf)(fp, h->tensor, STR2CSTR(argv[1]));
|
303
|
-
else
|
304
|
-
rb_raise(rb_eTypeError, "argv 2 String expected");
|
305
|
-
break;
|
306
|
-
default:
|
307
|
-
status = FUNCTION(tensor,fprintf)(fp, h->tensor, OUT_FORMAT);
|
308
|
-
break;
|
309
|
-
}
|
310
|
-
if (flag == 1) fclose(fp);
|
311
|
-
return INT2FIX(status);
|
312
|
-
}
|
313
|
-
|
314
|
-
static VALUE FUNCTION(rb_tensor,printf)(int argc, VALUE *argv, VALUE obj)
|
315
|
-
{
|
316
|
-
GSL_TYPE(rbgsl_tensor) *h = NULL;
|
317
|
-
int status;
|
318
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), h);
|
319
|
-
if (argc == 1) {
|
320
|
-
if (TYPE(argv[0]) != T_STRING)
|
321
|
-
rb_raise(rb_eTypeError, "String expected");
|
322
|
-
else
|
323
|
-
status = FUNCTION(tensor,fprintf)(stdout, h->tensor, STR2CSTR(argv[0]));
|
324
|
-
} else {
|
325
|
-
status = FUNCTION(tensor,fprintf)(stdout, h->tensor, OUT_FORMAT);
|
326
|
-
}
|
327
|
-
return INT2FIX(status);
|
328
|
-
}
|
329
|
-
|
330
|
-
static VALUE FUNCTION(rb_tensor,fscanf)(VALUE obj, VALUE io)
|
331
|
-
{
|
332
|
-
GSL_TYPE(rbgsl_tensor) *h = NULL;
|
333
|
-
FILE *fp = NULL;
|
334
|
-
int status, flag = 0;
|
335
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), h);
|
336
|
-
fp = rb_gsl_open_readfile(io, &flag);
|
337
|
-
status = FUNCTION(tensor,fscanf)(fp, h->tensor);
|
338
|
-
if (flag == 1) fclose(fp);
|
339
|
-
return INT2FIX(status);
|
340
|
-
}
|
341
|
-
|
342
|
-
static VALUE FUNCTION(rb_tensor,swap_indices)(VALUE obj, VALUE ii, VALUE jj)
|
343
|
-
{
|
344
|
-
GSL_TYPE(rbgsl_tensor) *t, *tnew;
|
345
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
346
|
-
tnew = ALLOC(GSL_TYPE(rbgsl_tensor));
|
347
|
-
if (t->tensor->rank == 0)
|
348
|
-
tnew->indices = gsl_permutation_alloc(1);
|
349
|
-
else
|
350
|
-
tnew->indices = gsl_permutation_alloc(t->tensor->rank);
|
351
|
-
tnew->tensor = FUNCTION(tensor,swap_indices)(t->tensor, FIX2INT(ii), FIX2INT(jj));
|
352
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), tnew);
|
353
|
-
}
|
354
|
-
|
355
|
-
static VALUE FUNCTION(rb_tensor,max)(VALUE obj)
|
356
|
-
{
|
357
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
358
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
359
|
-
return C_TO_VALUE(FUNCTION(tensor,max)(t->tensor));
|
360
|
-
}
|
361
|
-
|
362
|
-
static VALUE FUNCTION(rb_tensor,min)(VALUE obj)
|
363
|
-
{
|
364
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
365
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
366
|
-
return C_TO_VALUE(FUNCTION(tensor,min)(t->tensor));
|
367
|
-
}
|
368
|
-
|
369
|
-
static VALUE FUNCTION(rb_tensor,minmax)(VALUE obj)
|
370
|
-
{
|
371
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
372
|
-
BASE min, max;
|
373
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
374
|
-
FUNCTION(tensor,minmax)(t->tensor, &min, &max);
|
375
|
-
return rb_ary_new3(2, C_TO_VALUE(min), C_TO_VALUE(max));
|
376
|
-
}
|
377
|
-
|
378
|
-
static VALUE FUNCTION(rb_tensor,max_index)(VALUE obj)
|
379
|
-
{
|
380
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
381
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
382
|
-
FUNCTION(tensor,max_index)(t->tensor, t->indices->data);
|
383
|
-
return Data_Wrap_Struct(cgsl_index, 0, NULL, t->indices);
|
384
|
-
}
|
385
|
-
|
386
|
-
static VALUE FUNCTION(rb_tensor,min_index)(VALUE obj)
|
387
|
-
{
|
388
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
389
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
390
|
-
FUNCTION(tensor,min_index)(t->tensor, t->indices->data);
|
391
|
-
return Data_Wrap_Struct(cgsl_index, 0, NULL, t->indices);
|
392
|
-
}
|
393
|
-
|
394
|
-
static VALUE FUNCTION(rb_tensor,minmax_index)(VALUE obj)
|
395
|
-
{
|
396
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
397
|
-
gsl_permutation *min, *max;
|
398
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
399
|
-
if (t->tensor->rank == 0) {
|
400
|
-
min = gsl_permutation_alloc(1);
|
401
|
-
max = gsl_permutation_alloc(1);
|
402
|
-
} else {
|
403
|
-
min = gsl_permutation_alloc(t->tensor->rank);
|
404
|
-
max = gsl_permutation_alloc(t->tensor->rank);
|
405
|
-
}
|
406
|
-
FUNCTION(tensor,minmax_index)(t->tensor, min->data, max->data);
|
407
|
-
return rb_ary_new3(2,
|
408
|
-
Data_Wrap_Struct(cgsl_index, 0, gsl_permutation_free, min),
|
409
|
-
Data_Wrap_Struct(cgsl_index, 0, gsl_permutation_free, max));
|
410
|
-
}
|
411
|
-
|
412
|
-
static VALUE FUNCTION(rb_tensor,isnull)(VALUE obj)
|
413
|
-
{
|
414
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
415
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
416
|
-
return INT2FIX(FUNCTION(tensor,isnull)(t->tensor));
|
417
|
-
}
|
418
|
-
|
419
|
-
static VALUE FUNCTION(rb_tensor,isnull2)(VALUE obj)
|
420
|
-
{
|
421
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
422
|
-
int status;
|
423
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
424
|
-
status = FUNCTION(tensor,isnull)(t->tensor);
|
425
|
-
if (status) return Qtrue;
|
426
|
-
else return Qfalse;
|
427
|
-
}
|
428
|
-
|
429
|
-
static VALUE FUNCTION(rb_tensor,oper)(VALUE obj, VALUE bb,
|
430
|
-
int flag)
|
431
|
-
{
|
432
|
-
GSL_TYPE(rbgsl_tensor) *a, *b, *anew;
|
433
|
-
BASE x;
|
434
|
-
int (*f)(GSL_TYPE(tensor)*, const GSL_TYPE(tensor)*);
|
435
|
-
int (*f2)(GSL_TYPE(tensor)*, const double);
|
436
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), a);
|
437
|
-
anew = FUNCTION(rbgsl_tensor,copy)(a);
|
438
|
-
if (TEN_P(bb)) {
|
439
|
-
Data_Get_Struct(bb, GSL_TYPE(rbgsl_tensor), b);
|
440
|
-
switch (flag) {
|
441
|
-
case TENSOR_ADD: f = FUNCTION(&tensor,add); break;
|
442
|
-
case TENSOR_SUB: f = FUNCTION(&tensor,sub); break;
|
443
|
-
case TENSOR_MUL_ELEMENTS: f = FUNCTION(&tensor,mul_elements); break;
|
444
|
-
case TENSOR_DIV_ELEMENTS: f = FUNCTION(&tensor,div_elements); break;
|
445
|
-
default: rb_raise(rb_eRuntimeError, "unknown operation"); break;
|
446
|
-
}
|
447
|
-
(*f)(anew->tensor, b->tensor);
|
448
|
-
} else {
|
449
|
-
switch (flag) {
|
450
|
-
case TENSOR_ADD:
|
451
|
-
case TENSOR_ADD_CONSTANT:
|
452
|
-
x = NUMCONV(bb);
|
453
|
-
f2 = FUNCTION(&tensor,add_constant);
|
454
|
-
break;
|
455
|
-
case TENSOR_SUB:
|
456
|
-
x = -NUMCONV(bb);
|
457
|
-
f2 = FUNCTION(&tensor,add_constant);
|
458
|
-
break;
|
459
|
-
case TENSOR_ADD_DIAGONAL: f2 = FUNCTION(&tensor,add_diagonal); break;
|
460
|
-
case TENSOR_MUL_ELEMENTS:
|
461
|
-
case TENSOR_SCALE:
|
462
|
-
x = NUMCONV(bb);
|
463
|
-
f2 = FUNCTION(&tensor,scale);
|
464
|
-
break;
|
465
|
-
case TENSOR_DIV_ELEMENTS:
|
466
|
-
x = 1.0/NUMCONV(bb);
|
467
|
-
f2 = FUNCTION(&tensor,scale);
|
468
|
-
break;
|
469
|
-
default: rb_raise(rb_eRuntimeError, "unknown operation"); break;
|
470
|
-
}
|
471
|
-
(*f2)(anew->tensor, x);
|
472
|
-
}
|
473
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), anew);
|
474
|
-
}
|
475
|
-
|
476
|
-
|
477
|
-
static VALUE FUNCTION(rb_tensor,oper_bang)(VALUE obj, VALUE bb, int flag)
|
478
|
-
{
|
479
|
-
GSL_TYPE(rbgsl_tensor) *a, *b;
|
480
|
-
BASE x;
|
481
|
-
int (*f)(GSL_TYPE(tensor)*, const GSL_TYPE(tensor)*);
|
482
|
-
int (*f2)(GSL_TYPE(tensor)*, const double);
|
483
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), a);
|
484
|
-
if (TEN_P(bb)) {
|
485
|
-
Data_Get_Struct(bb, GSL_TYPE(rbgsl_tensor), b);
|
486
|
-
switch (flag) {
|
487
|
-
case TENSOR_ADD: f = FUNCTION(&tensor,add); break;
|
488
|
-
case TENSOR_SUB: f = FUNCTION(&tensor,sub); break;
|
489
|
-
case TENSOR_MUL_ELEMENTS: f = FUNCTION(&tensor,mul_elements); break;
|
490
|
-
case TENSOR_DIV_ELEMENTS: f = FUNCTION(&tensor,div_elements); break;
|
491
|
-
default: rb_raise(rb_eRuntimeError, "unknown operation"); break;
|
492
|
-
}
|
493
|
-
(*f)(a->tensor, b->tensor);
|
494
|
-
} else {
|
495
|
-
switch (flag) {
|
496
|
-
case TENSOR_ADD:
|
497
|
-
case TENSOR_ADD_CONSTANT:
|
498
|
-
x = NUMCONV(bb);
|
499
|
-
f2 = FUNCTION(&tensor,add_constant);
|
500
|
-
break;
|
501
|
-
case TENSOR_SUB:
|
502
|
-
x = -NUMCONV(bb);
|
503
|
-
f2 = FUNCTION(&tensor,add_constant);
|
504
|
-
break;
|
505
|
-
case TENSOR_ADD_DIAGONAL: f2 = FUNCTION(&tensor,add_diagonal); break;
|
506
|
-
case TENSOR_MUL_ELEMENTS:
|
507
|
-
case TENSOR_SCALE:
|
508
|
-
x = NUMCONV(bb);
|
509
|
-
f2 = FUNCTION(&tensor,scale);
|
510
|
-
break;
|
511
|
-
case TENSOR_DIV_ELEMENTS:
|
512
|
-
x = 1.0/NUMCONV(bb);
|
513
|
-
f2 = FUNCTION(&tensor,scale);
|
514
|
-
break;
|
515
|
-
default: rb_raise(rb_eRuntimeError, "unknown operation"); break;
|
516
|
-
}
|
517
|
-
(*f2)(a->tensor, x);
|
518
|
-
}
|
519
|
-
return obj;
|
520
|
-
}
|
521
|
-
|
522
|
-
static VALUE FUNCTION(rb_tensor,add)(VALUE obj, VALUE bb)
|
523
|
-
{
|
524
|
-
return FUNCTION(rb_tensor,oper)(obj, bb, TENSOR_ADD);
|
525
|
-
}
|
526
|
-
|
527
|
-
static VALUE FUNCTION(rb_tensor,sub)(VALUE obj, VALUE bb)
|
528
|
-
{
|
529
|
-
return FUNCTION(rb_tensor,oper)(obj, bb, TENSOR_SUB);
|
530
|
-
}
|
531
|
-
|
532
|
-
static VALUE FUNCTION(rb_tensor,mul_elements)(VALUE obj, VALUE bb)
|
533
|
-
{
|
534
|
-
return FUNCTION(rb_tensor,oper)(obj, bb, TENSOR_MUL_ELEMENTS);
|
535
|
-
}
|
536
|
-
|
537
|
-
static VALUE FUNCTION(rb_tensor,div_elements)(VALUE obj, VALUE bb)
|
538
|
-
{
|
539
|
-
return FUNCTION(rb_tensor,oper)(obj, bb, TENSOR_DIV_ELEMENTS);
|
540
|
-
}
|
541
|
-
|
542
|
-
static VALUE FUNCTION(rb_tensor,add_constant)(VALUE obj, VALUE bb)
|
543
|
-
{
|
544
|
-
return FUNCTION(rb_tensor,oper)(obj, bb, TENSOR_ADD_CONSTANT);
|
545
|
-
}
|
546
|
-
|
547
|
-
static VALUE FUNCTION(rb_tensor,add_diagonal)(VALUE obj, VALUE bb)
|
548
|
-
{
|
549
|
-
return FUNCTION(rb_tensor,oper)(obj, bb, TENSOR_ADD_DIAGONAL);
|
550
|
-
}
|
551
|
-
|
552
|
-
static VALUE FUNCTION(rb_tensor,scale)(VALUE obj, VALUE bb)
|
553
|
-
{
|
554
|
-
return FUNCTION(rb_tensor,oper)(obj, bb, TENSOR_SCALE);
|
555
|
-
}
|
556
|
-
|
557
|
-
/***/
|
558
|
-
static VALUE FUNCTION(rb_tensor,add_bang)(VALUE obj, VALUE bb)
|
559
|
-
{
|
560
|
-
return FUNCTION(rb_tensor,oper_bang)(obj, bb, TENSOR_ADD);
|
561
|
-
}
|
562
|
-
|
563
|
-
static VALUE FUNCTION(rb_tensor,sub_bang)(VALUE obj, VALUE bb)
|
564
|
-
{
|
565
|
-
return FUNCTION(rb_tensor,oper_bang)(obj, bb, TENSOR_SUB);
|
566
|
-
}
|
567
|
-
|
568
|
-
static VALUE FUNCTION(rb_tensor,mul_elements_bang)(VALUE obj, VALUE bb)
|
569
|
-
{
|
570
|
-
return FUNCTION(rb_tensor,oper_bang)(obj, bb, TENSOR_MUL_ELEMENTS);
|
571
|
-
}
|
572
|
-
|
573
|
-
static VALUE FUNCTION(rb_tensor,div_elements_bang)(VALUE obj, VALUE bb)
|
574
|
-
{
|
575
|
-
return FUNCTION(rb_tensor,oper_bang)(obj, bb, TENSOR_DIV_ELEMENTS);
|
576
|
-
}
|
577
|
-
|
578
|
-
static VALUE FUNCTION(rb_tensor,add_constant_bang)(VALUE obj, VALUE bb)
|
579
|
-
{
|
580
|
-
return FUNCTION(rb_tensor,oper_bang)(obj, bb, TENSOR_ADD_CONSTANT);
|
581
|
-
}
|
582
|
-
|
583
|
-
static VALUE FUNCTION(rb_tensor,add_diagonal_bang)(VALUE obj, VALUE bb)
|
584
|
-
{
|
585
|
-
return FUNCTION(rb_tensor,oper_bang)(obj, bb, TENSOR_ADD_DIAGONAL);
|
586
|
-
}
|
587
|
-
|
588
|
-
static VALUE FUNCTION(rb_tensor,scale_bang)(VALUE obj, VALUE bb)
|
589
|
-
{
|
590
|
-
return FUNCTION(rb_tensor,oper_bang)(obj, bb, TENSOR_SCALE);
|
591
|
-
}
|
592
|
-
|
593
|
-
/*****/
|
594
|
-
static VALUE FUNCTION(rb_tensor,product_singleton)(VALUE obj, VALUE aa, VALUE bb)
|
595
|
-
{
|
596
|
-
GSL_TYPE(rbgsl_tensor) *a, *b, *c;
|
597
|
-
CHECK_TEN(aa);
|
598
|
-
CHECK_TEN(bb);
|
599
|
-
Data_Get_Struct(aa, GSL_TYPE(rbgsl_tensor), a);
|
600
|
-
switch (TYPE(bb)) {
|
601
|
-
case T_FIXNUM:
|
602
|
-
case T_BIGNUM:
|
603
|
-
case T_FLOAT:
|
604
|
-
return FUNCTION(rb_tensor,mul_elements)(aa, bb);
|
605
|
-
break;
|
606
|
-
default:
|
607
|
-
Data_Get_Struct(bb, GSL_TYPE(rbgsl_tensor), b);
|
608
|
-
c = ALLOC(GSL_TYPE(rbgsl_tensor));
|
609
|
-
c->tensor = FUNCTION(tensor,product(a->tensor, b->tensor));
|
610
|
-
if (c->tensor->rank == 0)
|
611
|
-
c->indices = gsl_permutation_alloc(1);
|
612
|
-
else
|
613
|
-
c->indices = gsl_permutation_alloc(c->tensor->rank);
|
614
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), c);
|
615
|
-
break;
|
616
|
-
}
|
617
|
-
}
|
618
|
-
|
619
|
-
static VALUE FUNCTION(rb_tensor,product)(VALUE obj, VALUE bb)
|
620
|
-
{
|
621
|
-
GSL_TYPE(rbgsl_tensor) *a, *b, *c;
|
622
|
-
switch (TYPE(bb)) {
|
623
|
-
case T_FIXNUM:
|
624
|
-
case T_BIGNUM:
|
625
|
-
case T_FLOAT:
|
626
|
-
return FUNCTION(rb_tensor,mul_elements)(obj, bb);
|
627
|
-
break;
|
628
|
-
default:
|
629
|
-
CHECK_TEN(bb);
|
630
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), a);
|
631
|
-
Data_Get_Struct(bb, GSL_TYPE(rbgsl_tensor), b);
|
632
|
-
c = ALLOC(GSL_TYPE(rbgsl_tensor));
|
633
|
-
c->tensor = FUNCTION(tensor,product(a->tensor, b->tensor));
|
634
|
-
if (c->tensor->rank == 0)
|
635
|
-
c->indices = gsl_permutation_alloc(1);
|
636
|
-
else
|
637
|
-
c->indices = gsl_permutation_alloc(c->tensor->rank);
|
638
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), c);
|
639
|
-
break;
|
640
|
-
}
|
641
|
-
}
|
642
|
-
|
643
|
-
static VALUE FUNCTION(rb_tensor,contract)(VALUE obj, VALUE ii, VALUE jj)
|
644
|
-
{
|
645
|
-
GSL_TYPE(rbgsl_tensor) *t, *tnew;
|
646
|
-
size_t rank;
|
647
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
648
|
-
tnew = ALLOC(GSL_TYPE(rbgsl_tensor));
|
649
|
-
tnew->tensor = FUNCTION(tensor,contract)(t->tensor, FIX2INT(ii), FIX2INT(jj));
|
650
|
-
if (tnew->tensor->rank == 0) rank = 1;
|
651
|
-
else rank = tnew->tensor->rank;
|
652
|
-
tnew->indices = gsl_permutation_alloc(rank);
|
653
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), tnew);
|
654
|
-
}
|
655
|
-
|
656
|
-
static VALUE FUNCTION(rb_tensor,size)(VALUE obj)
|
657
|
-
{
|
658
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
659
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
660
|
-
return INT2FIX(t->tensor->size);
|
661
|
-
}
|
662
|
-
|
663
|
-
static VALUE FUNCTION(rb_tensor,rank)(VALUE obj)
|
664
|
-
{
|
665
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
666
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
667
|
-
return INT2FIX(t->tensor->rank);
|
668
|
-
}
|
669
|
-
|
670
|
-
static VALUE FUNCTION(rb_tensor,dimension)(VALUE obj)
|
671
|
-
{
|
672
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
673
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
674
|
-
return INT2FIX(t->tensor->dimension);
|
675
|
-
}
|
676
|
-
|
677
|
-
static VALUE FUNCTION(rb_tensor,data)(VALUE obj)
|
678
|
-
{
|
679
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
680
|
-
QUALIFIED_VIEW(gsl_vector,view) *v = NULL;
|
681
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
682
|
-
v = FUNCTION(rb_gsl_make_vector,view)(t->tensor->data, t->tensor->size, 1);
|
683
|
-
return Data_Wrap_Struct(QUALIFIED_VIEW(cgsl_vector,view), 0, free, v);
|
684
|
-
}
|
685
|
-
|
686
|
-
static VALUE FUNCTION(rb_tensor,2matrix)(VALUE obj)
|
687
|
-
{
|
688
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
689
|
-
GSL_TYPE(gsl_matrix) *m = NULL;
|
690
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
691
|
-
m = (GSL_TYPE(gsl_matrix)*)FUNCTION(tensor,2matrix)(t->tensor);
|
692
|
-
return Data_Wrap_Struct(QUALIFIED_VIEW(cgsl_matrix,view), 0, FUNCTION(gsl_matrix,free), m);
|
693
|
-
}
|
694
|
-
|
695
|
-
static VALUE FUNCTION(rb_tensor,2vector)(VALUE obj)
|
696
|
-
{
|
697
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
698
|
-
GSL_TYPE(gsl_vector) *v = NULL;
|
699
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
700
|
-
v = (GSL_TYPE(gsl_vector) *)FUNCTION(tensor,2vector)(t->tensor);
|
701
|
-
return Data_Wrap_Struct(QUALIFIED_VIEW(cgsl_vector,view), 0, FUNCTION(gsl_vector,free), v);
|
702
|
-
}
|
703
|
-
|
704
|
-
static VALUE FUNCTION(rb_tensor,to_v)(VALUE obj)
|
705
|
-
{
|
706
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
707
|
-
GSL_TYPE(gsl_vector) *v;
|
708
|
-
|
709
|
-
v = FUNCTION(gsl_vector,alloc)(t->tensor->size);
|
710
|
-
memcpy(v->data, t->tensor->data, sizeof(BASE)*v->size);
|
711
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_vector), 0, FUNCTION(gsl_vector,free), v);
|
712
|
-
}
|
713
|
-
|
714
|
-
/*
|
715
|
-
Creates a subtensor slicing the existing tensor.
|
716
|
-
NOTE: no new data region is malloced.
|
717
|
-
t: Tensor
|
718
|
-
rank: rank of the tensor created
|
719
|
-
*/
|
720
|
-
GSL_TYPE(tensor) FUNCTION(tensor,subtensor)(const GSL_TYPE(tensor) *t,
|
721
|
-
const unsigned int rank,
|
722
|
-
size_t *indices)
|
723
|
-
{
|
724
|
-
GSL_TYPE(tensor) tnew;
|
725
|
-
size_t position;
|
726
|
-
tnew.rank = rank;
|
727
|
-
tnew.dimension = t->dimension;
|
728
|
-
tnew.size = quick_pow(t->dimension, rank);
|
729
|
-
position = FUNCTION(tensor,position)(indices, t);
|
730
|
-
if (position >= t->size)
|
731
|
-
rb_raise(rb_eRangeError, "wrong indices given");
|
732
|
-
tnew.data = t->data + position;
|
733
|
-
return tnew;
|
734
|
-
}
|
735
|
-
|
736
|
-
static VALUE FUNCTION(rb_tensor,subtensor)(int argc, VALUE *argv, VALUE obj)
|
737
|
-
{
|
738
|
-
GSL_TYPE(rbgsl_tensor) *t, *tnew;
|
739
|
-
unsigned int rank;
|
740
|
-
size_t n;
|
741
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
742
|
-
/* n: number of indices given */
|
743
|
-
rbgsl_tensor_get_indices(argc, argv, t->indices, &n);
|
744
|
-
rank = t->tensor->rank - n;
|
745
|
-
tnew = ALLOC(GSL_TYPE(rbgsl_tensor));
|
746
|
-
tnew->tensor = (GSL_TYPE(tensor)*)malloc(sizeof(GSL_TYPE(tensor)));
|
747
|
-
*(tnew->tensor) = FUNCTION(tensor,subtensor)(t->tensor, rank, t->indices->data);
|
748
|
-
if (rank == 0)
|
749
|
-
tnew->indices = gsl_permutation_alloc(1);
|
750
|
-
else
|
751
|
-
tnew->indices = gsl_permutation_alloc(rank);
|
752
|
-
return Data_Wrap_Struct(QUALIFIED_VIEW(cgsl_tensor,view), 0, FUNCTION(rbgsl_tensor,free2), tnew);
|
753
|
-
}
|
754
|
-
|
755
|
-
#ifdef BASE_DOUBLE
|
756
|
-
#define SHOW_ELM 6
|
757
|
-
#define PRINTF_FORMAT "%4.3e "
|
758
|
-
#else
|
759
|
-
#define SHOW_ELM 15
|
760
|
-
#define PRINTF_FORMAT "%d "
|
761
|
-
#endif
|
762
|
-
static VALUE FUNCTION(rb_tensor,to_s)(VALUE obj)
|
763
|
-
{
|
764
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
765
|
-
QUALIFIED_VIEW(gsl_matrix,view) matrix;
|
766
|
-
QUALIFIED_VIEW(gsl_vector,view) vector;
|
767
|
-
GSL_TYPE(gsl_matrix) *m;
|
768
|
-
GSL_TYPE(gsl_vector) *v;
|
769
|
-
char buf[16];
|
770
|
-
size_t i, j;
|
771
|
-
VALUE str;
|
772
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
773
|
-
str = rb_str_new2("[ ");
|
774
|
-
switch (t->tensor->rank) {
|
775
|
-
case 2:
|
776
|
-
matrix.matrix.data = t->tensor->data;
|
777
|
-
matrix.matrix.size1 = t->tensor->dimension;
|
778
|
-
matrix.matrix.size2 = t->tensor->dimension;
|
779
|
-
matrix.matrix.tda = t->tensor->dimension;
|
780
|
-
matrix.matrix.block = 0;
|
781
|
-
matrix.matrix.owner = 0;
|
782
|
-
m = &(matrix.matrix);
|
783
|
-
for (i = 0; i < m->size1; i++) {
|
784
|
-
if (i != 0) {
|
785
|
-
strcpy(buf, " ");
|
786
|
-
rb_str_cat(str, buf, strlen(buf));
|
787
|
-
}
|
788
|
-
for (j = 0; j < m->size2; j++) {
|
789
|
-
sprintf(buf, PRINTF_FORMAT, FUNCTION(gsl_matrix,get)(m, i, j));
|
790
|
-
rb_str_cat(str, buf, strlen(buf));
|
791
|
-
if (j == SHOW_ELM) {
|
792
|
-
strcpy(buf, "... ");
|
793
|
-
rb_str_cat(str, buf, strlen(buf));
|
794
|
-
break;
|
795
|
-
}
|
796
|
-
}
|
797
|
-
if (i == 6) {
|
798
|
-
strcpy(buf, "\n ... ]");
|
799
|
-
rb_str_cat(str, buf, strlen(buf));
|
800
|
-
break;
|
801
|
-
}
|
802
|
-
if (i == m->size1 - 1) {
|
803
|
-
strcpy(buf, "]");
|
804
|
-
rb_str_cat(str, buf, strlen(buf));
|
805
|
-
} else {
|
806
|
-
strcpy(buf, "\n");
|
807
|
-
rb_str_cat(str, buf, strlen(buf));
|
808
|
-
}
|
809
|
-
}
|
810
|
-
return str;
|
811
|
-
break;
|
812
|
-
default:
|
813
|
-
vector.vector.data = t->tensor->data;
|
814
|
-
vector.vector.stride = 1;
|
815
|
-
vector.vector.size = t->tensor->size;
|
816
|
-
vector.vector.owner = 0;
|
817
|
-
vector.vector.block = 0;
|
818
|
-
v = &(vector.vector);
|
819
|
-
sprintf(buf, PRINTF_FORMAT, FUNCTION(gsl_vector,get)(v, 0));
|
820
|
-
rb_str_cat(str, buf, strlen(buf));
|
821
|
-
for (i = 1; i < v->size; i++) {
|
822
|
-
sprintf(buf, PRINTF_FORMAT, FUNCTION(gsl_vector,get)(v, i));
|
823
|
-
rb_str_cat(str, buf, strlen(buf));
|
824
|
-
if (i == SHOW_ELM && i != v->size-1) {
|
825
|
-
strcpy(buf, "... ");
|
826
|
-
rb_str_cat(str, buf, strlen(buf));
|
827
|
-
break;
|
828
|
-
}
|
829
|
-
}
|
830
|
-
sprintf(buf, "]");
|
831
|
-
rb_str_cat(str, buf, strlen(buf));
|
832
|
-
return str;
|
833
|
-
break;
|
834
|
-
}
|
835
|
-
}
|
836
|
-
#undef SHOW_ELM
|
837
|
-
#undef PRINTF_FORMAT
|
838
|
-
|
839
|
-
static VALUE FUNCTION(rb_tensor,inspect)(VALUE obj)
|
840
|
-
{
|
841
|
-
VALUE str;
|
842
|
-
char buf[64];
|
843
|
-
sprintf(buf, "%s\n", rb_class2name(CLASS_OF(obj)));
|
844
|
-
str = rb_str_new2(buf);
|
845
|
-
return rb_str_concat(str, FUNCTION(rb_tensor,to_s)(obj));
|
846
|
-
}
|
847
|
-
|
848
|
-
VALUE FUNCTION(rb_tensor,equal)(int argc, VALUE *argv, VALUE obj)
|
849
|
-
{
|
850
|
-
GSL_TYPE(rbgsl_tensor) *a, *b;
|
851
|
-
GSL_TYPE(gsl_matrix) *m;
|
852
|
-
GSL_TYPE(gsl_vector) *v;
|
853
|
-
VALUE other;
|
854
|
-
double eps = 1e-10;
|
855
|
-
size_t i;
|
856
|
-
switch (argc) {
|
857
|
-
case 2:
|
858
|
-
other = argv[0];
|
859
|
-
eps = NUM2DBL(argv[1]);
|
860
|
-
break;
|
861
|
-
case 1:
|
862
|
-
other = argv[0];
|
863
|
-
break;
|
864
|
-
default:
|
865
|
-
rb_raise(rb_eArgError, "wrong number of arguments (%d for 1 or 2)", argc);
|
866
|
-
}
|
867
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), a);
|
868
|
-
if (TEN_P(other)) {
|
869
|
-
Data_Get_Struct(other, GSL_TYPE(rbgsl_tensor), b);
|
870
|
-
if (a->tensor->rank != b->tensor->rank) return Qfalse;
|
871
|
-
if (a->tensor->dimension != b->tensor->dimension) return Qfalse;
|
872
|
-
if (a->tensor->size != b->tensor->size) return Qfalse;
|
873
|
-
for (i = 0; i < a->tensor->size; i++)
|
874
|
-
if (fabs(a->tensor->data[i]-b->tensor->data[i]) > eps)
|
875
|
-
return Qfalse;
|
876
|
-
return Qtrue;
|
877
|
-
} else if (MAT_P(other)) {
|
878
|
-
if (a->tensor->rank != 2) return Qfalse;
|
879
|
-
Data_Get_Struct(other, GSL_TYPE(gsl_matrix), m);
|
880
|
-
if (a->tensor->dimension != m->size1 || a->tensor->dimension != m->size2)
|
881
|
-
return Qfalse;
|
882
|
-
for (i = 0; i < a->tensor->size; i++)
|
883
|
-
if (fabs(a->tensor->data[i]-m->data[i]) > eps)
|
884
|
-
return Qfalse;
|
885
|
-
return Qtrue;
|
886
|
-
} else if (VEC_P(other)) {
|
887
|
-
Data_Get_Struct(other, GSL_TYPE(gsl_vector), v);
|
888
|
-
if (a->tensor->size != v->size) return Qfalse;
|
889
|
-
for (i = 0; i < a->tensor->size; i++)
|
890
|
-
if (fabs(a->tensor->data[i]-v->data[i]) > eps)
|
891
|
-
return Qfalse;
|
892
|
-
return Qtrue;
|
893
|
-
} else {
|
894
|
-
rb_raise(rb_eTypeError, "wrong argument type %s (Tensor, Matrix or Vector expected)",
|
895
|
-
rb_class2name(CLASS_OF(other)));
|
896
|
-
}
|
897
|
-
}
|
898
|
-
|
899
|
-
static VALUE FUNCTION(rb_tensor,uplus)(VALUE obj)
|
900
|
-
{
|
901
|
-
return obj;
|
902
|
-
}
|
903
|
-
|
904
|
-
static VALUE FUNCTION(rb_tensor,uminus)(VALUE obj)
|
905
|
-
{
|
906
|
-
GSL_TYPE(rbgsl_tensor) *t, *tnew;
|
907
|
-
size_t i;
|
908
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
909
|
-
tnew = FUNCTION(rbgsl_tensor,copy)(t);
|
910
|
-
for (i = 0; i < tnew->tensor->size; i++)
|
911
|
-
tnew->tensor->data[i] *= -1;
|
912
|
-
return Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), tnew);
|
913
|
-
}
|
914
|
-
|
915
|
-
static VALUE FUNCTION(rb_tensor,coerce)(VALUE obj, VALUE other)
|
916
|
-
{
|
917
|
-
GSL_TYPE(rbgsl_tensor) *t, *tnew;
|
918
|
-
VALUE tt;
|
919
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
920
|
-
switch (TYPE(other)) {
|
921
|
-
case T_FLOAT:
|
922
|
-
case T_FIXNUM:
|
923
|
-
case T_BIGNUM:
|
924
|
-
tnew = FUNCTION(rbgsl_tensor,alloc)(t->tensor->rank, t->tensor->dimension);
|
925
|
-
FUNCTION(tensor,set_all)(tnew->tensor, NUMCONV(other));
|
926
|
-
tt = Data_Wrap_Struct(GSL_TYPE(cgsl_tensor), 0, FUNCTION(rbgsl_tensor,free), tnew);
|
927
|
-
return rb_ary_new3(2, tt, obj);
|
928
|
-
break;
|
929
|
-
default:
|
930
|
-
rb_raise(rb_eRuntimeError, "undefined operation with %s",
|
931
|
-
rb_class2name(CLASS_OF(other)));
|
932
|
-
break;
|
933
|
-
}
|
934
|
-
}
|
935
|
-
|
936
|
-
static VALUE FUNCTION(rb_tensor,info)(VALUE obj)
|
937
|
-
{
|
938
|
-
GSL_TYPE(rbgsl_tensor) *t;
|
939
|
-
char buf[256];
|
940
|
-
Data_Get_Struct(obj, GSL_TYPE(rbgsl_tensor), t);
|
941
|
-
sprintf(buf, "Class: %s\n", rb_class2name(CLASS_OF(obj)));
|
942
|
-
sprintf(buf, "%sSuperClass: %s\n", buf, rb_class2name(RCLASS_SUPER(CLASS_OF(obj))));
|
943
|
-
sprintf(buf, "%sRank: %d\n", buf, (int) t->tensor->rank);
|
944
|
-
sprintf(buf, "%sDimension: %d\n", buf, (int) t->tensor->dimension);
|
945
|
-
sprintf(buf, "%sSize: %d\n", buf, (int) t->tensor->size);
|
946
|
-
return rb_str_new2(buf);
|
947
|
-
}
|
948
|
-
|
949
|
-
void FUNCTION(Init_tensor,init)(VALUE module)
|
950
|
-
{
|
951
|
-
#ifdef BASE_DOUBLE
|
952
|
-
cgsl_tensor = rb_define_class_under(module, "Tensor", cGSL_Object);
|
953
|
-
cgsl_tensor_int = rb_define_class_under(cgsl_tensor, "Int", cGSL_Object);
|
954
|
-
cgsl_tensor_view = rb_define_class_under(cgsl_tensor, "View", cgsl_tensor);
|
955
|
-
cgsl_tensor_int_view = rb_define_class_under(cgsl_tensor_int, "View",
|
956
|
-
cgsl_tensor_int);
|
957
|
-
/*
|
958
|
-
cgsl_index = rb_define_class_under(cgsl_tensor, "Index",
|
959
|
-
cgsl_permutation);*/
|
960
|
-
#endif
|
961
|
-
|
962
|
-
rb_define_singleton_method(GSL_TYPE(cgsl_tensor), "new",
|
963
|
-
FUNCTION(rb_tensor,new), -1);
|
964
|
-
rb_define_singleton_method(GSL_TYPE(cgsl_tensor), "[]",
|
965
|
-
FUNCTION(rb_tensor,new), -1);
|
966
|
-
rb_define_singleton_method(GSL_TYPE(cgsl_tensor), "alloc",
|
967
|
-
FUNCTION(rb_tensor,new), -1);
|
968
|
-
rb_define_singleton_method(GSL_TYPE(cgsl_tensor), "calloc",
|
969
|
-
FUNCTION(rb_tensor,calloc), 2);
|
970
|
-
rb_define_singleton_method(GSL_TYPE(cgsl_tensor), "copy",
|
971
|
-
FUNCTION(rb_tensor,copy_singleton), 1);
|
972
|
-
rb_define_singleton_method(GSL_TYPE(cgsl_tensor), "memcpy",
|
973
|
-
FUNCTION(rb_tensor,memcpy_singleton), 2);
|
974
|
-
rb_define_singleton_method(GSL_TYPE(cgsl_tensor), "swap",
|
975
|
-
FUNCTION(rb_tensor,swap_singleton), 2);
|
976
|
-
|
977
|
-
/*****/
|
978
|
-
|
979
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "copy",
|
980
|
-
FUNCTION(rb_tensor,copy), 0);
|
981
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "clone", "copy");
|
982
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "duplicate", "copy");
|
983
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "set_zero",
|
984
|
-
FUNCTION(rb_tensor,set_zero), 0);
|
985
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "set_all",
|
986
|
-
FUNCTION(rb_tensor,set_all), 1);
|
987
|
-
|
988
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "position",
|
989
|
-
FUNCTION(rb_tensor,position), -1);
|
990
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "get",
|
991
|
-
FUNCTION(rb_tensor,get), -1);
|
992
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "[]", "get");
|
993
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "set",
|
994
|
-
FUNCTION(rb_tensor,set), -1);
|
995
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "[]=", "set");
|
996
|
-
|
997
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "fread",
|
998
|
-
FUNCTION(rb_tensor,fread), 1);
|
999
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "fwrite",
|
1000
|
-
FUNCTION(rb_tensor,fwrite), 1);
|
1001
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "fprintf",
|
1002
|
-
FUNCTION(rb_tensor,fprintf), -1);
|
1003
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "printf",
|
1004
|
-
FUNCTION(rb_tensor,printf), -1);
|
1005
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "fscanf",
|
1006
|
-
FUNCTION(rb_tensor,fscanf), 1);
|
1007
|
-
|
1008
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "swap_indices",
|
1009
|
-
FUNCTION(rb_tensor,swap_indices), 2);
|
1010
|
-
|
1011
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "max",
|
1012
|
-
FUNCTION(rb_tensor,max), 0);
|
1013
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "min",
|
1014
|
-
FUNCTION(rb_tensor,min), 0);
|
1015
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "minmax",
|
1016
|
-
FUNCTION(rb_tensor,minmax), 0);
|
1017
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "max_index",
|
1018
|
-
FUNCTION(rb_tensor,max_index), 0);
|
1019
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "min_index",
|
1020
|
-
FUNCTION(rb_tensor,min_index), 0);
|
1021
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "minmax_index",
|
1022
|
-
FUNCTION(rb_tensor,minmax_index), 0);
|
1023
|
-
|
1024
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "isnull",
|
1025
|
-
FUNCTION(rb_tensor,isnull), 0);
|
1026
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "isnull?",
|
1027
|
-
FUNCTION(rb_tensor,isnull2), 0);
|
1028
|
-
|
1029
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "add",
|
1030
|
-
FUNCTION(rb_tensor,add), 1);
|
1031
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "sub",
|
1032
|
-
FUNCTION(rb_tensor,sub), 1);
|
1033
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "mul_elements",
|
1034
|
-
FUNCTION(rb_tensor,mul_elements), 1);
|
1035
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "div_elements",
|
1036
|
-
FUNCTION(rb_tensor,div_elements), 1);
|
1037
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "add_constant",
|
1038
|
-
FUNCTION(rb_tensor,add_constant), 1);
|
1039
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "add_diagonal",
|
1040
|
-
FUNCTION(rb_tensor,add_diagonal), 1);
|
1041
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "scale",
|
1042
|
-
FUNCTION(rb_tensor,scale), 1);
|
1043
|
-
rb_define_singleton_method(GSL_TYPE(cgsl_tensor), "product",
|
1044
|
-
FUNCTION(rb_tensor,product_singleton), 2);
|
1045
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "product",
|
1046
|
-
FUNCTION(rb_tensor,product), 1);
|
1047
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "contract",
|
1048
|
-
FUNCTION(rb_tensor,contract), 2);
|
1049
|
-
|
1050
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "+", "add");
|
1051
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "-", "sub");
|
1052
|
-
/* rb_define_alias(GSL_TYPE(cgsl_tensor), "*", "mul_elements");*/
|
1053
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "/", "div_elements");
|
1054
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "*", "product");
|
1055
|
-
|
1056
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "add!",
|
1057
|
-
FUNCTION(rb_tensor,add_bang), 1);
|
1058
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "sub!",
|
1059
|
-
FUNCTION(rb_tensor,sub_bang), 1);
|
1060
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "mul_elements!",
|
1061
|
-
FUNCTION(rb_tensor,mul_elements_bang), 1);
|
1062
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "div_elements!",
|
1063
|
-
FUNCTION(rb_tensor,div_elements_bang), 1);
|
1064
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "add_constant!",
|
1065
|
-
FUNCTION(rb_tensor,add_constant_bang), 1);
|
1066
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "add_diagonal!",
|
1067
|
-
FUNCTION(rb_tensor,add_diagonal_bang), 1);
|
1068
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "scale!",
|
1069
|
-
FUNCTION(rb_tensor,scale_bang), 1);
|
1070
|
-
|
1071
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "+@",
|
1072
|
-
FUNCTION(rb_tensor,uplus), 0);
|
1073
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "-@",
|
1074
|
-
FUNCTION(rb_tensor,uminus), 0);
|
1075
|
-
|
1076
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "size",
|
1077
|
-
FUNCTION(rb_tensor,size), 0);
|
1078
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "rank",
|
1079
|
-
FUNCTION(rb_tensor,rank), 0);
|
1080
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "dimension",
|
1081
|
-
FUNCTION(rb_tensor,dimension), 0);
|
1082
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "dim", "dimension");
|
1083
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "data",
|
1084
|
-
FUNCTION(rb_tensor,data), 0);
|
1085
|
-
|
1086
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "to_v",
|
1087
|
-
FUNCTION(rb_tensor,to_v), 0);
|
1088
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "to_gv", "to_v");
|
1089
|
-
|
1090
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "to_vector",
|
1091
|
-
FUNCTION(rb_tensor,2vector), 0);
|
1092
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "to_matrix",
|
1093
|
-
FUNCTION(rb_tensor,2matrix), 0);
|
1094
|
-
|
1095
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "subtensor",
|
1096
|
-
FUNCTION(rb_tensor,subtensor), -1);
|
1097
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "view", "subtensor");
|
1098
|
-
|
1099
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "to_s",
|
1100
|
-
FUNCTION(rb_tensor,to_s), 0);
|
1101
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "inspect",
|
1102
|
-
FUNCTION(rb_tensor,inspect), 0);
|
1103
|
-
|
1104
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "equal?",
|
1105
|
-
FUNCTION(rb_tensor,equal), -1);
|
1106
|
-
rb_define_alias(GSL_TYPE(cgsl_tensor), "==", "equal?");
|
1107
|
-
|
1108
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "coerce",
|
1109
|
-
FUNCTION(rb_tensor,coerce), 1);
|
1110
|
-
|
1111
|
-
rb_define_method(GSL_TYPE(cgsl_tensor), "info",
|
1112
|
-
FUNCTION(rb_tensor,info), 0);
|
1113
|
-
}
|
1114
|
-
|
1115
|
-
#undef NUMCONV
|
1116
|
-
#undef C_TO_VALUE
|
1117
|
-
#undef CHECK_TEN
|
1118
|
-
#undef TEN_P
|
1119
|
-
#undef VEC_P
|
1120
|
-
#undef MAT_P
|
1121
|
-
|
1122
|
-
#endif
|