Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/moveToXY/elevation_sublane/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 sumolib # noqa
29
import traci # noqa
30
31
sumoBinary = sumolib.checkBinary("sumo")
32
traci.start([sumoBinary,
33
'-n', 'input_net.net.xml',
34
'--no-step-log',
35
# '-S', '-Q'
36
])
37
38
ANGLE_UNDEF = traci.constants.INVALID_DOUBLE_VALUE
39
INVALID = traci.constants.INVALID_DOUBLE_VALUE
40
vehID = "v0"
41
42
43
def check(x, y, angle, exZ, comment):
44
traci.vehicle.moveToXY(vehID, "", 0, x, y, angle, keepRoute=2)
45
traci.simulationStep()
46
x2, y2 = traci.vehicle.getPosition(vehID)
47
z2 = traci.vehicle.getPosition3D(vehID)[2]
48
if (abs(x - x2) > 0.1 or
49
abs(y - y2) > 0.1 or
50
abs(exZ - z2) > 0.1):
51
print(comment, ("failed: exZ=%s, z2=%s" % (exZ, z2)))
52
else:
53
# (comment, "success")
54
pass
55
56
57
traci.simulationStep()
58
traci.route.add("beg", ["beg"])
59
traci.vehicle.add(vehID, "beg")
60
check(50, 0, ANGLE_UNDEF, 5, "ascending beg")
61
check(150, 50, ANGLE_UNDEF, 10, "middle")
62
check(250, 100, ANGLE_UNDEF, 5, "descending end")
63
check(250, 110, ANGLE_UNDEF, 5, "outside network, use last position")
64
check(1250, 1100, ANGLE_UNDEF, 5, "far outside network, use last position")
65
traci.close()
66
67