Path: blob/main/tests/complex/traci/vehicle/moveTo/controller_loop/runner.py
169771 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 Jakob Erdmann16# @date 2017-01-23171819from __future__ import print_function20from __future__ import absolute_import21import os22import sys2324if "SUMO_HOME" in os.environ:25sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))2627import traci # noqa28import sumolib # noqa2930WATCH = False31TS = 1.03233sumoBinary = sumolib.checkBinary("sumo")34cmd = [35sumoBinary,36'-n', 'input_net.net.xml',37'-r', 'input_routes.rou.xml',38'--step-length', str(TS),39'--fcd-output', 'fcd.xml',40'--no-step-log', ]41if not WATCH:42cmd += ['-S', '-Q']4344traci.start(cmd)4546vehID = "ego"47vehInSim = False4849while traci.simulation.getMinExpectedNumber() > 0:50traci.simulationStep()51t = traci.simulation.getTime()52if vehID in traci.simulation.getDepartedIDList():53vehInSim = True54if vehID in traci.simulation.getArrivedIDList():55vehInSim = False56if vehInSim:57v = traci.vehicle.getSpeed(vehID)58laneID = traci.vehicle.getLaneID(vehID)59lanePos = traci.vehicle.getLanePosition(vehID)60# if the speed is sufficiently high, we'll make it drive a bit slower61# (retroactively)62DELTA_V = 163if v > DELTA_V:64v2 = v - DELTA_V65lanePos2 = lanePos - TS * DELTA_V66if lanePos2 < 0:67print("not using full DELTA_V at time %s (pending #11081)" % t)68lanePos2 = 069# we could also traverse the network graph to determine the70# previous/next lane ourselves.71print(v, v2)72traci.vehicle.moveTo(vehID, laneID, lanePos2)73traci.vehicle.setPreviousSpeed(vehID, v2)7475traci.close()767778