Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/gui/b50/runner.py
169689 views
1
#!/usr/bin/env python
2
# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
# Copyright (C) 2008-2025 German Aerospace Center (DLR) and others.
4
# This program and the accompanying materials are made available under the
5
# terms of the Eclipse Public License 2.0 which is available at
6
# https://www.eclipse.org/legal/epl-2.0/
7
# This Source Code may also be made available under the following Secondary
8
# Licenses when the conditions for such availability set forth in the Eclipse
9
# Public License 2.0 are satisfied: GNU General Public License, version 2
10
# or later which is available at
11
# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12
# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13
14
# @file runner.py
15
# @author Michael Behrisch
16
# @author Laura Bieker
17
# @date 2011-07-22
18
19
from __future__ import absolute_import
20
21
import os
22
import subprocess
23
import sys
24
sumoHome = os.path.abspath(
25
os.path.join(os.path.dirname(__file__), '..', '..', '..', '..'))
26
if "SUMO_HOME" in os.environ:
27
sumoHome = os.environ["SUMO_HOME"]
28
sys.path.append(os.path.join(sumoHome, "tools"))
29
import sumolib # noqa
30
import traci # noqa
31
PORT = 8765
32
33
sumoBinary = os.environ.get(
34
"GUISIM_BINARY", os.path.join(sumoHome, 'bin', 'sumo-gui'))
35
netconvertBinary = os.environ.get(
36
"NETCONVERT_BINARY", os.path.join(sumoHome, 'bin', 'netconvert'))
37
38
subprocess.call([netconvertBinary, "-n", "input_nodes.nod.xml",
39
"-e", "input_edges.edg.xml"], stdout=sys.stdout, stderr=sys.stderr)
40
p = subprocess.Popen(
41
[sumoBinary, "-c", "sumo.sumocfg", "-v", "-S", "-Q", "--remote-port", str(PORT)],
42
stdout=sys.stdout, stderr=sys.stderr)
43
traci.init(PORT)
44
traci.simulationStep(200)
45
for i in range(10):
46
for j in range(10):
47
traci.gui.screenshot('View #0', "test_%s_%s.png" % (i, j))
48
traci.simulationStep()
49
traci.close()
50
p.wait()
51
52