diff options
author | Damien George <damien.p.george@gmail.com> | 2018-09-27 15:21:25 +1000 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2018-09-27 15:21:25 +1000 |
commit | b3eadf3f3d0cfd4c56a519ae289288ee829229a5 (patch) | |
tree | 20e3c574c23d6a7676b2bca15b8aa03ee52fe5f4 | |
parent | 8960a2823800c4b699d319e63b7472b3628d7344 (diff) |
py/objfloat: Fix abs(-0.0) so it returns 0.0.
Nan and inf (signed and unsigned) are also handled correctly by using
signbit (they were also handled correctly with "val<0", but that didn't
handle -0.0 correctly). A test case is added for this behaviour.
-rw-r--r-- | py/objfloat.c | 3 | ||||
-rw-r--r-- | tests/float/builtin_float_abs.py | 13 |
2 files changed, 14 insertions, 2 deletions
diff --git a/py/objfloat.c b/py/objfloat.c index 2ea9947fe..4db1bb89e 100644 --- a/py/objfloat.c +++ b/py/objfloat.c @@ -161,8 +161,7 @@ STATIC mp_obj_t float_unary_op(mp_unary_op_t op, mp_obj_t o_in) { case MP_UNARY_OP_POSITIVE: return o_in; case MP_UNARY_OP_NEGATIVE: return mp_obj_new_float(-val); case MP_UNARY_OP_ABS: { - // TODO check for NaN etc - if (val < 0) { + if (signbit(val)) { return mp_obj_new_float(-val); } else { return o_in; diff --git a/tests/float/builtin_float_abs.py b/tests/float/builtin_float_abs.py new file mode 100644 index 000000000..c0935c6ee --- /dev/null +++ b/tests/float/builtin_float_abs.py @@ -0,0 +1,13 @@ +# test builtin abs function with float args + +for val in ( + '1.0', + '-1.0', + '0.0', + '-0.0', + 'nan', + '-nan', + 'inf', + '-inf', + ): + print(val, abs(float(val))) |