isl_ast_codegen.c: generate_shifted_component_tree: explain convex "isolated"
[isl.git] / test_inputs / codegen / isolate7.st
blob673eb08b5b8852addac729c00214d5fff6e2c846
1 # Check that no expressions of the form ((-n + 2147483648) % 32) are produced.
2 domain: "[n] -> { S_2[i] : i >= 0 and i <= -1 + n; S_1[i, j] : j >= 0 and j <= -1 + n and i >= 0 and i <= -1 + n }"
3 child:
4   context: "[n] -> { [] : n <= 2147483647 and n >= 0 }"
5   child:
6     schedule: "[n] -> [{ S_1[i, j] -> [(32*floor((i)/32))]; S_2[i] -> [(32*floor((i)/32))] }, { S_1[i, j] -> [(32*floor((j)/32))]; S_2[i] -> [(32*floor((n)/32))] }]"
7     permutable: 1
8     options: "[n] -> { atomic[i0] : i0 >= 0 and i0 <= 1; isolate[[] -> [i0, i1]] : (exists (e0 = floor((i0)/32), e1 = floor((i1)/32): 32e0 = i0 and 32e1 = i1 and i0 >= 0 and i0 <= -32 + n and i1 >= 0 and i1 <= n)) or (exists (e0 = floor((i0)/32), e1 = floor((i1)/32): 32e0 = i0 and 32e1 = i1 and i0 >= 0 and i0 <= -32 + n and i1 >= -31 + n and i1 <= -31 + 2n)) }"
9     child:
10           schedule: "[n] -> [{ S_1[i, j] -> [(i - 32*floor((i)/32))]; S_2[i] -> [(i - 32*floor((i)/32))] }, { S_1[i, j] -> [(j - 32*floor((j)/32))]; S_2[i] -> [(n - 32*floor((n)/32))] }]"
11           permutable: 1
12           options: "{ separate[i0] : i0 >= 0 and i0 <= 1 }"
13           child:
14             sequence:
15             - filter: "[n] -> { S_1[i, j] }"
16             - filter: "[n] -> { S_2[i] }"