SUMO - Simulation of Urban MObility
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
MSActuatedTrafficLightLogic.h
Go to the documentation of this file.
1 /****************************************************************************/
9 // An actuated (adaptive) traffic light logic
10 /****************************************************************************/
11 // SUMO, Simulation of Urban MObility; see http://sumo-sim.org/
12 // Copyright (C) 2002-2014 DLR (http://www.dlr.de/) and contributors
13 /****************************************************************************/
14 //
15 // This file is part of SUMO.
16 // SUMO is free software: you can redistribute it and/or modify
17 // it under the terms of the GNU General Public License as published by
18 // the Free Software Foundation, either version 3 of the License, or
19 // (at your option) any later version.
20 //
21 /****************************************************************************/
22 #ifndef MSActuatedTrafficLightLogic_h
23 #define MSActuatedTrafficLightLogic_h
24 
25 
26 // ===========================================================================
27 // included modules
28 // ===========================================================================
29 #ifdef _MSC_VER
30 #include <windows_config.h>
31 #else
32 #include <config.h>
33 #endif
34 
35 #include <utility>
36 #include <vector>
37 #include <bitset>
38 #include <map>
43 
44 
45 // ===========================================================================
46 // class declarations
47 // ===========================================================================
48 class NLDetectorBuilder;
49 
50 
51 // ===========================================================================
52 // class definitions
53 // ===========================================================================
59 public:
61  typedef std::map<MSLane*, MSInductLoop*> InductLoopMap;
62 
63 public:
74  const std::string& id, const std::string& programID,
76  unsigned int step, SUMOTime delay,
77  const std::map<std::string, std::string>& parameter);
78 
79 
84  void init(NLDetectorBuilder& nb);
85 
86 
89 
90 
91 
94 
100  SUMOTime trySwitch(bool isActive);
102 
103 
104 protected:
107 
111  SUMOTime duration() const;
112 
113 
116  void gapControl();
118 
119 
120 protected:
123 
126 
129 
132 
135 
136 };
137 
138 
139 #endif
140 
141 /****************************************************************************/
142 
Builds detectors for microsim.
void init(NLDetectorBuilder &nb)
Initialises the tls with information about incoming lanes.
A fixed traffic light logic.
std::map< MSLane *, MSInductLoop * > InductLoopMap
Definition of a map from lanes to induct loops lying on them.
An actuated (adaptive) traffic light logic.
A class that stores and controls tls and switching of their programs.
SUMOTime trySwitch(bool isActive)
Switches to the next phase.
SUMOReal myMaxGap
The maximum gap to check.
SUMOTime duration() const
Returns the duration of the given step.
SUMOReal myPassingTime
The passing time used.
InductLoopMap myInductLoops
A map from lanes to induct loops lying on them.
std::vector< MSPhaseDefinition * > Phases
Definition of a list of phases, being the junction logic.
SUMOReal myDetectorGap
The detector distance.
bool myContinue
information whether the current phase should be lenghtend
MSActuatedTrafficLightLogic(MSTLLogicControl &tlcontrol, const std::string &id, const std::string &programID, const MSSimpleTrafficLightLogic::Phases &phases, unsigned int step, SUMOTime delay, const std::map< std::string, std::string > &parameter)
Constructor.
#define SUMOReal
Definition: config.h:215
void gapControl()
Decides, whether a phase should be continued by checking the gaps of vehicles having green...