SUMO - Simulation of Urban MObility
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
MSFullExport.cpp
Go to the documentation of this file.
1 /****************************************************************************/
10 // Dumping a hugh List of Parameters available in the Simulation
11 /****************************************************************************/
12 // SUMO, Simulation of Urban MObility; see http://sumo-sim.org/
13 // Copyright (C) 2012-2014 DLR (http://www.dlr.de/) and contributors
14 /****************************************************************************/
15 //
16 // This file is part of SUMO.
17 // SUMO is free software: you can redistribute it and/or modify
18 // it under the terms of the GNU General Public License as published by
19 // the Free Software Foundation, either version 3 of the License, or
20 // (at your option) any later version.
21 //
22 /****************************************************************************/
23 
24 
25 // ===========================================================================
26 // included modules
27 // ===========================================================================
28 #ifdef _MSC_VER
29 #include <windows_config.h>
30 #else
31 #include <config.h>
32 #endif
33 
36 #include <microsim/MSEdge.h>
37 #include <microsim/MSEdgeControl.h>
38 #include <microsim/MSNet.h>
39 #include <microsim/MSVehicle.h>
41 #include "MSFullExport.h"
42 
43 #ifdef CHECK_MEMORY_LEAKS
44 #include <foreign/nvwa/debug_new.h>
45 #endif // CHECK_MEMORY_LEAKS
46 
47 
48 // ===========================================================================
49 // method definitions
50 // ===========================================================================
51 void
53  of.openTag("data") << " timestep=\"" << time2string(timestep) << "\"";
54  //Vehicles
55  writeVehicles(of);
56  //Edges
57  writeEdge(of);
58  //TrafficLights
59  writeTLS(of, timestep);
60  of.closeTag();
61 }
62 
63 
64 void
66  of.openTag("vehicles");
70  for (; it != end; ++it) {
71  const MSVehicle* veh = static_cast<const MSVehicle*>((*it).second);
72  if (veh->isOnRoad()) {
73  std::string fclass = veh->getVehicleType().getID();
74  fclass = fclass.substr(0, fclass.find_first_of("@"));
76  of.openTag("vehicle").writeAttr("id", veh->getID()).writeAttr("eclass", PollutantsInterface::getName(veh->getVehicleType().getEmissionClass()));
77  of.writeAttr("CO2", veh->getCO2Emissions()).writeAttr("CO", veh->getCOEmissions()).writeAttr("HC", veh->getHCEmissions());
78  of.writeAttr("NOx", veh->getNOxEmissions()).writeAttr("PMx", veh->getPMxEmissions()).writeAttr("noise", veh->getHarmonoise_NoiseEmissions());
79  of.writeAttr("route", veh->getRoute().getID()).writeAttr("type", fclass).writeAttr("waiting", veh->getWaitingSeconds());
80  of.writeAttr("lane", veh->getLane()->getID()).writeAttr("pos_lane", veh->getPositionOnLane()).writeAttr("speed", veh->getSpeed());
81  of.writeAttr("angle", veh->getAngle()).writeAttr("x", pos.x()).writeAttr("y", pos.y());
82  // !!! fuel is missing here
83  of.closeTag();
84  }
85  }
86  of.closeTag();
87 }
88 
89 void
91  of.openTag("edges");
93  const std::vector<MSEdge*>& edges = ec.getEdges();
94  for (std::vector<MSEdge*>::const_iterator e = edges.begin(); e != edges.end(); ++e) {
95  MSEdge& edge = **e;
96  of.openTag("edge").writeAttr("id", edge.getID()).writeAttr("traveltime", edge.getCurrentTravelTime());
97  const std::vector<MSLane*>& lanes = edge.getLanes();
98  for (std::vector<MSLane*>::const_iterator lane = lanes.begin(); lane != lanes.end(); ++lane) {
99  writeLane(of, **lane);
100  }
101  of.closeTag();
102  }
103  of.closeTag();
104 }
105 
106 
107 void
109 
110  of.openTag("lane").writeAttr("id", lane.getID()).writeAttr("CO", lane.getCOEmissions()).writeAttr("CO2", lane.getCO2Emissions());
111  of.writeAttr("NOx", lane.getNOxEmissions()).writeAttr("PMx", lane.getPMxEmissions()).writeAttr("HC", lane.getHCEmissions());
112  of.writeAttr("noise", lane.getHarmonoise_NoiseEmissions()).writeAttr("fuel", lane.getFuelConsumption()).writeAttr("maxspeed", lane.getSpeedLimit());
113  of.writeAttr("meanspeed", lane.getMeanSpeed() * 3.6).writeAttr("occupancy", lane.getNettoOccupancy()).writeAttr("vehicle_count", lane.getVehicleNumber());
114  of.closeTag();
115 }
116 
117 
118 void
120  of.openTag("tls");
122  std::vector<std::string> ids = vc.getAllTLIds();
123  for (std::vector<std::string>::const_iterator id_it = ids.begin(); id_it != ids.end(); ++id_it) {
126 
127  std::vector<std::string> laneIDs;
128  for (MSTrafficLightLogic::LaneVectorVector::const_iterator i = lanes.begin(); i != lanes.end(); ++i) {
129  const MSTrafficLightLogic::LaneVector& llanes = (*i);
130  for (MSTrafficLightLogic::LaneVector::const_iterator j = llanes.begin(); j != llanes.end(); ++j) {
131  laneIDs.push_back((*j)->getID());
132  }
133  }
134 
135  std::string lane_output = "";
136  for (unsigned int i1 = 0; i1 < laneIDs.size(); ++i1) {
137  lane_output += laneIDs[i1] + " ";
138  }
139 
140  std::string state = vars.getActive()->getCurrentPhaseDef().getState();
141  of.openTag("trafficlight").writeAttr("id", *id_it).writeAttr("state", state).closeTag();
142  }
143  of.closeTag();
144 }
145