from __future__ import absolute_import
import os
import sys
from collections import defaultdict
sys.path.append(os.path.join(os.path.dirname(sys.argv[0]), '..'))
from sumolib.output import parse
from sumolib.options import ArgumentParser
def parse_args():
optParser = ArgumentParser()
optParser.add_argument("netstate", help="Netstate Dump File")
optParser.add_argument("out", help="Output file")
return optParser.parse_args()
def trackLanes(netstate, out):
laneTimes = defaultdict(list)
laneChanges = defaultdict(lambda: 0)
lastEdge = defaultdict(lambda: None)
arrivals = {}
running = set()
with open(out, 'w') as f:
f.write("<vehLanes>\n")
for timestep in parse(netstate, 'timestep'):
seen = set()
if timestep.edge is not None:
for edge in timestep.edge:
if edge.lane is not None:
for lane in edge.lane:
if lane.vehicle is not None:
for vehicle in lane.vehicle:
seen.add(vehicle.id)
if vehicle.id not in running or laneTimes[vehicle.id][-1][1] != lane.id:
laneTimes[vehicle.id].append(
(timestep.time, lane.id))
running.add(vehicle.id)
if lastEdge[vehicle.id] == edge.id:
laneChanges[vehicle.id] += 1
lastEdge[vehicle.id] = edge.id
for veh_id in running:
if veh_id not in seen:
arrivals[veh_id] = timestep.time
running = running - set(arrivals.keys())
for veh_id, lt in laneTimes.items():
f.write(' <vehicle id="%s" laneTimes="%s" arrival="%s" laneChanges="%s"/>\n' % (
veh_id,
' '.join(['%s,%s' % (t, l) for t, l in lt]),
arrivals.get(veh_id),
laneChanges[veh_id]))
f.write("</vehLanes>\n")
if __name__ == "__main__":
options = parse_args()
trackLanes(options.netstate, options.out)