bigdecimal-math_r 0.2.0
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 +7 -0
- data/.ruby-version +1 -0
- data/CODE_OF_CONDUCT.md +132 -0
- data/LICENSE +21 -0
- data/LICENSE.txt +21 -0
- data/README.md +41 -0
- data/Rakefile +13 -0
- data/changelog.md +24 -0
- data/ext/bigdecimal/math_r/algofunc.h +203 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/check_precise.h +12 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/infinity.h +6 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/minus_infinity.h +5 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/minus_one.h +6 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/minus_zero.h +6 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/nan.h +6 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/one.h +6 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/sign.h +10 -0
- data/ext/bigdecimal/math_r/api/bigdecimal/zero.h +6 -0
- data/ext/bigdecimal/math_r/api/bigmath/api_call1.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/api_call2.h +6 -0
- data/ext/bigdecimal/math_r/api/bigmath/atan.h +7 -0
- data/ext/bigdecimal/math_r/api/bigmath/atan_adopt.h +42 -0
- data/ext/bigdecimal/math_r/api/bigmath/cabs.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/carg.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/cexp.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/clog.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/const.h +39 -0
- data/ext/bigdecimal/math_r/api/bigmath/const_e.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/const_log10.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/const_log2.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/const_log_pi.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/const_pi.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/const_sqrt2.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/const_sqrt3.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/cpow.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/csqrt.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/degree_sparg.h +199 -0
- data/ext/bigdecimal/math_r/api/bigmath/escalb.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/exp.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/expxt.h +18 -0
- data/ext/bigdecimal/math_r/api/bigmath/hypot.h +10 -0
- data/ext/bigdecimal/math_r/api/bigmath/ipow.h +14 -0
- data/ext/bigdecimal/math_r/api/bigmath/l2norm.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/log.h +7 -0
- data/ext/bigdecimal/math_r/api/bigmath/pow.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/quadrant.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/sincos.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/sqrt.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/to_rad.h +41 -0
- data/ext/bigdecimal/math_r/api/kernel/rb_BigDecimal.h +6 -0
- data/ext/bigdecimal/math_r/api/kernel/rb_BigDecimal1.h +6 -0
- data/ext/bigdecimal/math_r/api/kernel/rb_BigDecimal_flo.h +9 -0
- data/ext/bigdecimal/math_r/api/kernel/rb_ImaginaryZ.h +8 -0
- data/ext/bigdecimal/math_r/api/numanalysis/condition_p.h +26 -0
- data/ext/bigdecimal/math_r/api/numanalysis/make_n.h +9 -0
- data/ext/bigdecimal/math_r/api/numeric/abs.h +7 -0
- data/ext/bigdecimal/math_r/api/numeric/canonicalize.h +140 -0
- data/ext/bigdecimal/math_r/api/numeric/cmpeql.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/equal_p.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/finite_p.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/imag.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/infinite_p.h +7 -0
- data/ext/bigdecimal/math_r/api/numeric/nan_p.h +5 -0
- data/ext/bigdecimal/math_r/api/numeric/negative_p.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/nonzero_p.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/notequal_p.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/numeric_p.h +5 -0
- data/ext/bigdecimal/math_r/api/numeric/positive_p.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/real.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/real_p.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/round.h +56 -0
- data/ext/bigdecimal/math_r/api/numeric/uminus.h +6 -0
- data/ext/bigdecimal/math_r/api/numeric/zero_p.h +6 -0
- data/ext/bigdecimal/math_r/api.c +13 -0
- data/ext/bigdecimal/math_r/api.h +69 -0
- data/ext/bigdecimal/math_r/const.c +186 -0
- data/ext/bigdecimal/math_r/decl.h +203 -0
- data/ext/bigdecimal/math_r/edf.c +180 -0
- data/ext/bigdecimal/math_r/erf.c +80 -0
- data/ext/bigdecimal/math_r/euler_f.c +572 -0
- data/ext/bigdecimal/math_r/exp.c +72 -0
- data/ext/bigdecimal/math_r/extconf.rb +185 -0
- data/ext/bigdecimal/math_r/gamma_r.c +251 -0
- data/ext/bigdecimal/math_r/hyperb.c +172 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/E/ser.h +22 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG10/ser.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG2/BBP2002.h +36 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG_PI/builtin.h +7 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/PI/machin.h +48 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/SQRT2/builtin.h +5 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/SQRT3/builtin.h +5 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/branch.h +25 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/edom.h +15 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/logrep.h +19 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/ser.h +34 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/branch.h +19 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/edom.h +17 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/logrep.h +14 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acot/branch.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acot/logrep.h +13 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/branch.h +20 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/edom.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/logrep.h +33 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/branch.h +21 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/edom.h +20 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/logrep.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsch/branch.h +25 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsch/logrep.h +25 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/branch.h +22 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/edom.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/logrep.h +21 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/branch.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/edom.h +19 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/logrep.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/branch.h +22 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/edom.h +20 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/logrep.h +15 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/ser.h +32 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/branch.h +26 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/logrep.h +24 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/ser.h +48 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/branch.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/logrep.h +14 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/ser_euler.h +84 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/ser_usual.h +41 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/branch.h +24 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/edom.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/logrep.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/ser.h +33 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cabs/formula.h +8 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacos/branch.h +38 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacos/logrep.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacosh/branch.h +34 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacosh/logrep.h +17 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacot/branch.h +39 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacot/logrep.h +17 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacoth/branch.h +29 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacoth/logrep.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsc/branch.h +28 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsc/logrep.h +19 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsch/branch.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsch/logrep.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/carg/formula.h +8 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casec/branch.h +29 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casec/logrep.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casech/branch.h +38 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casech/logrep.h +9 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casin/branch.h +35 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casin/logrep.h +14 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casinh/branch.h +59 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casinh/logrep.h +13 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/catan/branch.h +46 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/catan/logrep.h +17 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/catanh/branch.h +26 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/catanh/logrep.h +10 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccbrt/formula.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccos/branch.h +41 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccos/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccosh/branch.h +37 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccosh/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccot/branch.h +46 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccot/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccoth/branch.h +43 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccoth/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsc/branch.h +42 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsc/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsch/branch.h +38 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsch/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp/branch.h +42 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp/eulerf.h +21 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp2/branch.h +42 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp2/eulerf.h +12 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog/branch.h +54 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog/formula.h +13 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog10/formula.h +12 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog1p/branch.h +34 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog2/formula.h +12 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/branch.h +21 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/ser.h +12 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/branch.h +22 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/formula.h +30 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/ser.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/branch.h +28 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/ser.h +12 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/branch.h +23 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/formula.h +30 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/ser.h +13 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cpow/formula.h +20 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/branch.h +28 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/ser.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/branch.h +23 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/formula.h +31 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/ser.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csec/branch.h +42 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csec/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csech/branch.h +38 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csech/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csin/branch.h +44 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csin/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csinh/branch.h +41 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csinh/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csqrt/formula.h +66 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ctan/branch.h +46 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ctan/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ctanh/branch.h +43 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ctanh/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cuberoot/newton.h +42 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/algo911.h +41 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/branch.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/cf.h +51 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/ser_inf.h +53 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/ser_zero.h +45 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/algo911.h +27 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/branch.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/cf.h +49 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/escalb/edf.h +87 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/branch.h +29 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/builtin.h +6 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/edf.h +23 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/exp2/branch.h +29 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/exp2/edf.h +19 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/expxt/edf.h +31 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/f_euler/formula.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/branch.h +25 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/l2norm.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/mmm.h +38 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ipow/edf.h +33 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/l2norm/formula.h +48 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/branch.h +40 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/builtin.h +12 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/edf.h +10 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/edom.h +10 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/mercator.h +34 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/ser_okumura.h +57 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/branch.h +40 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/edf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/mercator.h +35 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/branch.h +34 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/p_adic.h +37 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/ser_mercator.h +35 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/branch.h +40 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/edf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/mercator.h +35 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/logxt/edf.h +33 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/pow/formula.h +30 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/quadrant/formula.h +352 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/rcm10/edf.h +34 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/rcm2/edf.h +34 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/branch.h +27 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/ser.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/branch.h +21 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/formula.h +25 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/ser.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/branch.h +23 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/ser.h +13 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sincos/ser.h +50 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/branch.h +23 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/formula.h +26 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/ser.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinhcosh/ser.h +70 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/branch.h +16 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/builtin.h +12 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/edom.h +9 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/newton.h +36 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/branch.h +26 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/ser.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/branch.h +23 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/eulerf.h +11 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/formula.h +27 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/ser.h +14 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/trig/f_euler.h +290 -0
- data/ext/bigdecimal/math_r/log.c +256 -0
- data/ext/bigdecimal/math_r/logrep.c +537 -0
- data/ext/bigdecimal/math_r/math_r/bigdecimal.h +30 -0
- data/ext/bigdecimal/math_r/math_r/bigmath.h +61 -0
- data/ext/bigdecimal/math_r/math_r/bigmath_r.h +9 -0
- data/ext/bigdecimal/math_r/math_r/ext_extern.h +18 -0
- data/ext/bigdecimal/math_r/math_r/globals.h +71 -0
- data/ext/bigdecimal/math_r/math_r/numdiff.h +18 -0
- data/ext/bigdecimal/math_r/math_r/numeric.h +63 -0
- data/ext/bigdecimal/math_r/math_r.c +130 -0
- data/ext/bigdecimal/math_r/nucomp.c +158 -0
- data/ext/bigdecimal/math_r/overrides.c +91 -0
- data/ext/bigdecimal/math_r/power.c +207 -0
- data/ext/bigdecimal/math_r/solver.c +1516 -0
- data/ext/bigdecimal/math_r/trig.c +205 -0
- data/lib/bigdecimal/math_r/const/EulerGamma_engel.rb +46 -0
- data/lib/bigdecimal/math_r/const/LOG2_bbp2007.rb +39 -0
- data/lib/bigdecimal/math_r/const/PI_chudnovsky.rb +59 -0
- data/lib/bigdecimal/math_r/const/PI_euler.rb +40 -0
- data/lib/bigdecimal/math_r/const/PI_ramanujan1.rb +45 -0
- data/lib/bigdecimal/math_r/const/PI_ramanujan2.rb +46 -0
- data/lib/bigdecimal/math_r/const/b053977/b053977.txt +306 -0
- data/lib/bigdecimal/math_r/version.rb +7 -0
- data/lib/bigdecimal/math_r.rb +12 -0
- data/lib/bigdecimal/math_r.so +0 -0
- data/sig/bigdecimal/math_r.rbs +6 -0
- metadata +393 -0
@@ -0,0 +1,87 @@
|
|
1
|
+
void
|
2
|
+
escalb_edf(VALUE a, VALUE x, VALUE prec, VALUE *exp, VALUE *fra)
|
3
|
+
{
|
4
|
+
const ID fix = rb_intern("fix");
|
5
|
+
const ID frac = rb_intern("frac");
|
6
|
+
const ID floor = rb_intern("floor");
|
7
|
+
const ID pred = rb_intern("pred");
|
8
|
+
const ID MAX_10_EXP = rb_intern("MAX_10_EXP");
|
9
|
+
VALUE max_10_exp = rb_const_get_at(rb_cFloat, MAX_10_EXP);
|
10
|
+
|
11
|
+
if (!rb_num_finite_p(a) && !rb_num_positive_p(a))
|
12
|
+
rb_raise(rb_eRangeError, "parameter a must be positive finite");
|
13
|
+
switch (TYPE(x)) {
|
14
|
+
case T_FIXNUM:
|
15
|
+
case T_BIGNUM:
|
16
|
+
*exp = x; *fra = BIG_ZERO;
|
17
|
+
break;
|
18
|
+
case T_FLOAT:
|
19
|
+
if (isinf(NUM2DBL(x)) || isnan(NUM2DBL(x)))
|
20
|
+
{
|
21
|
+
*exp = rb_BigDecimal_flo(x); *fra = BIG_ZERO;
|
22
|
+
}
|
23
|
+
else
|
24
|
+
{
|
25
|
+
*exp = rb_funcall(x, floor, 0);
|
26
|
+
*fra = rb_BigDecimal_flo(rb_funcall1(x, '%', INT2FIX(1)));
|
27
|
+
}
|
28
|
+
break;
|
29
|
+
case T_RATIONAL:
|
30
|
+
*exp = rb_funcall(x, floor, 0);
|
31
|
+
*fra = rb_BigDecimal(rb_funcall1(x, '%', INT2FIX(1)), prec);
|
32
|
+
break;
|
33
|
+
case T_COMPLEX:
|
34
|
+
rb_raise(rb_eTypeError, "no solution for Complex");
|
35
|
+
break;
|
36
|
+
default:
|
37
|
+
if (rb_class_superclass(CLASS_OF(x)) == rb_cNumeric)
|
38
|
+
{
|
39
|
+
if (CLASS_OF(x) == rb_cBigDecimal)
|
40
|
+
{
|
41
|
+
if (!rb_num_finite_p(x))
|
42
|
+
{
|
43
|
+
*exp = x; *fra = BIG_ZERO;
|
44
|
+
}
|
45
|
+
else
|
46
|
+
{
|
47
|
+
*exp = rb_Integer(rb_funcall(x, fix, 0));
|
48
|
+
if (rb_num_negative_p(x) &&
|
49
|
+
rb_num_notequal_p(*exp, x))
|
50
|
+
*exp = rb_funcall(*exp, pred, 0);
|
51
|
+
if (rb_num_notequal_p(*exp, x))
|
52
|
+
{
|
53
|
+
*fra = rb_funcall(x, frac, 0);
|
54
|
+
if (rb_num_negative_p(*fra))
|
55
|
+
*fra = rb_funcall1(BIG_ONE, '+', *fra);
|
56
|
+
}
|
57
|
+
else
|
58
|
+
*fra = BIG_ZERO;
|
59
|
+
}
|
60
|
+
}
|
61
|
+
else
|
62
|
+
rb_raise(rb_eTypeError, "unknown numeric type");
|
63
|
+
}
|
64
|
+
rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
|
65
|
+
break;
|
66
|
+
}
|
67
|
+
if (!rb_num_finite_p(x))
|
68
|
+
{
|
69
|
+
switch (rb_num_infinite_p(x)) {
|
70
|
+
case 1:
|
71
|
+
*exp = x;
|
72
|
+
break;
|
73
|
+
case -1:
|
74
|
+
*exp = BIG_ZERO;
|
75
|
+
break;
|
76
|
+
default:
|
77
|
+
*exp = BIG_NAN;
|
78
|
+
break;
|
79
|
+
}
|
80
|
+
*fra = BIG_ZERO;
|
81
|
+
return;
|
82
|
+
}
|
83
|
+
*exp = rb_bigmath_ipow(a, *exp,
|
84
|
+
NUM2INT(rb_num_cmpeql(prec, max_10_exp)) == 1 ? prec : max_10_exp);
|
85
|
+
*exp = rb_num_round(*exp,
|
86
|
+
NUM2INT(rb_num_cmpeql(prec, max_10_exp)) == 1 ? prec : max_10_exp);
|
87
|
+
}
|
@@ -0,0 +1,29 @@
|
|
1
|
+
VALUE
|
2
|
+
exp_branch(VALUE x, VALUE prec, bigmath_func1 exp_cb)
|
3
|
+
{
|
4
|
+
const ID mult = rb_intern("mult");
|
5
|
+
VALUE w = Qundef;
|
6
|
+
|
7
|
+
x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
|
8
|
+
|
9
|
+
if (rb_num_nan_p(x))
|
10
|
+
w = BIG_NAN;
|
11
|
+
else
|
12
|
+
{
|
13
|
+
VALUE exp = Qundef, fra = Qundef;
|
14
|
+
rb_bigmath_escalb(
|
15
|
+
rb_bigmath_const_e(prec), x, prec, &exp, &fra);
|
16
|
+
if (exp == Qundef || fra == Qundef)
|
17
|
+
rb_raise(rb_eRuntimeError, "no solution");
|
18
|
+
else if (rb_num_infinite_p(exp) || rb_num_zero_p(exp) || rb_num_zero_p(fra))
|
19
|
+
w = rb_num_round(exp, prec);
|
20
|
+
else
|
21
|
+
{
|
22
|
+
fra = exp_cb(fra, prec);
|
23
|
+
if (CLASS_OF(exp) != rb_cBigDecimal)
|
24
|
+
exp = rb_num_canonicalize(exp, prec, ARG_REAL, ARG_RAWVALUE);
|
25
|
+
w = rb_funcall(exp, mult, 2, fra, prec);
|
26
|
+
}
|
27
|
+
}
|
28
|
+
return w;
|
29
|
+
}
|
@@ -0,0 +1,23 @@
|
|
1
|
+
VALUE
|
2
|
+
exp_edf(VALUE x, VALUE prec)
|
3
|
+
{
|
4
|
+
const ID mult = rb_intern("mult");
|
5
|
+
VALUE exp = Qundef, fra = Qundef;
|
6
|
+
|
7
|
+
rb_check_precise(prec);
|
8
|
+
|
9
|
+
if (rb_num_notequal_p(x, x))
|
10
|
+
return BIG_NAN;
|
11
|
+
rb_bigmath_escalb(rb_bigmath_const_e(prec), x, prec, &exp, &fra);
|
12
|
+
if (exp == Qundef || fra == Qundef)
|
13
|
+
rb_raise(rb_eRuntimeError, "no solution");
|
14
|
+
if (rb_num_infinite_p(exp) ||
|
15
|
+
rb_num_zero_p(exp) ||
|
16
|
+
rb_num_zero_p(fra))
|
17
|
+
return rb_num_round(exp, prec);
|
18
|
+
fra = rb_bigmath_expxt(fra, BIG_ONE, prec);
|
19
|
+
if (CLASS_OF(exp) != rb_cBigDecimal)
|
20
|
+
exp = rb_num_canonicalize(exp, prec, ARG_REAL, ARG_RAWVALUE);
|
21
|
+
|
22
|
+
return rb_funcall(exp, mult, 2, fra, prec);
|
23
|
+
}
|
@@ -0,0 +1,29 @@
|
|
1
|
+
VALUE
|
2
|
+
exp2_branch(VALUE x, VALUE prec, bigmath_func1 exp2_cb)
|
3
|
+
{
|
4
|
+
const ID mult = rb_intern("mult");
|
5
|
+
VALUE w = Qundef;
|
6
|
+
|
7
|
+
x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
|
8
|
+
|
9
|
+
if (rb_num_nan_p(x))
|
10
|
+
w = BIG_NAN;
|
11
|
+
else
|
12
|
+
{
|
13
|
+
VALUE exp = Qundef, fra = Qundef;
|
14
|
+
rb_bigmath_escalb(
|
15
|
+
rb_BigDecimal1(INT2FIX(2)), x, prec, &exp, &fra);
|
16
|
+
if (exp == Qundef || fra == Qundef)
|
17
|
+
rb_raise(rb_eRuntimeError, "no solution");
|
18
|
+
else if (rb_num_infinite_p(exp) || rb_num_zero_p(exp) || rb_num_zero_p(fra))
|
19
|
+
w = rb_num_round(exp, prec);
|
20
|
+
else
|
21
|
+
{
|
22
|
+
fra = exp2_cb(fra, prec);
|
23
|
+
if (CLASS_OF(exp) != rb_cBigDecimal)
|
24
|
+
exp = rb_num_canonicalize(exp, prec, ARG_REAL, ARG_RAWVALUE);
|
25
|
+
w = rb_funcall(exp, mult, 2, fra, prec);
|
26
|
+
}
|
27
|
+
}
|
28
|
+
return w;
|
29
|
+
}
|
@@ -0,0 +1,19 @@
|
|
1
|
+
VALUE
|
2
|
+
exp2_edf(VALUE x, VALUE prec)
|
3
|
+
{
|
4
|
+
const ID mult = rb_intern("mult");
|
5
|
+
VALUE exp = Qundef, fra = Qundef;
|
6
|
+
if (rb_num_notequal_p(x, x))
|
7
|
+
return BIG_NAN;
|
8
|
+
rb_bigmath_escalb(INT2FIX(2), x, prec, &exp, &fra);
|
9
|
+
if (exp == Qundef || fra == Qundef)
|
10
|
+
rb_raise(rb_eRuntimeError, "no solution");
|
11
|
+
if (rb_num_infinite_p(exp) ||
|
12
|
+
rb_num_zero_p(exp) ||
|
13
|
+
rb_num_zero_p(fra))
|
14
|
+
return rb_num_round(exp, prec);
|
15
|
+
fra = rb_bigmath_expxt(fra, rb_bigmath_const_log2(prec), prec);
|
16
|
+
if (CLASS_OF(exp) != rb_cBigDecimal)
|
17
|
+
exp = rb_num_canonicalize(exp, prec, ARG_REAL, ARG_RAWVALUE);
|
18
|
+
return rb_funcall(exp, mult, 2, fra, prec);
|
19
|
+
}
|
@@ -0,0 +1,31 @@
|
|
1
|
+
VALUE
|
2
|
+
expxt_edf(VALUE x, VALUE t, VALUE prec)
|
3
|
+
{
|
4
|
+
const ID mult = rb_intern("mult");
|
5
|
+
const ID div = rb_intern("div");
|
6
|
+
VALUE n, m, a, xt, e;
|
7
|
+
long i = 0;
|
8
|
+
|
9
|
+
rb_check_precise(prec);
|
10
|
+
|
11
|
+
n = rb_numdiff_make_n(prec), m;
|
12
|
+
a = BIG_ONE;
|
13
|
+
xt = rb_funcall1(x, '*', t);
|
14
|
+
e = BIG_ZERO;
|
15
|
+
|
16
|
+
if (rb_num_zero_p(xt))
|
17
|
+
return e;
|
18
|
+
|
19
|
+
while (rb_numdiff_condition_p(e, a, n, &m))
|
20
|
+
{
|
21
|
+
e = rb_funcall1(e, '+', a);
|
22
|
+
a = rb_funcall(a, div, 2, LONG2NUM(++i), m);
|
23
|
+
a = rb_funcall(a, mult, 2, xt, m);
|
24
|
+
}
|
25
|
+
|
26
|
+
RB_GC_GUARD(a);
|
27
|
+
RB_GC_GUARD(xt);
|
28
|
+
RB_GC_GUARD(e);
|
29
|
+
|
30
|
+
return rb_num_round(e, prec);
|
31
|
+
}
|
@@ -0,0 +1,25 @@
|
|
1
|
+
VALUE
|
2
|
+
hypot_branch(VALUE a, VALUE b, VALUE prec, bigmath_func2 hypot_cb)
|
3
|
+
{
|
4
|
+
VALUE c = Qundef;
|
5
|
+
|
6
|
+
a = rb_num_real_p(a) ?
|
7
|
+
rb_num_canonicalize(a, prec, ARG_REAL, ARG_RAWVALUE) :
|
8
|
+
rb_num_canonicalize(a, prec, ARG_COMPLEX, ARG_RAWVALUE);
|
9
|
+
b = rb_num_real_p(b) ?
|
10
|
+
rb_num_canonicalize(b, prec, ARG_REAL, ARG_RAWVALUE) :
|
11
|
+
rb_num_canonicalize(b, prec, ARG_COMPLEX, ARG_RAWVALUE);
|
12
|
+
|
13
|
+
if (!rb_num_finite_p(a) || !rb_num_finite_p(b))
|
14
|
+
{
|
15
|
+
if (rb_num_nan_p(a) || rb_num_nan_p(b))
|
16
|
+
c = BIG_NAN;
|
17
|
+
else if (rb_num_infinite_p(a) || rb_num_infinite_p(b))
|
18
|
+
c = BIG_INF;
|
19
|
+
}
|
20
|
+
if (c == Qundef)
|
21
|
+
c = hypot_cb(a, b, prec);
|
22
|
+
|
23
|
+
return c;
|
24
|
+
}
|
25
|
+
|
@@ -0,0 +1,38 @@
|
|
1
|
+
// Reference: C-gengo no yoru hyoujun algorithm jiten - Haruhiko Okumura
|
2
|
+
VALUE
|
3
|
+
hypot_mmm(VALUE a, VALUE b, VALUE prec)
|
4
|
+
{
|
5
|
+
const ID div = rb_intern("div");
|
6
|
+
VALUE n, m, two, four, t;
|
7
|
+
|
8
|
+
rb_check_precise(prec);
|
9
|
+
|
10
|
+
n = rb_numdiff_make_n(prec);
|
11
|
+
m = Qundef;
|
12
|
+
two = rb_BigDecimal1(INT2FIX(2));
|
13
|
+
four = rb_BigDecimal1(INT2FIX(4));
|
14
|
+
t = BIG_ONE;
|
15
|
+
|
16
|
+
if (rb_num_negative_p(a)) a = rb_num_uminus(a);
|
17
|
+
if (rb_num_negative_p(b)) b = rb_num_uminus(b);
|
18
|
+
if (rb_num_coerce_cmp(a, b, '<'))
|
19
|
+
{
|
20
|
+
t = a; a = b; b = t;
|
21
|
+
}
|
22
|
+
if (rb_num_zero_p(b)) return a;
|
23
|
+
while (rb_numdiff_condition_p(a, t, n, &m))
|
24
|
+
{
|
25
|
+
t = rb_funcall1(b, '/', a);
|
26
|
+
t = rb_funcall1(t, '*', t);
|
27
|
+
t = rb_funcall(t, div, 2, rb_funcall1(four, '+', t), m);
|
28
|
+
a = rb_funcall1(a, '+',
|
29
|
+
rb_funcall1(rb_funcall1(two, '*', a), '*', t));
|
30
|
+
b = rb_funcall1(b, '*', t);
|
31
|
+
}
|
32
|
+
|
33
|
+
RB_GC_GUARD(two);
|
34
|
+
RB_GC_GUARD(four);
|
35
|
+
RB_GC_GUARD(t);
|
36
|
+
|
37
|
+
return rb_num_round(a, prec);
|
38
|
+
}
|
@@ -0,0 +1,33 @@
|
|
1
|
+
VALUE
|
2
|
+
ipow_edf(VALUE x, VALUE n, VALUE exp)
|
3
|
+
{
|
4
|
+
const ID mult = rb_intern("mult");
|
5
|
+
const ID exponent = rb_intern("exponent");
|
6
|
+
const ID r_shift = rb_intern(">>");
|
7
|
+
const ID geq = rb_intern(">=");
|
8
|
+
VALUE abs_n = Qundef, r = Qundef;
|
9
|
+
|
10
|
+
if (!rb_num_finite_p(x))
|
11
|
+
return BIG_NAN;
|
12
|
+
x = rb_num_canonicalize(x, exp, ARG_REAL, ARG_RAWVALUE);
|
13
|
+
abs_n = n;
|
14
|
+
if (rb_num_negative_p(n)) abs_n = rb_num_uminus(abs_n); // abs()
|
15
|
+
r = BIG_ONE;
|
16
|
+
while (rb_num_nonzero_p(abs_n))
|
17
|
+
{
|
18
|
+
if (RTEST(NUM2INT(rb_num_coerce_bit(abs_n, INT2FIX(1), '&'))))
|
19
|
+
{
|
20
|
+
r = rb_funcall(r, mult, 2, x, exp);
|
21
|
+
if (RTEST(rb_num_coerce_cmp(rb_funcall(
|
22
|
+
r, exponent, 0), exp, '>')))
|
23
|
+
r = BIG_INF;
|
24
|
+
}
|
25
|
+
if (rb_num_infinite_p(r))
|
26
|
+
break;
|
27
|
+
x = rb_funcall(x, mult, 2, x, exp);
|
28
|
+
abs_n = rb_num_coerce_bit(abs_n, INT2FIX(1), r_shift);
|
29
|
+
}
|
30
|
+
|
31
|
+
return RTEST(rb_num_coerce_cmp(n, INT2FIX(0), geq)) ?
|
32
|
+
r : rb_funcall1(INT2FIX(1), '/', r);
|
33
|
+
}
|
@@ -0,0 +1,48 @@
|
|
1
|
+
|
2
|
+
static VALUE
|
3
|
+
l2norm_iter(RB_BLOCK_CALL_FUNC_ARGLIST(y, c))
|
4
|
+
{
|
5
|
+
const ID abs2 = rb_intern("abs2");
|
6
|
+
return rb_funcall(y, abs2, 0);
|
7
|
+
}
|
8
|
+
|
9
|
+
static VALUE
|
10
|
+
l2norm_sum(VALUE self)
|
11
|
+
{
|
12
|
+
const ID sum = rb_intern("sum");
|
13
|
+
return rb_block_call(self, sum, 0, NULL, l2norm_iter, Qnil);
|
14
|
+
}
|
15
|
+
|
16
|
+
static VALUE
|
17
|
+
bigmath_l2norm(VALUE vec, VALUE prec)
|
18
|
+
{
|
19
|
+
VALUE sum;
|
20
|
+
if (CLASS_OF(vec) != rb_cArray)
|
21
|
+
rb_raise(rb_eTypeError, "vec must be an Array");
|
22
|
+
|
23
|
+
sum = l2norm_sum(vec);
|
24
|
+
|
25
|
+
switch (TYPE(sum)) {
|
26
|
+
case T_FIXNUM:
|
27
|
+
case T_BIGNUM:
|
28
|
+
sum = rb_BigDecimal1(sum);
|
29
|
+
break;
|
30
|
+
case T_FLOAT:
|
31
|
+
sum = rb_BigDecimal_flo(sum);
|
32
|
+
break;
|
33
|
+
case T_RATIONAL:
|
34
|
+
sum = rb_BigDecimal(sum, prec);
|
35
|
+
break;
|
36
|
+
default:
|
37
|
+
break;
|
38
|
+
}
|
39
|
+
return rb_bigmath_sqrt(sum, prec);
|
40
|
+
}
|
41
|
+
|
42
|
+
VALUE
|
43
|
+
l2norm_formula(VALUE vec, VALUE prec)
|
44
|
+
{
|
45
|
+
rb_check_precise(prec);
|
46
|
+
|
47
|
+
return bigmath_l2norm(vec, prec);
|
48
|
+
}
|
@@ -0,0 +1,40 @@
|
|
1
|
+
VALUE
|
2
|
+
log_branch(VALUE x, VALUE prec, bigmath_func1 log_cb)
|
3
|
+
{
|
4
|
+
VALUE y = Qundef;
|
5
|
+
|
6
|
+
x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
|
7
|
+
|
8
|
+
if (!rb_num_finite_p(x))
|
9
|
+
{
|
10
|
+
switch (rb_num_infinite_p(x)) {
|
11
|
+
case 1:
|
12
|
+
y = BIG_INF;
|
13
|
+
break;
|
14
|
+
case -1: case 0:
|
15
|
+
default:
|
16
|
+
y = BIG_NAN;
|
17
|
+
break;
|
18
|
+
}
|
19
|
+
}
|
20
|
+
else if (rb_num_zero_p(x))
|
21
|
+
{
|
22
|
+
y = BIG_MINUS_INF;
|
23
|
+
}
|
24
|
+
else
|
25
|
+
{
|
26
|
+
if (rb_num_positive_p(x))
|
27
|
+
{
|
28
|
+
const ID add = rb_intern("add");
|
29
|
+
VALUE exp, fra;
|
30
|
+
fra = rcm2_edf(x, &exp);
|
31
|
+
exp = rb_funcall1(rb_bigmath_const_log2(prec), '*', exp);
|
32
|
+
fra = log_cb(fra, prec);
|
33
|
+
y = rb_funcall(exp, add, 2, fra, prec);
|
34
|
+
}
|
35
|
+
else
|
36
|
+
y = BIG_NAN;
|
37
|
+
}
|
38
|
+
return y;
|
39
|
+
}
|
40
|
+
|
@@ -0,0 +1,10 @@
|
|
1
|
+
VALUE
|
2
|
+
log_edf(VALUE x, VALUE prec)
|
3
|
+
{
|
4
|
+
VALUE fra = Qundef, exp = Qundef, y = Qundef;
|
5
|
+
fra = rcm2_edf(x, &exp);
|
6
|
+
fra = logxt_edf(fra, INT2FIX(2), prec);
|
7
|
+
y = rb_funcall1(exp, '+', fra);
|
8
|
+
y = rb_funcall1(y, '*', rb_bigmath_const_log2(prec));
|
9
|
+
return rb_num_round(y, prec);
|
10
|
+
}
|
@@ -0,0 +1,10 @@
|
|
1
|
+
VALUE
|
2
|
+
log_edom(VALUE x, VALUE prec)
|
3
|
+
{
|
4
|
+
VALUE y, pi = rb_bigmath_const_pi(prec);
|
5
|
+
x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
|
6
|
+
RUBY_ASSERT (rb_num_negative_p(x));
|
7
|
+
x = rb_num_uminus(x);
|
8
|
+
y = rb_bigmath_log(x, prec);
|
9
|
+
return rb_Complex(y, pi);
|
10
|
+
}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
|
2
|
+
#if 0
|
3
|
+
static VALUE
|
4
|
+
log_ser_mercator_x(VALUE x, VALUE prec)
|
5
|
+
{
|
6
|
+
const ID div = rb_intern("div");
|
7
|
+
VALUE y;
|
8
|
+
x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
|
9
|
+
y = rb_funcall1(x, '-', INT2FIX(1));
|
10
|
+
y = rb_funcall(y, div, 2, x, prec);
|
11
|
+
y = rb_num_uminus(y);
|
12
|
+
return y;
|
13
|
+
}
|
14
|
+
#endif
|
15
|
+
|
16
|
+
VALUE
|
17
|
+
log_mercator(VALUE x, VALUE prec)
|
18
|
+
{
|
19
|
+
const ID div = rb_intern("div");
|
20
|
+
VALUE fra = Qundef, exp = Qundef, y = Qundef;
|
21
|
+
fra = rcm2_edf(x, &exp);
|
22
|
+
|
23
|
+
rb_check_precise(prec);
|
24
|
+
|
25
|
+
y = rb_funcall1(fra, '-', INT2FIX(1));
|
26
|
+
fra = rb_funcall(y, div, 2, fra, prec);
|
27
|
+
fra = rb_num_uminus(fra);
|
28
|
+
fra = log1p_ser_mercator(fra, prec);
|
29
|
+
fra = rb_num_uminus(fra);
|
30
|
+
|
31
|
+
exp = rb_funcall1(exp, '*', rb_bigmath_const_log2(prec));
|
32
|
+
y = rb_funcall1(exp, '+', fra);
|
33
|
+
return rb_num_round(y, prec);
|
34
|
+
}
|
@@ -0,0 +1,57 @@
|
|
1
|
+
VALUE
|
2
|
+
log_ser_okumura(VALUE x, VALUE prec)
|
3
|
+
{
|
4
|
+
const ID add = rb_intern("add");
|
5
|
+
const ID div = rb_intern("div");
|
6
|
+
const ID mult = rb_intern("mult");
|
7
|
+
const ID pow = rb_intern("**");
|
8
|
+
const ID succ = rb_intern("succ");
|
9
|
+
bool inv;
|
10
|
+
VALUE one = BIG_ONE;
|
11
|
+
VALUE two = rb_BigDecimal1(INT2FIX(2));
|
12
|
+
VALUE n = rb_numdiff_make_n(prec), m;
|
13
|
+
VALUE k, x2, i, s, d, y;
|
14
|
+
|
15
|
+
inv = RTEST(rb_num_coerce_cmp(x, INT2FIX(1), '>'));
|
16
|
+
if (inv)
|
17
|
+
x = rb_num_canonicalize(x, n, ARG_REAL, ARG_RECIPROCAL);
|
18
|
+
else
|
19
|
+
x = rb_num_canonicalize(x, n, ARG_REAL, ARG_RAWVALUE);
|
20
|
+
|
21
|
+
rcm2_edf(rb_funcall1(x, '/', rb_bigmath_const_sqrt2(n)), &k);
|
22
|
+
k = rb_funcall(k, succ, 0);
|
23
|
+
k = rb_BigDecimal1(k);
|
24
|
+
x = rb_funcall1(x, '/', rb_funcall1(two, pow, k));
|
25
|
+
x = rb_funcall(
|
26
|
+
rb_funcall1(x, '-', one), div, 2,
|
27
|
+
rb_funcall1(x, '+', one), n);
|
28
|
+
#if 0
|
29
|
+
x2 = rb_funcall1(x, '*', x);
|
30
|
+
#else
|
31
|
+
x2 = rb_funcall(x, mult, 2, x, n);
|
32
|
+
#endif
|
33
|
+
i = one;
|
34
|
+
s = x;
|
35
|
+
d = one;
|
36
|
+
while (rb_numdiff_condition_p(s, d, n, &m))
|
37
|
+
{
|
38
|
+
x = rb_funcall(x, mult, 2, x2, m);
|
39
|
+
i = rb_funcall1(i, '+', two);
|
40
|
+
d = rb_funcall(x, div, 2, i, m);
|
41
|
+
s = rb_funcall1(s, '+', d);
|
42
|
+
}
|
43
|
+
|
44
|
+
y = rb_funcall(
|
45
|
+
rb_funcall1(rb_bigmath_const_log2(n), '*', k),
|
46
|
+
add, 2, rb_funcall1(two, '*', s), prec);
|
47
|
+
|
48
|
+
RB_GC_GUARD(x);
|
49
|
+
RB_GC_GUARD(x2);
|
50
|
+
RB_GC_GUARD(i);
|
51
|
+
RB_GC_GUARD(s);
|
52
|
+
RB_GC_GUARD(d);
|
53
|
+
RB_GC_GUARD(one);
|
54
|
+
RB_GC_GUARD(two);
|
55
|
+
|
56
|
+
return inv ? rb_num_uminus(y) : y;
|
57
|
+
}
|
@@ -0,0 +1,40 @@
|
|
1
|
+
VALUE
|
2
|
+
log10_branch(VALUE x, VALUE prec, bigmath_func1 log10_cb)
|
3
|
+
{
|
4
|
+
VALUE y = Qundef;
|
5
|
+
|
6
|
+
x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
|
7
|
+
|
8
|
+
if (!rb_num_finite_p(x))
|
9
|
+
{
|
10
|
+
switch (rb_num_infinite_p(x)) {
|
11
|
+
case 1:
|
12
|
+
y = BIG_INF;
|
13
|
+
break;
|
14
|
+
case -1: case 0:
|
15
|
+
default:
|
16
|
+
y = BIG_NAN;
|
17
|
+
break;
|
18
|
+
}
|
19
|
+
}
|
20
|
+
else if (rb_num_zero_p(x))
|
21
|
+
{
|
22
|
+
y = BIG_MINUS_INF;
|
23
|
+
}
|
24
|
+
else
|
25
|
+
{
|
26
|
+
if (rb_num_positive_p(x))
|
27
|
+
{
|
28
|
+
const ID add = rb_intern("add");
|
29
|
+
VALUE exp, fra;
|
30
|
+
fra = rcm10_edf(x, &exp);
|
31
|
+
exp = rb_BigDecimal1(exp);
|
32
|
+
fra = log10_cb(fra, prec);
|
33
|
+
y = rb_funcall(exp, add, 2, fra, prec);
|
34
|
+
}
|
35
|
+
else
|
36
|
+
y = BIG_NAN;
|
37
|
+
}
|
38
|
+
return y;
|
39
|
+
}
|
40
|
+
|
@@ -0,0 +1,35 @@
|
|
1
|
+
|
2
|
+
#if 0
|
3
|
+
static VALUE
|
4
|
+
log_ser_mercator_x(VALUE x, VALUE prec)
|
5
|
+
{
|
6
|
+
const ID div = rb_intern("div");
|
7
|
+
VALUE y;
|
8
|
+
x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
|
9
|
+
y = rb_funcall1(x, '-', INT2FIX(1));
|
10
|
+
y = rb_funcall(y, div, 2, x, prec);
|
11
|
+
y = rb_num_uminus(y);
|
12
|
+
return y;
|
13
|
+
}
|
14
|
+
#endif
|
15
|
+
|
16
|
+
VALUE
|
17
|
+
log10_mercator(VALUE x, VALUE prec)
|
18
|
+
{
|
19
|
+
const ID div = rb_intern("div");
|
20
|
+
VALUE fra = Qundef, exp = Qundef, y = Qundef;
|
21
|
+
|
22
|
+
rb_check_precise(prec);
|
23
|
+
|
24
|
+
fra = rcm10_edf(x, &exp);
|
25
|
+
|
26
|
+
y = rb_funcall1(fra, '-', INT2FIX(1));
|
27
|
+
fra = rb_funcall(y, div, 2, fra, prec);
|
28
|
+
fra = rb_num_uminus(fra);
|
29
|
+
fra = log1p_ser_mercator(fra, prec);
|
30
|
+
fra = rb_num_uminus(fra);
|
31
|
+
fra = rb_funcall(fra, div, 2, rb_bigmath_const_log10(prec), prec);
|
32
|
+
|
33
|
+
y = rb_funcall1(exp, '+', fra);
|
34
|
+
return rb_num_round(y, prec);
|
35
|
+
}
|