71 const std::string& vTypes,
const double departPos,
const double arrivalPos,
const std::string& busStop,
74 void addRide(
const ROEdge*
const from,
const ROEdge*
const to,
const std::string& lines,
const std::string& destStop);
77 const double departPos,
const double arrivalPos,
const std::string& busStop);
113 : stopDesc(stop), edge(stopEdge) {}
163 const std::string& _lines,
const double _cost,
const std::string& _destStop =
"")
164 :
TripItem(_cost), from(_from), to(_to), lines(_lines), destStop(_destStop) {}
193 double departPos = std::numeric_limits<double>::infinity(),
194 double arrivalPos = std::numeric_limits<double>::infinity(),
195 const std::string& _destStop =
"")
196 :
TripItem(_cost), edges(_edges), dur(-1), v(-1), dep(departPos), arr(arrivalPos), destStop(_destStop) {}
198 const double departPos,
const double arrivalPos,
const std::string& _destStop)
199 :
TripItem(_cost), edges(edges), dur(duration), v(speed), dep(departPos), arr(arrivalPos), destStop(_destStop) {}
201 return edges.front();
210 const double dur,
v, dep, arr;
226 : from(0), to(0), modes(
SVC_PEDESTRIAN), dep(0), arr(0), busStop(
""), walkFactor(1.0) {}
228 const double departPos,
const double arrivalPos,
const std::string& busStop,
double _walkFactor)
229 : from(from), to(to), modes(modeSet), dep(departPos), arr(arrivalPos), busStop(busStop), walkFactor(_walkFactor) {}
232 for (std::vector<TripItem*>::const_iterator it = myTripItems.begin(); it != myTripItems.end(); ++it) {
235 for (std::vector<ROVehicle*>::const_iterator it = myVehicles.begin(); it != myVehicles.end(); ++it) {
236 delete(*it)->getRouteDefinition();
242 myTripItems.push_back(tripIt);
245 myVehicles.push_back(veh);
251 return from != 0 ? from : myTripItems.front()->getOrigin();
254 return to != 0 ? to : myTripItems.back()->getDestination();
257 return dep == std::numeric_limits<double>::infinity() && replaceDefault ? 0 : dep;
260 return arr == std::numeric_limits<double>::infinity() && replaceDefault ? -
POSITION_EPS : arr;
266 return busStop !=
"";
269 return myTripItems.empty();
273 for (std::vector<TripItem*>::const_iterator it = myTripItems.begin(); it != myTripItems.end(); ++it) {
274 (*it)->saveAsXML(os, extended);
306 return myPlan.front()->getOrigin();
311 const bool removeLoops,
MsgHandler* errorHandler);
void addRide(const ROEdge *const from, const ROEdge *const to, const std::string &lines, const std::string &destStop)
SVCPermissions getModes() const
bool hasBusStopDest() const
void addVehicle(ROVehicle *veh)
Structure representing possible vehicle parameter.
const SVCPermissions modes
int SVCPermissions
bitset where each bit declares whether a certain SVC may use this edge/lane
A planItem can be a Stop.
std::vector< ROVehicle * > myVehicles
the vehicles which may be used for routing
bool computeIntermodal(const RORouterProvider &provider, PersonTrip *const trip, const ROVehicle *const veh, MsgHandler *const errorHandler)
PersonTrip(const ROEdge *const from, const ROEdge *const to, const SVCPermissions modeSet, const double departPos, const double arrivalPos, const std::string &busStop, double _walkFactor)
std::vector< const ROEdge * > ConstROEdgeVector
const ROEdge * getOrigin() const
Every person has a plan comprising of multiple planItems.
A planItem can be a Trip which contains multiple tripItems.
virtual ~PlanItem()
Destructor.
Walk(const ConstROEdgeVector &edges, const double _cost, const double duration, const double speed, const double departPos, const double arrivalPos, const std::string &_destStop)
const ROEdge * getOrigin() const
A routable thing such as a vehicle or person.
const ROEdge * getDestination() const
A ride is part of a trip, e.g., go from here to here by car or bus.
A vehicle as used by router.
ROPerson & operator=(const ROPerson &src)
Invalidated assignment operator.
const ROEdge * getOrigin() const
virtual void saveVehicles(OutputDevice &, OutputDevice *const, bool, OptionsCont &) const
std::vector< PlanItem * > myPlan
The plan of the person.
SUMOVehicleParameter::Stop stopDesc
std::vector< PlanItem * > & getPlan()
TripItem(const double _cost)
virtual bool needsRouting() const
virtual void addTripItem(TripItem *)
void addStop(const SUMOVehicleParameter::Stop &stopPar, const ROEdge *const stopEdge)
void saveAsXML(OutputDevice &os, const bool extended) const
const ROEdge * getDestination() const
A person as used by router.
A TripItem is part of a trip, e.g., go from here to here by car.
A walk is part of a trip, e.g., go from here to here by foot.
A basic edge for routing applications.
virtual const ROEdge * getDestination() const =0
virtual ~ROPerson()
Destructor.
std::vector< TripItem * > myTripItems
the fully specified trips
void addTrip(const ROEdge *const from, const ROEdge *const to, const SVCPermissions modeSet, const std::string &vTypes, const double departPos, const double arrivalPos, const std::string &busStop, double walkFactor)
ROPerson(const SUMOVehicleParameter &pars, const SUMOVTypeParameter *type)
Constructor.
virtual ~PersonTrip()
Destructor.
double getWalkFactor() const
void computeRoute(const RORouterProvider &provider, const bool removeLoops, MsgHandler *errorHandler)
Structure representing possible vehicle parameter.
const std::string destStop
double getArrivalPos(bool replaceDefault=true) const
virtual bool needsRouting() const
void addWalk(const ConstROEdgeVector &edges, const double duration, const double speed, const double departPos, const double arrivalPos, const std::string &busStop)
Walk(const ConstROEdgeVector &_edges, const double _cost, double departPos=std::numeric_limits< double >::infinity(), double arrivalPos=std::numeric_limits< double >::infinity(), const std::string &_destStop="")
Definition of vehicle stop (position and duration)
A storage for options typed value containers)
const std::string destStop
double getDepartPos(bool replaceDefault=true) const
const ROEdge * getDestination() const
Ride(const ROEdge *const _from, const ROEdge *const _to, const std::string &_lines, const double _cost, const std::string &_destStop="")
Static storage of an output device and its base (abstract) implementation.
const ConstROEdgeVector edges
std::vector< ROVehicle * > & getVehicles()
virtual void addTripItem(TripItem *tripIt)
void saveAsXML(OutputDevice &os, const bool) const
Stop(const SUMOVehicleParameter::Stop &stop, const ROEdge *const stopEdge)
virtual const ROEdge * getOrigin() const =0
virtual void saveAsXML(OutputDevice &os, const bool extended) const =0
double walkFactor
walking speed factor
const ROEdge * getDepartEdge() const
Returns the first edge the person takes.
const ROEdge * getOrigin() const
virtual bool isStop() const
virtual ~TripItem()
Destructor.
const std::string busStop
const ROEdge * getDestination() const