You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1833 lines
62 KiB
1833 lines
62 KiB
3 years ago
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-11 12:40:40.079363480 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-11 12:40:40.119363040 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+decimal128-conv
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2020-07-10 11:52:33.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-11 12:40:40.119363040 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0
|
||
|
+4.1.0-p1
|
||
|
diff -Naurd mpfr-4.1.0-a/src/get_d128.c mpfr-4.1.0-b/src/get_d128.c
|
||
|
--- mpfr-4.1.0-a/src/get_d128.c 2020-04-08 22:39:35.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/get_d128.c 2021-02-11 12:40:40.103363216 +0000
|
||
|
@@ -40,22 +40,21 @@
|
||
|
static _Decimal128
|
||
|
get_decimal128_nan (void)
|
||
|
{
|
||
|
- return (_Decimal128) MPFR_DBL_NAN;
|
||
|
+ return 0.0dl / 0.0dl;
|
||
|
}
|
||
|
|
||
|
/* construct the decimal128 Inf with given sign */
|
||
|
static _Decimal128
|
||
|
get_decimal128_inf (int negative)
|
||
|
{
|
||
|
- return (_Decimal128) (negative ? MPFR_DBL_INFM : MPFR_DBL_INFP);
|
||
|
+ return negative ? - 1.0dl / 0.0dl : 1.0dl / 0.0dl;
|
||
|
}
|
||
|
|
||
|
/* construct the decimal128 zero with given sign */
|
||
|
static _Decimal128
|
||
|
get_decimal128_zero (int negative)
|
||
|
{
|
||
|
- _Decimal128 zero = 0;
|
||
|
- return (_Decimal128) (negative ? -zero : zero);
|
||
|
+ return negative ? - 0.0dl : 0.0dl;
|
||
|
}
|
||
|
|
||
|
/* construct the decimal128 smallest non-zero with given sign:
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2020-07-10 11:52:33.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-11 12:40:40.115363084 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p1"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2020-07-10 11:52:33.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-11 12:40:40.119363040 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0";
|
||
|
+ return "4.1.0-p1";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-11 12:43:51.761257868 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-11 12:43:51.801257430 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+random_deviate
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2021-02-11 12:40:40.119363040 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-11 12:43:51.801257430 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0-p1
|
||
|
+4.1.0-p2
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2021-02-11 12:40:40.115363084 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-11 12:43:51.801257430 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0-p1"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p2"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
diff -Naurd mpfr-4.1.0-a/src/random_deviate.c mpfr-4.1.0-b/src/random_deviate.c
|
||
|
--- mpfr-4.1.0-a/src/random_deviate.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/random_deviate.c 2021-02-11 12:43:51.789257562 +0000
|
||
|
@@ -289,6 +289,7 @@
|
||
|
mpfr_random_size_t p = mpfr_get_prec (z); /* Number of bits in result */
|
||
|
mpz_t t;
|
||
|
int inex;
|
||
|
+ mpfr_exp_t negxe;
|
||
|
|
||
|
if (n == 0)
|
||
|
{
|
||
|
@@ -370,14 +371,22 @@
|
||
|
mpz_setbit (t, 0); /* Set the trailing bit so result is always inexact */
|
||
|
if (neg)
|
||
|
mpz_neg (t, t);
|
||
|
- /* Is -x->e representable as a mpfr_exp_t? */
|
||
|
- MPFR_ASSERTN (x->e <= (mpfr_uexp_t)(-1) >> 1);
|
||
|
+ /* Portable version of the negation of x->e, with a check of overflow. */
|
||
|
+ if (MPFR_UNLIKELY (x->e > MPFR_EXP_MAX))
|
||
|
+ {
|
||
|
+ /* Overflow, except when x->e = MPFR_EXP_MAX + 1 = - MPFR_EXP_MIN. */
|
||
|
+ MPFR_ASSERTN (MPFR_EXP_MIN + MPFR_EXP_MAX == -1 &&
|
||
|
+ x->e == (mpfr_random_size_t) MPFR_EXP_MAX + 1);
|
||
|
+ negxe = MPFR_EXP_MIN;
|
||
|
+ }
|
||
|
+ else
|
||
|
+ negxe = - (mpfr_exp_t) x->e;
|
||
|
/*
|
||
|
* Let mpfr_set_z_2exp do all the work of rounding to the requested
|
||
|
* precision, setting overflow/underflow flags, and returning the right
|
||
|
* inexact value.
|
||
|
*/
|
||
|
- inex = mpfr_set_z_2exp (z, t, -x->e, rnd);
|
||
|
+ inex = mpfr_set_z_2exp (z, t, negxe, rnd);
|
||
|
mpz_clear (t);
|
||
|
return inex;
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2021-02-11 12:40:40.119363040 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-11 12:43:51.801257430 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0-p1";
|
||
|
+ return "4.1.0-p2";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-11 12:46:49.075316772 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-11 12:46:49.115316335 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+set_z_2exp-overflow
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2021-02-11 12:43:51.801257430 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-11 12:46:49.115316335 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0-p2
|
||
|
+4.1.0-p3
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2021-02-11 12:43:51.801257430 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-11 12:46:49.115316335 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0-p2"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p3"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
diff -Naurd mpfr-4.1.0-a/src/set_z_exp.c mpfr-4.1.0-b/src/set_z_exp.c
|
||
|
--- mpfr-4.1.0-a/src/set_z_exp.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/set_z_exp.c 2021-02-11 12:46:49.103316466 +0000
|
||
|
@@ -28,10 +28,11 @@
|
||
|
int
|
||
|
mpfr_set_z_2exp (mpfr_ptr f, mpz_srcptr z, mpfr_exp_t e, mpfr_rnd_t rnd_mode)
|
||
|
{
|
||
|
- mp_size_t fn, zn, dif, en;
|
||
|
+ mp_size_t fn, zn, dif;
|
||
|
int k, sign_z, inex;
|
||
|
mp_limb_t *fp, *zp;
|
||
|
- mpfr_exp_t exp;
|
||
|
+ mpfr_exp_t exp, nmax;
|
||
|
+ mpfr_uexp_t uexp;
|
||
|
|
||
|
sign_z = mpz_sgn (z);
|
||
|
if (MPFR_UNLIKELY (sign_z == 0)) /* ignore the exponent for 0 */
|
||
|
@@ -43,10 +44,15 @@
|
||
|
MPFR_ASSERTD (sign_z == MPFR_SIGN_POS || sign_z == MPFR_SIGN_NEG);
|
||
|
|
||
|
zn = ABSIZ(z); /* limb size of z */
|
||
|
- /* compute en = floor(e/GMP_NUMB_BITS) */
|
||
|
- en = (e >= 0) ? e / GMP_NUMB_BITS : (e + 1) / GMP_NUMB_BITS - 1;
|
||
|
MPFR_ASSERTD (zn >= 1);
|
||
|
- if (MPFR_UNLIKELY (zn + en > MPFR_EMAX_MAX / GMP_NUMB_BITS + 1))
|
||
|
+ nmax = MPFR_EMAX_MAX / GMP_NUMB_BITS + 1;
|
||
|
+ /* Detect early overflow with zn + en > nmax,
|
||
|
+ where en = floor(e / GMP_NUMB_BITS).
|
||
|
+ This is checked without an integer overflow (even assuming some
|
||
|
+ future version of GMP, where limitations may be removed). */
|
||
|
+ if (MPFR_UNLIKELY (e >= 0 ?
|
||
|
+ zn > nmax - e / GMP_NUMB_BITS :
|
||
|
+ zn + (e + 1) / GMP_NUMB_BITS - 1 > nmax))
|
||
|
return mpfr_overflow (f, rnd_mode, sign_z);
|
||
|
/* because zn + en >= MPFR_EMAX_MAX / GMP_NUMB_BITS + 2
|
||
|
implies (zn + en) * GMP_NUMB_BITS >= MPFR_EMAX_MAX + GMP_NUMB_BITS + 1
|
||
|
@@ -64,8 +70,21 @@
|
||
|
and exp = zn * GMP_NUMB_BITS + e - k
|
||
|
<= (zn + en) * GMP_NUMB_BITS - k + GMP_NUMB_BITS - 1
|
||
|
<= MPFR_EMAX_MAX + 2 * GMP_NUMB_BITS - 1 */
|
||
|
- exp = (mpfr_prec_t) zn * GMP_NUMB_BITS + e - k;
|
||
|
+ /* We need to compute exp = zn * GMP_NUMB_BITS + e - k with well-defined
|
||
|
+ operations (no integer overflows / no implementation-defined results).
|
||
|
+ The mathematical result of zn * GMP_NUMB_BITS may be larger than
|
||
|
+ the largest value of mpfr_exp_t while exp could still be less than
|
||
|
+ __gmpfr_emax. Thanks to early overflow detection, we can compute the
|
||
|
+ result in modular arithmetic, using mpfr_uexp_t, and convert it to
|
||
|
+ mpfr_exp_t. */
|
||
|
+ uexp = (mpfr_uexp_t) zn * GMP_NUMB_BITS + (mpfr_uexp_t) e - k;
|
||
|
+
|
||
|
+ /* Convert to signed in a portable way (see doc/README.dev).
|
||
|
+ On most platforms, this can be optimized to identity (no-op). */
|
||
|
+ exp = uexp > MPFR_EXP_MAX ? -1 - (mpfr_exp_t) ~uexp : (mpfr_exp_t) uexp;
|
||
|
+
|
||
|
/* The exponent will be exp or exp + 1 (due to rounding) */
|
||
|
+
|
||
|
if (MPFR_UNLIKELY (exp > __gmpfr_emax))
|
||
|
return mpfr_overflow (f, rnd_mode, sign_z);
|
||
|
if (MPFR_UNLIKELY (exp + 1 < __gmpfr_emin))
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2021-02-11 12:43:51.801257430 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-11 12:46:49.115316335 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0-p2";
|
||
|
+ return "4.1.0-p3";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tset_z_exp.c mpfr-4.1.0-b/tests/tset_z_exp.c
|
||
|
--- mpfr-4.1.0-a/tests/tset_z_exp.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tset_z_exp.c 2021-02-11 12:46:49.103316466 +0000
|
||
|
@@ -97,49 +97,149 @@
|
||
|
mpfr_get_si is a rather indirect test of a low level routine. */
|
||
|
|
||
|
static void
|
||
|
-check (long i, mpfr_rnd_t rnd)
|
||
|
+check (long i, mpfr_rnd_t rnd, int reduced)
|
||
|
{
|
||
|
- mpfr_t f;
|
||
|
+ mpfr_t f1, f2, f3;
|
||
|
mpz_t z;
|
||
|
- mpfr_exp_t e;
|
||
|
+ mpfr_exp_t e, old_emin, old_emax;
|
||
|
int inex;
|
||
|
+ mpfr_flags_t flags;
|
||
|
+
|
||
|
+ old_emin = mpfr_get_emin ();
|
||
|
+ old_emax = mpfr_get_emax ();
|
||
|
|
||
|
/* using CHAR_BIT * sizeof(long) bits of precision ensures that
|
||
|
mpfr_set_z_2exp is exact below */
|
||
|
- mpfr_init2 (f, CHAR_BIT * sizeof(long));
|
||
|
+ mpfr_inits2 (CHAR_BIT * sizeof(long), f1, f2, f3, (mpfr_ptr) 0);
|
||
|
mpz_init (z);
|
||
|
mpz_set_ui (z, i);
|
||
|
/* the following loop ensures that no overflow occurs */
|
||
|
do
|
||
|
e = randexp ();
|
||
|
while (e > mpfr_get_emax () - CHAR_BIT * sizeof(long));
|
||
|
- inex = mpfr_set_z_2exp (f, z, e, rnd);
|
||
|
- if (inex != 0)
|
||
|
+
|
||
|
+ mpfr_clear_flags ();
|
||
|
+ inex = mpfr_set_z_2exp (f1, z, e, rnd);
|
||
|
+ flags = __gmpfr_flags;
|
||
|
+
|
||
|
+ if (inex != 0 || flags != 0 ||
|
||
|
+ (mpfr_div_2si (f2, f1, e, rnd), mpfr_get_si (f2, MPFR_RNDZ) != i))
|
||
|
{
|
||
|
- printf ("Error in mpfr_set_z_2exp for i=%ld, e=%ld,"
|
||
|
- " wrong ternary value\n", i, (long) e);
|
||
|
- printf ("expected 0, got %d\n", inex);
|
||
|
+ printf ("Error in mpfr_set_z_2exp for i=%ld e=%" MPFR_EXP_FSPEC
|
||
|
+ "d rnd_mode=%d\n", i, (mpfr_eexp_t) e, rnd);
|
||
|
+ mpfr_set_si_2exp (f2, i, e, MPFR_RNDN);
|
||
|
+ printf ("expected "); mpfr_dump (f2);
|
||
|
+ printf ("with inex = %d and flags =", 0);
|
||
|
+ flags_out (0);
|
||
|
+ printf ("got "); mpfr_dump (f1);
|
||
|
+ printf ("with inex = %d and flags =", inex);
|
||
|
+ flags_out (flags);
|
||
|
exit (1);
|
||
|
}
|
||
|
- mpfr_div_2si (f, f, e, rnd);
|
||
|
- if (mpfr_get_si (f, MPFR_RNDZ) != i)
|
||
|
+
|
||
|
+ if (reduced)
|
||
|
{
|
||
|
- printf ("Error in mpfr_set_z_2exp for i=%ld e=", i);
|
||
|
- if (e < LONG_MIN)
|
||
|
- printf ("(<LONG_MIN)");
|
||
|
- else if (e > LONG_MAX)
|
||
|
- printf ("(>LONG_MAX)");
|
||
|
- else
|
||
|
- printf ("%ld", (long) e);
|
||
|
- printf (" rnd_mode=%d\n", rnd);
|
||
|
- printf ("expected %ld\n", i);
|
||
|
- printf ("got "); mpfr_dump (f);
|
||
|
- exit (1);
|
||
|
+ mpfr_exp_t ef, emin, emax;
|
||
|
+ int inex2, inex3;
|
||
|
+ mpfr_flags_t flags2, flags3;
|
||
|
+
|
||
|
+ ef = i == 0 ? 0 : mpfr_get_exp (f1);
|
||
|
+ for (emin = ef - 2; emin <= ef + 2; emin++)
|
||
|
+ for (emax = emin; emax <= ef + 2; emax++)
|
||
|
+ {
|
||
|
+ inex3 = mpfr_set (f3, f1, rnd);
|
||
|
+ MPFR_ASSERTN (inex3 == 0);
|
||
|
+ mpfr_set_emin (emin);
|
||
|
+ mpfr_set_emax (emax);
|
||
|
+ mpfr_clear_flags ();
|
||
|
+ inex2 = mpfr_set_z_2exp (f2, z, e, rnd);
|
||
|
+ flags2 = __gmpfr_flags;
|
||
|
+ mpfr_clear_flags ();
|
||
|
+ inex3 = mpfr_check_range (f3, 0, rnd);
|
||
|
+ flags3 = __gmpfr_flags;
|
||
|
+ if (!(mpfr_equal_p (f2, f3) &&
|
||
|
+ SAME_SIGN (inex2, inex3) &&
|
||
|
+ flags2 == flags3))
|
||
|
+ {
|
||
|
+ printf ("Error in mpfr_set_z_2exp for i=%ld e=%"
|
||
|
+ MPFR_EXP_FSPEC "d rnd_mode=%d\nand emin=%"
|
||
|
+ MPFR_EXP_FSPEC "d emax=%" MPFR_EXP_FSPEC
|
||
|
+ "d\n", i, (mpfr_eexp_t) e, rnd,
|
||
|
+ (mpfr_eexp_t) emin, (mpfr_eexp_t) emax);
|
||
|
+ printf ("expected "); mpfr_dump (f3);
|
||
|
+ printf ("with inex = %d and flags =", inex3);
|
||
|
+ flags_out (flags3);
|
||
|
+ printf ("got "); mpfr_dump (f2);
|
||
|
+ printf ("with inex = %d and flags =", inex2);
|
||
|
+ flags_out (flags2);
|
||
|
+ exit (1);
|
||
|
+ }
|
||
|
+ }
|
||
|
+ mpfr_set_emin (old_emin);
|
||
|
+ mpfr_set_emax (old_emax);
|
||
|
}
|
||
|
- mpfr_clear (f);
|
||
|
+
|
||
|
+ mpfr_clears (f1, f2, f3, (mpfr_ptr) 0);
|
||
|
mpz_clear (z);
|
||
|
}
|
||
|
|
||
|
+static void
|
||
|
+check_huge (void)
|
||
|
+{
|
||
|
+ if (getenv ("MPFR_CHECK_LARGEMEM") != NULL)
|
||
|
+ {
|
||
|
+ mpfr_t x;
|
||
|
+ mpz_t z;
|
||
|
+ long e;
|
||
|
+
|
||
|
+ /* Increase tests_memory_limit to the maximum in order to avoid
|
||
|
+ an obvious failure due to insufficient memory. */
|
||
|
+ tests_memory_limit = (size_t) -1; /* no memory limit */
|
||
|
+
|
||
|
+ mpfr_init2 (x, 32);
|
||
|
+
|
||
|
+ /* In r14140, with a 32-bit ABI (GCC's -m32):
|
||
|
+ - With UBsan (-fsanitize=undefined -fno-sanitize-recover),
|
||
|
+ this fails with:
|
||
|
+ set_z_2exp.c:71:26: runtime error: signed integer overflow:
|
||
|
+ 67108864 * 32 cannot be represented in type 'long int'
|
||
|
+ - With -D_MPFR_EXP_FORMAT=4, this fails with:
|
||
|
+ Expected 0.10001000000000000000000000000000E5
|
||
|
+ Got 0
|
||
|
+ */
|
||
|
+ mpz_init_set_ui (z, 17);
|
||
|
+ e = 0x7ffffff0;
|
||
|
+ mpz_mul_2exp (z, z, e);
|
||
|
+ mpz_add_ui (z, z, 1);
|
||
|
+ mpfr_set_z_2exp (x, z, -e, MPFR_RNDN);
|
||
|
+ if (mpfr_cmp_ui0 (x, 17) != 0)
|
||
|
+ {
|
||
|
+ printf ("Error 1 in check_huge\n");
|
||
|
+ printf ("Expected 0.10001000000000000000000000000000E5\n");
|
||
|
+ printf ("Got ");
|
||
|
+ mpfr_dump (x);
|
||
|
+ exit (1);
|
||
|
+ }
|
||
|
+ mpz_clear (z);
|
||
|
+
|
||
|
+ mpz_init_set_ui (z, 17);
|
||
|
+ mpz_mul_2exp (z, z, 0xffffffb0);
|
||
|
+ mpz_add_ui (z, z, 1);
|
||
|
+ mpfr_set_z_2exp (x, z, -1, MPFR_RNDN);
|
||
|
+ if (! MPFR_IS_INF (x) || MPFR_IS_NEG (x))
|
||
|
+ {
|
||
|
+ printf ("Error 2 in check_huge\n");
|
||
|
+ printf ("Expected @Inf@\n");
|
||
|
+ printf ("Got ");
|
||
|
+ mpfr_dump (x);
|
||
|
+ exit (1);
|
||
|
+ }
|
||
|
+ mpz_clear (z);
|
||
|
+
|
||
|
+ mpfr_clear (x);
|
||
|
+ }
|
||
|
+}
|
||
|
+
|
||
|
int
|
||
|
main (int argc, char *argv[])
|
||
|
{
|
||
|
@@ -147,11 +247,13 @@
|
||
|
|
||
|
tests_start_mpfr ();
|
||
|
|
||
|
- check (0, MPFR_RNDN);
|
||
|
+ check (0, MPFR_RNDN, 0);
|
||
|
for (j = 0; j < 200000; j++)
|
||
|
- check (randlimb () & LONG_MAX, RND_RAND ());
|
||
|
+ check (randlimb () & LONG_MAX, RND_RAND (), j < 200);
|
||
|
check0 ();
|
||
|
|
||
|
+ check_huge ();
|
||
|
+
|
||
|
tests_end_mpfr ();
|
||
|
|
||
|
return 0;
|
||
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-11 12:48:27.322243271 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-11 12:48:27.370242746 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+prototypes
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2021-02-11 12:46:49.115316335 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-11 12:48:27.370242746 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0-p3
|
||
|
+4.1.0-p4
|
||
|
diff -Naurd mpfr-4.1.0-a/src/atan.c mpfr-4.1.0-b/src/atan.c
|
||
|
--- mpfr-4.1.0-a/src/atan.c 2020-04-22 15:27:07.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/atan.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -56,7 +56,7 @@
|
||
|
};
|
||
|
|
||
|
static void
|
||
|
-set_table (mpfr_t y, const mp_limb_t x[3])
|
||
|
+set_table (mpfr_ptr y, const mp_limb_t x[3])
|
||
|
{
|
||
|
mpfr_prec_t p = MPFR_PREC(y);
|
||
|
mp_size_t n = MPFR_PREC2LIMBS(p);
|
||
|
diff -Naurd mpfr-4.1.0-a/src/const_euler.c mpfr-4.1.0-b/src/const_euler.c
|
||
|
--- mpfr-4.1.0-a/src/const_euler.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/const_euler.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -181,7 +181,7 @@
|
||
|
}
|
||
|
|
||
|
int
|
||
|
-mpfr_const_euler_internal (mpfr_t x, mpfr_rnd_t rnd)
|
||
|
+mpfr_const_euler_internal (mpfr_ptr x, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpfr_const_euler_bs_t sum;
|
||
|
mpz_t t, u, v;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/eint.c mpfr-4.1.0-b/src/eint.c
|
||
|
--- mpfr-4.1.0-a/src/eint.c 2020-03-09 15:31:45.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/eint.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -36,7 +36,7 @@
|
||
|
Return PREC(y) when the truncated series does not converge.
|
||
|
*/
|
||
|
static mpfr_exp_t
|
||
|
-mpfr_eint_aux (mpfr_t y, mpfr_srcptr x)
|
||
|
+mpfr_eint_aux (mpfr_ptr y, mpfr_srcptr x)
|
||
|
{
|
||
|
mpfr_t eps; /* dynamic (absolute) error bound on t */
|
||
|
mpfr_t erru, errs;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/erandom.c mpfr-4.1.0-b/src/erandom.c
|
||
|
--- mpfr-4.1.0-a/src/erandom.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/erandom.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -80,7 +80,7 @@
|
||
|
|
||
|
/* return an exponential random deviate with mean 1 as a MPFR */
|
||
|
int
|
||
|
-mpfr_erandom (mpfr_t z, gmp_randstate_t r, mpfr_rnd_t rnd)
|
||
|
+mpfr_erandom (mpfr_ptr z, gmp_randstate_t r, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpfr_random_deviate_t x, p, q;
|
||
|
int inex;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/fpif.c mpfr-4.1.0-b/src/fpif.c
|
||
|
--- mpfr-4.1.0-a/src/fpif.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/fpif.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -291,7 +291,8 @@
|
||
|
* until one has integer types larger than 128 bits).
|
||
|
*/
|
||
|
static unsigned char*
|
||
|
-mpfr_fpif_store_exponent (unsigned char *buffer, size_t *buffer_size, mpfr_t x)
|
||
|
+mpfr_fpif_store_exponent (unsigned char *buffer, size_t *buffer_size,
|
||
|
+ mpfr_ptr x)
|
||
|
{
|
||
|
unsigned char *result;
|
||
|
mpfr_uexp_t uexp;
|
||
|
@@ -372,7 +373,7 @@
|
||
|
* than 128 bits).
|
||
|
*/
|
||
|
static int
|
||
|
-mpfr_fpif_read_exponent_from_file (mpfr_t x, FILE * fh)
|
||
|
+mpfr_fpif_read_exponent_from_file (mpfr_ptr x, FILE * fh)
|
||
|
{
|
||
|
mpfr_exp_t exponent;
|
||
|
mpfr_uexp_t uexp;
|
||
|
@@ -456,7 +457,7 @@
|
||
|
* format
|
||
|
*/
|
||
|
static unsigned char*
|
||
|
-mpfr_fpif_store_limbs (unsigned char *buffer, size_t *buffer_size, mpfr_t x)
|
||
|
+mpfr_fpif_store_limbs (unsigned char *buffer, size_t *buffer_size, mpfr_ptr x)
|
||
|
{
|
||
|
unsigned char *result;
|
||
|
mpfr_prec_t precision;
|
||
|
@@ -492,7 +493,7 @@
|
||
|
* Assume buffer is not NULL.
|
||
|
*/
|
||
|
static void
|
||
|
-mpfr_fpif_read_limbs (mpfr_t x, unsigned char *buffer, size_t nb_byte)
|
||
|
+mpfr_fpif_read_limbs (mpfr_ptr x, unsigned char *buffer, size_t nb_byte)
|
||
|
{
|
||
|
size_t mp_bytes_per_limb;
|
||
|
size_t nb_partial_byte;
|
||
|
@@ -522,7 +523,7 @@
|
||
|
* return 0 if successful
|
||
|
*/
|
||
|
int
|
||
|
-mpfr_fpif_export (FILE *fh, mpfr_t x)
|
||
|
+mpfr_fpif_export (FILE *fh, mpfr_ptr x)
|
||
|
{
|
||
|
int status;
|
||
|
unsigned char *buf;
|
||
|
@@ -582,7 +583,7 @@
|
||
|
* Return 0 if the import was successful.
|
||
|
*/
|
||
|
int
|
||
|
-mpfr_fpif_import (mpfr_t x, FILE *fh)
|
||
|
+mpfr_fpif_import (mpfr_ptr x, FILE *fh)
|
||
|
{
|
||
|
int status;
|
||
|
mpfr_prec_t precision;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/li2.c mpfr-4.1.0-b/src/li2.c
|
||
|
--- mpfr-4.1.0-a/src/li2.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/li2.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -31,7 +31,7 @@
|
||
|
for determinating the relative error.
|
||
|
*/
|
||
|
static int
|
||
|
-li2_series (mpfr_t sum, mpfr_srcptr z, mpfr_rnd_t rnd_mode)
|
||
|
+li2_series (mpfr_ptr sum, mpfr_srcptr z, mpfr_rnd_t rnd_mode)
|
||
|
{
|
||
|
int i;
|
||
|
mpfr_t s, u, v, w;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/lngamma.c mpfr-4.1.0-b/src/lngamma.c
|
||
|
--- mpfr-4.1.0-a/src/lngamma.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/lngamma.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -31,7 +31,7 @@
|
||
|
precision should be >= 4.
|
||
|
*/
|
||
|
static void
|
||
|
-mpfr_gamma_alpha (mpfr_t s, mpfr_prec_t p)
|
||
|
+mpfr_gamma_alpha (mpfr_ptr s, mpfr_prec_t p)
|
||
|
{
|
||
|
MPFR_LOG_FUNC
|
||
|
(("p=%Pu", p),
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr-impl.h mpfr-4.1.0-b/src/mpfr-impl.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr-impl.h 2020-06-10 21:50:12.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr-impl.h 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -2474,7 +2474,8 @@
|
||
|
__MPFR_DECLSPEC mpz_srcptr mpfr_bernoulli_cache (unsigned long);
|
||
|
__MPFR_DECLSPEC void mpfr_bernoulli_freecache (void);
|
||
|
|
||
|
-__MPFR_DECLSPEC int mpfr_sincos_fast (mpfr_t, mpfr_t, mpfr_srcptr, mpfr_rnd_t);
|
||
|
+__MPFR_DECLSPEC int mpfr_sincos_fast (mpfr_ptr, mpfr_ptr, mpfr_srcptr,
|
||
|
+ mpfr_rnd_t);
|
||
|
|
||
|
__MPFR_DECLSPEC double mpfr_scale2 (double, int);
|
||
|
|
||
|
@@ -2485,7 +2486,7 @@
|
||
|
mpfr_prec_t);
|
||
|
|
||
|
__MPFR_DECLSPEC void mpfr_mpz_init (mpz_ptr);
|
||
|
-__MPFR_DECLSPEC void mpfr_mpz_init2 (mpz_t, mp_bitcnt_t);
|
||
|
+__MPFR_DECLSPEC void mpfr_mpz_init2 (mpz_ptr, mp_bitcnt_t);
|
||
|
__MPFR_DECLSPEC void mpfr_mpz_clear (mpz_ptr);
|
||
|
|
||
|
__MPFR_DECLSPEC int mpfr_odd_p (mpfr_srcptr);
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2021-02-11 12:46:49.115316335 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-11 12:48:27.366242791 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0-p3"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p4"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
@@ -781,8 +781,8 @@
|
||
|
__MPFR_DECLSPEC int mpfr_strtofr (mpfr_ptr, const char *, char **, int,
|
||
|
mpfr_rnd_t);
|
||
|
|
||
|
-__MPFR_DECLSPEC void mpfr_round_nearest_away_begin (mpfr_t);
|
||
|
-__MPFR_DECLSPEC int mpfr_round_nearest_away_end (mpfr_t, int);
|
||
|
+__MPFR_DECLSPEC void mpfr_round_nearest_away_begin (mpfr_ptr);
|
||
|
+__MPFR_DECLSPEC int mpfr_round_nearest_away_end (mpfr_ptr, int);
|
||
|
|
||
|
__MPFR_DECLSPEC size_t mpfr_custom_get_size (mpfr_prec_t);
|
||
|
__MPFR_DECLSPEC void mpfr_custom_init (void *, mpfr_prec_t);
|
||
|
@@ -1080,10 +1080,12 @@
|
||
|
#define mpfr_set_uj_2exp __gmpfr_set_uj_2exp
|
||
|
#define mpfr_get_sj __gmpfr_mpfr_get_sj
|
||
|
#define mpfr_get_uj __gmpfr_mpfr_get_uj
|
||
|
-__MPFR_DECLSPEC int mpfr_set_sj (mpfr_t, intmax_t, mpfr_rnd_t);
|
||
|
-__MPFR_DECLSPEC int mpfr_set_sj_2exp (mpfr_t, intmax_t, intmax_t, mpfr_rnd_t);
|
||
|
-__MPFR_DECLSPEC int mpfr_set_uj (mpfr_t, uintmax_t, mpfr_rnd_t);
|
||
|
-__MPFR_DECLSPEC int mpfr_set_uj_2exp (mpfr_t, uintmax_t, intmax_t, mpfr_rnd_t);
|
||
|
+__MPFR_DECLSPEC int mpfr_set_sj (mpfr_ptr, intmax_t, mpfr_rnd_t);
|
||
|
+__MPFR_DECLSPEC int mpfr_set_sj_2exp (mpfr_ptr, intmax_t, intmax_t,
|
||
|
+ mpfr_rnd_t);
|
||
|
+__MPFR_DECLSPEC int mpfr_set_uj (mpfr_ptr, uintmax_t, mpfr_rnd_t);
|
||
|
+__MPFR_DECLSPEC int mpfr_set_uj_2exp (mpfr_ptr, uintmax_t, intmax_t,
|
||
|
+ mpfr_rnd_t);
|
||
|
__MPFR_DECLSPEC intmax_t mpfr_get_sj (mpfr_srcptr, mpfr_rnd_t);
|
||
|
__MPFR_DECLSPEC uintmax_t mpfr_get_uj (mpfr_srcptr, mpfr_rnd_t);
|
||
|
|
||
|
diff -Naurd mpfr-4.1.0-a/src/nrandom.c mpfr-4.1.0-b/src/nrandom.c
|
||
|
--- mpfr-4.1.0-a/src/nrandom.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/nrandom.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -155,7 +155,7 @@
|
||
|
|
||
|
/* return a normal random deviate with mean 0 and variance 1 as a MPFR */
|
||
|
int
|
||
|
-mpfr_nrandom (mpfr_t z, gmp_randstate_t r, mpfr_rnd_t rnd)
|
||
|
+mpfr_nrandom (mpfr_ptr z, gmp_randstate_t r, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpfr_random_deviate_t x, p, q;
|
||
|
int inex;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/pool.c mpfr-4.1.0-b/src/pool.c
|
||
|
--- mpfr-4.1.0-a/src/pool.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/pool.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -35,7 +35,7 @@
|
||
|
static MPFR_THREAD_ATTR __mpz_struct mpz_tab[MPFR_POOL_NENTRIES];
|
||
|
|
||
|
MPFR_HOT_FUNCTION_ATTR void
|
||
|
-mpfr_mpz_init (mpz_t z)
|
||
|
+mpfr_mpz_init (mpz_ptr z)
|
||
|
{
|
||
|
if (MPFR_LIKELY (n_alloc > 0))
|
||
|
{
|
||
|
@@ -54,7 +54,7 @@
|
||
|
}
|
||
|
|
||
|
MPFR_HOT_FUNCTION_ATTR void
|
||
|
-mpfr_mpz_init2 (mpz_t z, mp_bitcnt_t n)
|
||
|
+mpfr_mpz_init2 (mpz_ptr z, mp_bitcnt_t n)
|
||
|
{
|
||
|
/* The condition on n is used below as the argument n will be ignored if
|
||
|
the mpz_t is obtained from the MPFR stack of previously used mpz_t.
|
||
|
@@ -82,7 +82,7 @@
|
||
|
|
||
|
|
||
|
MPFR_HOT_FUNCTION_ATTR void
|
||
|
-mpfr_mpz_clear (mpz_t z)
|
||
|
+mpfr_mpz_clear (mpz_ptr z)
|
||
|
{
|
||
|
/* We only put objects with at most MPFR_POOL_MAX_SIZE in the mpz_t pool,
|
||
|
to avoid it takes too much memory (and anyway the speedup is mainly
|
||
|
diff -Naurd mpfr-4.1.0-a/src/random_deviate.c mpfr-4.1.0-b/src/random_deviate.c
|
||
|
--- mpfr-4.1.0-a/src/random_deviate.c 2021-02-11 12:43:51.789257562 +0000
|
||
|
+++ mpfr-4.1.0-b/src/random_deviate.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -64,7 +64,7 @@
|
||
|
|
||
|
/* allocate and set to (0,1) */
|
||
|
void
|
||
|
-mpfr_random_deviate_init (mpfr_random_deviate_t x)
|
||
|
+mpfr_random_deviate_init (mpfr_random_deviate_ptr x)
|
||
|
{
|
||
|
mpz_init (x->f);
|
||
|
x->e = 0;
|
||
|
@@ -72,21 +72,22 @@
|
||
|
|
||
|
/* reset to (0,1) */
|
||
|
void
|
||
|
-mpfr_random_deviate_reset (mpfr_random_deviate_t x)
|
||
|
+mpfr_random_deviate_reset (mpfr_random_deviate_ptr x)
|
||
|
{
|
||
|
x->e = 0;
|
||
|
}
|
||
|
|
||
|
/* deallocate */
|
||
|
void
|
||
|
-mpfr_random_deviate_clear (mpfr_random_deviate_t x)
|
||
|
+mpfr_random_deviate_clear (mpfr_random_deviate_ptr x)
|
||
|
{
|
||
|
mpz_clear (x->f);
|
||
|
}
|
||
|
|
||
|
/* swap two random deviates */
|
||
|
void
|
||
|
-mpfr_random_deviate_swap (mpfr_random_deviate_t x, mpfr_random_deviate_t y)
|
||
|
+mpfr_random_deviate_swap (mpfr_random_deviate_ptr x,
|
||
|
+ mpfr_random_deviate_ptr y)
|
||
|
{
|
||
|
mpfr_random_size_t s;
|
||
|
unsigned long t;
|
||
|
@@ -107,7 +108,7 @@
|
||
|
|
||
|
/* ensure x has at least k bits */
|
||
|
static void
|
||
|
-random_deviate_generate (mpfr_random_deviate_t x, mpfr_random_size_t k,
|
||
|
+random_deviate_generate (mpfr_random_deviate_ptr x, mpfr_random_size_t k,
|
||
|
gmp_randstate_t r, mpz_t t)
|
||
|
{
|
||
|
/* Various compile time checks on mpfr_random_deviate_t */
|
||
|
@@ -223,7 +224,7 @@
|
||
|
|
||
|
/* return position of leading bit, counting from 1 */
|
||
|
static mpfr_random_size_t
|
||
|
-random_deviate_leading_bit (mpfr_random_deviate_t x, gmp_randstate_t r)
|
||
|
+random_deviate_leading_bit (mpfr_random_deviate_ptr x, gmp_randstate_t r)
|
||
|
{
|
||
|
mpfr_random_size_t l;
|
||
|
random_deviate_generate (x, W, r, 0);
|
||
|
@@ -243,7 +244,7 @@
|
||
|
|
||
|
/* return kth bit of fraction, representing 2^-k */
|
||
|
int
|
||
|
-mpfr_random_deviate_tstbit (mpfr_random_deviate_t x, mpfr_random_size_t k,
|
||
|
+mpfr_random_deviate_tstbit (mpfr_random_deviate_ptr x, mpfr_random_size_t k,
|
||
|
gmp_randstate_t r)
|
||
|
{
|
||
|
if (k == 0)
|
||
|
@@ -256,7 +257,8 @@
|
||
|
|
||
|
/* compare two random deviates, x < y */
|
||
|
int
|
||
|
-mpfr_random_deviate_less (mpfr_random_deviate_t x, mpfr_random_deviate_t y,
|
||
|
+mpfr_random_deviate_less (mpfr_random_deviate_ptr x,
|
||
|
+ mpfr_random_deviate_ptr y,
|
||
|
gmp_randstate_t r)
|
||
|
{
|
||
|
mpfr_random_size_t k = 1;
|
||
|
@@ -280,7 +282,7 @@
|
||
|
/* set mpfr_t z = (neg ? -1 : 1) * (n + x) */
|
||
|
int
|
||
|
mpfr_random_deviate_value (int neg, unsigned long n,
|
||
|
- mpfr_random_deviate_t x, mpfr_t z,
|
||
|
+ mpfr_random_deviate_ptr x, mpfr_ptr z,
|
||
|
gmp_randstate_t r, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
/* r is used to add as many bits as necessary to match the precision of z */
|
||
|
diff -Naurd mpfr-4.1.0-a/src/random_deviate.h mpfr-4.1.0-b/src/random_deviate.h
|
||
|
--- mpfr-4.1.0-a/src/random_deviate.h 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/random_deviate.h 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -76,7 +76,7 @@
|
||
|
/* set mpfr_t z = (neg ? -1 : 1) * (n + x) */
|
||
|
__MPFR_DECLSPEC int
|
||
|
mpfr_random_deviate_value (int, unsigned long,
|
||
|
- mpfr_random_deviate_ptr, mpfr_t,
|
||
|
+ mpfr_random_deviate_ptr, mpfr_ptr,
|
||
|
gmp_randstate_t, mpfr_rnd_t);
|
||
|
|
||
|
#if defined(__cplusplus)
|
||
|
diff -Naurd mpfr-4.1.0-a/src/rndna.c mpfr-4.1.0-b/src/rndna.c
|
||
|
--- mpfr-4.1.0-a/src/rndna.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/rndna.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -61,7 +61,7 @@
|
||
|
and prepares rop to give it one more bit of precision
|
||
|
and to save its old value within it. */
|
||
|
void
|
||
|
-mpfr_round_nearest_away_begin (mpfr_t rop)
|
||
|
+mpfr_round_nearest_away_begin (mpfr_ptr rop)
|
||
|
{
|
||
|
mpfr_t tmp;
|
||
|
mp_size_t xsize;
|
||
|
@@ -129,7 +129,7 @@
|
||
|
copying it back the result of the applied function
|
||
|
and performing additional roundings. */
|
||
|
int
|
||
|
-mpfr_round_nearest_away_end (mpfr_t rop, int inex)
|
||
|
+mpfr_round_nearest_away_end (mpfr_ptr rop, int inex)
|
||
|
{
|
||
|
mpfr_t tmp;
|
||
|
mp_size_t xsize;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/set_sj.c mpfr-4.1.0-b/src/set_sj.c
|
||
|
--- mpfr-4.1.0-a/src/set_sj.c 2020-06-01 10:39:52.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/set_sj.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -26,13 +26,13 @@
|
||
|
#ifdef _MPFR_H_HAVE_INTMAX_T
|
||
|
|
||
|
int
|
||
|
-mpfr_set_sj (mpfr_t x, intmax_t j, mpfr_rnd_t rnd)
|
||
|
+mpfr_set_sj (mpfr_ptr x, intmax_t j, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
return mpfr_set_sj_2exp (x, j, 0, rnd);
|
||
|
}
|
||
|
|
||
|
int
|
||
|
-mpfr_set_sj_2exp (mpfr_t x, intmax_t j, intmax_t e, mpfr_rnd_t rnd)
|
||
|
+mpfr_set_sj_2exp (mpfr_ptr x, intmax_t j, intmax_t e, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
if (j >= 0)
|
||
|
return mpfr_set_uj_2exp (x, j, e, rnd);
|
||
|
diff -Naurd mpfr-4.1.0-a/src/set_str.c mpfr-4.1.0-b/src/set_str.c
|
||
|
--- mpfr-4.1.0-a/src/set_str.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/set_str.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -23,7 +23,7 @@
|
||
|
#include "mpfr-impl.h"
|
||
|
|
||
|
int
|
||
|
-mpfr_set_str (mpfr_t x, const char *str, int base, mpfr_rnd_t rnd)
|
||
|
+mpfr_set_str (mpfr_ptr x, const char *str, int base, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
char *p;
|
||
|
|
||
|
diff -Naurd mpfr-4.1.0-a/src/set_uj.c mpfr-4.1.0-b/src/set_uj.c
|
||
|
--- mpfr-4.1.0-a/src/set_uj.c 2020-06-01 10:39:52.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/set_uj.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -29,13 +29,13 @@
|
||
|
#define uintmaxpml (sizeof(uintmax_t) / sizeof(mp_limb_t))
|
||
|
|
||
|
int
|
||
|
-mpfr_set_uj (mpfr_t x, uintmax_t j, mpfr_rnd_t rnd)
|
||
|
+mpfr_set_uj (mpfr_ptr x, uintmax_t j, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
return mpfr_set_uj_2exp (x, j, 0, rnd);
|
||
|
}
|
||
|
|
||
|
int
|
||
|
-mpfr_set_uj_2exp (mpfr_t x, uintmax_t j, intmax_t e, mpfr_rnd_t rnd)
|
||
|
+mpfr_set_uj_2exp (mpfr_ptr x, uintmax_t j, intmax_t e, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
int cnt, inex;
|
||
|
mp_size_t i, k;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/sin_cos.c mpfr-4.1.0-b/src/sin_cos.c
|
||
|
--- mpfr-4.1.0-a/src/sin_cos.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/sin_cos.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -463,7 +463,7 @@
|
||
|
Return err such that the relative error is bounded by 2^err ulps.
|
||
|
*/
|
||
|
static int
|
||
|
-sincos_aux (mpfr_t s, mpfr_t c, mpfr_srcptr x, mpfr_rnd_t rnd_mode)
|
||
|
+sincos_aux (mpfr_ptr s, mpfr_ptr c, mpfr_srcptr x, mpfr_rnd_t rnd_mode)
|
||
|
{
|
||
|
mpfr_prec_t prec_s, sh;
|
||
|
mpz_t Q, S, C, Q2, S2, C2, y;
|
||
|
@@ -577,7 +577,7 @@
|
||
|
Assumes s differs from c.
|
||
|
*/
|
||
|
int
|
||
|
-mpfr_sincos_fast (mpfr_t s, mpfr_t c, mpfr_srcptr x, mpfr_rnd_t rnd)
|
||
|
+mpfr_sincos_fast (mpfr_ptr s, mpfr_ptr c, mpfr_srcptr x, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
int inexs, inexc;
|
||
|
mpfr_t x_red, ts, tc;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/strtofr.c mpfr-4.1.0-b/src/strtofr.c
|
||
|
--- mpfr-4.1.0-a/src/strtofr.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/strtofr.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -226,7 +226,7 @@
|
||
|
BUT if it returns 0 (NAN or INF), the ternary value is also '0'
|
||
|
(ie NAN and INF are exact) */
|
||
|
static int
|
||
|
-parse_string (mpfr_t x, struct parsed_string *pstr,
|
||
|
+parse_string (mpfr_ptr x, struct parsed_string *pstr,
|
||
|
const char **string, int base)
|
||
|
{
|
||
|
const char *str = *string;
|
||
|
@@ -451,7 +451,7 @@
|
||
|
and the precision of x.
|
||
|
Returns the ternary value. */
|
||
|
static int
|
||
|
-parsed_string_to_mpfr (mpfr_t x, struct parsed_string *pstr, mpfr_rnd_t rnd)
|
||
|
+parsed_string_to_mpfr (mpfr_ptr x, struct parsed_string *pstr, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpfr_prec_t precx, prec, ysize_bits, pstr_size;
|
||
|
mpfr_exp_t exp;
|
||
|
@@ -934,7 +934,7 @@
|
||
|
}
|
||
|
|
||
|
int
|
||
|
-mpfr_strtofr (mpfr_t x, const char *string, char **end, int base,
|
||
|
+mpfr_strtofr (mpfr_ptr x, const char *string, char **end, int base,
|
||
|
mpfr_rnd_t rnd)
|
||
|
{
|
||
|
int res;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/vasprintf.c mpfr-4.1.0-b/src/vasprintf.c
|
||
|
--- mpfr-4.1.0-a/src/vasprintf.c 2020-06-01 10:39:52.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/vasprintf.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -963,7 +963,7 @@
|
||
|
#define NDIGITS 8
|
||
|
|
||
|
MPFR_RETURNS_NONNULL static char *
|
||
|
-mpfr_get_str_wrapper (mpfr_exp_t *exp, int base, size_t n, const mpfr_t op,
|
||
|
+mpfr_get_str_wrapper (mpfr_exp_t *exp, int base, size_t n, mpfr_srcptr op,
|
||
|
const struct printf_spec spec)
|
||
|
{
|
||
|
size_t ndigits;
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2021-02-11 12:46:49.115316335 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-11 12:48:27.370242746 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0-p3";
|
||
|
+ return "4.1.0-p4";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/src/zeta.c mpfr-4.1.0-b/src/zeta.c
|
||
|
--- mpfr-4.1.0-a/src/zeta.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/zeta.c 2021-02-11 12:48:27.354242922 +0000
|
||
|
@@ -35,7 +35,7 @@
|
||
|
sum(tc[i]*product((s+2j)*(s+2j-1)/n^2,j=1..i-1), i=1..p)*s*n^(-s-1)
|
||
|
*/
|
||
|
static void
|
||
|
-mpfr_zeta_part_b (mpfr_t b, mpfr_srcptr s, int n, int p, mpfr_t *tc)
|
||
|
+mpfr_zeta_part_b (mpfr_ptr b, mpfr_srcptr s, int n, int p, mpfr_t *tc)
|
||
|
{
|
||
|
mpfr_t s1, d, u;
|
||
|
unsigned long n2;
|
||
|
@@ -130,7 +130,7 @@
|
||
|
n - an integer
|
||
|
Output: sum - a floating-point number approximating sum(1/i^s, i=1..n-1) */
|
||
|
static void
|
||
|
-mpfr_zeta_part_a (mpfr_t sum, mpfr_srcptr s, int n)
|
||
|
+mpfr_zeta_part_a (mpfr_ptr sum, mpfr_srcptr s, int n)
|
||
|
{
|
||
|
mpfr_t u, s1;
|
||
|
int i;
|
||
|
@@ -158,7 +158,7 @@
|
||
|
Output: z - Zeta(s) rounded to the precision of z with direction rnd_mode
|
||
|
*/
|
||
|
static int
|
||
|
-mpfr_zeta_pos (mpfr_t z, mpfr_srcptr s, mpfr_rnd_t rnd_mode)
|
||
|
+mpfr_zeta_pos (mpfr_ptr z, mpfr_srcptr s, mpfr_rnd_t rnd_mode)
|
||
|
{
|
||
|
mpfr_t b, c, z_pre, f, s1;
|
||
|
double beta, sd, dnep;
|
||
|
@@ -356,8 +356,8 @@
|
||
|
At input, p is Pi rounded down.
|
||
|
The comments in the code are for rnd = RNDD. */
|
||
|
static void
|
||
|
-mpfr_reflection_overflow (mpfr_t z, mpfr_t s1, const mpfr_t s, mpfr_t y,
|
||
|
- mpfr_t p, mpfr_rnd_t rnd)
|
||
|
+mpfr_reflection_overflow (mpfr_ptr z, mpfr_ptr s1, mpfr_srcptr s, mpfr_ptr y,
|
||
|
+ mpfr_ptr p, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpz_t sint;
|
||
|
|
||
|
@@ -432,7 +432,7 @@
|
||
|
}
|
||
|
|
||
|
int
|
||
|
-mpfr_zeta (mpfr_t z, mpfr_srcptr s, mpfr_rnd_t rnd_mode)
|
||
|
+mpfr_zeta (mpfr_ptr z, mpfr_srcptr s, mpfr_rnd_t rnd_mode)
|
||
|
{
|
||
|
mpfr_t z_pre, s1, y, p;
|
||
|
long add;
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tcmp2.c mpfr-4.1.0-b/tests/tcmp2.c
|
||
|
--- mpfr-4.1.0-a/tests/tcmp2.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tcmp2.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -24,7 +24,7 @@
|
||
|
|
||
|
/* set bit n of x to b, where bit 0 is the most significant one */
|
||
|
static void
|
||
|
-set_bit (mpfr_t x, unsigned int n, int b)
|
||
|
+set_bit (mpfr_ptr x, unsigned int n, int b)
|
||
|
{
|
||
|
unsigned l;
|
||
|
mp_size_t xn;
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tdiv.c mpfr-4.1.0-b/tests/tdiv.c
|
||
|
--- mpfr-4.1.0-a/tests/tdiv.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tdiv.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -369,7 +369,7 @@
|
||
|
/* given y = o(x/u), x, u, find the inexact flag by
|
||
|
multiplying y by u */
|
||
|
static int
|
||
|
-get_inexact (mpfr_t y, mpfr_t x, mpfr_t u)
|
||
|
+get_inexact (mpfr_ptr y, mpfr_ptr x, mpfr_ptr u)
|
||
|
{
|
||
|
mpfr_t xx;
|
||
|
int inex;
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/teq.c mpfr-4.1.0-b/tests/teq.c
|
||
|
--- mpfr-4.1.0-a/tests/teq.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/teq.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -23,7 +23,7 @@
|
||
|
#include "mpfr-test.h"
|
||
|
|
||
|
static void
|
||
|
-teq (mpfr_t x)
|
||
|
+teq (mpfr_ptr x)
|
||
|
{
|
||
|
mpfr_t y;
|
||
|
unsigned long k, px, mx;
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/terandom_chisq.c mpfr-4.1.0-b/tests/terandom_chisq.c
|
||
|
--- mpfr-4.1.0-a/tests/terandom_chisq.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/terandom_chisq.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -26,7 +26,7 @@
|
||
|
* exponential distribution. We only take differences of this function so the
|
||
|
* offset doesn't matter; here Phi(0) = 0. */
|
||
|
static void
|
||
|
-exponential_cumulative (mpfr_t z, mpfr_t x, mpfr_rnd_t rnd)
|
||
|
+exponential_cumulative (mpfr_ptr z, mpfr_ptr x, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpfr_neg (z, x, rnd);
|
||
|
mpfr_expm1 (z, z, rnd);
|
||
|
@@ -43,7 +43,7 @@
|
||
|
* TAOCP, Vol 2, 3.3.1, Table 1. It more accurate than the similar formula,
|
||
|
* DLMF 8.11.10. */
|
||
|
static void
|
||
|
-chisq_prob (mpfr_t q, long nu, mpfr_t chisqp)
|
||
|
+chisq_prob (mpfr_ptr q, long nu, mpfr_ptr chisqp)
|
||
|
{
|
||
|
mpfr_t t;
|
||
|
mpfr_rnd_t rnd;
|
||
|
@@ -170,7 +170,7 @@
|
||
|
* this function. low precision means prec = 2, 3, or 4. High values of
|
||
|
* precision will result in integer overflow. */
|
||
|
static long
|
||
|
-sequential (mpfr_t x)
|
||
|
+sequential (mpfr_ptr x)
|
||
|
{
|
||
|
long expt, prec;
|
||
|
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tfmma.c mpfr-4.1.0-b/tests/tfmma.c
|
||
|
--- mpfr-4.1.0-a/tests/tfmma.c 2020-03-24 13:47:38.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tfmma.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -24,7 +24,7 @@
|
||
|
|
||
|
/* check both mpfr_fmma and mpfr_fmms */
|
||
|
static void
|
||
|
-random_test (mpfr_t a, mpfr_t b, mpfr_t c, mpfr_t d, mpfr_rnd_t rnd)
|
||
|
+random_test (mpfr_ptr a, mpfr_ptr b, mpfr_ptr c, mpfr_ptr d, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpfr_t ref, res, ab, cd;
|
||
|
int inex_ref, inex_res;
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tfmod.c mpfr-4.1.0-b/tests/tfmod.c
|
||
|
--- mpfr-4.1.0-a/tests/tfmod.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tfmod.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -62,8 +62,8 @@
|
||
|
}
|
||
|
|
||
|
static void
|
||
|
-test_failed (mpfr_t erem, mpfr_t grem, int eret, int gret, mpfr_t x, mpfr_t y,
|
||
|
- mpfr_rnd_t rnd)
|
||
|
+test_failed (mpfr_ptr erem, mpfr_ptr grem, int eret, int gret,
|
||
|
+ mpfr_ptr x, mpfr_ptr y, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
printf ("error: mpfr_fmod (r, x, y, rnd)\n x = ");
|
||
|
mpfr_out_str (stdout, 10, 0, x, MPFR_RNDD);
|
||
|
@@ -83,7 +83,7 @@
|
||
|
}
|
||
|
|
||
|
static void
|
||
|
-check (mpfr_t r0, mpfr_t x, mpfr_t y, mpfr_rnd_t rnd)
|
||
|
+check (mpfr_ptr r0, mpfr_ptr x, mpfr_ptr y, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
int inex0, inex1;
|
||
|
mpfr_t r1;
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tfprintf.c mpfr-4.1.0-b/tests/tfprintf.c
|
||
|
--- mpfr-4.1.0-a/tests/tfprintf.c 2020-06-01 10:39:52.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tfprintf.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -65,7 +65,7 @@
|
||
|
const int prec_max_printf = 5000;
|
||
|
|
||
|
static void
|
||
|
-check (FILE *fout, const char *fmt, mpfr_t x)
|
||
|
+check (FILE *fout, const char *fmt, mpfr_ptr x)
|
||
|
{
|
||
|
if (mpfr_fprintf (fout, fmt, x) == -1)
|
||
|
{
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tgamma.c mpfr-4.1.0-b/tests/tgamma.c
|
||
|
--- mpfr-4.1.0-a/tests/tgamma.c 2020-06-01 00:15:37.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tgamma.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -890,7 +890,7 @@
|
||
|
computing with a working precision p2. Assume that x is not an
|
||
|
integer <= 2. */
|
||
|
static void
|
||
|
-exp_lgamma (mpfr_t x, mpfr_prec_t p1, mpfr_prec_t p2)
|
||
|
+exp_lgamma (mpfr_ptr x, mpfr_prec_t p1, mpfr_prec_t p2)
|
||
|
{
|
||
|
mpfr_t yd, yu, zd, zu;
|
||
|
int inexd, inexu, sign;
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tnrandom_chisq.c mpfr-4.1.0-b/tests/tnrandom_chisq.c
|
||
|
--- mpfr-4.1.0-a/tests/tnrandom_chisq.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tnrandom_chisq.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -26,7 +26,7 @@
|
||
|
* for the normal distribution. We only take differences of this function so
|
||
|
* the offset doesn't matter; here Phi(0) = 0. */
|
||
|
static void
|
||
|
-normal_cumulative (mpfr_t z, mpfr_t x, mpfr_rnd_t rnd)
|
||
|
+normal_cumulative (mpfr_ptr z, mpfr_ptr x, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpfr_sqrt_ui (z, 2, rnd);
|
||
|
mpfr_div (z, x, z, rnd);
|
||
|
@@ -44,7 +44,7 @@
|
||
|
* TAOCP, Vol 2, 3.3.1, Table 1. It more accurate than the similar formula,
|
||
|
* DLMF 8.11.10. */
|
||
|
static void
|
||
|
-chisq_prob (mpfr_t q, long nu, mpfr_t chisqp)
|
||
|
+chisq_prob (mpfr_ptr q, long nu, mpfr_ptr chisqp)
|
||
|
{
|
||
|
mpfr_t t;
|
||
|
mpfr_rnd_t rnd;
|
||
|
@@ -166,7 +166,7 @@
|
||
|
* this function. low precision means prec = 2, 3, or 4. High values of
|
||
|
* precision will result in integer overflow. */
|
||
|
static long
|
||
|
-sequential (mpfr_t x)
|
||
|
+sequential (mpfr_ptr x)
|
||
|
{
|
||
|
long expt, prec;
|
||
|
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tprintf.c mpfr-4.1.0-b/tests/tprintf.c
|
||
|
--- mpfr-4.1.0-a/tests/tprintf.c 2020-06-01 10:39:52.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tprintf.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -74,7 +74,7 @@
|
||
|
int stdout_redirect;
|
||
|
|
||
|
static void
|
||
|
-check (const char *fmt, mpfr_t x)
|
||
|
+check (const char *fmt, mpfr_ptr x)
|
||
|
{
|
||
|
if (mpfr_printf (fmt, x) == -1)
|
||
|
{
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/trint.c mpfr-4.1.0-b/tests/trint.c
|
||
|
--- mpfr-4.1.0-a/tests/trint.c 2020-02-12 13:04:50.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/trint.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -367,7 +367,7 @@
|
||
|
#endif
|
||
|
|
||
|
static void
|
||
|
-err (const char *str, mp_size_t s, mpfr_t x, mpfr_t y, mpfr_prec_t p,
|
||
|
+err (const char *str, mp_size_t s, mpfr_ptr x, mpfr_ptr y, mpfr_prec_t p,
|
||
|
mpfr_rnd_t r, int trint, int inexact)
|
||
|
{
|
||
|
printf ("Error: %s\ns = %u, p = %u, r = %s, trint = %d, inexact = %d\nx = ",
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tsinh_cosh.c mpfr-4.1.0-b/tests/tsinh_cosh.c
|
||
|
--- mpfr-4.1.0-a/tests/tsinh_cosh.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tsinh_cosh.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -23,7 +23,7 @@
|
||
|
#include "mpfr-test.h"
|
||
|
|
||
|
static void
|
||
|
-failed (mpfr_t x, mpfr_t esh, mpfr_t gsh, mpfr_t ech, mpfr_t gch)
|
||
|
+failed (mpfr_ptr x, mpfr_ptr esh, mpfr_ptr gsh, mpfr_ptr ech, mpfr_ptr gch)
|
||
|
{
|
||
|
printf ("error : mpfr_sinh_cosh (x) x = ");
|
||
|
mpfr_out_str (stdout, 10, 0, x, MPFR_RNDD);
|
||
|
@@ -43,7 +43,7 @@
|
||
|
|
||
|
/* check against sinh, cosh */
|
||
|
static void
|
||
|
-check (mpfr_t x, mpfr_rnd_t rnd)
|
||
|
+check (mpfr_ptr x, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
mpfr_t s, c, sx, cx;
|
||
|
int isc, is, ic;
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tsqr.c mpfr-4.1.0-b/tests/tsqr.c
|
||
|
--- mpfr-4.1.0-a/tests/tsqr.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tsqr.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -33,7 +33,7 @@
|
||
|
|
||
|
static void
|
||
|
error1 (mpfr_rnd_t rnd, mpfr_prec_t prec,
|
||
|
- mpfr_t in, mpfr_t outmul, mpfr_t outsqr)
|
||
|
+ mpfr_t in, mpfr_ptr outmul, mpfr_ptr outsqr)
|
||
|
{
|
||
|
printf("ERROR: for %s and prec=%lu\nINPUT=", mpfr_print_rnd_mode(rnd),
|
||
|
(unsigned long) prec);
|
||
|
@@ -44,7 +44,7 @@
|
||
|
}
|
||
|
|
||
|
static void
|
||
|
-error2 (mpfr_rnd_t rnd, mpfr_prec_t prec, mpfr_t in, mpfr_t out,
|
||
|
+error2 (mpfr_rnd_t rnd, mpfr_prec_t prec, mpfr_ptr in, mpfr_ptr out,
|
||
|
int inexactmul, int inexactsqr)
|
||
|
{
|
||
|
printf("ERROR: for %s and prec=%lu\nINPUT=", mpfr_print_rnd_mode(rnd),
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tsum.c mpfr-4.1.0-b/tests/tsum.c
|
||
|
--- mpfr-4.1.0-a/tests/tsum.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tsum.c 2021-02-11 12:48:27.350242965 +0000
|
||
|
@@ -59,7 +59,7 @@
|
||
|
}
|
||
|
|
||
|
static void
|
||
|
-get_exact_sum (mpfr_t sum, mpfr_t *tab, int n)
|
||
|
+get_exact_sum (mpfr_ptr sum, mpfr_t *tab, int n)
|
||
|
{
|
||
|
int i;
|
||
|
|
||
|
@@ -1198,7 +1198,7 @@
|
||
|
}
|
||
|
|
||
|
static int
|
||
|
-mpfr_sum_naive (mpfr_t s, mpfr_t *x, int n, mpfr_rnd_t rnd)
|
||
|
+mpfr_sum_naive (mpfr_ptr s, mpfr_t *x, int n, mpfr_rnd_t rnd)
|
||
|
{
|
||
|
int ret, i;
|
||
|
switch (n)
|
||
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-11 12:50:22.384987438 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-11 12:50:22.424987002 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+digamma-hugemem
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2021-02-11 12:48:27.370242746 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-11 12:50:22.424987002 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0-p4
|
||
|
+4.1.0-p5
|
||
|
diff -Naurd mpfr-4.1.0-a/src/digamma.c mpfr-4.1.0-b/src/digamma.c
|
||
|
--- mpfr-4.1.0-a/src/digamma.c 2020-06-18 17:17:18.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/digamma.c 2021-02-11 12:50:22.412987133 +0000
|
||
|
@@ -214,19 +214,27 @@
|
||
|
(("x[%Pu]=%.*Rg rnd=%d", mpfr_get_prec(x), mpfr_log_prec, x, rnd_mode),
|
||
|
("y[%Pu]=%.*Rg inexact=%d", mpfr_get_prec(y), mpfr_log_prec, y, inex));
|
||
|
|
||
|
- /* compute a precision q such that x+1 is exact */
|
||
|
- if (MPFR_PREC(x) < MPFR_GET_EXP(x))
|
||
|
- q = MPFR_EXP(x);
|
||
|
- else
|
||
|
- q = MPFR_PREC(x) + 1;
|
||
|
-
|
||
|
- /* for very large x, use |digamma(x) - log(x)| < 1/x < 2^(1-EXP(x)) */
|
||
|
- if (MPFR_PREC(y) + 10 < MPFR_EXP(x))
|
||
|
+ /* For very large x, use |digamma(x) - log(x)| < 1/x < 2^(1-EXP(x)).
|
||
|
+ However, for a fixed value of GUARD, MPFR_CAN_ROUND() might fail
|
||
|
+ with probability 1/2^GUARD, in which case the default code will
|
||
|
+ fail since it requires x+1 to be exact, thus a huge precision if
|
||
|
+ x is huge. There are two workarounds:
|
||
|
+ * either perform a Ziv's loop, by increasing GUARD at each step.
|
||
|
+ However, this might fail if x is moderately large, in which case
|
||
|
+ more terms of the asymptotic expansion would be needed.
|
||
|
+ * implement a full asymptotic expansion (with Ziv's loop). */
|
||
|
+#define GUARD 30
|
||
|
+ if (MPFR_PREC(y) + GUARD < MPFR_EXP(x))
|
||
|
{
|
||
|
/* this ensures EXP(x) >= 3, thus x >= 4, thus log(x) > 1 */
|
||
|
- mpfr_init2 (t, MPFR_PREC(y) + 10);
|
||
|
- mpfr_log (t, x, MPFR_RNDZ);
|
||
|
- if (MPFR_CAN_ROUND (t, MPFR_PREC(y) + 10, MPFR_PREC(y), rnd_mode))
|
||
|
+ mpfr_init2 (t, MPFR_PREC(y) + GUARD);
|
||
|
+ mpfr_log (t, x, MPFR_RNDN);
|
||
|
+ /* |t - digamma(x)| <= 1/2*ulp(t) + |digamma(x) - log(x)|
|
||
|
+ <= 1/2*ulp(t) + 2^(1-EXP(x))
|
||
|
+ <= 1/2*ulp(t) + 2^(-PREC(y)-GUARD)
|
||
|
+ <= ulp(t)
|
||
|
+ since |t| >= 1 thus ulp(t) >= 2^(1-PREC(y)-GUARD) */
|
||
|
+ if (MPFR_CAN_ROUND (t, MPFR_PREC(y) + GUARD, MPFR_PREC(y), rnd_mode))
|
||
|
{
|
||
|
inex = mpfr_set (y, t, rnd_mode);
|
||
|
mpfr_clear (t);
|
||
|
@@ -235,6 +243,21 @@
|
||
|
mpfr_clear (t);
|
||
|
}
|
||
|
|
||
|
+ /* compute a precision q such that x+1 is exact */
|
||
|
+ if (MPFR_PREC(x) < MPFR_GET_EXP(x))
|
||
|
+ {
|
||
|
+ /* The goal of the first assertion is to let the compiler ignore
|
||
|
+ the second one when MPFR_EMAX_MAX <= MPFR_PREC_MAX. */
|
||
|
+ MPFR_ASSERTD (MPFR_EXP(x) <= MPFR_EMAX_MAX);
|
||
|
+ MPFR_ASSERTN (MPFR_EXP(x) <= MPFR_PREC_MAX);
|
||
|
+ q = MPFR_EXP(x);
|
||
|
+ }
|
||
|
+ else
|
||
|
+ q = MPFR_PREC(x) + 1;
|
||
|
+
|
||
|
+ /* FIXME: q can be much too large, e.g. equal to the maximum exponent! */
|
||
|
+ MPFR_LOG_MSG (("q=%Pu\n", q));
|
||
|
+
|
||
|
mpfr_init2 (x_plus_j, q);
|
||
|
|
||
|
mpfr_init2 (t, p);
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2021-02-11 12:48:27.366242791 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-11 12:50:22.424987002 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0-p4"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p5"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2021-02-11 12:48:27.370242746 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-11 12:50:22.424987002 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0-p4";
|
||
|
+ return "4.1.0-p5";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tdigamma.c mpfr-4.1.0-b/tests/tdigamma.c
|
||
|
--- mpfr-4.1.0-a/tests/tdigamma.c 2020-06-18 17:17:18.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tdigamma.c 2021-02-11 12:50:22.412987133 +0000
|
||
|
@@ -49,12 +49,54 @@
|
||
|
mpfr_clear (y);
|
||
|
}
|
||
|
|
||
|
+/* With some GMP_CHECK_RANDOMIZE values, test_generic triggers an error
|
||
|
+ tests_addsize(): too much memory (576460752303432776 bytes)
|
||
|
+ Each time on prec = 200, n = 3, xprec = 140.
|
||
|
+ The following test is a more general testcase.
|
||
|
+*/
|
||
|
+static void
|
||
|
+bug20210206 (void)
|
||
|
+{
|
||
|
+#define NPREC 4
|
||
|
+ mpfr_t x, y[NPREC], z;
|
||
|
+ mpfr_exp_t emin, emax;
|
||
|
+ int i, precx, precy[NPREC] = { 200, 400, 520, 1416 };
|
||
|
+
|
||
|
+ emin = mpfr_get_emin ();
|
||
|
+ emax = mpfr_get_emax ();
|
||
|
+ set_emin (MPFR_EMIN_MIN);
|
||
|
+ set_emax (MPFR_EMAX_MAX);
|
||
|
+
|
||
|
+ for (i = 0; i < NPREC; i++)
|
||
|
+ mpfr_init2 (y[i], precy[i]);
|
||
|
+ mpfr_init2 (z, precy[0]);
|
||
|
+
|
||
|
+ for (precx = MPFR_PREC_MIN; precx < 150; precx++)
|
||
|
+ {
|
||
|
+ mpfr_init2 (x, precx);
|
||
|
+ mpfr_setmax (x, __gmpfr_emax);
|
||
|
+ for (i = 0; i < NPREC; i++)
|
||
|
+ mpfr_digamma (y[i], x, MPFR_RNDA);
|
||
|
+ mpfr_set (z, y[1], MPFR_RNDA);
|
||
|
+ MPFR_ASSERTN (mpfr_equal_p (y[0], z));
|
||
|
+ mpfr_clear (x);
|
||
|
+ }
|
||
|
+
|
||
|
+ for (i = 0; i < NPREC; i++)
|
||
|
+ mpfr_clear (y[i]);
|
||
|
+ mpfr_clear (z);
|
||
|
+
|
||
|
+ set_emin (emin);
|
||
|
+ set_emax (emax);
|
||
|
+}
|
||
|
+
|
||
|
int
|
||
|
main (int argc, char *argv[])
|
||
|
{
|
||
|
tests_start_mpfr ();
|
||
|
|
||
|
special ();
|
||
|
+ bug20210206 ();
|
||
|
|
||
|
test_generic (MPFR_PREC_MIN, 200, 20);
|
||
|
|
||
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-11 12:52:52.519350662 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-11 12:52:52.563350183 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+digamma-interm-zero
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2021-02-11 12:50:22.424987002 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-11 12:52:52.563350183 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0-p5
|
||
|
+4.1.0-p6
|
||
|
diff -Naurd mpfr-4.1.0-a/src/digamma.c mpfr-4.1.0-b/src/digamma.c
|
||
|
--- mpfr-4.1.0-a/src/digamma.c 2021-02-11 12:50:22.412987133 +0000
|
||
|
+++ mpfr-4.1.0-b/src/digamma.c 2021-02-11 12:52:52.547350357 +0000
|
||
|
@@ -296,21 +296,26 @@
|
||
|
errt = mpfr_digamma_approx (t, x_plus_j);
|
||
|
expt = MPFR_GET_EXP (t);
|
||
|
mpfr_sub (t, t, u, MPFR_RNDN);
|
||
|
- if (MPFR_GET_EXP (t) < expt)
|
||
|
- errt += expt - MPFR_EXP(t);
|
||
|
- /* Warning: if u is zero (which happens when x_plus_j >= min at the
|
||
|
- beginning of the while loop above), EXP(u) is not defined.
|
||
|
- In this case we have no error from u. */
|
||
|
- if (MPFR_NOTZERO(u) && MPFR_GET_EXP (t) < MPFR_GET_EXP (u))
|
||
|
- erru += MPFR_EXP(u) - MPFR_EXP(t);
|
||
|
- if (errt > erru)
|
||
|
- errt = errt + 1;
|
||
|
- else if (errt == erru)
|
||
|
- errt = errt + 2;
|
||
|
- else
|
||
|
- errt = erru + 1;
|
||
|
- if (MPFR_CAN_ROUND (t, p - errt, MPFR_PREC(y), rnd_mode))
|
||
|
- break;
|
||
|
+ /* Warning! t may be zero (more likely in small precision). Note
|
||
|
+ that in this case, this is an exact zero, not an underflow. */
|
||
|
+ if (MPFR_NOTZERO(t))
|
||
|
+ {
|
||
|
+ if (MPFR_GET_EXP (t) < expt)
|
||
|
+ errt += expt - MPFR_EXP(t);
|
||
|
+ /* Warning: if u is zero (which happens when x_plus_j >= min at the
|
||
|
+ beginning of the while loop above), EXP(u) is not defined.
|
||
|
+ In this case we have no error from u. */
|
||
|
+ if (MPFR_NOTZERO(u) && MPFR_GET_EXP (t) < MPFR_GET_EXP (u))
|
||
|
+ erru += MPFR_EXP(u) - MPFR_EXP(t);
|
||
|
+ if (errt > erru)
|
||
|
+ errt = errt + 1;
|
||
|
+ else if (errt == erru)
|
||
|
+ errt = errt + 2;
|
||
|
+ else
|
||
|
+ errt = erru + 1;
|
||
|
+ if (MPFR_CAN_ROUND (t, p - errt, MPFR_PREC(y), rnd_mode))
|
||
|
+ break;
|
||
|
+ }
|
||
|
MPFR_ZIV_NEXT (loop, p);
|
||
|
mpfr_set_prec (t, p);
|
||
|
mpfr_set_prec (u, p);
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2021-02-11 12:50:22.424987002 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-11 12:52:52.559350226 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0-p5"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p6"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2021-02-11 12:50:22.424987002 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-11 12:52:52.559350226 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0-p5";
|
||
|
+ return "4.1.0-p6";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tdigamma.c mpfr-4.1.0-b/tests/tdigamma.c
|
||
|
--- mpfr-4.1.0-a/tests/tdigamma.c 2021-02-11 12:50:22.412987133 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tdigamma.c 2021-02-11 12:52:52.547350357 +0000
|
||
|
@@ -90,6 +90,26 @@
|
||
|
set_emax (emax);
|
||
|
}
|
||
|
|
||
|
+/* another test that fails with GMP_CHECK_RANDOMIZE=1612741376857003
|
||
|
+ on revision 14398 */
|
||
|
+static void
|
||
|
+bug20210208 (void)
|
||
|
+{
|
||
|
+ mpfr_t x, y;
|
||
|
+ int inex;
|
||
|
+
|
||
|
+ mpfr_init2 (x, 73);
|
||
|
+ mpfr_init2 (y, 1);
|
||
|
+ mpfr_set_str (x, "1.4613470547060071827450", 10, MPFR_RNDN);
|
||
|
+ mpfr_clear_flags ();
|
||
|
+ inex = mpfr_digamma (y, x, MPFR_RNDU);
|
||
|
+ MPFR_ASSERTN (mpfr_cmp_si_2exp (y, -1, -12) == 0);
|
||
|
+ MPFR_ASSERTN (inex > 0);
|
||
|
+ MPFR_ASSERTN (__gmpfr_flags == MPFR_FLAGS_INEXACT);
|
||
|
+ mpfr_clear (x);
|
||
|
+ mpfr_clear (y);
|
||
|
+}
|
||
|
+
|
||
|
int
|
||
|
main (int argc, char *argv[])
|
||
|
{
|
||
|
@@ -97,6 +117,7 @@
|
||
|
|
||
|
special ();
|
||
|
bug20210206 ();
|
||
|
+ bug20210208 ();
|
||
|
|
||
|
test_generic (MPFR_PREC_MIN, 200, 20);
|
||
|
|
||
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-11 12:53:38.382850990 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-11 12:53:38.426850512 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+jn-interm-zero
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2021-02-11 12:52:52.563350183 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-11 12:53:38.426850512 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0-p6
|
||
|
+4.1.0-p7
|
||
|
diff -Naurd mpfr-4.1.0-a/src/jyn_asympt.c mpfr-4.1.0-b/src/jyn_asympt.c
|
||
|
--- mpfr-4.1.0-a/src/jyn_asympt.c 2020-07-10 10:33:32.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/src/jyn_asympt.c 2021-02-11 12:53:38.410850685 +0000
|
||
|
@@ -69,6 +69,8 @@
|
||
|
MPFR_ZIV_INIT (loop, w);
|
||
|
for (;;)
|
||
|
{
|
||
|
+ int ok = 1;
|
||
|
+
|
||
|
mpfr_set_prec (c, w);
|
||
|
mpfr_init2 (s, w);
|
||
|
mpfr_init2 (P, w);
|
||
|
@@ -92,6 +94,13 @@
|
||
|
/* now s approximates sin(z)+cos(z), and c approximates sin(z)-cos(z),
|
||
|
with total absolute error bounded by 2^(1-w). */
|
||
|
|
||
|
+ /* if s or c is zero, MPFR_GET_EXP will fail below */
|
||
|
+ if (MPFR_IS_ZERO(s) || MPFR_IS_ZERO(c))
|
||
|
+ {
|
||
|
+ ok = 0;
|
||
|
+ goto clear;
|
||
|
+ }
|
||
|
+
|
||
|
/* precompute 1/(8|z|) */
|
||
|
mpfr_si_div (iz, MPFR_IS_POS(z) ? 1 : -1, z, MPFR_RNDN); /* err <= 1 */
|
||
|
mpfr_div_2ui (iz, iz, 3, MPFR_RNDN);
|
||
|
@@ -257,6 +266,9 @@
|
||
|
err = (err >= err2) ? err + 1 : err2 + 1;
|
||
|
/* the absolute error on c is bounded by 2^(err - w) */
|
||
|
|
||
|
+ err -= MPFR_GET_EXP (c);
|
||
|
+
|
||
|
+ clear:
|
||
|
mpfr_clear (s);
|
||
|
mpfr_clear (P);
|
||
|
mpfr_clear (Q);
|
||
|
@@ -266,8 +278,7 @@
|
||
|
mpfr_clear (err_s);
|
||
|
mpfr_clear (err_u);
|
||
|
|
||
|
- err -= MPFR_GET_EXP (c);
|
||
|
- if (MPFR_LIKELY (MPFR_CAN_ROUND (c, w - err, MPFR_PREC(res), r)))
|
||
|
+ if (ok && MPFR_LIKELY (MPFR_CAN_ROUND (c, w - err, MPFR_PREC(res), r)))
|
||
|
break;
|
||
|
if (diverge != 0)
|
||
|
{
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2021-02-11 12:52:52.559350226 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-11 12:53:38.422850555 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0-p6"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p7"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2021-02-11 12:52:52.559350226 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-11 12:53:38.426850512 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0-p6";
|
||
|
+ return "4.1.0-p7";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tj0.c mpfr-4.1.0-b/tests/tj0.c
|
||
|
--- mpfr-4.1.0-a/tests/tj0.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tj0.c 2021-02-11 12:53:38.410850685 +0000
|
||
|
@@ -27,6 +27,25 @@
|
||
|
#define REDUCE_EMAX 262143 /* otherwise arg. reduction is too expensive */
|
||
|
#include "tgeneric.c"
|
||
|
|
||
|
+/* bug found in revision 14399 with GMP_CHECK_RANDOMIZE=1612721106588971 */
|
||
|
+static void
|
||
|
+bug20210208 (void)
|
||
|
+{
|
||
|
+ mpfr_t x, y;
|
||
|
+ int inex;
|
||
|
+
|
||
|
+ mpfr_init2 (x, 79);
|
||
|
+ mpfr_init2 (y, 1);
|
||
|
+ mpfr_set_str (x, "2.552495117262005805960565e+02", 10, MPFR_RNDN);
|
||
|
+ mpfr_clear_flags ();
|
||
|
+ inex = mpfr_j0 (y, x, MPFR_RNDZ);
|
||
|
+ MPFR_ASSERTN (mpfr_cmp_si_2exp (y, -1, -5) == 0);
|
||
|
+ MPFR_ASSERTN (inex > 0);
|
||
|
+ MPFR_ASSERTN (__gmpfr_flags == MPFR_FLAGS_INEXACT);
|
||
|
+ mpfr_clear (x);
|
||
|
+ mpfr_clear (y);
|
||
|
+}
|
||
|
+
|
||
|
int
|
||
|
main (int argc, char *argv[])
|
||
|
{
|
||
|
@@ -35,6 +54,8 @@
|
||
|
|
||
|
tests_start_mpfr ();
|
||
|
|
||
|
+ bug20210208 ();
|
||
|
+
|
||
|
mpfr_init (x);
|
||
|
mpfr_init (y);
|
||
|
|
||
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-17 17:22:34.594973310 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-17 17:22:34.702972090 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+digamma-interm-zero2
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2021-02-11 12:53:38.426850512 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-17 17:22:34.702972090 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0-p7
|
||
|
+4.1.0-p8
|
||
|
diff -Naurd mpfr-4.1.0-a/src/digamma.c mpfr-4.1.0-b/src/digamma.c
|
||
|
--- mpfr-4.1.0-a/src/digamma.c 2021-02-11 12:52:52.547350357 +0000
|
||
|
+++ mpfr-4.1.0-b/src/digamma.c 2021-02-17 17:22:34.690972226 +0000
|
||
|
@@ -173,16 +173,19 @@
|
||
|
mpfr_digamma (v, u, MPFR_RNDN); /* error <= 1/2 ulp */
|
||
|
expv = MPFR_GET_EXP (v);
|
||
|
mpfr_sub (v, v, t, MPFR_RNDN);
|
||
|
- if (MPFR_GET_EXP (v) < MPFR_GET_EXP (t))
|
||
|
- e1 += MPFR_EXP(t) - MPFR_EXP(v); /* scale error for t wrt new v */
|
||
|
- /* now take into account the 1/2 ulp error for v */
|
||
|
- if (expv - MPFR_EXP(v) - 1 > e1)
|
||
|
- e1 = expv - MPFR_EXP(v) - 1;
|
||
|
- else
|
||
|
- e1 ++;
|
||
|
- e1 ++; /* rounding error for mpfr_sub */
|
||
|
- if (MPFR_CAN_ROUND (v, p - e1, MPFR_PREC(y), rnd_mode))
|
||
|
- break;
|
||
|
+ if (MPFR_NOTZERO(v))
|
||
|
+ {
|
||
|
+ if (MPFR_GET_EXP (v) < MPFR_GET_EXP (t))
|
||
|
+ e1 += MPFR_EXP(t) - MPFR_EXP(v); /* scale error for t wrt new v */
|
||
|
+ /* now take into account the 1/2 ulp error for v */
|
||
|
+ if (expv - MPFR_EXP(v) - 1 > e1)
|
||
|
+ e1 = expv - MPFR_EXP(v) - 1;
|
||
|
+ else
|
||
|
+ e1 ++;
|
||
|
+ e1 ++; /* rounding error for mpfr_sub */
|
||
|
+ if (MPFR_CAN_ROUND (v, p - e1, MPFR_PREC(y), rnd_mode))
|
||
|
+ break;
|
||
|
+ }
|
||
|
MPFR_ZIV_NEXT (loop, p);
|
||
|
mpfr_set_prec (t, p);
|
||
|
mpfr_set_prec (v, p);
|
||
|
@@ -416,10 +419,8 @@
|
||
|
}
|
||
|
}
|
||
|
|
||
|
- if (MPFR_IS_NEG(x))
|
||
|
- inex = mpfr_digamma_reflection (y, x, rnd_mode);
|
||
|
/* if x < 1/2 we use the reflection formula */
|
||
|
- else if (MPFR_EXP(x) < 0)
|
||
|
+ if (MPFR_IS_NEG(x) || MPFR_EXP(x) < 0)
|
||
|
inex = mpfr_digamma_reflection (y, x, rnd_mode);
|
||
|
else
|
||
|
inex = mpfr_digamma_positive (y, x, rnd_mode);
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2021-02-11 12:53:38.422850555 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-17 17:22:34.702972090 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0-p7"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p8"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2021-02-11 12:53:38.426850512 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-17 17:22:34.702972090 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0-p7";
|
||
|
+ return "4.1.0-p8";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tdigamma.c mpfr-4.1.0-b/tests/tdigamma.c
|
||
|
--- mpfr-4.1.0-a/tests/tdigamma.c 2021-02-11 12:52:52.547350357 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tdigamma.c 2021-02-17 17:22:34.690972226 +0000
|
||
|
@@ -110,6 +110,26 @@
|
||
|
mpfr_clear (y);
|
||
|
}
|
||
|
|
||
|
+/* another test that fails with GMP_CHECK_RANDOMIZE=1613197421465830
|
||
|
+ on revision 14429 */
|
||
|
+static void
|
||
|
+bug20210215 (void)
|
||
|
+{
|
||
|
+ mpfr_t x, y;
|
||
|
+ int inex;
|
||
|
+
|
||
|
+ mpfr_init2 (x, 510);
|
||
|
+ mpfr_init2 (y, 4);
|
||
|
+ mpfr_set_str (x, "-8.2923051438433494998166335341807999322052669984208422481227138906096000469898717007386115912802685588348601663465077353194268894939972221117314512518182580e+35", 10, MPFR_RNDN);
|
||
|
+ mpfr_clear_flags ();
|
||
|
+ inex = mpfr_digamma (y, x, MPFR_RNDU);
|
||
|
+ MPFR_ASSERTN (mpfr_cmp_ui0 (y, 88) == 0);
|
||
|
+ MPFR_ASSERTN (inex > 0);
|
||
|
+ MPFR_ASSERTN (__gmpfr_flags == MPFR_FLAGS_INEXACT);
|
||
|
+ mpfr_clear (x);
|
||
|
+ mpfr_clear (y);
|
||
|
+}
|
||
|
+
|
||
|
int
|
||
|
main (int argc, char *argv[])
|
||
|
{
|
||
|
@@ -118,6 +138,7 @@
|
||
|
special ();
|
||
|
bug20210206 ();
|
||
|
bug20210208 ();
|
||
|
+ bug20210215 ();
|
||
|
|
||
|
test_generic (MPFR_PREC_MIN, 200, 20);
|
||
|
|
||
|
diff -Naurd mpfr-4.1.0-a/PATCHES mpfr-4.1.0-b/PATCHES
|
||
|
--- mpfr-4.1.0-a/PATCHES 2021-02-17 17:25:46.396981483 +0000
|
||
|
+++ mpfr-4.1.0-b/PATCHES 2021-02-17 17:25:46.440981068 +0000
|
||
|
@@ -0,0 +1 @@
|
||
|
+jyn_asympt-interm-zero
|
||
|
diff -Naurd mpfr-4.1.0-a/VERSION mpfr-4.1.0-b/VERSION
|
||
|
--- mpfr-4.1.0-a/VERSION 2021-02-17 17:22:34.702972090 +0000
|
||
|
+++ mpfr-4.1.0-b/VERSION 2021-02-17 17:25:46.440981068 +0000
|
||
|
@@ -1 +1 @@
|
||
|
-4.1.0-p8
|
||
|
+4.1.0-p9
|
||
|
diff -Naurd mpfr-4.1.0-a/src/jyn_asympt.c mpfr-4.1.0-b/src/jyn_asympt.c
|
||
|
--- mpfr-4.1.0-a/src/jyn_asympt.c 2021-02-11 12:53:38.410850685 +0000
|
||
|
+++ mpfr-4.1.0-b/src/jyn_asympt.c 2021-02-17 17:25:46.424981219 +0000
|
||
|
@@ -69,7 +69,7 @@
|
||
|
MPFR_ZIV_INIT (loop, w);
|
||
|
for (;;)
|
||
|
{
|
||
|
- int ok = 1;
|
||
|
+ int ok = 0;
|
||
|
|
||
|
mpfr_set_prec (c, w);
|
||
|
mpfr_init2 (s, w);
|
||
|
@@ -96,10 +96,7 @@
|
||
|
|
||
|
/* if s or c is zero, MPFR_GET_EXP will fail below */
|
||
|
if (MPFR_IS_ZERO(s) || MPFR_IS_ZERO(c))
|
||
|
- {
|
||
|
- ok = 0;
|
||
|
- goto clear;
|
||
|
- }
|
||
|
+ goto clear; /* with ok=0 */
|
||
|
|
||
|
/* precompute 1/(8|z|) */
|
||
|
mpfr_si_div (iz, MPFR_IS_POS(z) ? 1 : -1, z, MPFR_RNDN); /* err <= 1 */
|
||
|
@@ -227,6 +224,9 @@
|
||
|
mpfr_sub (s, c, s, MPFR_RNDN);
|
||
|
#endif
|
||
|
}
|
||
|
+ if (MPFR_IS_ZERO(s))
|
||
|
+ goto clear; /* with ok=0 */
|
||
|
+ ok = 1;
|
||
|
if ((n & 2) != 0)
|
||
|
mpfr_neg (s, s, MPFR_RNDN);
|
||
|
if (MPFR_GET_EXP (s) > err)
|
||
|
diff -Naurd mpfr-4.1.0-a/src/mpfr.h mpfr-4.1.0-b/src/mpfr.h
|
||
|
--- mpfr-4.1.0-a/src/mpfr.h 2021-02-17 17:22:34.702972090 +0000
|
||
|
+++ mpfr-4.1.0-b/src/mpfr.h 2021-02-17 17:25:46.436981105 +0000
|
||
|
@@ -27,7 +27,7 @@
|
||
|
#define MPFR_VERSION_MAJOR 4
|
||
|
#define MPFR_VERSION_MINOR 1
|
||
|
#define MPFR_VERSION_PATCHLEVEL 0
|
||
|
-#define MPFR_VERSION_STRING "4.1.0-p8"
|
||
|
+#define MPFR_VERSION_STRING "4.1.0-p9"
|
||
|
|
||
|
/* User macros:
|
||
|
MPFR_USE_FILE: Define it to make MPFR define functions dealing
|
||
|
diff -Naurd mpfr-4.1.0-a/src/version.c mpfr-4.1.0-b/src/version.c
|
||
|
--- mpfr-4.1.0-a/src/version.c 2021-02-17 17:22:34.702972090 +0000
|
||
|
+++ mpfr-4.1.0-b/src/version.c 2021-02-17 17:25:46.440981068 +0000
|
||
|
@@ -25,5 +25,5 @@
|
||
|
const char *
|
||
|
mpfr_get_version (void)
|
||
|
{
|
||
|
- return "4.1.0-p8";
|
||
|
+ return "4.1.0-p9";
|
||
|
}
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/mpfr-test.h mpfr-4.1.0-b/tests/mpfr-test.h
|
||
|
--- mpfr-4.1.0-a/tests/mpfr-test.h 2020-06-29 13:57:32.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/mpfr-test.h 2021-02-17 17:25:46.424981219 +0000
|
||
|
@@ -191,6 +191,8 @@
|
||
|
|
||
|
#define mpfr_cmp0(x,y) (MPFR_ASSERTN (!MPFR_IS_NAN (x) && !MPFR_IS_NAN (y)), mpfr_cmp (x,y))
|
||
|
#define mpfr_cmp_ui0(x,i) (MPFR_ASSERTN (!MPFR_IS_NAN (x)), mpfr_cmp_ui (x,i))
|
||
|
+#define mpfr_cmp_si_2exp0(x,i,e) (MPFR_ASSERTN (!MPFR_IS_NAN (x)), \
|
||
|
+ mpfr_cmp_si_2exp (x,i,e))
|
||
|
|
||
|
/* define CHECK_EXTERNAL if you want to check mpfr against another library
|
||
|
with correct rounding. You'll probably have to modify mpfr_print_raw()
|
||
|
diff -Naurd mpfr-4.1.0-a/tests/tj1.c mpfr-4.1.0-b/tests/tj1.c
|
||
|
--- mpfr-4.1.0-a/tests/tj1.c 2020-01-08 18:11:13.000000000 +0000
|
||
|
+++ mpfr-4.1.0-b/tests/tj1.c 2021-02-17 17:25:46.424981219 +0000
|
||
|
@@ -55,14 +55,14 @@
|
||
|
/* since |x| is just above 2^e, |j1(x)| is just above 2^(e-1),
|
||
|
thus y should be 2^(e-1) and the inexact flag should be
|
||
|
of opposite sign of x */
|
||
|
- MPFR_ASSERTN(mpfr_cmp_si_2exp (y, sign, e - 1) == 0);
|
||
|
+ MPFR_ASSERTN(mpfr_cmp_si_2exp0 (y, sign, e - 1) == 0);
|
||
|
MPFR_ASSERTN(VSIGN (inex) * sign < 0);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
/* here |y| should be 0.5*2^emin and the inexact flag should
|
||
|
have the sign of x */
|
||
|
- MPFR_ASSERTN(mpfr_cmp_si_2exp (y, sign, e) == 0);
|
||
|
+ MPFR_ASSERTN(mpfr_cmp_si_2exp0 (y, sign, e) == 0);
|
||
|
MPFR_ASSERTN(VSIGN (inex) * sign > 0);
|
||
|
}
|
||
|
}
|
||
|
@@ -72,6 +72,26 @@
|
||
|
mpfr_clear (y);
|
||
|
}
|
||
|
|
||
|
+/* a test that fails with GMP_CHECK_RANDOMIZE=1613146232984428
|
||
|
+ on revision 14429 */
|
||
|
+static void
|
||
|
+bug20210215 (void)
|
||
|
+{
|
||
|
+ mpfr_t x, y;
|
||
|
+ int inex;
|
||
|
+
|
||
|
+ mpfr_init2 (x, 221);
|
||
|
+ mpfr_init2 (y, 1);
|
||
|
+ mpfr_set_str (x, "1.6484611511696130037307738844228498447763863563070374544054791168614e+01", 10, MPFR_RNDN);
|
||
|
+ mpfr_clear_flags ();
|
||
|
+ inex = mpfr_j1 (y, x, MPFR_RNDZ);
|
||
|
+ MPFR_ASSERTN (mpfr_cmp_si_2exp0 (y, -1, -9) == 0);
|
||
|
+ MPFR_ASSERTN (inex > 0);
|
||
|
+ MPFR_ASSERTN (__gmpfr_flags == MPFR_FLAGS_INEXACT);
|
||
|
+ mpfr_clear (x);
|
||
|
+ mpfr_clear (y);
|
||
|
+}
|
||
|
+
|
||
|
int
|
||
|
main (int argc, char *argv[])
|
||
|
{
|
||
|
@@ -79,6 +99,8 @@
|
||
|
|
||
|
tests_start_mpfr ();
|
||
|
|
||
|
+ bug20210215 ();
|
||
|
+
|
||
|
test_small ();
|
||
|
|
||
|
mpfr_init (x);
|