Skip to content

Commit

Permalink
Copy2Map: formatted
Browse files Browse the repository at this point in the history
  • Loading branch information
lukastruemper committed Dec 2, 2023
1 parent 2407a55 commit e17f0f4
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 3 deletions.
10 changes: 8 additions & 2 deletions dace/transformation/dataflow/copy_to_map.py
Original file line number Diff line number Diff line change
Expand Up @@ -108,11 +108,17 @@ def apply(self, state: SDFGState, sdfg: SDFG):

# Linearize and delinearize to get index expression for other side
if copy_a:
a_index = [symbolic.pystr_to_symbolic(f'__i{i} + {edge.data.src_subset.ranges[i][0]}') for i in range(len(copy_shape))]
a_index = [
symbolic.pystr_to_symbolic(f'__i{i} + {edge.data.src_subset.ranges[i][0]}')
for i in range(len(copy_shape))
]
b_index = self.delinearize_linearize(bdesc, copy_shape, edge.data.get_dst_subset(edge, state))
else:
a_index = self.delinearize_linearize(adesc, copy_shape, edge.data.get_src_subset(edge, state))
b_index = [symbolic.pystr_to_symbolic(f'__i{i} + {edge.data.dst_subset.ranges[i][0]}') for i in range(len(copy_shape))]
b_index = [
symbolic.pystr_to_symbolic(f'__i{i} + {edge.data.dst_subset.ranges[i][0]}')
for i in range(len(copy_shape))
]

a_subset = subsets.Range([(ind, ind, 1) for ind in a_index])
b_subset = subsets.Range([(ind, ind, 1) for ind in b_index])
Expand Down
6 changes: 5 additions & 1 deletion tests/transformations/copy_to_map_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@


def _copy_to_map(storage: dace.StorageType):

@dace
def somecopy(a, b):
b[:] = a
Expand All @@ -24,6 +25,7 @@ def somecopy(a, b):


def _flatten_to_map(storage: dace.StorageType):

@dace
def somecopy(a, b):
b[:] = a.flatten()
Expand Down Expand Up @@ -103,6 +105,7 @@ def test_preprocess():


def test_squeezed_subset_src():

@dace.program
def squeezed_subset_src(a: dace.float32[10], b: dace.float32[10, 10]):
for i in range(10):
Expand All @@ -126,10 +129,11 @@ def squeezed_subset_src(a: dace.float32[10], b: dace.float32[10, 10]):


def test_squeezed_subset_src_swapped():

@dace.program
def squeezed_subset_src_swapped(a: dace.float32[10], b: dace.float32[10, 10]):
for i in range(10):
b[i+1:10, i] = a[0:10-(i+1)]
b[i + 1:10, i] = a[0:10 - (i + 1)]

sdfg = squeezed_subset_src_swapped.to_sdfg()

Expand Down

0 comments on commit e17f0f4

Please sign in to comment.