72 x(*this, opt.size(), 0, opt.size()-1),
73 d(*this, opt.size()-1, 1, opt.size()-1) {
74 const int n = x.size();
77 for (
int i=0; i<n-1; i++)
78 rel(*
this, d[i] ==
abs(x[i+1]-x[i]), opt.ipl());
104 const int n = x.size();
105 os <<
"\tx[" << n <<
"] = {";
106 for (
int i = 0; i < n-1; i++)
107 os << x[i] <<
"(" << d[i] <<
"),";
108 os << x[n-1] <<
"}" << std::endl;
122 opt.
parse(argc, argv);
123 if (opt.size() < 2) {
124 std::cerr <<
"size must be at least 2!" << std::endl;
AllInterval(AllInterval &s)
Constructor for cloning e.
int main(int argc, char *argv[])
Main-function.
virtual void print(std::ostream &os) const
Print solution.
virtual Space * copy(void)
Copy during cloning.
AllInterval(const SizeOptions &opt)
Actual model.
static void run(const Options &opt, Script *s=NULL)
Options for scripts with additional size parameter
void parse(int argc, char *argv[])
Parse commandline arguments.
Driver::ScriptBase< Driver::IgnoreStepOption< Space > > Script
Base-class for scripts.
void branch(Home home, const FloatVarArgs &x, FloatVarBranch vars, FloatValBranch vals, FloatBranchFilter bf=nullptr, FloatVarValPrint vvp=nullptr)
Branch over x with variable selection vars and value selection vals.
void rel(Home home, FloatVar x0, FloatRelType frt, FloatVar x1)
Post propagator for .
@ IPL_BND
Bounds propagation.
Gecode toplevel namespace
IntValBranch INT_VAL_SPLIT_MIN(void)
Select values not greater than mean of smallest and largest value.
void distinct(Home home, const IntVarArgs &x, IntPropLevel ipl=IPL_DEF)
Post propagator for for all .
void abs(Home home, FloatVar x0, FloatVar x1)
Post propagator for .
IntVarBranch INT_VAR_SIZE_MIN(BranchTbl tbl=nullptr)
Select variable with smallest domain size.