2021-10-25 08:25:27 +00:00
|
|
|
/* log1p(x) = log(1+x). The log1p function is designed to avoid the
|
|
|
|
significant loss of precision that arises from direct evaluation when x is
|
|
|
|
small. Use the substitute from _math.h on all platforms: it includes
|
|
|
|
workarounds for buggy handling of zeros.
|
|
|
|
*/
|
2009-12-21 15:27:41 +00:00
|
|
|
|
2021-10-25 08:25:27 +00:00
|
|
|
static double
|
|
|
|
_Py_log1p(double x)
|
|
|
|
{
|
2023-02-09 08:40:52 +00:00
|
|
|
/* Some platforms (e.g. MacOS X 10.8, see gh-59682) 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.
|
2009-12-21 15:27:41 +00:00
|
|
|
|
2021-10-25 08:25:27 +00:00
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
2009-12-16 20:23:42 +00:00
|
|
|
|
2009-12-21 15:27:41 +00:00
|
|
|
#define m_log1p _Py_log1p
|