Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/vehicle/moveTo/moveTo_detector/runner.py
169772 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 Mirko Barthauer (Technische Universitaet Braunschweig)
17
# @date 2018-09-27
18
19
from __future__ import print_function
20
import os
21
import sys
22
23
if "SUMO_HOME" in os.environ:
24
sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))
25
26
import traci # noqa
27
import sumolib # noqa
28
import traci.constants as tc # noqa
29
30
sumoBinary = sumolib.checkBinary('sumo')
31
traci.start([sumoBinary,
32
"-n", "input_net2.net.xml",
33
"-r", "input_routes.rou.xml",
34
"-a", "input_additional.add.xml",
35
"--no-step-log",
36
] + sys.argv[1:])
37
38
vehID = "v0"
39
40
while traci.simulation.getMinExpectedNumber() > 0:
41
t = traci.simulation.getTime()
42
if t == 10:
43
# move onto detector (automatic -> teleport)
44
traci.vehicle.moveTo(vehID, "WC_1", 50)
45
if t == 50:
46
# move onto detector (normal)
47
traci.vehicle.moveTo(vehID, "WC_1", 50, tc.MOVE_NORMAL)
48
if t == 60:
49
# move close to detector
50
traci.vehicle.moveTo(vehID, "CW_1", 80)
51
# move onto detector (automatic -> normal)
52
traci.vehicle.moveTo(vehID, "WC_1", 10)
53
if t == 70:
54
# move close to detector
55
traci.vehicle.moveTo(vehID, "CW_1", 80)
56
# move onto detector (teleport)
57
traci.vehicle.moveTo(vehID, "WC_1", 10, tc.MOVE_TELEPORT)
58
traci.simulationStep()
59
60
61
traci.close()
62
63