Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
MEVehicle.h
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2026 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/****************************************************************************/
18// A vehicle from the mesoscopic point of view
19/****************************************************************************/
20#pragma once
21#include <config.h>
22
23#include <iostream>
24#include <cassert>
25#include <map>
26#include <vector>
28#include <microsim/MSEdge.h>
30#include "MESegment.h"
31
32class MSLane;
33class MSLink;
34
35// ===========================================================================
36// class definitions
37// ===========================================================================
42class MEVehicle : public MSBaseVehicle {
43public:
52 MSVehicleType* type, const double speedFactor);
53
54
58 double getPositionOnLane() const;
59
60
64 double getBackPositionOnLane(const MSLane* lane) const;
65
66
70 double getAngle() const;
71
72
76 double getSlope() const;
77
81 const MSEdge* getCurrentEdge() const;
82
86 const MSLane* getLane() const {
87 return nullptr;
88 }
89
90 const MSLane* getBackLane() const {
91 return nullptr;
92 }
93
101 Position getPosition(const double offset = 0) const;
102
104 PositionVector getBoundingBox(double offset = 0) const;
105
110 double getSpeed() const;
111
116 double getAverageSpeed() const;
117
119 double estimateLeaveSpeed(const MSLink* link) const;
120
121
127 double getConservativeSpeed(SUMOTime& earliestArrival) const;
128
130
131
141
142
146 bool moveRoutePointer();
147
151 bool hasArrived() const;
152
156 bool isOnRoad() const;
157
161 virtual bool isIdling() const;
162
163
168 void setApproaching(MSLink* link);
169
172 return 0;
173 }
174
176 void processStop();
177
183
188 bool resumeFromStopping();
189
191 double getBrakeGap(bool delayed = false) const {
192 UNUSED_PARAMETER(delayed);
193 return mySegment == nullptr || myQueIndex == MESegment::PARKING_QUEUE ? 0 : mySegment->getLength();
194 }
195
199 inline void setEventTime(SUMOTime t, bool hasDelay = true) {
200 assert(t > myLastEntryTime);
201 if (hasDelay && mySegment != nullptr) {
203 }
204 myEventTime = t;
205 }
206
207
211 inline SUMOTime getEventTime() const {
212 return myEventTime;
213 }
214
215
220 inline virtual void setSegment(MESegment* s, int idx = 0) {
221 mySegment = s;
222 myQueIndex = idx;
223 }
224
225
229 inline MESegment* getSegment() const {
230 return mySegment;
231 }
232
233 int getSegmentIndex() const;
234
238 inline int getQueIndex() const {
239 return myQueIndex;
240 }
241
247 double getRightSideOnEdge(const MSLane* /*lane*/) const;
248
252 inline void setLastEntryTime(SUMOTime t) {
253 myLastEntryTime = t;
254 }
255
256
261 return myLastEntryTime;
262 }
263
268 return SIMSTEP;
269 }
270
274 inline void setBlockTime(const SUMOTime t) {
275 assert(t > myLastEntryTime);
276 myBlockTime = t;
277 }
278
279
283 inline SUMOTime getBlockTime() const {
284 return myBlockTime;
285 }
286
287
289 inline SUMOTime getWaitingTime(const bool accumulated = false) const {
290 UNUSED_PARAMETER(accumulated);
291 return MAX2(SUMOTime(0), myEventTime - myBlockTime);
292 }
293
294 inline SUMOTime getTimeLoss() const {
295 // slow-downs while driving are not modelled
296 return getWaitingTime();
297 }
298
300 double getEventTimeSeconds() const {
301 return STEPS2TIME(getEventTime());
302 }
303
305 double getLastEntryTimeSeconds() const {
307 }
308
310 double getBlockTimeSeconds() const {
311 return STEPS2TIME(getBlockTime());
312 }
313
315 double getCurrentLinkPenaltySeconds() const;
316
318 double getCurrentStoppingTimeSeconds() const;
319
321 bool replaceRoute(ConstMSRoutePtr route, const std::string& info, bool onInit = false, int offset = 0, bool addRouteStops = true, bool removeStops = true, std::string* msgReturn = nullptr);
322
326 bool mayProceed();
327
330 void updateDetectorForWriting(MSMoveReminder* rem, SUMOTime currentTime, SUMOTime exitTime);
331
334 void updateDetectors(const SUMOTime currentTime, const SUMOTime exitTime, const bool isLeave,
336
342 BaseInfluencer& getBaseInfluencer();
343
344 const BaseInfluencer* getBaseInfluencer() const;
345
346 bool hasInfluencer() const {
347 return myInfluencer != nullptr;
348 }
349
351
352
354 void saveState(OutputDevice& out);
355
358 void loadState(const SUMOSAXAttributes& attrs, const SUMOTime offset);
360
361
362protected:
365
368
371
374
377
380
381};
long long int SUMOTime
Definition GUI.h:36
std::shared_ptr< const MSRoute > ConstMSRoutePtr
Definition Route.h:32
#define STEPS2TIME(x)
Definition SUMOTime.h:58
#define SIMSTEP
Definition SUMOTime.h:64
T MAX2(T a, T b)
Definition StdDefs.h:86
A single mesoscopic segment (cell)
Definition MESegment.h:50
static const int PARKING_QUEUE
Definition MESegment.h:53
double getLength() const
Returns the length of the segment in meters.
Definition MESegment.h:246
const MSEdge & getEdge() const
Returns the edge this segment belongs to.
Definition MESegment.h:366
A vehicle from the mesoscopic point of view.
Definition MEVehicle.h:42
double getConservativeSpeed(SUMOTime &earliestArrival) const
Returns the vehicle's estimated speed taking into account delays.
double getLastEntryTimeSeconds() const
Returns the entry time for the current segment.
Definition MEVehicle.h:305
double getBlockTimeSeconds() const
Returns the time at which the vehicle was blocked on the current segment.
Definition MEVehicle.h:310
Position getPosition(const double offset=0) const
Return current position (x/y, cartesian)
bool hasInfluencer() const
whether the vehicle is individually influenced (via TraCI or special parameters)
Definition MEVehicle.h:346
double getAverageSpeed() const
Returns the vehicle's estimated average speed on the segment assuming no further delays.
SUMOTime getLastActionTime() const
Returns the time of the vehicle's last action point.
Definition MEVehicle.h:267
double getAngle() const
Returns the vehicle's direction in degrees.
Definition MEVehicle.cpp:80
double getBackPositionOnLane(const MSLane *lane) const
Get the vehicle's position relative to the given lane.
Definition MEVehicle.cpp:66
bool replaceRoute(ConstMSRoutePtr route, const std::string &info, bool onInit=false, int offset=0, bool addRouteStops=true, bool removeStops=true, std::string *msgReturn=nullptr)
Replaces the current route by the given one.
SUMOTime myEventTime
The (planned) time of leaving the segment (cell)
Definition MEVehicle.h:370
const MSLane * getBackLane() const
Returns the lane the where the rear of the object is currently at.
Definition MEVehicle.h:90
void onRemovalFromNet(const MSMoveReminder::Notification reason)
Called when the vehicle is removed from the network.
void updateDetectorForWriting(MSMoveReminder *rem, SUMOTime currentTime, SUMOTime exitTime)
Updates a single vehicle detector if present.
BaseInfluencer & getBaseInfluencer()
Returns the velocity/lane influencer.
double getCurrentStoppingTimeSeconds() const
Returns the delay that is accrued due to option –meso-tls-penalty or –meso-minor-penalty.
double getBrakeGap(bool delayed=false) const
get distance for coming to a stop (used for rerouting checks)
Definition MEVehicle.h:191
bool mayProceed()
Returns whether the vehicle is allowed to pass the next junction, checks also for triggered stops.
double estimateLeaveSpeed(const MSLink *link) const
Returns the vehicle's estimated speed after driving across the link.
void processStop()
ends the current stop and performs loading/unloading
SUMOTime getWaitingTime(const bool accumulated=false) const
Returns the duration for which the vehicle was blocked.
Definition MEVehicle.h:289
bool hasArrived() const
Returns whether this vehicle has already arrived (reached the arrivalPosition on its final edge)
bool moveRoutePointer()
Update when the vehicle enters a new edge in the move step.
int myQueIndex
Index of the que the vehicle is in (important for multiqueue extension)
Definition MEVehicle.h:367
void updateDetectors(const SUMOTime currentTime, const SUMOTime exitTime, const bool isLeave, const MSMoveReminder::Notification reason=MSMoveReminder::NOTIFICATION_JUNCTION)
Updates all vehicle detectors.
SUMOTime checkStop(SUMOTime time)
Returns until when to stop at the current segment and sets the information that the stop has been rea...
virtual bool isIdling() const
Returns whether the vehicle is trying to re-enter the net.
SUMOTime getLastEntryTime() const
Returns the time the vehicle entered the current segment.
Definition MEVehicle.h:260
double getPositionOnLane() const
Get the vehicle's position along the lane.
Definition MEVehicle.cpp:72
SUMOTime myLastEntryTime
The time the vehicle entered its current segment.
Definition MEVehicle.h:373
void setEventTime(SUMOTime t, bool hasDelay=true)
Sets the (planned) time at which the vehicle leaves its current segment.
Definition MEVehicle.h:199
BaseInfluencer * myInfluencer
An instance of a velocity/lane influencing instance; built in "getInfluencer".
Definition MEVehicle.h:379
void setApproaching(MSLink *link)
registers vehicle with the given link
void saveState(OutputDevice &out)
Saves the states of a vehicle.
SUMOTime getTimeLoss() const
Definition MEVehicle.h:294
MESegment * getSegment() const
Returns the current segment the vehicle is on.
Definition MEVehicle.h:229
const MSEdge * getCurrentEdge() const
Returns the edge the vehicle is currently at (possibly an internal edge)
Definition MEVehicle.cpp:94
void setLastEntryTime(SUMOTime t)
Sets the entry time for the current segment.
Definition MEVehicle.h:252
MESegment * mySegment
The segment the vehicle is at.
Definition MEVehicle.h:364
int getQueIndex() const
Returns the index of the que the vehicle is in.
Definition MEVehicle.h:238
int getSegmentIndex() const
const MSLane * getLane() const
Returns the lane the vehicle is on.
Definition MEVehicle.h:86
void loadState(const SUMOSAXAttributes &attrs, const SUMOTime offset)
Loads the state of this vehicle from the given description.
virtual void setSegment(MESegment *s, int idx=0)
Sets the current segment the vehicle is at together with its que.
Definition MEVehicle.h:220
SUMOTime remainingStopDuration() const
Returns the remaining stop duration for a stopped vehicle or 0.
Definition MEVehicle.h:171
double getCurrentLinkPenaltySeconds() const
Returns the delay that is accrued due to option –meso-tls-penalty or –meso-minor-penalty.
SUMOTime getEventTime() const
Returns the (planned) time at which the vehicle leaves its current segment.
Definition MEVehicle.h:211
void setBlockTime(const SUMOTime t)
Sets the time at which the vehicle was blocked.
Definition MEVehicle.h:274
bool isOnRoad() const
Returns the information whether the vehicle is on a road (is simulated)
bool resumeFromStopping()
double getSpeed() const
Returns the vehicle's estimated speed assuming no delays.
PositionVector getBoundingBox(double offset=0) const
get bounding rectangle
double getSlope() const
Returns the slope of the road at vehicle's position in degrees.
Definition MEVehicle.cpp:87
double getEventTimeSeconds() const
Returns the earliest leave time for the current segment.
Definition MEVehicle.h:300
SUMOTime myBlockTime
The time at which the vehicle was blocked on its current segment.
Definition MEVehicle.h:376
double getRightSideOnEdge(const MSLane *) const
Get the vehicle's lateral position on the edge of the given lane (or its current edge if lane == 0)
SUMOTime getBlockTime() const
Returns the time at which the vehicle was blocked.
Definition MEVehicle.h:283
The base class for microscopic and mesoscopic vehicles.
A road/street connecting two junctions.
Definition MSEdge.h:77
void markDelayed() const
Definition MSEdge.h:740
Representation of a lane in the micro simulation.
Definition MSLane.h:84
Something on a lane to be noticed about vehicle movement.
Notification
Definition of a vehicle state.
@ NOTIFICATION_JUNCTION
The vehicle arrived at a junction.
The car-following model and parameter.
Static storage of an output device and its base (abstract) implementation.
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
A list of positions.
Encapsulated SAX-Attributes.
Structure representing possible vehicle parameter.
#define UNUSED_PARAMETER(x)