70 const Pos&
pos(
void)
const;
72 virtual void archive(
Archive& e)
const;
81 template<
class View,
class Filter,
int n>
85 typedef typename View::VarType
Var;
97 View view(
const Pos&
p)
const;
105 virtual bool status(
const Space& home)
const;
107 virtual size_t dispose(
Space& home);
139 template<
class View,
class Filter,
int n>
145 for (
int i=0;
i<
n;
i++)
147 for (
int i=0;
i<
n;
i++)
148 if (
f.notice() || vs[
i]->notice()) {
154 template<
class View,
class Filter,
int n>
158 :
Brancher(home,vb), start(vb.start),
f(vb.
f) {
160 for (
int i=0;
i<
n;
i++)
164 template<
class View,
class Filter,
int n>
167 for (
int i=start;
i <
x.size();
i++)
175 template<
class View,
class Filter,
int n>
182 s = vs[0]->select(home,
x,start,
f);
185 int* ties = r.
alloc<
int>(
x.size()-start+1);
187 vs[0]->ties(home,
x,start,ties,n_ties,
f);
188 for (
int i=1; (
i <
n-1) && (n_ties > 1);
i++)
189 vs[
i]->brk(home,
x,ties,n_ties);
191 s = vs[
n-1]->select(home,
x,ties,n_ties);
197 s = vs[0]->select(home,
x,start);
200 int* ties = r.
alloc<
int>(
x.size()-start+1);
202 vs[0]->ties(home,
x,start,ties,n_ties);
203 for (
int i=1; (
i <
n-1) && (n_ties > 1);
i++)
204 vs[
i]->brk(home,
x,ties,n_ties);
206 s = vs[
n-1]->select(home,
x,ties,n_ties);
215 template<
class View,
class Filter,
int n>
221 template<
class View,
class Filter,
int n>
224 for (
int i=0;
i<
n;
i++)
225 if (
f.notice() || vs[
i]->notice()) {
229 for (
int i=0;
i<
n;
i++)
230 vs[
i]->dispose(home);
231 (void) Brancher::dispose(home);
Actor must always be disposed.
T * alloc(long unsigned int n)
Allocate block of n objects of type T from region.
Generic brancher by view selection.
bool pos(const View &x)
Test whether x is postive.
ViewArray< View > x
Views to branch on.
const Pos & pos(void) const
Return position in array.
ViewSel< View > * vs[n]
View selection objects.
Gecode::FloatVal c(-8, 8)
int p
Number of positive literals for node type.
Gecode::IntArgs i(4, 1, 2, 3, 4)
Base-class for branchers.
int n
Number of negative literals for node type.
int start
Unassigned views start at x[start].
std::function< bool(const Space &home, Var x, int i)> BranchFilter
Function type for branch filter functions.
ViewBrancher(Space &home, ViewBrancher< View, Filter, n > &b)
Constructor for cloning b.
void notice(Actor &a, ActorProperty p, bool duplicate=false)
Notice actor property.
virtual ViewSel< View > * copy(Space &home)=0
Create copy during cloning.
Pos(int p)
Create position information.
struct Gecode::@585::NNF::@62::@63 b
For binary nodes (and, or, eqv)
Post propagator for f(x \diamond_{\mathit{op}} y) \sim_r z \f$ void rel(Home home
Node * x
Pointer to corresponding Boolean expression node.
void ignore(Actor &a, ActorProperty p, bool duplicate=false)
Ignore actor property.
virtual void archive(Archive &e) const
Archive into e.
struct Gecode::@585::NNF::@62::@64 a
For atomic nodes.
Choice for performing commit
bool assigned(View x, int v)
Whether x is assigned to value v.
View::VarType Var
The corresponding variable.
Post propagator for SetVar x
virtual void archive(Archive &e) const
Archive into e.
Gecode toplevel namespace
#define GECODE_VTABLE_EXPORT
const int pos
Position of view.
PosChoice(const PosChoice &c)
Initialize.
Home class for posting propagators