Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tools/purgatory/accelerations.py
169674 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 accelerations.py
16
# @author Jakob Erdmann
17
# @date 2012-11-20
18
19
from __future__ import absolute_import
20
from __future__ import print_function
21
import os
22
import sys
23
sys.path.append(os.path.join(os.path.dirname(sys.argv[0]), '..'))
24
from sumolib.output import parse_fast # noqa
25
from sumolib.miscutils import Statistics # noqa
26
27
28
def accelStats(netstate):
29
lastSpeed = {}
30
stats = Statistics("Accelerations", histogram=True, printMin=True, scale=0.2)
31
for vehicle in parse_fast(netstate, 'vehicle', ['id', 'speed']):
32
speed = float(vehicle.speed)
33
prevSpeed = lastSpeed.get(vehicle.id, speed)
34
stats.add(speed - prevSpeed, (vehicle.id, vehicle.speed))
35
lastSpeed[vehicle.id] = speed
36
print(stats)
37
38
39
if __name__ == "__main__":
40
if len(sys.argv) != 2:
41
sys.exit("call %s <netstate-dump>" % sys.argv[0])
42
accelStats(sys.argv[1])
43
44