isl_basic_map_is_empty: special case known empty basic sets
[platform/upstream/isl.git] / include / isl_set.h
1 #ifndef ISL_SET_H
2 #define ISL_SET_H
3
4 #include "isl_map.h"
5
6 #if defined(__cplusplus)
7 extern "C" {
8 #endif
9
10 /* A "basic set" is a basic map with a zero-dimensional
11  * domain.
12  */
13 struct isl_basic_set {
14         int ref;
15 #define ISL_BASIC_SET_FINAL             (1 << 0)
16 #define ISL_BASIC_SET_EMPTY             (1 << 1)
17         unsigned flags;
18
19         unsigned nparam;
20         unsigned zero;
21         unsigned dim;
22         unsigned extra;
23
24         unsigned n_eq;
25         unsigned n_ineq;
26
27         size_t c_size;
28         isl_int **eq;
29         isl_int **ineq;
30
31         unsigned n_div;
32
33         isl_int **div;
34
35         struct isl_blk block;
36         struct isl_blk block2;
37 };
38
39 /* A "set" is a (possibly disjoint) union of basic sets.
40  *
41  * See the documentation of isl_map.
42  */
43 struct isl_set {
44         int ref;
45 #define ISL_SET_DISJOINT                (1 << 0)
46         unsigned flags;
47
48         unsigned nparam;
49         unsigned zero;
50         unsigned dim;
51
52         int n;
53
54         size_t size;
55         struct isl_basic_set *p[0];
56 };
57
58 struct isl_basic_set *isl_basic_set_alloc(struct isl_ctx *ctx,
59                 unsigned nparam, unsigned dim, unsigned extra,
60                 unsigned n_eq, unsigned n_ineq);
61 struct isl_basic_set *isl_basic_set_extend(struct isl_ctx *ctx,
62                 struct isl_basic_set *base,
63                 unsigned nparam, unsigned dim, unsigned extra,
64                 unsigned n_eq, unsigned n_ineq);
65 struct isl_basic_set *isl_basic_set_finalize(struct isl_ctx *ctx,
66                 struct isl_basic_set *bset);
67 void isl_basic_set_free(struct isl_ctx *ctx, struct isl_basic_set *bset);
68 struct isl_basic_set *isl_basic_set_copy(struct isl_ctx *ctx,
69                                         struct isl_basic_set *bset);
70 void isl_basic_set_dump(struct isl_ctx *ctx, struct isl_basic_set *bset,
71                                 FILE *out, int indent);
72 struct isl_basic_set *isl_basic_set_swap_vars(struct isl_ctx *ctx,
73                 struct isl_basic_set *bset, unsigned n);
74 struct isl_basic_set *isl_basic_set_drop_vars(struct isl_ctx *ctx,
75                 struct isl_basic_set *bset, unsigned first, unsigned n);
76 struct isl_basic_set *isl_basic_set_intersect(
77                 struct isl_ctx *ctx, struct isl_basic_set *bset1,
78                 struct isl_basic_set *bset2);
79 struct isl_basic_set *isl_basic_set_affine_hull(struct isl_ctx *ctx,
80                                                 struct isl_basic_set *bset);
81 struct isl_basic_set *isl_basic_set_simplify(
82                 struct isl_ctx *ctx, struct isl_basic_set *bset);
83
84 struct isl_set *isl_basic_set_lexmin(struct isl_ctx *ctx,
85                 struct isl_basic_set *bset);
86 struct isl_set *isl_basic_set_union(
87                 struct isl_ctx *ctx, struct isl_basic_set *bset1,
88                 struct isl_basic_set *bset2);
89
90 struct isl_set *isl_set_alloc(struct isl_ctx *ctx,
91                 unsigned nparam, unsigned dim, int n, unsigned flags);
92 struct isl_set *isl_set_empty(struct isl_ctx *ctx,
93                 unsigned nparam, unsigned dim);
94 struct isl_set *isl_set_add(struct isl_ctx *ctx, struct isl_set *set,
95                                 struct isl_basic_set *bset);
96 struct isl_set *isl_set_finalize(struct isl_ctx *ctx, struct isl_set *set);
97 struct isl_set *isl_set_copy(struct isl_ctx *ctx, struct isl_set *set);
98 void isl_set_free(struct isl_ctx *ctx, struct isl_set *set);
99 struct isl_set *isl_set_dup(struct isl_ctx *ctx, struct isl_set *set);
100 struct isl_set *isl_set_from_basic_set(struct isl_ctx *ctx,
101                                 struct isl_basic_set *bset);
102 struct isl_basic_set *isl_set_affine_hull(struct isl_ctx *ctx,
103                 struct isl_set *set);
104
105 struct isl_set *isl_set_union_disjoint(struct isl_ctx *ctx,
106                         struct isl_set *set1, struct isl_set *set2);
107 struct isl_set *isl_set_union(struct isl_ctx *ctx,
108                         struct isl_set *set1, struct isl_set *set2);
109 struct isl_set *isl_set_subtract(struct isl_ctx *ctx, struct isl_set *set1,
110                 struct isl_set *set2);
111 struct isl_set *isl_set_apply(struct isl_ctx *ctx, struct isl_set *set,
112                 struct isl_map *map);
113
114 void isl_set_dump(struct isl_ctx *ctx, struct isl_set *set, FILE *out,
115                   int indent);
116 struct isl_set *isl_set_swap_vars(struct isl_ctx *ctx,
117                 struct isl_set *set, unsigned n);
118 int isl_set_is_empty(struct isl_ctx *ctx, struct isl_set *set);
119 int isl_set_is_subset(struct isl_ctx *ctx,
120                 struct isl_set *set1, struct isl_set *set2);
121 int isl_set_is_equal(struct isl_ctx *ctx,
122                 struct isl_set *set1, struct isl_set *set2);
123
124 struct isl_set *isl_basic_set_compute_divs(struct isl_ctx *ctx,
125                 struct isl_basic_set *bset);
126
127 #if defined(__cplusplus)
128 }
129 #endif
130
131 #endif