Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/connection/multiconnect/runner.py
169689 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 Michael Behrisch
17
# @author Daniel Krajzewicz
18
# @date 2011-03-04
19
20
21
from __future__ import print_function
22
from __future__ import absolute_import
23
import os
24
import sys
25
SUMO_HOME = os.environ.get('SUMO_HOME',
26
os.path.join(os.path.dirname(os.path.abspath(__file__)), '..', '..', '..', '..', '..'))
27
sys.path.append(os.path.join(SUMO_HOME, 'tools'))
28
import traci # noqa
29
import sumolib # noqa
30
31
sumoBinary = sumolib.checkBinary('sumo')
32
conns = []
33
sumoProcess = []
34
try:
35
for i in range(2):
36
traci.start([sumoBinary, "-c", "sumo.sumocfg"], label=str(i))
37
conns.append(traci.getConnection(str(i)))
38
for c in conns:
39
for step in range(3):
40
print("step", step)
41
c.simulationStep()
42
for c in conns:
43
print("routes", c.route.getIDList())
44
print("route count", c.route.getIDCount())
45
routeID = "horizontal"
46
print("examining", routeID)
47
print("edges", c.route.getEdges(routeID))
48
c.route.subscribe(routeID)
49
for c in conns:
50
print(c.route.getSubscriptionResults(routeID))
51
for step in range(3, 6):
52
print("step", step)
53
c.simulationStep(step)
54
print(c.route.getSubscriptionResults(routeID))
55
c.route.add("h2", ["1o"])
56
print("routes", c.route.getIDList())
57
print("edges", c.route.getEdges("h2"))
58
c.close()
59
except Exception:
60
traci.close()
61
raise
62
63