diff options
author | Sebastian Berg <sebastian@sipsolutions.net> | 2013-10-01 12:44:48 +0200 |
---|---|---|
committer | Sebastian Berg <sebastian@sipsolutions.net> | 2013-10-01 16:21:42 +0200 |
commit | 069ecaecd09a97c54dfd1b4acb3a3721f9e91aa9 (patch) | |
tree | 3cc4a855350d75df3377448501290f7cc8c7d417 /numpy/linalg/tests/test_linalg.py | |
parent | 74abfa27763f76cbce0ec1a1763f0687e5d8a4c0 (diff) | |
download | numpy-069ecaecd09a97c54dfd1b4acb3a3721f9e91aa9.tar.gz |
BUG: Allos linalg.solve to handle zero equations.
This was previously correct, but the special case was missing
since the gufunc code cannot handle it.
Diffstat (limited to 'numpy/linalg/tests/test_linalg.py')
-rw-r--r-- | numpy/linalg/tests/test_linalg.py | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/numpy/linalg/tests/test_linalg.py b/numpy/linalg/tests/test_linalg.py index af9c778a3..2c003a072 100644 --- a/numpy/linalg/tests/test_linalg.py +++ b/numpy/linalg/tests/test_linalg.py @@ -246,6 +246,24 @@ class TestSolve(LinalgTestCase, LinalgGeneralizedTestCase, TestCase): assert_raises(ValueError, linalg.solve, a[0:0], b[0:0]) assert_raises(ValueError, linalg.solve, a[:, 0:0, 0:0], b) + def test_0_size_k(self): + # test zero multiple equation (K=0) case. + class ArraySubclass(np.ndarray): + pass + a = np.arange(4).reshape(1, 2, 2) + b = np.arange(6).reshape(3, 2, 1).view(ArraySubclass) + + expected = linalg.solve(a, b)[:,:, 0:0] + result = linalg.solve(a, b[:,:, 0:0]) + assert_array_equal(result, expected) + assert_(isinstance(result, ArraySubclass)) + + # test both zero. + expected = linalg.solve(a, b)[:, 0:0, 0:0] + result = linalg.solve(a[:, 0:0, 0:0], b[:,0:0, 0:0]) + assert_array_equal(result, expected) + assert_(isinstance(result, ArraySubclass)) + class TestInv(LinalgTestCase, LinalgGeneralizedTestCase, TestCase): def do(self, a, b): |