test_miobase.py 1.4 KB

1234567891011121314151617181920212223242526272829303132
  1. """ Testing miobase module
  2. """
  3. import numpy as np
  4. from numpy.testing import assert_equal
  5. from pytest import raises as assert_raises
  6. from scipy.io.matlab._miobase import matdims
  7. def test_matdims():
  8. # Test matdims dimension finder
  9. assert_equal(matdims(np.array(1)), (1, 1)) # NumPy scalar
  10. assert_equal(matdims(np.array([1])), (1, 1)) # 1-D array, 1 element
  11. assert_equal(matdims(np.array([1,2])), (2, 1)) # 1-D array, 2 elements
  12. assert_equal(matdims(np.array([[2],[3]])), (2, 1)) # 2-D array, column vector
  13. assert_equal(matdims(np.array([[2,3]])), (1, 2)) # 2-D array, row vector
  14. # 3d array, rowish vector
  15. assert_equal(matdims(np.array([[[2,3]]])), (1, 1, 2))
  16. assert_equal(matdims(np.array([])), (0, 0)) # empty 1-D array
  17. assert_equal(matdims(np.array([[]])), (1, 0)) # empty 2-D array
  18. assert_equal(matdims(np.array([[[]]])), (1, 1, 0)) # empty 3-D array
  19. assert_equal(matdims(np.empty((1, 0, 1))), (1, 0, 1)) # empty 3-D array
  20. # Optional argument flips 1-D shape behavior.
  21. assert_equal(matdims(np.array([1,2]), 'row'), (1, 2)) # 1-D array, 2 elements
  22. # The argument has to make sense though
  23. assert_raises(ValueError, matdims, np.array([1,2]), 'bizarre')
  24. # Check empty sparse matrices get their own shape
  25. from scipy.sparse import csr_matrix, csc_matrix
  26. assert_equal(matdims(csr_matrix(np.zeros((3, 3)))), (3, 3))
  27. assert_equal(matdims(csc_matrix(np.zeros((2, 2)))), (2, 2))