SUMO - Simulation of Urban MObility
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
NWFrame.cpp
Go to the documentation of this file.
1 /****************************************************************************/
9 // Sets and checks options for netwrite
10 /****************************************************************************/
11 // SUMO, Simulation of Urban MObility; see http://sumo-sim.org/
12 // Copyright (C) 2001-2014 DLR (http://www.dlr.de/) and contributors
13 /****************************************************************************/
14 //
15 // This file is part of SUMO.
16 // SUMO is free software: you can redistribute it and/or modify
17 // it under the terms of the GNU General Public License as published by
18 // the Free Software Foundation, either version 3 of the License, or
19 // (at your option) any later version.
20 //
21 /****************************************************************************/
22 
23 
24 // ===========================================================================
25 // included modules
26 // ===========================================================================
27 #ifdef _MSC_VER
28 #include <windows_config.h>
29 #else
30 #include <config.h>
31 #endif
32 
33 #include <string>
34 #include <utils/options/Option.h>
39 #include <netbuild/NBNetBuilder.h>
40 #include "NWFrame.h"
41 #include "NWWriter_SUMO.h"
42 #include "NWWriter_Amitran.h"
43 #include "NWWriter_MATSim.h"
44 #include "NWWriter_XML.h"
45 #include "NWWriter_OpenDrive.h"
46 #include "NWWriter_DlrNavteq.h"
47 
48 #ifdef CHECK_MEMORY_LEAKS
49 #include <foreign/nvwa/debug_new.h>
50 #endif // CHECK_MEMORY_LEAKS
51 
52 // ===========================================================================
53 // static members
54 // ===========================================================================
55 const std::string NWFrame::MAJOR_VERSION = "version=\"0.13\"";
56 
57 
58 // ===========================================================================
59 // method definitions
60 // ===========================================================================
61 void
62 NWFrame::fillOptions(bool forNetgen) {
64  // register options
65  oc.doRegister("output-file", 'o', new Option_FileName());
66  oc.addSynonyme("output-file", "sumo-output");
67  oc.addSynonyme("output-file", "output");
68  oc.addDescription("output-file", "Output", "The generated net will be written to FILE");
69 
70  oc.doRegister("plain-output-prefix", new Option_FileName());
71  oc.addSynonyme("plain-output-prefix", "plain-output");
72  oc.addSynonyme("plain-output-prefix", "plain");
73  oc.addDescription("plain-output-prefix", "Output", "Prefix of files to write plain xml nodes, edges and connections to");
74 
75  oc.doRegister("junctions.join-output", new Option_FileName());
76  oc.addDescription("junctions.join-output", "Output",
77  "Writes information about joined junctions to FILE (can be loaded as additional node-file to reproduce joins");
78 
79 #ifdef HAVE_PROJ
80  if (!forNetgen) {
81  oc.doRegister("proj.plain-geo", new Option_Bool(false));
82  oc.addDescription("proj.plain-geo", "Projection", "Write geo coordinates in plain-xml");
83  }
84 #endif // HAVE_PROJ
85 
86  oc.doRegister("map-output", 'M', new Option_FileName());
87  oc.addDescription("map-output", "Output", "Writes joined edges information to FILE");
88 
89  oc.doRegister("amitran-output", new Option_FileName());
90  oc.addDescription("amitran-output", "Output", "The generated net will be written to FILE using Amitran format");
91 
92  oc.doRegister("matsim-output", new Option_FileName());
93  oc.addDescription("matsim-output", "Output", "The generated net will be written to FILE using MATsim format");
94 
95  oc.doRegister("opendrive-output", new Option_FileName());
96  oc.addDescription("opendrive-output", "Output", "The generated net will be written to FILE using OpenDRIVE format");
97 
98  oc.doRegister("dlr-navteq-output", new Option_FileName());
99  oc.addDescription("dlr-navteq-output", "Output", "The generated net will be written to dlr-navteq files with the given PREFIX");
100 
101  oc.doRegister("output.street-names", new Option_Bool(false));
102  oc.addDescription("output.street-names", "Output", "Street names will be included in the output (if available)");
103 
104  oc.doRegister("output.original-names", new Option_Bool(false));
105  oc.addDescription("output.original-names", "Output", "Writes original names, if given, as parameter");
106 
107  oc.doRegister("street-sign-output", new Option_FileName());
108  oc.addDescription("street-sign-output", "Output", "Writes street signs as POIs to FILE");
109 }
110 
111 
112 bool
115  bool ok = true;
116  // check whether the output is valid and can be build
117  if (!oc.isSet("output-file")
118  && !oc.isSet("plain-output-prefix")
119  && !oc.isSet("amitran-output")
120  && !oc.isSet("matsim-output")
121  && !oc.isSet("opendrive-output")
122  && !oc.isSet("dlr-navteq-output")) {
123  oc.set("output-file", "net.net.xml");
124  }
125  // some outputs need internal lanes
126  if (oc.isSet("opendrive-output") && oc.getBool("no-internal-links")) {
127  WRITE_ERROR("OpenDRIVE export needs internal links computation.");
128  ok = false;
129  }
130  return ok;
131 }
132 
133 
134 void
142  // save the mapping information when wished
143  if (oc.isSet("map-output")) {
144  OutputDevice& mdevice = OutputDevice::getDevice(oc.getString("map-output"));
145  mdevice << nb.getJoinedEdgesMap();
146  mdevice.close();
147  }
148 }
149 
150 
151 void
153  dev.writeAttr(SUMO_ATTR_X, pos.x());
154  dev.writeAttr(SUMO_ATTR_Y, pos.y());
155  if (pos.z() != 0) {
156  dev.writeAttr(SUMO_ATTR_Z, pos.z());
157  }
158 }
159 
160 /****************************************************************************/
161