bigdecimal-math_r 0.2.0 → 0.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (181) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +63 -10
  3. data/changelog.md +32 -0
  4. data/ext/bigdecimal/math_r/algofunc.h +11 -1
  5. data/ext/bigdecimal/math_r/api/bigmath/const_e.h +1 -1
  6. data/ext/bigdecimal/math_r/api/bigmath/const_euler_gamma.h +5 -0
  7. data/ext/bigdecimal/math_r/api/bigmath/csqrt.h +1 -1
  8. data/ext/bigdecimal/math_r/api/kernel/rb_BigDecimal_flo.h +8 -2
  9. data/ext/bigdecimal/math_r/api/numeric/domain_p.h +7 -0
  10. data/ext/bigdecimal/math_r/api/numeric/nan_p.h +4 -1
  11. data/ext/bigdecimal/math_r/api.h +2 -0
  12. data/ext/bigdecimal/math_r/const.c +42 -5
  13. data/ext/bigdecimal/math_r/decl.h +11 -1
  14. data/ext/bigdecimal/math_r/exp.c +45 -3
  15. data/ext/bigdecimal/math_r/extconf.rb +5 -1
  16. data/ext/bigdecimal/math_r/{gamma_r.c → gamma_beta.c} +11 -78
  17. data/ext/bigdecimal/math_r/internal/algo/bigmath/E/{ser.h → napier.h} +1 -1
  18. data/ext/bigdecimal/math_r/internal/algo/bigmath/EulerGamma/borwein_bailey.h +37 -0
  19. data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG10/ser.h +4 -2
  20. data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG_PI/builtin.h +3 -1
  21. data/ext/bigdecimal/math_r/internal/algo/bigmath/SQRT2/builtin.h +4 -1
  22. data/ext/bigdecimal/math_r/internal/algo/bigmath/SQRT3/builtin.h +4 -1
  23. data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/branch.h +11 -4
  24. data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/branch.h +2 -2
  25. data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/edom.h +7 -5
  26. data/ext/bigdecimal/math_r/internal/algo/bigmath/acot/logrep.h +9 -6
  27. data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/branch.h +4 -4
  28. data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/edom.h +4 -3
  29. data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/logrep.h +5 -2
  30. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/branch.h +3 -4
  31. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/edom.h +7 -6
  32. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/logrep.h +6 -5
  33. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsch/branch.h +3 -9
  34. data/ext/bigdecimal/math_r/internal/algo/bigmath/acsch/logrep.h +7 -6
  35. data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/branch.h +7 -4
  36. data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/edom.h +7 -6
  37. data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/logrep.h +8 -7
  38. data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/branch.h +2 -5
  39. data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/edom.h +10 -6
  40. data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/logrep.h +3 -2
  41. data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/branch.h +4 -2
  42. data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/edom.h +6 -5
  43. data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/logrep.h +3 -2
  44. data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/ser.h +1 -0
  45. data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/logrep.h +6 -5
  46. data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/ser.h +1 -0
  47. data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/branch.h +1 -1
  48. data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/logrep.h +7 -6
  49. data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/ser_euler.h +4 -50
  50. data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/ser_usual.h +2 -9
  51. data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/branch.h +4 -3
  52. data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/edom.h +6 -3
  53. data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/logrep.h +2 -0
  54. data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/ser.h +1 -0
  55. data/ext/bigdecimal/math_r/internal/algo/bigmath/cabs/formula.h +6 -2
  56. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacos/logrep.h +7 -4
  57. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacosh/logrep.h +6 -5
  58. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacot/logrep.h +3 -2
  59. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacoth/logrep.h +8 -4
  60. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsc/logrep.h +5 -4
  61. data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsch/logrep.h +7 -3
  62. data/ext/bigdecimal/math_r/internal/algo/bigmath/carg/formula.h +6 -2
  63. data/ext/bigdecimal/math_r/internal/algo/bigmath/casec/logrep.h +5 -4
  64. data/ext/bigdecimal/math_r/internal/algo/bigmath/casech/logrep.h +3 -1
  65. data/ext/bigdecimal/math_r/internal/algo/bigmath/casin/logrep.h +6 -4
  66. data/ext/bigdecimal/math_r/internal/algo/bigmath/casinh/logrep.h +1 -0
  67. data/ext/bigdecimal/math_r/internal/algo/bigmath/catan/logrep.h +3 -2
  68. data/ext/bigdecimal/math_r/internal/algo/bigmath/catanh/logrep.h +5 -2
  69. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccbrt/branch.h +40 -0
  70. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccbrt/formula.h +5 -2
  71. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccos/eulerf.h +4 -3
  72. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccosh/eulerf.h +4 -3
  73. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccot/eulerf.h +5 -3
  74. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccoth/eulerf.h +4 -2
  75. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsc/eulerf.h +4 -2
  76. data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsch/eulerf.h +5 -3
  77. data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp/eulerf.h +10 -7
  78. data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp2/eulerf.h +5 -3
  79. data/ext/bigdecimal/math_r/internal/algo/bigmath/cexpm1/branch.h +13 -0
  80. data/ext/bigdecimal/math_r/internal/algo/bigmath/cexpm1/identity.h +17 -0
  81. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog/branch.h +11 -12
  82. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog10/branch.h +53 -0
  83. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog10/formula.h +4 -3
  84. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog2/branch.h +53 -0
  85. data/ext/bigdecimal/math_r/internal/algo/bigmath/clog2/formula.h +4 -3
  86. data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/eulerf.h +6 -4
  87. data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/ser.h +4 -4
  88. data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/eulerf.h +5 -3
  89. data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/formula.h +5 -5
  90. data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/ser.h +4 -3
  91. data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/eulerf.h +5 -3
  92. data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/ser.h +3 -2
  93. data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/eulerf.h +4 -2
  94. data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/formula.h +1 -0
  95. data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/ser.h +3 -2
  96. data/ext/bigdecimal/math_r/internal/algo/bigmath/cpow/formula.h +9 -7
  97. data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/eulerf.h +4 -2
  98. data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/ser.h +5 -3
  99. data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/eulerf.h +5 -3
  100. data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/formula.h +2 -2
  101. data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/ser.h +6 -3
  102. data/ext/bigdecimal/math_r/internal/algo/bigmath/csec/eulerf.h +5 -3
  103. data/ext/bigdecimal/math_r/internal/algo/bigmath/csech/eulerf.h +5 -3
  104. data/ext/bigdecimal/math_r/internal/algo/bigmath/csin/eulerf.h +4 -3
  105. data/ext/bigdecimal/math_r/internal/algo/bigmath/csinh/eulerf.h +4 -3
  106. data/ext/bigdecimal/math_r/internal/algo/bigmath/csqrt/branch.h +40 -0
  107. data/ext/bigdecimal/math_r/internal/algo/bigmath/csqrt/formula.h +13 -43
  108. data/ext/bigdecimal/math_r/internal/algo/bigmath/ctan/eulerf.h +4 -3
  109. data/ext/bigdecimal/math_r/internal/algo/bigmath/ctanh/eulerf.h +4 -3
  110. data/ext/bigdecimal/math_r/internal/algo/bigmath/cuberoot/branch.h +18 -0
  111. data/ext/bigdecimal/math_r/internal/algo/bigmath/cuberoot/newton.h +4 -12
  112. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/algo911.h +7 -4
  113. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/cf.h +1 -0
  114. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/ser_inf.h +1 -0
  115. data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/ser_zero.h +1 -0
  116. data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/algo911.h +5 -2
  117. data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/cf.h +1 -0
  118. data/ext/bigdecimal/math_r/internal/algo/bigmath/escalb/edf.h +2 -0
  119. data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/builtin.h +7 -1
  120. data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/edf.h +6 -5
  121. data/ext/bigdecimal/math_r/internal/algo/bigmath/exp2/edf.h +9 -5
  122. data/ext/bigdecimal/math_r/internal/algo/bigmath/expm1/branch.h +13 -0
  123. data/ext/bigdecimal/math_r/internal/algo/bigmath/expm1/identity.h +18 -0
  124. data/ext/bigdecimal/math_r/internal/algo/bigmath/expxt/edf.h +1 -1
  125. data/ext/bigdecimal/math_r/internal/algo/bigmath/f_euler/formula.h +3 -2
  126. data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/l2norm.h +5 -4
  127. data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/mmm.h +1 -1
  128. data/ext/bigdecimal/math_r/internal/algo/bigmath/ipow/edf.h +6 -4
  129. data/ext/bigdecimal/math_r/internal/algo/bigmath/l2norm/formula.h +6 -1
  130. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/branch.h +6 -2
  131. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/builtin.h +3 -2
  132. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/edf.h +8 -5
  133. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/edom.h +10 -4
  134. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/mercator.h +7 -9
  135. data/ext/bigdecimal/math_r/internal/algo/bigmath/log/ser_okumura.h +4 -1
  136. data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/edf.h +3 -2
  137. data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/mercator.h +9 -9
  138. data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/branch.h +8 -5
  139. data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/ser_mercator.h +16 -6
  140. data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/branch.h +1 -1
  141. data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/edf.h +3 -2
  142. data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/mercator.h +9 -9
  143. data/ext/bigdecimal/math_r/internal/algo/bigmath/logxt/edf.h +6 -1
  144. data/ext/bigdecimal/math_r/internal/algo/bigmath/pow/formula.h +13 -8
  145. data/ext/bigdecimal/math_r/internal/algo/bigmath/rcm10/edf.h +10 -4
  146. data/ext/bigdecimal/math_r/internal/algo/bigmath/rcm2/edf.h +11 -3
  147. data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/eulerf.h +5 -3
  148. data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/ser.h +6 -4
  149. data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/eulerf.h +5 -3
  150. data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/formula.h +8 -4
  151. data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/ser.h +5 -3
  152. data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/eulerf.h +5 -2
  153. data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/ser.h +4 -5
  154. data/ext/bigdecimal/math_r/internal/algo/bigmath/sincos/ser.h +9 -2
  155. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/eulerf.h +5 -3
  156. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/formula.h +8 -4
  157. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/ser.h +4 -3
  158. data/ext/bigdecimal/math_r/internal/algo/bigmath/sinhcosh/ser.h +10 -3
  159. data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/branch.h +2 -1
  160. data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/builtin.h +2 -2
  161. data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/edom.h +1 -0
  162. data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/eulerf.h +5 -3
  163. data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/ser.h +3 -8
  164. data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/eulerf.h +5 -3
  165. data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/formula.h +7 -3
  166. data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/ser.h +3 -3
  167. data/ext/bigdecimal/math_r/internal/algo/bigmath/trig/f_euler.h +11 -5
  168. data/ext/bigdecimal/math_r/log.c +5 -5
  169. data/ext/bigdecimal/math_r/math_r/bigdecimal.h +5 -1
  170. data/ext/bigdecimal/math_r/math_r/bigmath.h +2 -0
  171. data/ext/bigdecimal/math_r/math_r/globals.h +1 -1
  172. data/ext/bigdecimal/math_r/math_r/numeric.h +1 -0
  173. data/ext/bigdecimal/math_r/math_r.c +14 -3
  174. data/ext/bigdecimal/math_r/solver.c +75 -21
  175. data/lib/bigdecimal/math_r/const/E_euler.rb +46 -0
  176. data/lib/bigdecimal/math_r/version.rb +1 -1
  177. data/lib/bigdecimal/math_r.rb +1 -0
  178. metadata +21 -11
  179. data/.ruby-version +0 -1
  180. data/LICENSE.txt +0 -21
  181. data/lib/bigdecimal/math_r.so +0 -0
