MATSIM
FastAStarLandmarksFactory.java
Go to the documentation of this file.
1 /* *********************************************************************** *
2  * project: org.matsim.*
3  * FastAStarLandmarksFactory.java
4  * *
5  * *********************************************************************** *
6  * *
7  * copyright : (C) 2011 by the members listed in the COPYING, *
8  * LICENSE and WARRANTY file. *
9  * email : info at matsim dot org *
10  * *
11  * *********************************************************************** *
12  * *
13  * This program is free software; you can redistribute it and/or modify *
14  * it under the terms of the GNU General Public License as published by *
15  * the Free Software Foundation; either version 2 of the License, or *
16  * (at your option) any later version. *
17  * See also COPYING, LICENSE and WARRANTY file *
18  * *
19  * *********************************************************************** */
20 
21 package org.matsim.core.router;
22 
23 import java.util.HashMap;
24 import java.util.Map;
25 
26 import jakarta.inject.Inject;
27 import jakarta.inject.Singleton;
28 
40 
44 @Singleton
46 
48  private final Map<Network, RoutingNetwork> routingNetworks = new HashMap<>();
49  private final Map<Network, PreProcessLandmarks> preProcessData = new HashMap<>();
50 
51  private final int nThreads;
52 
53  @Inject
54  public FastAStarLandmarksFactory(final GlobalConfigGroup globalConfigGroup) {
55  this(FastRouterType.ARRAY, globalConfigGroup.getNumberOfThreads());
56  }
57 
58  public FastAStarLandmarksFactory(int nThreads) {
60  }
61 
62  // hide this constructor, as only one router type is allowed anyway...
63  private FastAStarLandmarksFactory(final FastRouterType fastRouterType, int numberOfThreads) {
64  switch (fastRouterType) {
65  case ARRAY:
66  this.routingNetworkFactory = new ArrayRoutingNetworkFactory();
67  break;
68  case POINTER:
69  throw new RuntimeException(
70  "PointerRoutingNetworks are no longer supported. Use ArrayRoutingNetworks instead. Aborting!");
71  default:
72  throw new RuntimeException("Undefined FastRouterType: " + fastRouterType);
73  }
74 
75  this.nThreads = numberOfThreads;
76  }
77 
78  @Override
79  public synchronized LeastCostPathCalculator createPathCalculator(final Network network,
80  final TravelDisutility travelCosts, final TravelTime travelTimes) {
81  RoutingNetwork routingNetwork = this.routingNetworks.get(network);
82  PreProcessLandmarks preProcessLandmarks = this.preProcessData.get(network);
83 
84  if (routingNetwork == null) {
85  routingNetwork = this.routingNetworkFactory.createRoutingNetwork(network);
86 
87  preProcessLandmarks = new PreProcessLandmarks(travelCosts);
88  preProcessLandmarks.setNumberOfThreads(nThreads);
89  preProcessLandmarks.run(network);
90  this.preProcessData.put(network, preProcessLandmarks);
91 
92  for (RoutingNetworkNode node : routingNetwork.getNodes().values()) {
93  node.setDeadEndData(preProcessLandmarks.getNodeData(node.getNode()));
94  }
95 
96  this.routingNetworks.put(network, routingNetwork);
97  }
99 
100  final double overdoFactor = 1.0;
101  return new FastAStarLandmarks(routingNetwork, preProcessLandmarks, travelCosts, travelTimes, overdoFactor,
102  fastRouterFactory);
103  }
104 }
FastAStarLandmarksFactory(final FastRouterType fastRouterType, int numberOfThreads)
final Map< Network, PreProcessLandmarks > preProcessData
Map< Id< Node >, RoutingNetworkNode > getNodes()
RoutingNetwork createRoutingNetwork(final Network network)
synchronized LeastCostPathCalculator createPathCalculator(final Network network, final TravelDisutility travelCosts, final TravelTime travelTimes)
FastAStarLandmarksFactory(final GlobalConfigGroup globalConfigGroup)