Merge branch 'maint'
[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 #include <isl/union_set_type.h>
11 #include <isl/vec.h>
12
13 #if defined(__cplusplus)
14 extern "C" {
15 #endif
16
17 __isl_give isl_aff *isl_aff_zero_on_domain(__isl_take isl_local_space *ls);
18 __isl_give isl_aff *isl_aff_var_on_domain(__isl_take isl_local_space *ls,
19         enum isl_dim_type type, unsigned pos);
20
21 __isl_give isl_aff *isl_aff_copy(__isl_keep isl_aff *aff);
22 void *isl_aff_free(__isl_take isl_aff *aff);
23
24 isl_ctx *isl_aff_get_ctx(__isl_keep isl_aff *aff);
25
26 int isl_aff_dim(__isl_keep isl_aff *aff, enum isl_dim_type type);
27 int isl_aff_involves_dims(__isl_keep isl_aff *aff,
28         enum isl_dim_type type, unsigned first, unsigned n);
29
30 __isl_give isl_space *isl_aff_get_domain_space(__isl_keep isl_aff *aff);
31 __isl_give isl_space *isl_aff_get_space(__isl_keep isl_aff *aff);
32 __isl_give isl_local_space *isl_aff_get_domain_local_space(
33         __isl_keep isl_aff *aff);
34 __isl_give isl_local_space *isl_aff_get_local_space(__isl_keep isl_aff *aff);
35
36 const char *isl_aff_get_dim_name(__isl_keep isl_aff *aff,
37         enum isl_dim_type type, unsigned pos);
38 int isl_aff_get_constant(__isl_keep isl_aff *aff, isl_int *v);
39 int isl_aff_get_coefficient(__isl_keep isl_aff *aff,
40         enum isl_dim_type type, int pos, isl_int *v);
41 int isl_aff_get_denominator(__isl_keep isl_aff *aff, isl_int *v);
42 __isl_give isl_aff *isl_aff_set_constant(__isl_take isl_aff *aff, isl_int v);
43 __isl_give isl_aff *isl_aff_set_constant_si(__isl_take isl_aff *aff, int v);
44 __isl_give isl_aff *isl_aff_set_coefficient(__isl_take isl_aff *aff,
45         enum isl_dim_type type, int pos, isl_int v);
46 __isl_give isl_aff *isl_aff_set_coefficient_si(__isl_take isl_aff *aff,
47         enum isl_dim_type type, int pos, int v);
48 __isl_give isl_aff *isl_aff_set_denominator(__isl_take isl_aff *aff, isl_int v);
49 __isl_give isl_aff *isl_aff_add_constant(__isl_take isl_aff *aff, isl_int v);
50 __isl_give isl_aff *isl_aff_add_constant_si(__isl_take isl_aff *aff, int v);
51 __isl_give isl_aff *isl_aff_add_constant_num(__isl_take isl_aff *aff,
52         isl_int v);
53 __isl_give isl_aff *isl_aff_add_constant_num_si(__isl_take isl_aff *aff, int v);
54 __isl_give isl_aff *isl_aff_add_coefficient(__isl_take isl_aff *aff,
55         enum isl_dim_type type, int pos, isl_int v);
56 __isl_give isl_aff *isl_aff_add_coefficient_si(__isl_take isl_aff *aff,
57         enum isl_dim_type type, int pos, int v);
58
59 int isl_aff_is_cst(__isl_keep isl_aff *aff);
60
61 __isl_give isl_aff *isl_aff_set_dim_name(__isl_take isl_aff *aff,
62         enum isl_dim_type type, unsigned pos, const char *s);
63 __isl_give isl_aff *isl_aff_set_dim_id(__isl_take isl_aff *aff,
64         enum isl_dim_type type, unsigned pos, __isl_take isl_id *id);
65
66 int isl_aff_plain_is_equal(__isl_keep isl_aff *aff1, __isl_keep isl_aff *aff2);
67 int isl_aff_plain_is_zero(__isl_keep isl_aff *aff);
68
69 __isl_give isl_aff *isl_aff_get_div(__isl_keep isl_aff *aff, int pos);
70
71 __isl_give isl_aff *isl_aff_neg(__isl_take isl_aff *aff);
72 __isl_give isl_aff *isl_aff_ceil(__isl_take isl_aff *aff);
73 __isl_give isl_aff *isl_aff_floor(__isl_take isl_aff *aff);
74 __isl_give isl_aff *isl_aff_mod(__isl_take isl_aff *aff, isl_int mod);
75
76 __isl_give isl_aff *isl_aff_mul(__isl_take isl_aff *aff1,
77         __isl_take isl_aff *aff2);
78 __isl_give isl_aff *isl_aff_div(__isl_take isl_aff *aff1,
79         __isl_take isl_aff *aff2);
80 __isl_give isl_aff *isl_aff_add(__isl_take isl_aff *aff1,
81         __isl_take isl_aff *aff2);
82 __isl_give isl_aff *isl_aff_sub(__isl_take isl_aff *aff1,
83         __isl_take isl_aff *aff2);
84
85 __isl_give isl_aff *isl_aff_scale(__isl_take isl_aff *aff, isl_int f);
86 __isl_give isl_aff *isl_aff_scale_down(__isl_take isl_aff *aff, isl_int f);
87 __isl_give isl_aff *isl_aff_scale_down_ui(__isl_take isl_aff *aff, unsigned f);
88
89 __isl_give isl_aff *isl_aff_insert_dims(__isl_take isl_aff *aff,
90         enum isl_dim_type type, unsigned first, unsigned n);
91 __isl_give isl_aff *isl_aff_add_dims(__isl_take isl_aff *aff,
92         enum isl_dim_type type, unsigned n);
93 __isl_give isl_aff *isl_aff_drop_dims(__isl_take isl_aff *aff,
94         enum isl_dim_type type, unsigned first, unsigned n);
95 __isl_give isl_aff *isl_aff_project_domain_on_params(__isl_take isl_aff *aff);
96
97 __isl_give isl_aff *isl_aff_align_params(__isl_take isl_aff *aff,
98         __isl_take isl_space *model);
99
100 __isl_give isl_aff *isl_aff_gist(__isl_take isl_aff *aff,
101         __isl_take isl_set *context);
102 __isl_give isl_aff *isl_aff_gist_params(__isl_take isl_aff *aff,
103         __isl_take isl_set *context);
104
105 __isl_give isl_aff *isl_aff_pullback_multi_aff(__isl_take isl_aff *aff,
106         __isl_take isl_multi_aff *ma);
107
108 __isl_give isl_basic_set *isl_aff_zero_basic_set(__isl_take isl_aff *aff);
109 __isl_give isl_basic_set *isl_aff_neg_basic_set(__isl_take isl_aff *aff);
110
111 __isl_give isl_basic_set *isl_aff_le_basic_set(__isl_take isl_aff *aff1,
112         __isl_take isl_aff *aff2);
113 __isl_give isl_basic_set *isl_aff_ge_basic_set(__isl_take isl_aff *aff1,
114         __isl_take isl_aff *aff2);
115
116 __isl_give isl_aff *isl_aff_read_from_str(isl_ctx *ctx, const char *str);
117 __isl_give isl_printer *isl_printer_print_aff(__isl_take isl_printer *p,
118         __isl_keep isl_aff *aff);
119 void isl_aff_dump(__isl_keep isl_aff *aff);
120
121 isl_ctx *isl_pw_aff_get_ctx(__isl_keep isl_pw_aff *pwaff);
122 __isl_give isl_space *isl_pw_aff_get_domain_space(__isl_keep isl_pw_aff *pwaff);
123 __isl_give isl_space *isl_pw_aff_get_space(__isl_keep isl_pw_aff *pwaff);
124
125 __isl_give isl_pw_aff *isl_pw_aff_from_aff(__isl_take isl_aff *aff);
126 __isl_give isl_pw_aff *isl_pw_aff_empty(__isl_take isl_space *dim);
127 __isl_give isl_pw_aff *isl_pw_aff_alloc(__isl_take isl_set *set,
128         __isl_take isl_aff *aff);
129 __isl_give isl_pw_aff *isl_pw_aff_zero_on_domain(
130         __isl_take isl_local_space *ls);
131 __isl_give isl_pw_aff *isl_pw_aff_var_on_domain(__isl_take isl_local_space *ls,
132         enum isl_dim_type type, unsigned pos);
133
134 __isl_give isl_pw_aff *isl_set_indicator_function(__isl_take isl_set *set);
135
136 const char *isl_pw_aff_get_dim_name(__isl_keep isl_pw_aff *pa,
137         enum isl_dim_type type, unsigned pos);
138 int isl_pw_aff_has_dim_id(__isl_keep isl_pw_aff *pa,
139         enum isl_dim_type type, unsigned pos);
140 __isl_give isl_id *isl_pw_aff_get_dim_id(__isl_keep isl_pw_aff *pa,
141         enum isl_dim_type type, unsigned pos);
142 __isl_give isl_pw_aff *isl_pw_aff_set_dim_id(__isl_take isl_pw_aff *pma,
143         enum isl_dim_type type, unsigned pos, __isl_take isl_id *id);
144
145 int isl_pw_aff_is_empty(__isl_keep isl_pw_aff *pwaff);
146 int isl_pw_aff_plain_is_equal(__isl_keep isl_pw_aff *pwaff1,
147         __isl_keep isl_pw_aff *pwaff2);
148
149 __isl_give isl_pw_aff *isl_pw_aff_union_min(__isl_take isl_pw_aff *pwaff1,
150         __isl_take isl_pw_aff *pwaff2);
151 __isl_give isl_pw_aff *isl_pw_aff_union_max(__isl_take isl_pw_aff *pwaff1,
152         __isl_take isl_pw_aff *pwaff2);
153 __isl_give isl_pw_aff *isl_pw_aff_union_add(__isl_take isl_pw_aff *pwaff1,
154         __isl_take isl_pw_aff *pwaff2);
155
156 __isl_give isl_pw_aff *isl_pw_aff_copy(__isl_keep isl_pw_aff *pwaff);
157 void *isl_pw_aff_free(__isl_take isl_pw_aff *pwaff);
158
159 unsigned isl_pw_aff_dim(__isl_keep isl_pw_aff *pwaff, enum isl_dim_type type);
160 int isl_pw_aff_involves_dims(__isl_keep isl_pw_aff *pwaff,
161         enum isl_dim_type type, unsigned first, unsigned n);
162
163 int isl_pw_aff_is_cst(__isl_keep isl_pw_aff *pwaff);
164
165 __isl_give isl_pw_aff *isl_pw_aff_align_params(__isl_take isl_pw_aff *pwaff,
166         __isl_take isl_space *model);
167
168 __isl_give isl_id *isl_pw_aff_get_tuple_id(__isl_keep isl_pw_aff *pa,
169         enum isl_dim_type type);
170 __isl_give isl_pw_aff *isl_pw_aff_set_tuple_id(__isl_take isl_pw_aff *pwaff,
171         enum isl_dim_type type, __isl_take isl_id *id);
172
173 __isl_give isl_set *isl_pw_aff_domain(__isl_take isl_pw_aff *pwaff);
174
175 __isl_give isl_pw_aff *isl_pw_aff_min(__isl_take isl_pw_aff *pwaff1,
176         __isl_take isl_pw_aff *pwaff2);
177 __isl_give isl_pw_aff *isl_pw_aff_max(__isl_take isl_pw_aff *pwaff1,
178         __isl_take isl_pw_aff *pwaff2);
179 __isl_give isl_pw_aff *isl_pw_aff_mul(__isl_take isl_pw_aff *pwaff1,
180         __isl_take isl_pw_aff *pwaff2);
181 __isl_give isl_pw_aff *isl_pw_aff_div(__isl_take isl_pw_aff *pa1,
182         __isl_take isl_pw_aff *pa2);
183 __isl_give isl_pw_aff *isl_pw_aff_add(__isl_take isl_pw_aff *pwaff1,
184         __isl_take isl_pw_aff *pwaff2);
185 __isl_give isl_pw_aff *isl_pw_aff_sub(__isl_take isl_pw_aff *pwaff1,
186         __isl_take isl_pw_aff *pwaff2);
187 __isl_give isl_pw_aff *isl_pw_aff_neg(__isl_take isl_pw_aff *pwaff);
188 __isl_give isl_pw_aff *isl_pw_aff_ceil(__isl_take isl_pw_aff *pwaff);
189 __isl_give isl_pw_aff *isl_pw_aff_floor(__isl_take isl_pw_aff *pwaff);
190 __isl_give isl_pw_aff *isl_pw_aff_mod(__isl_take isl_pw_aff *pwaff,
191         isl_int mod);
192 __isl_give isl_pw_aff *isl_pw_aff_tdiv_q(__isl_take isl_pw_aff *pa1,
193         __isl_take isl_pw_aff *pa2);
194 __isl_give isl_pw_aff *isl_pw_aff_tdiv_r(__isl_take isl_pw_aff *pa1,
195         __isl_take isl_pw_aff *pa2);
196
197 __isl_give isl_pw_aff *isl_pw_aff_intersect_params(__isl_take isl_pw_aff *pa,
198         __isl_take isl_set *set);
199 __isl_give isl_pw_aff *isl_pw_aff_intersect_domain(__isl_take isl_pw_aff *pa,
200         __isl_take isl_set *set);
201
202 __isl_give isl_pw_aff *isl_pw_aff_cond(__isl_take isl_pw_aff *cond,
203         __isl_take isl_pw_aff *pwaff_true, __isl_take isl_pw_aff *pwaff_false);
204
205 __isl_give isl_pw_aff *isl_pw_aff_scale(__isl_take isl_pw_aff *pwaff,
206         isl_int f);
207 __isl_give isl_pw_aff *isl_pw_aff_scale_down(__isl_take isl_pw_aff *pwaff,
208         isl_int f);
209
210 __isl_give isl_pw_aff *isl_pw_aff_insert_dims(__isl_take isl_pw_aff *pwaff,
211         enum isl_dim_type type, unsigned first, unsigned n);
212 __isl_give isl_pw_aff *isl_pw_aff_add_dims(__isl_take isl_pw_aff *pwaff,
213         enum isl_dim_type type, unsigned n);
214 __isl_give isl_pw_aff *isl_pw_aff_drop_dims(__isl_take isl_pw_aff *pwaff,
215         enum isl_dim_type type, unsigned first, unsigned n);
216
217 __isl_give isl_pw_aff *isl_pw_aff_coalesce(__isl_take isl_pw_aff *pwqp);
218 __isl_give isl_pw_aff *isl_pw_aff_gist(__isl_take isl_pw_aff *pwaff,
219         __isl_take isl_set *context);
220 __isl_give isl_pw_aff *isl_pw_aff_gist_params(__isl_take isl_pw_aff *pwaff,
221         __isl_take isl_set *context);
222
223 __isl_give isl_pw_aff *isl_pw_aff_pullback_multi_aff(
224         __isl_take isl_pw_aff *pa, __isl_take isl_multi_aff *ma);
225 __isl_give isl_pw_aff *isl_pw_aff_pullback_pw_multi_aff(
226         __isl_take isl_pw_aff *pa, __isl_take isl_pw_multi_aff *pma);
227
228 int isl_pw_aff_n_piece(__isl_keep isl_pw_aff *pwaff);
229 int isl_pw_aff_foreach_piece(__isl_keep isl_pw_aff *pwaff,
230         int (*fn)(__isl_take isl_set *set, __isl_take isl_aff *aff,
231                     void *user), void *user);
232
233 __isl_give isl_set *isl_set_from_pw_aff(__isl_take isl_pw_aff *pwaff);
234 __isl_give isl_map *isl_map_from_pw_aff(__isl_take isl_pw_aff *pwaff);
235
236 __isl_give isl_set *isl_pw_aff_nonneg_set(__isl_take isl_pw_aff *pwaff);
237 __isl_give isl_set *isl_pw_aff_zero_set(__isl_take isl_pw_aff *pwaff);
238 __isl_give isl_set *isl_pw_aff_non_zero_set(__isl_take isl_pw_aff *pwaff);
239
240 __isl_give isl_set *isl_pw_aff_eq_set(__isl_take isl_pw_aff *pwaff1,
241         __isl_take isl_pw_aff *pwaff2);
242 __isl_give isl_set *isl_pw_aff_ne_set(__isl_take isl_pw_aff *pwaff1,
243         __isl_take isl_pw_aff *pwaff2);
244 __isl_give isl_set *isl_pw_aff_le_set(__isl_take isl_pw_aff *pwaff1,
245         __isl_take isl_pw_aff *pwaff2);
246 __isl_give isl_set *isl_pw_aff_lt_set(__isl_take isl_pw_aff *pwaff1,
247         __isl_take isl_pw_aff *pwaff2);
248 __isl_give isl_set *isl_pw_aff_ge_set(__isl_take isl_pw_aff *pwaff1,
249         __isl_take isl_pw_aff *pwaff2);
250 __isl_give isl_set *isl_pw_aff_gt_set(__isl_take isl_pw_aff *pwaff1,
251         __isl_take isl_pw_aff *pwaff2);
252
253 __isl_give isl_pw_aff *isl_pw_aff_read_from_str(isl_ctx *ctx, const char *str);
254 __isl_give isl_printer *isl_printer_print_pw_aff(__isl_take isl_printer *p,
255         __isl_keep isl_pw_aff *pwaff);
256 void isl_pw_aff_dump(__isl_keep isl_pw_aff *pwaff);
257
258 __isl_give isl_pw_aff *isl_pw_aff_list_min(__isl_take isl_pw_aff_list *list);
259 __isl_give isl_pw_aff *isl_pw_aff_list_max(__isl_take isl_pw_aff_list *list);
260
261 __isl_give isl_set *isl_pw_aff_list_eq_set(__isl_take isl_pw_aff_list *list1,
262         __isl_take isl_pw_aff_list *list2);
263 __isl_give isl_set *isl_pw_aff_list_ne_set(__isl_take isl_pw_aff_list *list1,
264         __isl_take isl_pw_aff_list *list2);
265 __isl_give isl_set *isl_pw_aff_list_le_set(__isl_take isl_pw_aff_list *list1,
266         __isl_take isl_pw_aff_list *list2);
267 __isl_give isl_set *isl_pw_aff_list_lt_set(__isl_take isl_pw_aff_list *list1,
268         __isl_take isl_pw_aff_list *list2);
269 __isl_give isl_set *isl_pw_aff_list_ge_set(__isl_take isl_pw_aff_list *list1,
270         __isl_take isl_pw_aff_list *list2);
271 __isl_give isl_set *isl_pw_aff_list_gt_set(__isl_take isl_pw_aff_list *list1,
272         __isl_take isl_pw_aff_list *list2);
273
274 ISL_DECLARE_MULTI(aff)
275
276 __isl_give isl_multi_aff *isl_multi_aff_from_aff(__isl_take isl_aff *aff);
277 __isl_give isl_multi_aff *isl_multi_aff_identity(__isl_take isl_space *space);
278
279 int isl_multi_aff_plain_is_equal(__isl_keep isl_multi_aff *maff1,
280         __isl_keep isl_multi_aff *maff2);
281
282 __isl_give isl_multi_aff *isl_multi_aff_add(__isl_take isl_multi_aff *maff1,
283         __isl_take isl_multi_aff *maff2);
284 __isl_give isl_multi_aff *isl_multi_aff_sub(__isl_take isl_multi_aff *ma1,
285         __isl_take isl_multi_aff *ma2);
286
287 __isl_give isl_multi_aff *isl_multi_aff_scale(__isl_take isl_multi_aff *maff,
288         isl_int f);
289 __isl_give isl_multi_aff *isl_multi_aff_scale_vec(__isl_take isl_multi_aff *ma,
290         __isl_take isl_vec *v);
291
292 __isl_give isl_multi_aff *isl_multi_aff_product(
293         __isl_take isl_multi_aff *ma1, __isl_take isl_multi_aff *ma2);
294
295 __isl_give isl_multi_aff *isl_multi_aff_align_params(
296         __isl_take isl_multi_aff *multi, __isl_take isl_space *model);
297
298 __isl_give isl_multi_aff *isl_multi_aff_gist_params(
299         __isl_take isl_multi_aff *maff, __isl_take isl_set *context);
300 __isl_give isl_multi_aff *isl_multi_aff_gist(__isl_take isl_multi_aff *maff,
301         __isl_take isl_set *context);
302
303 __isl_give isl_multi_aff *isl_multi_aff_lift(__isl_take isl_multi_aff *maff,
304         __isl_give isl_local_space **ls);
305
306 __isl_give isl_multi_aff *isl_multi_aff_pullback_multi_aff(
307         __isl_take isl_multi_aff *ma1, __isl_take isl_multi_aff *ma2);
308
309 __isl_give isl_set *isl_multi_aff_lex_le_set(__isl_take isl_multi_aff *ma1,
310         __isl_take isl_multi_aff *ma2);
311 __isl_give isl_set *isl_multi_aff_lex_ge_set(__isl_take isl_multi_aff *ma1,
312         __isl_take isl_multi_aff *ma2);
313
314 __isl_give isl_printer *isl_printer_print_multi_aff(__isl_take isl_printer *p,
315         __isl_keep isl_multi_aff *maff);
316
317 __isl_give isl_multi_aff *isl_multi_aff_read_from_str(isl_ctx *ctx,
318                 const char *str);
319 void isl_multi_aff_dump(__isl_keep isl_multi_aff *maff);
320
321 ISL_DECLARE_MULTI(pw_aff)
322
323 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_identity(
324         __isl_take isl_space *space);
325 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_from_multi_aff(
326         __isl_take isl_multi_aff *ma);
327 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_alloc(__isl_take isl_set *set,
328         __isl_take isl_multi_aff *maff);
329 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_copy(
330         __isl_keep isl_pw_multi_aff *pma);
331 void *isl_pw_multi_aff_free(__isl_take isl_pw_multi_aff *pma);
332
333 unsigned isl_pw_multi_aff_dim(__isl_keep isl_pw_multi_aff *pma,
334         enum isl_dim_type type);
335 __isl_give isl_pw_aff *isl_pw_multi_aff_get_pw_aff(
336         __isl_keep isl_pw_multi_aff *pma, int pos);
337 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_set_pw_aff(
338         __isl_take isl_pw_multi_aff *pma, unsigned pos,
339         __isl_take isl_pw_aff *pa);
340
341 isl_ctx *isl_pw_multi_aff_get_ctx(__isl_keep isl_pw_multi_aff *pma);
342 __isl_give isl_space *isl_pw_multi_aff_get_domain_space(
343         __isl_keep isl_pw_multi_aff *pma);
344 __isl_give isl_space *isl_pw_multi_aff_get_space(
345         __isl_keep isl_pw_multi_aff *pma);
346 int isl_pw_multi_aff_has_tuple_name(__isl_keep isl_pw_multi_aff *pma,
347         enum isl_dim_type type);
348 const char *isl_pw_multi_aff_get_tuple_name(__isl_keep isl_pw_multi_aff *pma,
349         enum isl_dim_type type);
350 __isl_give isl_id *isl_pw_multi_aff_get_tuple_id(
351         __isl_keep isl_pw_multi_aff *pma, enum isl_dim_type type);
352 int isl_pw_multi_aff_has_tuple_id(__isl_keep isl_pw_multi_aff *pma,
353         enum isl_dim_type type);
354 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_set_tuple_id(
355         __isl_take isl_pw_multi_aff *pma,
356         enum isl_dim_type type, __isl_take isl_id *id);
357
358 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_drop_dims(
359         __isl_take isl_pw_multi_aff *pma,
360         enum isl_dim_type type, unsigned first, unsigned n);
361
362 __isl_give isl_set *isl_pw_multi_aff_domain(__isl_take isl_pw_multi_aff *pma);
363
364 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_empty(__isl_take isl_space *space);
365 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_from_domain(
366         __isl_take isl_set *set);
367
368 const char *isl_pw_multi_aff_get_dim_name(__isl_keep isl_pw_multi_aff *pma,
369         enum isl_dim_type type, unsigned pos);
370 __isl_give isl_id *isl_pw_multi_aff_get_dim_id(
371         __isl_keep isl_pw_multi_aff *pma, enum isl_dim_type type,
372         unsigned pos);
373 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_set_dim_id(
374         __isl_take isl_pw_multi_aff *pma,
375         enum isl_dim_type type, unsigned pos, __isl_take isl_id *id);
376
377 int isl_pw_multi_aff_plain_is_equal(__isl_keep isl_pw_multi_aff *pma1,
378         __isl_keep isl_pw_multi_aff *pma2);
379
380 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_union_add(
381         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
382
383 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_add(
384         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
385 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_sub(
386         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
387
388 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_scale_vec(
389         __isl_take isl_pw_multi_aff *pma, __isl_take isl_vec *v);
390
391 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_union_lexmin(
392         __isl_take isl_pw_multi_aff *pma1,
393         __isl_take isl_pw_multi_aff *pma2);
394 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_union_lexmax(
395         __isl_take isl_pw_multi_aff *pma1,
396         __isl_take isl_pw_multi_aff *pma2);
397
398 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_range_product(
399         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
400 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_flat_range_product(
401         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
402 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_product(
403         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
404
405 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_intersect_params(
406         __isl_take isl_pw_multi_aff *pma, __isl_take isl_set *set);
407 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_intersect_domain(
408         __isl_take isl_pw_multi_aff *pma, __isl_take isl_set *set);
409
410 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_project_domain_on_params(
411         __isl_take isl_pw_multi_aff *pma);
412
413 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_align_params(
414         __isl_take isl_pw_multi_aff *pma, __isl_take isl_space *model);
415
416 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_coalesce(
417         __isl_take isl_pw_multi_aff *pma);
418 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_gist_params(
419         __isl_take isl_pw_multi_aff *pma, __isl_take isl_set *set);
420 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_gist(
421         __isl_take isl_pw_multi_aff *pma, __isl_take isl_set *set);
422
423 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_pullback_multi_aff(
424         __isl_take isl_pw_multi_aff *pma, __isl_take isl_multi_aff *ma);
425 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_pullback_pw_multi_aff(
426         __isl_take isl_pw_multi_aff *pma1, __isl_take isl_pw_multi_aff *pma2);
427
428 int isl_pw_multi_aff_foreach_piece(__isl_keep isl_pw_multi_aff *pma,
429         int (*fn)(__isl_take isl_set *set, __isl_take isl_multi_aff *maff,
430                     void *user), void *user);
431
432 __isl_give isl_map *isl_map_from_pw_multi_aff(__isl_take isl_pw_multi_aff *pma);
433 __isl_give isl_set *isl_set_from_pw_multi_aff(__isl_take isl_pw_multi_aff *pma);
434
435 __isl_give isl_printer *isl_printer_print_pw_multi_aff(__isl_take isl_printer *p,
436         __isl_keep isl_pw_multi_aff *pma);
437
438 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_from_set(__isl_take isl_set *set);
439 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_from_map(__isl_take isl_map *map);
440
441 __isl_give isl_pw_multi_aff *isl_pw_multi_aff_read_from_str(isl_ctx *ctx,
442         const char *str);
443 void isl_pw_multi_aff_dump(__isl_keep isl_pw_multi_aff *pma);
444
445
446 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_empty(
447         __isl_take isl_space *space);
448 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_from_domain(
449         __isl_take isl_union_set *uset);
450 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_copy(
451         __isl_keep isl_union_pw_multi_aff *upma);
452 void *isl_union_pw_multi_aff_free(__isl_take isl_union_pw_multi_aff *upma);
453
454 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_add_pw_multi_aff(
455         __isl_take isl_union_pw_multi_aff *upma,
456         __isl_take isl_pw_multi_aff *pma);
457
458 isl_ctx *isl_union_pw_multi_aff_get_ctx(
459         __isl_keep isl_union_pw_multi_aff *upma);
460 __isl_give isl_space *isl_union_pw_multi_aff_get_space(
461         __isl_keep isl_union_pw_multi_aff *upma);
462
463 int isl_union_pw_multi_aff_foreach_pw_multi_aff(
464         __isl_keep isl_union_pw_multi_aff *upma,
465         int (*fn)(__isl_take isl_pw_multi_aff *pma, void *user), void *user);
466
467 __isl_give isl_union_set *isl_union_pw_multi_aff_domain(
468         __isl_take isl_union_pw_multi_aff *upma);
469
470 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_add(
471         __isl_take isl_union_pw_multi_aff *upma1,
472         __isl_take isl_union_pw_multi_aff *upma2);
473 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_sub(
474         __isl_take isl_union_pw_multi_aff *upma1,
475         __isl_take isl_union_pw_multi_aff *upma2);
476
477 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_scale_vec(
478         __isl_take isl_union_pw_multi_aff *upma, __isl_take isl_vec *v);
479
480 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_flat_range_product(
481         __isl_take isl_union_pw_multi_aff *upma1,
482         __isl_take isl_union_pw_multi_aff *upma2);
483
484 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_intersect_domain(
485         __isl_take isl_union_pw_multi_aff *upma,
486         __isl_take isl_union_set *uset);
487
488 __isl_give isl_union_map *isl_union_map_from_union_pw_multi_aff(
489         __isl_take isl_union_pw_multi_aff *upma);
490
491 __isl_give isl_printer *isl_printer_print_union_pw_multi_aff(
492         __isl_take isl_printer *p, __isl_keep isl_union_pw_multi_aff *upma);
493
494 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_from_union_set(
495         __isl_take isl_union_set *uset);
496 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_from_union_map(
497         __isl_take isl_union_map *umap);
498
499 __isl_give isl_union_pw_multi_aff *isl_union_pw_multi_aff_read_from_str(
500         isl_ctx *ctx, const char *str);
501 void isl_union_pw_multi_aff_dump(__isl_keep isl_union_pw_multi_aff *upma);
502 __isl_give char *isl_union_pw_multi_aff_to_str(
503         __isl_keep isl_union_pw_multi_aff *upma);
504
505 __isl_give isl_multi_pw_aff *isl_multi_pw_aff_identity(
506         __isl_take isl_space *space);
507 __isl_give isl_multi_pw_aff *isl_multi_pw_aff_from_pw_aff(
508         __isl_take isl_pw_aff *pa);
509
510 __isl_give isl_printer *isl_printer_print_multi_pw_aff(
511         __isl_take isl_printer *p, __isl_keep isl_multi_pw_aff *mpa);
512 void isl_multi_pw_aff_dump(__isl_keep isl_multi_pw_aff *mpa);
513
514 #if defined(__cplusplus)
515 }
516 #endif
517
518 #include <isl/dim.h>
519
520 #endif