42 #ifdef CHECK_MEMORY_LEAKS 44 #endif // CHECK_MEMORY_LEAKS 58 : myDestination(destination), myDestinationStop(toStop), myArrivalPos(arrivalPos), myDeparted(-1), myArrived(-1), myType(type) {}
97 return e->
getLanes()[0]->getShape().rotationAtOffset(at);
106 const bool initial) :
110 myWaitingDuration(duration),
111 myWaitingUntil(until),
159 if (dynamic_cast<MSPerson*>(transportable) != 0) {
225 myVehicle(0), myStopWaitPos(
Position::INVALID) {}
284 return myLines.count(line) > 0;
329 for (MSTransportablePlan::const_iterator i =
myPlan->begin(); i !=
myPlan->end(); ++i) {
350 (*myStep)->setDeparted(now);
375 return (*myStep)->getSpeed();
SUMOReal getSpeed() const
the speed of the transportable
virtual void proceed(MSNet *net, MSTransportable *transportable, SUMOTime now, Stage *previous)
proceeds to the next step
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
void setArrived(SUMOTime now)
logs end of the step
Representation of a vehicle in the micro simulation.
std::string myActType
The type of activity.
SUMOReal getEdgeAngle(const MSEdge *e, SUMOReal at) const
get angle of the edge at a certain position
A lane area vehicles can halt at.
Stage(const MSEdge &destination, MSStoppingPlace *toStop, const SUMOReal arrivalPos, StageType type)
constructor
virtual bool isWaitingFor(const std::string &line) const
Whether the transportable waits for a vehicle of the line specified.
virtual const MSEdge * getEdge() const =0
Returns the current edge.
SUMOReal getAngle(SUMOTime now) const
returns the angle of the transportable
virtual SUMOReal getPositionOnLane() const =0
Get the vehicle's position along the lane.
const MSEdge * getEdge() const
Returns the current edge.
virtual const MSEdge * getEdge() const =0
Returns the edge the vehicle is currently at.
virtual void beginEventOutput(const MSTransportable &p, SUMOTime t, OutputDevice &os) const
Called for writing the events output.
std::string time2string(SUMOTime t)
void setWaitEnd(SUMOTime time, MSTransportable *transportable)
sets the arrival time for a waiting transportable
const MSEdge * getFromEdge() const
Position positionAtOffset(SUMOReal pos, SUMOReal lateralOffset=0) const
Returns the position at the given length.
const std::vector< MSLane * > & getLanes() const
Returns this edge's lanes.
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
const PositionVector & getShape() const
Returns this lane's shape.
const std::set< std::string > myLines
the lines to choose from
SUMOReal interpolateLanePosToGeometryPos(SUMOReal lanePos) const
virtual void beginEventOutput(const MSTransportable &p, SUMOTime t, OutputDevice &os) const
Called for writing the events output.
const std::string & getID() const
Returns the id.
SUMOReal getSpeed() const
the speed of the transportable
SUMOTime getUntil() const
MSTransportablePlan::iterator myStep
the iterator over the route
MSTransportable(const SUMOVehicleParameter *pars, const MSVehicleType *vtype, MSTransportablePlan *plan)
constructor
const MSEdge * getFromEdge() const
const MSEdge * getEdge() const
Returns the current edge.
Position getLanePosition(const MSLane *lane, SUMOReal at, SUMOReal offset) const
get position on lane at length at with orthogonal offset
SUMOReal getEdgePos(SUMOTime now) const
The simulated network and simulation perfomer.
The car-following model and parameter.
virtual MSTransportableControl & getContainerControl()
Returns the container control.
const SUMOVehicleParameter * myParameter
the plan of the transportable
virtual SUMOReal getAngle() const
return the current angle of the transportable
bool isWaiting4Vehicle() const
Whether the person waits for a vehicle.
SUMOTime myWaitingSince
The time since which this person is waiting for a ride.
Stage_Driving(const MSEdge &destination, MSStoppingPlace *toStop, const SUMOReal arrivalPos, const std::vector< std::string > &lines)
constructor
A road/street connecting two junctions.
std::vector< MSTransportable::Stage * > MSTransportablePlan
the structure holding the plan of a transportable
SUMOTime myArrived
the time at which this stage ended
SUMOTime myDeparted
the time at which this stage started
static const SUMOReal ROADSIDE_OFFSET
the offset for computing positions when standing at an edge
void setDeparted(SUMOTime now)
logs depart time of the current stage
virtual MSTransportableControl & getPersonControl()
Returns the person control.
A point in 2D or 3D with translation and scaling methods.
SUMOTime getDesiredDepart() const
Returns the desired departure time.
Position getPosition(SUMOTime now) const
returns the position of the transportable
const MSVehicleType * myVType
This transportable's type. (mainly used for drawing related information Note sure if it is really nec...
virtual void addPerson(MSTransportable *p) const
virtual ~MSTransportable()
destructor
SUMOReal myArrivalPos
the position at which we want to arrive
SUMOTime getWaitingTime(SUMOTime now) const
time spent waiting for a ride
SUMOTime depart
The vehicle's departure time.
virtual SUMOReal getWaitingSeconds() const
the time this transportable spent waiting in seconds
SUMOTime getCurrentTimeStep() const
Returns the current simulation step.
Stage_Waiting(const MSEdge &destination, SUMOTime duration, SUMOTime until, SUMOReal pos, const std::string &actType, const bool initial)
constructor
const std::string & getID() const
returns the id of the transportable
virtual ~Stage_Driving()
destructor
SUMOTime myWaitingUntil
the time until the person is waiting
SUMOVehicle * myVehicle
The taken vehicle.
virtual SUMOReal getEdgePos() const
Return the position on the edge.
Position getPosition(SUMOTime now) const
returns the position of the transportable
virtual void endEventOutput(const MSTransportable &p, SUMOTime t, OutputDevice &os) const
Called for writing the events output (end of an action)
Position getEdgePosition(const MSEdge *e, SUMOReal at, SUMOReal offset) const
get position on edge e at length at with orthogonal offset
SUMOReal getEdgePos(SUMOTime now) const
virtual void endEventOutput(const MSTransportable &p, SUMOTime t, OutputDevice &os) const
Called for writing the events output (end of an action)
SUMOReal getAngle(SUMOTime now) const
returns the angle of the transportable
StageType myType
The type of this stage.
virtual SUMOReal getSpeed() const =0
Returns the vehicle's current speed.
Structure representing possible vehicle parameter.
SUMOReal getAngle() const
Returns the vehicle's direction in radians.
virtual void addContainer(MSTransportable *container) const
Add a container to myContainers.
virtual Position getPosition() const
Return the Network coordinate of the transportable.
SUMOReal getLength() const
return the length of the edge
virtual void routeOutput(OutputDevice &os) const
Called on writing vehroute output.
virtual Position getPosition(const SUMOReal offset=0) const =0
Return current position (x/y, cartesian)
SUMOTime getWaitingTime(SUMOTime now) const
the time this transportable spent waiting
const MSEdge & getDestination() const
returns the destination edge
Static storage of an output device and its base (abstract) implementation.
void setDeparted(SUMOTime now)
logs end of the step
bool closeTag()
Closes the most recently opened tag.
virtual void tripInfoOutput(OutputDevice &os) const
Called on writing tripinfo output.
MSTransportablePlan * myPlan
the plan of the transportable
virtual ~Stage_Waiting()
destructor
virtual SUMOReal getSpeed() const
the current speed of the transportable
const MSEdge * myWaitingEdge
virtual ~Stage()
destructor
bool isWaitingFor(const std::string &line) const
Whether the person waits for a vehicle of the line specified.
const MSEdge & myDestination
the next edge to reach by getting transported
Representation of a lane in the micro simulation.
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
SUMOTime myWaitingDuration
the time the person is waiting
std::string id
The vehicle's id.
static const Position INVALID
SUMOTime myWaitingStart
the time the person is waiting