
org.btrplace.scheduler.choco.constraint.CFence Maven / Gradle / Ivy
/*
* Copyright (c) 2016 University Nice Sophia Antipolis
*
* This file is part of btrplace.
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see .
*/
package org.btrplace.scheduler.choco.constraint;
import org.btrplace.model.Instance;
import org.btrplace.model.Mapping;
import org.btrplace.model.Node;
import org.btrplace.model.VM;
import org.btrplace.model.constraint.Ban;
import org.btrplace.model.constraint.Fence;
import org.btrplace.scheduler.choco.Parameters;
import org.btrplace.scheduler.choco.ReconfigurationProblem;
import org.btrplace.scheduler.choco.Slice;
import org.chocosolver.solver.Cause;
import org.chocosolver.solver.exception.ContradictionException;
import java.util.*;
/**
* Choco implementation of {@link org.btrplace.model.constraint.Fence}.
*
* @author Fabien Hermenier
*/
public class CFence implements ChocoConstraint {
private Fence cstr;
/**
* Make a new constraint.
*
* @param c the constraint to rely on
*/
public CFence(Fence c) {
cstr = c;
}
@Override
public boolean inject(Parameters ps, ReconfigurationProblem rp) {
if (cstr.isContinuous() && !cstr.getChecker().startsWith(rp.getSourceModel())) {
rp.getLogger().error("Constraint {} is not satisfied initially", cstr);
return false;
}
VM vm = cstr.getInvolvedVMs().iterator().next();
Collection nodes = cstr.getInvolvedNodes();
if (rp.getFutureRunningVMs().contains(vm)) {
if (nodes.size() == 1) {
//Only 1 possible destination node, so we directly instantiate the variable.
Slice t = rp.getVMAction(vm).getDSlice();
Node n = nodes.iterator().next();
try {
t.getHoster().instantiateTo(rp.getNode(n), Cause.Null);
} catch (ContradictionException ex) {
rp.getLogger().error("Unable to force VM '" + vm + "' to be running on node '" + n + "'", ex);
return false;
}
} else {
//Transformation to a ban constraint that disallow all the other nodes
List otherNodes = new ArrayList<>(rp.getNodes().size() - nodes.size());
for (Node n : rp.getNodes()) {
if (!nodes.contains(n)) {
otherNodes.add(n);
}
}
return new CBan(new Ban(vm, otherNodes)).inject(ps, rp);
}
}
return true;
}
@Override
public Set getMisPlacedVMs(Instance i) {
Mapping map = i.getModel().getMapping();
VM vm = cstr.getInvolvedVMs().iterator().next();
if (map.isRunning(vm) && !cstr.getInvolvedNodes().contains(map.getVMLocation(vm))) {
return Collections.singleton(vm);
}
return Collections.emptySet();
}
@Override
public String toString() {
return cstr.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy