summaryrefslogtreecommitdiff
path: root/numpy/linalg/tests/test_linalg.py
diff options
context:
space:
mode:
authorSebastian Berg <sebastian@sipsolutions.net>2013-10-01 12:44:48 +0200
committerSebastian Berg <sebastian@sipsolutions.net>2013-10-01 16:21:42 +0200
commit069ecaecd09a97c54dfd1b4acb3a3721f9e91aa9 (patch)
tree3cc4a855350d75df3377448501290f7cc8c7d417 /numpy/linalg/tests/test_linalg.py
parent74abfa27763f76cbce0ec1a1763f0687e5d8a4c0 (diff)
downloadnumpy-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.py18
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):