use of org.chocosolver.solver.Model in project scheduler by btrplace.
the class CRunningCapacity method injectContinuous.
private boolean injectContinuous(ReconfigurationProblem rp) throws SchedulerException {
Model csp = rp.getModel();
// The constraint must be already satisfied
if (!cstr.isSatisfied(rp.getSourceModel())) {
rp.getLogger().error("The constraint '{}' must be already satisfied to provide a continuous restriction", cstr);
return false;
}
int[] alias = new int[cstr.getInvolvedNodes().size()];
int i = 0;
for (Node n : cstr.getInvolvedNodes()) {
alias[i++] = rp.getNode(n);
}
int nbRunning = 0;
for (Node n : rp.getSourceModel().getMapping().getOnlineNodes()) {
nbRunning += rp.getSourceModel().getMapping().getRunningVMs(n).size();
}
int[] cUse = new int[nbRunning];
IntVar[] dUse = new IntVar[rp.getFutureRunningVMs().size()];
Arrays.fill(cUse, 1);
Arrays.fill(dUse, csp.intVar(1));
ChocoView v = rp.getView(AliasedCumulatives.VIEW_ID);
if (v == null) {
throw SchedulerModelingException.missingView(rp.getSourceModel(), Cumulatives.VIEW_ID);
}
((AliasedCumulatives) v).addDim(cstr.getAmount(), cUse, dUse, alias);
return true;
}
use of org.chocosolver.solver.Model in project scheduler by btrplace.
the class CSplit method inject.
@Override
public boolean inject(Parameters ps, ReconfigurationProblem rp) throws SchedulerException {
List<List<IntVar>> groups = new ArrayList<>();
List<List<VM>> vmGroups = new ArrayList<>();
for (Collection<VM> grp : cstr.getSets()) {
List<IntVar> l = new ArrayList<>();
List<VM> vl = new ArrayList<>();
for (VM vm : grp) {
if (rp.getFutureRunningVMs().contains(vm)) {
Slice s = rp.getVMAction(vm).getDSlice();
l.add(s.getHoster());
vl.add(vm);
}
}
if (!l.isEmpty()) {
groups.add(l);
vmGroups.add(vl);
}
}
Model csp = rp.getModel();
int nbNodes = rp.getNodes().size();
IntVar[][] vars = new IntVar[groups.size()][];
for (int i = 0; i < groups.size(); i++) {
vars[i] = groups.get(i).toArray(new IntVar[groups.get(i).size()]);
}
csp.post(new DisjointMultiple(vars, nbNodes));
return !(cstr.isContinuous() && !injectContinuous(rp, vmGroups));
}
use of org.chocosolver.solver.Model in project scheduler by btrplace.
the class CSplitAmong method inject.
@Override
public boolean inject(Parameters ps, ReconfigurationProblem rp) throws SchedulerException {
if (cstr.isContinuous() && !cstr.isSatisfied(rp.getSourceModel())) {
rp.getLogger().error("The constraint '{}' must be already satisfied to provide a continuous restriction", cstr);
return false;
}
Collection<Collection<VM>> vGroups = cstr.getGroupsOfVMs();
Collection<Collection<Node>> pGroups = cstr.getGroupsOfNodes();
Model csp = rp.getModel();
IntVar[] grpVars = new IntVar[vGroups.size()];
// VM is assigned on a node <-> group variable associated to the VM
// is assigned to the group of nodes it belong too.
int i = 0;
for (Collection<VM> vms : vGroups) {
Among a = new Among(vms, pGroups);
// If the constraint is continuous, there is no way a group of VMs already bound to a group of
// nodes can move to another group. It also means the group of VMs will never overlap
a.setContinuous(cstr.isContinuous());
CAmong ca = new CAmong(a);
if (!ca.inject(ps, rp)) {
return false;
}
grpVars[i++] = ca.getGroupVariable();
}
// forces all the vGroups to use different group of nodes
csp.post(csp.allDifferent(grpVars, "DEFAULT"));
return true;
}
Aggregations