Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/moveToXY/permissions/runner.py
169720 views
1
#!/usr/bin/env python
2
# -*- coding: utf-8 -*-
3
# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
4
# Copyright (C) 2008-2025 German Aerospace Center (DLR) and others.
5
# This program and the accompanying materials are made available under the
6
# terms of the Eclipse Public License 2.0 which is available at
7
# https://www.eclipse.org/legal/epl-2.0/
8
# This Source Code may also be made available under the following Secondary
9
# Licenses when the conditions for such availability set forth in the Eclipse
10
# Public License 2.0 are satisfied: GNU General Public License, version 2
11
# or later which is available at
12
# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
13
# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
14
15
# @file runner.py
16
# @author Jakob Erdmann
17
# @date 2017-01-23
18
19
20
from __future__ import print_function
21
from __future__ import absolute_import
22
import os
23
import sys
24
25
if "SUMO_HOME" in os.environ:
26
sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))
27
28
import traci # noqa
29
import sumolib # noqa
30
31
ANGLE_UNDEF = traci.constants.INVALID_DOUBLE_VALUE
32
INVALID = traci.constants.INVALID_DOUBLE_VALUE
33
34
vehID = "v0"
35
36
37
def check(mode, x, y, angle, exLane, exPos, exPosLat, comment):
38
traci.vehicle.moveToXY(vehID, "", 0, x, y, angle, keepRoute=mode)
39
traci.simulationStep()
40
x2, y2 = traci.vehicle.getPosition(vehID)
41
lane2 = traci.vehicle.getLaneID(vehID)
42
pos2 = traci.vehicle.getLanePosition(vehID)
43
posLat2 = traci.vehicle.getLateralLanePosition(vehID)
44
exactXY = mode & 2 != 0
45
if (
46
(exactXY and abs(x - x2) > 0.1)
47
or (exactXY and abs(y - y2) > 0.1)
48
or exLane != lane2
49
or (exPos is not None and abs(exPos - pos2) > 0.1)
50
or (exPosLat is not None and abs(exPosLat - posLat2) > 0.1)):
51
print(comment, ("failed: mode=%s x=%s, x2=%s, y=%s, y2=%s, lane=%s, lane2=%s, pos=%s, pos2=%s " +
52
"posLat=%s posLat2=%s") % (mode, x, x2, y, y2, exLane, lane2, exPos, pos2, exPosLat, posLat2))
53
else:
54
# (comment, "success")
55
pass
56
57
58
traci.start([sumolib.checkBinary("sumo"), '-n', 'input_net.net.xml', '--no-step-log'])
59
traci.simulationStep()
60
traci.route.add("beg", ["beg"])
61
traci.vehicle.add(vehID, "beg")
62
check(1, 40, 1, 0, "beg_1", 40, 0.0, "left lane")
63
check(2, 40, -1.5, 0, "", None, None, "no valid lane at pos (permissions)")
64
check(1, 40, -1.5, 0, "beg_1", 40, 0.0, "shifted to left lane (permissions)")
65
check(2, 40, -1.5, 0, "", None, None, "no valid lane at pos (permissions)")
66
check(5, 40, -1.6, 0, "beg_0", 40, 0.0, "right lane (ignore permissions)")
67
check(2, 40, -1.5, 0, "", None, None, "no valid lane at pos (permissions)")
68
check(6, 40, -1.6, 0, "beg_0", 40, 0.0, "right lane (ignore permissions)")
69
check(2, 40, -1.5, 0, "", None, None, "no valid lane at pos (permissions)")
70
print("vehicleList", traci.vehicle.getIDList())
71
traci.close()
72
73