-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathm3_perf_public.inter_poi_perf_hard.toronto_canada.cpp
243 lines (204 loc) · 24.9 KB
/
m3_perf_public.inter_poi_perf_hard.toronto_canada.cpp
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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
#include <random>
#include <unittest++/UnitTest++.h>
#include "StreetsDatabaseAPI.h"
#include "m1.h"
#include "m3.h"
#include "unit_test_util.h"
#include "path_verify.h"
using ece297test::relative_error;
using ece297test::path_is_legal;
SUITE(inter_inter_path_perf_hard_public) {
struct MapFixture {
MapFixture() {
rng = std::minstd_rand(4);
rand_intersection = std::uniform_int_distribution<unsigned>(0, getNumberOfIntersections()-1);
rand_street = std::uniform_int_distribution<unsigned>(1, getNumberOfStreets()-1);
rand_segment = std::uniform_int_distribution<unsigned>(0, getNumberOfStreetSegments()-1);
rand_poi = std::uniform_int_distribution<unsigned>(0, getNumberOfPointsOfInterest()-1);
rand_lat = std::uniform_real_distribution<double>(43.479999542, 43.919979095);
rand_lon = std::uniform_real_distribution<double>(-79.789978027, -79.000007629);
rand_turn_penalty = std::uniform_real_distribution<double>(0., 30.);
}
std::minstd_rand rng;
std::uniform_int_distribution<unsigned> rand_intersection;
std::uniform_int_distribution<unsigned> rand_street;
std::uniform_int_distribution<unsigned> rand_segment;
std::uniform_int_distribution<unsigned> rand_poi;
std::uniform_real_distribution<double> rand_lat;
std::uniform_real_distribution<double> rand_lon;
std::uniform_real_distribution<double> rand_turn_penalty;
};
TEST_FIXTURE(MapFixture, find_path_to_point_of_interest_perf_hard) {
//Verify Functionality
std::vector<unsigned> path;
std::vector<unsigned> valid_end_intersections;
double path_cost;
valid_end_intersections = {6735};
path = find_path_to_point_of_interest(12095, "East Liberty Medical Centre", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(12095, valid_end_intersections, path));
CHECK(path_cost <= 213.53910729428389459);
valid_end_intersections = {11985, 99962, 26840, 42518, 93467, 59314, 91928, 2259, 79863, 79755, 82549, 62037, 1272, 13884, 65372, 50288, 28905, 20005, 79308, 93863};
path = find_path_to_point_of_interest(13875, "HSBC", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(13875, valid_end_intersections, path));
CHECK(path_cost <= 399.64349954940001908);
valid_end_intersections = {71637};
path = find_path_to_point_of_interest(15493, "Fallingbrook Presbyterian Church", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(15493, valid_end_intersections, path));
CHECK(path_cost <= 892.49681788033069552);
valid_end_intersections = {12310, 97205, 94183, 7826, 45680, 61360, 4320, 28860, 81174, 6263, 9369, 81945, 12718, 18482, 71673, 2236, 6456, 16915, 99110, 23084, 25690, 32614, 32603, 38393, 81717, 39763, 10084, 94170, 81749, 45385, 57096, 43650, 89467, 59013, 60623, 107461, 82021, 23975, 35110, 69667, 78939, 87129, 97688, 4731, 35727, 93715, 67901, 35989, 36298, 79077, 37111, 61309, 41827, 52520, 9136, 68516, 41497, 3404, 71552, 429, 455, 92840, 52030, 57749, 67785, 82645, 96422, 50569, 92165, 72341, 66414, 98164, 51967, 107581, 60860, 60721, 20009, 12131, 21291, 53500, 86567, 86899, 24805, 71366, 69738, 71564, 10741, 79743, 73505, 75962, 74432, 106172, 26371, 82676, 27494, 69680, 49648, 54814, 18577, 105027, 75735, 87077, 98859, 39763, 92165, 70691, 38394, 86671, 69786, 74783, 20627, 54003, 86638, 92886, 75695, 60355, 60639, 79077, 79547, 86620, 69709, 67715, 73443, 60456, 107634, 60199, 78015, 96679, 90111, 2236, 94579, 106839, 77569};
path = find_path_to_point_of_interest(17541, "Esso", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(17541, valid_end_intersections, path));
CHECK(path_cost <= 105.42422607981161775);
valid_end_intersections = {12238, 6430, 7636, 61358, 104721, 5812, 100051, 47489, 15240, 44763, 18487, 29135, 71078, 28893, 19467, 88387, 60237, 26919, 61543, 32459, 30411, 83360, 8595, 28345, 56682, 59316, 58041, 89470, 57138, 7388, 26459, 29974, 86732, 44165, 17035, 35099, 71518, 78976, 14206, 54944, 78533, 62144, 61725, 74932, 43686, 58006, 57748, 14339, 60650, 37963, 52515, 70098, 97142, 89317, 105726, 8404, 77212, 66400, 59291, 30509, 82641, 33542, 81992, 82269, 20118, 50793, 89873, 100007, 23371, 28269, 107531, 98394, 54000, 54808, 55450, 51806, 1351, 55859, 90671, 92477, 1089, 55121, 95479, 69747, 53731, 87686, 54002, 56688, 76190, 70987, 55047, 77061, 63408, 59511, 60402, 64239, 75753, 77948, 77927, 92004, 60456, 87207, 24728, 61400, 322, 67438, 74302, 78617, 82751, 90682, 89317, 24864, 67871, 36512, 35246, 17338, 26347, 25516, 15594, 26609, 92879, 50506, 88706, 106895, 59185, 101114, 74779, 68628, 94397, 74578, 106127, 29414, 14484, 55712};
path = find_path_to_point_of_interest(21779, "Petro-Canada", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(21779, valid_end_intersections, path));
CHECK(path_cost <= 235.85110626748439699);
valid_end_intersections = {103729, 34416, 33473};
path = find_path_to_point_of_interest(23931, "Anytime Fitness", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(23931, valid_end_intersections, path));
CHECK(path_cost <= 700.83369401299955825);
valid_end_intersections = {6779, 5614, 3128, 80947, 28913, 56395, 26807, 93049, 71621, 98893, 94488, 104617, 95409, 62001, 11658, 3679, 70561, 104554, 70708, 78658, 76141, 79761, 105838, 94141, 69682, 11140, 92125, 70747, 79167, 56688, 27882, 16566, 30989, 36589, 4669, 84594, 104874, 55558, 95268, 75539, 58757, 97077, 32574, 97232, 1215, 71749, 1649, 96491, 50352};
path = find_path_to_point_of_interest(28786, "Pizza Nova", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(28786, valid_end_intersections, path));
CHECK(path_cost <= 304.93833557874387452);
valid_end_intersections = {106800};
path = find_path_to_point_of_interest(33321, "Humber Bay Dental Centre", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(33321, valid_end_intersections, path));
CHECK(path_cost <= 1523.86376346010706584);
valid_end_intersections = {61321, 45089};
path = find_path_to_point_of_interest(34501, "Retro Burger", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(34501, valid_end_intersections, path));
CHECK(path_cost <= 2073.13130370410772230);
valid_end_intersections = {241, 59292, 18797, 102703, 105955, 18480, 88403, 12790, 71555, 24961, 66412, 16774, 8586, 52498, 15040, 95457, 88451, 18402, 76168, 85695, 79879, 9937, 67837, 41902, 27093, 82738, 39706, 36957, 33435, 31340, 1651, 60527, 90216, 83793, 1587, 48861, 25585, 94618, 78585};
path = find_path_to_point_of_interest(34980, "Swiss Chalet", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(34980, valid_end_intersections, path));
CHECK(path_cost <= 280.72011978660594878);
valid_end_intersections = {96284, 3703, 30577, 39596, 26678, 28345, 19205, 35799, 92835, 21033, 41849, 74357, 59509, 86899, 79860, 30436, 100046, 28419, 103127, 94556, 69943, 52172, 75758, 28740, 74655, 60458, 108040, 60671, 80162, 56135, 77801};
path = find_path_to_point_of_interest(23235, "Husky", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(23235, valid_end_intersections, path));
CHECK(path_cost <= 221.54956930711392715);
valid_end_intersections = {1826};
path = find_path_to_point_of_interest(54259, "First Portugese Evangelical Church", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(54259, valid_end_intersections, path));
CHECK(path_cost <= 1573.60742924799524189);
valid_end_intersections = {4111, 4015, 1401, 6304, 9511, 6718, 4137, 512, 2355, 70790, 2290, 15786, 1855, 759, 12544, 7765, 2543, 1014, 1868, 3468, 89255, 28892, 88345, 1118, 1656, 28591, 23132, 23220, 3701, 11016, 16749, 5176, 4183, 19143, 68577, 74994, 107653, 20244, 71793, 107821, 35792, 87129, 105429, 14691, 82479, 45670, 28896, 87695, 94740, 89171, 1896, 1744, 53720, 11454, 101715, 80730, 101976, 100230, 105568, 16941, 62042, 97497, 1078, 78903, 3172, 551, 70063, 70573, 70701, 70707, 89487, 11649, 8876, 98946, 4669, 69736, 16222, 28929, 52382, 9799, 28633, 2318, 20676, 2324, 4218, 91116, 2264, 86069, 45659, 80971, 30545, 101900, 1418, 15585, 94150, 79798, 5205, 89310, 12747, 85963, 98897, 41885, 71708, 34358, 87031, 2634, 20185, 12410, 100647, 79525, 14608, 1043, 99707, 33347, 1423, 96496, 33061, 71967, 38660, 100551, 94697, 95439, 79402, 75710, 61521, 34494, 34781, 99049, 64251, 85319, 21227, 11645, 85051, 106042, 19856, 2260, 3411, 15792, 34613, 19322, 44112, 3705, 86275, 71979, 99120, 6856, 20193, 30407, 2270, 2294, 5833, 73484, 104560, 20083, 18532, 369, 5852, 32615, 100120, 60407, 30537, 63236, 45673, 55062, 4321, 18888, 107893, 9313, 80267};
path = find_path_to_point_of_interest(60182, "Starbucks Coffee", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(60182, valid_end_intersections, path));
CHECK(path_cost <= 304.12357693917095958);
valid_end_intersections = {25731, 1949};
path = find_path_to_point_of_interest(69324, "Scotia Bank", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(69324, valid_end_intersections, path));
CHECK(path_cost <= 1525.75420602323129060);
valid_end_intersections = {5204, 45670, 5185, 82551, 1487, 1833, 12572, 11031, 513, 6997, 63067, 97836, 4182, 727, 16674, 81174, 2259, 45089, 3340, 2292, 9236, 70897, 95463, 18670, 99114, 93480, 1078, 23113, 59300, 20194, 10869, 11016, 24460, 10077, 99992, 2955, 7359, 57768, 23035, 57420, 2142, 4320, 14601, 45640, 107820, 57809, 4756, 62134, 61721, 25555, 21033, 21437, 1219, 69668, 54322, 35151, 56405, 15076, 19848, 41888, 82161, 45499, 88579, 44755, 36643, 57025, 11621, 35124, 2277, 13491, 103732, 78869, 98642, 50657, 4297, 13280, 103325, 20697, 7374, 90859, 70714, 85313, 70080, 30545, 13547, 91, 89185, 16270, 101013, 86929, 11652, 71366, 55837, 51470, 62041, 98166, 67837, 1014, 72647, 72722, 13509, 78657, 90530, 20573, 31198, 75072, 2616, 61318, 78708, 79851, 12380, 31088, 39914, 100978, 59011, 41993, 83226, 20638, 58307, 44748, 108439, 94713, 71708, 41888, 49570, 28929, 10705, 14875, 15327, 96378, 102316, 26561, 31353, 31436, 90149, 86671, 92235, 90611, 105177, 33433, 34329, 16982, 105008, 105754, 10654, 73025, 76161, 89164, 41888, 91364, 22203, 64251, 97329, 96696, 21220, 97512, 5454, 13479, 106280, 35327, 3339, 19847, 24385, 45095, 34069, 86359, 91838, 53707, 36467, 79328, 2569, 91665, 7830, 52498, 6652, 32341, 106756, 63321, 49388, 101345, 93394, 103775, 103980, 18532, 49629, 93660};
path = find_path_to_point_of_interest(44253, "TD Canada Trust", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(44253, valid_end_intersections, path));
CHECK(path_cost <= 162.21214997761853738);
valid_end_intersections = {34736, 6514};
path = find_path_to_point_of_interest(70629, "The Pita Pit", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(70629, valid_end_intersections, path));
CHECK(path_cost <= 1595.24768339195497902);
valid_end_intersections = {102025, 6339, 1606, 12751, 2376, 2324, 2290, 20025, 69682, 14820, 29104, 86232, 7765, 16975, 1014, 9244, 21369, 103429, 24460, 16462, 85315, 29210, 2954, 98707, 101446, 99962, 31614, 57675, 17010, 92414, 12581, 71793, 49815, 77452, 91245, 92502, 61261, 49579, 22702, 33213, 35826, 61521, 42735, 36000, 59406, 103939, 35151, 54004, 19844, 29581, 16757, 33014, 70058, 41887, 1451, 44754, 24760, 31089, 31857, 106573, 101979, 107521, 68572, 4309, 103323, 103248, 98622, 62004, 23686, 7225, 60370, 90042, 92175, 61318, 6724, 20730, 98946, 11442, 107221, 62041, 12338, 79040, 71545, 70909, 68931, 72646, 41218, 75682, 76109, 90534, 56109, 73344, 75072, 81689, 50236, 100978, 101900, 70747, 8233, 2272, 74435, 24813, 82898, 83204, 96009, 67794, 1387, 6056, 2242, 23123, 10854, 87690, 90, 66053, 66552, 36589, 81814, 90600, 57025, 33577, 32573, 24733, 3803, 98153, 99122, 105007, 725, 84727, 75746, 34810, 90766, 22148, 22525, 36643, 55855, 21221, 99329, 71569, 63993, 21715, 61723, 4650, 25731, 45402, 56308, 87078, 78708, 41490, 68958, 102029, 61137, 6668, 104741, 59974, 63316, 93394, 27002, 80410, 13495, 59482, 103983, 35794, 105725};
path = find_path_to_point_of_interest(24753, "Shoppers Drug Mart", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(24753, valid_end_intersections, path));
CHECK(path_cost <= 123.55147836641206993);
valid_end_intersections = {32606, 27273, 32558, 50517, 94879, 42332, 86670, 27273, 69215, 26564, 70693, 36961, 36963, 86670, 40911, 89535, 94349, 86833, 73524, 88124};
path = find_path_to_point_of_interest(77557, "Petro Canada", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(77557, valid_end_intersections, path));
CHECK(path_cost <= 568.97122676156141097);
valid_end_intersections = {80263, 2125, 41447, 1316, 9964, 11321, 2387, 11876, 3229, 103058, 70936, 11985, 3944, 16762, 45680, 14601, 74426, 4310, 18627, 97181, 103430, 10854, 5176, 4183, 99992, 7849, 52792, 57675, 2142, 33052, 33061, 3510, 81988, 54325, 31979, 61275, 26800, 61721, 108067, 35994, 91835, 36637, 16674, 72383, 14121, 89171, 44639, 58442, 5403, 24656, 16771, 18157, 98617, 51225, 55854, 88675, 93931, 70066, 5812, 92171, 6339, 14229, 55444, 5703, 36300, 98946, 71394, 6104, 71967, 28591, 68889, 2309, 41178, 75677, 72066, 105467, 73513, 8172, 38952, 82897, 58757, 54746, 70336, 92396, 1080, 58307, 6514, 10006, 31104, 67229, 28492, 26563, 74230, 1702, 24818, 24732, 105755, 95439, 76109, 89164, 11621, 10351, 26378, 8502, 22430, 35286, 19837, 80609, 58778, 104991, 11809, 19422, 56273, 73523, 91457, 94618, 101407, 63320, 101339, 82702, 5597, 5570};
path = find_path_to_point_of_interest(79051, "Pizza Pizza", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(79051, valid_end_intersections, path));
CHECK(path_cost <= 123.29037825827850838);
valid_end_intersections = {12238, 6430, 7636, 61358, 104721, 5812, 100051, 47489, 15240, 44763, 18487, 29135, 71078, 28893, 19467, 88387, 60237, 26919, 61543, 32459, 30411, 83360, 8595, 28345, 56682, 59316, 58041, 89470, 57138, 7388, 26459, 29974, 86732, 44165, 17035, 35099, 71518, 78976, 14206, 54944, 78533, 62144, 61725, 74932, 43686, 58006, 57748, 14339, 60650, 37963, 52515, 70098, 97142, 89317, 105726, 8404, 77212, 66400, 59291, 30509, 82641, 33542, 81992, 82269, 20118, 50793, 89873, 100007, 23371, 28269, 107531, 98394, 54000, 54808, 55450, 51806, 1351, 55859, 90671, 92477, 1089, 55121, 95479, 69747, 53731, 87686, 54002, 56688, 76190, 70987, 55047, 77061, 63408, 59511, 60402, 64239, 75753, 77948, 77927, 92004, 60456, 87207, 24728, 61400, 322, 67438, 74302, 78617, 82751, 90682, 89317, 24864, 67871, 36512, 35246, 17338, 26347, 25516, 15594, 26609, 92879, 50506, 88706, 106895, 59185, 101114, 74779, 68628, 94397, 74578, 106127, 29414, 14484, 55712};
path = find_path_to_point_of_interest(79996, "Petro-Canada", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(79996, valid_end_intersections, path));
CHECK(path_cost <= 150.72440564230817017);
valid_end_intersections = {8618};
path = find_path_to_point_of_interest(83122, "University Eye Clinic", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(83122, valid_end_intersections, path));
CHECK(path_cost <= 1559.15471449399728954);
valid_end_intersections = {3128, 1127, 87701, 1130, 9511, 7276, 7245, 8227, 91425, 16773, 16695, 20024, 20228, 1750, 16570, 71078, 8374, 88345, 1118, 97185, 103427, 18672, 59292, 99983, 24740, 18487, 98904, 41909, 9163, 28915, 57095, 80708, 88674, 107653, 61242, 61372, 3305, 105178, 105429, 77832, 43589, 36000, 36298, 54326, 61296, 97143, 104617, 16757, 2600, 44754, 28907, 19182, 5510, 1671, 60902, 70584, 26925, 68574, 4308, 82642, 29789, 44161, 7854, 91776, 86833, 61226, 71731, 54006, 90874, 18970, 1078, 23758, 108379, 3679, 64275, 4461, 88344, 70573, 1744, 20826, 14901, 12572, 14675, 333, 5702, 44066, 71262, 98900, 4318, 24452, 99720, 71027, 57995, 5812, 13135, 749, 61308, 71869, 54499, 70708, 2246, 1862, 6753, 2294, 30964, 44035, 52383, 69685, 9799, 8172, 98946, 56866, 86200, 41916, 94133, 34255, 20233, 79798, 54863, 1884, 85971, 73908, 62074, 9400, 61321, 79167, 546, 5206, 16758, 6047, 96169, 60475, 41905, 10006, 41812, 34379, 82546, 24525, 75745, 8874, 94645, 3955, 11491, 67223, 96378, 96917, 6759, 29104, 1381, 25473, 17227, 72214, 31343, 26706, 87691, 24556, 58705, 38400, 104991, 44800, 23035, 1419, 92486, 75763, 22074, 99065, 22524, 97232, 22525, 28508, 66430, 98637, 22226, 64250, 85319, 41834, 39079, 97503, 58757, 70909, 29507, 104447, 22151, 67695, 40479, 50517, 30374, 58785, 59718, 107465, 45250, 7711, 71564, 91365, 84589, 2634, 96346, 80538, 4631, 89207, 99358, 97595, 11422, 104877, 28913, 46545, 96491, 14761, 56420, 104752, 60402, 36288, 7512, 11035, 6866, 33311, 89158, 3293, 88146, 1252, 85234, 93076, 93394, 63216, 101341, 28634, 105187, 35880, 97857, 35792, 61872};
path = find_path_to_point_of_interest(87201, "Subway", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(87201, valid_end_intersections, path));
CHECK(path_cost <= 135.75954054922632963);
valid_end_intersections = {6407};
path = find_path_to_point_of_interest(90371, "Our Lady Of Sorrows", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(90371, valid_end_intersections, path));
CHECK(path_cost <= 1534.13883221136893553);
valid_end_intersections = {105444, 12425, 14609, 18768, 5184, 2290, 41909, 1745, 58152, 87075, 4712, 15309, 16690, 12788, 33025, 7766, 2277, 36641, 21369, 1666, 2125, 23135, 3394, 15228, 20195, 1113, 1080, 71671, 101438, 33279, 72235, 102554, 54322, 95335, 31988, 26814, 96942, 101800, 74932, 43196, 8192, 36298, 23842, 8874, 96170, 41904, 28591, 28896, 9799, 1272, 2600, 21238, 59297, 6779, 45677, 92099, 68036, 81392, 105975, 106581, 1870, 95400, 96689, 54015, 44157, 60874, 72563, 61229, 20009, 84777, 79040, 102490, 90879, 6152, 47606, 53501, 1949, 60378, 2243, 6867, 5510, 11261, 16263, 90758, 70075, 44349, 20232, 1792, 5176, 71114, 98946, 1422, 51282, 35154, 13097, 14985, 97865, 5198, 1131, 3984, 41268, 76172, 75682, 2272, 4017, 75739, 31198, 32076, 95943, 1744, 77284, 23975, 28331, 82477, 105838, 106166, 2270, 50317, 33060, 74417, 90256, 104623, 30926, 82001, 58307, 61331, 99545, 5814, 96062, 10562, 96525, 6056, 45674, 79798, 4016, 70806, 11348, 67447, 78734, 78718, 69926, 82046, 25311, 26564, 10496, 90120, 40907, 42219, 96908, 55962, 25923, 71477, 33281, 44748, 24805, 70646, 108023, 33024, 58772, 81880, 84593, 60721, 58790, 18982, 94170, 63869, 95305, 23034, 22959, 96293, 35061, 35582, 22612, 39503, 26474, 7801, 9714, 89550, 34721, 67695, 86620, 97329, 16770, 79726, 50621, 50542, 41887, 83219, 106040, 99329, 15793, 5458, 98781, 22107, 99294, 100639, 101455, 36512, 42192, 69946, 19145, 1897, 7743, 92199, 25414, 1047, 4631, 79345, 45499, 82021, 6514, 23412, 100133, 1744, 1059, 53719, 100647, 4303, 74077, 79885, 1353, 107455, 56415, 5093, 22698, 35110, 97748, 79631, 727, 6668, 45124, 59967, 82274, 107639, 99904, 73443, 107650, 27011, 13495, 52477, 82678, 13027, 93607, 29584};
path = find_path_to_point_of_interest(19701, "Tim Hortons", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(19701, valid_end_intersections, path));
CHECK(path_cost <= 99.53092586383000651);
valid_end_intersections = {33013, 41902};
path = find_path_to_point_of_interest(98444, "Il Fornello", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(98444, valid_end_intersections, path));
CHECK(path_cost <= 1430.88569160213000941);
valid_end_intersections = {2261, 52383, 82104, 62042, 24453, 41887, 1896, 101460};
path = find_path_to_point_of_interest(99743, "La Prep", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(99743, valid_end_intersections, path));
CHECK(path_cost <= 1206.02053219765161884);
valid_end_intersections = {5204, 45670, 5185, 82551, 1487, 1833, 12572, 11031, 513, 6997, 63067, 97836, 4182, 727, 16674, 81174, 2259, 45089, 3340, 2292, 9236, 70897, 95463, 18670, 99114, 93480, 1078, 23113, 59300, 20194, 10869, 11016, 24460, 10077, 99992, 2955, 7359, 57768, 23035, 57420, 2142, 4320, 14601, 45640, 107820, 57809, 4756, 62134, 61721, 25555, 21033, 21437, 1219, 69668, 54322, 35151, 56405, 15076, 19848, 41888, 82161, 45499, 88579, 44755, 36643, 57025, 11621, 35124, 2277, 13491, 103732, 78869, 98642, 50657, 4297, 13280, 103325, 20697, 7374, 90859, 70714, 85313, 70080, 30545, 13547, 91, 89185, 16270, 101013, 86929, 11652, 71366, 55837, 51470, 62041, 98166, 67837, 1014, 72647, 72722, 13509, 78657, 90530, 20573, 31198, 75072, 2616, 61318, 78708, 79851, 12380, 31088, 39914, 100978, 59011, 41993, 83226, 20638, 58307, 44748, 108439, 94713, 71708, 41888, 49570, 28929, 10705, 14875, 15327, 96378, 102316, 26561, 31353, 31436, 90149, 86671, 92235, 90611, 105177, 33433, 34329, 16982, 105008, 105754, 10654, 73025, 76161, 89164, 41888, 91364, 22203, 64251, 97329, 96696, 21220, 97512, 5454, 13479, 106280, 35327, 3339, 19847, 24385, 45095, 34069, 86359, 91838, 53707, 36467, 79328, 2569, 91665, 7830, 52498, 6652, 32341, 106756, 63321, 49388, 101345, 93394, 103775, 103980, 18532, 49629, 93660};
path = find_path_to_point_of_interest(101774, "TD Canada Trust", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(101774, valid_end_intersections, path));
CHECK(path_cost <= 304.78515787532842296);
valid_end_intersections = {17854};
path = find_path_to_point_of_interest(103377, "4x", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(103377, valid_end_intersections, path));
CHECK(path_cost <= 1360.27007795982558491);
valid_end_intersections = {82889};
path = find_path_to_point_of_interest(24878, "Britannia Pharmacy", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(24878, valid_end_intersections, path));
CHECK(path_cost <= 1295.66138827049030624);
valid_end_intersections = {16758, 106316, 78734, 97507, 25725, 77614};
path = find_path_to_point_of_interest(11642, "Teriyaki Experience", 15.00000000000000000);
path_cost = compute_path_travel_time(path, 15.00000000000000000);
CHECK(path_is_legal(11642, valid_end_intersections, path));
CHECK(path_cost <= 665.49052017018846072);
//Generate random inputs
std::vector<unsigned> intersection_ids;
std::vector<std::string> poi_names;
std::vector<double> turn_penalties;
for(size_t i = 0; i < 200; i++) {
intersection_ids.push_back(rand_intersection(rng));
poi_names.push_back(getPointOfInterestName(rand_poi(rng)));
turn_penalties.push_back(rand_turn_penalty(rng));
}
{
//Timed Test
ECE297_TIME_CONSTRAINT(19632);
std::vector<unsigned> result;
for(size_t i = 0; i < 200; i++) {
result = find_path_to_point_of_interest(intersection_ids[i], poi_names[i], turn_penalties[i]);
}
}
} //find_path_to_point_of_interest_perf_hard
} //inter_inter_path_perf_hard_public