Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/ssm/runner.py
169689 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
traci.setLegacyGetLeader(False)
33
34
35
def checkSSM(vehID):
36
# to find junction leaders we need to look beyond brakeDist
37
leader, dist = traci.vehicle.getLeader(vehID, 200)
38
curTTC = None
39
if leader:
40
dv = traci.vehicle.getSpeed(vehID) - traci.vehicle.getSpeed(leader)
41
curTTC = (dist + traci.vehicle.getMinGap(vehID)) / dv
42
print(" veh=%s minTTC=%s maxDRAC=%s minPET=%s minPPET=%s curTTC=%s" % (
43
vehID,
44
traci.vehicle.getParameter(vehID, "device.ssm.minTTC"),
45
traci.vehicle.getParameter(vehID, "device.ssm.maxDRAC"),
46
traci.vehicle.getParameter(vehID, "device.ssm.minPET"),
47
traci.vehicle.getParameter(vehID, "device.ssm.minPPET"),
48
curTTC))
49
50
51
repeat = 2 if len(sys.argv) > 1 else 1
52
for _ in range(repeat):
53
traci.start([
54
sumolib.checkBinary('sumo'),
55
"-c", "sumo.sumocfg",
56
'--device.ssm.probability', '1',
57
])
58
for i in range(15):
59
traci.simulationStep()
60
print("step %s" % i)
61
checkSSM("ego")
62
checkSSM("leader")
63
traci.close()
64
65