40 namespace Test {
namespace Int {
55 :
Test(
"GCC::Int::All::MinMax::"+
str(
ipl),4,-1,3,false,
ipl) {}
61 for (
int i=
x.size();
i--; )
72 using namespace Gecode;
76 for (
int i=0;
i<5;
i++) {
89 :
Test(
"GCC::Int::All::MinMaxDef::"+
str(
ipl),4,0,3,false,
ipl) {}
95 for (
int i=
x.size();
i--; )
106 using namespace Gecode;
109 for (
int i=0;
i<4;
i++) {
122 :
Test(
"GCC::Int::All::Max::"+
str(
ipl), 4, 1,2, false,
ipl) {}
128 for (
int i=
x.size();
i--; )
130 if (
n[0] != 2 ||
n[1] != 2)
148 :
Test(
std::string(
"GCC::Int::Some::")+
149 (hole ?
"::Hole" :
"::Full")+
str(
ipl),4,1,4,false,
ipl) {}
155 for (
int i=
x.size();
i--; )
157 if ((
n[0] < 2) || (
n[1] < 2) || (
n[2] > 0) || (
n[3] > 0))
163 using namespace Gecode;
173 cards[0]=fixed; cards[1]=fixed;
182 static const int n = 4;
191 for (
int i=0;
i<
n;
i++)
192 if ((
x[
i] < 0) || (
x[
i] > 2))
194 int*
card =
new int[m];
195 for (
int i=0;
i<m;
i++) {
197 if ((
x[
n+
i] < 0) || (
x[
n+
i] > 2)) {
202 for (
int i=0;
i<
n;
i++)
204 for (
int i=0;
i<m;
i++)
214 using namespace Gecode;
219 for (
int i=0;
i<
n;
i++)
221 for (
int i=0;
i<m;
i++)
233 static const int randomArity = 7;
243 if (
arity>randomArity)
250 int*
card =
new int[m];
251 for (
int i=0;
i<m;
i++) {
253 if ((
x[
n+
i] < 0) || (
x[
n+
i] >
n)) {
258 for (
int i=0;
i<
n;
i++)
260 for (
int i=0;
i<m;
i++)
270 if (
arity > randomArity)
277 using namespace Gecode;
281 for (
int i=0;
i<
n;
i++)
283 for (
int i=0;
i<m;
i++)
303 (void)
new VarAll(ipls.ipl());
304 (void)
new VarSome(
"Small",2,-1,3,ipls.ipl());
305 (void)
new VarSome(
"Large",3,-1,4,ipls.ipl());
void values(Home home, const IntVarArgs &x, IntSet y, IntPropLevel ipl)
Post constraint .
int n
Number of negative literals for node type.
Node * x
Pointer to corresponding Boolean expression node.
Passing integer arguments.
int min(int i) const
Return minimum of range at position i.
Passing integer variables.
int size(void) const
Return size of array (number of elements)
Base class for assignments
Generate all assignments.
Help class to create and register tests.
Create(void)
Perform creation and registration.
Test for integer cardinality with max cardinality for all variables
IntAllMax(Gecode::IntPropLevel ipl)
Create and register test.
virtual bool solution(const Assignment &x) const
Test whether x is solution
virtual void post(Gecode::Space &home, Gecode::IntVarArray &x)
Post constraint on x.
Test for integer cardinality with min and max for all variables
IntAllMinMaxDef(Gecode::IntPropLevel ipl)
Create and register test.
virtual bool solution(const Assignment &x) const
Test whether x is solution
virtual void post(Gecode::Space &home, Gecode::IntVarArray &x)
Post constraint on x.
Test for integer cardinality with min and max for all variables
IntAllMinMax(Gecode::IntPropLevel ipl)
Create and register test.
virtual void post(Gecode::Space &home, Gecode::IntVarArray &x)
Post constraint on x.
virtual bool solution(const Assignment &x) const
Test whether x is solution
Test for integer cardinality for some variables
virtual bool solution(const Assignment &x) const
Test whether x is solution
IntSome(Gecode::IntPropLevel ipl)
Create and register test.
virtual void post(Gecode::Space &home, Gecode::IntVarArray &x)
Post constraint on x.
Test for variable cardinality for all cardinality values
virtual bool solution(const Assignment &x) const
Test whether x is solution
VarAll(Gecode::IntPropLevel ipl)
Create and register test.
virtual void post(Gecode::Space &home, Gecode::IntVarArray &xy)
Post constraint on xy.
Test for variable cardinality for some cardinality values
int n
Number of non-cardinality variables.
virtual void post(Gecode::Space &home, Gecode::IntVarArray &xy)
Post constraint on xy.
virtual bool solution(const Assignment &x) const
Test whether x is solution
VarSome(std::string s, int n0, int min, int max, Gecode::IntPropLevel ipl)
Create and register test.
virtual Assignment * assignment(void) const
Create and register initial assignment.
Iterator for simple integer propagation levels.
Generate random selection of assignments.
bool testsearch
Whether to perform search test.
Gecode::IntPropLevel ipl
Propagation level.
int arity
Number of variables.
static std::string str(Gecode::IntPropLevel ipl)
Map integer propagation level to string.
Gecode::IntSet dom
Domain of variables.
ConTestLevel contest
Whether to test for certain consistency.
void count(Home home, const IntVarArgs &x, int n, IntRelType irt, int m, IntPropLevel)
Post propagator for .
Post propagator for SetVar SetOpType SetVar y
IntPropLevel
Propagation levels for integer propagators.
const FloatNum max
Largest allowed float value.
const FloatNum min
Smallest allowed float value.
const unsigned int card
Maximum cardinality of an integer set.
Gecode::IntArgs i({1, 2, 3, 4})
@ CTL_NONE
No consistency-test.