Skip to content

Commit

Permalink
[bug] [lang] Fix copyback for fortran contiguous numpy arrays" (#6390)
Browse files Browse the repository at this point in the history
Attempt #2
This PR got reverted due to failed release tests.

ghstack-source-id: 50cc5a88a985cb40020be0f9a07f8e38afd9e569
Pull Request resolved: #6394
  • Loading branch information
Ailing Zhang committed Oct 20, 2022
1 parent 1f4b4ba commit b7a550c
Show file tree
Hide file tree
Showing 3 changed files with 44 additions and 9 deletions.
8 changes: 6 additions & 2 deletions misc/ci_check_pr_title.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,12 @@ def get_old_ver():
with open(json_path) as f:
prtags = json.load(f)

# PR must be properly tagged. The only exception allowed here is the revert pr automatically generated by github.
if not title.startswith('[') and not title.startswith('Revert '):
# If PR titles starts with "Revert", skip title check
if title.startswith('Revert '):
exit()

# PR must be properly tagged.
if not title.startswith('['):
exit(f'PR title does not start with any tag: {title}')

if title.endswith(' '):
Expand Down
28 changes: 22 additions & 6 deletions python/taichi/lang/kernel_impl.py
Original file line number Diff line number Diff line change
Expand Up @@ -711,12 +711,28 @@ def func__(*args):
array_shape = v.shape[
element_dim:] if is_soa else v.shape[:-element_dim]
if is_numpy:
tmp = np.ascontiguousarray(v)
# Purpose: DO NOT GC |tmp|!
tmps.append(tmp)
launch_ctx.set_arg_external_array_with_shape(
actual_argument_slot, int(tmp.ctypes.data),
tmp.nbytes, array_shape)
if v.flags.c_contiguous:
launch_ctx.set_arg_external_array_with_shape(
actual_argument_slot, int(v.ctypes.data),
v.nbytes, array_shape)
elif v.flags.f_contiguous:
# TODO: A better way that avoids copying is saving strides info.
tmp = np.ascontiguousarray(v)
# Purpose: DO NOT GC |tmp|!
tmps.append(tmp)

def callback(original, updated):
np.copyto(original, np.asfortranarray(updated))

callbacks.append(
functools.partial(callback, v, tmp))
launch_ctx.set_arg_external_array_with_shape(
actual_argument_slot, int(tmp.ctypes.data),
tmp.nbytes, array_shape)
else:
raise ValueError(
"Non contiguous numpy arrays are not supported, please call np.ascontiguousarray(arr) before passing it into taichi kernel."
)
elif is_torch:
is_ndarray = False
tmp, torch_callbacks = self.get_torch_callbacks(
Expand Down
17 changes: 16 additions & 1 deletion tests/python/test_numpy.py
Original file line number Diff line number Diff line change
Expand Up @@ -89,18 +89,21 @@ def test_numpy_2d_transpose():
def test_numpy(arr: ti.types.ndarray()):
for i in ti.grouped(val):
val[i] = arr[i]
arr[i] = 1

a = np.empty(shape=(n, m), dtype=np.int32)
b = a.transpose()

for i in range(n):
for j in range(m):
a[i, j] = i * j + i * 4

test_numpy(a.transpose())
test_numpy(b)

for i in range(n):
for j in range(m):
assert val[i, j] == i * j + j * 4
assert a[i][j] == 1


@test_utils.test()
Expand Down Expand Up @@ -234,3 +237,15 @@ def test():
assert all(y == [1.0, 2.0])

test()


@test_utils.test()
def test_numpy_view():
@ti.kernel
def fill(img: ti.types.ndarray()):
img[0] = 1

a = np.zeros(shape=(2, 2))[:, 0]
with pytest.raises(ValueError,
match='Non contiguous numpy arrays are not supported'):
fill(a)

0 comments on commit b7a550c

Please sign in to comment.