Path: blob/main/tests/complex/simpla/statistics/runner.py
169686 views
#!/usr/bin/env python1# -*- coding: utf-8 -*-2# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo3# Copyright (C) 2008-2025 German Aerospace Center (DLR) and others.4# This program and the accompanying materials are made available under the5# terms of the Eclipse Public License 2.0 which is available at6# https://www.eclipse.org/legal/epl-2.0/7# This Source Code may also be made available under the following Secondary8# Licenses when the conditions for such availability set forth in the Eclipse9# Public License 2.0 are satisfied: GNU General Public License, version 210# or later which is available at11# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html12# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later1314# @file runner.py15# @author Mirko Barthauer16# @date 2023-02-08171819from __future__ import print_function20from __future__ import absolute_import21import os22import sys23if "SUMO_HOME" in os.environ:24sys.path.append(os.path.join(os.environ['SUMO_HOME'], 'tools'))25import traci # noqa26import sumolib # noqa27import simpla # noqa28from simpla import SimplaException # noqa2930binary = 'sumo-gui'31if 'nogui' in sys.argv:32binary = 'sumo'3334traci.start([sumolib.checkBinary(binary),35'-c', 'sumo.sumocfg',36'--step-length', '0.5'])3738simpla.load("simpla.cfg.xml")3940step = 041platoonID = None42while traci.simulation.getMinExpectedNumber() > 0:43if step % 50 == 0:44if platoonID is None:45platoonIDs = simpla.getPlatoonIDList("left0A0")46if len(platoonIDs) > 0:47platoonID = platoonIDs[0]48else:49print("Step %d" % step)50print("\tsimpla platoon count: %d" % len(platoonIDs))51print("\tsimpla platoon leaders: %s" % ", ".join(simpla.getPlatoonLeaderIDList()))52print("\tsimpla platoon average length: %.2f" % simpla.getAveragePlatoonLength())53print("\tsimpla platoon average speed: %.2f" % simpla.getAveragePlatoonSpeed())54platoonInfo = simpla.getPlatoonInfo(platoonID)55print("\tsimpla platoon info ID %d: %s" % (platoonID, str(platoonInfo)))56confirmedPlatoonID = simpla.getPlatoonID(platoonInfo["members"][0])57print("\tsimpla platoon of vehicle %s: %d" % (platoonInfo["members"][0], confirmedPlatoonID))58traci.simulationStep()59step += 16061traci.close()626364