From 346b81ee463ae906f68f66ed7e7ea55a159f1799 Mon Sep 17 00:00:00 2001 From: rakow Date: Mon, 1 Apr 2024 20:28:20 +0200 Subject: [PATCH] enable scheduled mode choice conditionally --- .../modechoice/ScheduledModeChoiceModule.java | 94 ++++++++++--------- 1 file changed, 50 insertions(+), 44 deletions(-) diff --git a/contribs/informed-mode-choice/src/main/java/org/matsim/modechoice/ScheduledModeChoiceModule.java b/contribs/informed-mode-choice/src/main/java/org/matsim/modechoice/ScheduledModeChoiceModule.java index deb8ae81f6e..ee951328aca 100644 --- a/contribs/informed-mode-choice/src/main/java/org/matsim/modechoice/ScheduledModeChoiceModule.java +++ b/contribs/informed-mode-choice/src/main/java/org/matsim/modechoice/ScheduledModeChoiceModule.java @@ -73,62 +73,68 @@ public void install() { ScheduledModeChoiceConfigGroup config = ConfigUtils.addOrGetModule(getConfig(), ScheduledModeChoiceConfigGroup.class); - Collection strategies = new ArrayList<>(getConfig().replanning().getStrategySettings()); - getConfig().replanning().clearStrategySettings(); + boolean enabled = !config.getSubpopulations().isEmpty(); - for (String subpopulation : config.getSubpopulations()) { + log.info("Scheduled mode choice is {}.", enabled ? "enabled" : "disabled"); - OptionalDouble reroute = strategies.stream().filter(s -> s.getStrategyName().equals(DefaultPlanStrategiesModule.DefaultStrategy.ReRoute) && - s.getSubpopulation().equals(subpopulation)) - .mapToDouble(ReplanningConfigGroup.StrategySettings::getWeight) - .findFirst(); + if (enabled) { - OptionalDouble timeMutate = strategies.stream().filter(s -> - (s.getStrategyName().equals(DefaultPlanStrategiesModule.DefaultStrategy.TimeAllocationMutator) || - s.getStrategyName().equals(DefaultPlanStrategiesModule.DefaultStrategy.TimeAllocationMutator_ReRoute)) && + Collection strategies = new ArrayList<>(getConfig().replanning().getStrategySettings()); + getConfig().replanning().clearStrategySettings(); + + for (String subpopulation : config.getSubpopulations()) { + + OptionalDouble reroute = strategies.stream().filter(s -> s.getStrategyName().equals(DefaultPlanStrategiesModule.DefaultStrategy.ReRoute) && s.getSubpopulation().equals(subpopulation)) - .mapToDouble(ReplanningConfigGroup.StrategySettings::getWeight) - .findFirst(); - - strategies.removeIf(s -> s.getSubpopulation().equals(subpopulation) && EXCLUDED.contains(s.getStrategyName())); - - ReplanningConfigGroup.StrategySettings strategy = new ReplanningConfigGroup.StrategySettings(); - strategy.setStrategyName(ALL_BEST_K_PLAN_MODES_STRATEGY); - strategy.setSubpopulation(subpopulation); - strategy.setWeight(1.0); - strategies.add(strategy); - - if (reroute.isPresent()) { - ReplanningConfigGroup.StrategySettings s = new ReplanningConfigGroup.StrategySettings(); - s.setStrategyName(REROUTE_SELECTED); - s.setSubpopulation(subpopulation); - s.setWeight(reroute.getAsDouble()); - strategies.add(s); + .mapToDouble(ReplanningConfigGroup.StrategySettings::getWeight) + .findFirst(); + + OptionalDouble timeMutate = strategies.stream().filter(s -> + (s.getStrategyName().equals(DefaultPlanStrategiesModule.DefaultStrategy.TimeAllocationMutator) || + s.getStrategyName().equals(DefaultPlanStrategiesModule.DefaultStrategy.TimeAllocationMutator_ReRoute)) && + s.getSubpopulation().equals(subpopulation)) + .mapToDouble(ReplanningConfigGroup.StrategySettings::getWeight) + .findFirst(); + + strategies.removeIf(s -> s.getSubpopulation().equals(subpopulation) && EXCLUDED.contains(s.getStrategyName())); + + ReplanningConfigGroup.StrategySettings strategy = new ReplanningConfigGroup.StrategySettings(); + strategy.setStrategyName(ALL_BEST_K_PLAN_MODES_STRATEGY); + strategy.setSubpopulation(subpopulation); + strategy.setWeight(1.0); + strategies.add(strategy); + + if (reroute.isPresent()) { + ReplanningConfigGroup.StrategySettings s = new ReplanningConfigGroup.StrategySettings(); + s.setStrategyName(REROUTE_SELECTED); + s.setSubpopulation(subpopulation); + s.setWeight(reroute.getAsDouble()); + strategies.add(s); + } + + if (timeMutate.isPresent()) { + ReplanningConfigGroup.StrategySettings s = new ReplanningConfigGroup.StrategySettings(); + s.setStrategyName(TIME_MUTATE_SELECTED); + s.setSubpopulation(subpopulation); + s.setWeight(timeMutate.getAsDouble()); + strategies.add(s); + } } - if (timeMutate.isPresent()) { - ReplanningConfigGroup.StrategySettings s = new ReplanningConfigGroup.StrategySettings(); - s.setStrategyName(TIME_MUTATE_SELECTED); - s.setSubpopulation(subpopulation); - s.setWeight(timeMutate.getAsDouble()); - strategies.add(s); - } - } + strategies.forEach(s -> getConfig().replanning().addStrategySettings(s)); - strategies.forEach(s -> getConfig().replanning().addStrategySettings(s)); + if (config.isAdjustTargetIterations()) { - if (config.isAdjustTargetIterations()) { + int iters = config.getWarumUpIterations() + config.getScheduleIterations() * (1 + config.getBetweenIterations()); - int iters = config.getWarumUpIterations() + config.getScheduleIterations() * (1 + config.getBetweenIterations()); + int target = (int) Math.ceil(iters / getConfig().replanning().getFractionOfIterationsToDisableInnovation()); - int target = (int) Math.ceil(iters / getConfig().replanning().getFractionOfIterationsToDisableInnovation()); + log.info("Adjusting number of iterations from {} to {}.", getConfig().controller().getLastIteration(), target); + getConfig().controller().setLastIteration(target); + } - log.info("Adjusting number of iterations from {} to {}.", getConfig().controller().getLastIteration(), target); - getConfig().controller().setLastIteration(target); + bindPlanSelectorForRemoval().to(WorstNotSelctedPlanSelector.class); } - - bindPlanSelectorForRemoval().to(WorstNotSelctedPlanSelector.class); - } /**