Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/distance_after_reroute/runner.py
169689 views
1
#!/usr/bin/env python
2
# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
# Copyright (C) 2008-2025 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 Laura Bieker
16
# @author Michael Behrisch
17
# @date 2014-08-28
18
19
20
from __future__ import print_function
21
from __future__ import absolute_import
22
import os
23
import sys
24
25
if "SUMO_HOME" in os.environ:
26
sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))
27
import traci # noqa
28
import sumolib # noqa
29
30
31
def main(args):
32
traci.start([sumolib.checkBinary('sumo'), "-c", "data/hello.sumocfg",
33
"--netstate-dump", "rawdump.xml",
34
"--no-step-log"] + sys.argv[1:])
35
36
for step in range(162):
37
traci.simulationStep()
38
if step == 120:
39
print(traci.vehicle.getDistance('Stapler_00'))
40
traci.vehicle.setRoute('Stapler_00', ('ed1', 'ed5'))
41
print(traci.vehicle.getRoute('Stapler_00'))
42
# assert traci.vehicle.getRoute('Stapler_00') == ('ed0', 'ed1', 'ed5')
43
print(traci.vehicle.getDistance('Stapler_00'))
44
if step == 122:
45
# assert traci.vehicle.getRoute('Stapler_00') == ('ed0', 'ed1', 'ed5')
46
print(traci.vehicle.getDistance('Stapler_00'))
47
traci.vehicle.setRouteID('Stapler_00', "short")
48
print(traci.vehicle.getRoute('Stapler_00'))
49
print(traci.vehicle.getDistance('Stapler_00'))
50
# We assume, that we reach an internal lane at step 130,
51
# if distance calc is correct, there should be a
52
# 10m distance difference between the
53
# output of step 129 and 130
54
if step in (129, 130):
55
print(step, round(traci.vehicle.getDistance('Stapler_00'), 2))
56
traci.close()
57
58
59
if __name__ == "__main__":
60
main(sys.argv[1:])
61
62