Move leg search to routing base
This commit is contained in:
		
							parent
							
								
									9005fe2f61
								
							
						
					
					
						commit
						4206d98b55
					
				| @ -64,143 +64,39 @@ class DirectShortestPathRouting final | |||||||
|     { |     { | ||||||
|         (void)uturn_indicators; // unused
 |         (void)uturn_indicators; // unused
 | ||||||
| 
 | 
 | ||||||
|         engine_working_data.InitializeOrClearFirstThreadLocalStorage( |  | ||||||
|             super::facade->GetNumberOfNodes()); |  | ||||||
|         engine_working_data.InitializeOrClearSecondThreadLocalStorage( |  | ||||||
|             super::facade->GetNumberOfNodes()); |  | ||||||
| 
 |  | ||||||
|         QueryHeap &forward_heap = *(engine_working_data.forward_heap_1); |  | ||||||
|         QueryHeap &reverse_heap = *(engine_working_data.reverse_heap_1); |  | ||||||
| 
 |  | ||||||
|         QueryHeap &forward_core_heap = *(engine_working_data.forward_heap_2); |  | ||||||
|         QueryHeap &reverse_core_heap = *(engine_working_data.reverse_heap_2); |  | ||||||
| 
 |  | ||||||
|         // Get distance to next pair of target nodes.
 |         // Get distance to next pair of target nodes.
 | ||||||
|         BOOST_ASSERT_MSG(1 == phantom_nodes_vector.size(), |         BOOST_ASSERT_MSG(1 == phantom_nodes_vector.size(), | ||||||
|                                          "Direct Shortest Path Query only accepts a single source and target pair. Multiple ones have been specified."); |                                          "Direct Shortest Path Query only accepts a single source and target pair. Multiple ones have been specified."); | ||||||
| 
 |  | ||||||
|         const auto& phantom_node_pair = phantom_nodes_vector.front(); |         const auto& phantom_node_pair = phantom_nodes_vector.front(); | ||||||
| 
 | 
 | ||||||
|  |         engine_working_data.InitializeOrClearFirstThreadLocalStorage( | ||||||
|  |             super::facade->GetNumberOfNodes()); | ||||||
|  |         QueryHeap &forward_heap = *(engine_working_data.forward_heap_1); | ||||||
|  |         QueryHeap &reverse_heap = *(engine_working_data.reverse_heap_1); | ||||||
|         forward_heap.Clear(); |         forward_heap.Clear(); | ||||||
|         reverse_heap.Clear(); |         reverse_heap.Clear(); | ||||||
|         int distance = INVALID_EDGE_WEIGHT; |  | ||||||
|         NodeID middle = SPECIAL_NODEID; |  | ||||||
| 
 | 
 | ||||||
|         const EdgeWeight min_edge_offset = |         int distance; | ||||||
|             std::min(-phantom_node_pair.source_phantom.GetForwardWeightPlusOffset(), |         std::vector<NodeID> packed_leg; | ||||||
|                      -phantom_node_pair.source_phantom.GetReverseWeightPlusOffset()); |  | ||||||
| 
 | 
 | ||||||
|         // insert new starting nodes into forward heap, adjusted by previous distances.
 |         if (super::facade->GetCoreSize() > 0) | ||||||
|         if (phantom_node_pair.source_phantom.forward_node_id != SPECIAL_NODEID) |  | ||||||
|         { |         { | ||||||
|             forward_heap.Insert( |             engine_working_data.InitializeOrClearSecondThreadLocalStorage( | ||||||
|                 phantom_node_pair.source_phantom.forward_node_id, |                 super::facade->GetNumberOfNodes()); | ||||||
|                 -phantom_node_pair.source_phantom.GetForwardWeightPlusOffset(), |             QueryHeap &forward_core_heap = *(engine_working_data.forward_heap_2); | ||||||
|                 phantom_node_pair.source_phantom.forward_node_id); |             QueryHeap &reverse_core_heap = *(engine_working_data.reverse_heap_2); | ||||||
|  |             forward_core_heap.Clear(); | ||||||
|  |             reverse_core_heap.Clear(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |             super::SearchWithCore(forward_heap, reverse_heap, forward_core_heap, reverse_core_heap, | ||||||
|  |                                   phantom_node_pair.source_phantom, phantom_node_pair.target_phantom, | ||||||
|  |                                   distance, packed_leg); | ||||||
|         } |         } | ||||||
|         if ( phantom_node_pair.source_phantom.reverse_node_id != SPECIAL_NODEID) |         else | ||||||
|         { |         { | ||||||
|             forward_heap.Insert( |             super::Search(forward_heap, reverse_heap, phantom_node_pair.source_phantom, | ||||||
|                 phantom_node_pair.source_phantom.reverse_node_id, |                           phantom_node_pair.target_phantom, distance, packed_leg); | ||||||
|                 -phantom_node_pair.source_phantom.GetReverseWeightPlusOffset(), |  | ||||||
|                 phantom_node_pair.source_phantom.reverse_node_id); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // insert new backward nodes into backward heap, unadjusted.
 |  | ||||||
|         if (phantom_node_pair.target_phantom.forward_node_id != SPECIAL_NODEID) |  | ||||||
|         { |  | ||||||
|             reverse_heap.Insert(phantom_node_pair.target_phantom.forward_node_id, |  | ||||||
|                                  phantom_node_pair.target_phantom.GetForwardWeightPlusOffset(), |  | ||||||
|                                  phantom_node_pair.target_phantom.forward_node_id); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         if (phantom_node_pair.target_phantom.reverse_node_id != SPECIAL_NODEID) |  | ||||||
|         { |  | ||||||
|             reverse_heap.Insert(phantom_node_pair.target_phantom.reverse_node_id, |  | ||||||
|                                  phantom_node_pair.target_phantom.GetReverseWeightPlusOffset(), |  | ||||||
|                                  phantom_node_pair.target_phantom.reverse_node_id); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         std::vector<std::pair<NodeID, EdgeWeight>> forward_entry_points; |  | ||||||
|         std::vector<std::pair<NodeID, EdgeWeight>> reverse_entry_points; |  | ||||||
| 
 |  | ||||||
|         // run two-Target Dijkstra routing step.
 |  | ||||||
|         while (0 < (forward_heap.Size() + reverse_heap.Size()) ) |  | ||||||
|         { |  | ||||||
|             if (!forward_heap.Empty()) |  | ||||||
|             { |  | ||||||
|                 if (super::facade->IsCoreNode(forward_heap.Min())) |  | ||||||
|                 { |  | ||||||
|                     const NodeID node = forward_heap.DeleteMin(); |  | ||||||
|                     const int key = forward_heap.GetKey(node); |  | ||||||
|                     forward_entry_points.emplace_back(node, key); |  | ||||||
|                 } |  | ||||||
|                 else |  | ||||||
|                 { |  | ||||||
|                     super::RoutingStep(forward_heap, reverse_heap, &middle, &distance, |  | ||||||
|                                        min_edge_offset, true); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             if (!reverse_heap.Empty()) |  | ||||||
|             { |  | ||||||
|                 if (super::facade->IsCoreNode(reverse_heap.Min())) |  | ||||||
|                 { |  | ||||||
|                     const NodeID node = reverse_heap.DeleteMin(); |  | ||||||
|                     const int key = reverse_heap.GetKey(node); |  | ||||||
|                     reverse_entry_points.emplace_back(node, key); |  | ||||||
|                 } |  | ||||||
|                 else |  | ||||||
|                 { |  | ||||||
|                     super::RoutingStep(reverse_heap, forward_heap, &middle, &distance, |  | ||||||
|                                        min_edge_offset, false); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // TODO check if unordered_set might be faster
 |  | ||||||
|         // sort by id and increasing by distance
 |  | ||||||
|         auto entry_point_comparator = [](const std::pair<NodeID, EdgeWeight>& lhs, const std::pair<NodeID, EdgeWeight>& rhs) |  | ||||||
|             { |  | ||||||
|                 return lhs.first < rhs.first || (lhs.first == rhs.first && lhs.second < rhs.second); |  | ||||||
|             }; |  | ||||||
|         std::sort(forward_entry_points.begin(), forward_entry_points.end(), entry_point_comparator); |  | ||||||
|         std::sort(reverse_entry_points.begin(), reverse_entry_points.end(), entry_point_comparator); |  | ||||||
| 
 |  | ||||||
|         NodeID last_id = SPECIAL_NODEID; |  | ||||||
|         for (const auto p : forward_entry_points) |  | ||||||
|         { |  | ||||||
|             if (p.first == last_id) |  | ||||||
|             { |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             forward_core_heap.Insert(p.first, p.second, p.first); |  | ||||||
|             last_id = p.first; |  | ||||||
|         } |  | ||||||
|         last_id = SPECIAL_NODEID; |  | ||||||
|         for (const auto p : reverse_entry_points) |  | ||||||
|         { |  | ||||||
|             if (p.first == last_id) |  | ||||||
|             { |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             reverse_core_heap.Insert(p.first, p.second, p.first); |  | ||||||
|             last_id = p.first; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // run two-target Dijkstra routing step on core with termination criterion
 |  | ||||||
|         while (0 < (forward_core_heap.Size() + reverse_core_heap.Size()) && |  | ||||||
|                distance > (forward_core_heap.MinKey() + reverse_core_heap.MinKey())) |  | ||||||
|         { |  | ||||||
|             if (!forward_core_heap.Empty()) |  | ||||||
|             { |  | ||||||
|                 super::RoutingStep(forward_core_heap, reverse_core_heap, &middle, &distance, |  | ||||||
|                                    min_edge_offset, true, false); |  | ||||||
|             } |  | ||||||
|             if (!reverse_core_heap.Empty()) |  | ||||||
|             { |  | ||||||
|                 super::RoutingStep(reverse_core_heap, forward_core_heap, &middle, &distance, |  | ||||||
|                                    min_edge_offset, false, false); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // No path found for both target nodes?
 |         // No path found for both target nodes?
 | ||||||
| @ -211,30 +107,9 @@ class DirectShortestPathRouting final | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // Was a paths over one of the forward/reverse nodes not found?
 |  | ||||||
|         BOOST_ASSERT_MSG((SPECIAL_NODEID == middle || INVALID_EDGE_WEIGHT != distance), |  | ||||||
|                          "no path found"); |  | ||||||
| 
 |  | ||||||
|         std::vector<NodeID> packed_leg; |  | ||||||
|         // we need to unpack sub path from core heaps
 |  | ||||||
|         if(super::facade->IsCoreNode(middle)) |  | ||||||
|         { |  | ||||||
|             std::vector<NodeID> packed_core_leg; |  | ||||||
|             super::RetrievePackedPathFromHeap(forward_core_heap, reverse_core_heap, middle, packed_core_leg); |  | ||||||
|             BOOST_ASSERT(packed_core_leg.size() > 0); |  | ||||||
|             super::RetrievePackedPathFromSingleHeap(forward_heap, packed_core_leg.front(), packed_leg); |  | ||||||
|             std::reverse(packed_leg.begin(), packed_leg.end()); |  | ||||||
|             packed_leg.insert(packed_leg.end(), packed_core_leg.begin(), packed_core_leg.end()); |  | ||||||
|             super::RetrievePackedPathFromSingleHeap(reverse_heap, packed_core_leg.back(), packed_leg); |  | ||||||
|         } |  | ||||||
|         else |  | ||||||
|         { |  | ||||||
|             super::RetrievePackedPathFromHeap(forward_heap, reverse_heap, middle, packed_leg); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|         BOOST_ASSERT_MSG(!packed_leg.empty(), "packed path empty"); |         BOOST_ASSERT_MSG(!packed_leg.empty(), "packed path empty"); | ||||||
| 
 | 
 | ||||||
|  |         raw_route_data.shortest_path_length = distance; | ||||||
|         raw_route_data.unpacked_path_segments.resize(1); |         raw_route_data.unpacked_path_segments.resize(1); | ||||||
|         raw_route_data.source_traversed_in_reverse.push_back( |         raw_route_data.source_traversed_in_reverse.push_back( | ||||||
|             (packed_leg.front() != phantom_node_pair.source_phantom.forward_node_id)); |             (packed_leg.front() != phantom_node_pair.source_phantom.forward_node_id)); | ||||||
| @ -243,7 +118,6 @@ class DirectShortestPathRouting final | |||||||
| 
 | 
 | ||||||
|         super::UnpackPath(packed_leg, phantom_node_pair, raw_route_data.unpacked_path_segments.front()); |         super::UnpackPath(packed_leg, phantom_node_pair, raw_route_data.unpacked_path_segments.front()); | ||||||
| 
 | 
 | ||||||
|         raw_route_data.shortest_path_length = distance; |  | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -416,6 +416,234 @@ template <class DataFacadeT, class Derived> class BasicRoutingInterface | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     // assumes that heaps are already setup correctly.
 | ||||||
|  |     void Search(SearchEngineData::QueryHeap &forward_heap, | ||||||
|  |                 SearchEngineData::QueryHeap &reverse_heap, | ||||||
|  |                 const PhantomNode &source_phantom, | ||||||
|  |                 const PhantomNode &target_phantom, | ||||||
|  |                 int &distance, | ||||||
|  |                 std::vector<NodeID> &packed_leg) const | ||||||
|  |     { | ||||||
|  |         NodeID middle = SPECIAL_NODEID; | ||||||
|  | 
 | ||||||
|  |         const EdgeWeight min_edge_offset = std::min(-source_phantom.GetForwardWeightPlusOffset(), | ||||||
|  |                                                     -source_phantom.GetReverseWeightPlusOffset()); | ||||||
|  | 
 | ||||||
|  |         // insert new starting nodes into forward heap, adjusted by previous distances.
 | ||||||
|  |         if (source_phantom.forward_node_id != SPECIAL_NODEID) | ||||||
|  |         { | ||||||
|  |             forward_heap.Insert(source_phantom.forward_node_id, | ||||||
|  |                                 -source_phantom.GetForwardWeightPlusOffset(), | ||||||
|  |                                 source_phantom.forward_node_id); | ||||||
|  |         } | ||||||
|  |         if (source_phantom.reverse_node_id != SPECIAL_NODEID) | ||||||
|  |         { | ||||||
|  |             forward_heap.Insert(source_phantom.reverse_node_id, | ||||||
|  |                                 -source_phantom.GetReverseWeightPlusOffset(), | ||||||
|  |                                 source_phantom.reverse_node_id); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // insert new backward nodes into backward heap, unadjusted.
 | ||||||
|  |         if (target_phantom.forward_node_id != SPECIAL_NODEID) | ||||||
|  |         { | ||||||
|  |             reverse_heap.Insert(target_phantom.forward_node_id, | ||||||
|  |                                 target_phantom.GetForwardWeightPlusOffset(), | ||||||
|  |                                 target_phantom.forward_node_id); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (target_phantom.reverse_node_id != SPECIAL_NODEID) | ||||||
|  |         { | ||||||
|  |             reverse_heap.Insert(target_phantom.reverse_node_id, | ||||||
|  |                                 target_phantom.GetReverseWeightPlusOffset(), | ||||||
|  |                                 target_phantom.reverse_node_id); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         std::vector<std::pair<NodeID, EdgeWeight>> forward_entry_points; | ||||||
|  |         std::vector<std::pair<NodeID, EdgeWeight>> reverse_entry_points; | ||||||
|  | 
 | ||||||
|  |         // run two-Target Dijkstra routing step.
 | ||||||
|  |         while (0 < (forward_heap.Size() + reverse_heap.Size())) | ||||||
|  |         { | ||||||
|  |             if (!forward_heap.Empty()) | ||||||
|  |             { | ||||||
|  |                   RoutingStep(forward_heap, reverse_heap, &middle, &distance, min_edge_offset, | ||||||
|  |                               true); | ||||||
|  |             } | ||||||
|  |             if (!reverse_heap.Empty()) | ||||||
|  |             { | ||||||
|  |                     RoutingStep(reverse_heap, forward_heap, &middle, &distance, min_edge_offset, | ||||||
|  |                                 false); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // No path found for both target nodes?
 | ||||||
|  |         if (INVALID_EDGE_WEIGHT == distance) | ||||||
|  |         { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // Was a paths over one of the forward/reverse nodes not found?
 | ||||||
|  |         BOOST_ASSERT_MSG((SPECIAL_NODEID == middle || INVALID_EDGE_WEIGHT != distance), | ||||||
|  |                          "no path found"); | ||||||
|  | 
 | ||||||
|  |         RetrievePackedPathFromHeap(forward_heap, reverse_heap, middle, packed_leg); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // assumes that heaps are already setup correctly.
 | ||||||
|  |     void SearchWithCore(SearchEngineData::QueryHeap &forward_heap, | ||||||
|  |                         SearchEngineData::QueryHeap &reverse_heap, | ||||||
|  |                         SearchEngineData::QueryHeap &forward_core_heap, | ||||||
|  |                         SearchEngineData::QueryHeap &reverse_core_heap, | ||||||
|  |                         const PhantomNode &source_phantom, | ||||||
|  |                         const PhantomNode &target_phantom, | ||||||
|  |                         int &distance, | ||||||
|  |                         std::vector<NodeID> &packed_leg) const | ||||||
|  |     { | ||||||
|  |         NodeID middle = SPECIAL_NODEID; | ||||||
|  | 
 | ||||||
|  |         const EdgeWeight min_edge_offset = std::min(-source_phantom.GetForwardWeightPlusOffset(), | ||||||
|  |                                                     -source_phantom.GetReverseWeightPlusOffset()); | ||||||
|  | 
 | ||||||
|  |         // insert new starting nodes into forward heap, adjusted by previous distances.
 | ||||||
|  |         if (source_phantom.forward_node_id != SPECIAL_NODEID) | ||||||
|  |         { | ||||||
|  |             forward_heap.Insert(source_phantom.forward_node_id, | ||||||
|  |                                 -source_phantom.GetForwardWeightPlusOffset(), | ||||||
|  |                                 source_phantom.forward_node_id); | ||||||
|  |         } | ||||||
|  |         if (source_phantom.reverse_node_id != SPECIAL_NODEID) | ||||||
|  |         { | ||||||
|  |             forward_heap.Insert(source_phantom.reverse_node_id, | ||||||
|  |                                 -source_phantom.GetReverseWeightPlusOffset(), | ||||||
|  |                                 source_phantom.reverse_node_id); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // insert new backward nodes into backward heap, unadjusted.
 | ||||||
|  |         if (target_phantom.forward_node_id != SPECIAL_NODEID) | ||||||
|  |         { | ||||||
|  |             reverse_heap.Insert(target_phantom.forward_node_id, | ||||||
|  |                                 target_phantom.GetForwardWeightPlusOffset(), | ||||||
|  |                                 target_phantom.forward_node_id); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (target_phantom.reverse_node_id != SPECIAL_NODEID) | ||||||
|  |         { | ||||||
|  |             reverse_heap.Insert(target_phantom.reverse_node_id, | ||||||
|  |                                 target_phantom.GetReverseWeightPlusOffset(), | ||||||
|  |                                 target_phantom.reverse_node_id); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         std::vector<std::pair<NodeID, EdgeWeight>> forward_entry_points; | ||||||
|  |         std::vector<std::pair<NodeID, EdgeWeight>> reverse_entry_points; | ||||||
|  | 
 | ||||||
|  |         // run two-Target Dijkstra routing step.
 | ||||||
|  |         while (0 < (forward_heap.Size() + reverse_heap.Size())) | ||||||
|  |         { | ||||||
|  |             if (!forward_heap.Empty()) | ||||||
|  |             { | ||||||
|  |                 if (facade->IsCoreNode(forward_heap.Min())) | ||||||
|  |                 { | ||||||
|  |                     const NodeID node = forward_heap.DeleteMin(); | ||||||
|  |                     const int key = forward_heap.GetKey(node); | ||||||
|  |                     forward_entry_points.emplace_back(node, key); | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     RoutingStep(forward_heap, reverse_heap, &middle, &distance, min_edge_offset, | ||||||
|  |                                 true); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             if (!reverse_heap.Empty()) | ||||||
|  |             { | ||||||
|  |                 if (facade->IsCoreNode(reverse_heap.Min())) | ||||||
|  |                 { | ||||||
|  |                     const NodeID node = reverse_heap.DeleteMin(); | ||||||
|  |                     const int key = reverse_heap.GetKey(node); | ||||||
|  |                     reverse_entry_points.emplace_back(node, key); | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     RoutingStep(reverse_heap, forward_heap, &middle, &distance, min_edge_offset, | ||||||
|  |                                 false); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // TODO check if unordered_set might be faster
 | ||||||
|  |         // sort by id and increasing by distance
 | ||||||
|  |         auto entry_point_comparator = [](const std::pair<NodeID, EdgeWeight> &lhs, | ||||||
|  |                                          const std::pair<NodeID, EdgeWeight> &rhs) | ||||||
|  |         { | ||||||
|  |             return lhs.first < rhs.first || (lhs.first == rhs.first && lhs.second < rhs.second); | ||||||
|  |         }; | ||||||
|  |         std::sort(forward_entry_points.begin(), forward_entry_points.end(), entry_point_comparator); | ||||||
|  |         std::sort(reverse_entry_points.begin(), reverse_entry_points.end(), entry_point_comparator); | ||||||
|  | 
 | ||||||
|  |         NodeID last_id = SPECIAL_NODEID; | ||||||
|  |         for (const auto p : forward_entry_points) | ||||||
|  |         { | ||||||
|  |             if (p.first == last_id) | ||||||
|  |             { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             forward_core_heap.Insert(p.first, p.second, p.first); | ||||||
|  |             last_id = p.first; | ||||||
|  |         } | ||||||
|  |         last_id = SPECIAL_NODEID; | ||||||
|  |         for (const auto p : reverse_entry_points) | ||||||
|  |         { | ||||||
|  |             if (p.first == last_id) | ||||||
|  |             { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             reverse_core_heap.Insert(p.first, p.second, p.first); | ||||||
|  |             last_id = p.first; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // run two-target Dijkstra routing step on core with termination criterion
 | ||||||
|  |         while (0 < (forward_core_heap.Size() + reverse_core_heap.Size()) && | ||||||
|  |                distance > (forward_core_heap.MinKey() + reverse_core_heap.MinKey())) | ||||||
|  |         { | ||||||
|  |             if (!forward_core_heap.Empty()) | ||||||
|  |             { | ||||||
|  |                 RoutingStep(forward_core_heap, reverse_core_heap, &middle, &distance, | ||||||
|  |                             min_edge_offset, true, false); | ||||||
|  |             } | ||||||
|  |             if (!reverse_core_heap.Empty()) | ||||||
|  |             { | ||||||
|  |                 RoutingStep(reverse_core_heap, forward_core_heap, &middle, &distance, | ||||||
|  |                             min_edge_offset, false, false); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // No path found for both target nodes?
 | ||||||
|  |         if (INVALID_EDGE_WEIGHT == distance) | ||||||
|  |         { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // Was a paths over one of the forward/reverse nodes not found?
 | ||||||
|  |         BOOST_ASSERT_MSG((SPECIAL_NODEID == middle || INVALID_EDGE_WEIGHT != distance), | ||||||
|  |                          "no path found"); | ||||||
|  | 
 | ||||||
|  |         // we need to unpack sub path from core heaps
 | ||||||
|  |         if (facade->IsCoreNode(middle)) | ||||||
|  |         { | ||||||
|  |             std::vector<NodeID> packed_core_leg; | ||||||
|  |             RetrievePackedPathFromHeap(forward_core_heap, reverse_core_heap, middle, | ||||||
|  |                                        packed_core_leg); | ||||||
|  |             BOOST_ASSERT(packed_core_leg.size() > 0); | ||||||
|  |             RetrievePackedPathFromSingleHeap(forward_heap, packed_core_leg.front(), packed_leg); | ||||||
|  |             std::reverse(packed_leg.begin(), packed_leg.end()); | ||||||
|  |             packed_leg.insert(packed_leg.end(), packed_core_leg.begin(), packed_core_leg.end()); | ||||||
|  |             RetrievePackedPathFromSingleHeap(reverse_heap, packed_core_leg.back(), packed_leg); | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             RetrievePackedPathFromHeap(forward_heap, reverse_heap, middle, packed_leg); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     double get_network_distance(SearchEngineData::QueryHeap &forward_heap, |     double get_network_distance(SearchEngineData::QueryHeap &forward_heap, | ||||||
|                                 SearchEngineData::QueryHeap &reverse_heap, |                                 SearchEngineData::QueryHeap &reverse_heap, | ||||||
|                                 const PhantomNode &source_phantom, |                                 const PhantomNode &source_phantom, | ||||||
|  | |||||||
| @ -118,6 +118,8 @@ template <class EdgeDataT> class BaseDataFacade | |||||||
| 
 | 
 | ||||||
|     virtual std::string get_name_for_id(const unsigned name_id) const = 0; |     virtual std::string get_name_for_id(const unsigned name_id) const = 0; | ||||||
| 
 | 
 | ||||||
|  |     virtual std::size_t GetCoreSize() const = 0; | ||||||
|  | 
 | ||||||
|     virtual std::string GetTimestamp() const = 0; |     virtual std::string GetTimestamp() const = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -447,6 +447,11 @@ template <class EdgeDataT> class InternalDataFacade final : public BaseDataFacad | |||||||
|         return m_via_node_list.at(id); |         return m_via_node_list.at(id); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     virtual std::size_t GetCoreSize() const override final | ||||||
|  |     { | ||||||
|  |         return m_is_core_node.size(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     virtual bool IsCoreNode(const NodeID id) const override final |     virtual bool IsCoreNode(const NodeID id) const override final | ||||||
|     { |     { | ||||||
|         if (m_is_core_node.size() > 0) |         if (m_is_core_node.size() > 0) | ||||||
|  | |||||||
| @ -473,6 +473,11 @@ template <class EdgeDataT> class SharedDataFacade final : public BaseDataFacade< | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     virtual std::size_t GetCoreSize() const override final | ||||||
|  |     { | ||||||
|  |         return m_is_core_node.size(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string GetTimestamp() const override final { return m_timestamp; } |     std::string GetTimestamp() const override final { return m_timestamp; } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user