Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/bugs/ticket4642/runner.py
169715 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
import os
20
import sys
21
22
if "SUMO_HOME" in os.environ:
23
sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))
24
25
import traci # noqa
26
import sumolib # noqa
27
28
sumoBinary = sumolib.checkBinary('sumo')
29
traci.start([sumoBinary,
30
"-n", "input_net.net.xml", "-r",
31
"input_routes.rou.xml",
32
"--no-step-log",
33
])
34
35
vehHasLeft = False
36
vehHasArrived = False
37
vehID = 'v1'
38
route = []
39
step = 0
40
resultList = [("step", "currentEdge", "targetEdge", "distoToTargetEdge")]
41
42
while not vehHasLeft:
43
if not vehHasArrived:
44
arrivedVehicles = traci.simulation.getDepartedIDList()
45
vehHasArrived = vehID in arrivedVehicles
46
route = traci.vehicle.getRoute(vehID)
47
48
if vehHasArrived:
49
target = route[-1]
50
remainingDist = traci.vehicle.getDrivingDistance(vehID, target, 0.0)
51
currentEdge = traci.vehicle.getRoadID(vehID)
52
vehHasLeft = currentEdge == route[-1]
53
resultList.append((str(step), currentEdge, target, str(remainingDist)))
54
target = ":gneJ1_2"
55
remainingDist = traci.vehicle.getDrivingDistance(vehID, target, 0.0)
56
resultList.append((str(step), currentEdge, target, str(remainingDist)))
57
target = ":gneJ1_3"
58
remainingDist = traci.vehicle.getDrivingDistance(vehID, target, 0.0)
59
resultList.append((str(step), currentEdge, target, str(remainingDist)))
60
step += 1
61
traci.simulationStep()
62
traci.close()
63
64
# print distance to target edge of the vehicle's route
65
for line in resultList:
66
print("%s" % ";".join(line))
67
68