Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/changeLane_subLane/basic/runner.py
169743 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 2018-09-27
18
19
import os
20
import sys
21
22
if "SUMO_HOME" in os.environ:
23
sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))
24
25
import traci # noqa
26
import sumolib # noqa
27
28
sumoBinary = sumolib.checkBinary('sumo')
29
traci.start([sumoBinary,
30
"-n", "input_net.net.xml",
31
"-r", "input_routes.rou.xml",
32
"--lanechange-output", "lanechanges.xml",
33
"--lateral-resolution", "0.8",
34
"--no-step-log",
35
])
36
37
38
def reportState(vehID):
39
print("t=%s laneIndex=%s\n R=%s\n C=%s\n L=%s" % (
40
traci.simulation.getTime(),
41
traci.vehicle.getLaneIndex(vehID),
42
traci.vehicle.getLaneChangeStatePretty(vehID, -1),
43
traci.vehicle.getLaneChangeStatePretty(vehID, 0),
44
traci.vehicle.getLaneChangeStatePretty(vehID, 1)))
45
46
47
vehID = "v0"
48
traci.vehicle.add(vehID, "r0")
49
traci.vehicle.setLaneChangeMode(vehID, 0)
50
for i in range(5):
51
traci.simulationStep()
52
traci.vehicle.setParameter(vehID, "lcReason", " relativeRight")
53
traci.vehicle.changeLaneRelative(vehID, 1, 3)
54
for i in range(5):
55
reportState(vehID)
56
traci.simulationStep()
57
traci.vehicle.setParameter(vehID, "lcReason", " relativeLeft")
58
traci.vehicle.changeLaneRelative(vehID, -1, 3)
59
for i in range(5):
60
reportState(vehID)
61
traci.simulationStep()
62
traci.vehicle.setParameter(vehID, "lcReason", " absolute2")
63
traci.vehicle.changeLane(vehID, 2, 7)
64
for i in range(10):
65
reportState(vehID)
66
traci.simulationStep()
67
68
print(traci.vehicle.getParameter(vehID, "laneChangeModel.minGapLat"))
69
traci.vehicle.setParameter(vehID, "laneChangeModel.minGapLat", "0.1")
70
print(traci.vehicle.getParameter(vehID, "laneChangeModel.minGapLat"))
71
72
traci.close()
73
74