90 : f(*this,4,-20,20), step(0.1) {
96 rel(*
this, theta >= 0);
98 rel(*
this, r*
cos(theta) == x);
99 rel(*
this, r*
sin(theta) == y);
100 rel(*
this,
exp(0.30649*theta) == r);
106 :
Script(share,p), step(p.step) {
116 rel(*
this, f[0] >= (b.
f[0].max()+
step));
119 virtual void print(std::ostream& os)
const {
120 os <<
"XY " << f[1].med() <<
" " << f[2].med()
129 int main(
int argc,
char* argv[]) {
131 opt.
parse(argc,argv);
133 Script::run<GoldenSpiral,BAB,Options>(
opt);
virtual void print(std::ostream &os) const
Print solution coordinates.
const Gecode::FloatNum step
GoldenSpiral(const Options &)
Actual model.
FloatVarArray f
The numbers.
FloatNum step
Minimum distance between two solutions.
Parametric base-class for scripts.
void update(Space &, bool share, VarArray< Var > &a)
Update array to be a clone of array a.
int main(int argc, char *argv[])
Main-function.
int p
Number of positive literals for node type.
virtual Space * copy(bool share)
Copy during cloning.
virtual void constrain(const Space &_b)
Add constraint to current model to get next solution (not too close)
FloatValBranch FLOAT_VAL_SPLIT_MIN(void)
Select values not greater than mean of smallest and largest value.
void parse(int &argc, char *argv[])
Parse options from arguments argv (number is argc)
void cos(Home home, FloatVar x0, FloatVar x1)
Post propagator for .
Node * x
Pointer to corresponding Boolean expression node.
void rel(Home home, FloatVar x0, FloatRelType frt, FloatVal n)
Propagates .
void solutions(unsigned int n)
Set default number of solutions to search for.
struct Gecode::@518::NNF::@57::@58 b
For binary nodes (and, or, eqv)
Gecode toplevel namespace
void sin(Home home, FloatVar x0, FloatVar x1)
Post propagator for .
BrancherHandle branch(Home home, const FloatVarArgs &x, FloatVarBranch vars, FloatValBranch vals, FloatBranchFilter bf, FloatVarValPrint vvp)
Branch over x with variable selection vars and value selection vals.
GoldenSpiral(bool share, GoldenSpiral &p)
Constructor for cloning p.
void exp(Home home, FloatVar x0, FloatVar x1)
Post propagator for .
double FloatNum
Floating point number base type.