set.h 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603
  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. #ifndef ISL_SET_H
  10. #define ISL_SET_H
  11. #include <isl/id_type.h>
  12. #include <isl/map_type.h>
  13. #include <isl/aff_type.h>
  14. #include <isl/list.h>
  15. #include <isl/mat.h>
  16. #include <isl/point.h>
  17. #include <isl/local_space.h>
  18. #include <isl/val_type.h>
  19. #include <isl/stdint.h>
  20. #include <isl/stride_info.h>
  21. #include <isl/fixed_box.h>
  22. #if defined(__cplusplus)
  23. extern "C" {
  24. #endif
  25. isl_size isl_basic_set_n_dim(__isl_keep isl_basic_set *bset);
  26. isl_size isl_basic_set_n_param(__isl_keep isl_basic_set *bset);
  27. isl_size isl_basic_set_total_dim(__isl_keep const isl_basic_set *bset);
  28. isl_size isl_basic_set_dim(__isl_keep isl_basic_set *bset,
  29. enum isl_dim_type type);
  30. isl_size isl_set_n_dim(__isl_keep isl_set *set);
  31. isl_size isl_set_n_param(__isl_keep isl_set *set);
  32. __isl_export
  33. isl_size isl_set_tuple_dim(__isl_keep isl_set *set);
  34. isl_size isl_set_dim(__isl_keep isl_set *set, enum isl_dim_type type);
  35. isl_ctx *isl_basic_set_get_ctx(__isl_keep isl_basic_set *bset);
  36. isl_ctx *isl_set_get_ctx(__isl_keep isl_set *set);
  37. __isl_give isl_space *isl_basic_set_get_space(__isl_keep isl_basic_set *bset);
  38. __isl_export
  39. __isl_give isl_space *isl_set_get_space(__isl_keep isl_set *set);
  40. __isl_give isl_set *isl_set_reset_space(__isl_take isl_set *set,
  41. __isl_take isl_space *space);
  42. __isl_give isl_aff *isl_basic_set_get_div(__isl_keep isl_basic_set *bset,
  43. int pos);
  44. __isl_give isl_local_space *isl_basic_set_get_local_space(
  45. __isl_keep isl_basic_set *bset);
  46. const char *isl_basic_set_get_tuple_name(__isl_keep isl_basic_set *bset);
  47. isl_bool isl_set_has_tuple_name(__isl_keep isl_set *set);
  48. const char *isl_set_get_tuple_name(__isl_keep isl_set *set);
  49. __isl_give isl_basic_set *isl_basic_set_set_tuple_name(
  50. __isl_take isl_basic_set *set, const char *s);
  51. __isl_give isl_set *isl_set_set_tuple_name(__isl_take isl_set *set,
  52. const char *s);
  53. const char *isl_basic_set_get_dim_name(__isl_keep isl_basic_set *bset,
  54. enum isl_dim_type type, unsigned pos);
  55. __isl_give isl_basic_set *isl_basic_set_set_dim_name(
  56. __isl_take isl_basic_set *bset,
  57. enum isl_dim_type type, unsigned pos, const char *s);
  58. isl_bool isl_set_has_dim_name(__isl_keep isl_set *set,
  59. enum isl_dim_type type, unsigned pos);
  60. const char *isl_set_get_dim_name(__isl_keep isl_set *set,
  61. enum isl_dim_type type, unsigned pos);
  62. __isl_give isl_set *isl_set_set_dim_name(__isl_take isl_set *set,
  63. enum isl_dim_type type, unsigned pos, const char *s);
  64. __isl_give isl_id *isl_basic_set_get_dim_id(__isl_keep isl_basic_set *bset,
  65. enum isl_dim_type type, unsigned pos);
  66. __isl_give isl_basic_set *isl_basic_set_set_tuple_id(
  67. __isl_take isl_basic_set *bset, __isl_take isl_id *id);
  68. __isl_give isl_set *isl_set_set_dim_id(__isl_take isl_set *set,
  69. enum isl_dim_type type, unsigned pos, __isl_take isl_id *id);
  70. isl_bool isl_set_has_dim_id(__isl_keep isl_set *set,
  71. enum isl_dim_type type, unsigned pos);
  72. __isl_give isl_id *isl_set_get_dim_id(__isl_keep isl_set *set,
  73. enum isl_dim_type type, unsigned pos);
  74. __isl_give isl_set *isl_set_set_tuple_id(__isl_take isl_set *set,
  75. __isl_take isl_id *id);
  76. __isl_give isl_set *isl_set_reset_tuple_id(__isl_take isl_set *set);
  77. isl_bool isl_set_has_tuple_id(__isl_keep isl_set *set);
  78. __isl_give isl_id *isl_set_get_tuple_id(__isl_keep isl_set *set);
  79. __isl_give isl_set *isl_set_reset_user(__isl_take isl_set *set);
  80. int isl_set_find_dim_by_id(__isl_keep isl_set *set, enum isl_dim_type type,
  81. __isl_keep isl_id *id);
  82. int isl_set_find_dim_by_name(__isl_keep isl_set *set, enum isl_dim_type type,
  83. const char *name);
  84. int isl_basic_set_is_rational(__isl_keep isl_basic_set *bset);
  85. __isl_null isl_basic_set *isl_basic_set_free(__isl_take isl_basic_set *bset);
  86. __isl_give isl_basic_set *isl_basic_set_copy(__isl_keep isl_basic_set *bset);
  87. __isl_give isl_basic_set *isl_basic_set_empty(__isl_take isl_space *space);
  88. __isl_give isl_basic_set *isl_basic_set_universe(__isl_take isl_space *space);
  89. __isl_give isl_basic_set *isl_basic_set_nat_universe(
  90. __isl_take isl_space *space);
  91. __isl_give isl_basic_set *isl_basic_set_positive_orthant(
  92. __isl_take isl_space *space);
  93. void isl_basic_set_print_internal(__isl_keep isl_basic_set *bset,
  94. FILE *out, int indent);
  95. __isl_export
  96. __isl_give isl_basic_set *isl_basic_set_intersect(
  97. __isl_take isl_basic_set *bset1,
  98. __isl_take isl_basic_set *bset2);
  99. __isl_export
  100. __isl_give isl_basic_set *isl_basic_set_intersect_params(
  101. __isl_take isl_basic_set *bset1, __isl_take isl_basic_set *bset2);
  102. __isl_export
  103. __isl_give isl_basic_set *isl_basic_set_apply(
  104. __isl_take isl_basic_set *bset,
  105. __isl_take isl_basic_map *bmap);
  106. __isl_give isl_basic_set *isl_basic_set_preimage_multi_aff(
  107. __isl_take isl_basic_set *bset, __isl_take isl_multi_aff *ma);
  108. __isl_export
  109. __isl_give isl_basic_set *isl_basic_set_affine_hull(
  110. __isl_take isl_basic_set *bset);
  111. __isl_give isl_basic_set *isl_basic_set_remove_dims(
  112. __isl_take isl_basic_set *bset,
  113. enum isl_dim_type type, unsigned first, unsigned n);
  114. __isl_export
  115. __isl_give isl_basic_set *isl_basic_set_sample(__isl_take isl_basic_set *bset);
  116. __isl_export
  117. __isl_give isl_basic_set *isl_basic_set_detect_equalities(
  118. __isl_take isl_basic_set *bset);
  119. __isl_give isl_basic_set *isl_basic_set_remove_redundancies(
  120. __isl_take isl_basic_set *bset);
  121. __isl_give isl_set *isl_set_remove_redundancies(__isl_take isl_set *set);
  122. __isl_give isl_basic_set *isl_basic_set_list_intersect(
  123. __isl_take struct isl_basic_set_list *list);
  124. __isl_give isl_set *isl_set_list_union(__isl_take isl_set_list *list);
  125. __isl_give isl_basic_set *isl_basic_set_read_from_file(isl_ctx *ctx,
  126. FILE *input);
  127. __isl_constructor
  128. __isl_give isl_basic_set *isl_basic_set_read_from_str(isl_ctx *ctx,
  129. const char *str);
  130. __isl_give isl_set *isl_set_read_from_file(isl_ctx *ctx, FILE *input);
  131. __isl_constructor
  132. __isl_give isl_set *isl_set_read_from_str(isl_ctx *ctx, const char *str);
  133. void isl_basic_set_dump(__isl_keep isl_basic_set *bset);
  134. void isl_set_dump(__isl_keep isl_set *set);
  135. __isl_give isl_printer *isl_printer_print_basic_set(
  136. __isl_take isl_printer *printer, __isl_keep isl_basic_set *bset);
  137. __isl_give isl_printer *isl_printer_print_set(__isl_take isl_printer *printer,
  138. __isl_keep isl_set *map);
  139. __isl_give isl_basic_set *isl_basic_set_fix_si(__isl_take isl_basic_set *bset,
  140. enum isl_dim_type type, unsigned pos, int value);
  141. __isl_give isl_basic_set *isl_basic_set_fix_val(__isl_take isl_basic_set *bset,
  142. enum isl_dim_type type, unsigned pos, __isl_take isl_val *v);
  143. __isl_give isl_set *isl_set_fix_si(__isl_take isl_set *set,
  144. enum isl_dim_type type, unsigned pos, int value);
  145. __isl_give isl_set *isl_set_lower_bound_si(__isl_take isl_set *set,
  146. enum isl_dim_type type, unsigned pos, int value);
  147. __isl_give isl_basic_set *isl_basic_set_lower_bound_val(
  148. __isl_take isl_basic_set *bset, enum isl_dim_type type, unsigned pos,
  149. __isl_take isl_val *value);
  150. __isl_give isl_set *isl_set_lower_bound_val(__isl_take isl_set *set,
  151. enum isl_dim_type type, unsigned pos, __isl_take isl_val *value);
  152. __isl_give isl_set *isl_set_upper_bound_si(__isl_take isl_set *set,
  153. enum isl_dim_type type, unsigned pos, int value);
  154. __isl_give isl_basic_set *isl_basic_set_upper_bound_val(
  155. __isl_take isl_basic_set *bset, enum isl_dim_type type, unsigned pos,
  156. __isl_take isl_val *value);
  157. __isl_give isl_set *isl_set_upper_bound_val(__isl_take isl_set *set,
  158. enum isl_dim_type type, unsigned pos, __isl_take isl_val *value);
  159. __isl_overload
  160. __isl_give isl_set *isl_set_lower_bound_multi_val(__isl_take isl_set *set,
  161. __isl_take isl_multi_val *lower);
  162. __isl_overload
  163. __isl_give isl_set *isl_set_upper_bound_multi_val(__isl_take isl_set *set,
  164. __isl_take isl_multi_val *upper);
  165. __isl_overload
  166. __isl_give isl_set *isl_set_lower_bound_multi_pw_aff(__isl_take isl_set *set,
  167. __isl_take isl_multi_pw_aff *lower);
  168. __isl_overload
  169. __isl_give isl_set *isl_set_upper_bound_multi_pw_aff(__isl_take isl_set *set,
  170. __isl_take isl_multi_pw_aff *upper);
  171. __isl_give isl_set *isl_set_equate(__isl_take isl_set *set,
  172. enum isl_dim_type type1, int pos1, enum isl_dim_type type2, int pos2);
  173. __isl_export
  174. isl_bool isl_basic_set_is_equal(__isl_keep isl_basic_set *bset1,
  175. __isl_keep isl_basic_set *bset2);
  176. isl_bool isl_basic_set_is_disjoint(__isl_keep isl_basic_set *bset1,
  177. __isl_keep isl_basic_set *bset2);
  178. __isl_give isl_set *isl_basic_set_partial_lexmin(
  179. __isl_take isl_basic_set *bset, __isl_take isl_basic_set *dom,
  180. __isl_give isl_set **empty);
  181. __isl_give isl_set *isl_basic_set_partial_lexmax(
  182. __isl_take isl_basic_set *bset, __isl_take isl_basic_set *dom,
  183. __isl_give isl_set **empty);
  184. __isl_give isl_set *isl_set_partial_lexmin(
  185. __isl_take isl_set *set, __isl_take isl_set *dom,
  186. __isl_give isl_set **empty);
  187. __isl_give isl_set *isl_set_partial_lexmax(
  188. __isl_take isl_set *set, __isl_take isl_set *dom,
  189. __isl_give isl_set **empty);
  190. __isl_export
  191. __isl_give isl_set *isl_basic_set_lexmin(__isl_take isl_basic_set *bset);
  192. __isl_export
  193. __isl_give isl_set *isl_basic_set_lexmax(__isl_take isl_basic_set *bset);
  194. __isl_export
  195. __isl_give isl_set *isl_set_lexmin(__isl_take isl_set *set);
  196. __isl_export
  197. __isl_give isl_set *isl_set_lexmax(__isl_take isl_set *set);
  198. __isl_give isl_pw_multi_aff *isl_basic_set_partial_lexmin_pw_multi_aff(
  199. __isl_take isl_basic_set *bset, __isl_take isl_basic_set *dom,
  200. __isl_give isl_set **empty);
  201. __isl_give isl_pw_multi_aff *isl_basic_set_partial_lexmax_pw_multi_aff(
  202. __isl_take isl_basic_set *bset, __isl_take isl_basic_set *dom,
  203. __isl_give isl_set **empty);
  204. __isl_export
  205. __isl_give isl_pw_multi_aff *isl_set_lexmin_pw_multi_aff(
  206. __isl_take isl_set *set);
  207. __isl_export
  208. __isl_give isl_pw_multi_aff *isl_set_lexmax_pw_multi_aff(
  209. __isl_take isl_set *set);
  210. __isl_export
  211. __isl_give isl_multi_pw_aff *isl_set_min_multi_pw_aff(__isl_take isl_set *set);
  212. __isl_export
  213. __isl_give isl_multi_pw_aff *isl_set_max_multi_pw_aff(__isl_take isl_set *set);
  214. __isl_export
  215. __isl_give isl_set *isl_basic_set_union(
  216. __isl_take isl_basic_set *bset1,
  217. __isl_take isl_basic_set *bset2);
  218. int isl_basic_set_compare_at(__isl_keep isl_basic_set *bset1,
  219. __isl_keep isl_basic_set *bset2, int pos);
  220. int isl_set_follows_at(__isl_keep isl_set *set1,
  221. __isl_keep isl_set *set2, int pos);
  222. __isl_export
  223. __isl_give isl_basic_set *isl_basic_set_params(__isl_take isl_basic_set *bset);
  224. __isl_give isl_basic_set *isl_basic_set_from_params(
  225. __isl_take isl_basic_set *bset);
  226. __isl_export
  227. __isl_give isl_set *isl_set_params(__isl_take isl_set *set);
  228. __isl_give isl_set *isl_set_from_params(__isl_take isl_set *set);
  229. __isl_export
  230. __isl_give isl_set *isl_set_bind(__isl_take isl_set *set,
  231. __isl_take isl_multi_id *tuple);
  232. __isl_export
  233. __isl_give isl_set *isl_set_unbind_params(__isl_take isl_set *set,
  234. __isl_take isl_multi_id *tuple);
  235. __isl_export
  236. __isl_give isl_map *isl_set_unbind_params_insert_domain(
  237. __isl_take isl_set *set, __isl_take isl_multi_id *domain);
  238. isl_stat isl_basic_set_dims_get_sign(__isl_keep isl_basic_set *bset,
  239. enum isl_dim_type type, unsigned pos, unsigned n, int *signs);
  240. isl_bool isl_basic_set_plain_is_universe(__isl_keep isl_basic_set *bset);
  241. isl_bool isl_basic_set_is_universe(__isl_keep isl_basic_set *bset);
  242. isl_bool isl_basic_set_plain_is_empty(__isl_keep isl_basic_set *bset);
  243. __isl_export
  244. isl_bool isl_basic_set_is_empty(__isl_keep isl_basic_set *bset);
  245. isl_bool isl_basic_set_is_bounded(__isl_keep isl_basic_set *bset);
  246. __isl_export
  247. isl_bool isl_basic_set_is_subset(__isl_keep isl_basic_set *bset1,
  248. __isl_keep isl_basic_set *bset2);
  249. isl_bool isl_basic_set_plain_is_equal(__isl_keep isl_basic_set *bset1,
  250. __isl_keep isl_basic_set *bset2);
  251. __isl_export
  252. __isl_give isl_set *isl_set_empty(__isl_take isl_space *space);
  253. __isl_export
  254. __isl_give isl_set *isl_set_universe(__isl_take isl_space *space);
  255. __isl_export
  256. __isl_give isl_set *isl_space_universe_set(__isl_take isl_space *space);
  257. __isl_give isl_set *isl_set_nat_universe(__isl_take isl_space *space);
  258. __isl_give isl_set *isl_set_copy(__isl_keep isl_set *set);
  259. __isl_null isl_set *isl_set_free(__isl_take isl_set *set);
  260. __isl_export
  261. __isl_give isl_set *isl_basic_set_to_set(__isl_take isl_basic_set *bset);
  262. __isl_constructor
  263. __isl_give isl_set *isl_set_from_basic_set(__isl_take isl_basic_set *bset);
  264. __isl_export
  265. __isl_give isl_basic_set *isl_set_sample(__isl_take isl_set *set);
  266. __isl_export
  267. __isl_give isl_point *isl_basic_set_sample_point(__isl_take isl_basic_set *bset);
  268. __isl_export
  269. __isl_give isl_point *isl_set_sample_point(__isl_take isl_set *set);
  270. __isl_export
  271. __isl_give isl_set *isl_set_detect_equalities(__isl_take isl_set *set);
  272. __isl_export
  273. __isl_give isl_basic_set *isl_set_affine_hull(__isl_take isl_set *set);
  274. __isl_give isl_basic_set *isl_set_convex_hull(__isl_take isl_set *set);
  275. __isl_export
  276. __isl_give isl_basic_set *isl_set_polyhedral_hull(__isl_take isl_set *set);
  277. __isl_give isl_basic_set *isl_set_simple_hull(__isl_take isl_set *set);
  278. __isl_export
  279. __isl_give isl_basic_set *isl_set_unshifted_simple_hull(
  280. __isl_take isl_set *set);
  281. __isl_give isl_basic_set *isl_set_plain_unshifted_simple_hull(
  282. __isl_take isl_set *set);
  283. __isl_give isl_basic_set *isl_set_unshifted_simple_hull_from_set_list(
  284. __isl_take isl_set *set, __isl_take isl_set_list *list);
  285. __isl_give isl_basic_set *isl_set_bounded_simple_hull(__isl_take isl_set *set);
  286. __isl_give isl_set *isl_set_union_disjoint(
  287. __isl_take isl_set *set1, __isl_take isl_set *set2);
  288. __isl_export
  289. __isl_give isl_set *isl_set_union(
  290. __isl_take isl_set *set1,
  291. __isl_take isl_set *set2);
  292. __isl_export
  293. __isl_give isl_set *isl_set_product(__isl_take isl_set *set1,
  294. __isl_take isl_set *set2);
  295. __isl_give isl_basic_set *isl_basic_set_flat_product(
  296. __isl_take isl_basic_set *bset1, __isl_take isl_basic_set *bset2);
  297. __isl_give isl_set *isl_set_flat_product(__isl_take isl_set *set1,
  298. __isl_take isl_set *set2);
  299. __isl_export
  300. __isl_give isl_set *isl_set_intersect(
  301. __isl_take isl_set *set1,
  302. __isl_take isl_set *set2);
  303. __isl_export
  304. __isl_give isl_set *isl_set_intersect_params(__isl_take isl_set *set,
  305. __isl_take isl_set *params);
  306. __isl_give isl_set *isl_set_intersect_factor_domain(__isl_take isl_set *set,
  307. __isl_take isl_set *domain);
  308. __isl_give isl_set *isl_set_intersect_factor_range(__isl_take isl_set *set,
  309. __isl_take isl_set *range);
  310. __isl_export
  311. __isl_give isl_set *isl_set_subtract(
  312. __isl_take isl_set *set1,
  313. __isl_take isl_set *set2);
  314. __isl_export
  315. __isl_give isl_set *isl_set_complement(__isl_take isl_set *set);
  316. __isl_export
  317. __isl_give isl_set *isl_set_apply(
  318. __isl_take isl_set *set,
  319. __isl_take isl_map *map);
  320. __isl_overload
  321. __isl_give isl_set *isl_set_preimage_multi_aff(__isl_take isl_set *set,
  322. __isl_take isl_multi_aff *ma);
  323. __isl_overload
  324. __isl_give isl_set *isl_set_preimage_pw_multi_aff(__isl_take isl_set *set,
  325. __isl_take isl_pw_multi_aff *pma);
  326. __isl_overload
  327. __isl_give isl_set *isl_set_preimage_multi_pw_aff(__isl_take isl_set *set,
  328. __isl_take isl_multi_pw_aff *mpa);
  329. __isl_give isl_set *isl_set_fix_val(__isl_take isl_set *set,
  330. enum isl_dim_type type, unsigned pos, __isl_take isl_val *v);
  331. __isl_give isl_set *isl_set_fix_dim_si(__isl_take isl_set *set,
  332. unsigned dim, int value);
  333. __isl_give isl_basic_set *isl_basic_set_insert_dims(
  334. __isl_take isl_basic_set *bset,
  335. enum isl_dim_type type, unsigned pos, unsigned n);
  336. __isl_give isl_set *isl_set_insert_dims(__isl_take isl_set *set,
  337. enum isl_dim_type type, unsigned pos, unsigned n);
  338. __isl_give isl_basic_set *isl_basic_set_add_dims(__isl_take isl_basic_set *bset,
  339. enum isl_dim_type type, unsigned n);
  340. __isl_give isl_set *isl_set_add_dims(__isl_take isl_set *set,
  341. enum isl_dim_type type, unsigned n);
  342. __isl_give isl_basic_set *isl_basic_set_move_dims(__isl_take isl_basic_set *bset,
  343. enum isl_dim_type dst_type, unsigned dst_pos,
  344. enum isl_dim_type src_type, unsigned src_pos, unsigned n);
  345. __isl_give isl_set *isl_set_move_dims(__isl_take isl_set *set,
  346. enum isl_dim_type dst_type, unsigned dst_pos,
  347. enum isl_dim_type src_type, unsigned src_pos, unsigned n);
  348. __isl_give isl_basic_set *isl_basic_set_project_out(
  349. __isl_take isl_basic_set *bset,
  350. enum isl_dim_type type, unsigned first, unsigned n);
  351. __isl_overload
  352. __isl_give isl_set *isl_set_project_out_param_id(__isl_take isl_set *set,
  353. __isl_take isl_id *id);
  354. __isl_overload
  355. __isl_give isl_set *isl_set_project_out_param_id_list(__isl_take isl_set *set,
  356. __isl_take isl_id_list *list);
  357. __isl_give isl_set *isl_set_project_out(__isl_take isl_set *set,
  358. enum isl_dim_type type, unsigned first, unsigned n);
  359. __isl_export
  360. __isl_give isl_set *isl_set_project_out_all_params(__isl_take isl_set *set);
  361. __isl_give isl_map *isl_set_project_onto_map(__isl_take isl_set *set,
  362. enum isl_dim_type type, unsigned first, unsigned n);
  363. __isl_give isl_basic_set *isl_basic_set_remove_divs(
  364. __isl_take isl_basic_set *bset);
  365. __isl_give isl_basic_set *isl_basic_set_eliminate(
  366. __isl_take isl_basic_set *bset,
  367. enum isl_dim_type type, unsigned first, unsigned n);
  368. __isl_give isl_set *isl_set_eliminate(__isl_take isl_set *set,
  369. enum isl_dim_type type, unsigned first, unsigned n);
  370. __isl_give isl_set *isl_set_eliminate_dims(__isl_take isl_set *set,
  371. unsigned first, unsigned n);
  372. __isl_give isl_set *isl_set_remove_dims(__isl_take isl_set *bset,
  373. enum isl_dim_type type, unsigned first, unsigned n);
  374. __isl_give isl_basic_set *isl_basic_set_remove_divs_involving_dims(
  375. __isl_take isl_basic_set *bset,
  376. enum isl_dim_type type, unsigned first, unsigned n);
  377. __isl_give isl_set *isl_set_remove_divs_involving_dims(__isl_take isl_set *set,
  378. enum isl_dim_type type, unsigned first, unsigned n);
  379. __isl_give isl_basic_set *isl_basic_set_remove_unknown_divs(
  380. __isl_take isl_basic_set *bset);
  381. __isl_give isl_set *isl_set_remove_unknown_divs(__isl_take isl_set *set);
  382. __isl_give isl_set *isl_set_remove_divs(__isl_take isl_set *set);
  383. __isl_give isl_set *isl_set_split_dims(__isl_take isl_set *set,
  384. enum isl_dim_type type, unsigned first, unsigned n);
  385. __isl_give isl_basic_set *isl_basic_set_drop_constraints_involving_dims(
  386. __isl_take isl_basic_set *bset,
  387. enum isl_dim_type type, unsigned first, unsigned n);
  388. __isl_give isl_basic_set *isl_basic_set_drop_constraints_not_involving_dims(
  389. __isl_take isl_basic_set *bset,
  390. enum isl_dim_type type, unsigned first, unsigned n);
  391. __isl_give isl_set *isl_set_drop_constraints_involving_dims(
  392. __isl_take isl_set *set,
  393. enum isl_dim_type type, unsigned first, unsigned n);
  394. __isl_give isl_set *isl_set_drop_constraints_not_involving_dims(
  395. __isl_take isl_set *set,
  396. enum isl_dim_type type, unsigned first, unsigned n);
  397. __isl_export
  398. isl_bool isl_set_involves_locals(__isl_keep isl_set *set);
  399. isl_bool isl_basic_set_involves_dims(__isl_keep isl_basic_set *bset,
  400. enum isl_dim_type type, unsigned first, unsigned n);
  401. isl_bool isl_set_involves_dims(__isl_keep isl_set *set,
  402. enum isl_dim_type type, unsigned first, unsigned n);
  403. void isl_set_print_internal(__isl_keep isl_set *set, FILE *out, int indent);
  404. isl_bool isl_set_plain_is_empty(__isl_keep isl_set *set);
  405. isl_bool isl_set_plain_is_universe(__isl_keep isl_set *set);
  406. isl_bool isl_set_is_params(__isl_keep isl_set *set);
  407. __isl_export
  408. isl_bool isl_set_is_empty(__isl_keep isl_set *set);
  409. isl_bool isl_set_is_bounded(__isl_keep isl_set *set);
  410. __isl_export
  411. isl_bool isl_set_is_subset(__isl_keep isl_set *set1, __isl_keep isl_set *set2);
  412. __isl_export
  413. isl_bool isl_set_is_strict_subset(__isl_keep isl_set *set1,
  414. __isl_keep isl_set *set2);
  415. __isl_export
  416. isl_bool isl_set_is_equal(__isl_keep isl_set *set1, __isl_keep isl_set *set2);
  417. __isl_export
  418. isl_bool isl_set_is_disjoint(__isl_keep isl_set *set1,
  419. __isl_keep isl_set *set2);
  420. __isl_export
  421. isl_bool isl_set_is_singleton(__isl_keep isl_set *set);
  422. isl_bool isl_set_is_box(__isl_keep isl_set *set);
  423. isl_bool isl_set_has_equal_space(__isl_keep isl_set *set1,
  424. __isl_keep isl_set *set2);
  425. __isl_give isl_set *isl_set_sum(__isl_take isl_set *set1,
  426. __isl_take isl_set *set2);
  427. __isl_give isl_basic_set *isl_basic_set_neg(__isl_take isl_basic_set *bset);
  428. __isl_give isl_set *isl_set_neg(__isl_take isl_set *set);
  429. __isl_give isl_set *isl_set_make_disjoint(__isl_take isl_set *set);
  430. __isl_give isl_set *isl_basic_set_compute_divs(__isl_take isl_basic_set *bset);
  431. __isl_give isl_set *isl_set_compute_divs(__isl_take isl_set *set);
  432. ISL_DEPRECATED
  433. __isl_give isl_set *isl_set_align_divs(__isl_take isl_set *set);
  434. __isl_export
  435. __isl_give isl_multi_val *isl_set_get_plain_multi_val_if_fixed(
  436. __isl_keep isl_set *set);
  437. __isl_give isl_val *isl_set_plain_get_val_if_fixed(__isl_keep isl_set *set,
  438. enum isl_dim_type type, unsigned pos);
  439. isl_bool isl_set_dim_is_bounded(__isl_keep isl_set *set,
  440. enum isl_dim_type type, unsigned pos);
  441. isl_bool isl_set_dim_has_lower_bound(__isl_keep isl_set *set,
  442. enum isl_dim_type type, unsigned pos);
  443. isl_bool isl_set_dim_has_upper_bound(__isl_keep isl_set *set,
  444. enum isl_dim_type type, unsigned pos);
  445. isl_bool isl_set_dim_has_any_lower_bound(__isl_keep isl_set *set,
  446. enum isl_dim_type type, unsigned pos);
  447. isl_bool isl_set_dim_has_any_upper_bound(__isl_keep isl_set *set,
  448. enum isl_dim_type type, unsigned pos);
  449. __isl_export
  450. __isl_give isl_basic_set *isl_basic_set_gist(__isl_take isl_basic_set *bset,
  451. __isl_take isl_basic_set *context);
  452. __isl_give isl_set *isl_set_gist_basic_set(__isl_take isl_set *set,
  453. __isl_take isl_basic_set *context);
  454. __isl_export
  455. __isl_give isl_set *isl_set_gist(__isl_take isl_set *set,
  456. __isl_take isl_set *context);
  457. __isl_export
  458. __isl_give isl_set *isl_set_gist_params(__isl_take isl_set *set,
  459. __isl_take isl_set *context);
  460. isl_stat isl_set_dim_residue_class_val(__isl_keep isl_set *set,
  461. int pos, __isl_give isl_val **modulo, __isl_give isl_val **residue);
  462. __isl_give isl_stride_info *isl_set_get_stride_info(__isl_keep isl_set *set,
  463. int pos);
  464. __isl_export
  465. __isl_give isl_val *isl_set_get_stride(__isl_keep isl_set *set, int pos);
  466. __isl_export
  467. __isl_give isl_fixed_box *isl_set_get_lattice_tile(__isl_keep isl_set *set);
  468. __isl_export
  469. __isl_give isl_fixed_box *isl_set_get_simple_fixed_box_hull(
  470. __isl_keep isl_set *set);
  471. __isl_export
  472. __isl_give isl_set *isl_set_coalesce(__isl_take isl_set *set);
  473. int isl_set_plain_cmp(__isl_keep isl_set *set1, __isl_keep isl_set *set2);
  474. isl_bool isl_set_plain_is_equal(__isl_keep isl_set *set1,
  475. __isl_keep isl_set *set2);
  476. isl_bool isl_set_plain_is_disjoint(__isl_keep isl_set *set1,
  477. __isl_keep isl_set *set2);
  478. uint32_t isl_set_get_hash(__isl_keep isl_set *set);
  479. __isl_export
  480. isl_size isl_set_n_basic_set(__isl_keep isl_set *set);
  481. __isl_export
  482. isl_stat isl_set_foreach_basic_set(__isl_keep isl_set *set,
  483. isl_stat (*fn)(__isl_take isl_basic_set *bset, void *user), void *user);
  484. __isl_give isl_basic_set_list *isl_set_get_basic_set_list(
  485. __isl_keep isl_set *set);
  486. __isl_export
  487. isl_stat isl_set_foreach_point(__isl_keep isl_set *set,
  488. isl_stat (*fn)(__isl_take isl_point *pnt, void *user), void *user);
  489. __isl_give isl_val *isl_set_count_val(__isl_keep isl_set *set);
  490. __isl_constructor
  491. __isl_give isl_basic_set *isl_basic_set_from_point(__isl_take isl_point *pnt);
  492. __isl_export
  493. __isl_give isl_set *isl_point_to_set(__isl_take isl_point *pnt);
  494. __isl_constructor
  495. __isl_give isl_set *isl_set_from_point(__isl_take isl_point *pnt);
  496. __isl_give isl_basic_set *isl_basic_set_box_from_points(
  497. __isl_take isl_point *pnt1, __isl_take isl_point *pnt2);
  498. __isl_give isl_set *isl_set_box_from_points(__isl_take isl_point *pnt1,
  499. __isl_take isl_point *pnt2);
  500. __isl_give isl_basic_set *isl_basic_set_lift(__isl_take isl_basic_set *bset);
  501. __isl_give isl_set *isl_set_lift(__isl_take isl_set *set);
  502. __isl_give isl_map *isl_set_lex_le_set(__isl_take isl_set *set1,
  503. __isl_take isl_set *set2);
  504. __isl_give isl_map *isl_set_lex_lt_set(__isl_take isl_set *set1,
  505. __isl_take isl_set *set2);
  506. __isl_give isl_map *isl_set_lex_ge_set(__isl_take isl_set *set1,
  507. __isl_take isl_set *set2);
  508. __isl_give isl_map *isl_set_lex_gt_set(__isl_take isl_set *set1,
  509. __isl_take isl_set *set2);
  510. int isl_set_size(__isl_keep isl_set *set);
  511. __isl_give isl_basic_set *isl_basic_set_align_params(
  512. __isl_take isl_basic_set *bset, __isl_take isl_space *model);
  513. __isl_give isl_set *isl_set_align_params(__isl_take isl_set *set,
  514. __isl_take isl_space *model);
  515. __isl_give isl_basic_set *isl_basic_set_drop_unused_params(
  516. __isl_take isl_basic_set *bset);
  517. __isl_give isl_set *isl_set_drop_unused_params(__isl_take isl_set *set);
  518. __isl_give isl_mat *isl_basic_set_equalities_matrix(
  519. __isl_keep isl_basic_set *bset, enum isl_dim_type c1,
  520. enum isl_dim_type c2, enum isl_dim_type c3, enum isl_dim_type c4);
  521. __isl_give isl_mat *isl_basic_set_inequalities_matrix(
  522. __isl_keep isl_basic_set *bset, enum isl_dim_type c1,
  523. enum isl_dim_type c2, enum isl_dim_type c3, enum isl_dim_type c4);
  524. __isl_give isl_basic_set *isl_basic_set_from_constraint_matrices(
  525. __isl_take isl_space *space,
  526. __isl_take isl_mat *eq, __isl_take isl_mat *ineq, enum isl_dim_type c1,
  527. enum isl_dim_type c2, enum isl_dim_type c3, enum isl_dim_type c4);
  528. __isl_give isl_basic_set *isl_basic_set_from_multi_aff(
  529. __isl_take isl_multi_aff *ma);
  530. __isl_export
  531. __isl_give isl_set *isl_multi_aff_as_set(__isl_take isl_multi_aff *ma);
  532. __isl_give isl_set *isl_set_from_multi_aff(__isl_take isl_multi_aff *ma);
  533. __isl_give isl_mat *isl_basic_set_reduced_basis(__isl_keep isl_basic_set *bset);
  534. __isl_give isl_basic_set *isl_basic_set_coefficients(
  535. __isl_take isl_basic_set *bset);
  536. __isl_give isl_basic_set_list *isl_basic_set_list_coefficients(
  537. __isl_take isl_basic_set_list *list);
  538. __isl_give isl_basic_set *isl_set_coefficients(__isl_take isl_set *set);
  539. __isl_give isl_basic_set *isl_basic_set_solutions(
  540. __isl_take isl_basic_set *bset);
  541. __isl_give isl_basic_set *isl_set_solutions(__isl_take isl_set *set);
  542. __isl_give isl_pw_aff *isl_set_dim_max(__isl_take isl_set *set, int pos);
  543. __isl_give isl_pw_aff *isl_set_dim_min(__isl_take isl_set *set, int pos);
  544. __isl_give char *isl_basic_set_to_str(__isl_keep isl_basic_set *bset);
  545. __isl_give char *isl_set_to_str(__isl_keep isl_set *set);
  546. #if defined(__cplusplus)
  547. }
  548. #endif
  549. #endif