]> oss.titaniummirror.com Git - msp430-gcc.git/blobdiff - mpfr/tests/tget_str.c
Imported gcc-4.4.3
[msp430-gcc.git] / mpfr / tests / tget_str.c
diff --git a/mpfr/tests/tget_str.c b/mpfr/tests/tget_str.c
new file mode 100644 (file)
index 0000000..8b45291
--- /dev/null
@@ -0,0 +1,1186 @@
+/* Test file for mpfr_get_str.
+
+Copyright 1999, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
+Contributed by the Arenaire and Cacao projects, INRIA.
+
+This file is part of the GNU MPFR Library.
+
+The GNU MPFR Library is free software; you can redistribute it and/or modify
+it under the terms of the GNU Lesser General Public License as published by
+the Free Software Foundation; either version 2.1 of the License, or (at your
+option) any later version.
+
+The GNU MPFR Library is distributed in the hope that it will be useful, but
+WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
+License for more details.
+
+You should have received a copy of the GNU Lesser General Public License
+along with the GNU MPFR Library; see the file COPYING.LIB.  If not, write to
+the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
+MA 02110-1301, USA. */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "mpfr-test.h"
+
+static void
+check3 (char *d, mp_rnd_t rnd, char *res)
+{
+  mpfr_t x;
+  char *str;
+  mp_exp_t e;
+
+  mpfr_init2 (x, 53);
+  mpfr_set_str (x, d, 10, rnd);
+  str = mpfr_get_str (NULL, &e, 10, 5, x, rnd);
+  if (strcmp (str, res))
+    {
+      printf ("Error in mpfr_get_str for x=%s\n", d);
+      printf ("got %s instead of %s\n", str, res);
+      exit (1);
+    }
+  mpfr_clear (x);
+  mpfr_free_str (str);
+}
+
+static void
+check_small (void)
+{
+  mpfr_t x;
+  char *s;
+  mp_exp_t e;
+  mp_prec_t p;
+
+  mpfr_init (x);
+
+  mpfr_set_prec (x, 20);
+  mpfr_set_ui (x, 2, GMP_RNDN);
+  mpfr_nexttozero (x);
+  s = mpfr_get_str (NULL, &e, 4, 2, x, GMP_RNDU);
+  if (strcmp (s, "20") || (e != 1))
+    {
+      printf ("Error in mpfr_get_str: 2- rounded up with 2 digits"
+              " in base 4\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* check n_digits=0 */
+  mpfr_set_prec (x, 5);
+  mpfr_set_ui (x, 17, GMP_RNDN);
+  s = mpfr_get_str (NULL, &e, 3, 0, x, GMP_RNDN);
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 36, 0, x, GMP_RNDN);
+  mpfr_free_str (s);
+
+  mpfr_set_prec (x, 64);
+  mpfr_set_si (x, -1, GMP_RNDN);
+  mpfr_div_2exp (x, x, 63, GMP_RNDN); /* x = -2^(-63) */
+  mpfr_add_ui (x, x, 1, GMP_RNDN); /* x = 1 - 2^(-63) */
+  mpfr_mul_2exp (x, x, 32, GMP_RNDN); /* x = 2^32 - 2^(-31) */
+  s = mpfr_get_str (NULL, &e, 3, 21, x, GMP_RNDU);
+  if (strcmp (s, "102002022201221111211") || (e != 21))
+    {
+      printf ("Error in mpfr_get_str: 2^32-2^(-31) rounded up with"
+              " 21 digits in base 3\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 3, 20, x, GMP_RNDU);
+  if (strcmp (s, "10200202220122111122") || (e != 21))
+    {
+      printf ("Error in mpfr_get_str: 2^32-2^(-31) rounded up with"
+              " 20 digits in base 3\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* check corner case ret!=0, j0!=0 in mpfr_get_str_aux */
+  mpfr_set_prec (x, 100);
+  mpfr_set_str_binary (x, "0.1001011111010001101110010101010101111001010111111101101101100110100011110110000101110110001011110000E-9");
+  s = mpfr_get_str (NULL, &e, 3, 2, x, GMP_RNDU);
+  if (strcmp (s, "22") || (e != -6))
+    {
+      printf ("Error in mpfr_get_str: 100-bit number rounded up with"
+              " 2 digits in base 3\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* check corner case exact=0 in mpfr_get_str_aux */
+  mpfr_set_prec (x, 100);
+  mpfr_set_str_binary (x, "0.1001001111101101111000101000110111111010101100000110010001111111011001101011101100001100110000000000E8");
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDZ);
+  if (strcmp (s, "14") || (e != 3))
+    {
+      printf ("Error in mpfr_get_str: 100-bit number rounded to zero with"
+              " 2 digits in base 10\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  for (p=4; p<=200; p++)
+    {
+      mpfr_set_prec (x, p);
+      mpfr_set_str (x, "6.5", 10, GMP_RNDN);
+
+      s = mpfr_get_str (NULL, &e, 6, 2, x, GMP_RNDN);
+      if (strcmp (s, "10") || (e != 2))
+        {
+          printf ("Error in mpfr_get_str: 6.5 rounded to nearest with"
+                  " 2 digits in base 6\n");
+          exit (1);
+        }
+      mpfr_free_str (s);
+
+      mpfr_nexttoinf (x);
+      s = mpfr_get_str (NULL, &e, 6, 2, x, GMP_RNDN);
+      if (strcmp (s, "11") || (e != 2))
+        {
+          printf ("Error in mpfr_get_str: 6.5+ rounded to nearest with"
+                  " 2 digits in base 6\ngot %se%d instead of 11e2\n",
+                  s, (int) e);
+          exit (1);
+        }
+      mpfr_free_str (s);
+
+      mpfr_set_str (x, "6.5", 10, GMP_RNDN);
+      mpfr_nexttozero (x);
+      s = mpfr_get_str (NULL, &e, 6, 2, x, GMP_RNDN);
+      if (strcmp (s, "10") || (e != 2))
+        {
+          printf ("Error in mpfr_get_str: 6.5- rounded to nearest with"
+                  " 2 digits in base 6\n");
+          exit (1);
+        }
+      mpfr_free_str (s);
+    }
+
+  mpfr_set_prec (x, 3);
+  mpfr_set_ui (x, 7, GMP_RNDN);
+  s = mpfr_get_str (NULL, &e, 2, 2, x, GMP_RNDU);
+  if (strcmp (s, "10") || (e != 4))
+    {
+      printf ("Error in mpfr_get_str: 7 rounded up with 2 bits should"
+              " give 0.10e3 instead of 0.%s*2^%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* problem found by Fabrice Rouillier */
+  mpfr_set_prec (x, 63);
+  mpfr_set_str (x, "5e14", 10, GMP_RNDN);
+  s = mpfr_get_str (NULL, &e, 10, 18, x, GMP_RNDU);
+  mpfr_free_str (s);
+
+  /* bug found by Johan Vervloet */
+  mpfr_set_prec (x, 6);
+  mpfr_set_str (x, "688.0", 10, GMP_RNDN);
+  s = mpfr_get_str (NULL, &e, 2, 4, x, GMP_RNDU);
+  if (strcmp (s, "1011") || (e != 10))
+    {
+      printf ("Error in mpfr_get_str: 688 printed up to 4 bits should"
+              " give 1.011e9\ninstead of ");
+      mpfr_out_str (stdout, 2, 4, x, GMP_RNDU);
+      puts ("");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_prec (x, 38);
+  mpfr_set_str_binary (x, "1.0001110111110100011010100010010100110e-6");
+  s = mpfr_get_str (NULL, &e, 8, 10, x, GMP_RNDU);
+  if (strcmp (s, "1073721522") || (e != -1))
+    {
+      printf ("Error in mpfr_get_str (3): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_prec (x, 53);
+  mpfr_set_str_binary (x, "0.11010111011101100010000100010101110001000000010111001E454");
+  s = mpfr_get_str (NULL, &e, 19, 12, x, GMP_RNDU);
+  if (strcmp (s, "b1cgfa4gha0h") || (e != 107))
+    {
+      printf ("Error in mpfr_get_str (4): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_prec (x, 145);
+  mpfr_set_str_binary (x, "-0.1000110011000001011000010101101010110110101100101110100011111100011110011001001001010000100001000011000011000000010111011001000111101001110100110e6");
+  s = mpfr_get_str (NULL, &e, 4, 53, x, GMP_RNDU);
+  if (strcmp (s, "-20303001120111222312230232203330132121021100201003003") || (e != 3))
+    {
+      printf ("Error in mpfr_get_str (5): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_prec (x, 45);
+  mpfr_set_str_binary (x, "-0.00100111010110010001011001110111010001010010010");
+  s = mpfr_get_str (NULL, &e, 32, 9, x, GMP_RNDN);
+  if (strcmp (s, "-4tchctq54") || (e != 0))
+    {
+      printf ("Error in mpfr_get_str (6): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* worst case found by Vincent Lefe`vre */
+  mpfr_set_prec (x, 53);
+  mpfr_set_str_binary (x, "10011110111100000000001011011110101100010000011011111E164");
+  s = mpfr_get_str (NULL, &e, 10, 17, x, GMP_RNDN);
+  if (strcmp (s, "13076622631878654") || (e != 66))
+    {
+      printf ("Error in mpfr_get_str (7): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10000001001001001100011101010011011011111000011000100E93");
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDU);
+  if (strcmp (s, "46") || e != 44)
+    {
+       printf ("Error in mpfr_get_str (8): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10010001111100000111001111010101001010000010111010101E55");
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDN);
+  if (strcmp (s, "19") || e != 33)
+    {
+       printf ("Error in mpfr_get_str (9): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "11011001010010111110010101101100111110111000010110110E44");
+  s = mpfr_get_str (NULL, &e, 10, 3, x, GMP_RNDN);
+  if (strcmp (s, "135") || e != 30)
+    {
+       printf ("Error in mpfr_get_str (10): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "11101111101000001011100001111000011111101111011001100E72");
+  s = mpfr_get_str (NULL, &e, 10, 4, x, GMP_RNDN);
+  if (strcmp (s, "3981") || e != 38)
+    {
+       printf ("Error in mpfr_get_str (11): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10011001001100100010111100001101110101001001111110000E46");
+  s = mpfr_get_str (NULL, &e, 10, 5, x, GMP_RNDN);
+  if (strcmp (s, "37930") || e != 30)
+    {
+       printf ("Error in mpfr_get_str (12): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10001100110111001011011110011011011101100011010001011E-72");
+  s = mpfr_get_str (NULL, &e, 10, 6, x, GMP_RNDN);
+  if (strcmp (s, "104950") || e != -5)
+    {
+       printf ("Error in mpfr_get_str (13): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "10100100001011001000011001101101000110100110000010111E89");
+  s = mpfr_get_str (NULL, &e, 10, 7, x, GMP_RNDN);
+  if (strcmp (s, "3575392") || e != 43)
+    {
+       printf ("Error in mpfr_get_str (14): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "11000011011110110010100110001010000001010011001011001E-73");
+  s = mpfr_get_str (NULL, &e, 10, 8, x, GMP_RNDN);
+  if (strcmp (s, "72822386") || e != -6)
+    {
+       printf ("Error in mpfr_get_str (15): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "10101010001101000111001100001000100011100010010001010E78");
+  s = mpfr_get_str (NULL, &e, 10, 9, x, GMP_RNDN);
+  if (strcmp (s, "180992873") || e != 40)
+    {
+      printf ("Error in mpfr_get_str (16): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "10110111001000100000001101111001100101101110011011101E91");
+  s = mpfr_get_str (NULL, &e, 10, 10, x, GMP_RNDN);
+  if (strcmp (s, "1595312255") || e != 44)
+    {
+      printf ("Error in mpfr_get_str (17): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10011101010111101111000100111011101011110100110110101E93");
+  s = mpfr_get_str (NULL, &e, 10, 11, x, GMP_RNDN);
+  if (strcmp (s, "54835744350") || e != 44)
+    {
+      printf ("Error in mpfr_get_str (18): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10011101010111101111000100111011101011110100110110101E92");
+  s = mpfr_get_str (NULL, &e, 10, 12, x, GMP_RNDN);
+  if (strcmp (s, "274178721752") || e != 44)
+    {
+      printf ("Error in mpfr_get_str (19): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10011101010111101111000100111011101011110100110110101E91");
+  s = mpfr_get_str (NULL, &e, 10, 13, x, GMP_RNDN);
+  if (strcmp (s, "1370893608762") || e != 44)
+    {
+      printf ("Error in mpfr_get_str (20): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "10010011010110011100010010100101100011101000011111111E92");
+  s = mpfr_get_str (NULL, &e, 10, 14, x, GMP_RNDN);
+  if (strcmp (s, "25672105101864") || e != 44)
+    {
+      printf ("Error in mpfr_get_str (21): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "100110111110110001000101110100100101101000011111001E87");
+  s = mpfr_get_str (NULL, &e, 10, 15, x, GMP_RNDN);
+  if (strcmp (s, "212231308858721") || e != 42)
+    {
+      printf ("Error in mpfr_get_str (22): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10111010110000111000101100101111001011011100101001111E-128");
+  s = mpfr_get_str (NULL, &e, 10, 15, x, GMP_RNDN);
+  if (strcmp (s, "193109287087290") || e != -22)
+    {
+      printf ("Error in mpfr_get_str (22b): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "10001101101011010001111110000111010111010000110101010E80");
+  s = mpfr_get_str (NULL, &e, 10, 16, x, GMP_RNDN);
+  if (strcmp (s, "6026241735727920") || e != 40)
+    {
+      printf ("Error in mpfr_get_str (23): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "100010001011101001110101000110011001001000110001001E-81");
+  s = mpfr_get_str (NULL, &e, 10, 17, x, GMP_RNDN);
+  if (strcmp (s, "49741483709103481") || e != -9)
+    {
+      printf ("Error in mpfr_get_str (24): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "11000100001001001110111010011001111001001010110101111E-101");
+  s = mpfr_get_str (NULL, &e, 10, 7, x, GMP_RNDN);
+  if (strcmp (s, "2722049") || e != -14)
+    {
+      printf ("Error in mpfr_get_str (25): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "11111001010011100101000001111111110001001001110110001E-135");
+  s = mpfr_get_str (NULL, &e, 10, 8, x, GMP_RNDN);
+  if (strcmp (s, "20138772") || e != -24)
+    {
+      printf ("Error in mpfr_get_str (26): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "11111001010011100101000001111111110001001001110110001E-136");
+  s = mpfr_get_str (NULL, &e, 10, 9, x, GMP_RNDN);
+  if (strcmp (s, "100693858") || e != -24)
+    {
+      printf ("Error in mpfr_get_str (27): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+    mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10001000001110010110001011111011111011011010000110001E-110");
+  s = mpfr_get_str (NULL, &e, 10, 14, x, GMP_RNDN);
+  if (strcmp (s, "36923634350619") || e != -17)
+    {
+      printf ("Error in mpfr_get_str (28): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "11001100010111000111100010000110011101110001000101111E-87");
+  s = mpfr_get_str (NULL, &e, 10, 16, x, GMP_RNDN);
+  if (strcmp (s, "4646636036100804") || e != -10)
+    {
+      printf ("Error in mpfr_get_str (29): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_set_str_binary (x, "10011111001111110100001001010111111011010101111111000E-99");
+  s = mpfr_get_str (NULL, &e, 10, 17, x, GMP_RNDN);
+  if (strcmp (s, "88399901882446712") || e != -14)
+    {
+      printf ("Error in mpfr_get_str (30): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 8116315218207718*2^(-293) ~ 0.5100000000000000000015*10^(-72) */
+  mpfr_set_str_binary (x, "11100110101011011111011100101011101110110001111100110E-293");
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDU);
+  if (strcmp (s, "52") || e != -72)
+    {
+      printf ("Error in mpfr_get_str (31u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDD);
+  if (strcmp (s, "51") || e != -72)
+    {
+      printf ("Error in mpfr_get_str (31d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 6712731423444934*2^536 ~ .151000000000000000000067*10^178 */
+  mpfr_set_str_binary (x, "10111110110010011000110010011111101111000111111000110E536");
+  s = mpfr_get_str (NULL, &e, 10, 3, x, GMP_RNDU);
+  if (strcmp (s, "152") || e != 178)
+    {
+      printf ("Error in mpfr_get_str (32u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 3, x, GMP_RNDD);
+  if (strcmp (s, "151") || e != 178)
+    {
+      printf ("Error in mpfr_get_str (32d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 3356365711722467*2^540 ~ .120800000000000000000054*10^179 */
+  mpfr_set_str_binary (x, "1011111011001001100011001001111110111100011111100011E540");
+  s = mpfr_get_str (NULL, &e, 10, 4, x, GMP_RNDU);
+  if (strcmp (s, "1209") || e != 179)
+    {
+      printf ("Error in mpfr_get_str (33u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 4, x, GMP_RNDD);
+  if (strcmp (s, "1208") || e != 179)
+    {
+      printf ("Error in mpfr_get_str (33d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 6475049196144587*2^100 ~ .8208099999999999999999988*10^46 */
+  mpfr_set_str_binary (x, "10111000000010000010111011111001111010100011111001011E100");
+  s = mpfr_get_str (NULL, &e, 10, 5, x, GMP_RNDU);
+  if (strcmp (s, "82081") || e != 46)
+    {
+      printf ("Error in mpfr_get_str (34u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 5, x, GMP_RNDD);
+  if (strcmp (s, "82080") || e != 46)
+    {
+      printf ("Error in mpfr_get_str (34d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 6722280709661868*2^364 ~ .25260100000000000000000012*10^126 */
+  mpfr_set_str_binary (x, "10111111000011110000011110001110001111010010010101100E364");
+  s = mpfr_get_str (NULL, &e, 10, 6, x, GMP_RNDU);
+  if (strcmp (s, "252602") || e != 126)
+    {
+      printf ("Error in mpfr_get_str (35u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 6, x, GMP_RNDD);
+  if (strcmp (s, "252601") || e != 126)
+    {
+      printf ("Error in mpfr_get_str (35d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 5381065484265332*2^(-455) ~ .578389299999999999999999982*10^(-121) */
+  mpfr_set_str_binary (x, "10011000111100000110011110000101100111110011101110100E-455");
+  s = mpfr_get_str (NULL, &e, 10, 7, x, GMP_RNDU);
+  if (strcmp (s, "5783893") || e != -121)
+    {
+      printf ("Error in mpfr_get_str (36u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 7, x, GMP_RNDD);
+  if (strcmp (s, "5783892") || e != -121)
+    {
+      printf ("Error in mpfr_get_str (36d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 8369123604277281*2^(-852) ~ .27869147000000000000000000056*10^(-240) */
+  mpfr_set_str_binary (x, "11101101110111010110001101111100000111010100000100001E-852");
+  s = mpfr_get_str (NULL, &e, 10, 8, x, GMP_RNDU);
+  if (strcmp (s, "27869148") || e != -240)
+    {
+      printf ("Error in mpfr_get_str (37u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 8, x, GMP_RNDD);
+  if (strcmp (s, "27869147") || e != -240)
+    {
+      printf ("Error in mpfr_get_str (37d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 7976538478610756*2^377 ~ .245540326999999999999999999982*10^130 */
+  mpfr_set_str_binary (x, "11100010101101001111010010110100011100000100101000100E377");
+  s = mpfr_get_str (NULL, &e, 10, 9, x, GMP_RNDU);
+  if (strcmp (s, "245540327") || e != 130)
+    {
+      printf ("Error in mpfr_get_str (38u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 9, x, GMP_RNDD);
+  if (strcmp (s, "245540326") || e != 130)
+    {
+      printf ("Error in mpfr_get_str (38d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 8942832835564782*2^(-382) ~ .9078555839000000000000000000038*10^(-99) */
+  mpfr_set_str_binary (x, "11111110001010111010110000110011100110001010011101110E-382");
+  s = mpfr_get_str (NULL, &e, 10, 10, x, GMP_RNDU);
+  if (strcmp (s, "9078555840") || e != -99)
+    {
+      printf ("Error in mpfr_get_str (39u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 10, x, GMP_RNDD);
+  if (strcmp (s, "9078555839") || e != -99)
+    {
+      printf ("Error in mpfr_get_str (39d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 4471416417782391*2^(-380) ~ .18157111678000000000000000000077*10^(-98) */
+  mpfr_set_str_binary (x, "1111111000101011101011000011001110011000101001110111E-380");
+  s = mpfr_get_str (NULL, &e, 10, 11, x, GMP_RNDU);
+  if (strcmp (s, "18157111679") || e != -98)
+    {
+      printf ("Error in mpfr_get_str (40u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 11, x, GMP_RNDD);
+  if (strcmp (s, "18157111678") || e != -98)
+    {
+      printf ("Error in mpfr_get_str (40d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 7225450889282194*2^711 ~ .778380362292999999999999999999971*10^230 */
+  mpfr_set_str_binary (x, "11001101010111000001001100001100110010000001010010010E711");
+  s = mpfr_get_str (NULL, &e, 10, 12, x, GMP_RNDU);
+  if (strcmp (s, "778380362293") || e != 230)
+    {
+      printf ("Error in mpfr_get_str (41u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 12, x, GMP_RNDD);
+  if (strcmp (s, "778380362292") || e != 230)
+    {
+      printf ("Error in mpfr_get_str (41d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 3612725444641097*2^713 ~ .1556760724585999999999999999999942*10^231 */
+  mpfr_set_str_binary (x, "1100110101011100000100110000110011001000000101001001E713");
+  s = mpfr_get_str (NULL, &e, 10, 13, x, GMP_RNDU);
+  if (strcmp (s, "1556760724586") || e != 231)
+    {
+      printf ("Error in mpfr_get_str (42u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 13, x, GMP_RNDD);
+  if (strcmp (s, "1556760724585") || e != 231)
+    {
+      printf ("Error in mpfr_get_str (42d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 6965949469487146*2^(-248) ~ .15400733123779000000000000000000016*10^(-58) */
+  mpfr_set_str_binary (x, "11000101111110111111001111111101001101111000000101010E-248");
+  s = mpfr_get_str (NULL, &e, 10, 14, x, GMP_RNDU);
+  if (strcmp (s, "15400733123780") || e != -58)
+    {
+      printf ("Error in mpfr_get_str (43u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 14, x, GMP_RNDD);
+  if (strcmp (s, "15400733123779") || e != -58)
+    {
+      printf ("Error in mpfr_get_str (43d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 3482974734743573*2^(-244) ~ .12320586499023200000000000000000013*10^(-57) */
+  mpfr_set_str_binary (x, "1100010111111011111100111111110100110111100000010101E-244");
+  s = mpfr_get_str (NULL, &e, 10, 15, x, GMP_RNDU);
+  if (strcmp (s, "123205864990233") || e != -57)
+    {
+      printf ("Error in mpfr_get_str (44u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 15, x, GMP_RNDD);
+  if (strcmp (s, "123205864990232") || e != -57)
+    {
+      printf ("Error in mpfr_get_str (44d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 7542952370752766*2^(-919) ~ .170206189963739699999999999999999974*10^(-260) */
+  mpfr_set_str_binary (x, "11010110011000100011001110100100111011100110011111110E-919");
+  s = mpfr_get_str (NULL, &e, 10, 16, x, GMP_RNDU);
+  if (strcmp (s, "1702061899637397") || e != -260)
+    {
+      printf ("Error in mpfr_get_str (45u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 16, x, GMP_RNDD);
+  if (strcmp (s, "1702061899637396") || e != -260)
+    {
+      printf ("Error in mpfr_get_str (45d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* 5592117679628511*2^165 ~ .26153245263757307000000000000000000074*10^66 */
+  mpfr_set_str_binary (x, "10011110111100000000001011011110101100010000011011111E165");
+  s = mpfr_get_str (NULL, &e, 10, 17, x, GMP_RNDU);
+  if (strcmp (s, "26153245263757308") || e != 66)
+    {
+      printf ("Error in mpfr_get_str (46u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 17, x, GMP_RNDD);
+  if (strcmp (s, "26153245263757307") || e != 66)
+    {
+      printf ("Error in mpfr_get_str (46d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "11010010110111100001011010000110010000100001011011101E1223");
+  s = mpfr_get_str (NULL, &e, 10, 17, x, GMP_RNDN);
+  if (strcmp (s, "10716284017294180") || e != 385)
+    {
+      printf ("Error in mpfr_get_str (47n): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 18, x, GMP_RNDU);
+  if (strcmp (s, "107162840172941805") || e != 385)
+    {
+      printf ("Error in mpfr_get_str (47u): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 18, x, GMP_RNDD);
+  if (strcmp (s, "107162840172941804") || e != 385)
+    {
+      printf ("Error in mpfr_get_str (47d): s=%s e=%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_str_binary (x, "11111101111011000001010100001101101000010010001111E122620");
+  s = mpfr_get_str (NULL, &e, 10, 17, x, GMP_RNDN);
+  if (strcmp (s, "22183435284042374") || e != 36928)
+    {
+      printf ("Error in mpfr_get_str (48n): s=%s e=%ld\n", s, (long) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 18, x, GMP_RNDU);
+  if (strcmp (s, "221834352840423736") || e != 36928)
+    {
+      printf ("Error in mpfr_get_str (48u): s=%s e=%ld\n", s, (long) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  s = mpfr_get_str (NULL, &e, 10, 18, x, GMP_RNDD);
+  if (strcmp (s, "221834352840423735") || e != 36928)
+    {
+      printf ("Error in mpfr_get_str (48d): s=%s e=%ld\n", s, (long) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_prec (x, 45);
+  mpfr_set_str_binary (x, "1E45");
+  s = mpfr_get_str (NULL, &e, 32, 9, x, GMP_RNDN);
+  mpfr_free_str (s);
+
+  mpfr_set_prec (x, 7);
+  mpfr_set_str_binary (x, "0.1010101E10");
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDU);
+  mpfr_free_str (s);
+
+  /* checks rounding of negative numbers */
+  mpfr_set_prec (x, 7);
+  mpfr_set_str (x, "-11.5", 10, GMP_RNDN);
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDD);
+  if (strcmp (s, "-12"))
+    {
+      printf ("Error in mpfr_get_str for x=-11.5 and rnd=GMP_RNDD\n"
+              "got %s instead of -12\n", s);
+      exit (1);
+  }
+  mpfr_free_str (s);
+
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDU);
+  if (strcmp (s, "-11"))
+    {
+      printf ("Error in mpfr_get_str for x=-11.5 and rnd=GMP_RNDU\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  /* bug found by Jean-Pierre Merlet, produced error in mpfr_get_str */
+  mpfr_set_prec (x, 128);
+  mpfr_set_str_binary (x, "0.10111001100110011001100110011001100110011001100110011001100110011001100110011001100110011001100110011001100110011001100110011010E3");
+  s = mpfr_get_str (NULL, &e, 10, 0, x, GMP_RNDU);
+  mpfr_free_str (s);
+
+  mpfr_set_prec (x, 381);
+  mpfr_set_str_binary (x, "0.111111111111111111111111111111111111111111111111111111111111111111101110110000100110011101101101001010111000101111000100100011110101010110101110100000010100001000110100000100011111001000010010000010001010111001011110000001110010111101100001111000101101100000010110000101100100000101010110010110001010100111001111100011100101100000100100111001100010010011110011011010110000001000010");
+  s = mpfr_get_str (NULL, &e, 10, 0, x, GMP_RNDD);
+  if (e != 0)
+    {
+      printf ("Error in mpfr_get_str for x=0.999999..., exponent is %d"
+              " instead of 0\n", (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_clear (x);
+}
+
+/* bugs found by Alain Delplanque */
+static void
+check_large (void)
+{
+  mpfr_t x;
+  char *s, s1[7];
+  const char xm[] = { '1', '1', '9', '1', '3', '2', '9', '3', '7', '3',
+                      '5', '8', '4', '4', '5', '4', '9', '0', '2', '9',
+                      '6', '3', '4', '4', '6', '9', '9', '1', '9', '5',
+                      '5', '7', '2', '0', '1', '7', '5', '2', '8', '6',
+                      '1', '2', '5', '2', '5', '2', '7', '4', '0', '2',
+                      '7', '9', '1', '1', '7', '4', '5', '6', '7', '5',
+                      '9', '3', '1', '4', '2', '5', '5', '6', '6', '6',
+                      '1', '6', '4', '3', '8', '1', '2', '8', '7', '6',
+                      '2', '9', '2', '0', '8', '8', '9', '4', '3', '9',
+                      '6', '2', '8', '4', '1', '1', '8', '1', '0', '6',
+                      '2', '3', '7', '6', '3', '8', '1', '5', '1', '7',
+                      '3', '4', '6', '1', '2', '4', '0', '1', '3', '0',
+                      '8', '4', '1', '3', '9', '3', '2', '0', '1', '6',
+                      '3', '6', '7', '1', '5', '1', '7', '5', '0', '1',
+                      '9', '8', '4', '0', '8', '2', '7', '9', '1', '3',
+                      '2', '2', '8', '3', '4', '1', '6', '2', '3', '9',
+                      '6', '2', '0', '7', '3', '5', '5', '5', '3', '4',
+                      '2', '1', '7', '0', '9', '7', '6', '2', '1', '0',
+                      '3', '3', '5', '4', '7', '6', '0', '9', '7', '6',
+                      '9', '3', '5', '1', '7', '8', '6', '8', '8', '2',
+                      '8', '1', '4', '3', '7', '4', '3', '3', '2', '4',
+                      '1', '5', '4', '7', '8', '1', '1', '4', '2', '1',
+                      '2', '4', '2', '7', '6', '5', '9', '5', '4', '5',
+                      '2', '6', '7', '3', '0', '3', '4', '0', '6', '9',
+                      '1', '8', '9', '9', '9', '8', '0', '5', '7', '0',
+                      '9', '3', '8', '7', '6', '2', '4', '6', '1', '6',
+                      '7', '2', '0', '3', '5', '9', '3', '5', '8', '8',
+                      '9', '7', '7', '9', '2', '7', '0', '8', '1', '6',
+                      '8', '7', '4', '8', '5', '3', '0', '8', '4', '3',
+                      '5', '6', '5', '1', '6', '6', '0', '9', '7', '9',
+                      '8', '9', '2', '7', '2', '6', '8', '5', '9', '4',
+                      '5', '8', '1', '3', '7', '2', '9', '3', '8', '3',
+                      '7', '9', '1', '7', '9', '9', '7', '7', '2', '8',
+                      '4', '6', '5', '5', '7', '3', '3', '8', '3', '6',
+                      '6', '9', '7', '1', '4', '3', '3', '7', '1', '4',
+                      '9', '4', '1', '2', '4', '9', '5', '1', '4', '7',
+                      '2', '6', '4', '4', '8', '0', '6', '2', '6', '0',
+                      '6', '9', '8', '1', '1', '7', '9', '9', '3', '9',
+                      '3', '8', '4', '7', '3', '1', '9', '0', '2', '3',
+                      '5', '3', '5', '4', '2', '1', '1', '7', '6', '7',
+                      '4', '3', '2', '2', '0', '6', '5', '9', '9', '3',
+                      '2', '6', '7', '1', '2', '0', '0', '3', '7', '3',
+                      '8', '7', '4', '3', '3', '3', '3', '3', '2', '3',
+                      '8', '2', '8', '6', '3', '1', '5', '5', '2', '2',
+                      '5', '9', '3', '3', '7', '0', '6', '2', '8', '1',
+                      '0', '3', '6', '7', '6', '9', '6', '5', '9', '0',
+                      '6', '6', '6', '3', '6', '9', '9', '3', '8', '7',
+                      '6', '5', '4', '5', '3', '5', '9', '4', '0', '0',
+                      '7', '5', '8', '5', '4', '1', '4', '3', '1', '5',
+                      '7', '6', '6', '3', '4', '4', '5', '0', '8', '7',
+                      '5', '7', '5', '0', '1', '0', '1', '8', '4', '7',
+                      '3', '1', '9', '9', '2', '7', '1', '1', '1', '2',
+                      '3', '9', '9', '6', '5', '9', '2', '3', '2', '8',
+                      '1', '5', '5', '1', '2', '6', '4', '9', '6', '6',
+                      '4', '5', '1', '1', '6', '0', '0', '3', '2', '8',
+                      '4', '8', '7', '1', '4', '9', '6', '8', '1', '6',
+                      '5', '9', '8', '3', '4', '2', '9', '7', '0', '1',
+                      '9', '2', '6', '6', '9', '1', '3', '5', '9', '3',
+                      '2', '9', '6', '2', '3', '0', '6', '0', '1', '1',
+                      '6', '5', '1', '7', '9', '0', '7', '5', '8', '6',
+                      '8', '4', '2', '1', '0', '3', '8', '6', '6', '4',
+                      '4', '9', '9', '7', '5', '8', '1', '7', '5', '7',
+                      '9', '6', '6', '8', '8', '5', '8', '6', '7', '4',
+                      '0', '7', '2', '0', '2', '9', '9', '4', '4', '1',
+                      '9', '5', '8', '6', '5', '0', '6', '7', '4', '2',
+                      '7', '3', '2', '3', '2', '7', '0', '2', '1', '3',
+                      '0', '5', '9', '0', '3', '9', '1', '4', '5', '3',
+                      '7', '2', '7', '0', '8', '5', '5', '4', '6', '1',
+                      '1', '0', '0', '9', '2', '0', '4', '1', '6', '6',
+                      '4', '6', '9', '1', '3', '2', '8', '5', '0', '3',
+                      '3', '8', '9', '8', '7', '8', '5', '9', '5', '5',
+                      '9', '1', '9', '3', '6', '5', '4', '1', '7', '4',
+                      '0', '2', '4', '7', '2', '9', '7', '1', '2', '4',
+                      '5', '8', '1', '4', '4', '6', '1', '8', '5', '8',
+                      '7', '6', '9', '7', '2', '1', '2', '0', '8', '9',
+                      '5', '9', '5', '5', '3', '8', '1', '2', '5', '4',
+                      '3', '0', '7', '6', '5', '1', '7', '8', '2', '0',
+                      '0', '7', '6', '7', '4', '8', '1', '0', '6', '3',
+                      '2', '3', '0', '5', '2', '5', '0', '1', '1', '4',
+                      '3', '8', '4', '5', '2', '3', '9', '5', '0', '9',
+                      '8', '2', '6', '4', '7', '4', '8', '0', '1', '1',
+                      '7', '1', '5', '4', '9', '0', '9', '2', '2', '3',
+                      '8', '1', '6', '9', '0', '4', '6', '4', '5', '4',
+                      '6', '3', '8', '7', '3', '6', '1', '7', '2', '3',
+                      '4', '5', '5', '2', '0', '2', '5', '8', '1', '4',
+                      '9', '3', '0', '7', '4', '1', '6', '8', '7', '8',
+                      '2', '6', '2', '5', '1', '0', '7', '4', '7', '3',
+                      '6', '6', '4', '5', '6', '6', '6', '6', '8', '5',
+                      '1', '3', '5', '7', '1', '6', '2', '0', '9', '2',
+                      '3', '2', '6', '0', '7', '9', '8', '1', '6', '2',
+                      '0', '3', '8', '8', '0', '2', '8', '7', '7', '5',
+                      '9', '3', '1', '0', '6', '7', '5', '7', '3', '1',
+                      '2', '7', '7', '2', '0', '0', '4', '1', '2', '8',
+                      '2', '0', '8', '4', '0', '5', '0', '5', '0', '1',
+                      '9', '3', '3', '6', '3', '6', '9', '6', '2', '8',
+                      '2', '9', '7', '5', '3', '8', '8', '9', '1', '1',
+                      '4', '5', '7', '7', '5', '6', '0', '2', '7', '9',
+                      '7', '2', '1', '7', '4', '3', '0', '3', '6', '7',
+                      '3', '7', '2', '2', '7', '5', '6', '2', '3', '1',
+                      '2', '1', '3', '1', '4', '2', '6', '9', '2', '3',
+                      '\0' };
+  mp_exp_t e;
+
+  mpfr_init2 (x, 3322);
+  mpfr_set_str (x, xm, 10, GMP_RNDN);
+  mpfr_div_2exp (x, x, 4343, GMP_RNDN);
+  s = mpfr_get_str (NULL, &e, 10, 1000, x, GMP_RNDN);
+  if (s[999] != '1') /* s must be 5.04383...689071e-309 */
+    {
+      printf ("Error in check_large: expected '689071', got '%s'\n",
+              s + 994);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_mul_2exp (x, x, 4343, GMP_RNDN);
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDN);
+  if (strcmp (s, "12") || (e != 1000))
+    {
+      printf ("Error in check_large: expected 0.12e1000\n");
+      printf ("got %se%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_set_nan (x);
+  s = mpfr_get_str (NULL, &e, 10, 1000, x, GMP_RNDN);
+  if (strcmp (s, "@NaN@"))
+    {
+      printf ("Error for NaN\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_get_str (s1, &e, 10, 1000, x, GMP_RNDN);
+
+  mpfr_set_inf (x, 1);
+  s = mpfr_get_str (NULL, &e, 10, 1000, x, GMP_RNDN);
+  if (strcmp (s, "@Inf@"))
+    {
+      printf ("Error for Inf\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_get_str (s1, &e, 10, 1000, x, GMP_RNDN);
+
+  mpfr_set_inf (x, -1);
+  s = mpfr_get_str (NULL, &e, 10, 1000, x, GMP_RNDN);
+  if (strcmp (s, "-@Inf@"))
+    {
+      printf ("Error for -Inf\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+
+  mpfr_get_str (s1, &e, 10, 1000, x, GMP_RNDN);
+
+  mpfr_set_ui (x, 0, GMP_RNDN);
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDN);
+  if (e != 0 || strcmp (s, "00"))
+    {
+      printf ("Error for 0.0\n");
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_get_str (s1, &e, 10, 2, x, GMP_RNDN);
+
+  mpfr_neg (x, x, GMP_RNDN); /* -0.0 */
+  s = mpfr_get_str (NULL, &e, 10, 2, x, GMP_RNDN);
+  if (e != 0 || strcmp (s, "-00"))
+    {
+      printf ("Error for -0.0\ngot %se%d\n", s, (int) e);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_get_str (s1, &e, 10, 2, x, GMP_RNDN);
+
+  mpfr_clear (x);
+}
+
+#define MAX_DIGITS 100
+
+static void
+check_special (int b, mp_prec_t p)
+{
+  mpfr_t x;
+  int i, j;
+  char s[MAX_DIGITS + 2], s2[MAX_DIGITS + 2], c;
+  mp_exp_t e;
+  int r;
+  size_t m;
+
+  /* check for invalid base */
+  MPFR_ASSERTN(mpfr_get_str (s, &e, 1, 10, x, GMP_RNDN) == NULL);
+  MPFR_ASSERTN(mpfr_get_str (s, &e, 37, 10, x, GMP_RNDN) == NULL);
+
+  s2[0] = '1';
+  for (i=1; i<MAX_DIGITS+2; i++)
+    s2[i] = '0';
+
+  mpfr_init2 (x, p);
+  mpfr_set_ui (x, 1, GMP_RNDN);
+  for (i=1; i<MAX_DIGITS && mpfr_mul_ui (x, x, b, GMP_RNDN) == 0; i++)
+    {
+      /* x = b^i (exact) */
+      for (r = 0; r < GMP_RND_MAX; r++)
+        for (m= (i<3)? 2 : i-1 ; (int) m <= i+1 ; m++)
+          {
+            mpfr_get_str (s, &e, b, m, x, (mp_rnd_t) r);
+            /* s should be 1 followed by (m-1) zeros, and e should be i+1 */
+            if ((e != i+1) || strncmp (s, s2, m) != 0)
+              {
+                printf ("Error in mpfr_get_str for %d^%d\n", b, i);
+                exit (1);
+              }
+          }
+      if (mpfr_sub_ui (x, x, 1, GMP_RNDN) != 0)
+        break;
+      /* now x = b^i-1 (exact) */
+      for (r = 0; r < GMP_RND_MAX; r++)
+        if (i >= 2)
+          {
+            mpfr_get_str (s, &e, b, i, x, (mp_rnd_t) r);
+            /* should be i times (b-1) */
+            c = (b <= 10) ? '0' + b - 1 : 'a' + (b - 11);
+            for (j=0; (j < i) && (s[j] == c); j++);
+            if ((j < i) || (e != i))
+              {
+                printf ("Error in mpfr_get_str for %d^%d-1\n", b, i);
+                printf ("got 0.%s*2^%d\n", s, (int) e);
+                exit (1);
+              }
+          }
+      if (i >= 3)
+        {
+          mpfr_get_str (s, &e, b, i - 1, x, GMP_RNDU);
+          /* should be b^i */
+          if ((e != i+1) || strncmp (s, s2, i - 1) != 0)
+            {
+              printf ("Error in mpfr_get_str for %d^%d-1\n", b, i);
+              printf ("got 0.%s*2^%d\n", s, (int) e);
+              exit (1);
+            }
+        }
+
+      mpfr_add_ui (x, x, 1, GMP_RNDN);
+    }
+  mpfr_clear (x);
+}
+
+static void
+check_bug_base2k (void)
+{
+  /*
+   * -2.63b22b55697e800000000000@130
+   * +-0.1001100011101100100010101101010101011010010111111010000000000000000000000000+00000000000000000000001E522
+  */
+  mpfr_t xx, yy, zz;
+  char *s;
+  mp_exp_t e;
+
+  mpfr_init2 (xx, 107);
+  mpfr_init2 (yy, 79);
+  mpfr_init2 (zz, 99);
+
+  mpfr_set_str (xx, "-1.90e8c3e525d7c0000000000000@-18", 16, GMP_RNDN);
+  mpfr_set_str (yy, "-2.63b22b55697e8000000@130", 16, GMP_RNDN);
+  mpfr_add (zz, xx, yy, GMP_RNDD);
+  s = mpfr_get_str (NULL, &e, 16, 0, zz, GMP_RNDN);
+  if (strcmp (s, "-263b22b55697e8000000000008"))
+    {
+      printf ("Error for get_str base 16\n"
+              "Got %s expected -263b22b55697e8000000000008\n", s);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_clears (xx, yy, zz, (mpfr_ptr) 0);
+}
+
+static void
+check_reduced_exprange (void)
+{
+  mpfr_t x;
+  char *s;
+  mp_exp_t emax, e;
+
+  emax = mpfr_get_emax ();
+  mpfr_init2 (x, 8);
+  mpfr_set_str (x, "0.11111111E0", 2, GMP_RNDN);
+  set_emax (0);
+  s = mpfr_get_str (NULL, &e, 16, 0, x, GMP_RNDN);
+  set_emax (emax);
+  if (strcmp (s, "ff0"))
+    {
+      printf ("Error for mpfr_get_str on 0.11111111E0 in base 16:\n"
+              "Got \"%s\" instead of \"ff0\".\n", s);
+      exit (1);
+    }
+  mpfr_free_str (s);
+  mpfr_clear (x);
+}
+
+#define ITER 1000
+
+int
+main (int argc, char *argv[])
+{
+  int b;
+  mpfr_t x;
+  mp_rnd_t r;
+  char s[MAX_DIGITS + 2];
+  mp_exp_t e, f;
+  size_t m;
+  mp_prec_t p;
+  int i;
+
+  tests_start_mpfr ();
+
+  check_small ();
+
+  check_special (2, 2);
+  for (i = 0; i < ITER; i++)
+    {
+      p = 2 + (randlimb () % (MAX_DIGITS - 1));
+      b = 2 + (randlimb () % 35);
+      check_special (b, p);
+    }
+
+  mpfr_init2 (x, MAX_DIGITS);
+  for (i = 0; i < ITER; i++)
+    {
+      m = 2 + (randlimb () % (MAX_DIGITS - 1));
+      mpfr_urandomb (x, RANDS);
+      e = (mp_exp_t) (randlimb () % 21) - 10;
+      mpfr_set_exp (x, (e == -10) ? mpfr_get_emin () :
+                    ((e == 10) ? mpfr_get_emax () : e));
+      b = 2 + (randlimb () % 35);
+      r = RND_RAND ();
+      mpfr_get_str (s, &f, b, m, x, r);
+    }
+  mpfr_clear (x);
+
+  check_large ();
+  check3 ("4.059650008e-83", GMP_RNDN, "40597");
+  check3 ("-6.606499965302424244461355e233", GMP_RNDN, "-66065");
+  check3 ("-7.4", GMP_RNDN, "-74000");
+  check3 ("0.997", GMP_RNDN, "99700");
+  check3 ("-4.53063926135729747564e-308", GMP_RNDN, "-45306");
+  check3 ("2.14478198760196000000e+16", GMP_RNDN, "21448");
+  check3 ("7.02293374921793516813e-84", GMP_RNDN, "70229");
+
+  check3 ("-6.7274500420134077e-87", GMP_RNDN, "-67275");
+  check3 ("-6.7274500420134077e-87", GMP_RNDZ, "-67274");
+  check3 ("-6.7274500420134077e-87", GMP_RNDU, "-67274");
+  check3 ("-6.7274500420134077e-87", GMP_RNDD, "-67275");
+
+  check3 ("6.7274500420134077e-87", GMP_RNDN, "67275");
+  check3 ("6.7274500420134077e-87", GMP_RNDZ, "67274");
+  check3 ("6.7274500420134077e-87", GMP_RNDU, "67275");
+  check3 ("6.7274500420134077e-87", GMP_RNDD, "67274");
+
+  check_bug_base2k ();
+  check_reduced_exprange ();
+
+  tests_end_mpfr ();
+  return 0;
+}