Issue #26288: Optimize PyLong_AsDouble.

This commit is contained in:
Yury Selivanov 2016-02-05 19:40:01 -05:00
parent eb588a1d10
commit 186c30b7ae
2 changed files with 8 additions and 0 deletions

View File

@ -165,6 +165,7 @@ Core and Builtins
- Issue #25660: Fix TAB key behaviour in REPL with readline. - Issue #25660: Fix TAB key behaviour in REPL with readline.
- Issue #26288: Optimize PyLong_AsDouble.
Library Library
------- -------

View File

@ -2769,6 +2769,13 @@ PyLong_AsDouble(PyObject *v)
PyErr_SetString(PyExc_TypeError, "an integer is required"); PyErr_SetString(PyExc_TypeError, "an integer is required");
return -1.0; return -1.0;
} }
if (Py_ABS(Py_SIZE(v)) <= 1) {
/* Fast path; single digit will always fit decimal.
This improves performance of FP/long operations by at
least 20%. This is even visible on macro-benchmarks.
*/
return (double)MEDIUM_VALUE((PyLongObject *)v);
}
x = _PyLong_Frexp((PyLongObject *)v, &exponent); x = _PyLong_Frexp((PyLongObject *)v, &exponent);
if ((x == -1.0 && PyErr_Occurred()) || exponent > DBL_MAX_EXP) { if ((x == -1.0 && PyErr_Occurred()) || exponent > DBL_MAX_EXP) {
PyErr_SetString(PyExc_OverflowError, PyErr_SetString(PyExc_OverflowError,