Path: blob/main/tests/tools/sumolib/net_customLength/runner.py
428384 views
#!/usr/bin/env python1# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo2# Copyright (C) 2008-2026 German Aerospace Center (DLR) and others.3# This program and the accompanying materials are made available under the4# terms of the Eclipse Public License 2.0 which is available at5# https://www.eclipse.org/legal/epl-2.0/6# This Source Code may also be made available under the following Secondary7# Licenses when the conditions for such availability set forth in the Eclipse8# Public License 2.0 are satisfied: GNU General Public License, version 29# or later which is available at10# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html11# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later1213# @file runner.py14# @author Jakob Erdmann15# @date1617from __future__ import absolute_import18from __future__ import print_function192021import os22import sys23if 'SUMO_HOME' in os.environ:24tools = os.path.join(os.environ['SUMO_HOME'], 'tools')25sys.path.append(tools)26else:27sys.exit("please declare environment variable 'SUMO_HOME'")28import sumolib.net # noqa293031def printSorted(d):32return ' '.join(["%s:%s" % (k, d[k]) for k in sorted(d.keys())])333435net = sumolib.net.readNet(sys.argv[1])3637for edge in net.getEdges():38fromXY = edge.getFromNode().getCoord()39toXY = edge.getToNode().getCoord()40mid = (fromXY[0] + toXY[0]) / 2, (fromXY[1] + toXY[1]) / 241for lane in edge.getLanes():42print("%s mid=%s halfLength=%s getClosestLanePosAndDist=%s" % (43lane.getID(), mid, lane.getLength() / 2,44lane.getClosestLanePosAndDist(mid)))454647