isl_basic_map_simplify: reduce coefficients of integer divisions
[isl.git] / test_inputs / codegen / cloog / faber.c
blob3310f2789472a5e08dbaca0fcc8af664758a1e97
2 for (int c0 = 0; c0 <= 36; c0 += 1) {
3 for (int c1 = -6; c1 < c0 / 14 - 5; c1 += 1) {
4 for (int c2 = -((-2 * c1 + 3) / 5) + 9; c2 <= c1 + 12; c2 += 1)
5 S6(c0, c1, c2);
6 for (int c2 = c1 + 24; c2 <= -2 * c1 + 24; c2 += 1)
7 S2(c0, c1, c2);
8 for (int c2 = -2 * c1 + 30; c2 <= c1 + 48; c2 += 1)
9 S1(c0, c1, c2);
11 for (int c1 = c0 / 14 - 5; c1 < 0; c1 += 1) {
12 if (c1 >= -3 && 2 * c0 >= 7 * c1 + 42)
13 S7(c0, c1, 6);
14 for (int c2 = max(c1 - (6 * c0 + 77) / 77 + 13, -((-2 * c1 + 3) / 5) + 9); c2 <= c1 + 12; c2 += 1)
15 S6(c0, c1, c2);
16 for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 + 48; c2 += 1)
17 S1(c0, c1, c2);
19 S3(c0, 0, 0);
20 S10(c0, 0, 0);
21 for (int c2 = 1; c2 <= 5; c2 += 1)
22 S3(c0, 0, c2);
23 for (int c2 = 6; c2 <= 2 * c0 / 21 + 4; c2 += 1) {
24 S3(c0, 0, c2);
25 S7(c0, 0, c2);
27 for (int c2 = max(6, 2 * c0 / 21 + 5); c2 <= -((6 * c0 + 77) / 77) + 12; c2 += 1)
28 S3(c0, 0, c2);
29 for (int c2 = -((6 * c0 + 77) / 77) + 13; c2 <= 12; c2 += 1) {
30 S3(c0, 0, c2);
31 S6(c0, 0, c2);
33 for (int c2 = 13; c2 <= 24; c2 += 1)
34 S3(c0, 0, c2);
35 for (int c2 = -((3 * c0 + 14) / 14) + 49; c2 <= 48; c2 += 1)
36 S1(c0, 0, c2);
37 for (int c1 = 1; c1 <= 18; c1 += 1) {
38 for (int c2 = -8 * c1; c2 <= min(6, -8 * c1 + 24); c2 += 1)
39 S3(c0, c1, c2);
40 if (c0 <= 34 && c1 == 1) {
41 S3(c0, 1, 7);
42 } else if (c1 == 2) {
43 S3(c0, 2, 7);
44 } else if (c0 >= 35 && c1 == 1) {
45 S3(c0, 1, 7);
46 S7(c0, 1, 7);
48 for (int c2 = 8; c2 <= min(-8 * c1 + 24, c1 - (6 * c0 + 77) / 77 + 12); c2 += 1)
49 S3(c0, c1, c2);
50 if (c1 == 1) {
51 for (int c2 = -((6 * c0 + 77) / 77) + 14; c2 <= 13; c2 += 1) {
52 S3(c0, 1, c2);
53 S6(c0, 1, c2);
55 for (int c2 = 14; c2 <= 16; c2 += 1)
56 S3(c0, 1, c2);
58 for (int c2 = max(-8 * c1 + 25, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 + 12; c2 += 1)
59 S6(c0, c1, c2);
60 for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 + 48; c2 += 1)
61 S1(c0, c1, c2);
63 for (int c1 = 19; c1 <= 24; c1 += 1) {
64 for (int c2 = -8 * c1; c2 <= -8 * c1 + 24; c2 += 1)
65 S3(c0, c1, c2);
66 for (int c2 = c1 - (6 * c0 + 77) / 77 + 13; c2 <= 30; c2 += 1)
67 S6(c0, c1, c2);
70 for (int c0 = 37; c0 <= 218; c0 += 1) {
71 for (int c1 = (c0 + 5) / 14 - 8; c1 < min(0, c0 / 14 - 5); c1 += 1) {
72 if (c0 <= 46 && c1 == -3)
73 S7(c0, -3, 6);
74 if (77 * c1 + 77 * ((-2 * c1 - 2) / 5) + 524 >= 6 * c0)
75 S6(c0, c1, -((-2 * c1 + 3) / 5) + 9);
76 for (int c2 = c1 + 24; c2 <= -2 * c1 + 24; c2 += 1)
77 S2(c0, c1, c2);
78 for (int c2 = -2 * c1 + 30; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
79 S1(c0, c1, c2);
81 if (c0 <= 148)
82 for (int c1 = max(0, (c0 + 5) / 14 - 8); c1 < c0 / 14 - 5; c1 += 1) {
83 if (c1 == 0)
84 S2(c0, 0, 24);
85 for (int c2 = max(c1 + 24, -2 * c1 + 30); c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
86 S1(c0, c1, c2);
88 if (c0 >= 70 && c0 % 14 >= 9)
89 for (int c2 = max(c0 / 14 + 19, -((3 * c0 + 14) / 14) + c0 / 14 + 44); c2 <= -((3 * c0 + 17) / 14) + c0 / 14 + 51; c2 += 1)
90 S1(c0, c0 / 14 - 5, c2);
91 for (int c1 = c0 / 14 - 5; c1 < 0; c1 += 1) {
92 if (7 * c1 + 114 >= 2 * c0)
93 S7(c0, c1, 6);
94 for (int c2 = max(8, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1)
95 S6(c0, c1, c2);
96 for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
97 S1(c0, c1, c2);
99 for (int c1 = max(0, (c0 + 5) / 14 - 5); c1 < c0 / 14 - 2; c1 += 1) {
100 for (int c2 = max(c1, -2 * c1 + 6); c2 <= min(c1 + 5, -2 * c1 + 24); c2 += 1)
101 S9(c0, c1, c2);
102 for (int c2 = c1 + 6; c2 <= min((2 * c1 + 1) / 5 + 7, (2 * c0 - 7 * c1 - 10) / 21 + 1); c2 += 1)
103 S9(c0, c1, c2);
104 for (int c2 = max(c1 + 6, (2 * c0 - 7 * c1 - 10) / 21 + 2); c2 <= (2 * c1 + 1) / 5 + 7; c2 += 1) {
105 S7(c0, c1, c2);
106 S9(c0, c1, c2);
108 if (c1 <= 3)
109 S9(c0, c1, (2 * c1 + 1) / 5 + 8);
110 for (int c2 = (2 * c1 + 1) / 5 + 9; c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1) {
111 S6(c0, c1, c2);
112 S9(c0, c1, c2);
114 for (int c2 = max(max(c1 + 6, c1 - (6 * c0 + 91) / 77 + 16), (2 * c1 + 1) / 5 + 9); c2 <= -2 * c1 + 24; c2 += 1)
115 S9(c0, c1, c2);
116 for (int c2 = max(c1, -2 * c1 + 30); c2 <= min(c1 + 24, c1 - (3 * c0 + 17) / 14 + 47); c2 += 1)
117 S8(c0, c1, c2);
118 for (int c2 = max(c1 + 24, c1 - (3 * c0 + 14) / 14 + 49); c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
119 S1(c0, c1, c2);
121 for (int c1 = c0 / 14 - 2; c1 <= 18; c1 += 1) {
122 for (int c2 = max(6, (c0 + 5) / 14 + 1); c2 <= min(min(c1, c0 / 14 + 3), -c1 + c1 / 2 + 18); c2 += 1)
123 S5(c0, c1, c2);
124 for (int c2 = c1 + 6; c2 <= min((2 * c1 + 1) / 5 + 7, (2 * c0 - 7 * c1 + 63) / 21 + 1); c2 += 1)
125 S7(c0, c1, c2);
126 for (int c2 = max(max(c1 + 6, c1 - (6 * c0 + 77) / 77 + 13), (2 * c1 + 1) / 5 + 9); c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1)
127 S6(c0, c1, c2);
128 for (int c2 = max(c1 + (3 * c0 + 3) / 14 - 40, -c1 + (c1 + 1) / 2 + 21); c2 <= min(c1, c1 + 3 * c0 / 14 - 33); c2 += 1)
129 S4(c0, c1, c2);
130 for (int c2 = max(c1, c1 - (3 * c0 + 14) / 14 + 40); c2 <= min(c1 + 24, c1 - (3 * c0 + 17) / 14 + 47); c2 += 1)
131 S8(c0, c1, c2);
132 for (int c2 = max(c1 + 24, c1 - (3 * c0 + 14) / 14 + 49); c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1)
133 S1(c0, c1, c2);
135 for (int c1 = 19; c1 <= 24; c1 += 1) {
136 for (int c2 = max(c1 - 12, (c0 + 5) / 14 + 1); c2 <= min(c0 / 14 + 3, -c1 + c1 / 2 + 18); c2 += 1)
137 S5(c0, c1, c2);
138 for (int c2 = max(max(c1 - 12, c1 + (3 * c0 + 3) / 14 - 40), -c1 + (c1 + 1) / 2 + 21); c2 <= min(c1, c1 + 3 * c0 / 14 - 33); c2 += 1)
139 S4(c0, c1, c2);
140 for (int c2 = max(c1 + 6, c1 - (6 * c0 + 77) / 77 + 13); c2 <= min(30, c1 - (6 * c0 + 91) / 77 + 15); c2 += 1)
141 S6(c0, c1, c2);
142 for (int c2 = max(c1, c1 - (3 * c0 + 14) / 14 + 40); c2 <= min(c1 + 24, c1 - (3 * c0 + 17) / 14 + 47); c2 += 1)
143 S8(c0, c1, c2);
145 for (int c1 = 25; c1 <= min(42, -((3 * c0 + 17) / 14) + 71); c1 += 1)
146 for (int c2 = max(c1 - 12, c1 + (3 * c0 + 3) / 14 - 40); c2 <= min(min(30, c1), c1 + 3 * c0 / 14 - 33); c2 += 1)
147 S4(c0, c1, c2);