@@ -1,5 +1,5 @@
1
1
  VALUE
2
- E_ser(VALUE prec)
2
+ E_napier(VALUE prec)
3
3
  {
4
4
  const ID div = rb_intern("div");
5
5
  VALUE n, m, a, e;
@@ -0,0 +1,37 @@
1
+ VALUE
2
+ EulerGamma_borwein_bailey(VALUE prec)
3
+ {
4
+ const ID add = rb_intern("add");
5
+ const ID div = rb_intern("div");
6
+ VALUE zero, one, m, n, nn, a, b, u, v, k;
7
+ rb_check_precise(prec);
8
+ zero = BIG_ZERO;
9
+ one = BIG_ONE;
10
+ n = rb_numdiff_make_n(prec);
11
+ nn = rb_BigDecimal1(n);
12
+ a = u = rb_num_uminus(rb_bigmath_log(n, n));
13
+ b = v = one;
14
+ k = zero;
15
+ while (rb_numdiff_condition_p(u, a, n, &m))
16
+ {
17
+ k = rb_funcall1(k, '+', one);
18
+ b = rb_funcall(rb_funcall1(b, '*', rb_funcall1(nn, '*', nn)),
19
+ div, 2, rb_funcall1(k, '*', k), m);
20
+ a = rb_funcall1(
21
+ rb_funcall(one, div, 2, k, m), '*',
22
+ rb_funcall(rb_funcall(rb_funcall1(a, '*', rb_funcall1(nn, '*', nn)),
23
+ div, 2, k, m),
24
+ add, 2, b, m));
25
+ u = rb_funcall1(u, '+', a);
26
+ v = rb_funcall1(v, '+', b);
27
+ }
28
+ RB_GC_GUARD(zero);
29
+ RB_GC_GUARD(one);
30
+ RB_GC_GUARD(nn);
31
+ RB_GC_GUARD(a);
32
+ RB_GC_GUARD(b);
33
+ RB_GC_GUARD(u);
34
+ RB_GC_GUARD(v);
35
+ RB_GC_GUARD(k);
36
+ return rb_funcall(u, div, 2, v, prec);
37
+ }
@@ -1,6 +1,8 @@
1
1
  VALUE
2
2
  LOG10_ser(VALUE prec)
3
3
  {
4
+ rb_check_precise(prec);
5
+ VALUE n = rb_numdiff_make_n(prec);
4
6
  #if 0
5
7
  VALUE x = rb_Rational(INT2FIX(-9), INT2FIX(10));
6
8
  x = log_ser_mercator(x, prec);
@@ -8,8 +10,8 @@ LOG10_ser(VALUE prec)
8
10
  #else
9
11
  const ID add = rb_intern("add");
10
12
  VALUE x = rb_Rational(INT2FIX(1), INT2FIX(4)), log2;
11
- x = log1p_p_adic(x, prec);
12
- log2 = LOG2_BBP2002(prec);
13
+ x = log1p_p_adic(x, n);
14
+ log2 = LOG2_BBP2002(n);
13
15
  return rb_funcall(rb_funcall1(log2, '*', INT2FIX(3)), add, 2, x, prec);
14
16
  #endif
15
17
  }
@@ -1,7 +1,9 @@
1
1
  VALUE
2
2
  LOG_PI_builtin(VALUE prec)
3
3
  {
4
- VALUE log_pi = rb_bigmath_const_pi(prec);
4
+ rb_check_precise(prec);
5
+ VALUE n = rb_numdiff_make_n(prec);
6
+ VALUE log_pi = rb_bigmath_const_pi(n);
5
7
  return log_builtin(log_pi, prec);
6
8
  }
7
9
 
@@ -1,5 +1,8 @@
1
1
  VALUE
2
2
  SQRT2_builtin(VALUE prec)
3
3
  {
4
- return rb_bigmath_sqrt(INT2FIX(2), prec);
4
+ rb_check_precise(prec);
5
+ VALUE n = rb_numdiff_make_n(prec);
6
+ VALUE x = rb_bigmath_sqrt(INT2FIX(2), n);
7
+ return rb_num_round(x, prec);
5
8
  }
@@ -1,5 +1,8 @@
1
1
  VALUE
2
2
  SQRT3_builtin(VALUE prec)
3
3
  {
4
- return rb_bigmath_sqrt(INT2FIX(3), prec);
4
+ rb_check_precise(prec);
5
+ VALUE n = rb_numdiff_make_n(prec);
6
+ VALUE x = rb_bigmath_sqrt(INT2FIX(3), n);
7
+ return rb_num_round(x, prec);
5
8
  }
@@ -2,21 +2,28 @@ VALUE
2
2
  acos_branch(VALUE x, VALUE prec, bigmath_func1 acos_cb)
3
3
  {
4
4
  const ID leq = rb_intern("<=");
5
- VALUE y = Qundef, p001 = rb_BigDecimal1(rb_str_new_cstr("0.001"));
5
+ VALUE y = Qundef;
6
+ VALUE p001 = rb_BigDecimal1(rb_str_new_cstr("0.001"));
7
+ VALUE domain = rb_range_new(INT2FIX(0), INT2FIX(1), true);
8
+
6
9
  x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
7
10
 
8
11
  if (!rb_num_finite_p(x))
9
12
  y = x;
10
13
  else
11
14
  {
12
- VALUE absx = rb_num_negative_p(x) ? rb_num_uminus(x) : x;
15
+ VALUE absx = rb_num_abs(x);
13
16
  if (RTEST(rb_num_coerce_cmp(absx, p001, leq)))
14
17
  {
15
18
  y = acos_ser(x, prec);
16
19
  }
17
- else if (RTEST(rb_num_coerce_cmp(absx, BIG_ONE, leq)))
20
+ else if (rb_num_domain_p(domain, absx))
18
21
  {
19
- y = acos_cb(x, prec);
22
+ if (rb_num_equal_p(absx, INT2FIX(1)))
23
+ y = rb_num_negative_p(x) ?
24
+ rb_bigmath_const_pi(prec) : BIG_ZERO;
25
+ else
26
+ y = acos_cb(x, prec);
20
27
  }
21
28
  else
22
29
  y = BIG_NAN;
@@ -1,15 +1,15 @@
1
1
  VALUE
2
2
  acosh_branch(VALUE x, VALUE prec, bigmath_func1 acosh_cb)
3
3
  {
4
- const ID geq = rb_intern(">=");
5
4
  VALUE y = Qundef;
5
+ VALUE domain = rb_range_new(INT2FIX(1), DBL2NUM(HUGE_VAL), false);
6
6
 
7
7
  x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
8
8
  if (rb_num_positive_p(x))
9
9
  {
10
10
  if (rb_num_infinite_p(x) == 1)
11
11
  y = BIG_INF;
12
- else if (RTEST(rb_num_coerce_cmp(x, BIG_ONE, geq)))
12
+ else if (rb_num_domain_p(domain, x))
13
13
  y = acosh_cb(x, prec);
14
14
  }
15
15
  if (y == Qundef)
@@ -3,15 +3,17 @@ acosh_edom(VALUE x, VALUE prec)
3
3
  {
4
4
  const ID add = rb_intern("add");
5
5
  const ID div = rb_intern("div");
6
- VALUE t, w, y;
6
+ VALUE t, w, y, n;
7
7
 
8
8
  rb_check_precise(prec);
9
+ n = rb_numdiff_make_n(prec);
9
10
 
10
11
  t = rb_funcall1(BIG_MINUS_ONE, '+', rb_funcall1(x, '*', x));
11
- w = rb_funcall(rb_bigmath_sqrt(rb_num_uminus(t), prec), div, 2, x, prec);
12
- y = rb_bigmath_atan(w, prec);
12
+ w = rb_funcall(rb_bigmath_sqrt(rb_num_uminus(t), prec), div, 2, x, n);
13
+ y = rb_bigmath_atan(w, n);
13
14
  if (rb_num_negative_p(x))
14
- y = rb_funcall(rb_bigmath_const_pi(prec), add, 2, y, prec);
15
+ y = rb_funcall(rb_bigmath_const_pi(n), add, 2, y, n);
16
+ y = rb_Complex(BIG_ZERO, y);
15
17
 
16
- return rb_Complex(BIG_ZERO, y);
18
+ return rb_num_round(y, prec);
17
19
  }
@@ -1,13 +1,16 @@
1
1
  VALUE
2
2
  acot_logrep(VALUE x, VALUE prec)
3
3
  {
4
- VALUE n, m, y;
4
+ VALUE n1, m1, y, n;
5
+
6
+ rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
5
8
 
6
9
  x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RECIPROCAL);
7
- n = rb_Complex(BIG_ONE, x);
8
- m = rb_bigmath_sqrt(rb_funcall1(BIG_ONE, '+', rb_funcall1(x, '*', x)), prec);
9
- y = rb_funcall1(n, '/', m);
10
- y = rb_bigmath_carg(y, prec);
10
+ n1 = rb_Complex(BIG_ONE, x);
11
+ m1 = rb_bigmath_sqrt(rb_funcall1(BIG_ONE, '+', rb_funcall1(x, '*', x)), n);
12
+ y = rb_funcall1(n1, '/', m1);
13
+ y = rb_bigmath_carg(y, n);
11
14
 
12
- return y;
15
+ return rb_num_round(y, prec);
13
16
  }
@@ -1,8 +1,9 @@
1
1
  VALUE
2
2
  acoth_branch(VALUE x, VALUE prec, bigmath_func1 acoth_cb)
3
3
  {
4
- VALUE y;
5
- const ID leq = rb_intern("<=");
4
+ VALUE y = Qundef;
5
+ VALUE p_domain = rb_range_new(INT2FIX(1), DBL2NUM(HUGE_VAL), false);
6
+ VALUE m_domain = rb_range_new(DBL2NUM(-HUGE_VAL), INT2FIX(-1), true);
6
7
 
7
8
  x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
8
9
 
@@ -10,8 +11,7 @@ acoth_branch(VALUE x, VALUE prec, bigmath_func1 acoth_cb)
10
11
  y = BIG_INF;
11
12
  else if (rb_num_equal_p(x, BIG_MINUS_ONE))
12
13
  y = BIG_MINUS_INF;
13
- else if (RTEST(rb_num_coerce_cmp(x, BIG_MINUS_ONE, leq)) ||
14
- RTEST(rb_num_coerce_cmp(BIG_ONE, x, leq)))
14
+ else if (rb_num_domain_p(p_domain, x) || rb_num_domain_p(m_domain, x))
15
15
  y = acoth_cb(x, prec);
16
16
  else
17
17
  y = BIG_NAN;
@@ -1,16 +1,17 @@
1
1
  VALUE
2
2
  acoth_edom(VALUE x, VALUE prec)
3
3
  {
4
- VALUE t, pi;
4
+ VALUE t, pi, n;
5
5
 
6
6
  rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
7
8
 
8
9
  t = rb_funcall1(
9
10
  rb_funcall1(x, '+', BIG_ONE), '/',
10
11
  rb_funcall1(x, '-', BIG_ONE));
11
- pi = rb_bigmath_const_pi(prec);
12
+ pi = rb_bigmath_const_pi(n);
12
13
  t = rb_Complex(
13
- rb_bigmath_log(rb_num_abs(t), prec),
14
+ rb_bigmath_log(rb_num_abs(t), n),
14
15
  rb_num_negative_p(x) ? pi : rb_num_uminus(pi));
15
16
  t = rb_funcall1(rb_Rational(INT2FIX(1), INT2FIX(2)), '*', t);
16
17
 
@@ -1,12 +1,15 @@
1
1
  VALUE
2
2
  acoth_logrep(VALUE x, VALUE prec)
3
3
  {
4
- VALUE y;
4
+ VALUE y, n;
5
+
6
+ rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
5
8
 
6
9
  y = rb_funcall1(
7
10
  rb_funcall1(x, '+', BIG_ONE), '/',
8
11
  rb_funcall1(x, '-', BIG_ONE));
9
- y = rb_bigmath_log(y, prec);
12
+ y = rb_bigmath_log(y, n);
10
13
  y = rb_funcall1(rb_Rational(INT2FIX(1), INT2FIX(2)), '*', y);
11
14
  y = rb_num_round(y, prec);
12
15
 
@@ -1,9 +1,9 @@
1
1
  VALUE
2
2
  acsc_branch(VALUE x, VALUE prec, bigmath_func1 acsc_cb)
3
3
  {
4
- const ID leq = rb_intern("<=");
5
- const ID geq = rb_intern(">=");
6
4
  VALUE y = Qundef;
5
+ VALUE p_domain = rb_range_new(INT2FIX(1), DBL2NUM(HUGE_VAL), false);
6
+ VALUE m_domain = rb_range_new(DBL2NUM(-HUGE_VAL), INT2FIX(-1), true);
7
7
 
8
8
  x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
9
9
 
@@ -11,8 +11,7 @@ acsc_branch(VALUE x, VALUE prec, bigmath_func1 acsc_cb)
11
11
  y = BIG_NAN;
12
12
  else if (rb_num_infinite_p(x) != 0)
13
13
  y = BIG_ONE;
14
- else if (RTEST(rb_num_coerce_bin(x, INT2FIX(-1), leq)) ||
15
- RTEST(rb_num_coerce_bin(x, INT2FIX( 1), geq)))
14
+ else if (rb_num_domain_p(p_domain, x) || rb_num_domain_p(m_domain, x))
16
15
  y = acsc_cb(x, prec);
17
16
  else
18
17
  y = BIG_NAN;
@@ -2,19 +2,20 @@ VALUE
2
2
  acsc_edom(VALUE x, VALUE prec)
3
3
  {
4
4
  const ID div = rb_intern("div");
5
- VALUE imag, y, arg, t;
5
+ VALUE imag, y, arg, t, n;
6
6
 
7
7
  rb_check_precise(prec);
8
+ n = rb_numdiff_make_n(prec);
8
9
 
9
- x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RECIPROCAL);
10
+ x = rb_num_canonicalize(x, n, ARG_REAL, ARG_RECIPROCAL);
10
11
  t = rb_funcall1(BIG_ONE, '-', rb_funcall1(x, '*', x));
11
- t = rb_funcall1(rb_bigmath_sqrt(rb_num_uminus(t), prec), '+', x);
12
- arg = rb_funcall(rb_bigmath_const_pi(prec), div, 2, INT2FIX(2), prec);
12
+ t = rb_funcall1(rb_bigmath_sqrt(rb_num_uminus(t), n), '+', x);
13
+ arg = rb_funcall(rb_bigmath_const_pi(n), div, 2, INT2FIX(2), n);
13
14
  if (!rb_num_negative_p(x))
14
15
  arg = rb_num_uminus(arg);
15
- imag = rb_bigmath_log(rb_num_abs(t), prec);
16
+ imag = rb_bigmath_log(rb_num_abs(t), n);
16
17
  y = rb_Complex(arg, imag);
17
18
  y = rb_num_uminus(y);
18
19
 
19
- return y;
20
+ return rb_num_round(y, prec);
20
21
  }
@@ -1,16 +1,17 @@
1
1
  VALUE
2
2
  acsc_logrep(VALUE x, VALUE prec)
3
3
  {
4
- VALUE t;
4
+ VALUE t, n;
5
5
 
6
6
  rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
7
8
 
8
- x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RECIPROCAL);
9
+ x = rb_num_canonicalize(x, n, ARG_REAL, ARG_RECIPROCAL);
9
10
  t = rb_funcall1(x, '*', x);
10
11
  t = rb_funcall1(INT2FIX(1), '-', t);
11
- t = rb_bigmath_sqrt(t, prec);
12
+ t = rb_bigmath_sqrt(t, n);
12
13
  t = rb_funcall1(x, '/', t);
13
- t = rb_bigmath_atan(t, prec);
14
+ t = rb_bigmath_atan(t, n);
14
15
 
15
- return t;
16
+ return rb_num_round(t, prec);
16
17
  }
@@ -1,7 +1,6 @@
1
1
  VALUE
2
2
  acsch_branch(VALUE x, VALUE prec, bigmath_func1 acsch_cb)
3
3
  {
4
- const ID leq = rb_intern("<=");
5
4
  VALUE y = Qundef;
6
5
  int sign;
7
6
 
@@ -10,16 +9,11 @@ acsch_branch(VALUE x, VALUE prec, bigmath_func1 acsch_cb)
10
9
  if (rb_num_nan_p(x))
11
10
  y = BIG_NAN;
12
11
  else if ((sign = rb_num_infinite_p(x)) != 0)
13
- {
14
12
  y = sign == 1 ? BIG_ZERO : BIG_MINUS_ZERO;
15
- }
16
- else if (RTEST(rb_num_coerce_bin(x, BIG_MINUS_ONE, leq)) ||
17
- RTEST(rb_num_coerce_bin(BIG_ONE, x, leq)))
18
- {
13
+ else if (rb_num_zero_p(x))
14
+ y = BIG_INF;
15
+ else
19
16
  y = acsch_cb(x, prec);
20
- }
21
- else
22
- y = BIG_NAN;
23
17
 
24
18
  return y;
25
19
  }
@@ -1,22 +1,23 @@
1
1
  VALUE
2
2
  acsch_logrep(VALUE x, VALUE prec)
3
3
  {
4
- VALUE t, y;
4
+ VALUE t, y, n;
5
5
 
6
6
  rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
7
8
 
8
- x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RECIPROCAL);
9
+ x = rb_num_canonicalize(x, n, ARG_REAL, ARG_RECIPROCAL);
9
10
  if (rb_num_positive_p(x))
10
11
  {
11
12
  t = rb_funcall1(rb_funcall1(x, '*', x), '+', BIG_ONE);
12
- t = rb_bigmath_sqrt(t, prec);
13
- y = rb_bigmath_log(rb_funcall1(x, '+', t), prec);
13
+ t = rb_bigmath_sqrt(t, n);
14
+ y = rb_bigmath_log(rb_funcall1(x, '+', t), n);
14
15
  }
15
16
  else if (rb_num_negative_p(x))
16
17
  {
17
18
  t = rb_funcall1(rb_funcall1(x, '*', x), '+', BIG_ONE);
18
- t = rb_bigmath_sqrt(t, prec);
19
- t = rb_bigmath_log(rb_funcall1(t, '-', x), prec);
19
+ t = rb_bigmath_sqrt(t, n);
20
+ t = rb_bigmath_log(rb_funcall1(t, '-', x), n);
20
21
  y = rb_num_uminus(t);
21
22
  }
22
23
  else
@@ -1,10 +1,10 @@
1
1
  VALUE
2
2
  asec_branch(VALUE x, VALUE prec, bigmath_func1 asec_cb)
3
3
  {
4
- const ID leq = rb_intern("<=");
5
- const ID geq = rb_intern(">=");
6
4
  const ID div = rb_intern("div");
7
5
  VALUE y = Qundef;
6
+ VALUE p_domain = rb_range_new(INT2FIX(1), DBL2NUM(HUGE_VAL), false);
7
+ VALUE m_domain = rb_range_new(DBL2NUM(-HUGE_VAL), INT2FIX(-1), true);
8
8
 
9
9
  x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
10
10
 
@@ -12,8 +12,11 @@ asec_branch(VALUE x, VALUE prec, bigmath_func1 asec_cb)
12
12
  y = BIG_NAN;
13
13
  else if (rb_num_infinite_p(x) != 0)
14
14
  y = rb_funcall(rb_bigmath_const_pi(prec), div, 2, INT2FIX(2), prec);
15
- else if (RTEST(rb_num_coerce_bin(x, INT2FIX(-1), leq)) ||
16
- RTEST(rb_num_coerce_bin(x, INT2FIX(1), geq)))
15
+ else if (rb_num_equal_p(x, INT2FIX(-1)))
16
+ y = rb_bigmath_const_pi(prec);
17
+ else if (rb_num_equal_p(x, INT2FIX(0)))
18
+ y = BIG_ZERO;
19
+ else if (rb_num_domain_p(p_domain, x) || rb_num_domain_p(m_domain, x))
17
20
  y = asec_cb(x, prec);
18
21
  else
19
22
  y = BIG_NAN;
@@ -1,16 +1,17 @@
1
1
  VALUE
2
2
  asec_edom(VALUE x, VALUE prec)
3
3
  {
4
- VALUE imag, y, arg, t;
4
+ VALUE imag, y, arg, t, n;
5
5
 
6
6
  rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
7
8
 
8
- x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RECIPROCAL);
9
+ x = rb_num_canonicalize(x, n, ARG_REAL, ARG_RECIPROCAL);
9
10
  t = rb_funcall1(BIG_ONE, '-', rb_funcall1(x, '*', x));
10
- t = rb_funcall1(rb_bigmath_sqrt(rb_num_uminus(t), prec), '+', x);
11
- arg = rb_num_negative_p(x) ? rb_bigmath_const_pi(prec) : BIG_ZERO;
12
- imag = rb_bigmath_log(rb_num_abs(t), prec);
11
+ t = rb_funcall1(rb_bigmath_sqrt(rb_num_uminus(t), n), '+', x);
12
+ arg = rb_num_negative_p(x) ? rb_bigmath_const_pi(n) : BIG_ZERO;
13
+ imag = rb_bigmath_log(rb_num_abs(t), n);
13
14
  y = rb_Complex(arg, imag);
14
15
 
15
- return y;
16
+ return rb_num_round(y, prec);
16
17
  }
@@ -3,19 +3,20 @@ asec_logrep(VALUE x, VALUE prec)
3
3
  {
4
4
  const ID div = rb_intern("div");
5
5
  const ID sub = rb_intern("sub");
6
- VALUE t, pi_2;
6
+ VALUE t, pi_2, n;
7
7
 
8
8
  rb_check_precise(prec);
9
+ n = rb_numdiff_make_n(prec);
9
10
 
10
- x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RECIPROCAL);
11
+ x = rb_num_canonicalize(x, n, ARG_REAL, ARG_RECIPROCAL);
11
12
  t = rb_funcall1(x, '*', x);
12
13
  t = rb_funcall1(INT2FIX(1), '-', t);
13
- t = rb_bigmath_sqrt(t, prec);
14
+ t = rb_bigmath_sqrt(t, n);
14
15
  t = rb_funcall1(x, '/', t);
15
- t = rb_bigmath_atan(t, prec);
16
+ t = rb_bigmath_atan(t, n);
16
17
  pi_2 = rb_funcall(
17
- rb_bigmath_const_pi(prec), div, 2, INT2FIX(2), prec);
18
- t = rb_funcall(pi_2, sub, 2, t, prec);
18
+ rb_bigmath_const_pi(n), div, 2, INT2FIX(2), n);
19
+ t = rb_funcall(pi_2, sub, 2, t, n);
19
20
 
20
- return t;
21
+ return rb_num_round(t, prec);
21
22
  }
@@ -1,16 +1,13 @@
1
1
  VALUE
2
2
  asech_branch(VALUE x, VALUE prec, bigmath_func1 asech_cb)
3
3
  {
4
- const ID leq = rb_intern("<=");
5
4
  VALUE y;
5
+ VALUE domain = rb_range_new(INT2FIX(0), INT2FIX(1), true);
6
6
 
7
7
  x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
8
8
 
9
- if (RTEST(rb_num_coerce_cmp(BIG_ZERO, x, leq)) &&
10
- RTEST(rb_num_coerce_cmp(x, BIG_ONE, leq)))
11
- {
9
+ if (rb_num_domain_p(domain, x))
12
10
  y = asech_cb(x, prec);
13
- }
14
11
  else
15
12
  y = BIG_NAN;
16
13
 
@@ -1,19 +1,23 @@
1
1
  VALUE
2
2
  asech_edom(VALUE x, VALUE prec)
3
3
  {
4
- VALUE absx, recip_x, sqr, w, y;
4
+ VALUE absx, recip_x, sqr, w, y, n;
5
+
6
+ rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
5
8
 
6
9
  absx = rb_num_abs(x);
7
- recip_x = rb_num_canonicalize(absx, prec, ARG_REAL, ARG_RECIPROCAL);
10
+ recip_x = rb_num_canonicalize(absx, n, ARG_REAL, ARG_RECIPROCAL);
8
11
  sqr = rb_funcall1(
9
12
  rb_funcall1(BIG_ONE, '-', absx), '/',
10
13
  rb_funcall1(absx, '+', BIG_ONE));
11
- w = rb_Complex(BIG_ZERO, rb_bigmath_sqrt(sqr, prec));
14
+ w = rb_Complex(BIG_ZERO, rb_bigmath_sqrt(sqr, n));
12
15
  w = rb_funcall1(w, '*', rb_funcall1(recip_x, '+', BIG_ONE));
13
16
  w = rb_funcall1(w, '+', recip_x);
14
- y = rb_bigmath_carg(w, prec);
17
+ y = rb_bigmath_carg(w, n);
15
18
  if (rb_num_negative_p(x))
16
- y =rb_funcall1(rb_bigmath_const_pi(prec), '-', y);
19
+ y =rb_funcall1(rb_bigmath_const_pi(n), '-', y);
20
+ y = rb_Complex(BIG_ZERO, y);
17
21
 
18
- return rb_Complex(BIG_ZERO, y);
22
+ return rb_num_round(y, prec);
19
23
  }
@@ -1,13 +1,14 @@
1
1
  VALUE
2
2
  asech_logrep(VALUE x, VALUE prec)
3
3
  {
4
- VALUE y;
4
+ VALUE y, n;
5
5
 
6
6
  rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
7
8
 
8
9
  y = rb_funcall1(x, '*', x);
9
10
  y = rb_funcall1(BIG_ONE, '-', y);
10
- y = rb_bigmath_sqrt(y, prec);
11
+ y = rb_bigmath_sqrt(y, n);
11
12
  y = rb_funcall1(y, '+', BIG_ONE);
12
13
  y = rb_funcall1(y, '/', x);
13
14
  y = rb_bigmath_log(y, prec);
@@ -2,7 +2,9 @@ VALUE
2
2
  asin_branch(VALUE x, VALUE prec, bigmath_func1 asin_cb)
3
3
  {
4
4
  const ID leq = rb_intern("<=");
5
- VALUE y = Qundef, p001 = rb_BigDecimal1(rb_str_new_cstr("0.001"));
5
+ VALUE y = Qundef;
6
+ VALUE p001 = rb_BigDecimal1(rb_str_new_cstr("0.001"));
7
+ VALUE domain = rb_range_new(INT2FIX(-1), INT2FIX(1), true);
6
8
 
7
9
  x = rb_num_canonicalize(x, prec, ARG_REAL, ARG_RAWVALUE);
8
10
 
@@ -13,7 +15,7 @@ asin_branch(VALUE x, VALUE prec, bigmath_func1 asin_cb)
13
15
  VALUE absx = rb_num_negative_p(x) ? rb_num_uminus(x) : x;
14
16
  if (RTEST(rb_num_coerce_cmp(absx, p001, leq)))
15
17
  y = asin_ser(x, prec);
16
- else if (RTEST(rb_num_coerce_cmp(absx, BIG_ONE, leq)))
18
+ else if (rb_num_domain_p(domain, x))
17
19
  y = asin_cb(x, prec);
18
20
  else
19
21
  y = BIG_NAN;
@@ -2,19 +2,20 @@ VALUE
2
2
  asin_edom(VALUE x, VALUE prec)
3
3
  {
4
4
  const ID div = rb_intern("div");
5
- VALUE imag, y, arg, t;
5
+ VALUE imag, y, arg, t, n;
6
6
 
7
7
  rb_check_precise(prec);
8
+ n = rb_numdiff_make_n(prec);
8
9
 
9
10
  t = rb_funcall1(BIG_ONE, '-', rb_funcall1(x, '*', x));
10
- t = rb_funcall1(rb_bigmath_sqrt(rb_num_uminus(t), prec), '+', x);
11
+ t = rb_funcall1(rb_bigmath_sqrt(rb_num_uminus(t), n), '+', x);
11
12
  arg = rb_funcall(
12
- rb_bigmath_const_pi(prec), div, 2, INT2FIX(2), prec);
13
+ rb_bigmath_const_pi(n), div, 2, INT2FIX(2), n);
13
14
  if (!rb_num_negative_p(x))
14
15
  arg = rb_num_uminus(arg);
15
- imag = rb_bigmath_log(rb_num_abs(t), prec);
16
+ imag = rb_bigmath_log(rb_num_abs(t), n);
16
17
  y = rb_Complex(arg, imag);
17
18
  y = rb_num_uminus(y);
18
19
 
19
- return y;
20
+ return rb_num_round(y, prec);
20
21
  }
@@ -1,13 +1,14 @@
1
1
  VALUE
2
2
  asin_logrep(VALUE x, VALUE prec)
3
3
  {
4
- VALUE t;
4
+ VALUE t, n;
5
5
 
6
6
  rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
7
8
 
8
9
  t = rb_funcall1(x, '*', x);
9
10
  t = rb_funcall1(INT2FIX(1), '-', t);
10
- t = rb_bigmath_sqrt(t, prec);
11
+ t = rb_bigmath_sqrt(t, n);
11
12
  t = rb_funcall1(x, '/', t);
12
13
  t = rb_bigmath_atan(t, prec);
13
14
 
@@ -4,6 +4,7 @@ asin_ser(VALUE x, VALUE prec)
4
4
  const ID mult = rb_intern("mult");
5
5
  VALUE one, i, d, x2, y, n, m;
6
6
 
7
+ rb_check_precise(prec);
7
8
  n = rb_numdiff_make_n(prec);
8
9
 
9
10
  one = BIG_ONE;
@@ -1,21 +1,22 @@
1
1
  VALUE
2
2
  asinh_logrep(VALUE x, VALUE prec)
3
3
  {
4
- VALUE t, y;
4
+ VALUE t, y, n;
5
5
 
6
6
  rb_check_precise(prec);
7
+ n = rb_numdiff_make_n(prec);
7
8
 
8
9
  if (rb_num_positive_p(x))
9
10
  {
10
11
  t = rb_funcall1(rb_funcall1(x, '*', x), '+', BIG_ONE);
11
- t = rb_bigmath_sqrt(t, prec);
12
- y = rb_bigmath_log(rb_funcall1(x, '+', t), prec);
12
+ t = rb_bigmath_sqrt(t, n);
13
+ y = rb_bigmath_log(rb_funcall1(x, '+', t), n);
13
14
  }
14
15
  else if (rb_num_negative_p(x))
15
16
  {
16
17
  t = rb_funcall1(rb_funcall1(x, '*', x), '+', BIG_ONE);
17
- t = rb_bigmath_sqrt(t, prec);
18
- t = rb_bigmath_log(rb_funcall1(t, '-', x), prec);
18
+ t = rb_bigmath_sqrt(t, n);
19
+ t = rb_bigmath_log(rb_funcall1(t, '-', x), n);
19
20
  y = rb_num_uminus(t);
20
21
  }
21
22
  else
@@ -5,6 +5,7 @@ asinh_ser(VALUE x, VALUE prec)
5
5
  VALUE n, m;
6
6
  VALUE one, two, x2, c, t, f_n, f_m, d, y, i;
7
7
 
8
+ rb_check_precise(prec);
8
9
  n = rb_numdiff_make_n(prec);
9
10
 
10
11
  one = BIG_ONE;