Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tools/import/transportationTestProblems.py
169674 views
1
#!/usr/bin/env python
2
# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
# Copyright (C) 2014-2025 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 transportationTestProblems.py
15
# @author Michael Behrisch
16
# @date 2015-02-24
17
18
19
from __future__ import print_function
20
from __future__ import absolute_import
21
import os
22
import sys
23
import subprocess
24
import csv
25
sys.path.append(os.path.join(os.environ["SUMO_HOME"], 'tools'))
26
import sumolib # noqa
27
28
csvfile = csv.DictReader(open(sys.argv[1]), delimiter='\t')
29
with open("nodes.nod.xml", "w") as nodeout:
30
nodeout.write("<nodes>\n")
31
for nl in csvfile:
32
nodeout.write(' <node id="%s" x="%s" y="%s"/>\n' % (nl['Node'], nl['X'], nl['Y']))
33
nodeout.write("</nodes>\n")
34
35
csvfile = csv.reader(open(sys.argv[2]), delimiter='\t')
36
with open("edges.edg.xml", "w") as edgeout:
37
edgeout.write("<edges>\n")
38
for el in csvfile:
39
if el and (el[0] == '' or el[0][0] not in "~<"):
40
edgeout.write(' <edge id="%s_%s" from="%s" to="%s"/>\n' % (2 * (el[1], el[2])))
41
edgeout.write("</edges>\n")
42
43
subprocess.call([sumolib.checkBinary("netconvert"), "-n", nodeout.name, "-e", edgeout.name, '--proj.utm'])
44
45