mirror of
https://github.com/graphhopper/jsprit.git
synced 2020-01-24 07:45:05 +01:00
added skills
This commit is contained in:
parent
b3cc891cc5
commit
501453490d
4 changed files with 149 additions and 6 deletions
|
|
@ -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;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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;
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue