Path: blob/main/tests/complex/traci/vehicle/changeLane_subLane/basic/runner.py
169743 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])353637def reportState(vehID):38print("t=%s laneIndex=%s\n R=%s\n C=%s\n L=%s" % (39traci.simulation.getTime(),40traci.vehicle.getLaneIndex(vehID),41traci.vehicle.getLaneChangeStatePretty(vehID, -1),42traci.vehicle.getLaneChangeStatePretty(vehID, 0),43traci.vehicle.getLaneChangeStatePretty(vehID, 1)))444546vehID = "v0"47traci.vehicle.add(vehID, "r0")48traci.vehicle.setLaneChangeMode(vehID, 0)49for i in range(5):50traci.simulationStep()51traci.vehicle.setParameter(vehID, "lcReason", " relativeRight")52traci.vehicle.changeLaneRelative(vehID, 1, 3)53for i in range(5):54reportState(vehID)55traci.simulationStep()56traci.vehicle.setParameter(vehID, "lcReason", " relativeLeft")57traci.vehicle.changeLaneRelative(vehID, -1, 3)58for i in range(5):59reportState(vehID)60traci.simulationStep()61traci.vehicle.setParameter(vehID, "lcReason", " absolute2")62traci.vehicle.changeLane(vehID, 2, 7)63for i in range(10):64reportState(vehID)65traci.simulationStep()6667print(traci.vehicle.getParameter(vehID, "laneChangeModel.minGapLat"))68traci.vehicle.setParameter(vehID, "laneChangeModel.minGapLat", "0.1")69print(traci.vehicle.getParameter(vehID, "laneChangeModel.minGapLat"))7071traci.close()727374