Path: blob/main/tests/tools/sumolib/net_intermodal/runner.py
428384 views
#!/usr/bin/env python1# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo2# Copyright (C) 2008-2026 German Aerospace Center (DLR) and others.3# This program and the accompanying materials are made available under the4# terms of the Eclipse Public License 2.0 which is available at5# https://www.eclipse.org/legal/epl-2.0/6# This Source Code may also be made available under the following Secondary7# Licenses when the conditions for such availability set forth in the Eclipse8# Public License 2.0 are satisfied: GNU General Public License, version 29# or later which is available at10# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html11# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later1213# @file runner.py14# @author Jakob Erdmann15# @date1617from __future__ import absolute_import18from __future__ import print_function192021import os22import sys23if 'SUMO_HOME' in os.environ:24tools = os.path.join(os.environ['SUMO_HOME'], 'tools')25sys.path.append(tools)26else:27sys.exit("please declare environment variable 'SUMO_HOME'")28import sumolib.net # noqa293031def printSorted(d):32return ' '.join(["%s:%s" % (k, d[k]) for k in sorted(d.keys())])333435net = sumolib.net.readNet(sys.argv[1], withInternal=True, withLatestPrograms=True)36print("list of all edges")37for edge in net.getEdges():38print(edge.getID())3940print("list of internal edgeIDs of node 'C' (attribute)")41for edgeID in net.getNode("C").getInternal():42print(edgeID)4344print("list of internal edgeIDs of node 'C' (complete)")45node = net.getNode("C")46for edge in net.getEdges():47if edge.getFromNode() == node and edge.getToNode() == node:48print(edge.getID())4950for laneID in ["SC_0", ":C_w2_0"]:51lane = net.getLane(laneID)52print("connections from %s:\n%s" % (53lane.getID(),54'\n'.join(list(map(str, lane.getOutgoing())))))55print("outgoing internal lanes of %s: %s" % (56lane.getID(), ' '.join(57[net.getLane(c.getViaLaneID()).getID()58if c.getViaLaneID() != "" else ""59for c in lane.getOutgoing()])))6061for laneID in ["CN_0", ":C_w2_0"]:62lane2 = net.getLane(laneID)63print("lanes to %s: %s" % (lane2.getID(), ' '.join(sorted([li.getID() for li in lane2.getIncoming()]))))6465internal_edge = net.getEdge(":C_0")66internal_lane = net.getLane(":C_0_0")67internal_lane_cons = internal_lane.getOutgoing()68print("connections from %s:\n%s" % (internal_lane.getID(),69'\n'.join(map(str, internal_lane_cons))))70internal_lane_incoming = sorted(internal_lane.getIncoming())71print("lanes to %s: %s" % (internal_lane.getID(),72' '.join([li.getID() for li in internal_lane_incoming])))73assert internal_edge.getFunction() == 'internal'74assert internal_edge.isSpecial()75assert internal_lane.getEdge().isSpecial()76assert internal_edge.getFromNode().getID() == "C"77assert internal_edge.getToNode().getID() == "C"7879# params80print("edgeParams", printSorted(net.getEdge("CE").getParams()))81print("laneParams", printSorted(net.getLane("CE_0").getParams()))82print("laneParams", printSorted(net.getLane("CE_1").getParams()))83print("junctionParams", printSorted(net.getNode("C").getParams()))84print("tlsParams", printSorted(net.getTLS("C").getPrograms()["0"].getParams()))8586# functions87print("getNeighboringEdges", ' '.join(sorted([e.getID() for e, _ in net.getNeighboringEdges(100, 0, 10)])))88print("getNeighboringLanes", ' '.join(sorted([ln.getID() for ln, _ in net.getNeighboringLanes(100, 0, 10)])))89print("getNeighboringNodes only for incoming edges",90' '.join(sorted([n.getID() for n in net.getNode("N").getNeighboringNodes(False, True)])))91print("getNeighboringNodes only for outgoing edges",92' '.join(sorted([n.getID() for n in net.getNode("S").getNeighboringNodes(True, False)])))93print("getNeighboringNodes", ' '.join(sorted([n.getID() for n in net.getNode("C").getNeighboringNodes()])))949596