2014-11-28 09:00:48 -05:00
|
|
|
#ifndef EXTRACTION_CONTAINERS_HPP
|
|
|
|
#define EXTRACTION_CONTAINERS_HPP
|
2012-08-29 12:33:18 -04:00
|
|
|
|
2016-05-27 15:05:04 -04:00
|
|
|
#include "extractor/internal_extractor_edge.hpp"
|
2020-12-20 16:59:57 -05:00
|
|
|
#include "extractor/nodes_of_way.hpp"
|
2017-07-06 20:16:40 -04:00
|
|
|
#include "extractor/query_node.hpp"
|
2016-01-02 11:13:44 -05:00
|
|
|
#include "extractor/restriction.hpp"
|
2016-05-27 15:05:04 -04:00
|
|
|
#include "extractor/scripting_environment.hpp"
|
2012-08-29 12:33:18 -04:00
|
|
|
|
2018-03-19 20:47:34 -04:00
|
|
|
#include "storage/tar_fwd.hpp"
|
2022-08-30 05:36:49 -04:00
|
|
|
#include "traffic_lights.hpp"
|
|
|
|
#include "traffic_signals.hpp"
|
2017-03-04 05:52:40 -05:00
|
|
|
|
2020-12-20 16:59:57 -05:00
|
|
|
#include <unordered_map>
|
2022-08-30 05:36:49 -04:00
|
|
|
#include <unordered_set>
|
2020-12-20 16:59:57 -05:00
|
|
|
|
2016-01-05 10:51:13 -05:00
|
|
|
namespace osrm
|
|
|
|
{
|
|
|
|
namespace extractor
|
|
|
|
{
|
|
|
|
|
2015-04-10 10:10:00 -04:00
|
|
|
/**
|
2017-07-10 17:26:31 -04:00
|
|
|
* Uses memory containers to store all the data that
|
2015-04-10 10:10:00 -04:00
|
|
|
* is collected by the extractor callbacks.
|
2015-05-09 11:21:36 -04:00
|
|
|
*
|
|
|
|
* The data is the filtered, aggregated and finally written to disk.
|
2015-04-10 10:10:00 -04:00
|
|
|
*/
|
2014-05-09 10:17:31 -04:00
|
|
|
class ExtractionContainers
|
|
|
|
{
|
2020-12-20 16:59:57 -05:00
|
|
|
using ReferencedWays = std::unordered_map<OSMWayID, NodesOfWay>;
|
2022-08-30 05:36:49 -04:00
|
|
|
using ReferencedTrafficSignals =
|
|
|
|
std::pair<std::unordered_set<OSMNodeID>, std::unordered_multimap<OSMNodeID, OSMNodeID>>;
|
2020-12-20 16:59:57 -05:00
|
|
|
// The relationship between way and nodes is lost during node preparation.
|
2022-08-30 05:36:49 -04:00
|
|
|
// We identify the ways and nodes relevant to restrictions/overrides/signals prior to
|
2020-12-20 16:59:57 -05:00
|
|
|
// node processing so that they can be referenced in the preparation phase.
|
|
|
|
ReferencedWays IdentifyRestrictionWays();
|
|
|
|
ReferencedWays IdentifyManeuverOverrideWays();
|
2022-08-30 05:36:49 -04:00
|
|
|
ReferencedTrafficSignals IdentifyTrafficSignals();
|
2020-12-20 16:59:57 -05:00
|
|
|
|
2015-05-09 11:21:36 -04:00
|
|
|
void PrepareNodes();
|
2020-12-20 16:59:57 -05:00
|
|
|
void PrepareManeuverOverrides(const ReferencedWays &maneuver_override_ways);
|
|
|
|
void PrepareRestrictions(const ReferencedWays &restriction_ways);
|
2022-08-30 05:36:49 -04:00
|
|
|
void PrepareTrafficSignals(const ReferencedTrafficSignals &referenced_traffic_signals);
|
2016-07-11 11:44:58 -04:00
|
|
|
void PrepareEdges(ScriptingEnvironment &scripting_environment);
|
2015-05-09 11:21:36 -04:00
|
|
|
|
2018-03-19 20:47:34 -04:00
|
|
|
void WriteNodes(storage::tar::FileWriter &file_out) const;
|
|
|
|
void WriteEdges(storage::tar::FileWriter &file_out) const;
|
|
|
|
void WriteMetadata(storage::tar::FileWriter &file_out) const;
|
2016-06-30 03:31:08 -04:00
|
|
|
void WriteCharData(const std::string &file_name);
|
2016-01-05 06:04:04 -05:00
|
|
|
|
2014-05-09 10:17:31 -04:00
|
|
|
public:
|
2017-07-10 17:26:31 -04:00
|
|
|
using NodeIDVector = std::vector<OSMNodeID>;
|
|
|
|
using NodeVector = std::vector<QueryNode>;
|
|
|
|
using EdgeVector = std::vector<InternalExtractorEdge>;
|
2017-09-25 09:37:11 -04:00
|
|
|
using AnnotationDataVector = std::vector<NodeBasedEdgeAnnotation>;
|
2017-07-10 17:26:31 -04:00
|
|
|
using NameCharData = std::vector<unsigned char>;
|
2020-12-20 16:59:57 -05:00
|
|
|
using NameOffsets = std::vector<size_t>;
|
|
|
|
using WayIDVector = std::vector<OSMWayID>;
|
|
|
|
using WayNodeIDOffsets = std::vector<size_t>;
|
2022-08-30 05:36:49 -04:00
|
|
|
using InputTrafficSignal = std::pair<OSMNodeID, TrafficLightClass::Direction>;
|
2013-11-13 15:23:44 -05:00
|
|
|
|
2017-07-06 20:16:40 -04:00
|
|
|
std::vector<OSMNodeID> barrier_nodes;
|
2017-07-07 06:09:52 -04:00
|
|
|
NodeIDVector used_node_id_list;
|
|
|
|
NodeVector all_nodes_list;
|
|
|
|
EdgeVector all_edges_list;
|
2017-09-25 09:37:11 -04:00
|
|
|
AnnotationDataVector all_edges_annotation_data_list;
|
2017-07-07 06:09:52 -04:00
|
|
|
NameCharData name_char_data;
|
|
|
|
NameOffsets name_offsets;
|
2020-12-20 16:59:57 -05:00
|
|
|
WayIDVector ways_list;
|
|
|
|
// Offsets into used nodes for each way_list entry
|
|
|
|
WayNodeIDOffsets way_node_id_offsets;
|
2017-07-06 11:09:24 -04:00
|
|
|
|
2015-09-10 06:21:36 -04:00
|
|
|
unsigned max_internal_node_id;
|
2017-07-06 11:09:24 -04:00
|
|
|
|
2022-08-30 05:36:49 -04:00
|
|
|
std::vector<InputTrafficSignal> external_traffic_signals;
|
|
|
|
TrafficSignals internal_traffic_signals;
|
|
|
|
|
2020-12-20 16:59:57 -05:00
|
|
|
// List of restrictions (conditional and unconditional) before we transform them into the
|
|
|
|
// output types. Input containers reference OSMNodeIDs. We can only transform them to the
|
|
|
|
// correct internal IDs after we've read everything. Without a multi-parse approach,
|
|
|
|
// we have to remember the output restrictions before converting them to the internal formats
|
|
|
|
std::vector<InputTurnRestriction> restrictions_list;
|
|
|
|
std::vector<TurnRestriction> turn_restrictions;
|
2012-08-29 12:33:18 -04:00
|
|
|
|
2018-02-09 13:32:09 -05:00
|
|
|
std::vector<InputManeuverOverride> external_maneuver_overrides_list;
|
|
|
|
std::vector<UnresolvedManeuverOverride> internal_maneuver_overrides;
|
|
|
|
|
2014-01-09 10:13:35 -05:00
|
|
|
ExtractionContainers();
|
2013-08-05 11:28:57 -04:00
|
|
|
|
2016-07-11 11:44:58 -04:00
|
|
|
void PrepareData(ScriptingEnvironment &scripting_environment,
|
2017-05-05 04:23:09 -04:00
|
|
|
const std::string &osrm_path,
|
2017-04-29 07:34:33 -04:00
|
|
|
const std::string &names_data_path);
|
2012-08-29 12:33:18 -04:00
|
|
|
};
|
2020-11-26 10:21:39 -05:00
|
|
|
} // namespace extractor
|
|
|
|
} // namespace osrm
|
2016-01-05 10:51:13 -05:00
|
|
|
|
2014-11-28 09:00:48 -05:00
|
|
|
#endif /* EXTRACTION_CONTAINERS_HPP */
|