Path: blob/main/tests/complex/traci/vehicle/changeSublane/runner.py
169713 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 2018-09-271718import os19import sys2021if "SUMO_HOME" in os.environ:22sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))2324import traci # noqa25import sumolib # noqa2627sumoBinary = sumolib.checkBinary('sumo')28traci.start([sumoBinary,29"-n", "input_net.net.xml",30"-r", "input_routes.rou.xml",31"--lanechange-output", "lanechanges.xml",32"--lateral-resolution", "0.8",33"--no-step-log",34])3536departLane = sys.argv[1]37latDist = float(sys.argv[2])383940def reportState(vehID):41print("t=%s laneIndex=%s posLat=%s state(-1)=%s state(0)=%s state(1)=%s" % (42traci.simulation.getTime(),43traci.vehicle.getLaneIndex(vehID),44traci.vehicle.getLateralLanePosition(vehID),45traci.vehicle.getLaneChangeStatePretty(vehID, -1),46traci.vehicle.getLaneChangeStatePretty(vehID, 0),47traci.vehicle.getLaneChangeStatePretty(vehID, 1)))484950vehID = "v0"51traci.vehicle.add(vehID, "r0", departLane=departLane)52traci.vehicle.setLaneChangeMode(vehID, 0)53for i in range(5):54traci.simulationStep()55traci.vehicle.setParameter(vehID, "lcReason", " sublane_3.2")56traci.vehicle.changeSublane(vehID, latDist)5758while traci.simulation.getMinExpectedNumber() > 0:59reportState(vehID)60traci.simulationStep()6162traci.close()636465