SUMO - Simulation of Urban MObility
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
ROHelper.h
Go to the documentation of this file.
1 /****************************************************************************/
8 // Some helping methods for router
9 /****************************************************************************/
10 // SUMO, Simulation of Urban MObility; see http://sumo.dlr.de/
11 // Copyright (C) 2001-2015 DLR (http://www.dlr.de/) and contributors
12 /****************************************************************************/
13 //
14 // This file is part of SUMO.
15 // SUMO is free software: you can redistribute it and/or modify
16 // it under the terms of the GNU General Public License as published by
17 // the Free Software Foundation, either version 3 of the License, or
18 // (at your option) any later version.
19 //
20 /****************************************************************************/
21 #ifndef ROHelper_h
22 #define ROHelper_h
23 
24 
25 // ===========================================================================
26 // included modules
27 // ===========================================================================
28 #ifdef _MSC_VER
29 #include <windows_config.h>
30 #else
31 #include <config.h>
32 #endif
33 
34 #include <functional>
35 #include <vector>
36 #include "ROEdge.h"
37 #include "ROVehicle.h"
38 
39 
40 // ===========================================================================
41 // class definitions
42 // ===========================================================================
50 class ROVehicleByDepartureComperator : public std::less<ROVehicle*> {
51 public:
54 
57 
69  bool operator()(ROVehicle* veh1, ROVehicle* veh2) const {
70  if (veh1->getDepart() == veh2->getDepart()) {
71  return veh1->getID() > veh2->getID();
72  }
73  return veh1->getDepart() > veh2->getDepart();
74  }
75 };
76 
77 
82 namespace ROHelper {
88 
89 }
90 
91 #endif
92 
93 /****************************************************************************/
94 
const std::string & getID() const
Returns the id of the vehicle.
Definition: ROVehicle.h:103
ROVehicleByDepartureComperator()
Constructor.
Definition: ROHelper.h:53
void recheckForLoops(ConstROEdgeVector &edges)
Checks whether the given edge list contains loops and removes them.
Definition: ROHelper.cpp:44
SUMOTime getDepart() const
Returns the time the vehicle starts at, -1 for triggered vehicles.
Definition: ROVehicle.h:120
std::vector< const ROEdge * > ConstROEdgeVector
Definition: ROEdge.h:59
Some helping methods for router.
Definition: ROHelper.cpp:42
A vehicle as used by router.
Definition: ROVehicle.h:60
bool operator()(ROVehicle *veh1, ROVehicle *veh2) const
Comparing operator.
Definition: ROHelper.h:69
A function for sorting vehicles by their departure time.
Definition: ROHelper.h:50
~ROVehicleByDepartureComperator()
Destructor.
Definition: ROHelper.h:56