Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/tools/sumolib/patch_network/runner.py
428384 views
1
#!/usr/bin/env python
2
# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
# Copyright (C) 2008-2026 German Aerospace Center (DLR) and others.
4
# This program and the accompanying materials are made available under the
5
# terms of the Eclipse Public License 2.0 which is available at
6
# https://www.eclipse.org/legal/epl-2.0/
7
# This Source Code may also be made available under the following Secondary
8
# Licenses when the conditions for such availability set forth in the Eclipse
9
# Public License 2.0 are satisfied: GNU General Public License, version 2
10
# or later which is available at
11
# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12
# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13
14
# @file runner.py
15
# @author Jakob Erdmann
16
# @date
17
18
# test for patching network with random node position offset
19
from __future__ import absolute_import
20
from __future__ import print_function
21
22
import os
23
import sys
24
import random
25
from subprocess import call
26
if 'SUMO_HOME' in os.environ:
27
tools = os.path.join(os.environ['SUMO_HOME'], 'tools')
28
sys.path.append(tools)
29
else:
30
sys.exit("please declare environment variable 'SUMO_HOME'")
31
import sumolib.net # noqa
32
33
random.seed(42)
34
netfile = sys.argv[1]
35
patchfile = 'nodes.nod.xml'
36
netconvert = sumolib.checkBinary('netconvert')
37
# disaggregate
38
call([netconvert, '-s', netfile, '--plain-output-prefix', 'plain'])
39
# create patch
40
with open(patchfile, 'w') as outf:
41
# setting attrs is optional, it results in a cleaner patch file
42
attrs = {'node': ['id', 'x', 'y']} # other attrs are not needed for patching
43
# parse always returns a generator but there is only one root element
44
nodes = list(sumolib.xml.parse('plain.nod.xml', 'nodes', attrs))[0]
45
for node in nodes.node:
46
node.addChild("param", {"key": "origPos", "value": "%s %s" % (node.x, node.y)})
47
node.x = "%.2f" % (float(node.x) + random.random() * 40. - 20.)
48
node.y = "%.2f" % (float(node.y) + random.random() * 40. - 20.)
49
outf.write(nodes.toXML())
50
51
# rebuild
52
call([netconvert, '-s', netfile, '-n', patchfile, '-o', 'net.net.xml'])
53
54