1 #ifndef ISL_UNION_MAP_H 2 #define ISL_UNION_MAP_H 3 4 #include <isl/stdint.h> 5 #include <isl/space_type.h> 6 #include <isl/aff_type.h> 7 #include <isl/map_type.h> 8 #include <isl/union_map_type.h> 9 #include <isl/printer.h> 10 #include <isl/val_type.h> 11 12 #if defined(__cplusplus) 13 extern "C" { 14 #endif 15 16 isl_size isl_union_map_dim(__isl_keep isl_union_map *umap, 17 enum isl_dim_type type); 18 isl_bool isl_union_map_involves_dims(__isl_keep isl_union_map *umap, 19 enum isl_dim_type type, unsigned first, unsigned n); 20 __isl_give isl_id *isl_union_map_get_dim_id(__isl_keep isl_union_map *umap, 21 enum isl_dim_type type, unsigned pos); 22 23 __isl_constructor 24 __isl_give isl_union_map *isl_union_map_from_basic_map( 25 __isl_take isl_basic_map *bmap); 26 __isl_constructor 27 __isl_give isl_union_map *isl_union_map_from_map(__isl_take isl_map *map); 28 __isl_overload 29 __isl_give isl_union_map *isl_union_map_empty_ctx(isl_ctx *ctx); 30 __isl_give isl_union_map *isl_union_map_empty_space( 31 __isl_take isl_space *space); 32 __isl_give isl_union_map *isl_union_map_empty(__isl_take isl_space *space); 33 __isl_give isl_union_map *isl_union_map_copy(__isl_keep isl_union_map *umap); 34 __isl_null isl_union_map *isl_union_map_free(__isl_take isl_union_map *umap); 35 36 isl_ctx *isl_union_map_get_ctx(__isl_keep isl_union_map *umap); 37 __isl_export 38 __isl_give isl_space *isl_union_map_get_space(__isl_keep isl_union_map *umap); 39 40 __isl_give isl_union_map *isl_union_map_reset_user( 41 __isl_take isl_union_map *umap); 42 43 int isl_union_map_find_dim_by_name(__isl_keep isl_union_map *umap, 44 enum isl_dim_type type, const char *name); 45 46 __isl_export 47 __isl_give isl_union_map *isl_union_map_universe( 48 __isl_take isl_union_map *umap); 49 __isl_give isl_set *isl_union_map_params(__isl_take isl_union_map *umap); 50 __isl_export 51 __isl_give isl_union_set *isl_union_map_domain(__isl_take isl_union_map *umap); 52 __isl_export 53 __isl_give isl_union_set *isl_union_map_range(__isl_take isl_union_map *umap); 54 __isl_export 55 __isl_give isl_union_map *isl_union_map_domain_map( 56 __isl_take isl_union_map *umap); 57 __isl_export 58 __isl_give isl_union_pw_multi_aff *isl_union_map_domain_map_union_pw_multi_aff( 59 __isl_take isl_union_map *umap); 60 __isl_export 61 __isl_give isl_union_map *isl_union_map_range_map( 62 __isl_take isl_union_map *umap); 63 __isl_give isl_union_map *isl_union_set_wrapped_domain_map( 64 __isl_take isl_union_set *uset); 65 __isl_export 66 __isl_give isl_union_map *isl_union_map_from_domain( 67 __isl_take isl_union_set *uset); 68 __isl_export 69 __isl_give isl_union_map *isl_union_map_from_range( 70 __isl_take isl_union_set *uset); 71 72 __isl_export 73 __isl_give isl_union_map *isl_union_map_affine_hull( 74 __isl_take isl_union_map *umap); 75 __isl_export 76 __isl_give isl_union_map *isl_union_map_polyhedral_hull( 77 __isl_take isl_union_map *umap); 78 __isl_give isl_union_map *isl_union_map_remove_redundancies( 79 __isl_take isl_union_map *umap); 80 __isl_give isl_union_map *isl_union_map_simple_hull( 81 __isl_take isl_union_map *umap); 82 __isl_export 83 __isl_give isl_union_map *isl_union_map_coalesce( 84 __isl_take isl_union_map *umap); 85 __isl_export 86 __isl_give isl_union_map *isl_union_map_compute_divs( 87 __isl_take isl_union_map *umap); 88 __isl_export 89 __isl_give isl_union_map *isl_union_map_lexmin(__isl_take isl_union_map *umap); 90 __isl_export 91 __isl_give isl_union_map *isl_union_map_lexmax(__isl_take isl_union_map *umap); 92 93 __isl_give isl_union_map *isl_union_map_add_map(__isl_take isl_union_map *umap, 94 __isl_take isl_map *map); 95 __isl_export 96 __isl_give isl_union_map *isl_union_map_union(__isl_take isl_union_map *umap1, 97 __isl_take isl_union_map *umap2); 98 __isl_export 99 __isl_give isl_union_map *isl_union_map_subtract( 100 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 101 __isl_export 102 __isl_give isl_union_map *isl_union_map_intersect( 103 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 104 __isl_export 105 __isl_give isl_union_map *isl_union_map_intersect_params( 106 __isl_take isl_union_map *umap, __isl_take isl_set *set); 107 __isl_export 108 __isl_give isl_union_map *isl_union_map_product(__isl_take isl_union_map *umap1, 109 __isl_take isl_union_map *umap2); 110 __isl_export 111 __isl_give isl_union_map *isl_union_map_domain_product( 112 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 113 __isl_give isl_union_map *isl_union_map_flat_domain_product( 114 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 115 __isl_export 116 __isl_give isl_union_map *isl_union_map_range_product( 117 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 118 __isl_give isl_union_map *isl_union_map_flat_range_product( 119 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 120 __isl_export 121 __isl_give isl_union_map *isl_union_map_domain_factor_domain( 122 __isl_take isl_union_map *umap); 123 __isl_export 124 __isl_give isl_union_map *isl_union_map_domain_factor_range( 125 __isl_take isl_union_map *umap); 126 __isl_export 127 __isl_give isl_union_map *isl_union_map_range_factor_domain( 128 __isl_take isl_union_map *umap); 129 __isl_export 130 __isl_give isl_union_map *isl_union_map_range_factor_range( 131 __isl_take isl_union_map *umap); 132 __isl_export 133 __isl_give isl_union_map *isl_union_map_factor_domain( 134 __isl_take isl_union_map *umap); 135 __isl_export 136 __isl_give isl_union_map *isl_union_map_factor_range( 137 __isl_take isl_union_map *umap); 138 __isl_export 139 __isl_give isl_union_map *isl_union_map_gist(__isl_take isl_union_map *umap, 140 __isl_take isl_union_map *context); 141 __isl_export 142 __isl_give isl_union_map *isl_union_map_gist_params( 143 __isl_take isl_union_map *umap, __isl_take isl_set *set); 144 __isl_export 145 __isl_give isl_union_map *isl_union_map_gist_domain( 146 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset); 147 __isl_export 148 __isl_give isl_union_map *isl_union_map_gist_range( 149 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset); 150 151 __isl_overload 152 __isl_give isl_union_map *isl_union_map_intersect_domain_union_set( 153 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset); 154 __isl_overload 155 __isl_give isl_union_map *isl_union_map_intersect_domain_space( 156 __isl_take isl_union_map *umap, __isl_take isl_space *space); 157 __isl_give isl_union_map *isl_union_map_intersect_domain( 158 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset); 159 __isl_overload 160 __isl_give isl_union_map *isl_union_map_intersect_range_union_set( 161 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset); 162 __isl_overload 163 __isl_give isl_union_map *isl_union_map_intersect_range_space( 164 __isl_take isl_union_map *umap, __isl_take isl_space *space); 165 __isl_give isl_union_map *isl_union_map_intersect_range( 166 __isl_take isl_union_map *umap, __isl_take isl_union_set *uset); 167 __isl_give isl_union_map *isl_union_map_intersect_domain_factor_range( 168 __isl_take isl_union_map *umap, __isl_take isl_union_map *factor); 169 __isl_give isl_union_map *isl_union_map_intersect_range_factor_domain( 170 __isl_take isl_union_map *umap, __isl_take isl_union_map *factor); 171 __isl_give isl_union_map *isl_union_map_intersect_range_factor_range( 172 __isl_take isl_union_map *umap, __isl_take isl_union_map *factor); 173 174 __isl_export 175 __isl_give isl_union_map *isl_union_map_subtract_domain( 176 __isl_take isl_union_map *umap, __isl_take isl_union_set *dom); 177 __isl_export 178 __isl_give isl_union_map *isl_union_map_subtract_range( 179 __isl_take isl_union_map *umap, __isl_take isl_union_set *dom); 180 181 __isl_export 182 __isl_give isl_union_map *isl_union_map_apply_domain( 183 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 184 __isl_export 185 __isl_give isl_union_map *isl_union_map_apply_range( 186 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 187 __isl_overload 188 __isl_give isl_union_map *isl_union_map_preimage_domain_multi_aff( 189 __isl_take isl_union_map *umap, __isl_take isl_multi_aff *ma); 190 __isl_overload 191 __isl_give isl_union_map *isl_union_map_preimage_range_multi_aff( 192 __isl_take isl_union_map *umap, __isl_take isl_multi_aff *ma); 193 __isl_overload 194 __isl_give isl_union_map *isl_union_map_preimage_domain_pw_multi_aff( 195 __isl_take isl_union_map *umap, __isl_take isl_pw_multi_aff *pma); 196 __isl_overload 197 __isl_give isl_union_map *isl_union_map_preimage_range_pw_multi_aff( 198 __isl_take isl_union_map *umap, __isl_take isl_pw_multi_aff *pma); 199 __isl_overload 200 __isl_give isl_union_map *isl_union_map_preimage_domain_multi_pw_aff( 201 __isl_take isl_union_map *umap, __isl_take isl_multi_pw_aff *mpa); 202 __isl_overload 203 __isl_give isl_union_map *isl_union_map_preimage_domain_union_pw_multi_aff( 204 __isl_take isl_union_map *umap, 205 __isl_take isl_union_pw_multi_aff *upma); 206 __isl_overload 207 __isl_give isl_union_map *isl_union_map_preimage_range_union_pw_multi_aff( 208 __isl_take isl_union_map *umap, 209 __isl_take isl_union_pw_multi_aff *upma); 210 __isl_export 211 __isl_give isl_union_map *isl_union_map_reverse(__isl_take isl_union_map *umap); 212 __isl_export 213 __isl_give isl_union_map *isl_union_map_range_reverse( 214 __isl_take isl_union_map *umap); 215 __isl_export 216 __isl_give isl_union_map *isl_union_map_from_domain_and_range( 217 __isl_take isl_union_set *domain, __isl_take isl_union_set *range); 218 219 __isl_export 220 __isl_give isl_union_map *isl_union_map_detect_equalities( 221 __isl_take isl_union_map *umap); 222 __isl_export 223 __isl_give isl_union_set *isl_union_map_deltas(__isl_take isl_union_map *umap); 224 __isl_give isl_union_map *isl_union_map_deltas_map( 225 __isl_take isl_union_map *umap); 226 __isl_export 227 __isl_give isl_union_map *isl_union_set_identity(__isl_take isl_union_set *uset); 228 229 __isl_give isl_union_map *isl_union_map_project_out( 230 __isl_take isl_union_map *umap, 231 enum isl_dim_type type, unsigned first, unsigned n); 232 __isl_export 233 __isl_give isl_union_map *isl_union_map_project_out_all_params( 234 __isl_take isl_union_map *umap); 235 __isl_give isl_union_map *isl_union_map_remove_divs( 236 __isl_take isl_union_map *bmap); 237 238 __isl_export 239 __isl_give isl_union_set *isl_union_map_bind_range( 240 __isl_take isl_union_map *umap, __isl_take isl_multi_id *tuple); 241 242 isl_bool isl_union_map_plain_is_empty(__isl_keep isl_union_map *umap); 243 __isl_export 244 isl_bool isl_union_map_is_empty(__isl_keep isl_union_map *umap); 245 __isl_export 246 isl_bool isl_union_map_is_single_valued(__isl_keep isl_union_map *umap); 247 isl_bool isl_union_map_plain_is_injective(__isl_keep isl_union_map *umap); 248 __isl_export 249 isl_bool isl_union_map_is_injective(__isl_keep isl_union_map *umap); 250 __isl_export 251 isl_bool isl_union_map_is_bijective(__isl_keep isl_union_map *umap); 252 isl_bool isl_union_map_is_identity(__isl_keep isl_union_map *umap); 253 254 __isl_export 255 isl_bool isl_union_map_is_subset(__isl_keep isl_union_map *umap1, 256 __isl_keep isl_union_map *umap2); 257 __isl_export 258 isl_bool isl_union_map_is_equal(__isl_keep isl_union_map *umap1, 259 __isl_keep isl_union_map *umap2); 260 __isl_export 261 isl_bool isl_union_map_is_disjoint(__isl_keep isl_union_map *umap1, 262 __isl_keep isl_union_map *umap2); 263 __isl_export 264 isl_bool isl_union_map_is_strict_subset(__isl_keep isl_union_map *umap1, 265 __isl_keep isl_union_map *umap2); 266 267 uint32_t isl_union_map_get_hash(__isl_keep isl_union_map *umap); 268 269 isl_size isl_union_map_n_map(__isl_keep isl_union_map *umap); 270 __isl_export 271 isl_stat isl_union_map_foreach_map(__isl_keep isl_union_map *umap, 272 isl_stat (*fn)(__isl_take isl_map *map, void *user), void *user); 273 __isl_give isl_map_list *isl_union_map_get_map_list( 274 __isl_keep isl_union_map *umap); 275 __isl_export 276 isl_bool isl_union_map_every_map(__isl_keep isl_union_map *umap, 277 isl_bool (*test)(__isl_keep isl_map *map, void *user), void *user); 278 __isl_give isl_union_map *isl_union_map_remove_map_if( 279 __isl_take isl_union_map *umap, 280 isl_bool (*fn)(__isl_keep isl_map *map, void *user), void *user); 281 isl_bool isl_union_map_contains(__isl_keep isl_union_map *umap, 282 __isl_keep isl_space *space); 283 __isl_export 284 __isl_give isl_map *isl_union_map_extract_map(__isl_keep isl_union_map *umap, 285 __isl_take isl_space *space); 286 __isl_export 287 isl_bool isl_union_map_isa_map(__isl_keep isl_union_map *umap); 288 __isl_give isl_map *isl_map_from_union_map(__isl_take isl_union_map *umap); 289 290 __isl_give isl_basic_map *isl_union_map_sample(__isl_take isl_union_map *umap); 291 292 __isl_overload 293 __isl_give isl_union_map *isl_union_map_fixed_power_val( 294 __isl_take isl_union_map *umap, __isl_take isl_val *exp); 295 __isl_give isl_union_map *isl_union_map_power(__isl_take isl_union_map *umap, 296 isl_bool *exact); 297 __isl_give isl_union_map *isl_union_map_transitive_closure( 298 __isl_take isl_union_map *umap, isl_bool *exact); 299 300 __isl_give isl_union_map *isl_union_map_lex_lt_union_map( 301 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 302 __isl_give isl_union_map *isl_union_map_lex_le_union_map( 303 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 304 __isl_give isl_union_map *isl_union_map_lex_gt_union_map( 305 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 306 __isl_give isl_union_map *isl_union_map_lex_ge_union_map( 307 __isl_take isl_union_map *umap1, __isl_take isl_union_map *umap2); 308 309 __isl_overload 310 __isl_give isl_union_map *isl_union_map_eq_at_multi_union_pw_aff( 311 __isl_take isl_union_map *umap, 312 __isl_take isl_multi_union_pw_aff *mupa); 313 __isl_give isl_union_map *isl_union_map_lex_lt_at_multi_union_pw_aff( 314 __isl_take isl_union_map *umap, 315 __isl_take isl_multi_union_pw_aff *mupa); 316 __isl_give isl_union_map *isl_union_map_lex_gt_at_multi_union_pw_aff( 317 __isl_take isl_union_map *umap, 318 __isl_take isl_multi_union_pw_aff *mupa); 319 320 __isl_give isl_union_map *isl_union_map_read_from_file(isl_ctx *ctx, 321 FILE *input); 322 __isl_constructor 323 __isl_give isl_union_map *isl_union_map_read_from_str(isl_ctx *ctx, 324 const char *str); 325 __isl_give char *isl_union_map_to_str(__isl_keep isl_union_map *umap); 326 __isl_give isl_printer *isl_printer_print_union_map(__isl_take isl_printer *p, 327 __isl_keep isl_union_map *umap); 328 void isl_union_map_dump(__isl_keep isl_union_map *umap); 329 330 __isl_export 331 __isl_give isl_union_set *isl_union_map_wrap(__isl_take isl_union_map *umap); 332 __isl_export 333 __isl_give isl_union_map *isl_union_set_unwrap(__isl_take isl_union_set *uset); 334 335 __isl_export 336 __isl_give isl_union_map *isl_union_map_zip(__isl_take isl_union_map *umap); 337 __isl_export 338 __isl_give isl_union_map *isl_union_map_curry(__isl_take isl_union_map *umap); 339 __isl_give isl_union_map *isl_union_map_range_curry( 340 __isl_take isl_union_map *umap); 341 __isl_export 342 __isl_give isl_union_map *isl_union_map_uncurry(__isl_take isl_union_map *umap); 343 344 __isl_give isl_union_map *isl_union_map_align_params( 345 __isl_take isl_union_map *umap, __isl_take isl_space *model); 346 __isl_give isl_union_set *isl_union_set_align_params( 347 __isl_take isl_union_set *uset, __isl_take isl_space *model); 348 349 ISL_DECLARE_LIST_FN(union_map) 350 351 #if defined(__cplusplus) 352 } 353 #endif 354 355 #endif 356