jdzejdzej
jdzejdzej

Reputation: 119

is numpy testing assert_array_less working correctly with np.inf?

I found this strange behaviour when testing arrays with infinite type.

This works good:

In [91]: np.testing.assert_array_less(5, 6)

In [92]: np.testing.assert_array_less(5, np.array([6]))

In [93]: 5 < np.inf
Out[93]: True

but when using numpy testing module it occurs that 5 is not less than inf:

In [94]: np.testing.assert_array_less(5, np.array([np.inf]))
---------------------------------------------------------------------------
AssertionError                            Traceback (most recent call last)
<ipython-input-93-c43a15aa8a1a> in <module>()
----> 1 np.testing.assert_array_less(5, np.array([np.inf]))

c:\python27\lib\site-packages\numpy\testing\utils.pyc in assert_array_less(x, y, err_msg, verbose)
    911     assert_array_compare(operator.__lt__, x, y, err_msg=err_msg,
    912                          verbose=verbose,
--> 913                          header='Arrays are not less-ordered')
    914
    915 def runstring(astr, dict):

c:\python27\lib\site-packages\numpy\testing\utils.pyc in assert_array_compare(comparison, x, y, err_msg, verbose, header, precision)
    629             if any(x_isinf) or any(y_isinf):
    630                 # Check +inf and -inf separately, since they are different
--> 631                 chk_same_position(x == +inf, y == +inf, hasval='+inf')
    632                 chk_same_position(x == -inf, y == -inf, hasval='-inf')
    633

c:\python27\lib\site-packages\numpy\testing\utils.pyc in chk_same_position(x_id, y_id, hasval)
    606                                 % (hasval), verbose=verbose, header=header,
    607                                 names=('x', 'y'), precision=precision)
--> 608             raise AssertionError(msg)
    609
    610     try:

AssertionError:
Arrays are not less-ordered

x and y +inf location mismatch:
 x: array(5)
 y: array([ inf])

Why numpy checks if infs are on the same positions? Is it desired behaviour?

In [99]: np.__version__
Out[99]: '1.9.3'

Upvotes: 3

Views: 388

Answers (1)

jotasi
jotasi

Reputation: 5177

As mentioned by Warren in his comment, this was/is a bug in numpy. It is fixed in the current master and thus will probably be fixed in the upcoming version 1.13:

In [1]: import numpy as np

In [2]: np.testing.assert_array_less(5, np.array([np.inf]))

In [3]: np.testing.assert_array_less(-np.inf, np.array([np.inf]))

In [4]: np.testing.assert_array_less(-np.inf, 5)

In [5]: np.testing.assert_array_less(np.inf, 5)
---------------------------------------------------------------------------
AssertionError                            Traceback (most recent call last)
<ipython-input-5-a31a27ca3803> in <module>()
----> 1 np.testing.assert_array_less(np.inf, 5)

/XXX/lib/python2.7/site-packages/numpy/testing/utils.pyc in assert_array_less(x, y, err_msg, verbose)
   1029                          verbose=verbose,
   1030                          header='Arrays are not less-ordered',
-> 1031                          equal_inf=False)
   1032
   1033

/XXX/lib/python2.7/site-packages/numpy/testing/utils.pyc in assert_array_compare(comparison, x, y, err_msg, verbose, header, precision, equal_nan, equal_inf)
    773                                 names=('x', 'y'), precision=precision)
    774             if not cond:
--> 775                 raise AssertionError(msg)
    776     except ValueError:
    777         import traceback

AssertionError:
Arrays are not less-ordered

(mismatch 100.0%)
 x: array(inf)
 y: array(5)

In [6]: np.__version__
Out[6]: '1.13.0.dev0+c5e1773'

Upvotes: 1

Related Questions