Path: blob/main/tests/complex/traci/vehicle/changeLane/basic/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 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"--no-step-log",33])343536def reportState(vehID, direction):37if vehID in traci.vehicle.getIDList():38print("t=%s laneIndex=%s state(%s)=%s" % (39traci.simulation.getTime(),40traci.vehicle.getLaneIndex(vehID),41direction,42traci.vehicle.getLaneChangeStatePretty(vehID, direction)))43else:44print("t=%s (vehicle missing)" % (traci.simulation.getTime()))454647vehID = "v0"48traci.vehicle.add(vehID, "r0")49traci.vehicle.setLaneChangeMode(vehID, 0)50for i in range(5):51traci.simulationStep()52traci.vehicle.setParameter(vehID, "lcReason", " relativeRight")53traci.vehicle.changeLaneRelative(vehID, 1, 3)54for i in range(5):55reportState(vehID, 1)56reportState(vehID, -1)57traci.simulationStep()58traci.vehicle.setParameter(vehID, "lcReason", " relativeLeft")59traci.vehicle.changeLaneRelative(vehID, -1, 0)60for i in range(5):61reportState(vehID, -1)62traci.simulationStep()63traci.vehicle.setParameter(vehID, "lcReason", " absolute2")64traci.vehicle.changeLane(vehID, 2, 5)65for i in range(5):66reportState(vehID, -1)67traci.simulationStep()6869traci.close()707172