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-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/****************************************************************************/
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 MSLane* getLane() const {
82 return nullptr;
83 }
84
85 const MSLane* getBackLane() const {
86 return nullptr;
87 }
88
96 Position getPosition(const double offset = 0) const;
97
99 PositionVector getBoundingBox(double offset = 0) const;
100
105 double getSpeed() const;
106
111 double getAverageSpeed() const;
112
114 double estimateLeaveSpeed(const MSLink* link) const;
115
116
122 double getConservativeSpeed(SUMOTime& earliestArrival) const;
123
125
126
136
137
141 bool moveRoutePointer();
142
146 bool hasArrived() const;
147
151 bool isOnRoad() const;
152
156 virtual bool isIdling() const;
157
158
163 void setApproaching(MSLink* link);
164
167 return 0;
168 }
169
171 void processStop();
172
178
183 bool resumeFromStopping();
184
186 double getBrakeGap(bool delayed = false) const {
187 UNUSED_PARAMETER(delayed);
188 return mySegment == nullptr || myQueIndex == MESegment::PARKING_QUEUE ? 0 : mySegment->getLength();
189 }
190
194 inline void setEventTime(SUMOTime t, bool hasDelay = true) {
195 assert(t > myLastEntryTime);
196 if (hasDelay && mySegment != nullptr) {
198 }
199 myEventTime = t;
200 }
201
202
206 inline SUMOTime getEventTime() const {
207 return myEventTime;
208 }
209
210
215 inline virtual void setSegment(MESegment* s, int idx = 0) {
216 mySegment = s;
217 myQueIndex = idx;
218 }
219
220
224 inline MESegment* getSegment() const {
225 return mySegment;
226 }
227
228 int getSegmentIndex() const;
229
233 inline int getQueIndex() const {
234 return myQueIndex;
235 }
236
242 double getRightSideOnEdge(const MSLane* /*lane*/) const;
243
247 inline void setLastEntryTime(SUMOTime t) {
248 myLastEntryTime = t;
249 }
250
251
256 return myLastEntryTime;
257 }
258
263 return SIMSTEP;
264 }
265
269 inline void setBlockTime(const SUMOTime t) {
270 assert(t > myLastEntryTime);
271 myBlockTime = t;
272 }
273
274
278 inline SUMOTime getBlockTime() const {
279 return myBlockTime;
280 }
281
282
284 inline SUMOTime getWaitingTime(const bool accumulated = false) const {
285 UNUSED_PARAMETER(accumulated);
286 return MAX2(SUMOTime(0), myEventTime - myBlockTime);
287 }
288
289 inline SUMOTime getTimeLoss() const {
290 // slow-downs while driving are not modelled
291 return getWaitingTime();
292 }
293
295 double getEventTimeSeconds() const {
296 return STEPS2TIME(getEventTime());
297 }
298
300 double getLastEntryTimeSeconds() const {
302 }
303
305 double getBlockTimeSeconds() const {
306 return STEPS2TIME(getBlockTime());
307 }
308
310 double getCurrentLinkPenaltySeconds() const;
311
313 double getCurrentStoppingTimeSeconds() const;
314
316 bool replaceRoute(ConstMSRoutePtr route, const std::string& info, bool onInit = false, int offset = 0, bool addRouteStops = true, bool removeStops = true, std::string* msgReturn = nullptr);
317
321 bool mayProceed();
322
325 void updateDetectorForWriting(MSMoveReminder* rem, SUMOTime currentTime, SUMOTime exitTime);
326
329 void updateDetectors(SUMOTime currentTime, const bool isLeave,
331
337 BaseInfluencer& getBaseInfluencer();
338
339 const BaseInfluencer* getBaseInfluencer() const;
340
341 bool hasInfluencer() const {
342 return myInfluencer != nullptr;
343 }
344
346
347
349 void saveState(OutputDevice& out);
350
353 void loadState(const SUMOSAXAttributes& attrs, const SUMOTime offset);
355
356
357protected:
360
363
366
369
372
375
376};
long long int SUMOTime
Definition GUI.h:36
std::shared_ptr< const MSRoute > ConstMSRoutePtr
Definition Route.h:32
#define STEPS2TIME(x)
Definition SUMOTime.h:55
#define SIMSTEP
Definition SUMOTime.h:61
#define UNUSED_PARAMETER(x)
Definition StdDefs.h:30
T MAX2(T a, T b)
Definition StdDefs.h:82
A single mesoscopic segment (cell)
Definition MESegment.h:49
static const int PARKING_QUEUE
Definition MESegment.h:52
double getLength() const
Returns the length of the segment in meters.
Definition MESegment.h:242
const MSEdge & getEdge() const
Returns the edge this segment belongs to.
Definition MESegment.h:359
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:300
double getBlockTimeSeconds() const
Returns the time at which the vehicle was blocked on the current segment.
Definition MEVehicle.h:305
Position getPosition(const double offset=0) const
Return current position (x/y, cartesian)
Definition MEVehicle.cpp:94
bool hasInfluencer() const
whether the vehicle is individually influenced (via TraCI or special parameters)
Definition MEVehicle.h:341
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:262
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:365
const MSLane * getBackLane() const
Returns the lane the where the rear of the object is currently at.
Definition MEVehicle.h:85
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:186
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:284
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:362
SUMOTime checkStop(SUMOTime time)
Returns until when to stop at the current segment and sets the information that the stop has been rea...
void updateDetectors(SUMOTime currentTime, const bool isLeave, const MSMoveReminder::Notification reason=MSMoveReminder::NOTIFICATION_JUNCTION)
Updates all vehicle detectors.
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:255
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:368
void setEventTime(SUMOTime t, bool hasDelay=true)
Sets the (planned) time at which the vehicle leaves its current segment.
Definition MEVehicle.h:194
BaseInfluencer * myInfluencer
An instance of a velocity/lane influencing instance; built in "getInfluencer".
Definition MEVehicle.h:374
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:289
MESegment * getSegment() const
Returns the current segment the vehicle is on.
Definition MEVehicle.h:224
void setLastEntryTime(SUMOTime t)
Sets the entry time for the current segment.
Definition MEVehicle.h:247
MESegment * mySegment
The segment the vehicle is at.
Definition MEVehicle.h:359
int getQueIndex() const
Returns the index of the que the vehicle is in.
Definition MEVehicle.h:233
int getSegmentIndex() const
const MSLane * getLane() const
Returns the lane the vehicle is on.
Definition MEVehicle.h:81
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:215
SUMOTime remainingStopDuration() const
Returns the remaining stop duration for a stopped vehicle or 0.
Definition MEVehicle.h:166
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:206
void setBlockTime(const SUMOTime t)
Sets the time at which the vehicle was blocked.
Definition MEVehicle.h:269
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:295
SUMOTime myBlockTime
The time at which the vehicle was blocked on its current segment.
Definition MEVehicle.h:371
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:278
The base class for microscopic and mesoscopic vehicles.
void markDelayed() const
Definition MSEdge.h:729
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.