Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 30 additions & 0 deletions include/nigiri/routing/search.h
Original file line number Diff line number Diff line change
Expand Up @@ -52,13 +52,19 @@ struct search_stats {
{"fastest_direct", fastest_direct_},
{"interval_extensions", interval_extensions_},
{"execute_time", execute_time_.count()},
{"n_events_skipped_by_early_termination",
n_events_skipped_by_early_termination_},
{"search_interval_reduction_by_early_termination",
search_interval_reduction_by_early_termination_.count()},
};
}

std::uint64_t lb_time_{0ULL};
std::uint64_t fastest_direct_{0ULL};
std::uint64_t interval_extensions_{0ULL};
std::chrono::milliseconds execute_time_{0LL};
std::uint64_t n_events_skipped_by_early_termination_{0ULL};
std::chrono::minutes search_interval_reduction_by_early_termination_{0LL};
};

struct routing_result {
Expand Down Expand Up @@ -430,12 +436,19 @@ struct search {
auto span = get_otel_tracer()->StartSpan("search::search_interval");
auto scope = opentelemetry::trace::Scope{span};

auto early_termination = false;
utl::equal_ranges_linear(
state_.starts_,
[](start const& a, start const& b) {
return a.time_at_start_ == b.time_at_start_;
},
[&](auto&& from_it, auto&& to_it) {
if (early_termination) {
stats_.n_events_skipped_by_early_termination_ +=
it_range{from_it, to_it}.size();
return;
}

algo_.next_start_time();
auto const start_time = from_it->time_at_start_;
for (auto const& s : it_range{from_it, to_it}) {
Expand Down Expand Up @@ -475,6 +488,23 @@ struct search {
}
}
}

if (q_.min_connection_count_ > 0 &&
n_results_in_interval() >= q_.min_connection_count_ &&
((kFwd && q_.extend_interval_earlier_ &&
!q_.extend_interval_later_) ||
(kBwd && !q_.extend_interval_earlier_ &&
q_.extend_interval_later_))) {
early_termination = true;
auto const start_size = search_interval_.size();
if constexpr (kFwd) {
search_interval_.from_ = start_time;
} else {
search_interval_.to_ = start_time + duration_t{1};
}
stats_.search_interval_reduction_by_early_termination_ =
std::chrono::abs(start_size - search_interval_.size());
}
});
}

Expand Down
Loading