Eclipse SUMO - Simulation of Urban MObility
MSDispatch_RouteExtension.h
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 /****************************************************************************/
18 // An algorithm that performs dispatch for the taxi device
19 /****************************************************************************/
20 #pragma once
21 #include <config.h>
22 
23 #include <set>
24 #include <vector>
25 #include <map>
26 #include <utils/common/SUMOTime.h>
27 #include "MSDispatch_Greedy.h"
28 #include "MSDevice_Taxi.h"
29 
30 
37 public:
39  MSDispatch_Greedy(params)
40  {}
41 
42 protected:
44  virtual int dispatch(MSDevice_Taxi* taxi, std::vector<Reservation*>::iterator& resIt, SUMOAbstractRouter<MSEdge, SUMOVehicle>& router, std::vector<Reservation*>& reservations);
45 
46 private:
47  typedef std::vector<std::pair<const MSEdge*, double> > EdgePosVector;
48  void findInsertionPoint(std::vector<const Reservation*>::iterator& resIt, EdgePosVector::iterator& edgeIt,
49  const EdgePosVector::iterator& edgeEnd, ConstMSEdgeVector& route,
50  const MSEdge* newEdge, const double newPos) const;
51 };
std::vector< const MSEdge * > ConstMSEdgeVector
Definition: MSEdge.h:74
A device which collects info on the vehicle trip (mainly on departure and arrival)
Definition: MSDevice_Taxi.h:49
A dispatch algorithm that services customers in reservation order and always sends the closest availa...
MSDispatch_RouteExtension(const Parameterised::Map &params)
void findInsertionPoint(std::vector< const Reservation * >::iterator &resIt, EdgePosVector::iterator &edgeIt, const EdgePosVector::iterator &edgeEnd, ConstMSEdgeVector &route, const MSEdge *newEdge, const double newPos) const
virtual int dispatch(MSDevice_Taxi *taxi, std::vector< Reservation * >::iterator &resIt, SUMOAbstractRouter< MSEdge, SUMOVehicle > &router, std::vector< Reservation * > &reservations)
trigger taxi dispatch.
std::vector< std::pair< const MSEdge *, double > > EdgePosVector
A road/street connecting two junctions.
Definition: MSEdge.h:77
std::map< std::string, std::string > Map
parameters map
Definition: Parameterised.h:45