forked from opentripplanner/OpenTripPlanner
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathRaptorService.java
More file actions
83 lines (71 loc) · 2.66 KB
/
RaptorService.java
File metadata and controls
83 lines (71 loc) · 2.66 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package org.opentripplanner.raptor;
import java.util.stream.Collectors;
import org.opentripplanner.raptor.api.model.RaptorTripSchedule;
import org.opentripplanner.raptor.api.request.RaptorRequest;
import org.opentripplanner.raptor.api.response.RaptorResponse;
import org.opentripplanner.raptor.configure.RaptorConfig;
import org.opentripplanner.raptor.service.DefaultStopArrivals;
import org.opentripplanner.raptor.service.HeuristicSearchTask;
import org.opentripplanner.raptor.service.RangeRaptorDynamicSearch;
import org.opentripplanner.raptor.spi.RaptorTransitDataProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* A service for performing Range Raptor routing request.
*
* @param <T> The TripSchedule type defined by the user of the range raptor API.
*/
public class RaptorService<T extends RaptorTripSchedule> {
private static final Logger LOG = LoggerFactory.getLogger(RaptorService.class);
private final RaptorConfig<T> config;
public RaptorService(RaptorConfig<T> config) {
this.config = config;
}
public RaptorResponse<T> route(
RaptorRequest<T> request,
RaptorTransitDataProvider<T> transitData
) {
LOG.debug("Original request: {}", request);
RaptorResponse<T> response;
if (request.isDynamicSearch()) {
response = new RangeRaptorDynamicSearch<>(config, transitData, request).route();
} else {
response = routeUsingStdWorker(transitData, request);
}
if (LOG.isDebugEnabled()) {
var pathsAsText = response
.paths()
.stream()
.map(p -> "\t\n" + p.toString(transitData.stopNameResolver()))
.collect(Collectors.joining());
LOG.debug("Result: {}", pathsAsText);
}
return response;
}
/**
* TODO Add back the possibility to compare heuristics using a test - like the SpeedTest,
* but maybe better to make a separate test.
*/
@SuppressWarnings("unused")
public void compareHeuristics(
RaptorRequest<T> r1,
RaptorRequest<T> r2,
RaptorTransitDataProvider<T> transitData
) {
HeuristicSearchTask<T> fwdHeur = new HeuristicSearchTask<>(r1, config, transitData);
HeuristicSearchTask<T> revHeur = new HeuristicSearchTask<>(r2, config, transitData);
fwdHeur.forceRun();
revHeur.forceRun();
fwdHeur.debugCompareResult(revHeur);
}
/* private methods */
private RaptorResponse<T> routeUsingStdWorker(
RaptorTransitDataProvider<T> transitData,
RaptorRequest<T> request
) {
var worker = config.createStdWorker(transitData, request);
var result = worker.route();
var arrivals = new DefaultStopArrivals(result);
return new RaptorResponse<>(result.extractPaths(), arrivals, request, request);
}
}