add isl_set_flatten
[platform/upstream/isl.git] / isl_map_private.h
index b462eb2..cc7d8c7 100644 (file)
@@ -7,10 +7,29 @@
  * Computerwetenschappen, Celestijnenlaan 200A, B-3001 Leuven, Belgium
  */
 
+#ifndef ISL_MAP_PRIVATE_H
+#define ISL_MAP_PRIVATE_H
+
 #include "isl_set.h"
 #include "isl_map.h"
+#include <isl_reordering.h>
 #include "isl_vec.h"
 
+__isl_give isl_map *isl_map_realign(__isl_take isl_map *map,
+       __isl_take isl_reordering *r);
+__isl_give isl_set *isl_set_realign(__isl_take isl_set *set,
+       __isl_take isl_reordering *r);
+
+__isl_give isl_map *isl_map_reset(__isl_take isl_map *map,
+       enum isl_dim_type type);
+
+__isl_give isl_basic_map *isl_basic_map_reset_dim(
+       __isl_take isl_basic_map *bmap, __isl_take isl_dim *dim);
+__isl_give isl_map *isl_map_reset_dim(__isl_take isl_map *map,
+       __isl_take isl_dim *dim);
+__isl_give isl_set *isl_set_reset_dim(__isl_take isl_set *set,
+       __isl_take isl_dim *dim);
+
 unsigned isl_basic_map_offset(struct isl_basic_map *bmap,
                                        enum isl_dim_type type);
 
@@ -92,6 +111,14 @@ struct isl_basic_map *isl_basic_map_gauss(
        struct isl_basic_map *bmap, int *progress);
 struct isl_basic_set *isl_basic_set_gauss(
        struct isl_basic_set *bset, int *progress);
+__isl_give isl_basic_set *isl_basic_set_sort_constraints(
+       __isl_take isl_basic_set *bset);
+int isl_basic_map_fast_cmp(const __isl_keep isl_basic_map *bmap1,
+       const __isl_keep isl_basic_map *bmap2);
+int isl_basic_set_fast_is_equal(__isl_keep isl_basic_set *bset1,
+       __isl_keep isl_basic_set *bset2);
+int isl_basic_map_fast_is_equal(__isl_keep isl_basic_map *bmap1,
+       __isl_keep isl_basic_map *bmap2);
 struct isl_basic_map *isl_basic_map_normalize_constraints(
        struct isl_basic_map *bmap);
 struct isl_basic_set *isl_basic_set_normalize_constraints(
@@ -104,6 +131,10 @@ __isl_give isl_basic_set *isl_basic_set_underlying_set(
 struct isl_set *isl_map_underlying_set(struct isl_map *map);
 struct isl_basic_map *isl_basic_map_overlying_set(struct isl_basic_set *bset,
        struct isl_basic_map *like);
+__isl_give isl_basic_set *isl_basic_set_drop_constraints_involving(
+       __isl_take isl_basic_set *bset, unsigned first, unsigned n);
+__isl_give isl_basic_set *isl_basic_set_drop(__isl_take isl_basic_set *bset,
+       enum isl_dim_type type, unsigned first, unsigned n);
 struct isl_basic_map *isl_basic_map_drop(struct isl_basic_map *bmap,
        enum isl_dim_type type, unsigned first, unsigned n);
 struct isl_set *isl_set_drop(struct isl_set *set,
@@ -161,3 +192,13 @@ isl_int *isl_set_wrap_facet(__isl_keep isl_set *set,
 int isl_basic_map_contains_point(__isl_keep isl_basic_map *bmap,
        __isl_keep isl_point *point);
 int isl_set_contains_point(__isl_keep isl_set *set, __isl_keep isl_point *point);
+
+int isl_basic_set_vars_get_sign(__isl_keep isl_basic_set *bset,
+       unsigned first, unsigned n, int *signs);
+
+int isl_basic_set_add_div_constraints_var(__isl_keep isl_basic_set *bset,
+       unsigned pos, isl_int *div);
+int isl_basic_map_is_div_constraint(__isl_keep isl_basic_map *bmap,
+       isl_int *constraint, unsigned div);
+
+#endif