Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/bugs/ticket4563/runner.py
169708 views
1
#!/usr/bin/env python
2
# -*- coding: utf-8 -*-
3
# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
4
# Copyright (C) 2008-2025 German Aerospace Center (DLR) and others.
5
# This program and the accompanying materials are made available under the
6
# terms of the Eclipse Public License 2.0 which is available at
7
# https://www.eclipse.org/legal/epl-2.0/
8
# This Source Code may also be made available under the following Secondary
9
# Licenses when the conditions for such availability set forth in the Eclipse
10
# Public License 2.0 are satisfied: GNU General Public License, version 2
11
# or later which is available at
12
# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
13
# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
14
15
# @file runner.py
16
# @author Jakob Erdmann
17
# @date 2011-03-04
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
28
import traci # noqa
29
import sumolib # noqa
30
31
32
def step():
33
s = traci.simulation.getTime()
34
traci.simulationStep()
35
return s
36
37
38
traci.start([sumolib.checkBinary('sumo'),
39
"-n", "input_net.net.xml",
40
"-r", "input_routes.rou.xml",
41
"--no-step-log",
42
"--fcd-output", "fcd.xml",
43
"--fcd-output.signals",
44
"--step-length", "0.2",
45
"--default.speeddev", "0",
46
])
47
48
lead = "lead"
49
follow = "follow"
50
51
changeDist = 10
52
tryChangeTime = None
53
tryChangeDuration = 5
54
55
for i in range(10000):
56
step()
57
dist = traci.vehicle.getLanePosition(lead) - traci.vehicle.getLanePosition(follow)
58
if dist < changeDist:
59
print("requesting changeLane down for vehicle '%s' at time %s. Remaining distance: %s" %
60
(follow, traci.simulation.getTime(), dist))
61
traci.vehicle.changeLane(follow, 0, tryChangeDuration)
62
tryChangeTime = traci.simulation.getTime()
63
break
64
65
while traci.simulation.getMinExpectedNumber() > 0 and traci.vehicle.getLaneIndex(follow) > 0:
66
t = step()
67
if (t - tryChangeTime) > tryChangeDuration:
68
# failed. try again
69
print("requesting changeLane down for vehicle '%s' at time %s. Remaining distance: %s" %
70
(follow, traci.simulation.getTime(), dist))
71
traci.vehicle.changeLane(follow, 0, tryChangeDuration)
72
tryChangeTime = traci.simulation.getTime()
73
74
# done
75
step()
76
traci.close()
77
78