Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/moveTo/controller_loop/runner.py
169771 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 2017-01-23
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
WATCH = False
32
TS = 1.0
33
34
sumoBinary = sumolib.checkBinary("sumo")
35
cmd = [
36
sumoBinary,
37
'-n', 'input_net.net.xml',
38
'-r', 'input_routes.rou.xml',
39
'--step-length', str(TS),
40
'--fcd-output', 'fcd.xml',
41
'--no-step-log', ]
42
if not WATCH:
43
cmd += ['-S', '-Q']
44
45
traci.start(cmd)
46
47
vehID = "ego"
48
vehInSim = False
49
50
while traci.simulation.getMinExpectedNumber() > 0:
51
traci.simulationStep()
52
t = traci.simulation.getTime()
53
if vehID in traci.simulation.getDepartedIDList():
54
vehInSim = True
55
if vehID in traci.simulation.getArrivedIDList():
56
vehInSim = False
57
if vehInSim:
58
v = traci.vehicle.getSpeed(vehID)
59
laneID = traci.vehicle.getLaneID(vehID)
60
lanePos = traci.vehicle.getLanePosition(vehID)
61
# if the speed is sufficiently high, we'll make it drive a bit slower
62
# (retroactively)
63
DELTA_V = 1
64
if v > DELTA_V:
65
v2 = v - DELTA_V
66
lanePos2 = lanePos - TS * DELTA_V
67
if lanePos2 < 0:
68
print("not using full DELTA_V at time %s (pending #11081)" % t)
69
lanePos2 = 0
70
# we could also traverse the network graph to determine the
71
# previous/next lane ourselves.
72
print(v, v2)
73
traci.vehicle.moveTo(vehID, laneID, lanePos2)
74
traci.vehicle.setPreviousSpeed(vehID, v2)
75
76
traci.close()
77
78