Eclipse SUMO - Simulation of Urban MObility
MSTransportableDevice_Routing.cpp
Go to the documentation of this file.
1 /****************************************************************************/
2 // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3 // Copyright (C) 2007-2024 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 /****************************************************************************/
22 // A device that performs vehicle rerouting based on current edge speeds
23 /****************************************************************************/
24 #include <config.h>
25 
26 #include <microsim/MSNet.h>
31 #include <microsim/MSEdge.h>
32 
33 #include "MSRoutingEngine.h"
35 
36 
37 // ===========================================================================
38 // method definitions
39 // ===========================================================================
40 // ---------------------------------------------------------------------------
41 // static initialisation methods
42 // ---------------------------------------------------------------------------
43 void
45  insertDefaultAssignmentOptions("rerouting", "Routing", oc, true);
46  oc.doRegister("person-device.rerouting.period", new Option_String("0", "TIME"));
47  oc.addSynonyme("person-device.rerouting.period", "person-device.routing.period", true);
48  oc.addDescription("person-device.rerouting.period", "Routing", TL("The period with which the person shall be rerouted"));
49 
50  oc.doRegister("person-device.rerouting.mode", new Option_String("0"));
51  oc.addDescription("person-device.rerouting.mode", "Routing", TL("Set routing flags (8 ignores temporary blockages)"));
52 
53  oc.doRegister("person-device.rerouting.scope", new Option_String("stage"));
54  oc.addDescription("person-device.rerouting.scope", "Routing", TL("Which part of the person plan is to be replaced (stage, sequence, or trip)"));
55 }
56 
57 
58 void
59 MSTransportableDevice_Routing::buildDevices(MSTransportable& p, std::vector<MSTransportableDevice*>& into) {
61  if (p.getParameter().wasSet(VEHPARS_FORCE_REROUTE) || equippedByDefaultAssignmentOptions(oc, "rerouting", p, false, true)) {
62  // route computation is enabled
63  const SUMOTime period = p.getTimeParam("person-device.rerouting.period");
64  if (period > 0) {
66  // build the device
67  into.push_back(new MSTransportableDevice_Routing(p, "routing_" + p.getID(), period));
68  }
69  }
70 }
71 
72 
73 // ---------------------------------------------------------------------------
74 // MSTransportableDevice_Routing-methods
75 // ---------------------------------------------------------------------------
77  : MSTransportableDevice(holder, id), myPeriod(period), myLastRouting(-1), myRerouteCommand(0) {
78  myScope = holder.getStringParam("person-device.rerouting.scope");
79  // no need for initial routing here, personTrips trigger it themselves
82  // the event will deschedule and destroy itself so it does not need to be stored
83 }
84 
85 
87  // make the rerouting command invalid if there is one
88  if (myRerouteCommand != nullptr) {
90  }
91 }
92 
93 
96  reroute(currentTime);
97  return myPeriod;
98 }
99 
100 
101 void
102 MSTransportableDevice_Routing::reroute(const SUMOTime currentTime, const bool onInit) {
104  //check whether the weights did change since the last reroute
106  return;
107  }
108  myLastRouting = currentTime;
109  MSRoutingEngine::reroute(myHolder, currentTime, "person-device.rerouting", onInit);
110 }
111 
112 
113 std::string
114 MSTransportableDevice_Routing::getParameter(const std::string& key) const {
115  if (key == "period") {
116  return time2string(myPeriod);
117  }
118  throw InvalidArgument("Parameter '" + key + "' is not supported for device of type '" + deviceName() + "'");
119 }
120 
121 
122 void
123 MSTransportableDevice_Routing::setParameter(const std::string& key, const std::string& value) {
124  double doubleValue;
125  try {
126  doubleValue = StringUtils::toDouble(value);
127  } catch (NumberFormatException&) {
128  throw InvalidArgument("Setting parameter '" + key + "' requires a number for device of type '" + deviceName() + "'");
129  }
130  if (key == "period") {
131  const SUMOTime oldPeriod = myPeriod;
132  myPeriod = TIME2STEPS(doubleValue);
133  if (myPeriod <= 0) {
135  } else if (oldPeriod <= 0) {
136  // re-schedule routing command
138  }
139  } else {
140  throw InvalidArgument("Setting parameter '" + key + "' is not supported for device of type '" + deviceName() + "'");
141  }
142 }
143 
144 
145 void
148  out.writeAttr(SUMO_ATTR_ID, getID());
149  std::vector<std::string> internals;
150  internals.push_back(toString(myPeriod));
151  out.writeAttr(SUMO_ATTR_STATE, toString(internals));
152  out.closeTag();
153 }
154 
155 
156 void
158  std::istringstream bis(attrs.getString(SUMO_ATTR_STATE));
159  bis >> myPeriod;
160 }
161 
162 
163 /****************************************************************************/
long long int SUMOTime
Definition: GUI.h:35
#define TL(string)
Definition: MsgHandler.h:315
std::string time2string(SUMOTime t, bool humanReadable)
convert SUMOTime to string (independently of global format setting)
Definition: SUMOTime.cpp:69
#define SIMSTEP
Definition: SUMOTime.h:61
#define TIME2STEPS(x)
Definition: SUMOTime.h:57
@ SVC_PEDESTRIAN
pedestrian
const int VEHPARS_FORCE_REROUTE
@ SUMO_TAG_DEVICE
@ SUMO_ATTR_ID
@ SUMO_ATTR_STATE
The state of a link.
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition: ToString.h:46
static void insertDefaultAssignmentOptions(const std::string &deviceName, const std::string &optionsTopic, OptionsCont &oc, const bool isPerson=false)
Adds common command options that allow to assign devices to vehicles.
Definition: MSDevice.cpp:155
static bool equippedByDefaultAssignmentOptions(const OptionsCont &oc, const std::string &deviceName, DEVICEHOLDER &v, bool outputOptionSet, const bool isPerson=false)
Determines whether a vehicle should get a certain device.
Definition: MSDevice.h:195
virtual void addEvent(Command *operation, SUMOTime execTimeStep=-1)
Adds an Event.
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
Definition: MSNet.cpp:184
MSEventControl * getInsertionEvents()
Returns the event control for insertion events.
Definition: MSNet.h:491
static void reroute(SUMOVehicle &vehicle, const SUMOTime currentTime, const std::string &info, const bool onInit=false, const bool silent=false, const MSEdgeVector &prohibited=MSEdgeVector())
initiate the rerouting, create router / thread pool on first use
static SUMOTime getLastAdaptation()
Information when the last edge weight adaptation occurred.
static void initWeightUpdate()
intialize period edge weight update
static void initEdgeWeights(SUMOVehicleClass svc)
initialize the edge weights if not done before
static void buildDevices(MSTransportable &p, std::vector< MSTransportableDevice * > &into)
Build devices for the given person, if needed.
static void insertOptions(OptionsCont &oc)
Inserts MSTransportableDevice_Routing-options.
const std::string deviceName() const
return the name for this type of device
SUMOTime myLastRouting
The last time a routing took place.
void loadState(const SUMOSAXAttributes &attrs)
Loads the state of the device from the given description.
MSTransportableDevice_Routing(MSTransportable &holder, const std::string &id, SUMOTime period)
Constructor.
void saveState(OutputDevice &out) const
Saves the state of the device.
SUMOTime wrappedRerouteCommandExecute(SUMOTime currentTime)
Performs rerouting after a period.
std::string myScope
The range of the plan which shall be replaced.
void setParameter(const std::string &key, const std::string &value)
try to set the given parameter for this device. Throw exception for unsupported key
std::string getParameter(const std::string &key) const
try to retrieve the given parameter from this device. Throw exception for unsupported key
WrappingCommand< MSTransportableDevice_Routing > * myRerouteCommand
The (optional) command responsible for rerouting.
SUMOTime myPeriod
The period with which a vehicle shall be rerouted.
void reroute(const SUMOTime currentTime, const bool onInit=false)
initiate the rerouting, create router / thread pool on first use
Abstract in-person device.
MSTransportable & myHolder
The person that stores the device.
const SUMOVehicleParameter & getParameter() const
Returns the vehicle's parameter (including departure definition)
const std::string & getID() const
Returns the id.
Definition: Named.h:74
A storage for options typed value containers)
Definition: OptionsCont.h:89
void addDescription(const std::string &name, const std::string &subtopic, const std::string &description)
Adds a description for an option.
void addSynonyme(const std::string &name1, const std::string &name2, bool isDeprecated=false)
Adds a synonyme for an options name (any order)
void doRegister(const std::string &name, Option *o)
Adds an option under the given name.
Definition: OptionsCont.cpp:76
static OptionsCont & getOptions()
Retrieves the options.
Definition: OptionsCont.cpp:60
Static storage of an output device and its base (abstract) implementation.
Definition: OutputDevice.h:61
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
Definition: OutputDevice.h:254
bool closeTag(const std::string &comment="")
Closes the most recently opened tag and optionally adds a comment.
Encapsulated SAX-Attributes.
virtual std::string getString(int id, bool *isPresent=nullptr) const =0
Returns the string-value of the named (by its enum-value) attribute.
std::string getStringParam(const std::string &paramName, const bool required=false, const std::string &deflt="") const
Retrieve a string parameter for the traffic object.
SUMOTime getTimeParam(const std::string &paramName, const bool required=false, const SUMOTime deflt=SUMOTime_MIN) const
Retrieve a time parameter for the traffic object.
bool wasSet(int what) const
Returns whether the given parameter was set.
static double toDouble(const std::string &sData)
converts a string into the double value described by it by calling the char-type converter
void deschedule()
Marks this Command as being descheduled.