Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/simpla/statistics/runner.py
169686 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
17
# @date 2023-02-08
18
19
20
from __future__ import print_function
21
from __future__ import absolute_import
22
import os
23
import sys
24
if "SUMO_HOME" in os.environ:
25
sys.path.append(os.path.join(os.environ['SUMO_HOME'], 'tools'))
26
import traci # noqa
27
import sumolib # noqa
28
import simpla # noqa
29
from simpla import SimplaException # noqa
30
31
binary = 'sumo-gui'
32
if 'nogui' in sys.argv:
33
binary = 'sumo'
34
35
traci.start([sumolib.checkBinary(binary),
36
'-c', 'sumo.sumocfg',
37
'--step-length', '0.5'])
38
39
simpla.load("simpla.cfg.xml")
40
41
step = 0
42
platoonID = None
43
while traci.simulation.getMinExpectedNumber() > 0:
44
if step % 50 == 0:
45
if platoonID is None:
46
platoonIDs = simpla.getPlatoonIDList("left0A0")
47
if len(platoonIDs) > 0:
48
platoonID = platoonIDs[0]
49
else:
50
print("Step %d" % step)
51
print("\tsimpla platoon count: %d" % len(platoonIDs))
52
print("\tsimpla platoon leaders: %s" % ", ".join(simpla.getPlatoonLeaderIDList()))
53
print("\tsimpla platoon average length: %.2f" % simpla.getAveragePlatoonLength())
54
print("\tsimpla platoon average speed: %.2f" % simpla.getAveragePlatoonSpeed())
55
platoonInfo = simpla.getPlatoonInfo(platoonID)
56
print("\tsimpla platoon info ID %d: %s" % (platoonID, str(platoonInfo)))
57
confirmedPlatoonID = simpla.getPlatoonID(platoonInfo["members"][0])
58
print("\tsimpla platoon of vehicle %s: %d" % (platoonInfo["members"][0], confirmedPlatoonID))
59
traci.simulationStep()
60
step += 1
61
62
traci.close()
63
64