#ifndef SEARCH_ENGINE_DATA_HPP #define SEARCH_ENGINE_DATA_HPP #include #include "engine/algorithm.hpp" #include "util/binary_heap.hpp" #include "util/typedefs.hpp" namespace osrm { namespace engine { // Algorithm-dependent heaps // - CH algorithms use CH heaps // - CoreCH algorithms use CoreCH heaps that can be upcasted to CH heaps when CH algorithms reused // by CoreCH at calling ch::routingStep, ch::retrievePackedPathFromSingleHeap and ch::unpackPath // - MLD algorithms use MLD heaps template struct SearchEngineData { }; struct HeapData { NodeID parent; /* explicit */ HeapData(NodeID p) : parent(p) {} }; struct ManyToManyHeapData : HeapData { EdgeWeight duration; ManyToManyHeapData(NodeID p, EdgeWeight duration) : HeapData(p), duration(duration) {} }; template <> struct SearchEngineData { using QueryHeap = util:: BinaryHeap>; using SearchEngineHeapPtr = boost::thread_specific_ptr; using ManyToManyQueryHeap = util::BinaryHeap>; using ManyToManyHeapPtr = boost::thread_specific_ptr; static SearchEngineHeapPtr forward_heap_1; static SearchEngineHeapPtr reverse_heap_1; static SearchEngineHeapPtr forward_heap_2; static SearchEngineHeapPtr reverse_heap_2; static SearchEngineHeapPtr forward_heap_3; static SearchEngineHeapPtr reverse_heap_3; static ManyToManyHeapPtr many_to_many_heap; void InitializeOrClearFirstThreadLocalStorage(unsigned number_of_nodes); void InitializeOrClearSecondThreadLocalStorage(unsigned number_of_nodes); void InitializeOrClearThirdThreadLocalStorage(unsigned number_of_nodes); void InitializeOrClearManyToManyThreadLocalStorage(unsigned number_of_nodes); }; template <> struct SearchEngineData : public SearchEngineData { }; struct MultiLayerDijkstraHeapData { NodeID parent; bool from_clique_arc; MultiLayerDijkstraHeapData(NodeID p) : parent(p), from_clique_arc(false) {} MultiLayerDijkstraHeapData(NodeID p, bool from) : parent(p), from_clique_arc(from) {} }; template <> struct SearchEngineData { using QueryHeap = util::BinaryHeap>; using SearchEngineHeapPtr = boost::thread_specific_ptr; static SearchEngineHeapPtr forward_heap_1; static SearchEngineHeapPtr reverse_heap_1; void InitializeOrClearFirstThreadLocalStorage(unsigned number_of_nodes); }; } } #endif // SEARCH_ENGINE_DATA_HPP