Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/moveToXY/keepRoute2_parking/runner.py
169730 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
traci.start([sumolib.checkBinary("sumo"),
32
'-n', 'input_net.net.xml',
33
'-a', 'input_additional.add.xml',
34
'-r', 'input_routes.rou.xml',
35
'--keep-after-arrival', '3',
36
'--fcd-output', 'fcd.xml',
37
'--no-step-log',
38
# '-C', 'debug.sumocfg'
39
])
40
traci.simulationStep()
41
vehID = traci.vehicle.getIDList()[0]
42
43
maneuver = [
44
(-3, 0, -30),
45
(-1, -3, -30),
46
(0, -3, -30),
47
]
48
maneuverStart = None
49
maneuverDuration = len(maneuver)
50
51
while traci.simulation.getMinExpectedNumber() > 0:
52
traci.simulationStep()
53
t = traci.simulation.getTime()
54
if traci.vehicle.isStopped(vehID):
55
if maneuverStart is None:
56
maneuverStart = t
57
if t < maneuverStart + maneuverDuration:
58
pos = traci.vehicle.getPosition(vehID)
59
a = traci.vehicle.getAngle(vehID)
60
dx, dy, da = maneuver[int(t - maneuverStart)]
61
traci.vehicle.moveToXY(vehID, '', 0, pos[0] + dx, pos[1] + dy, a + da, keepRoute=2)
62
traci.simulationStep()
63
traci.simulationStep()
64
traci.simulationStep()
65
traci.simulationStep()
66
traci.close()
67
68