SUMO - Simulation of Urban MObility
MSAmitranTrajectories.cpp
Go to the documentation of this file.
1 /****************************************************************************/
7 // Realises dumping the complete network state
8 /****************************************************************************/
9 // SUMO, Simulation of Urban MObility; see http://sumo.dlr.de/
10 // Copyright (C) 2014-2017 DLR (http://www.dlr.de/) and contributors
11 /****************************************************************************/
12 //
13 // This file is part of SUMO.
14 // SUMO is free software: you can redistribute it and/or modify
15 // it under the terms of the GNU General Public License as published by
16 // the Free Software Foundation, either version 3 of the License, or
17 // (at your option) any later version.
18 //
19 /****************************************************************************/
20 
21 
22 // ===========================================================================
23 // included modules
24 // ===========================================================================
25 #ifdef _MSC_VER
26 #include <windows_config.h>
27 #else
28 #include <config.h>
29 #endif
30 
32 #include <microsim/MSEdge.h>
33 #include <microsim/MSLane.h>
34 #include <microsim/MSNet.h>
35 #include <microsim/MSVehicle.h>
36 #include <microsim/MSGlobals.h>
39 #include "MSAmitranTrajectories.h"
40 
41 // ===========================================================================
42 // static member definitions
43 // ===========================================================================
44 std::set<std::string> MSAmitranTrajectories::myWrittenTypes;
45 std::map<std::string, int> MSAmitranTrajectories::myWrittenVehicles;
46 
47 
48 // ===========================================================================
49 // method definitions
50 // ===========================================================================
51 void
54  for (MSVehicleControl::constVehIt v = vc.loadedVehBegin(); v != vc.loadedVehEnd(); ++v) {
55  writeVehicle(of, *v->second, timestep);
56  }
57 }
58 
59 
60 void
62  if (veh.isOnRoad()) {
63  const std::string& type = veh.getVehicleType().getID();
64  if (myWrittenTypes.count(type) == 0) {
67  if (c != 0) {
71  const double weight = PollutantsInterface::getWeight(c);
72  if (weight > 0.) {
73  of.writeAttr(SUMO_ATTR_WEIGHT, int(weight / 10. + 0.5));
74  }
75  }
76  of.writeAttr(SUMO_ATTR_REF, type).closeTag();
77  myWrittenTypes.insert(type);
78  }
79  if (myWrittenVehicles.count(veh.getID()) == 0) {
80  const int index = (int)myWrittenVehicles.size();
83  .writeAttr(SUMO_ATTR_STARTTIME, STEPS2MS(veh.getDeparture()));
84  of.writeAttr(SUMO_ATTR_REF, veh.getID()).closeTag();
85  myWrittenVehicles[veh.getID()] = index;
86  }
88  .writeAttr(SUMO_ATTR_SPEED, int(100.*veh.getSpeed() + 0.5))
89  .writeAttr(SUMO_ATTR_TIME, STEPS2MS(timestep))
90  .writeAttr(SUMO_ATTR_ACCELERATION, int(1000.*veh.getAcceleration() + 0.5));
91  of.closeTag();
92  }
93 }
94 
95 
96 /****************************************************************************/
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
Definition: OutputDevice.h:256
constVehIt loadedVehBegin() const
Returns the begin of the internal vehicle map.
static std::map< std::string, int > myWrittenVehicles
int getNumericalID() const
Returns the running index of the vehicle type.
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
Definition: MSNet.cpp:158
static std::string getAmitranVehicleClass(const SUMOEmissionClass c)
Returns the vehicle class described by the given emission class.
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition: ToString.h:56
Representation of a vehicle.
Definition: SUMOVehicle.h:67
int SUMOEmissionClass
MSVehicleControl & getVehicleControl()
Returns the vehicle control.
Definition: MSNet.h:310
virtual bool isOnRoad() const =0
Returns the information whether the vehicle is on a road (is simulated)
static std::set< std::string > myWrittenTypes
static int getEuroClass(const SUMOEmissionClass c)
Returns the Euro norm described by the given emission class.
trigger: the time of the step
static double getWeight(const SUMOEmissionClass c)
Returns a representative weight for the given emission class see http://colombo-fp7.eu/deliverables/COLOMBO_D4.2_ExtendedPHEMSUMO_v1.7.pdf.
virtual SUMOTime getDeparture() const =0
Returns this vehicle&#39;s real departure time.
static void writeVehicle(OutputDevice &of, const SUMOVehicle &veh, const SUMOTime timestep)
Writes the dump of the given vehicle into the given device.
const std::string & getID() const
Returns the name of the vehicle type.
static void write(OutputDevice &of, const SUMOTime timestep)
Writes the complete network state into the given device.
std::map< std::string, SUMOVehicle * >::const_iterator constVehIt
Definition of the internal vehicles map iterator.
description of a vehicle
Static storage of an output device and its base (abstract) implementation.
Definition: OutputDevice.h:71
bool closeTag()
Closes the most recently opened tag.
long long int SUMOTime
Definition: TraCIDefs.h:52
The class responsible for building and deletion of vehicles.
virtual double getSpeed() const =0
Returns the vehicle&#39;s current speed.
SUMOEmissionClass getEmissionClass() const
Get this vehicle type&#39;s emission class.
#define STEPS2MS(x)
Definition: SUMOTime.h:68
virtual const std::string & getID() const =0
Get the vehicle&#39;s ID.
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
constVehIt loadedVehEnd() const
Returns the end of the internal vehicle map.
static std::string getFuel(const SUMOEmissionClass c)
Returns the fuel type of the given emission class.
virtual double getAcceleration() const =0
Returns the vehicle&#39;s acceleration.
virtual const MSVehicleType & getVehicleType() const =0
Returns the vehicle&#39;s type.