From 8f8a0b84449787766ce53fe02c16994e7a1b9a8d Mon Sep 17 00:00:00 2001 From: Amanda Potts Date: Tue, 10 Sep 2024 19:57:51 -0400 Subject: [PATCH] Closes #3757: ak.array gives unexpected results on a transposed numpy multi-dimensional array. --- arkouda/pdarraycreation.py | 2 ++ tests/pdarray_creation_test.py | 12 ++++++++++++ 2 files changed, 14 insertions(+) diff --git a/arkouda/pdarraycreation.py b/arkouda/pdarraycreation.py index 5a17da21cf..50d6be1b88 100644 --- a/arkouda/pdarraycreation.py +++ b/arkouda/pdarraycreation.py @@ -291,6 +291,8 @@ def array( raise RuntimeError( "Array exceeds allowed transfer size. Increase ak.client.maxTransferBytes to allow" ) + # Make a copy to avoid error #3757 + a = a.copy() # Pack binary array data into a bytes object with a command header # including the dtype and size. If the server has a different byteorder # than our numpy array we need to swap to match since the server expects diff --git a/tests/pdarray_creation_test.py b/tests/pdarray_creation_test.py index fb574d86f0..82339d8ea7 100644 --- a/tests/pdarray_creation_test.py +++ b/tests/pdarray_creation_test.py @@ -8,6 +8,7 @@ import pytest import arkouda as ak +from arkouda.testing import assert_arkouda_array_equal INT_SCALARS = list(ak.dtypes.int_scalars.__args__) NUMERIC_SCALARS = list(ak.dtypes.numeric_scalars.__args__) @@ -104,6 +105,17 @@ def test_array_creation_misc(self): with pytest.raises(TypeError): ak.array(list(list(0))) + @pytest.mark.skip_if_max_rank_less_than(2) + def test_array_creation_transpose_bug_reproducer(self): + + import numpy as np + + rows = 5 + cols = 5 + nda = np.random.randint(1, 10, (rows, cols)) + + assert_arkouda_array_equal(ak.transpose(ak.array(nda)), ak.array(np.transpose(nda))) + def test_infer_shape_from_size(self): from arkouda.util import _infer_shape_from_size