MATSIM
FastMultiNodeDijkstraFactory.java
Go to the documentation of this file.
1 /* *********************************************************************** *
2  * project: org.matsim.*
3  * FastMultiNodeDijkstraFactory.java
4  * *
5  * *********************************************************************** *
6  * *
7  * copyright : (C) 2013 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 
36 
38 
39  private final boolean searchAllEndNodes;
40  private final boolean usePreProcessData;
42  private final Map<Network, RoutingNetwork> routingNetworks = new HashMap<>();
43  private final Map<Network, PreProcessDijkstra> preProcessData = new HashMap<>();
44 
46  this(false);
47  }
48 
49  public FastMultiNodeDijkstraFactory(boolean searchAllEndNodes) {
50  this(false, searchAllEndNodes);
51  }
52 
53  public FastMultiNodeDijkstraFactory(final boolean usePreProcessData, final boolean searchAllEndNodes) {
54  this.usePreProcessData = usePreProcessData;
55  this.searchAllEndNodes = searchAllEndNodes;
56  this.routingNetworkFactory = new ArrayRoutingNetworkFactory();
57  }
58 
59  @Override
60  public synchronized LeastCostPathCalculator createPathCalculator(final Network network,
61  final TravelDisutility travelCosts, final TravelTime travelTimes) {
62 
63  RoutingNetwork routingNetwork = this.routingNetworks.get(network);
64  PreProcessDijkstra preProcessDijkstra = this.preProcessData.get(network);
65 
66  if (routingNetwork == null) {
67  routingNetwork = this.routingNetworkFactory.createRoutingNetwork(network);
68 
69  if (this.usePreProcessData) {
70  preProcessDijkstra = new PreProcessDijkstra();
71  preProcessDijkstra.run(network);
72  this.preProcessData.put(network, preProcessDijkstra);
73 
74  for (RoutingNetworkNode node : routingNetwork.getNodes().values()) {
75  node.setDeadEndData(preProcessDijkstra.getNodeData(node.getNode()));
76  }
77  }
78 
79  this.routingNetworks.put(network, routingNetwork);
80  }
82 
83  return new FastMultiNodeDijkstra(routingNetwork, travelCosts, travelTimes, preProcessDijkstra,
84  fastRouterFactory, this.searchAllEndNodes);
85  }
86 }
Map< Id< Node >, RoutingNetworkNode > getNodes()
synchronized LeastCostPathCalculator createPathCalculator(final Network network, final TravelDisutility travelCosts, final TravelTime travelTimes)
FastMultiNodeDijkstraFactory(final boolean usePreProcessData, final boolean searchAllEndNodes)
RoutingNetwork createRoutingNetwork(final Network network)