Path: blob/main/tests/complex/traci/vehicle/moveToXY/elevation_sublane/runner.py
169720 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 sumolib # noqa28import traci # noqa2930sumoBinary = sumolib.checkBinary("sumo")31traci.start([sumoBinary,32'-n', 'input_net.net.xml',33'--no-step-log',34# '-S', '-Q'35])3637ANGLE_UNDEF = traci.constants.INVALID_DOUBLE_VALUE38INVALID = traci.constants.INVALID_DOUBLE_VALUE39vehID = "v0"404142def check(x, y, angle, exZ, comment):43traci.vehicle.moveToXY(vehID, "", 0, x, y, angle, keepRoute=2)44traci.simulationStep()45x2, y2 = traci.vehicle.getPosition(vehID)46z2 = traci.vehicle.getPosition3D(vehID)[2]47if (abs(x - x2) > 0.1 or48abs(y - y2) > 0.1 or49abs(exZ - z2) > 0.1):50print(comment, ("failed: exZ=%s, z2=%s" % (exZ, z2)))51else:52# (comment, "success")53pass545556traci.simulationStep()57traci.route.add("beg", ["beg"])58traci.vehicle.add(vehID, "beg")59check(50, 0, ANGLE_UNDEF, 5, "ascending beg")60check(150, 50, ANGLE_UNDEF, 10, "middle")61check(250, 100, ANGLE_UNDEF, 5, "descending end")62check(250, 110, ANGLE_UNDEF, 5, "outside network, use last position")63check(1250, 1100, ANGLE_UNDEF, 5, "far outside network, use last position")64traci.close()656667