1
0
Fork 0
mirror of https://github.com/graphhopper/jsprit.git synced 2020-01-24 07:45:05 +01:00

added skills

This commit is contained in:
oblonski 2014-07-03 10:38:08 +02:00
parent b3cc891cc5
commit 501453490d
4 changed files with 149 additions and 6 deletions

View file

@ -118,7 +118,7 @@ public class ConstraintManager implements HardActivityStateLevelConstraint, Hard
public void addSkillsConstraint() {
if (!skillconstraintSet){
addConstraint(new SkillConstraint(stateManager));
addConstraint(new HardSkillConstraint(stateManager));
skillconstraintSet=true;
}
}

View file

@ -9,24 +9,24 @@ import jsprit.core.problem.solution.route.state.StateFactory;
* SkillConstraint that ensures that only vehicles with according skills can serve route and job to be inserted.
*
*/
public class SkillConstraint implements HardRouteStateLevelConstraint{
public class HardSkillConstraint implements HardRouteStateLevelConstraint{
private RouteAndActivityStateGetter states;
public SkillConstraint(RouteAndActivityStateGetter states) {
public HardSkillConstraint(RouteAndActivityStateGetter states) {
this.states = states;
}
@Override
public boolean fulfilled(JobInsertionContext insertionContext) {
for(String skill : insertionContext.getJob().getRequiredSkills().values()){
if(!insertionContext.getRoute().getVehicle().getSkills().containsSkill(skill)){
if(!insertionContext.getNewVehicle().getSkills().containsSkill(skill)){
return false;
}
}
Skills requiredSkillsForRoute = states.getRouteState(insertionContext.getRoute(), StateFactory.SKILLS, Skills.class);
for(String skill : requiredSkillsForRoute.values()){
if(!insertionContext.getRoute().getVehicle().getSkills().containsSkill(skill)){
if(!insertionContext.getNewVehicle().getSkills().containsSkill(skill)){
return false;
}
}