Go to the documentation of this file.
38 namespace Gecode {
namespace Int {
namespace Cumulative {
40 template<
class OptTask,
class Cap,
class PL>
47 template<
class OptTask,
class Cap,
class PL>
54 template<
class OptTask,
class Cap,
class PL>
61 for (
int i=
n;
i--; ) {
66 else if (
t[
i].mandatory())
72 if (
t[0].mandatory()) {
75 }
else if (
c.
min() >=
t[0].c()) {
82 if (
c.assigned() && (
c.val() == 1)) {
84 for (
int i=0;
i<
t.size();
i++)
91 for (
int i=0;
i<m;
i++)
100 template<
class OptTask,
class Cap,
class PL>
106 template<
class OptTask,
class Cap,
class PL>
111 return sizeof(*this);
114 template<
class OptTask,
class Cap,
class PL>
133 while ((
i <
n) &&
t[
i].mandatory())
i++;
134 while ((j >= 0) && !
t[j].mandatory()) j--;
148 if (Cap::varderived() &&
c.assigned() &&
c.val()==1) {
150 for (
int i=0;
i<
t.size();
i++)
155 for (
int i=0;
i<
t.size();
i++)
159 ::
post(home(*
this),ut)));
162 if (!PL::basic &&
c.assigned())
friend FloatVal max(const FloatVal &x, const FloatVal &y)
virtual size_t dispose(Space &home)
Delete propagator and return its size.
friend FloatVal min(const FloatVal &x, const FloatVal &y)
Scheduling propagator for unary resource with optional tasks
Scheduling propagator for cumulative resource with mandatory tasks.
ExecStatus subsumed(Space &home, Propagator &p, int c, TaskArray< Task > &t)
Check for subsumption (all tasks must be assigned)
Base-class for both propagators and branchers.
ExecStatus timetabling(Space &home, Propagator &p, Cap c, TaskArray< Task > &t)
Perform time-tabling propagation.
const Gecode::ModEvent ME_BOOL_VAL
Domain operation has resulted in a value (assigned variable)
OptProp(Home home, Cap c, TaskArray< OptTask > &t)
Constructor for creation.
virtual ExecStatus propagate(Space &home, const ModEventDelta &med)
Perform propagation.
Traits class for mapping tasks to task views.
Gecode toplevel namespace
#define GECODE_ES_CHECK(es)
Check whether execution status es is failed or subsumed, and forward failure or subsumption.
Home class for posting propagators
ExecStatus edgefinding(Space &home, int c, TaskViewArray< TaskView > &t)
static ModEvent me(const ModEventDelta &med)
Return modification event for view type in med.
static ExecStatus post(Home home, Cap c, TaskArray< OptTask > &t)
Post propagator that schedules tasks on cumulative resource.
TFE post(PropagatorGroup g)
Only post functions (but not propagators) from g are considered.
IntRelType swap(IntRelType irt)
Return swapped relation type of irt.
ExecStatus overload(Space &home, int c, TaskArray< ManTask > &t)
Check mandatory tasks t for overload.
Scheduling propagator for cumulative resource with optional tasks.
const Gecode::PropCond PC_INT_BND
Propagate when minimum or maximum of a view changes.
virtual Actor * copy(Space &home)
Perform copying during cloning.
#define GECODE_ME_CHECK(me)
Check whether modification event me is failed, and forward failure.
Gecode::FloatVal c(-8, 8)
int n
Number of negative literals for node type.
int ModEventDelta
Modification event deltas.
Propagation has not computed fixpoint.
Gecode::IntArgs i({1, 2, 3, 4})
const Gecode::ModEvent ME_INT_DOM
Domain operation has changed the domain.
#define GECODE_REWRITE(prop, post)
Rewrite propagator by executing post function.
int p
Number of positive literals for node type.