Path: blob/main/tests/tools/sumolib/getFastestRoute/runner.py
428387 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# @author Matthias Schwamborn16# @date1718from __future__ import absolute_import19from __future__ import print_function2021import 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 # noqa2930net = sumolib.net.readNet(sys.argv[1], withInternal=True, withLatestPrograms=True)31SC = net.getEdge("SC")32CE = net.getEdge("CE")33print("%s %.2f" % net.getFastestPath(SC, CE))34route = net.getFastestPath(SC, CE, vClass="passenger")35print("%s %.2f" % route)36print("%s %.2f" % net.getFastestPath(SC, CE, vClass="bus"))37print("%s %.2f" % net.getFastestPath(SC, CE, withInternal=True))38route2 = net.getFastestPath(SC, CE, vClass="passenger", withInternal=True)39print("%s %.2f" % route2)40routeA = tuple(sumolib.route.addInternal(net, route[0]))41print(routeA, routeA == route2[0])42print("%s %.2f" % net.getFastestPath(net.getEdge(":C_12"), CE))43print("%s %.2f" % net.getFastestPath(net.getEdge(":C_22"), CE))44print("%s %.2f" % net.getFastestPath(SC, net.getEdge(":C_15")))45print("%s %.2f" % net.getFastestPath(net.getEdge(":C_12"), net.getEdge(":C_15")))46print("%s %.2f" % net.getFastestPath(CE, SC))47print("%s %.2f" % net.getFastestPath(CE, SC, ignoreDirection=True))4849net = sumolib.net.readNet(sys.argv[2], withInternal=True, withLatestPrograms=True)50print("%s %.2f" % net.getFastestPath(net.getEdge("beg"), net.getEdge("rend")))51print("%s %.2f" % net.getFastestPath(net.getEdge("rend"), net.getEdge("beg"), ignoreDirection=True))52print("%s %.2f" % net.getFastestPath(net.getEdge("rend"), net.getEdge("beg")))53print("%s %.2f" % net.getFastestPath(net.getEdge("beg2left"), net.getEdge("rend")))54print("%s %.2f" % net.getFastestPath(net.getEdge("rend"), net.getEdge("beg2left"), ignoreDirection=True))555657