export isl_multi_aff_drop_dims
[platform/upstream/isl.git] / include / isl / aff.h
1 #ifndef ISL_AFF_H
2 #define ISL_AFF_H
3
4 #include <isl/local_space.h>
5 #include <isl/printer.h>
6 #include <isl/set_type.h>
7 #include <isl/aff_type.h>
8 #include <isl/list.h>
9 #include <isl/multi.h>
10
11 #if defined(__cplusplus)
12 extern "C" {
13 #endif
14
15 __isl_give isl_aff *isl_aff_zero_on_domain(__isl_take isl_local_space *ls);
16
17 __isl_give isl_aff *isl_aff_copy(__isl_keep isl_aff *aff);
18 void *isl_aff_free(__isl_take isl_aff *aff);
19
20 isl_ctx *isl_aff_get_ctx(__isl_keep isl_aff *aff);
21
22 int isl_aff_dim(__isl_keep isl_aff *aff, enum isl_dim_type type);
23 int isl_aff_involves_dims(__isl_keep isl_aff *aff,
24         enum isl_dim_type type, unsigned first, unsigned n);
25
26 __isl_give isl_space *isl_aff_get_domain_space(__isl_keep isl_aff *aff);
27 __isl_give isl_space *isl_aff_get_space(__isl_keep isl_aff *aff);
28 __isl_give isl_local_space *isl_aff_get_domain_local_space(
29         __isl_keep isl_aff *aff);
30 __isl_give isl_local_space *isl_aff_get_local_space(__isl_keep isl_aff *aff);
31
32 const char *isl_aff_get_dim_name(__isl_keep isl_aff *aff,
33         enum isl_dim_type type, unsigned pos);
34 int isl_aff_get_constant(__isl_keep isl_aff *aff, isl_int *v);
35 int isl_aff_get_coefficient(__isl_keep isl_aff *aff,
36         enum isl_dim_type type, int pos, isl_int *v);
37 int isl_aff_get_denominator(__isl_keep isl_aff *aff, isl_int *v);
38 __isl_give isl_aff *isl_aff_set_constant(__isl_take isl_aff *aff, isl_int v);
39 __isl_give isl_aff *isl_aff_set_constant_si(__isl_take isl_aff *aff, int v);
40 __isl_give isl_aff *isl_aff_set_coefficient(__isl_take isl_aff *aff,
41         enum isl_dim_type type, int pos, isl_int v);
42 __isl_give isl_aff *isl_aff_set_coefficient_si(__isl_take isl_aff *aff,
43         enum isl_dim_type type, int pos, int v);
44 __isl_give isl_aff *isl_aff_set_denominator(__isl_take isl_aff *aff, isl_int v);
45 __isl_give isl_aff *isl_aff_add_constant(__isl_take isl_aff *aff, isl_int v);
46 __isl_give isl_aff *isl_aff_add_constant_si(__isl_take isl_aff *aff, int v);
47 __isl_give isl_aff *isl_aff_add_coefficient(__isl_take isl_aff *aff,
48         enum isl_dim_type type, int pos, isl_int v);
49 __isl_give isl_aff *isl_aff_add_coefficient_si(__isl_take isl_aff *aff,
50         enum isl_dim_type type, int pos, int v);
51
52 int isl_aff_is_cst(__isl_keep isl_aff *aff);
53
54 __isl_give isl_aff *isl_aff_set_dim_name(__isl_take isl_aff *aff,
55         enum isl_dim_type type, unsigned pos, const char *s);
56 __isl_give isl_aff *isl_aff_set_dim_id(__isl_take isl_aff *aff,
57         enum isl_dim_type type, unsigned pos, __isl_take isl_id *id);
58
59 int isl_aff_plain_is_equal(__isl_keep isl_aff *aff1, __isl_keep isl_aff *aff2);
60 int isl_aff_plain_is_zero(__isl_keep isl_aff *aff);
61
62 __isl_give isl_aff *isl_aff_get_div(__isl_keep isl_aff *aff, int pos);
63
64 __isl_give isl_aff *isl_aff_neg(__isl_take isl_aff *aff);
65 __isl_give isl_aff *isl_aff_ceil(__isl_take isl_aff *aff);
66 __isl_give isl_aff *isl_aff_floor(__isl_take isl_aff *aff);
67 __isl_give isl_aff *isl_aff_mod(__isl_take isl_aff *aff, isl_int mod);
68
69 __isl_give isl_aff *isl_aff_mul(__isl_take isl_aff *aff1,
70         __isl_take isl_aff *aff2);
71 __isl_give isl_aff *isl_aff_add(__isl_take isl_aff *aff1,
72         __isl_take isl_aff *aff2);
73 __isl_give isl_aff *isl_aff_sub(__isl_take isl_aff *aff1,
74         __isl_take isl_aff *aff2);
75
76 __isl_give isl_aff *isl_aff_scale(__isl_take isl_aff *aff, isl_int f);
77 __isl_give isl_aff *isl_aff_scale_down(__isl_take isl_aff *aff, isl_int f);
78 __isl_give isl_aff *isl_aff_scale_down_ui(__isl_take isl_aff *aff, unsigned f);
79
80 __isl_give isl_aff *isl_aff_insert_dims(__isl_take isl_aff *aff,
81         enum isl_dim_type type, unsigned first, unsigned n);
82 __isl_give isl_aff *isl_aff_add_dims(__isl_take isl_aff *aff,
83         enum isl_dim_type type, unsigned n);
84 __isl_give isl_aff *isl_aff_drop_dims(__isl_take isl_aff *aff,
85         enum isl_dim_type type, unsigned first, unsigned n);
86 __isl_give isl_aff *isl_aff_project_domain_on_params(__isl_take isl_aff *aff);
87
88 __isl_give isl_aff *isl_aff_align_params(__isl_take isl_aff *aff,
89         __isl_take isl_space *model);
90
91 __isl_give isl_aff *isl_aff_gist(__isl_take isl_aff *aff,
92         __isl_take isl_set *context);
93 __isl_give isl_aff *isl_aff_gist_params(__isl_take isl_aff *aff,
94         __isl_take isl_set *context);
95
96 __isl_give isl_basic_set *isl_aff_le_basic_set(__isl_take isl_aff *aff1,
97         __isl_take isl_aff *aff2);
98 __isl_give isl_basic_set *isl_aff_ge_basic_set(__isl_take isl_aff *aff1,
99         __isl_take isl_aff *aff2);
100
101 __isl_give isl_aff *isl_aff_read_from_str(isl_ctx *ctx, const char *str);
102 __isl_give isl_printer *isl_printer_print_aff(__isl_take isl_printer *p,
103         __isl_keep isl_aff *aff);
104 void isl_aff_dump(__isl_keep isl_aff *aff);
105
106 isl_ctx *isl_pw_aff_get_ctx(__isl_keep isl_pw_aff *pwaff);
107 __isl_give isl_space *isl_pw_aff_get_domain_space(__isl_keep isl_pw_aff *pwaff);
108 __isl_give isl_space *isl_pw_aff_get_space(__isl_keep isl_pw_aff *pwaff);
109
110 __isl_give isl_pw_aff *isl_pw_aff_from_aff(__isl_take isl_aff *aff);
111 __isl_give isl_pw_aff *isl_pw_aff_empty(__isl_take isl_space *dim);
112 __isl_give isl_pw_aff *isl_pw_aff_alloc(__isl_take isl_set *set,
113         __isl_take isl_aff *aff);
114
115 const char *isl_pw_aff_get_dim_name(__isl_keep isl_pw_aff *pa,
116         enum isl_dim_type type, unsigned pos);
117 int isl_pw_aff_has_dim_id(__isl_keep isl_pw_aff *pa,
118         enum isl_dim_type type, unsigned pos);
119 __isl_give isl_id *isl_pw_aff_get_dim_id(__isl_keep isl_pw_aff *pa,
120         enum isl_dim_type type, unsigned pos);
121 __isl_give isl_pw_aff *isl_pw_aff_set_dim_id(__isl_take isl_pw_aff *pma,
122         enum isl_dim_type type, unsigned pos, __isl_take isl_id *id);
123
124 int isl_pw_aff_is_empty(__isl_keep isl_pw_aff *pwaff);
125 int isl_pw_aff_plain_is_equal(__isl_keep isl_pw_aff *pwaff1,
126         __isl_keep isl_pw_aff *pwaff2);
127
128 __isl_give isl_pw_aff *isl_pw_aff_union_min(__isl_take isl_pw_aff *pwaff1,
129         __isl_take isl_pw_aff *pwaff2);
130 __isl_give isl_pw_aff *isl_pw_aff_union_max(__isl_take isl_pw_aff *pwaff1,
131         __isl_take isl_pw_aff *pwaff2);
132 __isl_give isl_pw_aff *isl_pw_aff_union_add(__isl_take isl_pw_aff *pwaff1,
133         __isl_take isl_pw_aff *pwaff2);
134
135 __isl_give isl_pw_aff *isl_pw_aff_copy(__isl_keep isl_pw_aff *pwaff);
136 void *isl_pw_aff_free(__isl_take isl_pw_aff *pwaff);
137
138 unsigned isl_pw_aff_dim(__isl_keep isl_pw_aff *pwaff, enum isl_dim_type type);
139 int isl_pw_aff_involves_dims(__isl_keep isl_pw_aff *pwaff,
140         enum isl_dim_type type, unsigned first, unsigned n);
141
142 int isl_pw_aff_is_cst(__isl_keep isl_pw_aff *pwaff);
143
144 __isl_give isl_pw_aff *isl_pw_aff_align_params(__isl_take isl_pw_aff *pwaff,
145         __isl_take isl_space *model);
146
147 __isl_give isl_pw_aff *isl_pw_aff_set_tuple_id(__isl_take isl_pw_aff *pwaff,
148         enum isl_dim_type type, __isl_take isl_id *id);
149
150 __isl_give isl_set *isl_pw_aff_domain(__isl_take isl_pw_aff *pwaff);
151
152 __isl_give isl_pw_aff *isl_pw_aff_min(__isl_take isl_pw_aff *pwaff1,
153         __isl_take isl_pw_aff *pwaff2);
154 __isl_give isl_pw_aff *isl_pw_aff_max(__isl_take isl_pw_aff *pwaff1,
155         __isl_take isl_pw_aff *pwaff2);
156 __isl_give isl_pw_aff *isl_pw_aff_mul(__isl_take isl_pw_aff *pwaff1,
157         __isl_take isl_pw_aff *pwaff2);
158 __isl_give isl_pw_aff *isl_pw_aff_add(__isl_take isl_pw_aff *pwaff1,
159         __isl_take isl_pw_aff *pwaff2);
160 __isl_give isl_pw_aff *isl_pw_aff_sub(__isl_take isl_pw_aff *pwaff1,
161         __isl_take isl_pw_aff *pwaff2);
162 __isl_give isl_pw_aff *isl_pw_aff_neg(__isl_take isl_pw_aff *pwaff);
163 __isl_give isl_pw_aff *isl_pw_aff_ceil(__isl_take isl_pw_aff *pwaff);
164 __isl_give isl_pw_aff *isl_pw_aff_floor(__isl_take isl_pw_aff *pwaff);
165 __isl_give isl_pw_aff *isl_pw_aff_mod(__isl_take isl_pw_aff *pwaff,
166         isl_int mod);
167
168 __isl_give isl_pw_aff *isl_pw_aff_intersect_params(__isl_take isl_pw_aff *pa,
169         __isl_take isl_set *set);
170 __isl_give isl_pw_aff *isl_pw_aff_intersect_domain(__isl_take isl_pw_aff *pa,
171         __isl_take isl_set *set);
172
173 __isl_give isl_pw_aff *isl_pw_aff_cond(__isl_take isl_set *cond,
174         __isl_take isl_pw_aff *pwaff_true, __isl_take isl_pw_aff *pwaff_false);
175
176 __isl_give isl_pw_aff *isl_pw_aff_scale(__isl_take isl_pw_aff *pwaff,
177         isl_int f);
178 __isl_give isl_pw_aff *isl_pw_aff_scale_down(__isl_take isl_pw_aff *pwaff,
179         isl_int f);
180
181 __isl_give isl_pw_aff *isl_pw_aff_insert_dims(__isl_take isl_pw_aff *pwaff,
182         enum isl_dim_type type, unsigned first, unsigned n);
183 __isl_give isl_pw_aff *isl_pw_aff_add_dims(__isl_take isl_pw_aff *pwaff,
184         enum isl_dim_type type, unsigned n);
185 __isl_give isl_pw_aff *isl_pw_aff_drop_dims(__isl_take isl_pw_aff *pwaff,
186         enum isl_dim_type type, unsigned first, unsigned n);
187
188 __isl_give isl_pw_aff *isl_pw_aff_coalesce(__isl_take isl_pw_aff *pwqp);
189 __isl_give isl_pw_aff *isl_pw_aff_gist(__isl_take isl_pw_aff *pwaff,
190         __isl_take isl_set *context);
191 __isl_give isl_pw_aff *isl_pw_aff_gist_params(__isl_take isl_pw_aff *pwaff,
192         __isl_take isl_set *context);
193
194 int isl_pw_aff_foreach_piece(__isl_keep isl_pw_aff *pwaff,
195         int (*fn)(__isl_take isl_set *set, __isl_take isl_aff *aff,
196                     void *user), void *user);
197
198 __isl_give isl_set *isl_set_from_pw_aff(__isl_take isl_pw_aff *pwaff);
199 __isl_give isl_map *isl_map_from_pw_aff(__isl_take isl_pw_aff *pwaff);
200
201 __isl_give isl_set *isl_pw_aff_nonneg_set(__isl_take isl_pw_aff *pwaff);
202 __isl_give isl_set *isl_pw_aff_zero_set(__isl_take isl_pw_aff *pwaff);
203 __isl_give isl_set *isl_pw_aff_non_zero_set(__isl_take isl_pw_aff *pwaff);
204
205 __isl_give isl_set *isl_pw_aff_eq_set(__isl_take isl_pw_aff *pwaff1,
206         __isl_take isl_pw_aff *pwaff2);
207 __isl_give isl_set *isl_pw_aff_ne_set(__isl_take isl_pw_aff *pwaff1,
208         __isl_take isl_pw_aff *pwaff2);
209 __isl_give isl_set *isl_pw_aff_le_set(__isl_take isl_pw_aff *pwaff1,
210         __isl_take isl_pw_aff *pwaff2);
211 __isl_give isl_set *isl_pw_aff_lt_set(__isl_take isl_pw_aff *pwaff1,
212         __isl_take isl_pw_aff *pwaff2);
213 __isl_give isl_set *isl_pw_aff_ge_set(__isl_take isl_pw_aff *pwaff1,
214         __isl_take isl_pw_aff *pwaff2);
215 __isl_give isl_set *isl_pw_aff_gt_set(__isl_take isl_pw_aff *pwaff1,
216         __isl_take isl_pw_aff *pwaff2);
217
218 __isl_give isl_pw_aff *isl_pw_aff_read_from_str(isl_ctx *ctx, const char *str);
219 __isl_give isl_printer *isl_printer_print_pw_aff(__isl_take isl_printer *p,
220         __isl_keep isl_pw_aff *pwaff);
221 void isl_pw_aff_dump(__isl_keep isl_pw_aff *pwaff);
222
223 __isl_give isl_pw_aff *isl_pw_aff_list_min(__isl_take isl_pw_aff_list *list);
224 __isl_give isl_pw_aff *isl_pw_aff_list_max(__isl_take isl_pw_aff_list *list);
225
226 __isl_give isl_set *isl_pw_aff_list_eq_set(__isl_take isl_pw_aff_list *list1,
227         __isl_take isl_pw_aff_list *list2);
228 __isl_give isl_set *isl_pw_aff_list_ne_set(__isl_take isl_pw_aff_list *list1,
229         __isl_take isl_pw_aff_list *list2);
230 __isl_give isl_set *isl_pw_aff_list_le_set(__isl_take isl_pw_aff_list *list1,
231         __isl_take isl_pw_aff_list *list2);
232 __isl_give isl_set *isl_pw_aff_list_lt_set(__isl_take isl_pw_aff_list *list1,
233         __isl_take isl_pw_aff_list *list2);
234 __isl_give isl_set *isl_pw_aff_list_ge_set(__isl_take isl_pw_aff_list *list1,
235         __isl_take isl_pw_aff_list *list2);
236 __isl_give isl_set *isl_pw_aff_list_gt_set(__isl_take isl_pw_aff_list *list1,
237         __isl_take isl_pw_aff_list *list2);
238
239 isl_ctx *isl_multi_aff_get_ctx(__isl_keep isl_multi_aff *maff);
240 __isl_give isl_space *isl_multi_aff_get_space(__isl_keep isl_multi_aff *maff);
241 __isl_give isl_multi_aff *isl_multi_aff_set_tuple_id(
242         __isl_take isl_multi_aff *maff,
243         enum isl_dim_type type, __isl_take isl_id *id);
244 __isl_give isl_multi_aff *isl_multi_aff_copy(__isl_keep isl_multi_aff *maff);
245 void *isl_multi_aff_free(__isl_take isl_multi_aff *maff);
246
247 unsigned isl_multi_aff_dim(__isl_keep isl_multi_aff *maff,
248         enum isl_dim_type type);
249 __isl_give isl_aff *isl_multi_aff_get_aff(__isl_keep isl_multi_aff *multi,
250         int pos);
251
252 __isl_give isl_multi_aff *isl_multi_aff_drop_dims(
253         __isl_take isl_multi_aff *maff,
254         enum isl_dim_type type, unsigned first, unsigned n);
255
256 __isl_give isl_multi_aff *isl_multi_aff_set_dim_name(
257         __isl_take isl_multi_aff *maff,
258         enum isl_dim_type type, unsigned pos, const char *s);
259
260 int isl_multi_aff_plain_is_equal(__isl_keep isl_multi_aff *maff1,
261         __isl_keep isl_multi_aff *maff2);
262
263 __isl_give isl_multi_aff *isl_multi_aff_add(__isl_take isl_multi_aff *maff1,
264         __isl_take isl_multi_aff *maff2);
265
266 __isl_give isl_multi_aff *isl_multi_aff_scale(__isl_take isl_multi_aff *maff,
267         isl_int f);
268
269 __isl_give isl_multi_aff *isl_multi_aff_gist_params(
270         __isl_take isl_multi_aff *maff, __isl_take isl_set *context);
271 __isl_give isl_multi_aff *isl_multi_aff_gist(__isl_take isl_multi_aff *maff,
272         __isl_take isl_set *context);
273
274 __isl_give isl_multi_aff *isl_multi_aff_lift(__isl_take isl_multi_aff *maff,
275         __isl_give isl_local_space **ls);
276
277 __isl_give isl_printer *isl_printer_print_multi_aff(__isl_take isl_printer *p,
278         __isl_keep isl_multi_aff *maff);
279
280 __isl_give isl_multi_aff *isl_multi_aff_read_from_str(isl_ctx *ctx,
281                 const char *str);
282 void isl_multi_aff_dump(__isl_keep isl_multi_aff *maff);
283
284 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_alloc(__isl_take isl_set *set,
285         __isl_take isl_multi_aff *maff);
286 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_copy(
287         __isl_keep isl_pw_multi_aff *pma);
288 void *isl_pw_multi_aff_free(__isl_take isl_pw_multi_aff *pma);
289
290 unsigned isl_pw_multi_aff_dim(__isl_keep isl_pw_multi_aff *pma,
291         enum isl_dim_type type);
292 __isl_give isl_pw_aff *isl_pw_multi_aff_get_pw_aff(
293         __isl_keep isl_pw_multi_aff *pma, int pos);
294
295 isl_ctx *isl_pw_multi_aff_get_ctx(__isl_keep isl_pw_multi_aff *pma);
296 __isl_give isl_space *isl_pw_multi_aff_get_domain_space(
297         __isl_keep isl_pw_multi_aff *pma);
298 __isl_give isl_space *isl_pw_multi_aff_get_space(
299         __isl_keep isl_pw_multi_aff *pma);
300 const char *isl_pw_multi_aff_get_tuple_name(__isl_keep isl_pw_multi_aff *pma,
301         enum isl_dim_type type);
302 __isl_give isl_id *isl_pw_multi_aff_get_tuple_id(
303         __isl_keep isl_pw_multi_aff *pma, enum isl_dim_type type);
304 int isl_pw_multi_aff_has_tuple_id(__isl_keep isl_pw_multi_aff *pma,
305         enum isl_dim_type type);
306 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_set_tuple_id(
307         __isl_take isl_pw_multi_aff *pma,
308         enum isl_dim_type type, __isl_take isl_id *id);
309
310 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_empty(__isl_take isl_space *space);
311
312 const char *isl_pw_multi_aff_get_dim_name(__isl_keep isl_pw_multi_aff *pma,
313         enum isl_dim_type type, unsigned pos);
314 __isl_give isl_id *isl_pw_multi_aff_get_dim_id(
315         __isl_keep isl_pw_multi_aff *pma, enum isl_dim_type type,
316         unsigned pos);
317 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_set_dim_id(
318         __isl_take isl_pw_multi_aff *pma,
319         enum isl_dim_type type, unsigned pos, __isl_take isl_id *id);
320
321 int isl_pw_multi_aff_plain_is_equal(__isl_keep isl_pw_multi_aff *pma1,
322         __isl_keep isl_pw_multi_aff *pma2);
323
324 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_union_add(
325         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
326
327 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_add(
328         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
329
330 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_intersect_params(
331         __isl_take isl_pw_multi_aff *pma, __isl_take isl_set *set);
332 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_intersect_domain(
333         __isl_take isl_pw_multi_aff *pma, __isl_take isl_set *set);
334
335 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_gist_params(
336         __isl_take isl_pw_multi_aff *pma, __isl_take isl_set *set);
337 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_gist(
338         __isl_take isl_pw_multi_aff *pma, __isl_take isl_set *set);
339
340 int isl_pw_multi_aff_foreach_piece(__isl_keep isl_pw_multi_aff *pma,
341         int (*fn)(__isl_take isl_set *set, __isl_take isl_multi_aff *maff,
342                     void *user), void *user);
343
344 __isl_give isl_map *isl_map_from_pw_multi_aff(__isl_take isl_pw_multi_aff *pma);
345 __isl_give isl_set *isl_set_from_pw_multi_aff(__isl_take isl_pw_multi_aff *pma);
346
347 __isl_give isl_printer *isl_printer_print_pw_multi_aff(__isl_take isl_printer *p,
348         __isl_keep isl_pw_multi_aff *pma);
349
350 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_from_set(__isl_take isl_set *set);
351 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_from_map(__isl_take isl_map *map);
352
353 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_read_from_str(isl_ctx *ctx,
354         const char *str);
355 void isl_pw_multi_aff_dump(__isl_keep isl_pw_multi_aff *pma);
356
357 #if defined(__cplusplus)
358 }
359 #endif
360
361 #include <isl/dim.h>
362
363 #endif