66 const Pos&
pos(
void)
const;
68 virtual void archive(
Archive& e)
const;
77 template<
class View,
class Filter,
int n>
81 typedef typename View::VarType
Var;
93 View view(
const Pos&
p)
const;
101 virtual bool status(
const Space& home)
const;
103 virtual size_t dispose(
Space& home);
135 template<
class View,
class Filter,
int n>
141 for (
int i=0;
i<
n;
i++)
143 for (
int i=0;
i<
n;
i++)
144 if (
f.notice() || vs[
i]->notice()) {
150 template<
class View,
class Filter,
int n>
154 :
Brancher(home,vb), start(vb.start),
f(vb.
f) {
156 for (
int i=0;
i<
n;
i++)
160 template<
class View,
class Filter,
int n>
163 for (
int i=start;
i <
x.size();
i++)
171 template<
class View,
class Filter,
int n>
178 s = vs[0]->select(home,
x,start,
f);
181 int* ties = r.
alloc<
int>(
x.size()-start+1);
183 vs[0]->ties(home,
x,start,ties,n_ties,
f);
184 for (
int i=1; (
i <
n-1) && (n_ties > 1);
i++)
185 vs[
i]->brk(home,
x,ties,n_ties);
187 s = vs[
n-1]->select(home,
x,ties,n_ties);
193 s = vs[0]->select(home,
x,start);
196 int* ties = r.
alloc<
int>(
x.size()-start+1);
198 vs[0]->ties(home,
x,start,ties,n_ties);
199 for (
int i=1; (
i <
n-1) && (n_ties > 1);
i++)
200 vs[
i]->brk(home,
x,ties,n_ties);
202 s = vs[
n-1]->select(home,
x,ties,n_ties);
211 template<
class View,
class Filter,
int n>
217 template<
class View,
class Filter,
int n>
220 for (
int i=0;
i<
n;
i++)
221 if (
f.notice() || vs[
i]->notice()) {
225 for (
int i=0;
i<
n;
i++)
226 vs[
i]->dispose(home);
227 (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.
Base-class for branchers.
int n
Number of negative literals for node type.
Gecode::IntArgs i({1, 2, 3, 4})
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.
struct Gecode::@593::NNF::@62::@63 b
For binary nodes (and, or, eqv)
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.
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.
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
struct Gecode::@593::NNF::@62::@64 a
For atomic nodes.