Path: blob/main/tests/complex/traci/vehicle/ssm/runner.py
169689 views
#!/usr/bin/env python1# -*- coding: utf-8 -*-2# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo3# Copyright (C) 2008-2025 German Aerospace Center (DLR) and others.4# This program and the accompanying materials are made available under the5# terms of the Eclipse Public License 2.0 which is available at6# https://www.eclipse.org/legal/epl-2.0/7# This Source Code may also be made available under the following Secondary8# Licenses when the conditions for such availability set forth in the Eclipse9# Public License 2.0 are satisfied: GNU General Public License, version 210# or later which is available at11# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html12# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later1314# @file runner.py15# @author Michael Behrisch16# @author Jakob Erdmann17# @author Daniel Krajzewicz18# @date 2011-03-04192021from __future__ import print_function22from __future__ import absolute_import23import os24import sys2526if "SUMO_HOME" in os.environ:27sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))28import traci # noqa29import sumolib # noqa3031traci.setLegacyGetLeader(False)323334def checkSSM(vehID):35# to find junction leaders we need to look beyond brakeDist36leader, dist = traci.vehicle.getLeader(vehID, 200)37curTTC = None38if leader:39dv = traci.vehicle.getSpeed(vehID) - traci.vehicle.getSpeed(leader)40curTTC = (dist + traci.vehicle.getMinGap(vehID)) / dv41print(" veh=%s minTTC=%s maxDRAC=%s minPET=%s minPPET=%s curTTC=%s" % (42vehID,43traci.vehicle.getParameter(vehID, "device.ssm.minTTC"),44traci.vehicle.getParameter(vehID, "device.ssm.maxDRAC"),45traci.vehicle.getParameter(vehID, "device.ssm.minPET"),46traci.vehicle.getParameter(vehID, "device.ssm.minPPET"),47curTTC))484950repeat = 2 if len(sys.argv) > 1 else 151for _ in range(repeat):52traci.start([53sumolib.checkBinary('sumo'),54"-c", "sumo.sumocfg",55'--device.ssm.probability', '1',56])57for i in range(15):58traci.simulationStep()59print("step %s" % i)60checkSSM("ego")61checkSSM("leader")62traci.close()636465