Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
NIImporter_OpenStreetMap.h
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2026 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
22// Importer for networks stored in OpenStreetMap format
23/****************************************************************************/
24#pragma once
25#include <config.h>
26
27#include <string>
28#include <map>
33
34
35// ===========================================================================
36// class declarations
37// ===========================================================================
38class NBEdge;
39class NBEdgeCont;
40class NBNetBuilder;
41class NBNode;
42class NBNodeCont;
44class NBTypeCont;
45class OptionsCont;
46
47
48// ===========================================================================
49// class definitions
50// ===========================================================================
57public:
69 static void loadNetwork(const OptionsCont& oc, NBNetBuilder& nb);
70
71protected:
72
76 enum WayType {
78 // technically possible
83 // recommended for routing
86 };
87
90 struct NIOSMNode : public Parameterised {
91 NIOSMNode(long long int _id, double _lon, double _lat)
92 :
93 id(_id), lon(_lon), lat(_lat), ele(0.),
94 tlsControlled(false),
95 pedestrianCrossing(false),
96 railwayCrossing(false),
97 railwaySignal(false),
98 railwayBufferStop(false),
99 ptStopPosition(false), ptStopLength(0), name(""),
101 positionMeters(std::numeric_limits<double>::max()),
103 node(nullptr) { }
104
106 const long long int id;
108 const double lon;
110 const double lat;
112 double ele;
128 std::string name;
132 std::string position;
139
140 private:
142 NIOSMNode& operator=(const NIOSMNode& s) = delete;
143
144
145 };
146
147public:
149 static SUMOVehicleClass interpretTransportType(const std::string& type, NIOSMNode* toSet = nullptr);
150
151protected:
152
153
164
171
172 enum class PlacementType {
173 NONE = 0,
174 LEFT_OF = 1,
175 RIGHT_OF = 2,
176 MIDDLE_OF = 3
177 };
178
181 class Edge : public Parameterised {
182 public:
183 explicit Edge(long long int _id) :
184 id(_id), myNoLanes(-1), myNoLanesForward(0),
189 myCyclewayType(WAY_UNKNOWN), // building of extra lane depends on bikelaneWidth of loaded typemap
190 myBuswayType(WAY_NONE), // buslanes are always built when declared
191 mySidewalkType(WAY_UNKNOWN), // building of extra lanes depends on sidewalkWidth of loaded typemap
192 myRailDirection(WAY_UNKNOWN), // store direction(s) of railway usage
193 myParkingType(PARKING_NONE), // parking areas exported optionally
196 myLayer(0), // layer is non-zero only in conflict areas
197 myCurrentIsRoad(false),
198 myAmInRoundabout(false),
200 myPlacementLane(-1),
201 myWidth(-1)
202 { }
203
204 virtual ~Edge() {}
205
207 const long long int id;
209 std::string streetName;
211 std::string ref;
225 std::string myHighWayType;
227 std::string myIsOneWay;
243 std::vector<bool> myDesignatedLaneForward;
245 std::vector<bool> myDesignatedLaneBackward;
247 std::vector<SVCPermissions> myAllowedLaneForward;
249 std::vector<SVCPermissions> myAllowedLaneBackward;
251 std::vector<SVCPermissions> myDisallowedLaneForward;
253 std::vector<SVCPermissions> myDisallowedLaneBackward;
257 std::vector<long long int> myCurrentNodes;
263 std::map<std::string, std::string> myExtraTags;
265 std::vector<int> myTurnSignsForward;
266 std::vector<int> myTurnSignsBackward;
272 std::vector<double> myWidthLanesForward;
273 std::vector<double> myWidthLanesBackward;
274 double myWidth;
275
276 private:
278 Edge& operator=(const Edge& s) = delete;
279 };
280
281
283
285
286 void load(const OptionsCont& oc, NBNetBuilder& nb);
287
288private:
293 public:
294 bool operator()(const NIOSMNode* n1, const NIOSMNode* n2) const {
295 return (n1->lat > n2->lat) || (n1->lat == n2->lat && n1->lon > n2->lon);
296 }
297 };
298
299
301 static const std::string compoundTypeSeparator;
302
303 class CompareEdges;
304
308 std::map<long long int, NIOSMNode*> myOSMNodes;
309
311 std::set<NIOSMNode*, CompareNodes> myUniqueNodes;
312
313
315 std::map<long long int, Edge*> myEdges;
316
318 std::map<long long int, Edge*> myPlatformShapes;
319
321 std::set<std::string> myUnusableTypes;
322
324 std::map<std::string, std::string> myKnownCompoundTypes;
325
328
331
334
337
340
343
346
349
352
354 static bool myAllAttributes;
355
357 static std::set<std::string> myExtraAttributes;
358
373 NBNode* insertNodeChecking(long long int id, NBNodeCont& nc, NBTrafficLightLogicCont& tlsc);
374
375
390 int insertEdge(Edge* e, int index, NBNode* from, NBNode* to,
391 const std::vector<long long int>& passed, NBNetBuilder& nb,
392 const NBNode* first, const NBNode* last);
393
395 void reconstructLayerElevation(double layerElevation, NBNetBuilder& nb);
396
398 std::map<NBNode*, std::pair<double, double> >
399 getNeighboringNodes(NBNode* node, double maxDist, const std::set<NBNode*>& knownElevation);
400
402 std::string usableType(const std::string& type, const std::string& id, NBTypeCont& tc);
403
406
408 static double interpretDistance(NIOSMNode* node);
409
410protected:
411 static const double MAXSPEED_UNGIVEN;
412 static const long long int INVALID_ID;
413
414 static void applyChangeProhibition(NBEdge* e, int changeProhibition);
425 void applyLaneUse(NBEdge* e, NIImporter_OpenStreetMap::Edge* nie, const bool forward);
426
427 static void mergeTurnSigns(std::vector<int>& signs, std::vector<int> signs2);
428 void applyTurnSigns(NBEdge* e, const std::vector<int>& turnSigns);
429
435 public:
441 NodesHandler(std::map<long long int, NIOSMNode*>& toFill, std::set<NIOSMNode*,
442 CompareNodes>& uniqueNodes,
443 const OptionsCont& cont);
444
445
447 ~NodesHandler() override;
448
449 int getDuplicateNodes() const {
450 return myDuplicateNodes;
451 }
452
455 }
456
457 protected:
459
460
468 void myStartElement(int element, const SUMOSAXAttributes& attrs) override;
469
470
477 void myEndElement(int element) override;
479
480
481 private:
483 std::map<long long int, NIOSMNode*>& myToFill;
484
486 std::string myLastNodeID;
487
490
492 std::string myRailwayRef;
493
496
498 std::set<NIOSMNode*, CompareNodes>& myUniqueNodes;
499
502
505
508
511
512 private:
515
518
519 };
520
521
527 public:
533 EdgesHandler(const std::map<long long int, NIOSMNode*>& osmNodes,
534 std::map<long long int, Edge*>& toFill, std::map<long long int, Edge*>& platformShapes,
535 const NBTypeCont& tc);
536
537
539 ~EdgesHandler() override;
540
541
542 protected:
544
545
553 void myStartElement(int element, const SUMOSAXAttributes& attrs) override;
554
555
562 void myEndElement(int element) override;
564
565 double interpretSpeed(const std::string& key, std::string value);
566
567 int interpretChangeType(const std::string& value) const;
568
569 void interpretLaneUse(const std::string& value, SUMOVehicleClass svc, const bool forward) const;
570
571 bool interpretPlacement(const std::string& value, NIImporter_OpenStreetMap::PlacementType& placement, int& laneIndex) const;
572
573 void addType(const std::string& singleTypeID);
574
575
576 private:
578 const std::map<long long int, NIOSMNode*>& myOSMNodes;
579
581 std::map<long long int, Edge*>& myEdgeMap;
582
584 std::map<long long int, Edge*>& myPlatformShapesMap;
585
587 Edge* myCurrentEdge = nullptr;
588
590 std::map<std::string, double> mySpeedMap;
591
593
594 private:
597
600
601 };
602
609 public:
615 RelationHandler(const std::map<long long int, NIOSMNode*>& osmNodes,
616 const std::map<long long int, Edge*>& osmEdges, NBPTStopCont* nbptStopCont,
617 const std::map<long long int, Edge*>& platfromShapes, NBPTLineCont* nbptLineCont,
618 const OptionsCont& oc);
619
620
623
624 protected:
626
627
635 void myStartElement(int element, const SUMOSAXAttributes& attrs) override;
636
637
644 void myEndElement(int element) override;
646
647
648 private:
650 const std::map<long long int, NIOSMNode*>& myOSMNodes;
651
653 const std::map<long long int, Edge*>& myOSMEdges;
654
656 const std::map<long long int, Edge*>& myPlatformShapes;
657
660
663
665 long long int myCurrentRelation;
666
669
672
674 long long int myFromWay;
675
677 long long int myToWay;
678
680 long long int myViaNode;
681 long long int myViaWay;
682
684 long long int myStation;
685
688
692 enum class RestrictionType {
694 ONLY,
696 NO,
698 UNKNOWN
699 };
701
703 void resetValues();
704
706 bool checkEdgeRef(long long int ref) const;
707
709 bool applyRestriction() const;
710
712 NBEdge* findEdgeRef(long long int wayRef, const std::vector<NBEdge*>& candidates) const;
713
714 private:
717
720
722 std::vector<long long int> myStops;
723
725 std::set<long long int> myPlatformStops;
726
727
729 long long int ref;
730 bool isWay;
731 };
732
734 std::vector<NIIPTPlatform> myPlatforms;
735
737 std::vector<long long int> myWays;
738
741
744
746 std::string myPTRouteType;
747
750
752 std::string myName;
753
755 std::string myRef;
756
759
761 std::string myNightService;
762
764 std::map<long long int, long long int > myStopAreas;
765
766 };
767
768};
std::vector< std::string > StringVector
Definition of a vector of strings.
Definition Option.h:42
long long int SVCPermissions
bitset where each bit declares whether a certain SVC may use this edge/lane
SUMOVehicleClass
Definition of vehicle classes to differ between different lane usage and authority types.
@ SVC_IGNORING
vehicles ignoring classes
Storage for edges, including some functionality operating on multiple edges.
Definition NBEdgeCont.h:59
The representation of a single edge during network building.
Definition NBEdge.h:92
Instance responsible for building networks.
Container for nodes during the netbuilding process.
Definition NBNodeCont.h:57
Represents a single node (junction) during network building.
Definition NBNode.h:66
Container for public transport stops during the net building process.
A container for traffic light definitions and built programs.
A storage for available edgeTypes of edges.
Definition NBTypeCont.h:52
Functor which compares two NIOSMNodes according to their coordinates.
bool operator()(const NIOSMNode *n1, const NIOSMNode *n2) const
An internal definition of a loaded edge.
int myPlacementLane
1-based lane index for placement specification
std::vector< SVCPermissions > myDisallowedLaneBackward
(optional) information about additional disallowed SVCs on backward lane(s)
std::map< std::string, std::string > myExtraTags
Additionally tagged information.
std::vector< double > myWidthLanesForward
Information on lane width.
WayType mySidewalkType
Information about the kind of sidwalk along this road.
Edge & operator=(const Edge &s)=delete
invalidated assignment operator
std::vector< SVCPermissions > myDisallowedLaneForward
(optional) information about additional disallowed SVCs on forward lane(s)
bool myCurrentIsRoad
Information whether this is a road.
WayType myCyclewayType
Information about the kind of cycleway along this road.
int myNoLanesForward
number of lanes in forward direction or 0 if unknown, negative if backwards lanes are meant
double myMaxSpeed
maximum speed in km/h, or MAXSPEED_UNGIVEN
std::string ref
The edge's track name.
std::vector< SVCPermissions > myAllowedLaneForward
(optional) information about additional allowed SVCs on forward lane(s)
std::string myHighWayType
The type, stored in "highway" key.
const long long int id
The edge's id.
bool myAmInRoundabout
Information whether this road is part of a roundabout.
int myLayer
Information about the relative z-ordering of ways.
int myRailDirection
Information about the direction(s) of railway usage.
std::vector< bool > myDesignatedLaneBackward
(optional) information about whether the backward lanes are designated to some SVCs
SVCPermissions myExtraDisallowed
Extra permissions prohibited from tags instead of highway type.
std::vector< SVCPermissions > myAllowedLaneBackward
(optional) information about additional allowed SVCs on backward lane(s)
int myNoLanes
number of lanes, or -1 if unknown
std::vector< int > myTurnSignsForward
turning direction (arrows printed on the road)
std::vector< long long int > myCurrentNodes
The list of nodes this edge is made of.
int myParkingType
Information about road-side parking.
double myMaxSpeedBackward
maximum speed in km/h, or MAXSPEED_UNGIVEN
WayType myBuswayType
Information about the kind of busway along this road.
int myChangeForward
Information about change prohibitions (forward direction.
SVCPermissions myExtraAllowed
Extra permissions added from tags instead of highway type.
int myChangeBackward
Information about change prohibitions (backward direction.
std::string streetName
The edge's street name.
PlacementType myPlacement
placement of the OSM way geometry relative to lanes
std::vector< bool > myDesignatedLaneForward
(optional) information about whether the forward lanes are designated to some SVCs
std::string myIsOneWay
Information whether this is an one-way road.
A class which extracts OSM-edges from a parsed OSM-file.
void addType(const std::string &singleTypeID)
Edge * myCurrentEdge
The currently built edge.
const std::map< long long int, NIOSMNode * > & myOSMNodes
The previously parsed nodes.
void interpretLaneUse(const std::string &value, SUMOVehicleClass svc, const bool forward) const
int interpretChangeType(const std::string &value) const
void myEndElement(int element) override
Called when a closing tag occurs.
bool interpretPlacement(const std::string &value, NIImporter_OpenStreetMap::PlacementType &placement, int &laneIndex) const
double interpretSpeed(const std::string &key, std::string value)
EdgesHandler(const EdgesHandler &s)
invalidated copy constructor
std::map< long long int, Edge * > & myEdgeMap
A map of built edges.
std::map< long long int, Edge * > & myPlatformShapesMap
A map of built edges.
std::map< std::string, double > mySpeedMap
A map of non-numeric speed descriptions to their numeric values.
void myStartElement(int element, const SUMOSAXAttributes &attrs) override
Called on the opening of a tag;.
EdgesHandler & operator=(const EdgesHandler &s)
invalidated assignment operator
A class which extracts OSM-nodes from a parsed OSM-file.
int myHierarchyLevel
The current hierarchy level.
const bool myImportElevation
whether elevation data should be imported
std::string myLastNodeID
id of the currently parsed node
NodesHandler(const NodesHandler &s)
invalidated copy constructor
std::set< NIOSMNode *, CompareNodes > & myUniqueNodes
the set of unique nodes (used for duplicate detection/substitution)
void myStartElement(int element, const SUMOSAXAttributes &attrs) override
Called on the opening of a tag;.
std::map< long long int, NIOSMNode * > & myToFill
The nodes container to fill.
NodesHandler & operator=(const NodesHandler &s)
invalidated assignment operator
void myEndElement(int element) override
Called when a closing tag occurs.
NIOSMNode * myCurrentNode
the currently parsed node
StringVector myRailSignalRules
custom requirements for rail signal tagging
A class which extracts relevant relation information from a parsed OSM-file.
void myEndElement(int element) override
Called when a closing tag occurs.
const std::map< long long int, Edge * > & myPlatformShapes
The previously parsed platform shapes.
long long int myViaNode
the via node/way for the current restriction
bool myIsRestriction
whether the currently parsed relation is a restriction
std::vector< long long int > myWays
ways in pt line references
SVCPermissions myRestrictionException
exceptions to the restriction currenlty being parsed
long long int myCurrentRelation
The currently parsed relation.
std::set< long long int > myPlatformStops
myStops which are actually platforms (in case there is no stop_position)
void resetValues()
reset members to their defaults for parsing a new relation
void myStartElement(int element, const SUMOSAXAttributes &attrs) override
Called on the opening of a tag;.
const std::map< long long int, NIOSMNode * > & myOSMNodes
The previously parsed nodes.
const OptionsCont & myOptionsCont
the options cont
RestrictionType
whether the only allowed or the only forbidden connection is defined
@ ONLY
The only valid connection is declared.
@ NO
The only invalid connection is declared.
std::string myNightService
night service information of the pt line
std::string myPTRouteType
indicates whether current relation is a pt route
std::vector< long long int > myStops
bus stop references
NBPTLineCont * myNBPTLineCont
PT Line container to be filled.
std::vector< NIIPTPlatform > myPlatforms
bus stop platforms
bool myIsStopArea
indicates whether current relation is a pt stop area
bool myIsRoute
indicates whether current relation is a route
RelationHandler & operator=(const RelationHandler &s)
invalidated assignment operator
long long int myStation
the station node for the current stop_area
int myInterval
service interval of the pt line in minutes
RelationHandler(const RelationHandler &s)
invalidated copy constructor
std::map< long long int, long long int > myStopAreas
the map from stop area member to stop_area id
NBPTStopCont * myNBPTStopCont
The previously filled pt stop container.
bool checkEdgeRef(long long int ref) const
check whether a referenced way has a corresponding edge
long long int myFromWay
the origination way for the current restriction
long long int myToWay
the destination way for the current restriction
bool applyRestriction() const
try to apply the parsed restriction and return whether successful
NBEdge * findEdgeRef(long long int wayRef, const std::vector< NBEdge * > &candidates) const
try to find the way segment among candidates
const std::map< long long int, Edge * > & myOSMEdges
The previously parsed edges.
Importer for networks stored in OpenStreetMap format.
int insertEdge(Edge *e, int index, NBNode *from, NBNode *to, const std::vector< long long int > &passed, NBNetBuilder &nb, const NBNode *first, const NBNode *last)
Builds an NBEdge.
std::map< long long int, Edge * > myEdges
the map from OSM way ids to edge objects
bool myImportCrossings
import crossings
std::map< long long int, NIOSMNode * > myOSMNodes
the map from OSM node ids to actual nodes
static void loadNetwork(const OptionsCont &oc, NBNetBuilder &nb)
Loads content of the optionally given OSM file.
static const long long int INVALID_ID
void applyLaneUse(NBEdge *e, NIImporter_OpenStreetMap::Edge *nie, const bool forward)
Applies lane use information from nie to e.
bool myOnewayDualSidewalk
import sidewalks
std::map< long long int, Edge * > myPlatformShapes
the map from OSM way ids to platform shapes
void load(const OptionsCont &oc, NBNetBuilder &nb)
void applyTurnSigns(NBEdge *e, const std::vector< int > &turnSigns)
bool myImportSidewalks
import sidewalks
std::set< NIOSMNode *, CompareNodes > myUniqueNodes
the set of unique nodes used in NodesHandler, used when freeing memory
static bool myAllAttributes
whether additional way and node attributes shall be imported
void reconstructLayerElevation(double layerElevation, NBNetBuilder &nb)
reconstruct elevation from layer info
static SUMOVehicleClass interpretTransportType(const std::string &type, NIOSMNode *toSet=nullptr)
translate osm transport designations into sumo vehicle class
int myPlacementSkippedNonExplicitOneWay
number of placement skips due to non-explicit oneway
bool myImportLaneAccess
import lane specific access restrictions
bool myImportTurnSigns
import turning signals (turn:lanes) to guide connection building
std::map< std::string, std::string > myKnownCompoundTypes
The compound types that have already been mapped to other known types.
static const std::string compoundTypeSeparator
The separator within newly created compound type names.
std::set< std::string > myUnusableTypes
The compounds types that do not contain known types.
std::map< NBNode *, std::pair< double, double > > getNeighboringNodes(NBNode *node, double maxDist, const std::set< NBNode * > &knownElevation)
collect neighboring nodes with their road distance and maximum between-speed. Search does not continu...
static std::set< std::string > myExtraAttributes
extra attributes to import
bool myImportBikeAccess
import bike path specific permissions and directions
bool myAnnotateDefaults
whether edges should carry information on the use of typemap defaults
static double interpretDistance(NIOSMNode *node)
read distance value from node and return value in m
NBNode * insertNodeChecking(long long int id, NBNodeCont &nc, NBTrafficLightLogicCont &tlsc)
Builds an NBNode.
static void mergeTurnSigns(std::vector< int > &signs, std::vector< int > signs2)
void extendRailwayDistances(Edge *e, NBTypeCont &tc)
extend kilometrage data for all nodes along railway
int myPlacementSkippedAuxOppositeDirection
number of placement skips due to generated opposite-direction auxiliary edges
std::string usableType(const std::string &type, const std::string &id, NBTypeCont &tc)
check whether the type is known or consists of known type compounds. return empty string otherwise
static void applyChangeProhibition(NBEdge *e, int changeProhibition)
A storage for options typed value containers)
Definition OptionsCont.h:89
An upper class for objects with additional parameters.
Encapsulated SAX-Attributes.
SAX-handler base for SUMO-files.
Definition json.hpp:4471
An internal representation of an OSM-node.
SVCPermissions permissions
type of pt stop
NIOSMNode & operator=(const NIOSMNode &s)=delete
invalidated assignment operator
NBNode * node
the NBNode that was instantiated
double positionMeters
position converted to m (using highest precision available)
std::string position
kilometrage/mileage
const long long int id
The node's id.
bool pedestrianCrossing
Whether this is a pedestrian crossing.
bool tlsControlled
Whether this is a tls controlled junction.
double ptStopLength
The length of the pt stop.
NIOSMNode(long long int _id, double _lon, double _lat)
bool ptStopPosition
Whether this is a public transport stop position.
std::string name
The name of the node.
bool railwayCrossing
Whether this is a railway crossing.
double ele
The elevation of this node.
bool railwayBufferStop
Whether this is a railway buffer stop.
const double lon
The longitude the node is located at.
const double lat
The latitude the node is located at.
bool railwaySignal
Whether this is a railway (main) signal.
WayType myRailDirection
Information about the direction(s) of railway usage.