hide isl_basic_set internals
[platform/upstream/isl.git] / isl_map_private.h
index 21438db..5130bc4 100644 (file)
@@ -7,9 +7,63 @@
  * Computerwetenschappen, Celestijnenlaan 200A, B-3001 Leuven, Belgium
  */
 
-#include "isl_set.h"
-#include "isl_map.h"
-#include "isl_vec.h"
+#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>
+
+/* A "basic set" is a basic map with a zero-dimensional
+ * domain.
+ */
+struct isl_basic_set {
+       int ref;
+#define ISL_BASIC_SET_FINAL            (1 << 0)
+#define ISL_BASIC_SET_EMPTY            (1 << 1)
+#define ISL_BASIC_SET_NO_IMPLICIT      (1 << 2)
+#define ISL_BASIC_SET_NO_REDUNDANT     (1 << 3)
+#define ISL_BASIC_SET_RATIONAL         (1 << 4)
+#define ISL_BASIC_SET_NORMALIZED       (1 << 5)
+#define ISL_BASIC_SET_NORMALIZED_DIVS  (1 << 6)
+#define ISL_BASIC_SET_ALL_EQUALITIES   (1 << 7)
+       unsigned flags;
+
+       struct isl_ctx *ctx;
+
+       struct isl_dim *dim;
+       unsigned extra;
+
+       unsigned n_eq;
+       unsigned n_ineq;
+
+       size_t c_size;
+       isl_int **eq;
+       isl_int **ineq;
+
+       unsigned n_div;
+
+       isl_int **div;
+
+       struct isl_vec *sample;
+
+       struct isl_blk block;
+       struct isl_blk block2;
+};
+
+__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);
 
 unsigned isl_basic_map_offset(struct isl_basic_map *bmap,
                                        enum isl_dim_type type);
@@ -92,6 +146,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 +166,8 @@ __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,
@@ -166,8 +230,13 @@ 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_set_foreach_orthant(__isl_keep isl_set *set,
+       int (*fn)(__isl_take isl_set *orthant, int *signs, void *user),
+       void *user);
 
 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);
 
-int isl_set_is_bounded(__isl_keep isl_set *set);
+#endif