Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/getNeighborsSublane/runner.py
169712 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 Michael Behrisch
17
# @author Jakob Erdmann
18
# @author Daniel Krajzewicz
19
# @date 2011-03-04
20
21
22
from __future__ import print_function
23
from __future__ import absolute_import
24
import os
25
import sys
26
27
if "SUMO_HOME" in os.environ:
28
sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))
29
import traci # noqa
30
import sumolib # noqa
31
32
33
def step():
34
s = traci.simulation.getTime()
35
traci.simulationStep()
36
return s
37
38
39
egoID = "ego"
40
41
42
def printNeighInfo():
43
print("Neigh infos for ego:")
44
rightFollowers = traci.vehicle.getRightFollowers(egoID)
45
print(" rightFollowers:\n %s" % sorted(rightFollowers))
46
rightLeaders = traci.vehicle.getRightLeaders(egoID)
47
print(" rightLeaders:\n %s" % sorted(rightLeaders))
48
leftFollowers = traci.vehicle.getLeftFollowers(egoID)
49
print(" leftFollowers:\n %s" % sorted(leftFollowers))
50
leftLeaders = traci.vehicle.getLeftLeaders(egoID)
51
print(" leftLeaders:\n %s" % sorted(leftLeaders))
52
rightFollowersBlocking = traci.vehicle.getRightFollowers(egoID, True)
53
print(" rightFollowers (only blocking):\n %s" % sorted(rightFollowersBlocking))
54
rightLeadersBlocking = traci.vehicle.getRightLeaders(egoID, True)
55
print(" rightLeaders (only blocking):\n %s" % sorted(rightLeadersBlocking))
56
leftFollowersBlocking = traci.vehicle.getLeftFollowers(egoID, True)
57
print(" leftFollowers (only blocking):\n %s" % sorted(leftFollowersBlocking))
58
leftLeadersBlocking = traci.vehicle.getLeftLeaders(egoID, True)
59
print(" leftLeaders (only blocking):\n %s" % sorted(leftLeadersBlocking))
60
sys.stdout.flush()
61
62
63
traci.start([sumolib.checkBinary('sumo'), "-c", "sumo.sumocfg"])
64
# ~ traci.init(port=12345)
65
66
for i in range(1):
67
print("step", step())
68
69
for vehID in traci.vehicle.getIDList():
70
traci.vehicle.changeLaneRelative(vehID, 0, 999)
71
72
for i in range(2):
73
print("step", step())
74
75
while egoID in traci.vehicle.getIDList():
76
if traci.simulation.getTime() == 10:
77
print("vehicle changes after ego")
78
traci.vehicle.changeLaneRelative("r0.0", 1, 999)
79
elif traci.simulation.getTime() == 15:
80
print("vehicle changes after ego")
81
traci.vehicle.changeLaneRelative("r0.0", -1, 999)
82
printNeighInfo()
83
print("step", step())
84
step()
85
# done
86
traci.close()
87
88