diff options
author | Mark Dickinson <mdickinson@enthought.com> | 2012-08-18 11:24:30 (GMT) |
---|---|---|
committer | Mark Dickinson <mdickinson@enthought.com> | 2012-08-18 11:24:30 (GMT) |
commit | 05d79e9abfac38878298e4381c9166e58488664a (patch) | |
tree | bf5cab95e59ccc598eb7b9c3707efa65fd0040f2 /Modules | |
parent | 31a11902b3c2483998cee2573deb42ac9e0e24c0 (diff) | |
download | cpython-05d79e9abfac38878298e4381c9166e58488664a.zip cpython-05d79e9abfac38878298e4381c9166e58488664a.tar.gz cpython-05d79e9abfac38878298e4381c9166e58488664a.tar.bz2 |
Issue #15477: Add workaround for log1p(-0.0) on platforms where it's broken.
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/_math.c | 23 | ||||
-rw-r--r-- | Modules/_math.h | 8 |
2 files changed, 25 insertions, 6 deletions
diff --git a/Modules/_math.c b/Modules/_math.c index 2fef481..fe75a36 100644 --- a/Modules/_math.c +++ b/Modules/_math.c @@ -189,6 +189,27 @@ _Py_expm1(double x) significant loss of precision that arises from direct evaluation when x is small. */ +#ifdef HAVE_LOG1P + +double +_Py_log1p(double x) +{ + /* Some platforms supply a log1p function but don't respect the sign of + zero: log1p(-0.0) gives 0.0 instead of the correct result of -0.0. + + To save fiddling with configure tests and platform checks, we handle the + special case of zero input directly on all platforms. + */ + if (x == 0.0) { + return x; + } + else { + return log1p(x); + } +} + +#else + double _Py_log1p(double x) { @@ -230,3 +251,5 @@ _Py_log1p(double x) return log(1.+x); } } + +#endif /* ifdef HAVE_LOG1P */ diff --git a/Modules/_math.h b/Modules/_math.h index c0ceece..cf079ad 100644 --- a/Modules/_math.h +++ b/Modules/_math.h @@ -36,10 +36,6 @@ double _Py_log1p(double x); #define m_expm1 _Py_expm1 #endif -#ifdef HAVE_LOG1P -#define m_log1p log1p -#else -/* if the system doesn't have log1p, use the substitute - function defined in Modules/_math.c. */ +/* Use the substitute from _math.c on all platforms: + it includes workarounds for buggy handling of zeros. */ #define m_log1p _Py_log1p -#endif |