| 1 | /* | 
 
 
 
 
 | 2 | * Copyright 2008-2009 Katholieke Universiteit Leuven | 
 
 
 
 
 | 3 | * | 
 
 
 
 
 | 4 | * Use of this software is governed by the MIT license | 
 
 
 
 
 | 5 | * | 
 
 
 
 
 | 6 | * Written by Sven Verdoolaege, K.U.Leuven, Departement | 
 
 
 
 
 | 7 | * Computerwetenschappen, Celestijnenlaan 200A, B-3001 Leuven, Belgium | 
 
 
 
 
 | 8 | */ | 
 
 
 
 
 | 9 |  | 
 
 
 
 
 | 10 | #ifndef ISL_MAP_H | 
 
 
 
 
 | 11 | #define ISL_MAP_H | 
 
 
 
 
 | 12 |  | 
 
 
 
 
 | 13 | #include <stdio.h> | 
 
 
 
 
 | 14 |  | 
 
 
 
 
 | 15 | #include <isl/ctx.h> | 
 
 
 
 
 | 16 | #include <isl/space_type.h> | 
 
 
 
 
 | 17 | #include <isl/vec.h> | 
 
 
 
 
 | 18 | #include <isl/mat.h> | 
 
 
 
 
 | 19 | #include <isl/printer.h> | 
 
 
 
 
 | 20 | #include <isl/local_space.h> | 
 
 
 
 
 | 21 | #include <isl/aff_type.h> | 
 
 
 
 
 | 22 | #include <isl/list.h> | 
 
 
 
 
 | 23 | #include <isl/map_type.h> | 
 
 
 
 
 | 24 | #include <isl/val_type.h> | 
 
 
 
 
 | 25 | #include <isl/stdint.h> | 
 
 
 
 
 | 26 | #include <isl/stride_info.h> | 
 
 
 
 
 | 27 | #include <isl/fixed_box.h> | 
 
 
 
 
 | 28 |  | 
 
 
 
 
 | 29 | #if defined(__cplusplus) | 
 
 
 
 
 | 30 | extern "C" { | 
 
 
 
 
 | 31 | #endif | 
 
 
 
 
 | 32 |  | 
 
 
 
 
 | 33 | isl_size isl_basic_map_total_dim(__isl_keep const isl_basic_map *bmap); | 
 
 
 
 
 | 34 | isl_size isl_basic_map_dim(__isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 35 | enum isl_dim_type type); | 
 
 
 
 
 | 36 |  | 
 
 
 
 
 | 37 | isl_size isl_map_dim(__isl_keep isl_map *map, enum isl_dim_type type); | 
 
 
 
 
 | 38 |  | 
 
 
 
 
 | 39 | isl_ctx *isl_basic_map_get_ctx(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 40 | isl_ctx *isl_map_get_ctx(__isl_keep isl_map *map); | 
 
 
 
 
 | 41 | __isl_give isl_space *isl_basic_map_get_space(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 42 | __isl_export | 
 
 
 
 
 | 43 | __isl_give isl_space *isl_map_get_space(__isl_keep isl_map *map); | 
 
 
 
 
 | 44 |  | 
 
 
 
 
 | 45 | __isl_give isl_aff *isl_basic_map_get_div(__isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 46 | int pos); | 
 
 
 
 
 | 47 |  | 
 
 
 
 
 | 48 | __isl_give isl_local_space *isl_basic_map_get_local_space( | 
 
 
 
 
 | 49 | __isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 50 |  | 
 
 
 
 
 | 51 | __isl_give isl_basic_map *isl_basic_map_set_tuple_name( | 
 
 
 
 
 | 52 | __isl_take isl_basic_map *bmap, enum isl_dim_type type, const char *s); | 
 
 
 
 
 | 53 | const char *isl_basic_map_get_tuple_name(__isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 54 | enum isl_dim_type type); | 
 
 
 
 
 | 55 | isl_bool isl_map_has_tuple_name(__isl_keep isl_map *map, | 
 
 
 
 
 | 56 | enum isl_dim_type type); | 
 
 
 
 
 | 57 | const char *isl_map_get_tuple_name(__isl_keep isl_map *map, | 
 
 
 
 
 | 58 | enum isl_dim_type type); | 
 
 
 
 
 | 59 | __isl_give isl_map *isl_map_set_tuple_name(__isl_take isl_map *map, | 
 
 
 
 
 | 60 | enum isl_dim_type type, const char *s); | 
 
 
 
 
 | 61 | const char *isl_basic_map_get_dim_name(__isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 62 | enum isl_dim_type type, unsigned pos); | 
 
 
 
 
 | 63 | isl_bool isl_map_has_dim_name(__isl_keep isl_map *map, | 
 
 
 
 
 | 64 | enum isl_dim_type type, unsigned pos); | 
 
 
 
 
 | 65 | const char *isl_map_get_dim_name(__isl_keep isl_map *map, | 
 
 
 
 
 | 66 | enum isl_dim_type type, unsigned pos); | 
 
 
 
 
 | 67 | __isl_give isl_basic_map *isl_basic_map_set_dim_name( | 
 
 
 
 
 | 68 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 69 | enum isl_dim_type type, unsigned pos, const char *s); | 
 
 
 
 
 | 70 | __isl_give isl_map *isl_map_set_dim_name(__isl_take isl_map *map, | 
 
 
 
 
 | 71 | enum isl_dim_type type, unsigned pos, const char *s); | 
 
 
 
 
 | 72 |  | 
 
 
 
 
 | 73 | __isl_give isl_basic_map *isl_basic_map_set_tuple_id( | 
 
 
 
 
 | 74 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 75 | enum isl_dim_type type, __isl_take isl_id *id); | 
 
 
 
 
 | 76 | __isl_give isl_map *isl_map_set_dim_id(__isl_take isl_map *map, | 
 
 
 
 
 | 77 | enum isl_dim_type type, unsigned pos, __isl_take isl_id *id); | 
 
 
 
 
 | 78 | isl_bool isl_basic_map_has_dim_id(__isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 79 | enum isl_dim_type type, unsigned pos); | 
 
 
 
 
 | 80 | isl_bool isl_map_has_dim_id(__isl_keep isl_map *map, | 
 
 
 
 
 | 81 | enum isl_dim_type type, unsigned pos); | 
 
 
 
 
 | 82 | __isl_give isl_id *isl_map_get_dim_id(__isl_keep isl_map *map, | 
 
 
 
 
 | 83 | enum isl_dim_type type, unsigned pos); | 
 
 
 
 
 | 84 | __isl_overload | 
 
 
 
 
 | 85 | __isl_give isl_map *isl_map_set_domain_tuple_id(__isl_take isl_map *map, | 
 
 
 
 
 | 86 | __isl_take isl_id *id); | 
 
 
 
 
 | 87 | __isl_overload | 
 
 
 
 
 | 88 | __isl_give isl_map *isl_map_set_range_tuple_id(__isl_take isl_map *map, | 
 
 
 
 
 | 89 | __isl_take isl_id *id); | 
 
 
 
 
 | 90 | __isl_give isl_map *isl_map_set_tuple_id(__isl_take isl_map *map, | 
 
 
 
 
 | 91 | enum isl_dim_type type, __isl_take isl_id *id); | 
 
 
 
 
 | 92 | __isl_give isl_map *isl_map_reset_tuple_id(__isl_take isl_map *map, | 
 
 
 
 
 | 93 | enum isl_dim_type type); | 
 
 
 
 
 | 94 | __isl_export | 
 
 
 
 
 | 95 | isl_bool isl_map_has_domain_tuple_id(__isl_keep isl_map *map); | 
 
 
 
 
 | 96 | __isl_export | 
 
 
 
 
 | 97 | isl_bool isl_map_has_range_tuple_id(__isl_keep isl_map *map); | 
 
 
 
 
 | 98 | isl_bool isl_map_has_tuple_id(__isl_keep isl_map *map, enum isl_dim_type type); | 
 
 
 
 
 | 99 | __isl_export | 
 
 
 
 
 | 100 | __isl_give isl_id *isl_map_get_domain_tuple_id(__isl_keep isl_map *map); | 
 
 
 
 
 | 101 | __isl_export | 
 
 
 
 
 | 102 | __isl_give isl_id *isl_map_get_range_tuple_id(__isl_keep isl_map *map); | 
 
 
 
 
 | 103 | __isl_give isl_id *isl_map_get_tuple_id(__isl_keep isl_map *map, | 
 
 
 
 
 | 104 | enum isl_dim_type type); | 
 
 
 
 
 | 105 | __isl_give isl_map *isl_map_reset_user(__isl_take isl_map *map); | 
 
 
 
 
 | 106 |  | 
 
 
 
 
 | 107 | int isl_basic_map_find_dim_by_name(__isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 108 | enum isl_dim_type type, const char *name); | 
 
 
 
 
 | 109 | int isl_map_find_dim_by_id(__isl_keep isl_map *map, enum isl_dim_type type, | 
 
 
 
 
 | 110 | __isl_keep isl_id *id); | 
 
 
 
 
 | 111 | int isl_map_find_dim_by_name(__isl_keep isl_map *map, enum isl_dim_type type, | 
 
 
 
 
 | 112 | const char *name); | 
 
 
 
 
 | 113 |  | 
 
 
 
 
 | 114 | isl_bool isl_basic_map_is_rational(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 115 |  | 
 
 
 
 
 | 116 | __isl_give isl_basic_map *isl_basic_map_identity(__isl_take isl_space *space); | 
 
 
 
 
 | 117 | __isl_null isl_basic_map *isl_basic_map_free(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 118 | __isl_give isl_basic_map *isl_basic_map_copy(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 119 | __isl_give isl_basic_map *isl_basic_map_equal( | 
 
 
 
 
 | 120 | __isl_take isl_space *space, unsigned n_equal); | 
 
 
 
 
 | 121 | __isl_give isl_basic_map *isl_basic_map_less_at(__isl_take isl_space *space, | 
 
 
 
 
 | 122 | unsigned pos); | 
 
 
 
 
 | 123 | __isl_give isl_basic_map *isl_basic_map_more_at(__isl_take isl_space *space, | 
 
 
 
 
 | 124 | unsigned pos); | 
 
 
 
 
 | 125 | __isl_give isl_basic_map *isl_basic_map_empty(__isl_take isl_space *space); | 
 
 
 
 
 | 126 | __isl_give isl_basic_map *isl_basic_map_universe(__isl_take isl_space *space); | 
 
 
 
 
 | 127 | __isl_give isl_basic_map *isl_basic_map_nat_universe( | 
 
 
 
 
 | 128 | __isl_take isl_space *space); | 
 
 
 
 
 | 129 | __isl_give isl_basic_map *isl_basic_map_remove_redundancies( | 
 
 
 
 
 | 130 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 131 | __isl_give isl_map *isl_map_remove_redundancies(__isl_take isl_map *map); | 
 
 
 
 
 | 132 | __isl_give isl_basic_map *isl_map_simple_hull(__isl_take isl_map *map); | 
 
 
 
 
 | 133 | __isl_export | 
 
 
 
 
 | 134 | __isl_give isl_basic_map *isl_map_unshifted_simple_hull( | 
 
 
 
 
 | 135 | __isl_take isl_map *map); | 
 
 
 
 
 | 136 | __isl_give isl_basic_map *isl_map_plain_unshifted_simple_hull( | 
 
 
 
 
 | 137 | __isl_take isl_map *map); | 
 
 
 
 
 | 138 | __isl_give isl_basic_map *isl_map_unshifted_simple_hull_from_map_list( | 
 
 
 
 
 | 139 | __isl_take isl_map *map, __isl_take isl_map_list *list); | 
 
 
 
 
 | 140 |  | 
 
 
 
 
 | 141 | __isl_export | 
 
 
 
 
 | 142 | __isl_give isl_basic_map *isl_basic_map_intersect_domain( | 
 
 
 
 
 | 143 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 144 | __isl_take isl_basic_set *bset); | 
 
 
 
 
 | 145 | __isl_export | 
 
 
 
 
 | 146 | __isl_give isl_basic_map *isl_basic_map_intersect_range( | 
 
 
 
 
 | 147 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 148 | __isl_take isl_basic_set *bset); | 
 
 
 
 
 | 149 | __isl_export | 
 
 
 
 
 | 150 | __isl_give isl_basic_map *isl_basic_map_intersect( | 
 
 
 
 
 | 151 | __isl_take isl_basic_map *bmap1, | 
 
 
 
 
 | 152 | __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 153 | __isl_give isl_basic_map *isl_basic_map_list_intersect( | 
 
 
 
 
 | 154 | __isl_take isl_basic_map_list *list); | 
 
 
 
 
 | 155 | __isl_export | 
 
 
 
 
 | 156 | __isl_give isl_map *isl_basic_map_union( | 
 
 
 
 
 | 157 | __isl_take isl_basic_map *bmap1, | 
 
 
 
 
 | 158 | __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 159 | __isl_export | 
 
 
 
 
 | 160 | __isl_give isl_basic_map *isl_basic_map_apply_domain( | 
 
 
 
 
 | 161 | __isl_take isl_basic_map *bmap1, | 
 
 
 
 
 | 162 | __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 163 | __isl_export | 
 
 
 
 
 | 164 | __isl_give isl_basic_map *isl_basic_map_apply_range( | 
 
 
 
 
 | 165 | __isl_take isl_basic_map *bmap1, | 
 
 
 
 
 | 166 | __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 167 | __isl_export | 
 
 
 
 
 | 168 | __isl_give isl_basic_map *isl_basic_map_affine_hull( | 
 
 
 
 
 | 169 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 170 | __isl_give isl_basic_map *isl_basic_map_preimage_domain_multi_aff( | 
 
 
 
 
 | 171 | __isl_take isl_basic_map *bmap, __isl_take isl_multi_aff *ma); | 
 
 
 
 
 | 172 | __isl_give isl_basic_map *isl_basic_map_preimage_range_multi_aff( | 
 
 
 
 
 | 173 | __isl_take isl_basic_map *bmap, __isl_take isl_multi_aff *ma); | 
 
 
 
 
 | 174 | __isl_export | 
 
 
 
 
 | 175 | __isl_give isl_basic_map *isl_basic_map_reverse(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 176 | __isl_give isl_basic_set *isl_basic_map_domain(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 177 | __isl_give isl_basic_set *isl_basic_map_range(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 178 | __isl_give isl_basic_map *isl_basic_map_domain_map( | 
 
 
 
 
 | 179 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 180 | __isl_give isl_basic_map *isl_basic_map_range_map( | 
 
 
 
 
 | 181 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 182 | __isl_give isl_basic_map *isl_basic_map_remove_dims( | 
 
 
 
 
 | 183 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 184 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 185 | __isl_give isl_basic_map *isl_basic_map_eliminate( | 
 
 
 
 
 | 186 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 187 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 188 | __isl_export | 
 
 
 
 
 | 189 | __isl_give isl_basic_map *isl_basic_map_sample(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 190 | __isl_export | 
 
 
 
 
 | 191 | __isl_give isl_basic_map *isl_basic_map_detect_equalities( | 
 
 
 
 
 | 192 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 193 | __isl_give isl_basic_map *isl_basic_map_read_from_file(isl_ctx *ctx, | 
 
 
 
 
 | 194 | FILE *input); | 
 
 
 
 
 | 195 | __isl_constructor | 
 
 
 
 
 | 196 | __isl_give isl_basic_map *isl_basic_map_read_from_str(isl_ctx *ctx, | 
 
 
 
 
 | 197 | const char *str); | 
 
 
 
 
 | 198 | __isl_give isl_map *isl_map_read_from_file(isl_ctx *ctx, FILE *input); | 
 
 
 
 
 | 199 | __isl_constructor | 
 
 
 
 
 | 200 | __isl_give isl_map *isl_map_read_from_str(isl_ctx *ctx, const char *str); | 
 
 
 
 
 | 201 | void isl_basic_map_dump(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 202 | void isl_map_dump(__isl_keep isl_map *map); | 
 
 
 
 
 | 203 | __isl_give char *isl_basic_map_to_str(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 204 | __isl_give isl_printer *isl_printer_print_basic_map( | 
 
 
 
 
 | 205 | __isl_take isl_printer *printer, __isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 206 | __isl_give char *isl_map_to_str(__isl_keep isl_map *map); | 
 
 
 
 
 | 207 | __isl_give isl_printer *isl_printer_print_map(__isl_take isl_printer *printer, | 
 
 
 
 
 | 208 | __isl_keep isl_map *map); | 
 
 
 
 
 | 209 | __isl_give isl_basic_map *isl_basic_map_fix_si(__isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 210 | enum isl_dim_type type, unsigned pos, int value); | 
 
 
 
 
 | 211 | __isl_give isl_basic_map *isl_basic_map_fix_val(__isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 212 | enum isl_dim_type type, unsigned pos, __isl_take isl_val *v); | 
 
 
 
 
 | 213 | __isl_give isl_basic_map *isl_basic_map_lower_bound_si( | 
 
 
 
 
 | 214 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 215 | enum isl_dim_type type, unsigned pos, int value); | 
 
 
 
 
 | 216 | __isl_give isl_basic_map *isl_basic_map_upper_bound_si( | 
 
 
 
 
 | 217 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 218 | enum isl_dim_type type, unsigned pos, int value); | 
 
 
 
 
 | 219 | __isl_overload | 
 
 
 
 
 | 220 | __isl_give isl_map *isl_map_lower_bound_multi_pw_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 221 | __isl_take isl_multi_pw_aff *lower); | 
 
 
 
 
 | 222 | __isl_overload | 
 
 
 
 
 | 223 | __isl_give isl_map *isl_map_upper_bound_multi_pw_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 224 | __isl_take isl_multi_pw_aff *upper); | 
 
 
 
 
 | 225 |  | 
 
 
 
 
 | 226 | __isl_give isl_basic_map *isl_basic_map_sum(__isl_take isl_basic_map *bmap1, | 
 
 
 
 
 | 227 | __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 228 | __isl_give isl_basic_map *isl_basic_map_neg(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 229 |  | 
 
 
 
 
 | 230 | __isl_give isl_map *isl_map_sum(__isl_take isl_map *map1, | 
 
 
 
 
 | 231 | __isl_take isl_map *map2); | 
 
 
 
 
 | 232 | __isl_give isl_map *isl_map_neg(__isl_take isl_map *map); | 
 
 
 
 
 | 233 | __isl_give isl_map *isl_map_floordiv_val(__isl_take isl_map *map, | 
 
 
 
 
 | 234 | __isl_take isl_val *d); | 
 
 
 
 
 | 235 |  | 
 
 
 
 
 | 236 | __isl_export | 
 
 
 
 
 | 237 | isl_bool isl_basic_map_is_equal(__isl_keep isl_basic_map *bmap1, | 
 
 
 
 
 | 238 | __isl_keep isl_basic_map *bmap2); | 
 
 
 
 
 | 239 | isl_bool isl_basic_map_is_disjoint(__isl_keep isl_basic_map *bmap1, | 
 
 
 
 
 | 240 | __isl_keep isl_basic_map *bmap2); | 
 
 
 
 
 | 241 |  | 
 
 
 
 
 | 242 | __isl_give isl_map *isl_basic_map_partial_lexmax( | 
 
 
 
 
 | 243 | __isl_take isl_basic_map *bmap, __isl_take isl_basic_set *dom, | 
 
 
 
 
 | 244 | __isl_give isl_set **empty); | 
 
 
 
 
 | 245 | __isl_give isl_map *isl_basic_map_partial_lexmin( | 
 
 
 
 
 | 246 | __isl_take isl_basic_map *bmap, __isl_take isl_basic_set *dom, | 
 
 
 
 
 | 247 | __isl_give isl_set **empty); | 
 
 
 
 
 | 248 | __isl_give isl_map *isl_map_partial_lexmax( | 
 
 
 
 
 | 249 | __isl_take isl_map *map, __isl_take isl_set *dom, | 
 
 
 
 
 | 250 | __isl_give isl_set **empty); | 
 
 
 
 
 | 251 | __isl_give isl_map *isl_map_partial_lexmin( | 
 
 
 
 
 | 252 | __isl_take isl_map *map, __isl_take isl_set *dom, | 
 
 
 
 
 | 253 | __isl_give isl_set **empty); | 
 
 
 
 
 | 254 | __isl_export | 
 
 
 
 
 | 255 | __isl_give isl_map *isl_basic_map_lexmin(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 256 | __isl_export | 
 
 
 
 
 | 257 | __isl_give isl_map *isl_basic_map_lexmax(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 258 | __isl_export | 
 
 
 
 
 | 259 | __isl_give isl_map *isl_map_lexmin(__isl_take isl_map *map); | 
 
 
 
 
 | 260 | __isl_export | 
 
 
 
 
 | 261 | __isl_give isl_map *isl_map_lexmax(__isl_take isl_map *map); | 
 
 
 
 
 | 262 | __isl_give isl_pw_multi_aff *isl_basic_map_partial_lexmin_pw_multi_aff( | 
 
 
 
 
 | 263 | __isl_take isl_basic_map *bmap, __isl_take isl_basic_set *dom, | 
 
 
 
 
 | 264 | __isl_give isl_set **empty); | 
 
 
 
 
 | 265 | __isl_give isl_pw_multi_aff *isl_basic_map_partial_lexmax_pw_multi_aff( | 
 
 
 
 
 | 266 | __isl_take isl_basic_map *bmap, __isl_take isl_basic_set *dom, | 
 
 
 
 
 | 267 | __isl_give isl_set **empty); | 
 
 
 
 
 | 268 | __isl_give isl_pw_multi_aff *isl_basic_map_lexmin_pw_multi_aff( | 
 
 
 
 
 | 269 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 270 | __isl_export | 
 
 
 
 
 | 271 | __isl_give isl_pw_multi_aff *isl_map_lexmin_pw_multi_aff( | 
 
 
 
 
 | 272 | __isl_take isl_map *map); | 
 
 
 
 
 | 273 | __isl_export | 
 
 
 
 
 | 274 | __isl_give isl_pw_multi_aff *isl_map_lexmax_pw_multi_aff( | 
 
 
 
 
 | 275 | __isl_take isl_map *map); | 
 
 
 
 
 | 276 | __isl_export | 
 
 
 
 
 | 277 | __isl_give isl_multi_pw_aff *isl_map_min_multi_pw_aff(__isl_take isl_map *map); | 
 
 
 
 
 | 278 | __isl_export | 
 
 
 
 
 | 279 | __isl_give isl_multi_pw_aff *isl_map_max_multi_pw_aff(__isl_take isl_map *map); | 
 
 
 
 
 | 280 |  | 
 
 
 
 
 | 281 | void isl_basic_map_print_internal(__isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 282 | FILE *out, int indent); | 
 
 
 
 
 | 283 |  | 
 
 
 
 
 | 284 | __isl_give isl_val *isl_basic_map_plain_get_val_if_fixed( | 
 
 
 
 
 | 285 | __isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 286 | enum isl_dim_type type, unsigned pos); | 
 
 
 
 
 | 287 |  | 
 
 
 
 
 | 288 | isl_bool isl_basic_map_image_is_bounded(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 289 | isl_bool isl_basic_map_plain_is_universe(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 290 | isl_bool isl_basic_map_is_universe(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 291 | isl_bool isl_basic_map_plain_is_empty(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 292 | __isl_export | 
 
 
 
 
 | 293 | isl_bool isl_basic_map_is_empty(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 294 | __isl_export | 
 
 
 
 
 | 295 | isl_bool isl_basic_map_is_subset(__isl_keep isl_basic_map *bmap1, | 
 
 
 
 
 | 296 | __isl_keep isl_basic_map *bmap2); | 
 
 
 
 
 | 297 | isl_bool isl_basic_map_is_strict_subset(__isl_keep isl_basic_map *bmap1, | 
 
 
 
 
 | 298 | __isl_keep isl_basic_map *bmap2); | 
 
 
 
 
 | 299 |  | 
 
 
 
 
 | 300 | __isl_export | 
 
 
 
 
 | 301 | __isl_give isl_map *isl_map_universe(__isl_take isl_space *space); | 
 
 
 
 
 | 302 | __isl_export | 
 
 
 
 
 | 303 | __isl_give isl_map *isl_space_universe_map(__isl_take isl_space *space); | 
 
 
 
 
 | 304 | __isl_give isl_map *isl_map_nat_universe(__isl_take isl_space *space); | 
 
 
 
 
 | 305 | __isl_export | 
 
 
 
 
 | 306 | __isl_give isl_map *isl_map_empty(__isl_take isl_space *space); | 
 
 
 
 
 | 307 | __isl_give isl_map *isl_map_identity(__isl_take isl_space *space); | 
 
 
 
 
 | 308 | __isl_give isl_map *isl_map_lex_lt_first(__isl_take isl_space *space, | 
 
 
 
 
 | 309 | unsigned n); | 
 
 
 
 
 | 310 | __isl_give isl_map *isl_map_lex_le_first(__isl_take isl_space *space, | 
 
 
 
 
 | 311 | unsigned n); | 
 
 
 
 
 | 312 | __isl_give isl_map *isl_map_lex_lt(__isl_take isl_space *set_space); | 
 
 
 
 
 | 313 | __isl_give isl_map *isl_map_lex_le(__isl_take isl_space *set_space); | 
 
 
 
 
 | 314 | __isl_give isl_map *isl_map_lex_gt_first(__isl_take isl_space *space, | 
 
 
 
 
 | 315 | unsigned n); | 
 
 
 
 
 | 316 | __isl_give isl_map *isl_map_lex_ge_first(__isl_take isl_space *space, | 
 
 
 
 
 | 317 | unsigned n); | 
 
 
 
 
 | 318 | __isl_give isl_map *isl_map_lex_gt(__isl_take isl_space *set_space); | 
 
 
 
 
 | 319 | __isl_give isl_map *isl_map_lex_ge(__isl_take isl_space *set_space); | 
 
 
 
 
 | 320 | __isl_null isl_map *isl_map_free(__isl_take isl_map *map); | 
 
 
 
 
 | 321 | __isl_give isl_map *isl_map_copy(__isl_keep isl_map *map); | 
 
 
 
 
 | 322 | __isl_export | 
 
 
 
 
 | 323 | __isl_give isl_map *isl_map_reverse(__isl_take isl_map *map); | 
 
 
 
 
 | 324 | __isl_export | 
 
 
 
 
 | 325 | __isl_give isl_map *isl_map_range_reverse(__isl_take isl_map *map); | 
 
 
 
 
 | 326 | __isl_export | 
 
 
 
 
 | 327 | __isl_give isl_map *isl_map_union( | 
 
 
 
 
 | 328 | __isl_take isl_map *map1, | 
 
 
 
 
 | 329 | __isl_take isl_map *map2); | 
 
 
 
 
 | 330 | __isl_give isl_map *isl_map_union_disjoint( | 
 
 
 
 
 | 331 | __isl_take isl_map *map1, __isl_take isl_map *map2); | 
 
 
 
 
 | 332 | __isl_export | 
 
 
 
 
 | 333 | __isl_give isl_map *isl_map_intersect_domain( | 
 
 
 
 
 | 334 | __isl_take isl_map *map, | 
 
 
 
 
 | 335 | __isl_take isl_set *set); | 
 
 
 
 
 | 336 | __isl_export | 
 
 
 
 
 | 337 | __isl_give isl_map *isl_map_intersect_range( | 
 
 
 
 
 | 338 | __isl_take isl_map *map, | 
 
 
 
 
 | 339 | __isl_take isl_set *set); | 
 
 
 
 
 | 340 | __isl_export | 
 
 
 
 
 | 341 | __isl_give isl_map *isl_map_intersect_domain_factor_domain( | 
 
 
 
 
 | 342 | __isl_take isl_map *map, __isl_take isl_map *factor); | 
 
 
 
 
 | 343 | __isl_export | 
 
 
 
 
 | 344 | __isl_give isl_map *isl_map_intersect_domain_factor_range( | 
 
 
 
 
 | 345 | __isl_take isl_map *map, __isl_take isl_map *factor); | 
 
 
 
 
 | 346 | __isl_export | 
 
 
 
 
 | 347 | __isl_give isl_map *isl_map_intersect_range_factor_domain( | 
 
 
 
 
 | 348 | __isl_take isl_map *map, __isl_take isl_map *factor); | 
 
 
 
 
 | 349 | __isl_export | 
 
 
 
 
 | 350 | __isl_give isl_map *isl_map_intersect_range_factor_range( | 
 
 
 
 
 | 351 | __isl_take isl_map *map, __isl_take isl_map *factor); | 
 
 
 
 
 | 352 | __isl_export | 
 
 
 
 
 | 353 | __isl_give isl_map *isl_map_apply_domain( | 
 
 
 
 
 | 354 | __isl_take isl_map *map1, | 
 
 
 
 
 | 355 | __isl_take isl_map *map2); | 
 
 
 
 
 | 356 | __isl_export | 
 
 
 
 
 | 357 | __isl_give isl_map *isl_map_apply_range( | 
 
 
 
 
 | 358 | __isl_take isl_map *map1, | 
 
 
 
 
 | 359 | __isl_take isl_map *map2); | 
 
 
 
 
 | 360 | __isl_overload | 
 
 
 
 
 | 361 | __isl_give isl_map *isl_map_preimage_domain_multi_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 362 | __isl_take isl_multi_aff *ma); | 
 
 
 
 
 | 363 | __isl_overload | 
 
 
 
 
 | 364 | __isl_give isl_map *isl_map_preimage_range_multi_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 365 | __isl_take isl_multi_aff *ma); | 
 
 
 
 
 | 366 | __isl_overload | 
 
 
 
 
 | 367 | __isl_give isl_map *isl_map_preimage_domain_pw_multi_aff( | 
 
 
 
 
 | 368 | __isl_take isl_map *map, __isl_take isl_pw_multi_aff *pma); | 
 
 
 
 
 | 369 | __isl_overload | 
 
 
 
 
 | 370 | __isl_give isl_map *isl_map_preimage_range_pw_multi_aff( | 
 
 
 
 
 | 371 | __isl_take isl_map *map, __isl_take isl_pw_multi_aff *pma); | 
 
 
 
 
 | 372 | __isl_overload | 
 
 
 
 
 | 373 | __isl_give isl_map *isl_map_preimage_domain_multi_pw_aff( | 
 
 
 
 
 | 374 | __isl_take isl_map *map, __isl_take isl_multi_pw_aff *mpa); | 
 
 
 
 
 | 375 | __isl_give isl_basic_map *isl_basic_map_product( | 
 
 
 
 
 | 376 | __isl_take isl_basic_map *bmap1, __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 377 | __isl_export | 
 
 
 
 
 | 378 | __isl_give isl_map *isl_map_product(__isl_take isl_map *map1, | 
 
 
 
 
 | 379 | __isl_take isl_map *map2); | 
 
 
 
 
 | 380 | __isl_give isl_basic_map *isl_basic_map_domain_product( | 
 
 
 
 
 | 381 | __isl_take isl_basic_map *bmap1, __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 382 | __isl_give isl_basic_map *isl_basic_map_range_product( | 
 
 
 
 
 | 383 | __isl_take isl_basic_map *bmap1, __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 384 | __isl_export | 
 
 
 
 
 | 385 | __isl_give isl_map *isl_map_domain_product(__isl_take isl_map *map1, | 
 
 
 
 
 | 386 | __isl_take isl_map *map2); | 
 
 
 
 
 | 387 | __isl_export | 
 
 
 
 
 | 388 | __isl_give isl_map *isl_map_range_product(__isl_take isl_map *map1, | 
 
 
 
 
 | 389 | __isl_take isl_map *map2); | 
 
 
 
 
 | 390 | __isl_give isl_basic_map *isl_basic_map_flat_product( | 
 
 
 
 
 | 391 | __isl_take isl_basic_map *bmap1, __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 392 | __isl_give isl_map *isl_map_flat_product(__isl_take isl_map *map1, | 
 
 
 
 
 | 393 | __isl_take isl_map *map2); | 
 
 
 
 
 | 394 | __isl_give isl_basic_map *isl_basic_map_flat_range_product( | 
 
 
 
 
 | 395 | __isl_take isl_basic_map *bmap1, __isl_take isl_basic_map *bmap2); | 
 
 
 
 
 | 396 | __isl_give isl_map *isl_map_flat_domain_product(__isl_take isl_map *map1, | 
 
 
 
 
 | 397 | __isl_take isl_map *map2); | 
 
 
 
 
 | 398 | __isl_give isl_map *isl_map_flat_range_product(__isl_take isl_map *map1, | 
 
 
 
 
 | 399 | __isl_take isl_map *map2); | 
 
 
 
 
 | 400 | isl_bool isl_map_domain_is_wrapping(__isl_keep isl_map *map); | 
 
 
 
 
 | 401 | isl_bool isl_map_range_is_wrapping(__isl_keep isl_map *map); | 
 
 
 
 
 | 402 | isl_bool isl_map_is_product(__isl_keep isl_map *map); | 
 
 
 
 
 | 403 | __isl_export | 
 
 
 
 
 | 404 | __isl_give isl_map *isl_map_factor_domain(__isl_take isl_map *map); | 
 
 
 
 
 | 405 | __isl_export | 
 
 
 
 
 | 406 | __isl_give isl_map *isl_map_factor_range(__isl_take isl_map *map); | 
 
 
 
 
 | 407 | __isl_export | 
 
 
 
 
 | 408 | __isl_give isl_map *isl_map_domain_factor_domain(__isl_take isl_map *map); | 
 
 
 
 
 | 409 | __isl_export | 
 
 
 
 
 | 410 | __isl_give isl_map *isl_map_domain_factor_range(__isl_take isl_map *map); | 
 
 
 
 
 | 411 | __isl_export | 
 
 
 
 
 | 412 | __isl_give isl_map *isl_map_range_factor_domain(__isl_take isl_map *map); | 
 
 
 
 
 | 413 | __isl_export | 
 
 
 
 
 | 414 | __isl_give isl_map *isl_map_range_factor_range(__isl_take isl_map *map); | 
 
 
 
 
 | 415 | __isl_export | 
 
 
 
 
 | 416 | __isl_give isl_map *isl_map_intersect(__isl_take isl_map *map1, | 
 
 
 
 
 | 417 | __isl_take isl_map *map2); | 
 
 
 
 
 | 418 | __isl_export | 
 
 
 
 
 | 419 | __isl_give isl_map *isl_map_intersect_params(__isl_take isl_map *map, | 
 
 
 
 
 | 420 | __isl_take isl_set *params); | 
 
 
 
 
 | 421 | __isl_export | 
 
 
 
 
 | 422 | __isl_give isl_map *isl_map_subtract( | 
 
 
 
 
 | 423 | __isl_take isl_map *map1, | 
 
 
 
 
 | 424 | __isl_take isl_map *map2); | 
 
 
 
 
 | 425 | __isl_give isl_map *isl_map_subtract_domain(__isl_take isl_map *map, | 
 
 
 
 
 | 426 | __isl_take isl_set *dom); | 
 
 
 
 
 | 427 | __isl_give isl_map *isl_map_subtract_range(__isl_take isl_map *map, | 
 
 
 
 
 | 428 | __isl_take isl_set *dom); | 
 
 
 
 
 | 429 | __isl_export | 
 
 
 
 
 | 430 | __isl_give isl_map *isl_map_complement(__isl_take isl_map *map); | 
 
 
 
 
 | 431 | __isl_give isl_map *isl_map_fix_input_si(__isl_take isl_map *map, | 
 
 
 
 
 | 432 | unsigned input, int value); | 
 
 
 
 
 | 433 | __isl_give isl_map *isl_map_fix_si(__isl_take isl_map *map, | 
 
 
 
 
 | 434 | enum isl_dim_type type, unsigned pos, int value); | 
 
 
 
 
 | 435 | __isl_give isl_map *isl_map_fix_val(__isl_take isl_map *map, | 
 
 
 
 
 | 436 | enum isl_dim_type type, unsigned pos, __isl_take isl_val *v); | 
 
 
 
 
 | 437 | __isl_give isl_map *isl_map_lower_bound_si(__isl_take isl_map *map, | 
 
 
 
 
 | 438 | enum isl_dim_type type, unsigned pos, int value); | 
 
 
 
 
 | 439 | __isl_give isl_map *isl_map_lower_bound_val(__isl_take isl_map *map, | 
 
 
 
 
 | 440 | enum isl_dim_type type, unsigned pos, __isl_take isl_val *value); | 
 
 
 
 
 | 441 | __isl_give isl_map *isl_map_upper_bound_si(__isl_take isl_map *map, | 
 
 
 
 
 | 442 | enum isl_dim_type type, unsigned pos, int value); | 
 
 
 
 
 | 443 | __isl_give isl_map *isl_map_upper_bound_val(__isl_take isl_map *map, | 
 
 
 
 
 | 444 | enum isl_dim_type type, unsigned pos, __isl_take isl_val *value); | 
 
 
 
 
 | 445 | __isl_export | 
 
 
 
 
 | 446 | __isl_give isl_basic_set *isl_basic_map_deltas(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 447 | __isl_export | 
 
 
 
 
 | 448 | __isl_give isl_set *isl_map_deltas(__isl_take isl_map *map); | 
 
 
 
 
 | 449 | __isl_give isl_basic_map *isl_basic_map_deltas_map( | 
 
 
 
 
 | 450 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 451 | __isl_give isl_map *isl_map_deltas_map(__isl_take isl_map *map); | 
 
 
 
 
 | 452 | __isl_export | 
 
 
 
 
 | 453 | __isl_give isl_map *isl_map_detect_equalities(__isl_take isl_map *map); | 
 
 
 
 
 | 454 | __isl_export | 
 
 
 
 
 | 455 | __isl_give isl_basic_map *isl_map_affine_hull(__isl_take isl_map *map); | 
 
 
 
 
 | 456 | __isl_give isl_basic_map *isl_map_convex_hull(__isl_take isl_map *map); | 
 
 
 
 
 | 457 | __isl_export | 
 
 
 
 
 | 458 | __isl_give isl_basic_map *isl_map_polyhedral_hull(__isl_take isl_map *map); | 
 
 
 
 
 | 459 | __isl_give isl_basic_map *isl_basic_map_add_dims(__isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 460 | enum isl_dim_type type, unsigned n); | 
 
 
 
 
 | 461 | __isl_give isl_map *isl_map_add_dims(__isl_take isl_map *map, | 
 
 
 
 
 | 462 | enum isl_dim_type type, unsigned n); | 
 
 
 
 
 | 463 | __isl_give isl_basic_map *isl_basic_map_insert_dims( | 
 
 
 
 
 | 464 | __isl_take isl_basic_map *bmap, enum isl_dim_type type, | 
 
 
 
 
 | 465 | unsigned pos, unsigned n); | 
 
 
 
 
 | 466 | __isl_give isl_map *isl_map_insert_dims(__isl_take isl_map *map, | 
 
 
 
 
 | 467 | enum isl_dim_type type, unsigned pos, unsigned n); | 
 
 
 
 
 | 468 | __isl_give isl_basic_map *isl_basic_map_move_dims( | 
 
 
 
 
 | 469 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 470 | enum isl_dim_type dst_type, unsigned dst_pos, | 
 
 
 
 
 | 471 | enum isl_dim_type src_type, unsigned src_pos, unsigned n); | 
 
 
 
 
 | 472 | __isl_give isl_map *isl_map_move_dims(__isl_take isl_map *map, | 
 
 
 
 
 | 473 | enum isl_dim_type dst_type, unsigned dst_pos, | 
 
 
 
 
 | 474 | enum isl_dim_type src_type, unsigned src_pos, unsigned n); | 
 
 
 
 
 | 475 | __isl_give isl_basic_map *isl_basic_map_project_out( | 
 
 
 
 
 | 476 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 477 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 478 | __isl_give isl_map *isl_map_project_out(__isl_take isl_map *map, | 
 
 
 
 
 | 479 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 480 | __isl_export | 
 
 
 
 
 | 481 | __isl_give isl_map *isl_map_project_out_all_params(__isl_take isl_map *map); | 
 
 
 
 
 | 482 | __isl_give isl_basic_map *isl_basic_map_remove_divs( | 
 
 
 
 
 | 483 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 484 | __isl_give isl_map *isl_map_remove_unknown_divs(__isl_take isl_map *map); | 
 
 
 
 
 | 485 | __isl_give isl_map *isl_map_remove_divs(__isl_take isl_map *map); | 
 
 
 
 
 | 486 | __isl_give isl_map *isl_map_eliminate(__isl_take isl_map *map, | 
 
 
 
 
 | 487 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 488 | __isl_give isl_map *isl_map_remove_dims(__isl_take isl_map *map, | 
 
 
 
 
 | 489 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 490 | __isl_give isl_basic_map *isl_basic_map_remove_divs_involving_dims( | 
 
 
 
 
 | 491 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 492 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 493 | __isl_give isl_map *isl_map_remove_divs_involving_dims(__isl_take isl_map *map, | 
 
 
 
 
 | 494 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 495 | __isl_give isl_map *isl_map_remove_inputs(__isl_take isl_map *map, | 
 
 
 
 
 | 496 | unsigned first, unsigned n); | 
 
 
 
 
 | 497 |  | 
 
 
 
 
 | 498 | __isl_give isl_basic_map *isl_basic_map_equate(__isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 499 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 500 | __isl_give isl_basic_map *isl_basic_map_order_ge(__isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 501 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 502 | __isl_give isl_map *isl_map_order_ge(__isl_take isl_map *map, | 
 
 
 
 
 | 503 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 504 | __isl_give isl_map *isl_map_order_le(__isl_take isl_map *map, | 
 
 
 
 
 | 505 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 506 | __isl_give isl_map *isl_map_equate(__isl_take isl_map *map, | 
 
 
 
 
 | 507 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 508 | __isl_give isl_map *isl_map_oppose(__isl_take isl_map *map, | 
 
 
 
 
 | 509 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 510 | __isl_give isl_map *isl_map_order_lt(__isl_take isl_map *map, | 
 
 
 
 
 | 511 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 512 | __isl_give isl_basic_map *isl_basic_map_order_gt(__isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 513 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 514 | __isl_give isl_map *isl_map_order_gt(__isl_take isl_map *map, | 
 
 
 
 
 | 515 | enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2); | 
 
 
 
 
 | 516 |  | 
 
 
 
 
 | 517 | __isl_export | 
 
 
 
 
 | 518 | __isl_give isl_map *isl_set_translation(__isl_take isl_set *deltas); | 
 
 
 
 
 | 519 | __isl_export | 
 
 
 
 
 | 520 | __isl_give isl_map *isl_set_identity(__isl_take isl_set *set); | 
 
 
 
 
 | 521 |  | 
 
 
 
 
 | 522 | __isl_export | 
 
 
 
 
 | 523 | isl_bool isl_basic_set_is_wrapping(__isl_keep isl_basic_set *bset); | 
 
 
 
 
 | 524 | __isl_export | 
 
 
 
 
 | 525 | isl_bool isl_set_is_wrapping(__isl_keep isl_set *set); | 
 
 
 
 
 | 526 | __isl_give isl_basic_set *isl_basic_map_wrap(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 527 | __isl_export | 
 
 
 
 
 | 528 | __isl_give isl_set *isl_map_wrap(__isl_take isl_map *map); | 
 
 
 
 
 | 529 | __isl_give isl_basic_map *isl_basic_set_unwrap(__isl_take isl_basic_set *bset); | 
 
 
 
 
 | 530 | __isl_export | 
 
 
 
 
 | 531 | __isl_give isl_map *isl_set_unwrap(__isl_take isl_set *set); | 
 
 
 
 
 | 532 | __isl_export | 
 
 
 
 
 | 533 | __isl_give isl_basic_map *isl_basic_map_flatten(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 534 | __isl_export | 
 
 
 
 
 | 535 | __isl_give isl_map *isl_map_flatten(__isl_take isl_map *map); | 
 
 
 
 
 | 536 | __isl_export | 
 
 
 
 
 | 537 | __isl_give isl_basic_map *isl_basic_map_flatten_domain( | 
 
 
 
 
 | 538 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 539 | __isl_export | 
 
 
 
 
 | 540 | __isl_give isl_basic_map *isl_basic_map_flatten_range( | 
 
 
 
 
 | 541 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 542 | __isl_export | 
 
 
 
 
 | 543 | __isl_give isl_map *isl_map_flatten_domain(__isl_take isl_map *map); | 
 
 
 
 
 | 544 | __isl_export | 
 
 
 
 
 | 545 | __isl_give isl_map *isl_map_flatten_range(__isl_take isl_map *map); | 
 
 
 
 
 | 546 | __isl_export | 
 
 
 
 
 | 547 | __isl_give isl_basic_set *isl_basic_set_flatten(__isl_take isl_basic_set *bset); | 
 
 
 
 
 | 548 | __isl_export | 
 
 
 
 
 | 549 | __isl_give isl_set *isl_set_flatten(__isl_take isl_set *set); | 
 
 
 
 
 | 550 | __isl_give isl_map *isl_set_flatten_map(__isl_take isl_set *set); | 
 
 
 
 
 | 551 | __isl_give isl_set *isl_map_params(__isl_take isl_map *map); | 
 
 
 
 
 | 552 | __isl_export | 
 
 
 
 
 | 553 | __isl_give isl_set *isl_map_domain(__isl_take isl_map *bmap); | 
 
 
 
 
 | 554 | __isl_export | 
 
 
 
 
 | 555 | __isl_give isl_set *isl_map_range(__isl_take isl_map *map); | 
 
 
 
 
 | 556 | __isl_export | 
 
 
 
 
 | 557 | __isl_give isl_map *isl_set_insert_domain(__isl_take isl_set *set, | 
 
 
 
 
 | 558 | __isl_take isl_space *domain); | 
 
 
 
 
 | 559 | __isl_give isl_map *isl_map_domain_map(__isl_take isl_map *map); | 
 
 
 
 
 | 560 | __isl_give isl_map *isl_map_range_map(__isl_take isl_map *map); | 
 
 
 
 
 | 561 | __isl_give isl_map *isl_set_wrapped_domain_map(__isl_take isl_set *set); | 
 
 
 
 
 | 562 | __isl_constructor | 
 
 
 
 
 | 563 | __isl_give isl_map *isl_map_from_basic_map(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 564 | __isl_give isl_map *isl_map_from_domain(__isl_take isl_set *set); | 
 
 
 
 
 | 565 | __isl_give isl_basic_map *isl_basic_map_from_domain( | 
 
 
 
 
 | 566 | __isl_take isl_basic_set *bset); | 
 
 
 
 
 | 567 | __isl_give isl_basic_map *isl_basic_map_from_range( | 
 
 
 
 
 | 568 | __isl_take isl_basic_set *bset); | 
 
 
 
 
 | 569 | __isl_give isl_map *isl_map_from_range(__isl_take isl_set *set); | 
 
 
 
 
 | 570 | __isl_give isl_basic_map *isl_basic_map_from_domain_and_range( | 
 
 
 
 
 | 571 | __isl_take isl_basic_set *domain, __isl_take isl_basic_set *range); | 
 
 
 
 
 | 572 | __isl_give isl_map *isl_map_from_domain_and_range(__isl_take isl_set *domain, | 
 
 
 
 
 | 573 | __isl_take isl_set *range); | 
 
 
 
 
 | 574 | __isl_export | 
 
 
 
 
 | 575 | __isl_give isl_basic_map *isl_map_sample(__isl_take isl_map *map); | 
 
 
 
 
 | 576 |  | 
 
 
 
 
 | 577 | __isl_export | 
 
 
 
 
 | 578 | __isl_give isl_set *isl_map_bind_domain(__isl_take isl_map *map, | 
 
 
 
 
 | 579 | __isl_take isl_multi_id *tuple); | 
 
 
 
 
 | 580 | __isl_export | 
 
 
 
 
 | 581 | __isl_give isl_set *isl_map_bind_range(__isl_take isl_map *map, | 
 
 
 
 
 | 582 | __isl_take isl_multi_id *tuple); | 
 
 
 
 
 | 583 |  | 
 
 
 
 
 | 584 | isl_bool isl_map_plain_is_empty(__isl_keep isl_map *map); | 
 
 
 
 
 | 585 | isl_bool isl_map_plain_is_universe(__isl_keep isl_map *map); | 
 
 
 
 
 | 586 | __isl_export | 
 
 
 
 
 | 587 | isl_bool isl_map_is_empty(__isl_keep isl_map *map); | 
 
 
 
 
 | 588 | __isl_export | 
 
 
 
 
 | 589 | isl_bool isl_map_is_subset(__isl_keep isl_map *map1, __isl_keep isl_map *map2); | 
 
 
 
 
 | 590 | __isl_export | 
 
 
 
 
 | 591 | isl_bool isl_map_is_strict_subset(__isl_keep isl_map *map1, | 
 
 
 
 
 | 592 | __isl_keep isl_map *map2); | 
 
 
 
 
 | 593 | __isl_export | 
 
 
 
 
 | 594 | isl_bool isl_map_is_equal(__isl_keep isl_map *map1, __isl_keep isl_map *map2); | 
 
 
 
 
 | 595 | __isl_export | 
 
 
 
 
 | 596 | isl_bool isl_map_is_disjoint(__isl_keep isl_map *map1, | 
 
 
 
 
 | 597 | __isl_keep isl_map *map2); | 
 
 
 
 
 | 598 | isl_bool isl_basic_map_is_single_valued(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 599 | isl_bool isl_map_plain_is_single_valued(__isl_keep isl_map *map); | 
 
 
 
 
 | 600 | __isl_export | 
 
 
 
 
 | 601 | isl_bool isl_map_is_single_valued(__isl_keep isl_map *map); | 
 
 
 
 
 | 602 | isl_bool isl_map_plain_is_injective(__isl_keep isl_map *map); | 
 
 
 
 
 | 603 | __isl_export | 
 
 
 
 
 | 604 | isl_bool isl_map_is_injective(__isl_keep isl_map *map); | 
 
 
 
 
 | 605 | __isl_export | 
 
 
 
 
 | 606 | isl_bool isl_map_is_bijective(__isl_keep isl_map *map); | 
 
 
 
 
 | 607 | isl_bool isl_map_is_identity(__isl_keep isl_map *map); | 
 
 
 
 
 | 608 | int isl_map_is_translation(__isl_keep isl_map *map); | 
 
 
 
 
 | 609 | isl_bool isl_map_has_equal_space(__isl_keep isl_map *map1, | 
 
 
 
 
 | 610 | __isl_keep isl_map *map2); | 
 
 
 
 
 | 611 |  | 
 
 
 
 
 | 612 | isl_bool isl_basic_map_can_zip(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 613 | isl_bool isl_map_can_zip(__isl_keep isl_map *map); | 
 
 
 
 
 | 614 | __isl_give isl_basic_map *isl_basic_map_zip(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 615 | __isl_export | 
 
 
 
 
 | 616 | __isl_give isl_map *isl_map_zip(__isl_take isl_map *map); | 
 
 
 
 
 | 617 |  | 
 
 
 
 
 | 618 | isl_bool isl_basic_map_can_curry(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 619 | isl_bool isl_map_can_curry(__isl_keep isl_map *map); | 
 
 
 
 
 | 620 | __isl_give isl_basic_map *isl_basic_map_curry(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 621 | __isl_export | 
 
 
 
 
 | 622 | __isl_give isl_map *isl_map_curry(__isl_take isl_map *map); | 
 
 
 
 
 | 623 |  | 
 
 
 
 
 | 624 | isl_bool isl_map_can_range_curry(__isl_keep isl_map *map); | 
 
 
 
 
 | 625 | __isl_give isl_map *isl_map_range_curry(__isl_take isl_map *map); | 
 
 
 
 
 | 626 |  | 
 
 
 
 
 | 627 | isl_bool isl_basic_map_can_uncurry(__isl_keep isl_basic_map *bmap); | 
 
 
 
 
 | 628 | isl_bool isl_map_can_uncurry(__isl_keep isl_map *map); | 
 
 
 
 
 | 629 | __isl_give isl_basic_map *isl_basic_map_uncurry(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 630 | __isl_export | 
 
 
 
 
 | 631 | __isl_give isl_map *isl_map_uncurry(__isl_take isl_map *map); | 
 
 
 
 
 | 632 |  | 
 
 
 
 
 | 633 | __isl_give isl_map *isl_map_make_disjoint(__isl_take isl_map *map); | 
 
 
 
 
 | 634 | __isl_give isl_map *isl_basic_map_compute_divs(__isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 635 | __isl_give isl_map *isl_map_compute_divs(__isl_take isl_map *map); | 
 
 
 
 
 | 636 | ISL_DEPRECATED | 
 
 
 
 
 | 637 | __isl_give isl_map *isl_map_align_divs(__isl_take isl_map *map); | 
 
 
 
 
 | 638 |  | 
 
 
 
 
 | 639 | __isl_give isl_basic_map *isl_basic_map_drop_constraints_involving_dims( | 
 
 
 
 
 | 640 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 641 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 642 | __isl_give isl_basic_map *isl_basic_map_drop_constraints_not_involving_dims( | 
 
 
 
 
 | 643 | __isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 644 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 645 | __isl_give isl_map *isl_map_drop_constraints_involving_dims( | 
 
 
 
 
 | 646 | __isl_take isl_map *map, | 
 
 
 
 
 | 647 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 648 | __isl_give isl_map *isl_map_drop_constraints_not_involving_dims( | 
 
 
 
 
 | 649 | __isl_take isl_map *map, | 
 
 
 
 
 | 650 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 651 |  | 
 
 
 
 
 | 652 | isl_bool isl_basic_map_involves_dims(__isl_keep isl_basic_map *bmap, | 
 
 
 
 
 | 653 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 654 | isl_bool isl_map_involves_dims(__isl_keep isl_map *map, | 
 
 
 
 
 | 655 | enum isl_dim_type type, unsigned first, unsigned n); | 
 
 
 
 
 | 656 |  | 
 
 
 
 
 | 657 | void isl_map_print_internal(__isl_keep isl_map *map, FILE *out, int indent); | 
 
 
 
 
 | 658 |  | 
 
 
 
 
 | 659 | __isl_give isl_val *isl_map_plain_get_val_if_fixed(__isl_keep isl_map *map, | 
 
 
 
 
 | 660 | enum isl_dim_type type, unsigned pos); | 
 
 
 
 
 | 661 |  | 
 
 
 
 
 | 662 | __isl_give isl_basic_map *isl_basic_map_gist_domain( | 
 
 
 
 
 | 663 | __isl_take isl_basic_map *bmap, __isl_take isl_basic_set *context); | 
 
 
 
 
 | 664 | __isl_export | 
 
 
 
 
 | 665 | __isl_give isl_basic_map *isl_basic_map_gist(__isl_take isl_basic_map *bmap, | 
 
 
 
 
 | 666 | __isl_take isl_basic_map *context); | 
 
 
 
 
 | 667 | __isl_export | 
 
 
 
 
 | 668 | __isl_give isl_map *isl_map_gist(__isl_take isl_map *map, | 
 
 
 
 
 | 669 | __isl_take isl_map *context); | 
 
 
 
 
 | 670 | __isl_export | 
 
 
 
 
 | 671 | __isl_give isl_map *isl_map_gist_domain(__isl_take isl_map *map, | 
 
 
 
 
 | 672 | __isl_take isl_set *context); | 
 
 
 
 
 | 673 | __isl_give isl_map *isl_map_gist_range(__isl_take isl_map *map, | 
 
 
 
 
 | 674 | __isl_take isl_set *context); | 
 
 
 
 
 | 675 | __isl_give isl_map *isl_map_gist_params(__isl_take isl_map *map, | 
 
 
 
 
 | 676 | __isl_take isl_set *context); | 
 
 
 
 
 | 677 | __isl_give isl_map *isl_map_gist_basic_map(__isl_take isl_map *map, | 
 
 
 
 
 | 678 | __isl_take isl_basic_map *context); | 
 
 
 
 
 | 679 |  | 
 
 
 
 
 | 680 | __isl_give isl_stride_info *isl_map_get_range_stride_info( | 
 
 
 
 
 | 681 | __isl_keep isl_map *map, int pos); | 
 
 
 
 
 | 682 | __isl_export | 
 
 
 
 
 | 683 | __isl_give isl_fixed_box *isl_map_get_range_simple_fixed_box_hull( | 
 
 
 
 
 | 684 | __isl_keep isl_map *map); | 
 
 
 
 
 | 685 |  | 
 
 
 
 
 | 686 | __isl_export | 
 
 
 
 
 | 687 | __isl_give isl_map *isl_map_coalesce(__isl_take isl_map *map); | 
 
 
 
 
 | 688 |  | 
 
 
 
 
 | 689 | isl_bool isl_map_plain_is_equal(__isl_keep isl_map *map1, | 
 
 
 
 
 | 690 | __isl_keep isl_map *map2); | 
 
 
 
 
 | 691 |  | 
 
 
 
 
 | 692 | uint32_t isl_map_get_hash(__isl_keep isl_map *map); | 
 
 
 
 
 | 693 |  | 
 
 
 
 
 | 694 | isl_size isl_map_n_basic_map(__isl_keep isl_map *map); | 
 
 
 
 
 | 695 | __isl_export | 
 
 
 
 
 | 696 | isl_stat isl_map_foreach_basic_map(__isl_keep isl_map *map, | 
 
 
 
 
 | 697 | isl_stat (*fn)(__isl_take isl_basic_map *bmap, void *user), void *user); | 
 
 
 
 
 | 698 | __isl_give isl_basic_map_list *isl_map_get_basic_map_list( | 
 
 
 
 
 | 699 | __isl_keep isl_map *map); | 
 
 
 
 
 | 700 |  | 
 
 
 
 
 | 701 | __isl_give isl_map *isl_map_fixed_power_val(__isl_take isl_map *map, | 
 
 
 
 
 | 702 | __isl_take isl_val *exp); | 
 
 
 
 
 | 703 | __isl_give isl_map *isl_map_power(__isl_take isl_map *map, isl_bool *exact); | 
 
 
 
 
 | 704 | __isl_give isl_map *isl_map_reaching_path_lengths(__isl_take isl_map *map, | 
 
 
 
 
 | 705 | isl_bool *exact); | 
 
 
 
 
 | 706 | __isl_give isl_map *isl_map_transitive_closure(__isl_take isl_map *map, | 
 
 
 
 
 | 707 | isl_bool *exact); | 
 
 
 
 
 | 708 |  | 
 
 
 
 
 | 709 | __isl_give isl_map *isl_map_lex_le_map(__isl_take isl_map *map1, | 
 
 
 
 
 | 710 | __isl_take isl_map *map2); | 
 
 
 
 
 | 711 | __isl_give isl_map *isl_map_lex_lt_map(__isl_take isl_map *map1, | 
 
 
 
 
 | 712 | __isl_take isl_map *map2); | 
 
 
 
 
 | 713 | __isl_give isl_map *isl_map_lex_ge_map(__isl_take isl_map *map1, | 
 
 
 
 
 | 714 | __isl_take isl_map *map2); | 
 
 
 
 
 | 715 | __isl_give isl_map *isl_map_lex_gt_map(__isl_take isl_map *map1, | 
 
 
 
 
 | 716 | __isl_take isl_map *map2); | 
 
 
 
 
 | 717 |  | 
 
 
 
 
 | 718 | __isl_overload | 
 
 
 
 
 | 719 | __isl_give isl_map *isl_map_eq_at_multi_pw_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 720 | __isl_take isl_multi_pw_aff *mpa); | 
 
 
 
 
 | 721 | __isl_overload | 
 
 
 
 
 | 722 | __isl_give isl_map *isl_map_lex_lt_at_multi_pw_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 723 | __isl_take isl_multi_pw_aff *mpa); | 
 
 
 
 
 | 724 | __isl_overload | 
 
 
 
 
 | 725 | __isl_give isl_map *isl_map_lex_le_at_multi_pw_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 726 | __isl_take isl_multi_pw_aff *mpa); | 
 
 
 
 
 | 727 | __isl_overload | 
 
 
 
 
 | 728 | __isl_give isl_map *isl_map_lex_gt_at_multi_pw_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 729 | __isl_take isl_multi_pw_aff *mpa); | 
 
 
 
 
 | 730 | __isl_overload | 
 
 
 
 
 | 731 | __isl_give isl_map *isl_map_lex_ge_at_multi_pw_aff(__isl_take isl_map *map, | 
 
 
 
 
 | 732 | __isl_take isl_multi_pw_aff *mpa); | 
 
 
 
 
 | 733 |  | 
 
 
 
 
 | 734 | __isl_give isl_basic_map *isl_basic_map_align_params( | 
 
 
 
 
 | 735 | __isl_take isl_basic_map *bmap, __isl_take isl_space *model); | 
 
 
 
 
 | 736 | __isl_give isl_map *isl_map_align_params(__isl_take isl_map *map, | 
 
 
 
 
 | 737 | __isl_take isl_space *model); | 
 
 
 
 
 | 738 | __isl_give isl_basic_map *isl_basic_map_drop_unused_params( | 
 
 
 
 
 | 739 | __isl_take isl_basic_map *bmap); | 
 
 
 
 
 | 740 | __isl_give isl_map *isl_map_drop_unused_params(__isl_take isl_map *map); | 
 
 
 
 
 | 741 |  | 
 
 
 
 
 | 742 | __isl_give isl_mat *isl_basic_map_equalities_matrix( | 
 
 
 
 
 | 743 | __isl_keep isl_basic_map *bmap, enum isl_dim_type c1, | 
 
 
 
 
 | 744 | enum isl_dim_type c2, enum isl_dim_type c3, | 
 
 
 
 
 | 745 | enum isl_dim_type c4, enum isl_dim_type c5); | 
 
 
 
 
 | 746 | __isl_give isl_mat *isl_basic_map_inequalities_matrix( | 
 
 
 
 
 | 747 | __isl_keep isl_basic_map *bmap, enum isl_dim_type c1, | 
 
 
 
 
 | 748 | enum isl_dim_type c2, enum isl_dim_type c3, | 
 
 
 
 
 | 749 | enum isl_dim_type c4, enum isl_dim_type c5); | 
 
 
 
 
 | 750 | __isl_give isl_basic_map *isl_basic_map_from_constraint_matrices( | 
 
 
 
 
 | 751 | __isl_take isl_space *space, | 
 
 
 
 
 | 752 | __isl_take isl_mat *eq, __isl_take isl_mat *ineq, enum isl_dim_type c1, | 
 
 
 
 
 | 753 | enum isl_dim_type c2, enum isl_dim_type c3, | 
 
 
 
 
 | 754 | enum isl_dim_type c4, enum isl_dim_type c5); | 
 
 
 
 
 | 755 |  | 
 
 
 
 
 | 756 | __isl_give isl_basic_map *isl_basic_map_from_aff(__isl_take isl_aff *aff); | 
 
 
 
 
 | 757 | __isl_give isl_basic_map *isl_basic_map_from_multi_aff( | 
 
 
 
 
 | 758 | __isl_take isl_multi_aff *maff); | 
 
 
 
 
 | 759 | __isl_give isl_basic_map *isl_basic_map_from_aff_list( | 
 
 
 
 
 | 760 | __isl_take isl_space *domain_space, __isl_take isl_aff_list *list); | 
 
 
 
 
 | 761 |  | 
 
 
 
 
 | 762 | __isl_give isl_map *isl_map_from_aff(__isl_take isl_aff *aff); | 
 
 
 
 
 | 763 | __isl_export | 
 
 
 
 
 | 764 | __isl_give isl_map *isl_multi_aff_as_map(__isl_take isl_multi_aff *ma); | 
 
 
 
 
 | 765 | __isl_give isl_map *isl_map_from_multi_aff(__isl_take isl_multi_aff *maff); | 
 
 
 
 
 | 766 |  | 
 
 
 
 
 | 767 | __isl_give isl_pw_aff *isl_map_dim_min(__isl_take isl_map *map, int pos); | 
 
 
 
 
 | 768 | __isl_give isl_pw_aff *isl_map_dim_max(__isl_take isl_map *map, int pos); | 
 
 
 
 
 | 769 |  | 
 
 
 
 
 | 770 | ISL_DECLARE_LIST_FN(basic_map) | 
 
 
 
 
 | 771 | ISL_DECLARE_LIST_FN(map) | 
 
 
 
 
 | 772 |  | 
 
 
 
 
 | 773 | #if defined(__cplusplus) | 
 
 
 
 
 | 774 | } | 
 
 
 
 
 | 775 | #endif | 
 
 
 
 
 | 776 |  | 
 
 
 
 
 | 777 | #endif |