Path: blob/main/tests/complex/traci/vehicle/moveToXY/multi_lane/runner.py
169776 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 # noqa2930sumoBinary = sumolib.checkBinary("sumo")31cmd = [sumoBinary,32'-n', 'input_net2.net.xml',33'--no-step-log',34# '-S', '-Q',35]3637ANGLE_UNDEF = traci.constants.INVALID_DOUBLE_VALUE38INVALID = traci.constants.INVALID_DOUBLE_VALUE3940vehID = "v0"414243def check(x, y, angle, exLane, exPos, exPosLat, comment, edgeHint="",44laneHint=0, keepRoute=1):45traci.vehicle.moveToXY(vehID, edgeHint, laneHint, x, y, angle, keepRoute)46traci.simulationStep()47x2, y2 = traci.vehicle.getPosition(vehID)48lane2 = traci.vehicle.getLaneID(vehID)49pos2 = traci.vehicle.getLanePosition(vehID)50posLat2 = traci.vehicle.getLateralLanePosition(vehID)51if (abs(x - x2) > 0.1 or52abs(y - y2) > 0.1 or53(exLane != lane2 and exLane is not None) or54(exPos is not None and abs(exPos - pos2) > 0.1) or55(exPosLat is not None and abs(exPosLat - posLat2) > 0.1)):56print(comment, ("failed: x=%s, x2=%s, y=%s, y2=%s, lane=%s, lane2=%s, pos=%s, pos2=%s " +57"posLat=%s posLat2=%s") % (x, x2, y, y2, exLane, lane2, exPos, pos2, exPosLat, posLat2))58else:59# (comment, "success")60pass61print(traci.simulation.getTime(),62" lane=%s" % lane2,63# " route=%s" % str(traci.vehicle.getRoute(vehID)),64" right=%s, %s" % traci.vehicle.getLaneChangeStatePretty(vehID, -1),65" left=%s, %s" % traci.vehicle.getLaneChangeStatePretty(vehID, 1),66" accel=%s" % traci.vehicle.getAcceleration(vehID),67" nextTLS=%s" % traci.vehicle.getNextTLS(vehID),68" leader=%s" % str(traci.vehicle.getLeader(vehID, 500)),69)707172traci.start(cmd)73traci.setLegacyGetLeader(False)74traci.simulationStep()75traci.route.add("SE", ["SC", "CE"])76traci.vehicle.add(vehID, "SE")77check(104.95, 20, ANGLE_UNDEF, None, None, None, "correct lane")78check(104.95, 30, ANGLE_UNDEF, None, None, None, "correct lane")79check(104.95, 40, ANGLE_UNDEF, None, None, None, "correct lane")80check(101.65, 50, ANGLE_UNDEF, None, None, None, "correct lane")81check(101.65, 60, ANGLE_UNDEF, None, None, None, "correct lane")82check(101.65, 70, ANGLE_UNDEF, None, None, None, "correct lane")83check(101.65, 80, ANGLE_UNDEF, None, None, None, "correct lane")84# test misleading lane hints (vehicle is on SC_1 but position is on SC_085check(104.95, 90, ANGLE_UNDEF, None, None, None, "inconsistent hint", edgeHint="SC", laneHint=1)86check(104.95, 20, ANGLE_UNDEF, None, None, None, "inconsistent hint", edgeHint="SC", laneHint=1, keepRoute=2)87traci.close()888990