From 7f5c697b4c2574e93c8822649e2523e68a5f3bdc Mon Sep 17 00:00:00 2001 From: aleks Date: Sun, 10 Nov 2024 17:47:08 +0100 Subject: [PATCH 1/7] Deleted the deprecated AccessEgressType.none enum-value (matsim-build will now crash, errors will be fixed in the next commits) --- .../java/org/matsim/core/config/groups/RoutingConfigGroup.java | 2 -- 1 file changed, 2 deletions(-) diff --git a/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java b/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java index c38fba94eec..26f46d29e9f 100644 --- a/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java +++ b/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java @@ -71,8 +71,6 @@ public final class RoutingConfigGroup extends ConfigGroup { private Double beelineDistanceFactor = 1.3 ; public enum AccessEgressType { - @Deprecated none, - /** * Euclidian distance from facility to nearest point on link; then teleported walk. In normal cases, all activities that belong to the * same link are mapped into the same facility; in consequence, in that situation all will have the same walk time. kai, may'23 From 1b9250d0c964969d9f96b0ec14ded9c4c4c2af91 Mon Sep 17 00:00:00 2001 From: aleks Date: Sun, 17 Nov 2024 14:59:34 +0100 Subject: [PATCH 2/7] Removed all AccessEgressType.none entries from main matsim-module (WIP: Some test will fail) --- .../VspConfigConsistencyCheckerImpl.java | 5 - .../config/groups/RoutingConfigGroup.java | 2 +- .../core/router/DefaultRoutingModules.java | 12 --- .../matsim/core/router/LinkToLinkRouting.java | 23 ++-- .../NetworkRoutingInclAccessEgressModule.java | 5 +- .../core/router/NetworkRoutingProvider.java | 30 +++--- .../matsim/core/controler/ControlerIT.java | 14 +-- ...workRoutingInclAccessEgressModuleTest.java | 6 ++ .../router/TripRouterFactoryImplTest.java | 11 +- .../core/router/old/PlanRouterTest.java | 57 ++++++---- .../matsim/modules/ScoreStatsModuleTest.java | 95 +++++++--------- .../withinday/utils/EditRoutesTest.java | 102 +++++------------- 12 files changed, 136 insertions(+), 226 deletions(-) diff --git a/matsim/src/main/java/org/matsim/core/config/consistency/VspConfigConsistencyCheckerImpl.java b/matsim/src/main/java/org/matsim/core/config/consistency/VspConfigConsistencyCheckerImpl.java index a7dba48bdb6..0801fca6a51 100644 --- a/matsim/src/main/java/org/matsim/core/config/consistency/VspConfigConsistencyCheckerImpl.java +++ b/matsim/src/main/java/org/matsim/core/config/consistency/VspConfigConsistencyCheckerImpl.java @@ -386,11 +386,6 @@ private static boolean checkPlanCalcScoreConfigGroup( Config config, Level lvl, log.error("found marginal utility of money < 0. You almost certainly want a value > 0 here. " ) ; } - // added feb'16 - if ( config.routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none ) ) { - log.log( lvl, "found `PlansCalcRouteConfigGroup.AccessEgressType.none'; vsp should use `accessEgressModeToLink' or " + - "some other value or talk to Kai." ) ; - } // added oct'17: if ( config.scoring().getFractionOfIterationsToStartScoreMSA() == null || config.scoring().getFractionOfIterationsToStartScoreMSA() >= 1. ) { problem = true ; diff --git a/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java b/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java index 26f46d29e9f..6ef6373c9f9 100644 --- a/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java +++ b/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java @@ -90,7 +90,7 @@ public enum AccessEgressType { private static final String ACCESSEGRESSTYPE = "accessEgressType"; private static final String ACCESSEGRESSTYPE_CMT = "Defines how access and egress to main mode is simulated. Either of [none, accessEgressModeToLink, walkConstantTimeToLink, accessEgressModeToLinkPlusTimeConstant], Current default=none which means no access or egress trips are simulated."; - private AccessEgressType accessEgressType = AccessEgressType.none; + private AccessEgressType accessEgressType = AccessEgressType.accessEgressModeToLink; // --- private static final String RANDOMNESS = "routingRandomness" ; diff --git a/matsim/src/main/java/org/matsim/core/router/DefaultRoutingModules.java b/matsim/src/main/java/org/matsim/core/router/DefaultRoutingModules.java index 88e99ba95ce..d566c20678b 100644 --- a/matsim/src/main/java/org/matsim/core/router/DefaultRoutingModules.java +++ b/matsim/src/main/java/org/matsim/core/router/DefaultRoutingModules.java @@ -57,18 +57,6 @@ public static RoutingModule createTeleportationRouter( String mode, Scenario sce params.getBeelineDistanceFactor() ); } - /** - * Creates network router without access/egress. - */ - @Deprecated // use AccessEgressNetworkRouter instead - public static RoutingModule createPureNetworkRouter( String mode, PopulationFactory popFact, Network net, final LeastCostPathCalculator routeAlgo ) { - return new NetworkRoutingModule( - mode, - popFact, - net, - routeAlgo); - } - // TODO: make package private again // Please use injection (NetworkRoutingProvider) to get a NetworkRoutingInclAccessEgressModule - kn/gl nov'19 public static RoutingModule createAccessEgressNetworkRouter( String mode, diff --git a/matsim/src/main/java/org/matsim/core/router/LinkToLinkRouting.java b/matsim/src/main/java/org/matsim/core/router/LinkToLinkRouting.java index 2d83a752dcb..9adee3b2d82 100644 --- a/matsim/src/main/java/org/matsim/core/router/LinkToLinkRouting.java +++ b/matsim/src/main/java/org/matsim/core/router/LinkToLinkRouting.java @@ -120,18 +120,17 @@ public RoutingModule get() { ); // see NetworkRoutingProvider for some notes - if (!routingConfigGroup.getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none)) { - if (mode.equals(TransportMode.walk)) { - return DefaultRoutingModules.createAccessEgressNetworkRouter(mode, leastCostPathCalculator, scenario, - filteredNetwork, invertedNetwork, null,null, timeInterpretation, multimodalLinkChooser); - } else { - return DefaultRoutingModules.createAccessEgressNetworkRouter(mode, leastCostPathCalculator, scenario, - filteredNetwork, invertedNetwork, walkRouter, walkRouter, timeInterpretation, multimodalLinkChooser); - } + if (mode.equals(TransportMode.walk)) { + return DefaultRoutingModules.createAccessEgressNetworkRouter(mode, leastCostPathCalculator, scenario, + filteredNetwork, invertedNetwork, null,null, timeInterpretation, multimodalLinkChooser); + } else { + return DefaultRoutingModules.createAccessEgressNetworkRouter(mode, leastCostPathCalculator, scenario, + filteredNetwork, invertedNetwork, walkRouter, walkRouter, timeInterpretation, multimodalLinkChooser); + } + + // pure inverted router + // TODO: I have disabled this Link2Link Router and instead make it 100% use AccessEgress. Make sure, that this is okay #aleks + //return new LinkToLinkRoutingModule(mode, populationFactory, filteredNetwork, invertedNetwork, leastCostPathCalculator); - } else { - // pure inverted router - return new LinkToLinkRoutingModule(mode, populationFactory, filteredNetwork, invertedNetwork, leastCostPathCalculator); - } } } diff --git a/matsim/src/main/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModule.java b/matsim/src/main/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModule.java index 1a24567b1dd..0a5dbc55e7e 100644 --- a/matsim/src/main/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModule.java +++ b/matsim/src/main/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModule.java @@ -114,10 +114,7 @@ public final class NetworkRoutingInclAccessEgressModule implements RoutingModule this.egressFromNetworkRouter = egressFromNetworkRouter; this.accessEgressType = config.routing().getAccessEgressType(); this.timeInterpretation = timeInterpretation; - if (accessEgressType.equals(AccessEgressType.none)) { - throw new RuntimeException("trying to use access/egress but not switched on in config. " - + "currently not supported; there are too many other problems"); - } else if (accessEgressType.equals(AccessEgressType.walkConstantTimeToLink) && !hasWarnedAccessEgress) { + if (accessEgressType.equals(AccessEgressType.walkConstantTimeToLink) && !hasWarnedAccessEgress) { hasWarnedAccessEgress = true; log.warn("you are using AccessEgressType=" + AccessEgressType.walkConstantTimeToLink + ". That means, access and egress won't get network-routed - even if you specified corresponding RoutingModules for access and egress "); diff --git a/matsim/src/main/java/org/matsim/core/router/NetworkRoutingProvider.java b/matsim/src/main/java/org/matsim/core/router/NetworkRoutingProvider.java index 7b874593fa1..283146e477d 100644 --- a/matsim/src/main/java/org/matsim/core/router/NetworkRoutingProvider.java +++ b/matsim/src/main/java/org/matsim/core/router/NetworkRoutingProvider.java @@ -114,28 +114,24 @@ public RoutingModule get() { travelDisutilityFactory.createTravelDisutility(travelTime), travelTime); - // the following again refers to the (transport)mode, since it will determine the mode of the leg on the network: - if ( !routingConfigGroup.getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - /* - * All network modes should fall back to the TransportMode.walk RoutingModule for access/egress to the Network. - * However, TransportMode.walk cannot fallback on itself for access/egress to the Network, so don't pass a standard - * accessEgressToNetworkRouter RoutingModule for walk.. - */ + /* + * The following again refers to the (transport)mode, since it will determine the mode of the leg on the network: + * + * All network modes should fall back to the TransportMode.walk RoutingModule for access/egress to the Network. + * However, TransportMode.walk cannot fallback on itself for access/egress to the Network, so don't pass a standard + * accessEgressToNetworkRouter RoutingModule for walk.. + */ - //null only works because walk is hardcoded and treated uniquely in the routing module. tschlenther june '20 + //null only works because walk is hardcoded and treated uniquely in the routing module. tschlenther june '20 - // more precisely: If the transport mode is walk, then code is used that does not need the accessEgressToNetwork router. kai, jun'22 - - if (mode.equals(TransportMode.walk)) { - return DefaultRoutingModules.createAccessEgressNetworkRouter(mode, routeAlgo, scenario, filteredNetwork, null, timeInterpretation, multimodalLinkChooser); - } else { - return DefaultRoutingModules.createAccessEgressNetworkRouter(mode, routeAlgo, scenario, filteredNetwork, walkRouter, timeInterpretation, multimodalLinkChooser) ; - } + // more precisely: If the transport mode is walk, then code is used that does not need the accessEgressToNetwork router. kai, jun'22 + if (mode.equals(TransportMode.walk)) { + return DefaultRoutingModules.createAccessEgressNetworkRouter(mode, routeAlgo, scenario, filteredNetwork, null, timeInterpretation, multimodalLinkChooser); } else { - log.warn("[mode: {}; routingMode: {}] Using deprecated routing module without access/egress. Consider using AccessEgressNetworkRouter instead.", mode, routingMode); - return DefaultRoutingModules.createPureNetworkRouter(mode, populationFactory, filteredNetwork, routeAlgo); + return DefaultRoutingModules.createAccessEgressNetworkRouter(mode, routeAlgo, scenario, filteredNetwork, walkRouter, timeInterpretation, multimodalLinkChooser) ; } + } private void checkNetwork(Network filteredNetwork) { diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java index 703ea500d06..e5554045cf0 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java @@ -456,11 +456,7 @@ public Mobsim get() { assertEquals(f.link1.getId(), act2a.getLinkId()); assertEquals(f.link3.getId(), act2b.getLinkId()); - int expectedPlanLength = 3 ; - if ( !f.scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - // now 7 instead of earlier 3: h-wlk-iact-car-iact-walk-h - expectedPlanLength = 7 ; - } + int expectedPlanLength = 7 ; // check that BOTH plans have a route set, even when we only run 1 iteration where only one of them is used. //assertNotNull(leg1.getRoute()); @@ -474,11 +470,9 @@ public Mobsim get() { assertNotNull( ((Leg) plan.getPlanElements().get( 1 )).getRoute(), "null route in plan "+plan.getPlanElements()); - if ( !f.scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - assertNotNull( - ((Leg) plan.getPlanElements().get( 3 )).getRoute(), - "null route in plan "+plan.getPlanElements()); - } + assertNotNull( + ((Leg) plan.getPlanElements().get( 3 )).getRoute(), + "null route in plan "+plan.getPlanElements()); } } diff --git a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java index 0b4cc89e381..961b284a36b 100644 --- a/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java +++ b/matsim/src/test/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModuleTest.java @@ -412,6 +412,11 @@ void calcAccessTimeFromDistanceToLink() { Assert.equals(0.0,legs.get(2).getTravelTime().seconds()); } + /* + + This test was removed, since AccesEgressType.none is not a valid config-setting anymore. aleks Nov'24 + TODO Check if this is okay #aleks + @Test void noBushwackingLegs() { @@ -433,6 +438,7 @@ void noBushwackingLegs() { Assert.equals(TransportMode.car,legs.get(0).getMode()); } + */ /** * returns the mode of the first leg in a plan, which is not a walk (walk is now used as access/egress mode to network modes, diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java index bd671737a31..b0ce2780419 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java @@ -129,10 +129,8 @@ public void install() { 0, PopulationUtils.getFactory().createPerson(Id.create("toto", Person.class)), new AttributesImpl()); - Leg l = (Leg) trip.get( 0 ); - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - l = (Leg) trip.get(2) ; - } + Leg l = (Leg) trip.get(2) ; + // actual test NetworkRoute r = (NetworkRoute) l.getRoute(); @@ -206,10 +204,7 @@ public void install() { 0, PopulationUtils.getFactory().createPerson(Id.create("toto", Person.class)), new AttributesImpl()); - Leg l = (Leg) trip.get( 0 ); - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - l = (Leg) trip.get(2) ; - } + Leg l = (Leg) trip.get(2) ; // actual test NetworkRoute r = (NetworkRoute) l.getRoute(); diff --git a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java index abf9b242c7a..0d6647489c2 100644 --- a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java @@ -27,6 +27,7 @@ import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; +import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; import org.matsim.api.core.v01.population.PlanElement; @@ -35,6 +36,9 @@ import org.matsim.core.config.groups.RoutingConfigGroup; import org.matsim.core.controler.AbstractModule; import org.matsim.core.controler.Injector; +import org.matsim.core.network.NetworkUtils; +import org.matsim.core.network.algorithms.TransportModeNetworkFilter; +import org.matsim.core.network.filter.NetworkLinkFilter; import org.matsim.core.population.routes.NetworkRoute; import org.matsim.core.router.*; import org.matsim.core.router.costcalculators.FreespeedTravelTimeAndDisutility; @@ -52,6 +56,7 @@ import java.util.Arrays; import java.util.List; +import java.util.Set; public class PlanRouterTest { @@ -80,14 +85,12 @@ public void install() { ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).setVehicleId(vehicleId); testee.run(plan); - if ( config.routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - Assertions.assertEquals(vehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).getVehicleId(), "Vehicle Id transferred to new Plan"); - } else { - Assertions.assertEquals(vehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(1).getRoute()).getVehicleId(), "Vehicle Id transferred to new Plan"); - // yy I changed get(0) to get(1) since in the input file there is no intervening walk leg, but in the output there is. kai, feb'16 - } + + Assertions.assertEquals(vehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(1).getRoute()).getVehicleId(), "Vehicle Id transferred to new Plan"); + // yy I changed get(0) to get(1) since in the input file there is no intervening walk leg, but in the output there is. kai, feb'16 } + //TODO This test will currently not work. The objects needed can only be injected. #aleks @Test void keepsVehicleIfTripRouterUsesOneAlready() { final Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); @@ -106,17 +109,27 @@ void keepsVehicleIfTripRouterUsesOneAlready() { final RoutingModule routingModule = new RoutingModule() { @Override public List calcRoute(RoutingRequest request) { - final Facility fromFacility = request.getFromFacility(); - final Facility toFacility = request.getToFacility(); - final double departureTime = request.getDepartureTime(); - final Person person = request.getPerson(); - - List trip = DefaultRoutingModules.createPureNetworkRouter("car", scenario.getPopulation().getFactory(), - scenario.getNetwork(), - leastCostAlgoFactory.createPathCalculator(scenario.getNetwork(), disutilityFactory.createTravelDisutility(travelTime), travelTime) - ).calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, departureTime, person)); - ((NetworkRoute) TripStructureUtils.getLegs(trip).get(0).getRoute()).setVehicleId(newVehicleId); - return trip; + final Facility fromFacility = request.getFromFacility(); + final Facility toFacility = request.getToFacility(); + final double departureTime = request.getDepartureTime(); + final Person person = request.getPerson(); + + + TransportModeNetworkFilter filter = new TransportModeNetworkFilter(scenario.getNetwork()); + Network carOnlyNetwork = NetworkUtils.createNetwork(); + filter.filter(carOnlyNetwork, Set.of("car")); + + List trip = DefaultRoutingModules.createAccessEgressNetworkRouter( + "car", + leastCostAlgoFactory.createPathCalculator(scenario.getNetwork(), disutilityFactory.createTravelDisutility(travelTime), travelTime), + scenario, + carOnlyNetwork, + null, + null, + null + ).calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, departureTime, person)); + ((NetworkRoute) TripStructureUtils.getLegs(trip).get(0).getRoute()).setVehicleId(newVehicleId); + return trip; } }; @@ -138,12 +151,10 @@ public void install() { PlanRouter testee = new PlanRouter(tripRouter, TimeInterpretation.create(config)); testee.run(plan); - if ( config.routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - Assertions.assertEquals(newVehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).getVehicleId(), "Vehicle Id from TripRouter used"); - } else { - Assertions.assertEquals(newVehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(1).getRoute()).getVehicleId(), "Vehicle Id from TripRouter used"); - // yy I changed get(0) to get(1) since in the input file there is no intervening walk leg, but in the output there is. kai, feb'16 - } + + Assertions.assertEquals(newVehicleId, ((NetworkRoute) TripStructureUtils.getLegs(plan).get(1).getRoute()).getVehicleId(), "Vehicle Id from TripRouter used"); + // yy I changed get(0) to get(1) since in the input file there is no intervening walk leg, but in the output there is. kai, feb'16 + } diff --git a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java index 5735acd4d8f..76a842ca52d 100644 --- a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java +++ b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java @@ -54,11 +54,11 @@ public static Stream arguments () { @ParameterizedTest @MethodSource("arguments") - void testScoreStats(boolean isUsingFastCapacityUpdate, boolean isInsertingAccessEgressWalk) { + void testScoreStats(boolean isUsingFastCapacityUpdate) { //TODO changed method signature, check if this broke something #aleks Config config = utils.loadConfig("test/scenarios/equil/config.xml"); config.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); - config.routing().setAccessEgressType(isInsertingAccessEgressWalk? AccessEgressType.accessEgressModeToLink : AccessEgressType.none); + config.routing().setAccessEgressType(AccessEgressType.accessEgressModeToLink); config.controller().setLastIteration(1); Controler controler = new Controler(config); @@ -90,65 +90,44 @@ public void notifyShutdown(ShutdownEvent event) { // } // yy the following is retrofitted from an older double[][] data structure and thus messy. Please improve it. kai, nov'16 - if ( config.routing().getAccessEgressType().equals(AccessEgressType.none) ) { + // yyyy these change with the access/egress car router, but I cannot say if the magnitude of change is plausible. kai, feb'16 +// if(config.qsim().isUsingFastCapacityUpdate()) { { - Double[] array = result.get(ScoreItem.worst).values().toArray(new Double[0]) ; - Assertions.assertEquals(64.75686659291274, array[0], DELTA); - Assertions.assertEquals(64.78366379257605, array[1], DELTA); - } { - Double[] array = result.get(ScoreItem.best).values().toArray(new Double[0]) ; - Assertions.assertEquals(64.75686659291274, array[0], DELTA); - Assertions.assertEquals(64.84180132563583, array[1], DELTA); + Double[] array = result.get(ScoreItem.worst).values().toArray(new Double[0]) ; + Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[0], array[0], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[1], array[1], DELTA); }{ - Double[] array = result.get(ScoreItem.average).values().toArray(new Double[0]) ; - Assertions.assertEquals(64.75686659291274, array[0], DELTA); - Assertions.assertEquals(64.81273255910591, array[1], DELTA); + Double[] array = result.get(ScoreItem.best).values().toArray(new Double[0]) ; + Assertions.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[0], array[0], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[1], array[1], DELTA); }{ - Double[] array = result.get(ScoreItem.executed).values().toArray(new Double[0]) ; - Assertions.assertEquals(64.75686659291274, array[0], DELTA); - Assertions.assertEquals(64.84180132563583, array[1], DELTA); - } - } else { - // yyyy these change with the access/egress car router, but I cannot say if the magnitude of change is plausible. kai, feb'16 -// if(config.qsim().isUsingFastCapacityUpdate()) { - { - Double[] array = result.get(ScoreItem.worst).values().toArray(new Double[0]) ; - Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[0], array[0], DELTA); - Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[1], array[1], DELTA); - }{ - Double[] array = result.get(ScoreItem.best).values().toArray(new Double[0]) ; - Assertions.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[0], array[0], DELTA); - Assertions.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[1], array[1], DELTA); - }{ - Double[] array = result.get(ScoreItem.average).values().toArray(new Double[0]) ; - Assertions.assertEquals(new double[]{53.18953957492432, 45.9741777194131}[0], array[0], DELTA); - Assertions.assertEquals(new double[]{53.18953957492432, 45.9741777194131}[1], array[1], DELTA); - }{ - Double[] array = result.get(ScoreItem.executed).values().toArray(new Double[0]) ; - Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[0], array[0], DELTA); - Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[1], array[1], DELTA); - } -// } else { -// { -// Double[] array = result.get(ScoreItem.worst).values().toArray(new Double[0]) ; -// Assert.assertEquals(new double[]{53.18953957492432, 38.73119275042525}[0], array[0], DELTA); -// Assert.assertEquals(new double[]{53.18953957492432, 38.73119275042525}[1], array[1], DELTA); -// }{ -// Double[] array = result.get(ScoreItem.best).values().toArray(new Double[0]) ; -// Assert.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[0], array[0], DELTA); -// Assert.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[1], array[1], DELTA); -// }{ -// Double[] array = result.get(ScoreItem.average).values().toArray(new Double[0]) ; -// Assert.assertEquals(new double[]{53.18953957492432, 45.97376498301028}[0], array[0], DELTA); -// Assert.assertEquals(new double[]{53.18953957492432, 45.97376498301028}[1], array[1], DELTA); -// }{ -// Double[] array = result.get(ScoreItem.executed).values().toArray(new Double[0]) ; -// Assert.assertEquals(new double[]{53.18953957492432, 38.73119275042525}[0], array[0], DELTA); -// Assert.assertEquals(new double[]{53.18953957492432, 38.73119275042525}[1], array[1], DELTA); -// } -// } + Double[] array = result.get(ScoreItem.average).values().toArray(new Double[0]) ; + Assertions.assertEquals(new double[]{53.18953957492432, 45.9741777194131}[0], array[0], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 45.9741777194131}[1], array[1], DELTA); + }{ + Double[] array = result.get(ScoreItem.executed).values().toArray(new Double[0]) ; + Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[0], array[0], DELTA); + Assertions.assertEquals(new double[]{53.18953957492432, 38.73201822323088}[1], array[1], DELTA); } - } +// } else { +// { +// Double[] array = result.get(ScoreItem.worst).values().toArray(new Double[0]) ; +// Assert.assertEquals(new double[]{53.18953957492432, 38.73119275042525}[0], array[0], DELTA); +// Assert.assertEquals(new double[]{53.18953957492432, 38.73119275042525}[1], array[1], DELTA); +// }{ +// Double[] array = result.get(ScoreItem.best).values().toArray(new Double[0]) ; +// Assert.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[0], array[0], DELTA); +// Assert.assertEquals(new double[]{53.18953957492432, 53.2163372155953}[1], array[1], DELTA); +// }{ +// Double[] array = result.get(ScoreItem.average).values().toArray(new Double[0]) ; +// Assert.assertEquals(new double[]{53.18953957492432, 45.97376498301028}[0], array[0], DELTA); +// Assert.assertEquals(new double[]{53.18953957492432, 45.97376498301028}[1], array[1], DELTA); +// }{ +// Double[] array = result.get(ScoreItem.executed).values().toArray(new Double[0]) ; +// Assert.assertEquals(new double[]{53.18953957492432, 38.73119275042525}[0], array[0], DELTA); +// Assert.assertEquals(new double[]{53.18953957492432, 38.73119275042525}[1], array[1], DELTA); +// } +// } } - } +} diff --git a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java index 5b0d8f2883b..f0f7d9f863e 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java @@ -94,12 +94,8 @@ void testReplanFutureLegRoute() { createScenario(); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory() ); @@ -153,16 +149,10 @@ void testRelocateFutureLegRoute() { createScenario(); - int firstCarLeg = 1 ; // 1-->3 - int scndAct = 2 ; - int scndCarLeg = 3 ; // 3-->9 - int thrdAct = 4 ; - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndAct = 6 ; - scndCarLeg = 9 ; // 3-->9 - thrdAct = 12 ; - } + int firstCarLeg = 3 ; // 1-->3 + int scndAct = 6 ; + int scndCarLeg = 9 ; // 3-->9 + int thrdAct = 12 ; EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory() ); @@ -233,12 +223,8 @@ void testReplanCurrentLegRouteOne() // this is ok (we can still replan a single leg with the computer science router). kai, dec'15 { createScenario(); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 @@ -283,12 +269,8 @@ void testReplanCurrentLegRouteTwo() // create new routes for HW-trip createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Activity activityW1; @@ -309,12 +291,8 @@ void testReplanCurrentLegRouteThree() createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Activity activityW1; @@ -331,12 +309,8 @@ void testReplanCurrentLegRouteFour() createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Activity activityW1; @@ -354,12 +328,8 @@ void testReplanCurrentLegRouteFive() createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Activity activityH2; @@ -375,12 +345,8 @@ void testReplanCurrentLegRouteSix() createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Activity activityH2; @@ -396,12 +362,8 @@ void testReplanCurrentLegRouteSeven() createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Activity activityH2; @@ -417,12 +379,8 @@ void testReplanCurrentLegRouteEight() createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Activity activityH2; @@ -438,12 +396,8 @@ void testReplanCurrentLegRouteNine() createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Activity activityH2; @@ -461,12 +415,8 @@ void testReplanCurrentLegRouteTen() createScenario(); // reset scenario EditRoutes ed = new EditRoutes(scenario.getNetwork(), pathCalculator, scenario.getPopulation().getFactory()); - int firstCarLeg = 1 ; // 1-->3 - int scndCarLeg = 3 ; // 3-->9 - if ( !scenario.getConfig().routing().getAccessEgressType().equals(RoutingConfigGroup.AccessEgressType.none) ) { - firstCarLeg = 3 ; // 1-->3 - scndCarLeg = 9 ; // 3-->9 - } + int firstCarLeg = 3 ; // 1-->3 + int scndCarLeg = 9 ; // 3-->9 Leg legHW = (Leg) plan.getPlanElements().get(firstCarLeg); From cf6a7ccc5e869ba189fb599d6ee879c3f7fd0e09 Mon Sep 17 00:00:00 2001 From: aleks Date: Mon, 6 Jan 2025 15:34:01 +0100 Subject: [PATCH 3/7] Fixed some tests --- .../NetworkRoutingInclAccessEgressModule.java | 4 ++-- .../org/matsim/core/controler/ControlerIT.java | 16 ++++++++++++---- .../matsim/core/router/old/PlanRouterTest.java | 16 ++++++++++++---- 3 files changed, 26 insertions(+), 10 deletions(-) diff --git a/matsim/src/main/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModule.java b/matsim/src/main/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModule.java index 0a5dbc55e7e..5befd7d9c3a 100644 --- a/matsim/src/main/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModule.java +++ b/matsim/src/main/java/org/matsim/core/router/NetworkRoutingInclAccessEgressModule.java @@ -397,7 +397,7 @@ public String toString() { } Id vehicleId = VehicleUtils.getVehicleId(person, leg.getMode()); - Vehicle vehicle = scenario.getVehicles().getVehicles().get(vehicleId); + Vehicle vehicle = scenario.getVehicles().getVehicles().get(vehicleId); // TODO This line creates a lot of problems in the tests: The old router did not need any vehicles, but this one does #aleks Path path = this.routeAlgo.calcLeastCostPath(startNode, endNode, depTime, person, vehicle); if (path == null) { throw new RuntimeException("No route found from node " + startNode.getId() + " to node " + endNode.getId() + " for mode " + mode + "."); @@ -417,7 +417,7 @@ public String toString() { route.setDistance(RouteUtils.calcDistance(route, relPosOnDepartureLink, relPosOnArrivalLink, this.filteredNetwork)); route.setVehicleId(vehicleId); leg.setRoute(route); - travTime = (int) path.travelTime; + travTime = (int) path.travelTime; // yyyy Why are we casting to int here? This causes the link traveltime to be different from the route traveltime. aleks Jan'2025 } else { // create an empty route == staying on place if toLink == endLink diff --git a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java index e5554045cf0..ec93a792564 100644 --- a/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java +++ b/matsim/src/test/java/org/matsim/core/controler/ControlerIT.java @@ -141,7 +141,7 @@ void testConstructor_EventsManagerTypeImmutable() { @ParameterizedTest @ValueSource(booleans = {true, false}) void testTravelTimeCalculation(boolean isUsingFastCapacityUpdate) { - Fixture f = new Fixture(ConfigUtils.createConfig()); + Fixture f = new Fixture(this.utils.loadConfig((String) null)); Config config = f.scenario.getConfig(); /* Create 2 persons driving from link 1 to link 3, both starting at the same time at 7am. */ @@ -185,7 +185,7 @@ void testTravelTimeCalculation(boolean isUsingFastCapacityUpdate) { // Complete the configuration for our test case config.controller().setOverwriteFileSetting(OutputDirectoryHierarchy.OverwriteFileSetting.overwriteExistingFiles); config.controller().setCreateGraphs(false); - config.controller().setWriteEventsInterval(0); + config.controller().setWriteEventsInterval(1); config.controller().setDumpDataAtEnd(false); // - set scoring parameters ActivityParams actParams = new ActivityParams("h"); @@ -222,8 +222,9 @@ void testTravelTimeCalculation(boolean isUsingFastCapacityUpdate) { // test that the plans have the correct travel times // (travel time of the plan does not contain first and last link) + double seconds = ((Leg) (person1.getPlans().get(1).getPlanElements().get(1))).getTravelTime().seconds(); assertEquals(avgTravelTimeLink2, - ((Leg)(person1.getPlans().get(1).getPlanElements().get(1))).getTravelTime().seconds(), MatsimTestUtils.EPSILON, "ReRoute seems to have wrong travel times."); + seconds, MatsimTestUtils.EPSILON, "ReRoute seems to have wrong travel times."); } /** @@ -241,7 +242,7 @@ void testSetScoringFunctionFactory(boolean isUsingFastCapacityUpdate) { config.qsim().setUsingFastCapacityUpdate( isUsingFastCapacityUpdate ); MutableScenario scenario = (MutableScenario) ScenarioUtils.createScenario(config); - // create a very simple network with one link only and an empty population + // create a very simple network with two links only and an empty population Network network = scenario.getNetwork(); Node node1 = network.getFactory().createNode(Id.create(1, Node.class), new Coord(0, 0)); Node node2 = network.getFactory().createNode(Id.create(2, Node.class), new Coord(100, 0)); @@ -252,6 +253,13 @@ void testSetScoringFunctionFactory(boolean isUsingFastCapacityUpdate) { link.setFreespeed(1); link.setCapacity(3600.0); link.setNumberOfLanes(1); + Link linkOpposite = network.getFactory().createLink(Id.create(2, Link.class), node2, node1); + link.setLength(100); + link.setFreespeed(1); + link.setCapacity(3600.0); + link.setNumberOfLanes(1); + network.addLink(link); + network.addLink(linkOpposite); final Controler controler = new Controler(scenario); controler.getConfig().controller().setCreateGraphs(false); diff --git a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java index 0d6647489c2..a455fe25eac 100644 --- a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java @@ -90,7 +90,6 @@ public void install() { // yy I changed get(0) to get(1) since in the input file there is no intervening walk leg, but in the output there is. kai, feb'16 } - //TODO This test will currently not work. The objects needed can only be injected. #aleks @Test void keepsVehicleIfTripRouterUsesOneAlready() { final Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); @@ -119,14 +118,23 @@ public List calcRoute(RoutingRequest request) { Network carOnlyNetwork = NetworkUtils.createNetwork(); filter.filter(carOnlyNetwork, Set.of("car")); + // We create a teleport with beelineDistanceFactor 0, so that the access and egress do not change the overall plan-stats + RoutingModule teleportModule = new TeleportationRoutingModule( + "walk", + scenario, + 1, + 0); + + // TODO I have used the default impls for all needed interfaces. Check if this is okay # aleks List trip = DefaultRoutingModules.createAccessEgressNetworkRouter( "car", leastCostAlgoFactory.createPathCalculator(scenario.getNetwork(), disutilityFactory.createTravelDisutility(travelTime), travelTime), scenario, carOnlyNetwork, - null, - null, - null + teleportModule, + teleportModule, + TimeInterpretation.create(config), + RouterUtils.getMultimodalLinkChooserDefault() ).calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, departureTime, person)); ((NetworkRoute) TripStructureUtils.getLegs(trip).get(0).getRoute()).setVehicleId(newVehicleId); return trip; From adfc569cc52ffc40dee488ba6229cf2f221c9946 Mon Sep 17 00:00:00 2001 From: aleks Date: Tue, 7 Jan 2025 15:18:26 +0100 Subject: [PATCH 4/7] Fixed EditRoutesTest and PlanRouterTest.passesVehicleFromOldPlan() --- .../core/router/old/PlanRouterTest.java | 27 ++++++++++++++++--- .../matsim/modules/ScoreStatsModuleTest.java | 2 +- .../withinday/utils/EditRoutesTest.java | 14 +++++++++- 3 files changed, 38 insertions(+), 5 deletions(-) diff --git a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java index a455fe25eac..5684a4b1e64 100644 --- a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java @@ -27,18 +27,17 @@ import org.junit.jupiter.api.extension.RegisterExtension; import org.matsim.api.core.v01.Id; import org.matsim.api.core.v01.Scenario; +import org.matsim.api.core.v01.TransportMode; import org.matsim.api.core.v01.network.Network; import org.matsim.api.core.v01.population.Person; import org.matsim.api.core.v01.population.Plan; import org.matsim.api.core.v01.population.PlanElement; import org.matsim.core.config.Config; import org.matsim.core.config.ConfigUtils; -import org.matsim.core.config.groups.RoutingConfigGroup; import org.matsim.core.controler.AbstractModule; import org.matsim.core.controler.Injector; import org.matsim.core.network.NetworkUtils; import org.matsim.core.network.algorithms.TransportModeNetworkFilter; -import org.matsim.core.network.filter.NetworkLinkFilter; import org.matsim.core.population.routes.NetworkRoute; import org.matsim.core.router.*; import org.matsim.core.router.costcalculators.FreespeedTravelTimeAndDisutility; @@ -52,7 +51,10 @@ import org.matsim.examples.ExamplesUtils; import org.matsim.facilities.Facility; import org.matsim.testcases.MatsimTestUtils; +import org.matsim.vehicles.PersonVehicles; import org.matsim.vehicles.Vehicle; +import org.matsim.vehicles.VehicleType; +import org.matsim.vehicles.VehicleUtils; import java.util.Arrays; import java.util.List; @@ -83,6 +85,16 @@ public void install() { Plan plan = scenario.getPopulation().getPersons().get(Id.createPersonId(1)).getSelectedPlan(); Id vehicleId = Id.create(1, Vehicle.class); ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).setVehicleId(vehicleId); + + // We need to add a vehicle, it however does not affect the results + Id typeId = Id.create(1, VehicleType.class); + scenario.getVehicles().addVehicleType(VehicleUtils.createVehicleType(typeId)); + scenario.getVehicles().addVehicle(VehicleUtils.createVehicle(Id.createVehicleId(1), scenario.getVehicles().getVehicleTypes().get(typeId))); + + PersonVehicles vehicles = new PersonVehicles(); + vehicles.addModeVehicle(TransportMode.car, Id.createVehicleId(1)); + VehicleUtils.insertVehicleIdsIntoPersonAttributes(plan.getPerson(), vehicles.getModeVehicles()); + testee.run(plan); @@ -103,7 +115,16 @@ void keepsVehicleIfTripRouterUsesOneAlready() { Id oldVehicleId = Id.create(1, Vehicle.class); ((NetworkRoute) TripStructureUtils.getLegs(plan).get(0).getRoute()).setVehicleId(oldVehicleId); - // A trip router which provides vehicle ids by itself. + // We need to add a vehicle, it however does not affect the results + Id typeId = Id.create(1, VehicleType.class); + scenario.getVehicles().addVehicleType(VehicleUtils.createVehicleType(typeId)); + scenario.getVehicles().addVehicle(VehicleUtils.createVehicle(Id.createVehicleId(1), scenario.getVehicles().getVehicleTypes().get(typeId))); + + PersonVehicles vehicles = new PersonVehicles(); + vehicles.addModeVehicle(TransportMode.car, Id.createVehicleId(1)); + VehicleUtils.insertVehicleIdsIntoPersonAttributes(plan.getPerson(), vehicles.getModeVehicles()); + + // A trip router which provides vehicle ids by itself. final Id newVehicleId = Id.create(2, Vehicle.class); final RoutingModule routingModule = new RoutingModule() { @Override diff --git a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java index 76a842ca52d..ae7fe21d0bf 100644 --- a/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java +++ b/matsim/src/test/java/org/matsim/modules/ScoreStatsModuleTest.java @@ -54,7 +54,7 @@ public static Stream arguments () { @ParameterizedTest @MethodSource("arguments") - void testScoreStats(boolean isUsingFastCapacityUpdate) { //TODO changed method signature, check if this broke something #aleks + void testScoreStats(boolean isUsingFastCapacityUpdate) { Config config = utils.loadConfig("test/scenarios/equil/config.xml"); config.qsim().setUsingFastCapacityUpdate(isUsingFastCapacityUpdate); diff --git a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java index f0f7d9f863e..8902366a839 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java @@ -65,6 +65,9 @@ import org.matsim.core.utils.timing.TimeInterpretation; import org.matsim.core.utils.timing.TimeInterpretationModule; import org.matsim.testcases.MatsimTestUtils; +import org.matsim.vehicles.PersonVehicles; +import org.matsim.vehicles.VehicleType; +import org.matsim.vehicles.VehicleUtils; public class EditRoutesTest { @@ -497,7 +500,16 @@ private void createSampleNetwork() { * @author cdobler */ private void createSamplePlan() { - plan = PopulationUtils.createPlan(PopulationUtils.getFactory().createPerson(Id.create(1, Person.class))); + // We need to add a vehicle, it however does not affect the results + Id typeId = Id.create(1, VehicleType.class); + scenario.getVehicles().addVehicleType(VehicleUtils.createVehicleType(typeId)); + scenario.getVehicles().addVehicle(VehicleUtils.createVehicle(Id.createVehicleId(1), scenario.getVehicles().getVehicleTypes().get(typeId))); + + Person p = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); + PersonVehicles vehicles = new PersonVehicles(); + vehicles.addModeVehicle(TransportMode.car, Id.createVehicleId(1)); + VehicleUtils.insertVehicleIdsIntoPersonAttributes(p, vehicles.getModeVehicles()); + plan = PopulationUtils.createPlan(p); Activity activityH1 = PopulationUtils.createAndAddActivityFromLinkId(((Plan) plan), "h", Id.create("l1", Link.class)); PopulationUtils.createAndAddLeg( ((Plan) plan), TransportMode.car ); From a5b4e5052ed3d08a123d0cdaa0f70fbd4dc5021c Mon Sep 17 00:00:00 2001 From: aleks Date: Tue, 7 Jan 2025 15:44:31 +0100 Subject: [PATCH 5/7] Fixed TripRouterFactoryImplTest --- .../router/TripRouterFactoryImplTest.java | 27 +++++++++++++++++-- .../withinday/utils/EditRoutesTest.java | 2 +- 2 files changed, 26 insertions(+), 3 deletions(-) diff --git a/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java b/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java index b0ce2780419..be08459ce0b 100644 --- a/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java +++ b/matsim/src/test/java/org/matsim/core/router/TripRouterFactoryImplTest.java @@ -46,6 +46,9 @@ import org.matsim.utils.objectattributes.attributable.AttributesImpl; import jakarta.inject.Provider; +import org.matsim.vehicles.PersonVehicles; +import org.matsim.vehicles.VehicleType; +import org.matsim.vehicles.VehicleUtils; import java.util.Arrays; import java.util.Collections; @@ -102,6 +105,16 @@ private static void testRestrictedNetwork(final Config config) throws Exception net.addLink( l2pt ); net.addLink( l3 ); + // We need to add a vehicle, it however does not affect the results + Id typeId = Id.create(1, VehicleType.class); + scenario.getVehicles().addVehicleType(VehicleUtils.createVehicleType(typeId)); + scenario.getVehicles().addVehicle(VehicleUtils.createVehicle(Id.createVehicleId(1), scenario.getVehicles().getVehicleTypes().get(typeId))); + + Person p = PopulationUtils.getFactory().createPerson(Id.createPersonId("toto")); + PersonVehicles vehicles = new PersonVehicles(); + vehicles.addModeVehicle(TransportMode.car, Id.createVehicleId(1)); + VehicleUtils.insertVehicleIdsIntoPersonAttributes(p, vehicles.getModeVehicles()); + com.google.inject.Injector injector = Injector.createInjector(scenario.getConfig(), new AbstractModule() { @Override public void install() { @@ -127,7 +140,7 @@ public void install() { new LinkFacility( l1 ), new LinkFacility( l3 ), 0, - PopulationUtils.getFactory().createPerson(Id.create("toto", Person.class)), new AttributesImpl()); + p, new AttributesImpl()); Leg l = (Leg) trip.get(2) ; @@ -179,6 +192,16 @@ void testMonomodalNetwork() throws Exception { net.addLink( l2short ); net.addLink( l3 ); + // We need to add a vehicle, it however does not affect the results + Id typeId = Id.create(1, VehicleType.class); + scenario.getVehicles().addVehicleType(VehicleUtils.createVehicleType(typeId)); + scenario.getVehicles().addVehicle(VehicleUtils.createVehicle(Id.createVehicleId(1), scenario.getVehicles().getVehicleTypes().get(typeId))); + + Person p = PopulationUtils.getFactory().createPerson(Id.createPersonId("toto")); + PersonVehicles vehicles = new PersonVehicles(); + vehicles.addModeVehicle(TransportMode.car, Id.createVehicleId(1)); + VehicleUtils.insertVehicleIdsIntoPersonAttributes(p, vehicles.getModeVehicles()); + // create the factory, get a router, route. com.google.inject.Injector injector = Injector.createInjector(scenario.getConfig(), new AbstractModule() { @Override @@ -202,7 +225,7 @@ public void install() { new LinkFacility( l1 ), new LinkFacility( l3 ), 0, - PopulationUtils.getFactory().createPerson(Id.create("toto", Person.class)), new AttributesImpl()); + p, new AttributesImpl()); Leg l = (Leg) trip.get(2) ; diff --git a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java index 8902366a839..e1b19e9b7ee 100644 --- a/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java +++ b/matsim/src/test/java/org/matsim/withinday/utils/EditRoutesTest.java @@ -505,7 +505,7 @@ private void createSamplePlan() { scenario.getVehicles().addVehicleType(VehicleUtils.createVehicleType(typeId)); scenario.getVehicles().addVehicle(VehicleUtils.createVehicle(Id.createVehicleId(1), scenario.getVehicles().getVehicleTypes().get(typeId))); - Person p = PopulationUtils.getFactory().createPerson(Id.create(1, Person.class)); + Person p = PopulationUtils.getFactory().createPerson(Id.createPersonId(1)); PersonVehicles vehicles = new PersonVehicles(); vehicles.addModeVehicle(TransportMode.car, Id.createVehicleId(1)); VehicleUtils.insertVehicleIdsIntoPersonAttributes(p, vehicles.getModeVehicles()); From 6f93104eb0a88ab715cf653ecf1cd14928ea905c Mon Sep 17 00:00:00 2001 From: aleks Date: Mon, 13 Jan 2025 14:45:04 +0100 Subject: [PATCH 6/7] Added back AccessEgressType.none and createPureNetworkRouter() for compatibility --- .../core/config/groups/RoutingConfigGroup.java | 2 ++ .../matsim/core/router/DefaultRoutingModules.java | 13 +++++++++++++ 2 files changed, 15 insertions(+) diff --git a/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java b/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java index 6ef6373c9f9..fcab52f6d59 100644 --- a/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java +++ b/matsim/src/main/java/org/matsim/core/config/groups/RoutingConfigGroup.java @@ -71,6 +71,8 @@ public final class RoutingConfigGroup extends ConfigGroup { private Double beelineDistanceFactor = 1.3 ; public enum AccessEgressType { + none, + /** * Euclidian distance from facility to nearest point on link; then teleported walk. In normal cases, all activities that belong to the * same link are mapped into the same facility; in consequence, in that situation all will have the same walk time. kai, may'23 diff --git a/matsim/src/main/java/org/matsim/core/router/DefaultRoutingModules.java b/matsim/src/main/java/org/matsim/core/router/DefaultRoutingModules.java index d566c20678b..f99f78c4232 100644 --- a/matsim/src/main/java/org/matsim/core/router/DefaultRoutingModules.java +++ b/matsim/src/main/java/org/matsim/core/router/DefaultRoutingModules.java @@ -57,6 +57,19 @@ public static RoutingModule createTeleportationRouter( String mode, Scenario sce params.getBeelineDistanceFactor() ); } + /** + * Creates network router without access/egress. + */ + @Deprecated // use AccessEgressNetworkRouter instead + public static RoutingModule createPureNetworkRouter( String mode, PopulationFactory popFact, Network net, final LeastCostPathCalculator routeAlgo ) { + return new NetworkRoutingModule( + mode, + popFact, + net, + routeAlgo); + } + + // TODO: make package private again // Please use injection (NetworkRoutingProvider) to get a NetworkRoutingInclAccessEgressModule - kn/gl nov'19 public static RoutingModule createAccessEgressNetworkRouter( String mode, From 85812cb27bde4740abddd0eb75e675479bb4a3fe Mon Sep 17 00:00:00 2001 From: aleks Date: Mon, 13 Jan 2025 15:27:07 +0100 Subject: [PATCH 7/7] Fixed PlanRouterTest --- .../java/org/matsim/core/router/old/PlanRouterTest.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java index 5684a4b1e64..061881c638d 100644 --- a/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java +++ b/matsim/src/test/java/org/matsim/core/router/old/PlanRouterTest.java @@ -42,6 +42,8 @@ import org.matsim.core.router.*; import org.matsim.core.router.costcalculators.FreespeedTravelTimeAndDisutility; import org.matsim.core.router.costcalculators.OnlyTimeDependentTravelDisutilityFactory; +import org.matsim.core.router.speedy.SpeedyALTFactory; +import org.matsim.core.router.util.LeastCostPathCalculatorFactory; import org.matsim.core.scenario.ScenarioByInstanceModule; import org.matsim.core.scenario.ScenarioUtils; import org.matsim.core.trafficmonitoring.FreeSpeedTravelTime; @@ -107,7 +109,7 @@ void keepsVehicleIfTripRouterUsesOneAlready() { final Config config = ConfigUtils.loadConfig(IOUtils.extendUrl(ExamplesUtils.getTestScenarioURL("equil"), "config.xml")); config.plans().setInputFile("plans1.xml"); final Scenario scenario = ScenarioUtils.loadScenario(config); - final DijkstraFactory leastCostAlgoFactory = new DijkstraFactory(); + final LeastCostPathCalculatorFactory leastCostAlgoFactory = new SpeedyALTFactory(); final OnlyTimeDependentTravelDisutilityFactory disutilityFactory = new OnlyTimeDependentTravelDisutilityFactory(); final FreeSpeedTravelTime travelTime = new FreeSpeedTravelTime(); @@ -157,7 +159,7 @@ public List calcRoute(RoutingRequest request) { TimeInterpretation.create(config), RouterUtils.getMultimodalLinkChooserDefault() ).calcRoute(DefaultRoutingRequest.withoutAttributes(fromFacility, toFacility, departureTime, person)); - ((NetworkRoute) TripStructureUtils.getLegs(trip).get(0).getRoute()).setVehicleId(newVehicleId); + ((NetworkRoute) TripStructureUtils.getLegs(trip).get(1).getRoute()).setVehicleId(newVehicleId); return trip; }