Eclipse SUMO - Simulation of Urban MObility
MSAmitranTrajectories.cpp
Go to the documentation of this file.
1 /****************************************************************************/
2 // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.org/sumo
3 // Copyright (C) 2014-2019 German Aerospace Center (DLR) and others.
4 // This program and the accompanying materials
5 // are made available under the terms of the Eclipse Public License v2.0
6 // which accompanies this distribution, and is available at
7 // http://www.eclipse.org/legal/epl-v20.html
8 // SPDX-License-Identifier: EPL-2.0
9 /****************************************************************************/
14 // Realises dumping the complete network state
15 /****************************************************************************/
16 
17 
18 // ===========================================================================
19 // included modules
20 // ===========================================================================
21 #include <config.h>
22 
24 #include <microsim/MSEdge.h>
25 #include <microsim/MSLane.h>
26 #include <microsim/MSNet.h>
27 #include <microsim/MSVehicle.h>
28 #include <microsim/MSGlobals.h>
31 #include "MSAmitranTrajectories.h"
32 
33 // ===========================================================================
34 // static member definitions
35 // ===========================================================================
36 std::set<std::string> MSAmitranTrajectories::myWrittenTypes;
37 std::map<std::string, int> MSAmitranTrajectories::myWrittenVehicles;
38 
39 
40 // ===========================================================================
41 // method definitions
42 // ===========================================================================
43 void
46  for (MSVehicleControl::constVehIt v = vc.loadedVehBegin(); v != vc.loadedVehEnd(); ++v) {
47  writeVehicle(of, *v->second, timestep);
48  }
49 }
50 
51 
52 void
54  if (veh.isOnRoad()) {
55  const std::string& type = veh.getVehicleType().getID();
56  if (myWrittenTypes.count(type) == 0) {
59  if (c != 0) {
63  const double weight = PollutantsInterface::getWeight(c);
64  if (weight > 0.) {
65  of.writeAttr(SUMO_ATTR_WEIGHT, int(weight / 10. + 0.5));
66  }
67  }
68  of.writeAttr(SUMO_ATTR_REF, type).closeTag();
69  myWrittenTypes.insert(type);
70  }
71  if (myWrittenVehicles.count(veh.getID()) == 0) {
72  const int index = (int)myWrittenVehicles.size();
75  .writeAttr(SUMO_ATTR_STARTTIME, STEPS2MS(veh.getDeparture()));
76  of.writeAttr(SUMO_ATTR_REF, veh.getID()).closeTag();
77  myWrittenVehicles[veh.getID()] = index;
78  }
80  .writeAttr(SUMO_ATTR_SPEED, int(100.*veh.getSpeed() + 0.5))
81  .writeAttr(SUMO_ATTR_TIME, STEPS2MS(timestep))
82  .writeAttr(SUMO_ATTR_ACCELERATION, int(1000.*veh.getAcceleration() + 0.5));
83  of.closeTag();
84  }
85 }
86 
87 
88 /****************************************************************************/
MSVehicleType::getEmissionClass
SUMOEmissionClass getEmissionClass() const
Get this vehicle type's emission class.
Definition: MSVehicleType.h:193
MSVehicleType::getID
const std::string & getID() const
Returns the name of the vehicle type.
Definition: MSVehicleType.h:93
SUMO_ATTR_ACCELERATION
@ SUMO_ATTR_ACCELERATION
Definition: SUMOXMLDefinitions.h:892
MSVehicleType::getNumericalID
int getNumericalID() const
Returns the running index of the vehicle type.
Definition: MSVehicleType.h:101
MSAmitranTrajectories::myWrittenVehicles
static std::map< std::string, int > myWrittenVehicles
Definition: MSAmitranTrajectories.h:77
MSNet.h
STEPS2MS
#define STEPS2MS(x)
Definition: SUMOTime.h:60
SUMOTrafficObject::getAcceleration
virtual double getAcceleration() const =0
Returns the vehicle's acceleration.
OutputDevice
Static storage of an output device and its base (abstract) implementation.
Definition: OutputDevice.h:63
SUMOTrafficObject::getVehicleType
virtual const MSVehicleType & getVehicleType() const =0
Returns the vehicle's type.
SUMO_ATTR_VEHICLE
@ SUMO_ATTR_VEHICLE
Definition: SUMOXMLDefinitions.h:888
SUMOTrafficObject::getID
virtual const std::string & getID() const =0
Get the vehicle's ID.
PollutantsInterface::getEuroClass
static int getEuroClass(const SUMOEmissionClass c)
Returns the Euro norm described by the given emission class.
Definition: PollutantsInterface.cpp:136
SUMOTime
long long int SUMOTime
Definition: SUMOTime.h:34
SUMOVehicle
Representation of a vehicle.
Definition: SUMOVehicle.h:60
SUMOVehicle::isOnRoad
virtual bool isOnRoad() const =0
Returns the information whether the vehicle is on a road (is simulated)
SUMOEmissionClass
int SUMOEmissionClass
Definition: SUMOVehicleClass.h:231
SUMO_ATTR_SPEED
@ SUMO_ATTR_SPEED
Definition: SUMOXMLDefinitions.h:384
SUMO_ATTR_ID
@ SUMO_ATTR_ID
Definition: SUMOXMLDefinitions.h:378
MSEdge.h
MSVehicleControl::constVehIt
std::map< std::string, SUMOVehicle * >::const_iterator constVehIt
Definition of the internal vehicles map iterator.
Definition: MSVehicleControl.h:74
MSVehicle.h
SUMO_ATTR_WEIGHT
@ SUMO_ATTR_WEIGHT
Definition: SUMOXMLDefinitions.h:421
OutputDevice::closeTag
bool closeTag(const std::string &comment="")
Closes the most recently opened tag and optionally adds a comment.
Definition: OutputDevice.cpp:253
SUMOVehicle::getDeparture
virtual SUMOTime getDeparture() const =0
Returns this vehicle's real departure time.
OutputDevice::writeAttr
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
Definition: OutputDevice.h:255
PollutantsInterface.h
SUMO_TAG_ACTORCONFIG
@ SUMO_TAG_ACTORCONFIG
Definition: SUMOXMLDefinitions.h:322
PollutantsInterface::getAmitranVehicleClass
static std::string getAmitranVehicleClass(const SUMOEmissionClass c)
Returns the vehicle class described by the given emission class.
Definition: PollutantsInterface.cpp:124
MSVehicleControl::loadedVehEnd
constVehIt loadedVehEnd() const
Returns the end of the internal vehicle map.
Definition: MSVehicleControl.h:185
MSAmitranTrajectories.h
OutputDevice.h
SUMO_TAG_MOTIONSTATE
@ SUMO_TAG_MOTIONSTATE
Definition: SUMOXMLDefinitions.h:323
MSGlobals.h
SUMO_TAG_VEHICLE
@ SUMO_TAG_VEHICLE
description of a vehicle
Definition: SUMOXMLDefinitions.h:119
SUMO_ATTR_TIME
@ SUMO_ATTR_TIME
trigger: the time of the step
Definition: SUMOXMLDefinitions.h:676
SUMO_ATTR_STARTTIME
@ SUMO_ATTR_STARTTIME
Definition: SUMOXMLDefinitions.h:889
PollutantsInterface::getWeight
static double getWeight(const SUMOEmissionClass c)
Returns a representative weight for the given emission class see http://colombo-fp7....
Definition: PollutantsInterface.cpp:142
PollutantsInterface::getFuel
static std::string getFuel(const SUMOEmissionClass c)
Returns the fuel type of the given emission class.
Definition: PollutantsInterface.cpp:130
MSAmitranTrajectories::myWrittenTypes
static std::set< std::string > myWrittenTypes
Definition: MSAmitranTrajectories.h:76
OutputDevice::openTag
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
Definition: OutputDevice.cpp:239
toString
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition: ToString.h:47
MSNet::getInstance
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
Definition: MSNet.cpp:167
MSAmitranTrajectories::writeVehicle
static void writeVehicle(OutputDevice &of, const SUMOVehicle &veh, const SUMOTime timestep)
Writes the dump of the given vehicle into the given device.
Definition: MSAmitranTrajectories.cpp:53
SUMO_ATTR_VEHICLECLASS
@ SUMO_ATTR_VEHICLECLASS
Definition: SUMOXMLDefinitions.h:890
config.h
MSVehicleControl
The class responsible for building and deletion of vehicles.
Definition: MSVehicleControl.h:71
SUMO_ATTR_REF
@ SUMO_ATTR_REF
Definition: SUMOXMLDefinitions.h:821
MSVehicleControl::loadedVehBegin
constVehIt loadedVehBegin() const
Returns the begin of the internal vehicle map.
Definition: MSVehicleControl.h:177
MSLane.h
MSVehicleControl.h
MSAmitranTrajectories::write
static void write(OutputDevice &of, const SUMOTime timestep)
Writes the complete network state into the given device.
Definition: MSAmitranTrajectories.cpp:44
SUMO_ATTR_EMISSIONCLASS
@ SUMO_ATTR_EMISSIONCLASS
Definition: SUMOXMLDefinitions.h:795
MSNet::getVehicleControl
MSVehicleControl & getVehicleControl()
Returns the vehicle control.
Definition: MSNet.h:336
SUMOTrafficObject::getSpeed
virtual double getSpeed() const =0
Returns the vehicle's current speed.
SUMO_ATTR_ACTORCONFIG
@ SUMO_ATTR_ACTORCONFIG
Definition: SUMOXMLDefinitions.h:887