add isl_union_map_domain_factor_range
[isl.git] / include / isl / union_map.h
blobeb2288dc3cb396dcb33ef6b4ca2767813b4840b5
1 #ifndef ISL_UNION_MAP_H
2 #define ISL_UNION_MAP_H
4 #include <isl/space.h>
5 #include <isl/map_type.h>
6 #include <isl/union_map_type.h>
7 #include <isl/printer.h>
8 #include <isl/val.h>
10 #if defined(__cplusplus)
11 extern "C" {
12 #endif
14 unsigned isl_union_map_dim(__isl_keep isl_union_map *umap,
15 enum isl_dim_type type);
16 int isl_union_map_involves_dims(__isl_keep isl_union_map *umap,
17 enum isl_dim_type type, unsigned first, unsigned n);
18 __isl_give isl_id *isl_union_map_get_dim_id(__isl_keep isl_union_map *umap,
19 enum isl_dim_type type, unsigned pos);
21 __isl_constructor
22 __isl_give isl_union_map *isl_union_map_from_basic_map(
23 __isl_take isl_basic_map *bmap);
24 __isl_constructor
25 __isl_give isl_union_map *isl_union_map_from_map(__isl_take isl_map *map);
26 __isl_give isl_union_map *isl_union_map_empty(__isl_take isl_space *dim);
27 __isl_give isl_union_map *isl_union_map_copy(__isl_keep isl_union_map *umap);
28 __isl_null isl_union_map *isl_union_map_free(__isl_take isl_union_map *umap);
30 isl_ctx *isl_union_map_get_ctx(__isl_keep isl_union_map *umap);
31 __isl_give isl_space *isl_union_map_get_space(__isl_keep isl_union_map *umap);
33 __isl_give isl_union_map *isl_union_map_reset_user(
34 __isl_take isl_union_map *umap);
36 int isl_union_map_find_dim_by_name(__isl_keep isl_union_map *umap,
37 enum isl_dim_type type, const char *name);
39 __isl_give isl_union_map *isl_union_map_universe(
40 __isl_take isl_union_map *umap);
41 __isl_give isl_set *isl_union_map_params(__isl_take isl_union_map *umap);
42 __isl_give isl_union_set *isl_union_map_domain(__isl_take isl_union_map *umap);
43 __isl_give isl_union_set *isl_union_map_range(__isl_take isl_union_map *umap);
44 __isl_give isl_union_map *isl_union_map_domain_map(
45 __isl_take isl_union_map *umap);
46 __isl_give isl_union_map *isl_union_map_range_map(
47 __isl_take isl_union_map *umap);
48 __isl_give isl_union_map *isl_union_set_wrapped_domain_map(
49 __isl_take isl_union_set *uset);
50 __isl_give isl_union_map *isl_union_map_from_domain(
51 __isl_take isl_union_set *uset);
52 __isl_give isl_union_map *isl_union_map_from_range(
53 __isl_take isl_union_set *uset);
55 __isl_export
56 __isl_give isl_union_map *isl_union_map_affine_hull(
57 __isl_take isl_union_map *umap);
58 __isl_export
59 __isl_give isl_union_map *isl_union_map_polyhedral_hull(
60 __isl_take isl_union_map *umap);
61 __isl_give isl_union_map *isl_union_map_simple_hull(
62 __isl_take isl_union_map *umap);
63 __isl_export
64 __isl_give isl_union_map *isl_union_map_coalesce(
65 __isl_take isl_union_map *umap);
66 __isl_give isl_union_map *isl_union_map_compute_divs(
67 __isl_take isl_union_map *umap);
68 __isl_export
69 __isl_give isl_union_map *isl_union_map_lexmin(__isl_take isl_union_map *umap);
70 __isl_export
71 __isl_give isl_union_map *isl_union_map_lexmax(__isl_take isl_union_map *umap);
73 __isl_give isl_union_map *isl_union_map_add_map(__isl_take isl_union_map *umap,
74 __isl_take isl_map *map);
75 __isl_export
76 __isl_give isl_union_map *isl_union_map_union(__isl_take isl_union_map *umap1,
77 __isl_take isl_union_map *umap2);
78 __isl_export
79 __isl_give isl_union_map *isl_union_map_subtract(
80 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
81 __isl_export
82 __isl_give isl_union_map *isl_union_map_intersect(
83 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
84 __isl_export
85 __isl_give isl_union_map *isl_union_map_intersect_params(
86 __isl_take isl_union_map *umap, __isl_take isl_set *set);
87 __isl_give isl_union_map *isl_union_map_product(__isl_take isl_union_map *umap1,
88 __isl_take isl_union_map *umap2);
89 __isl_give isl_union_map *isl_union_map_domain_product(
90 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
91 __isl_give isl_union_map *isl_union_map_range_product(
92 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
93 __isl_give isl_union_map *isl_union_map_flat_range_product(
94 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
95 __isl_give isl_union_map *isl_union_map_domain_factor_range(
96 __isl_take isl_union_map *umap);
97 __isl_export
98 __isl_give isl_union_map *isl_union_map_gist(__isl_take isl_union_map *umap,
99 __isl_take isl_union_map *context);
100 __isl_export
101 __isl_give isl_union_map *isl_union_map_gist_params(
102 __isl_take isl_union_map *umap, __isl_take isl_set *set);
103 __isl_export
104 __isl_give isl_union_map *isl_union_map_gist_domain(
105 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset);
106 __isl_export
107 __isl_give isl_union_map *isl_union_map_gist_range(
108 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset);
110 __isl_export
111 __isl_give isl_union_map *isl_union_map_intersect_domain(
112 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset);
113 __isl_export
114 __isl_give isl_union_map *isl_union_map_intersect_range(
115 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset);
117 __isl_export
118 __isl_give isl_union_map *isl_union_map_subtract_domain(
119 __isl_take isl_union_map *umap, __isl_take isl_union_set *dom);
120 __isl_export
121 __isl_give isl_union_map *isl_union_map_subtract_range(
122 __isl_take isl_union_map *umap, __isl_take isl_union_set *dom);
124 __isl_export
125 __isl_give isl_union_map *isl_union_map_apply_domain(
126 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
127 __isl_export
128 __isl_give isl_union_map *isl_union_map_apply_range(
129 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
130 __isl_give isl_union_map *isl_union_map_preimage_domain_multi_aff(
131 __isl_take isl_union_map *umap, __isl_take isl_multi_aff *ma);
132 __isl_give isl_union_map *isl_union_map_preimage_range_multi_aff(
133 __isl_take isl_union_map *umap, __isl_take isl_multi_aff *ma);
134 __isl_give isl_union_map *isl_union_map_preimage_domain_pw_multi_aff(
135 __isl_take isl_union_map *umap, __isl_take isl_pw_multi_aff *pma);
136 __isl_give isl_union_map *isl_union_map_preimage_range_pw_multi_aff(
137 __isl_take isl_union_map *umap, __isl_take isl_pw_multi_aff *pma);
138 __isl_give isl_union_map *isl_union_map_preimage_domain_multi_pw_aff(
139 __isl_take isl_union_map *umap, __isl_take isl_multi_pw_aff *mpa);
140 __isl_give isl_union_map *isl_union_map_preimage_domain_union_pw_multi_aff(
141 __isl_take isl_union_map *umap,
142 __isl_take isl_union_pw_multi_aff *upma);
143 __isl_give isl_union_map *isl_union_map_preimage_range_union_pw_multi_aff(
144 __isl_take isl_union_map *umap,
145 __isl_take isl_union_pw_multi_aff *upma);
146 __isl_export
147 __isl_give isl_union_map *isl_union_map_reverse(__isl_take isl_union_map *umap);
148 __isl_give isl_union_map *isl_union_map_from_domain_and_range(
149 __isl_take isl_union_set *domain, __isl_take isl_union_set *range);
151 __isl_export
152 __isl_give isl_union_map *isl_union_map_detect_equalities(
153 __isl_take isl_union_map *umap);
154 __isl_export
155 __isl_give isl_union_set *isl_union_map_deltas(__isl_take isl_union_map *umap);
156 __isl_give isl_union_map *isl_union_map_deltas_map(
157 __isl_take isl_union_map *umap);
158 __isl_export
159 __isl_give isl_union_map *isl_union_set_identity(__isl_take isl_union_set *uset);
161 __isl_give isl_union_map *isl_union_map_project_out(
162 __isl_take isl_union_map *umap,
163 enum isl_dim_type type, unsigned first, unsigned n);
165 __isl_export
166 int isl_union_map_is_empty(__isl_keep isl_union_map *umap);
167 __isl_export
168 int isl_union_map_is_single_valued(__isl_keep isl_union_map *umap);
169 int isl_union_map_plain_is_injective(__isl_keep isl_union_map *umap);
170 __isl_export
171 int isl_union_map_is_injective(__isl_keep isl_union_map *umap);
172 __isl_export
173 int isl_union_map_is_bijective(__isl_keep isl_union_map *umap);
175 __isl_export
176 int isl_union_map_is_subset(__isl_keep isl_union_map *umap1,
177 __isl_keep isl_union_map *umap2);
178 __isl_export
179 int isl_union_map_is_equal(__isl_keep isl_union_map *umap1,
180 __isl_keep isl_union_map *umap2);
181 __isl_export
182 int isl_union_map_is_strict_subset(__isl_keep isl_union_map *umap1,
183 __isl_keep isl_union_map *umap2);
185 int isl_union_map_n_map(__isl_keep isl_union_map *umap);
186 __isl_export
187 int isl_union_map_foreach_map(__isl_keep isl_union_map *umap,
188 int (*fn)(__isl_take isl_map *map, void *user), void *user);
189 __isl_give int isl_union_map_contains(__isl_keep isl_union_map *umap,
190 __isl_keep isl_space *dim);
191 __isl_give isl_map *isl_union_map_extract_map(__isl_keep isl_union_map *umap,
192 __isl_take isl_space *dim);
193 __isl_give isl_map *isl_map_from_union_map(__isl_take isl_union_map *umap);
195 __isl_give isl_basic_map *isl_union_map_sample(__isl_take isl_union_map *umap);
197 __isl_give isl_union_map *isl_union_map_fixed_power_val(
198 __isl_take isl_union_map *umap, __isl_take isl_val *exp);
199 __isl_give isl_union_map *isl_union_map_power(__isl_take isl_union_map *umap,
200 int *exact);
201 __isl_give isl_union_map *isl_union_map_transitive_closure(
202 __isl_take isl_union_map *umap, int *exact);
204 __isl_give isl_union_map *isl_union_map_lex_lt_union_map(
205 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
206 __isl_give isl_union_map *isl_union_map_lex_le_union_map(
207 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
208 __isl_give isl_union_map *isl_union_map_lex_gt_union_map(
209 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
210 __isl_give isl_union_map *isl_union_map_lex_ge_union_map(
211 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2);
213 __isl_give isl_union_map *isl_union_map_read_from_file(isl_ctx *ctx,
214 FILE *input);
215 __isl_constructor
216 __isl_give isl_union_map *isl_union_map_read_from_str(isl_ctx *ctx,
217 const char *str);
218 __isl_give char *isl_union_map_to_str(__isl_keep isl_union_map *umap);
219 __isl_give isl_printer *isl_printer_print_union_map(__isl_take isl_printer *p,
220 __isl_keep isl_union_map *umap);
221 void isl_union_map_dump(__isl_keep isl_union_map *umap);
223 __isl_give isl_union_set *isl_union_map_wrap(__isl_take isl_union_map *umap);
224 __isl_give isl_union_map *isl_union_set_unwrap(__isl_take isl_union_set *uset);
226 __isl_give isl_union_map *isl_union_map_zip(__isl_take isl_union_map *umap);
227 __isl_give isl_union_map *isl_union_map_curry(__isl_take isl_union_map *umap);
228 __isl_give isl_union_map *isl_union_map_uncurry(__isl_take isl_union_map *umap);
230 __isl_give isl_union_map *isl_union_map_align_params(
231 __isl_take isl_union_map *umap, __isl_take isl_space *model);
232 __isl_give isl_union_set *isl_union_set_align_params(
233 __isl_take isl_union_set *uset, __isl_take isl_space *model);
235 #if defined(__cplusplus)
237 #endif
239 #include <isl/dim.h>
241 #endif