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.
- checksums.yaml +4 -4
- data/README.md +63 -10
- data/changelog.md +32 -0
- data/ext/bigdecimal/math_r/algofunc.h +11 -1
- data/ext/bigdecimal/math_r/api/bigmath/const_e.h +1 -1
- data/ext/bigdecimal/math_r/api/bigmath/const_euler_gamma.h +5 -0
- data/ext/bigdecimal/math_r/api/bigmath/csqrt.h +1 -1
- data/ext/bigdecimal/math_r/api/kernel/rb_BigDecimal_flo.h +8 -2
- data/ext/bigdecimal/math_r/api/numeric/domain_p.h +7 -0
- data/ext/bigdecimal/math_r/api/numeric/nan_p.h +4 -1
- data/ext/bigdecimal/math_r/api.h +2 -0
- data/ext/bigdecimal/math_r/const.c +42 -5
- data/ext/bigdecimal/math_r/decl.h +11 -1
- data/ext/bigdecimal/math_r/exp.c +45 -3
- data/ext/bigdecimal/math_r/extconf.rb +5 -1
- data/ext/bigdecimal/math_r/{gamma_r.c → gamma_beta.c} +11 -78
- data/ext/bigdecimal/math_r/internal/algo/bigmath/E/{ser.h → napier.h} +1 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/EulerGamma/borwein_bailey.h +37 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG10/ser.h +4 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/LOG_PI/builtin.h +3 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/SQRT2/builtin.h +4 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/SQRT3/builtin.h +4 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acos/branch.h +11 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/branch.h +2 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acosh/edom.h +7 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acot/logrep.h +9 -6
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/branch.h +4 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/edom.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acoth/logrep.h +5 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/branch.h +3 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/edom.h +7 -6
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsc/logrep.h +6 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsch/branch.h +3 -9
- data/ext/bigdecimal/math_r/internal/algo/bigmath/acsch/logrep.h +7 -6
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/branch.h +7 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/edom.h +7 -6
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asec/logrep.h +8 -7
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/branch.h +2 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/edom.h +10 -6
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asech/logrep.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/branch.h +4 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/edom.h +6 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/logrep.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asin/ser.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/logrep.h +6 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/asinh/ser.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/branch.h +1 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/logrep.h +7 -6
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/ser_euler.h +4 -50
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atan/ser_usual.h +2 -9
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/branch.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/edom.h +6 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/logrep.h +2 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/atanh/ser.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cabs/formula.h +6 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacos/logrep.h +7 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacosh/logrep.h +6 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacot/logrep.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacoth/logrep.h +8 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsc/logrep.h +5 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cacsch/logrep.h +7 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/carg/formula.h +6 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casec/logrep.h +5 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casech/logrep.h +3 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casin/logrep.h +6 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/casinh/logrep.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/catan/logrep.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/catanh/logrep.h +5 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccbrt/branch.h +40 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccbrt/formula.h +5 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccos/eulerf.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccosh/eulerf.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccot/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccoth/eulerf.h +4 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsc/eulerf.h +4 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ccsch/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp/eulerf.h +10 -7
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cexp2/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cexpm1/branch.h +13 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cexpm1/identity.h +17 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog/branch.h +11 -12
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog10/branch.h +53 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog10/formula.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog2/branch.h +53 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/clog2/formula.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/eulerf.h +6 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cos/ser.h +4 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/formula.h +5 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cosh/ser.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cot/ser.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/eulerf.h +4 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/formula.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/coth/ser.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cpow/formula.h +9 -7
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/eulerf.h +4 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csc/ser.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/formula.h +2 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csch/ser.h +6 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csec/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csech/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csin/eulerf.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csinh/eulerf.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csqrt/branch.h +40 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/csqrt/formula.h +13 -43
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ctan/eulerf.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ctanh/eulerf.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cuberoot/branch.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/cuberoot/newton.h +4 -12
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/algo911.h +7 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/cf.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/ser_inf.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erf/ser_zero.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/algo911.h +5 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/erfc/cf.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/escalb/edf.h +2 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/builtin.h +7 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/exp/edf.h +6 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/exp2/edf.h +9 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/expm1/branch.h +13 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/expm1/identity.h +18 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/expxt/edf.h +1 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/f_euler/formula.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/l2norm.h +5 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/hypot/mmm.h +1 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/ipow/edf.h +6 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/l2norm/formula.h +6 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/branch.h +6 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/builtin.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/edf.h +8 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/edom.h +10 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/mercator.h +7 -9
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log/ser_okumura.h +4 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/edf.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log10/mercator.h +9 -9
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/branch.h +8 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log1p/ser_mercator.h +16 -6
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/branch.h +1 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/edf.h +3 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/log2/mercator.h +9 -9
- data/ext/bigdecimal/math_r/internal/algo/bigmath/logxt/edf.h +6 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/pow/formula.h +13 -8
- data/ext/bigdecimal/math_r/internal/algo/bigmath/rcm10/edf.h +10 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/rcm2/edf.h +11 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sec/ser.h +6 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/formula.h +8 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sech/ser.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/eulerf.h +5 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sin/ser.h +4 -5
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sincos/ser.h +9 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/formula.h +8 -4
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinh/ser.h +4 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sinhcosh/ser.h +10 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/branch.h +2 -1
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/builtin.h +2 -2
- data/ext/bigdecimal/math_r/internal/algo/bigmath/sqrt/edom.h +1 -0
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tan/ser.h +3 -8
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/eulerf.h +5 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/formula.h +7 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/tanh/ser.h +3 -3
- data/ext/bigdecimal/math_r/internal/algo/bigmath/trig/f_euler.h +11 -5
- data/ext/bigdecimal/math_r/log.c +5 -5
- data/ext/bigdecimal/math_r/math_r/bigdecimal.h +5 -1
- data/ext/bigdecimal/math_r/math_r/bigmath.h +2 -0
- data/ext/bigdecimal/math_r/math_r/globals.h +1 -1
- data/ext/bigdecimal/math_r/math_r/numeric.h +1 -0
- data/ext/bigdecimal/math_r/math_r.c +14 -3
- data/ext/bigdecimal/math_r/solver.c +75 -21
- data/lib/bigdecimal/math_r/const/E_euler.rb +46 -0
- data/lib/bigdecimal/math_r/version.rb +1 -1
- data/lib/bigdecimal/math_r.rb +1 -0
- metadata +21 -11
- data/.ruby-version +0 -1
- data/LICENSE.txt +0 -21
- data/lib/bigdecimal/math_r.so +0 -0
@@ -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,
|
12
|
-
log2 = LOG2_BBP2002(
|
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
|
}
|
@@ -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
|
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 =
|
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 (
|
20
|
+
else if (rb_num_domain_p(domain, absx))
|
18
21
|
{
|
19
|
-
|
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 (
|
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,
|
12
|
-
y = rb_bigmath_atan(w,
|
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(
|
15
|
+
y = rb_funcall(rb_bigmath_const_pi(n), add, 2, y, n);
|
16
|
+
y = rb_Complex(BIG_ZERO, y);
|
15
17
|
|
16
|
-
return
|
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
|
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
|
-
|
8
|
-
|
9
|
-
y = rb_funcall1(
|
10
|
-
y = rb_bigmath_carg(y,
|
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
|
-
|
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 (
|
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(
|
12
|
+
pi = rb_bigmath_const_pi(n);
|
12
13
|
t = rb_Complex(
|
13
|
-
rb_bigmath_log(rb_num_abs(t),
|
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,
|
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 (
|
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,
|
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),
|
12
|
-
arg = rb_funcall(rb_bigmath_const_pi(
|
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),
|
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,
|
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,
|
12
|
+
t = rb_bigmath_sqrt(t, n);
|
12
13
|
t = rb_funcall1(x, '/', t);
|
13
|
-
t = rb_bigmath_atan(t,
|
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
|
-
|
17
|
-
|
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,
|
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,
|
13
|
-
y = rb_bigmath_log(rb_funcall1(x, '+', t),
|
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,
|
19
|
-
t = rb_bigmath_log(rb_funcall1(t, '-', x),
|
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 (
|
16
|
-
|
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,
|
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),
|
11
|
-
arg = rb_num_negative_p(x) ? rb_bigmath_const_pi(
|
12
|
-
imag = rb_bigmath_log(rb_num_abs(t),
|
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,
|
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,
|
14
|
+
t = rb_bigmath_sqrt(t, n);
|
14
15
|
t = rb_funcall1(x, '/', t);
|
15
|
-
t = rb_bigmath_atan(t,
|
16
|
+
t = rb_bigmath_atan(t, n);
|
16
17
|
pi_2 = rb_funcall(
|
17
|
-
rb_bigmath_const_pi(
|
18
|
-
t = rb_funcall(pi_2, sub, 2, t,
|
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 (
|
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,
|
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,
|
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,
|
17
|
+
y = rb_bigmath_carg(w, n);
|
15
18
|
if (rb_num_negative_p(x))
|
16
|
-
y =rb_funcall1(rb_bigmath_const_pi(
|
19
|
+
y =rb_funcall1(rb_bigmath_const_pi(n), '-', y);
|
20
|
+
y = rb_Complex(BIG_ZERO, y);
|
17
21
|
|
18
|
-
return
|
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,
|
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
|
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 (
|
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),
|
11
|
+
t = rb_funcall1(rb_bigmath_sqrt(rb_num_uminus(t), n), '+', x);
|
11
12
|
arg = rb_funcall(
|
12
|
-
rb_bigmath_const_pi(
|
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),
|
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,
|
11
|
+
t = rb_bigmath_sqrt(t, n);
|
11
12
|
t = rb_funcall1(x, '/', t);
|
12
13
|
t = rb_bigmath_atan(t, prec);
|
13
14
|
|
@@ -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,
|
12
|
-
y = rb_bigmath_log(rb_funcall1(x, '+', t),
|
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,
|
18
|
-
t = rb_bigmath_log(rb_funcall1(t, '-', x),
|
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
|