Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/tools/sumolib/getFastestRoute/runner.py
428387 views
1
#!/usr/bin/env python
2
# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
# Copyright (C) 2008-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
14
# @file runner.py
15
# @author Jakob Erdmann
16
# @author Matthias Schwamborn
17
# @date
18
19
from __future__ import absolute_import
20
from __future__ import print_function
21
22
import os
23
import sys
24
if 'SUMO_HOME' in os.environ:
25
tools = os.path.join(os.environ['SUMO_HOME'], 'tools')
26
sys.path.append(tools)
27
else:
28
sys.exit("please declare environment variable 'SUMO_HOME'")
29
import sumolib # noqa
30
31
net = sumolib.net.readNet(sys.argv[1], withInternal=True, withLatestPrograms=True)
32
SC = net.getEdge("SC")
33
CE = net.getEdge("CE")
34
print("%s %.2f" % net.getFastestPath(SC, CE))
35
route = net.getFastestPath(SC, CE, vClass="passenger")
36
print("%s %.2f" % route)
37
print("%s %.2f" % net.getFastestPath(SC, CE, vClass="bus"))
38
print("%s %.2f" % net.getFastestPath(SC, CE, withInternal=True))
39
route2 = net.getFastestPath(SC, CE, vClass="passenger", withInternal=True)
40
print("%s %.2f" % route2)
41
routeA = tuple(sumolib.route.addInternal(net, route[0]))
42
print(routeA, routeA == route2[0])
43
print("%s %.2f" % net.getFastestPath(net.getEdge(":C_12"), CE))
44
print("%s %.2f" % net.getFastestPath(net.getEdge(":C_22"), CE))
45
print("%s %.2f" % net.getFastestPath(SC, net.getEdge(":C_15")))
46
print("%s %.2f" % net.getFastestPath(net.getEdge(":C_12"), net.getEdge(":C_15")))
47
print("%s %.2f" % net.getFastestPath(CE, SC))
48
print("%s %.2f" % net.getFastestPath(CE, SC, ignoreDirection=True))
49
50
net = sumolib.net.readNet(sys.argv[2], withInternal=True, withLatestPrograms=True)
51
print("%s %.2f" % net.getFastestPath(net.getEdge("beg"), net.getEdge("rend")))
52
print("%s %.2f" % net.getFastestPath(net.getEdge("rend"), net.getEdge("beg"), ignoreDirection=True))
53
print("%s %.2f" % net.getFastestPath(net.getEdge("rend"), net.getEdge("beg")))
54
print("%s %.2f" % net.getFastestPath(net.getEdge("beg2left"), net.getEdge("rend")))
55
print("%s %.2f" % net.getFastestPath(net.getEdge("rend"), net.getEdge("beg2left"), ignoreDirection=True))
56
57