def test_walk_duration(self): node_profile = NodeProfileMultiObjective(dep_times=[10, 5], walk_to_target_duration=27, label_class=LabelTime) self.assertEqual(27, node_profile.get_walk_to_target_duration()) pt2 = LabelTime(departure_time=10, arrival_time_target=35) pt1 = LabelTime(departure_time=5, arrival_time_target=35) node_profile.update([pt2]) node_profile.update([pt1])
def test_pareto_optimality2(self): node_profile = NodeProfileMultiObjective(dep_times=[5, 10], label_class=LabelTime) pt2 = LabelTime(departure_time=10, arrival_time_target=35, last_leg_is_walk=False) node_profile.update([pt2]) pt1 = LabelTime(departure_time=5, arrival_time_target=35, last_leg_is_walk=False) node_profile.update([pt1]) self.assertEquals(len(node_profile.get_labels_for_real_connections()), 1)
def test_evaluate(self): node_profile = NodeProfileMultiObjective(dep_times=[3, 1], label_class=LabelTime) node_profile.update([LabelTime(departure_time=3, arrival_time_target=4)]) self.assertEquals(4, min_arrival_time_target(node_profile.evaluate(3))) node_profile.update([LabelTime(departure_time=1, arrival_time_target=1)]) self.assertEquals(1, min_arrival_time_target(node_profile.evaluate(1)))
def test_pareto_optimality_with_transfers_and_time(self): node_profile = NodeProfileMultiObjective(dep_times=[5, 6, 7]) pt3 = LabelTimeWithBoardingsCount(departure_time=5, arrival_time_target=45, n_boardings=0, first_leg_is_walk=False) pt2 = LabelTimeWithBoardingsCount(departure_time=6, arrival_time_target=40, n_boardings=1, first_leg_is_walk=False) pt1 = LabelTimeWithBoardingsCount(departure_time=7, arrival_time_target=35, n_boardings=2, first_leg_is_walk=False) self.assertTrue(node_profile.update([pt1])) self.assertTrue(node_profile.update([pt2])) self.assertTrue(node_profile.update([pt3])) self.assertEqual(3, len(node_profile.get_labels_for_real_connections()))
def test_pareto_optimality_with_transfers_only(self): LabelClass = LabelVehLegCount node_profile = NodeProfileMultiObjective(dep_times=[5, 6, 7], label_class=LabelClass) pt3 = LabelClass(departure_time=5, n_vehicle_legs=0, last_leg_is_walk=False) pt2 = LabelClass(departure_time=6, n_vehicle_legs=1, last_leg_is_walk=False) pt1 = LabelClass(departure_time=7, n_vehicle_legs=2, last_leg_is_walk=False) self.assertTrue(node_profile.update([pt1])) self.assertTrue(node_profile.update([pt2])) self.assertTrue(node_profile.update([pt3])) node_profile.finalize() self.assertEqual(1, len(node_profile.get_final_optimal_labels()))
def test_dep_time_skipped_in_update(self): label3 = LabelTimeWithBoardingsCount(departure_time=30, arrival_time_target=20, n_boardings=0, first_leg_is_walk=False) label2 = LabelTimeWithBoardingsCount(departure_time=20, arrival_time_target=20, n_boardings=0, first_leg_is_walk=False) label1 = LabelTimeWithBoardingsCount(departure_time=10, arrival_time_target=20, n_boardings=0, first_leg_is_walk=False) # This should work ok node_profile = NodeProfileMultiObjective(label_class=LabelTimeWithBoardingsCount, dep_times=[10, 20, 30]) node_profile.update([label3]) node_profile.update([label2]) node_profile.update([label2]) node_profile.update([label1]) # This should fail due to dep time 20 missing in between with self.assertRaises(AssertionError): node_profile = NodeProfileMultiObjective(label_class=LabelTimeWithBoardingsCount, dep_times=[10, 20, 30]) node_profile.update([label3]) node_profile.update([label1]) # This should fail due to dep time 30 not being the first to deal with with self.assertRaises(AssertionError): node_profile = NodeProfileMultiObjective(label_class=LabelTimeWithBoardingsCount, dep_times=[10, 20, 30]) node_profile.update([label2])
def _get_analyzer(self, labels, start_time, end_time, walk_to_target_duration=float('inf')): dep_times = list(set(map(lambda el: el.departure_time, labels))) p = NodeProfileMultiObjective( dep_times=dep_times, walk_to_target_duration=walk_to_target_duration, label_class=LabelTimeWithBoardingsCount) for label in labels: p.update([label]) p.finalize() analyzer = NodeProfileAnalyzerTimeAndVehLegs.from_profile( p, start_time, end_time) return analyzer
def test_finalize(self): node_profile = NodeProfileMultiObjective(label_class=LabelTimeWithBoardingsCount, dep_times=[10]) own_label = LabelTimeWithBoardingsCount(departure_time=10, arrival_time_target=20, n_boardings=0, first_leg_is_walk=False) self.assertTrue(node_profile.update([own_label])) neighbor_label = LabelTimeWithBoardingsCount(departure_time=15, arrival_time_target=18, n_boardings=2, first_leg_is_walk=False) assert(len(node_profile.get_labels_for_real_connections()) == 1) node_profile.finalize([[neighbor_label]], [3]) assert (len(node_profile.get_final_optimal_labels()) == 2) self.assertTrue(any(map(lambda el: el.departure_time == 12, node_profile.get_final_optimal_labels())))
def test_identity_profile(self): identity_profile = NodeProfileMultiObjective(dep_times=[10]) identity_profile.update([LabelTimeWithBoardingsCount(10, 10, 0, True)]) self.assertEqual(10, min_arrival_time_target(identity_profile.evaluate(10, first_leg_can_be_walk=True)))
def plot_transfer_profile(): alphabetical_labels = list(labels_t_dep_dur_b) alphabetical_labels.sort(key=lambda el: el[-1]) for label in alphabetical_labels: print(label[-1] + " & " + str(label[0]) + " & " + str(label[0] + label[1]) + " & " + str(label[1]) + " & " + str(label[2]) + " \\\\") labels = [ LabelTimeWithBoardingsCount(departure_time=label[0], arrival_time_target=label[0] + label[1], n_boardings=label[2], first_leg_is_walk=False) for label in labels_t_dep_dur_b ] dep_times = list(set(map(lambda el: el.departure_time, labels))) p = NodeProfileMultiObjective(dep_times=dep_times, walk_to_target_duration=10, label_class=LabelTimeWithBoardingsCount) for label in labels: p.update([label]) p.finalize() analyzer = NodeProfileAnalyzerTimeAndVehLegs(p, 0, 20) print(analyzer.mean_n_boardings_on_shortest_paths()) journey_letters = [label[-1] for label in labels_t_dep_dur_b[::-1]] fig = plt.figure(figsize=(5.5, 3.5)) ax1 = plt.subplot(gs[:, :4]) fig = analyzer.plot_new_transfer_temporal_distance_profile( format_string="%S", duration_divider=1, default_lw=4, journey_letters=journey_letters, ax=ax1, ncol_legend=2, legend_font_size=9) ax1.set_xlabel("Departure time $t_{\\text{dep}}$ (min)") ax1.set_ylabel("Temporal distance $\\tau$ (min)") ax2 = plt.subplot(gs[:, 4:]) ax2 = analyzer.plot_temporal_distance_pdf_horizontal(use_minutes=True, duration_divider=1, ax=ax2, legend_font_size=9) ax2.set_ylabel("") ax1.set_ylim(0, 11.5) ax2.set_ylim(0, 11.5) ax2.set_xlim(0, 0.3) ax2.set_yticklabels(["" for _ in ax2.get_yticks()]) ax2.set_xlabel("Probability density $P(\\tau)$") ax2.set_xticks([0.1, 0.2, 0.3]) for _ax, letter in zip([ax1, ax2], "AB"): _ax.text(0.04, 0.98, "\\textbf{" + letter + "}", horizontalalignment="left", verticalalignment="top", transform=_ax.transAxes, fontsize=15, color="black") fig.savefig(settings.FIGS_DIRECTORY + "schematic_transfer_profile.pdf") plt.show()