mirror of
https://github.com/graphhopper/jsprit.git
synced 2020-01-24 07:45:05 +01:00
add driver breaks
This commit is contained in:
parent
2503a96237
commit
28dcb2fb56
9 changed files with 100 additions and 25 deletions
|
|
@ -25,6 +25,7 @@ import jsprit.core.problem.solution.InitialSolutionFactory;
|
|||
import jsprit.core.problem.solution.SolutionCostCalculator;
|
||||
import jsprit.core.problem.solution.VehicleRoutingProblemSolution;
|
||||
import jsprit.core.problem.solution.route.VehicleRoute;
|
||||
import jsprit.core.problem.vehicle.Vehicle;
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
|
||||
|
|
@ -60,7 +61,11 @@ public final class InsertionInitialSolutionFactory implements InitialSolutionFac
|
|||
}
|
||||
|
||||
private List<Job> getUnassignedJobs(VehicleRoutingProblem vrp) {
|
||||
return new ArrayList<Job>(vrp.getJobs().values());
|
||||
ArrayList<Job> jobs = new ArrayList<Job>(vrp.getJobs().values());
|
||||
for(Vehicle v : vrp.getVehicles()){
|
||||
if(v.getBreak() != null) jobs.add(v.getBreak());
|
||||
}
|
||||
return jobs;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -95,6 +95,7 @@ final class BreakInsertionCalculator implements JobInsertionCostsCalculator{
|
|||
public InsertionData getInsertionData(final VehicleRoute currentRoute, final Job jobToInsert, final Vehicle newVehicle, double newVehicleDepartureTime, final Driver newDriver, final double bestKnownCosts) {
|
||||
Break breakToInsert = (Break) jobToInsert;
|
||||
if(newVehicle.getBreak() == null || newVehicle.getBreak() != breakToInsert) return InsertionData.createEmptyInsertionData();
|
||||
if(currentRoute.isEmpty()) return InsertionData.createEmptyInsertionData();
|
||||
|
||||
JobInsertionContext insertionContext = new JobInsertionContext(currentRoute, jobToInsert, newVehicle, newDriver, newVehicleDepartureTime);
|
||||
int insertionIndex = InsertionData.NO_INDEX;
|
||||
|
|
@ -160,11 +161,11 @@ final class BreakInsertionCalculator implements JobInsertionCostsCalculator{
|
|||
} else if (status.equals(ConstraintsStatus.NOT_FULFILLED)) {
|
||||
breakThis = false;
|
||||
}
|
||||
double nextActArrTime = prevActStartTime + transportCosts.getTransportTime(prevAct.getLocation(), nextAct.getLocation(), prevActStartTime, newDriver, newVehicle);
|
||||
prevActStartTime = CalculationUtils.getActivityEndTime(nextActArrTime, nextAct);
|
||||
prevAct = nextAct;
|
||||
actIndex++;
|
||||
}
|
||||
double nextActArrTime = prevActStartTime + transportCosts.getTransportTime(prevAct.getLocation(), nextAct.getLocation(), prevActStartTime, newDriver, newVehicle);
|
||||
prevActStartTime = CalculationUtils.getActivityEndTime(nextActArrTime, nextAct);
|
||||
prevAct = nextAct;
|
||||
actIndex++;
|
||||
if(breakThis) break;
|
||||
}
|
||||
if(insertionIndex == InsertionData.NO_INDEX) {
|
||||
|
|
|
|||
|
|
@ -1,12 +1,16 @@
|
|||
package jsprit.core.algorithm.recreate;
|
||||
|
||||
import jsprit.core.problem.solution.route.VehicleRoute;
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
|
||||
/**
|
||||
* Created by schroeder on 19/05/15.
|
||||
*/
|
||||
class InsertBreakListener implements EventListener {
|
||||
|
||||
private static final Logger logger = LogManager.getLogger();
|
||||
|
||||
@Override
|
||||
public void inform(Event event) {
|
||||
if(event instanceof InsertBreak){
|
||||
|
|
@ -20,7 +24,9 @@ class InsertBreakListener implements EventListener {
|
|||
if(!vehicleRoute.isEmpty()){
|
||||
if(vehicleRoute.getVehicle() != ((InsertBreak) event).getNewVehicle()){
|
||||
if(vehicleRoute.getVehicle().getBreak() != null){
|
||||
vehicleRoute.getTourActivities().removeJob(vehicleRoute.getVehicle().getBreak());
|
||||
boolean removed = vehicleRoute.getTourActivities().removeJob(vehicleRoute.getVehicle().getBreak());
|
||||
if(removed)
|
||||
logger.trace("remove old break " + vehicleRoute.getVehicle().getBreak());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -66,6 +66,7 @@ class LocalActivityInsertionCostsCalculator implements ActivityInsertionCostsCal
|
|||
double newAct_endTime = CalculationUtils.getActivityEndTime(newAct_arrTime, newAct);
|
||||
|
||||
double act_costs_newAct = activityCosts.getActivityCost(newAct, newAct_arrTime, iFacts.getNewDriver(), iFacts.getNewVehicle());
|
||||
// if(newAct instanceof BreakActivity) act_costs_newAct = 0.;
|
||||
|
||||
if(isEnd(nextAct) && !toDepot(iFacts.getNewVehicle())) return tp_costs_prevAct_newAct;
|
||||
|
||||
|
|
@ -74,6 +75,7 @@ class LocalActivityInsertionCostsCalculator implements ActivityInsertionCostsCal
|
|||
double nextAct_arrTime = newAct_endTime + tp_time_newAct_nextAct;
|
||||
double endTime_nextAct_new = CalculationUtils.getActivityEndTime(nextAct_arrTime, nextAct);
|
||||
double act_costs_nextAct = activityCosts.getActivityCost(nextAct, nextAct_arrTime, iFacts.getNewDriver(), iFacts.getNewVehicle());
|
||||
// if(nextAct instanceof BreakActivity) act_costs_nextAct = 0;
|
||||
|
||||
double totalCosts = tp_costs_prevAct_newAct + tp_costs_newAct_nextAct + solutionCompletenessRatio * activityCostsWeight * (act_costs_newAct + act_costs_nextAct);
|
||||
|
||||
|
|
@ -87,6 +89,7 @@ class LocalActivityInsertionCostsCalculator implements ActivityInsertionCostsCal
|
|||
double arrTime_nextAct = depTimeAtPrevAct + routingCosts.getTransportTime(prevAct.getLocation(), nextAct.getLocation(), prevAct.getEndTime(), iFacts.getRoute().getDriver(), iFacts.getRoute().getVehicle());
|
||||
double endTime_nextAct_old = CalculationUtils.getActivityEndTime(arrTime_nextAct,nextAct);
|
||||
double actCost_nextAct = activityCosts.getActivityCost(nextAct, arrTime_nextAct, iFacts.getRoute().getDriver(), iFacts.getRoute().getVehicle());
|
||||
// if(nextAct instanceof BreakActivity) actCost_nextAct = 0;
|
||||
|
||||
double endTimeDelay_nextAct = Math.max(0, endTime_nextAct_new - endTime_nextAct_old);
|
||||
Double futureWaiting = stateManager.getActivityState(nextAct, iFacts.getRoute().getVehicle(), InternalStates.FUTURE_WAITING, Double.class);
|
||||
|
|
|
|||
|
|
@ -1,15 +1,33 @@
|
|||
package jsprit.core.algorithm.recreate;
|
||||
|
||||
import jsprit.core.problem.job.Break;
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
|
||||
/**
|
||||
* Created by schroeder on 19/05/15.
|
||||
*/
|
||||
class SwitchVehicleListener implements EventListener{
|
||||
|
||||
private static final Logger logger = LogManager.getLogger();
|
||||
|
||||
@Override
|
||||
public void inform(Event event) {
|
||||
if(event instanceof SwitchVehicle){
|
||||
SwitchVehicle switchVehicle = (SwitchVehicle) event;
|
||||
if(vehiclesDifferent((SwitchVehicle) event)) {
|
||||
logger.trace("switch vehicle (" + ((SwitchVehicle) event).getRoute().getVehicle().getId() + " to " + ((SwitchVehicle) event).getVehicle().getId() + ")");
|
||||
Break aBreak = ((SwitchVehicle) event).getRoute().getVehicle().getBreak();
|
||||
if (aBreak != null) {
|
||||
boolean removed = ((SwitchVehicle) event).getRoute().getTourActivities().removeJob(aBreak);
|
||||
if (removed) logger.trace("remove " + aBreak.getId());
|
||||
}
|
||||
}
|
||||
switchVehicle.getRoute().setVehicleAndDepartureTime(switchVehicle.getVehicle(),((SwitchVehicle) event).getDepartureTime());
|
||||
}
|
||||
}
|
||||
|
||||
private boolean vehiclesDifferent(SwitchVehicle event) {
|
||||
return !event.getRoute().getVehicle().getId().equals(event.getVehicle().getId());
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -4,6 +4,8 @@ import jsprit.core.algorithm.ruin.listener.RuinListener;
|
|||
import jsprit.core.problem.job.Break;
|
||||
import jsprit.core.problem.job.Job;
|
||||
import jsprit.core.problem.solution.route.VehicleRoute;
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
|
||||
import java.util.Collection;
|
||||
|
||||
|
|
@ -12,6 +14,8 @@ import java.util.Collection;
|
|||
*/
|
||||
public class RuinBreaks implements RuinListener {
|
||||
|
||||
private final static Logger logger = LogManager.getLogger();
|
||||
|
||||
@Override
|
||||
public void ruinStarts(Collection<VehicleRoute> routes) {}
|
||||
|
||||
|
|
@ -21,6 +25,7 @@ public class RuinBreaks implements RuinListener {
|
|||
Break aBreak = r.getVehicle().getBreak();
|
||||
if(aBreak != null){
|
||||
r.getTourActivities().removeJob(aBreak);
|
||||
logger.trace("ruin: " + aBreak.getId());
|
||||
unassignedJobs.add(aBreak);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -52,7 +52,9 @@ public class UpdateFutureWaitingTimes implements ReverseActivityVisitor, StateUp
|
|||
@Override
|
||||
public void visit(TourActivity activity) {
|
||||
states.putInternalTypedActivityState(activity,route.getVehicle(),InternalStates.FUTURE_WAITING,futureWaiting);
|
||||
futureWaiting += Math.max(activity.getTheoreticalEarliestOperationStartTime() - activity.getArrTime(),0);
|
||||
// if(!(activity instanceof BreakActivity)) {
|
||||
futureWaiting += Math.max(activity.getTheoreticalEarliestOperationStartTime() - activity.getArrTime(), 0);
|
||||
// }
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue