Skip to content

Commit

Permalink
Keep the intermediate values in float64.
Browse files Browse the repository at this point in the history
  • Loading branch information
jkadbear committed Jun 15, 2022
1 parent 2fbe721 commit b21dfbe
Showing 1 changed file with 9 additions and 3 deletions.
12 changes: 9 additions & 3 deletions bottleneck/src/move_template.c
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,9 @@ mover(char *name,
/* dtype = [['float64'], ['float32']] */
MOVE(move_sum, DTYPE0) {
Py_ssize_t count;
npy_DTYPE0 asum, ai, aold;
// Keep the intermediate values in float64 to reduce precision error.
// See issue pydata/bottleneck#164.
npy_float64 asum, ai, aold;
INIT(NPY_DTYPE0)
BN_BEGIN_ALLOW_THREADS
WHILE {
Expand Down Expand Up @@ -156,7 +158,9 @@ MOVE_MAIN(move_sum, 0)
/* dtype = [['float64'], ['float32']] */
MOVE(move_mean, DTYPE0) {
Py_ssize_t count;
npy_DTYPE0 asum, ai, aold, count_inv;
// Keep the intermediate values in float64 to reduce precision error.
// See issue pydata/bottleneck#164.
npy_float64 asum, ai, aold, count_inv;
INIT(NPY_DTYPE0)
BN_BEGIN_ALLOW_THREADS
WHILE {
Expand Down Expand Up @@ -244,7 +248,9 @@ MOVE_MAIN(move_mean, 0)
/* dtype = [['float64'], ['float32']] */
MOVE(NAME, DTYPE0) {
Py_ssize_t count;
npy_DTYPE0 delta, amean, assqdm, ai, aold, yi, count_inv, ddof_inv;
// Keep the intermediate values in float64 to reduce precision error.
// See issue pydata/bottleneck#164.
npy_float64 delta, amean, assqdm, ai, aold, yi, count_inv, ddof_inv;
INIT(NPY_DTYPE0)
BN_BEGIN_ALLOW_THREADS
WHILE {
Expand Down

0 comments on commit b21dfbe

Please sign in to comment.