forked from simbuerg/isl-cpp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPwQpolynomialFold.h
285 lines (243 loc) · 7.77 KB
/
PwQpolynomialFold.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
#ifndef ISL_CXX_PwQpolynomialFold_H
#define ISL_CXX_PwQpolynomialFold_H
#include "isl/polynomial.h"
#include "isl/Bool.h"
#include "isl/DimType.h"
#include "isl/Fold.h"
#include "isl/Format.h"
#include "isl/IslBase.h"
#include "isl/IslException.h"
#include "isl/Stat.h"
#include "isl/polynomial.h"
#include "isl/set.h"
#include <string>
#include "isl/IslFnPtr.h"
namespace isl {
class Point;
class PwQpolynomial;
class QpolynomialFold;
class Set;
class Space;
class Val;
class PwQpolynomialFold {
protected:
Ctx ctx;
void * This;
public:
explicit PwQpolynomialFold(Ctx ctx, isl_pw_qpolynomial_fold *That) : ctx(ctx), This(That) {}
PwQpolynomialFold() : ctx(Ctx(nullptr)), This(nullptr) {}
const Ctx &Context() const { return ctx; }
__isl_give isl_pw_qpolynomial_fold *GetCopy() const;
/// \brief Release ownership of the wrapped object.
///
/// You are on your own now buddy.
/// The wrapper cannot be used anymore after calling Give()
///
/// \returns the wrapped isl object.
__isl_give isl_pw_qpolynomial_fold *Give();
/// \brief unwrap the stored isl object.
/// \return a the wrapped isl object.
__isl_give isl_pw_qpolynomial_fold *Get() const;
/// \brief Constructor for isl_pw_qpolynomial_fold_from_pw_qpolynomial
///
/// \param type
/// \param pwqp
static PwQpolynomialFold fromPwQpolynomial(Fold type, const PwQpolynomial &pwqp);
/// \brief Constructor for isl_pw_qpolynomial_fold_alloc
///
/// \param type
/// \param set
/// \param fold
static PwQpolynomialFold alloc(Fold type, const Set &set, const QpolynomialFold &fold);
/// \brief Constructor for isl_pw_qpolynomial_fold_zero
///
/// \param dim
/// \param type
static PwQpolynomialFold zero(const Space &dim, Fold type);
public:
virtual ~PwQpolynomialFold();
/// \brief Generated from ::<isl_pw_qpolynomial_fold_add>
///
/// \param [in] pwf2
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold add(const PwQpolynomialFold &pwf2) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_add_disjoint>
///
/// \param [in] pwf2
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold addDisjoint(const PwQpolynomialFold &pwf2) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_bound>
///
/// \param [in] tight
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold bound(int * tight) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_coalesce>
///
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold coalesce() const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_dim>
///
/// \param [in] type
///
/// \returns A new unsigned int
unsigned int dim(DimType type) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_domain>
///
///
/// \returns A new Set
Set domain() const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_drop_dims>
///
/// \param [in] type
/// \param [in] first
/// \param [in] n
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold dropDims(DimType type, unsigned int first, unsigned int n) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_eval>
///
/// \param [in] pnt
///
/// \returns A new Val
Val eval(const Point &pnt) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_fold>
///
/// \param [in] pwf2
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold fold(const PwQpolynomialFold &pwf2) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_foreach_lifted_piece>
///
/// \param [in] fn
/// \param [in] user
///
/// \returns A new Stat
Stat foreachLiftedPiece(const std::function<isl_stat(isl_set *, isl_qpolynomial_fold *, void *)> && fn, void * user) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_foreach_piece>
///
/// \param [in] fn
/// \param [in] user
///
/// \returns A new Stat
Stat foreachPiece(const std::function<isl_stat(isl_set *, isl_qpolynomial_fold *, void *)> && fn, void * user) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_get_domain_space>
///
///
/// \returns A new Space
Space getDomainSpace() const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_get_space>
///
///
/// \returns A new Space
Space getSpace() const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_gist>
///
/// \param [in] context
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold gist(const Set &context) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_gist_params>
///
/// \param [in] context
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold gistParams(const Set &context) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_has_equal_space>
///
/// \param [in] pwf2
///
/// \returns A new int
int hasEqualSpace(const PwQpolynomialFold &pwf2) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_intersect_domain>
///
/// \param [in] set
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold intersectDomain(const Set &set) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_intersect_params>
///
/// \param [in] set
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold intersectParams(const Set &set) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_is_zero>
///
///
/// \returns A new Bool
Bool isZero() const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_max>
///
///
/// \returns A new Val
Val max() const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_min>
///
///
/// \returns A new Val
Val min() const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_move_dims>
///
/// \param [in] dst_type
/// \param [in] dst_pos
/// \param [in] src_type
/// \param [in] src_pos
/// \param [in] n
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold moveDims(DimType dst_type, unsigned int dst_pos, DimType src_type, unsigned int src_pos, unsigned int n) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_plain_is_equal>
///
/// \param [in] pwf2
///
/// \returns A new Bool
Bool plainIsEqual(const PwQpolynomialFold &pwf2) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_project_domain_on_params>
///
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold projectDomainOnParams() const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_reset_space>
///
/// \param [in] dim
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold resetSpace(const Space &dim) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_scale_val>
///
/// \param [in] v
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold scaleVal(const Val &v) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_set_dim_name>
///
/// \param [in] type
/// \param [in] pos
/// \param [in] s
///
/// \returns A new PwQpolynomialFold
PwQpolynomialFold setDimName(DimType type, unsigned int pos, std::string s) const;
/// \brief Generated from ::<isl_pw_qpolynomial_fold_size>
///
///
/// \returns A new size_t
size_t size() const;
PwQpolynomialFold(const PwQpolynomialFold &Other) : ctx(Other.Context()), This(Other.GetCopy()) {}
PwQpolynomialFold &operator=(const PwQpolynomialFold &Other);
PwQpolynomialFold (PwQpolynomialFold && Other) : ctx(Other.Context()), This(Other.Give()) {}
PwQpolynomialFold &operator=(PwQpolynomialFold && Other) {
isl_pw_qpolynomial_fold *New = Other.Give();
isl_pw_qpolynomial_fold_free((isl_pw_qpolynomial_fold *)This);
This = New;
ctx = Other.Context();
return *this;
}
/// \brief Implement lt via pointer comparison of the
/// wrapped isl objects.
bool operator<(const PwQpolynomialFold &RHS) const { return This < RHS.This; }
};
} // namespace isl
#endif //ISL_CXX_PwQpolynomialFold_H