* lib/expl.c (expl) [HAVE_SAME_LONG_DOUBLE_AS_DOUBLE]: New alternative
implementation.
* m4/expl.m4 (gl_FUNC_EXPL): Require gl_LONG_DOUBLE_VS_DOUBLE.
Determine EXPL_LIBM according to HAVE_SAME_LONG_DOUBLE_AS_DOUBLE.
* modules/expl (Depends-on): Add exp. Update conditions.
2011-10-10 Bruno Haible <bruno@clisp.org>
2011-10-10 Bruno Haible <bruno@clisp.org>
+ expl: Simplify for platforms where 'long double' == 'double'.
+ * lib/expl.c (expl) [HAVE_SAME_LONG_DOUBLE_AS_DOUBLE]: New alternative
+ implementation.
+ * m4/expl.m4 (gl_FUNC_EXPL): Require gl_LONG_DOUBLE_VS_DOUBLE.
+ Determine EXPL_LIBM according to HAVE_SAME_LONG_DOUBLE_AS_DOUBLE.
+ * modules/expl (Depends-on): Add exp. Update conditions.
+
+2011-10-10 Bruno Haible <bruno@clisp.org>
+
sqrtl: Simplify for platforms where 'long double' == 'double'.
* lib/sqrtl.c (sqrtl) [HAVE_SAME_LONG_DOUBLE_AS_DOUBLE]: New
alternative implementation.
sqrtl: Simplify for platforms where 'long double' == 'double'.
* lib/sqrtl.c (sqrtl) [HAVE_SAME_LONG_DOUBLE_AS_DOUBLE]: New
alternative implementation.
/* Specification. */
#include <math.h>
/* Specification. */
#include <math.h>
+#if HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
+
+long double
+expl (long double x)
+{
+ return exp (x);
+}
+
+#else
+
+# include <float.h>
static const long double C[] = {
/* Chebyshev polynom coeficients for (exp(x)-1)/x */
static const long double C[] = {
/* Chebyshev polynom coeficients for (exp(x)-1)/x */
-#define P1 C[0]
-#define P2 C[1]
-#define P3 C[2]
-#define P4 C[3]
-#define P5 C[4]
-#define P6 C[5]
+# define P1 C[0]
+# define P2 C[1]
+# define P3 C[2]
+# define P4 C[3]
+# define P5 C[4]
+# define P6 C[5]
0.5L,
1.66666666666666666666666666666666683E-01L,
4.16666666666666666666654902320001674E-02L,
0.5L,
1.66666666666666666666666666666666683E-01L,
4.16666666666666666666654902320001674E-02L,
1.98412698413981650382436541785404286E-04L,
/* Smallest integer x for which e^x overflows. */
1.98412698413981650382436541785404286E-04L,
/* Smallest integer x for which e^x overflows. */
11356.523406294143949491931077970765L,
/* Largest integer x for which e^x underflows. */
11356.523406294143949491931077970765L,
/* Largest integer x for which e^x underflows. */
-11433.4627433362978788372438434526231L,
/* very small number */
-11433.4627433362978788372438434526231L,
/* very small number */
1.0e-4900L,
/* 2^16383 */
1.0e-4900L,
/* 2^16383 */
5.94865747678615882542879663314003565E+4931L};
long double
5.94865747678615882542879663314003565E+4931L};
long double
dnl Copyright (C) 2010-2011 Free Software Foundation, Inc.
dnl This file is free software; the Free Software Foundation
dnl gives unlimited permission to copy and/or distribute it,
dnl Copyright (C) 2010-2011 Free Software Foundation, Inc.
dnl This file is free software; the Free Software Foundation
dnl gives unlimited permission to copy and/or distribute it,
AC_DEFUN([gl_FUNC_EXPL],
[
AC_REQUIRE([gl_MATH_H_DEFAULTS])
AC_DEFUN([gl_FUNC_EXPL],
[
AC_REQUIRE([gl_MATH_H_DEFAULTS])
+ AC_REQUIRE([gl_LONG_DOUBLE_VS_DOUBLE])
+
dnl Persuade glibc <math.h> to declare expl().
AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS])
dnl Persuade glibc <math.h> to declare expl().
AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS])
HAVE_DECL_EXPL=0
HAVE_EXPL=0
dnl Find libraries needed to link lib/expl.c.
HAVE_DECL_EXPL=0
HAVE_EXPL=0
dnl Find libraries needed to link lib/expl.c.
- AC_REQUIRE([gl_FUNC_FLOORL])
- EXPL_LIBM="$FLOORL_LIBM"
+ if test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 1; then
+ AC_REQUIRE([gl_FUNC_EXP])
+ EXPL_LIBM="$EXP_LIBM"
+ else
+ AC_REQUIRE([gl_FUNC_FLOORL])
+ EXPL_LIBM="$FLOORL_LIBM"
+ fi
fi
AC_SUBST([EXPL_LIBM])
])
fi
AC_SUBST([EXPL_LIBM])
])
Depends-on:
math
extensions
Depends-on:
math
extensions
-float [test $HAVE_EXPL = 0]
-floorl [test $HAVE_EXPL = 0]
+exp [test $HAVE_EXPL = 0 && test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 1]
+float [test $HAVE_EXPL = 0 && test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 0]
+floorl [test $HAVE_EXPL = 0 && test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 0]
configure.ac:
gl_FUNC_EXPL
configure.ac:
gl_FUNC_EXPL