diff --git a/src/operator/tensor/matrix_op-inl.h b/src/operator/tensor/matrix_op-inl.h index 50cb1ae4d1df..5cd7bf6652d3 100644 --- a/src/operator/tensor/matrix_op-inl.h +++ b/src/operator/tensor/matrix_op-inl.h @@ -1950,10 +1950,10 @@ struct ReverseParam : public dmlc::Parameter { #define REVERSE_MAX_DIM 10U struct reverse { - MSHADOW_XINLINE static int ReverseIndex(index_t idx, - index_t nreversedim, - const index_t * stride_, - const index_t * trailing_) { + MSHADOW_XINLINE static index_t ReverseIndex(index_t idx, + index_t nreversedim, + const index_t * stride_, + const index_t * trailing_) { index_t outputIndex = idx; for (index_t i = 0; i < nreversedim; ++i) { const index_t low = outputIndex % trailing_[i]; diff --git a/tests/nightly/test_large_array.py b/tests/nightly/test_large_array.py index 4f47acf9ddd1..715652b9d820 100644 --- a/tests/nightly/test_large_array.py +++ b/tests/nightly/test_large_array.py @@ -279,6 +279,33 @@ def test_diag(): assert_almost_equal(r.asnumpy(), np.diag(a_np, k=k)) +def create_2d_tensor(rows, columns): + a = np.arange(0, rows).reshape(rows, 1) + b = np.broadcast_to(a, shape=(a.shape[0], columns)) + return nd.array(b, dtype=np.int64) + + +def test_transpose(): + b = create_2d_tensor(rows=LARGE_X, columns=SMALL_Y) + t = b.T + assert t.shape == (SMALL_Y, LARGE_X) + assert np.sum(t[:, -1].asnumpy() == (LARGE_X - 1)) == b.shape[1] + + +def test_swapaxes(): + b = create_2d_tensor(rows=LARGE_X, columns=SMALL_Y) + t = nd.swapaxes(b, dim1=0, dim2=1) + assert t.shape == (SMALL_Y, LARGE_X) + assert np.sum(t[:, -1].asnumpy() == (LARGE_X - 1)) == b.shape[1] + + +def test_flip(): + b = create_2d_tensor(rows=LARGE_X, columns=SMALL_Y) + t = nd.flip(b, axis=0) + assert t.shape == (LARGE_X, SMALL_Y) + assert np.sum(t[-1, :].asnumpy() == 0) == b.shape[1] + + if __name__ == '__main__': import nose nose.runmodule()