Line data Source code
1 : /****************************************************************************/
2 : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3 : // Copyright (C) 2001-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 : /****************************************************************************/
14 : /// @file MSPhaseDefinition.h
15 : /// @author Daniel Krajzewicz
16 : /// @author Julia Ringel
17 : /// @author Jakob Erdmann
18 : /// @author Sascha Krieg
19 : /// @author Michael Behrisch
20 : /// @date Jan 2004
21 : ///
22 : // The definition of a single phase of a tls logic
23 : /****************************************************************************/
24 : #pragma once
25 : #include <config.h>
26 :
27 : #define TARGET_BIT 0
28 : #define TRANSIENT_NOTDECISIONAL_BIT 1
29 : #define COMMIT_BIT 2
30 : #define UNDEFINED_BIT 3
31 : #include <config.h>
32 :
33 : #include <bitset>
34 : #include <string>
35 : #include <vector>
36 : #include <utils/common/MsgHandler.h>
37 : #include <utils/common/SUMOTime.h>
38 : #include <utils/options/OptionsCont.h>
39 : #include <utils/xml/SUMOXMLDefinitions.h>
40 :
41 :
42 : // ===========================================================================
43 : // class definitions
44 : // ===========================================================================
45 : /**
46 : * @class MSPhaseDefinition
47 : * @brief The definition of a single phase of a tls logic
48 : */
49 :
50 :
51 : class MSPhaseDefinition {
52 : public:
53 :
54 : static const SUMOTime UNSPECIFIED_DURATION = -1;
55 : static const SUMOTime OVERRIDE_DURATION = TIME2STEPS(-1);
56 :
57 : /// @brief The duration of the phase
58 : SUMOTime duration;
59 :
60 : /// @brief The previous duration of the phase
61 : SUMOTime lastDuration;
62 :
63 : /// @brief The minimum duration of the phase
64 : SUMOTime minDuration;
65 :
66 : /// @brief The maximum duration of the phase
67 : SUMOTime maxDuration;
68 :
69 : /// @brief The minimum time within the cycle for switching (for coordinated actuation)
70 : SUMOTime earliestEnd;
71 :
72 : /// @brief The maximum time within the cycle for switching (for coordinated actuation)
73 : SUMOTime latestEnd;
74 :
75 : /// @brief The condition expression for an early switch into this phase
76 : std::string earlyTarget;
77 :
78 : /// @brief The condition expression for switching into this phase when the active phase must end
79 : std::string finalTarget;
80 :
81 : /// @brief Stores the timestep of the last on-switched of the phase
82 : SUMOTime myLastSwitch;
83 :
84 : /// @brief Stores the timestep when the previous instance of this phase was switched off
85 : SUMOTime myLastEnd;
86 :
87 : /// @brief The index of the phase that suceeds this one (or -1)
88 : std::vector<int> nextPhases;
89 :
90 : /// @brief Optional name or description for the current phase
91 : std::string name;
92 :
93 : /// @brief for NEMA phase
94 : SUMOTime yellow;
95 :
96 : /// @brief for NEMA phase
97 : SUMOTime red;
98 :
99 : /// @brief for NEMA phase
100 : SUMOTime vehext;
101 :
102 : /// @brief the phase is a transient one or a decisional one, compulsory directive for SOTL policies
103 : bool myTransientNotDecisional;
104 :
105 : /// @brief the phase is a commit, compulsory directive for SOTL policies
106 : bool myCommit;
107 :
108 : /// @brief Leaving the phase type as "undefined" lets SOTL policies malfunction
109 : bool myUndefined;
110 :
111 : /*
112 : * @brief The lanes-set
113 : * This array can be empty if this phase is not a target step,
114 : * otherwise, a bit is true if the corresponding lane belongs to a
115 : * set of input lanes.
116 : * SOTL traffic light logics choose the target step according to sensors
117 : * belonging to the lane-set.
118 : */
119 : std::vector<std::string> myTargetLaneSet;
120 :
121 : private:
122 : /// @brief The phase definition
123 : std::string myState;
124 :
125 :
126 : public:
127 : /** @brief Constructor **/
128 522385 : MSPhaseDefinition(SUMOTime _duration, const std::string& state, const std::string& _name = ""):
129 522385 : duration(_duration),
130 522385 : lastDuration(UNSPECIFIED_DURATION),
131 522385 : minDuration(duration),
132 522385 : maxDuration(duration),
133 522385 : earliestEnd(UNSPECIFIED_DURATION),
134 522385 : latestEnd(UNSPECIFIED_DURATION),
135 522385 : myLastSwitch(UNSPECIFIED_DURATION),
136 522385 : myLastEnd(UNSPECIFIED_DURATION),
137 522385 : name(_name),
138 522385 : yellow(UNSPECIFIED_DURATION),
139 522385 : red(UNSPECIFIED_DURATION),
140 522385 : vehext(UNSPECIFIED_DURATION),
141 522385 : myTransientNotDecisional(false),
142 522385 : myCommit(false),
143 522385 : myUndefined(false),
144 1044770 : myState(state)
145 522385 : {}
146 :
147 :
148 : /// @brief Destructor
149 1450389 : virtual ~MSPhaseDefinition() { }
150 :
151 :
152 : /** @brief Returns the state within this phase
153 : * @return The state in this phase
154 : */
155 : const std::string& getState() const {
156 20788021 : return myState;
157 : }
158 :
159 : void setState(const std::string& _state) {
160 67 : myState = _state;
161 36900 : }
162 :
163 : const std::vector<std::string>& getTargetLaneSet() const {
164 14752 : return myTargetLaneSet;
165 : }
166 :
167 : const std::vector<int>& getNextPhases() const {
168 1023 : return nextPhases;
169 : }
170 :
171 : const std::string& getName() const {
172 31915 : return name;
173 : }
174 :
175 : void setName(const std::string& _name) {
176 9626 : name = _name;
177 9612 : }
178 :
179 : /** @brief Returns whether this phase is a pure "green" phase
180 : *
181 : * "pure green" means in this case that at least one stream has green
182 : * and no stream has yellow. Such phases are meant to be candidates
183 : * for being stretched by actuated or agentbased traffic light logics.
184 : * @return Whether this phase is a "pure green" phase
185 : */
186 540579 : bool isGreenPhase() const {
187 540579 : if (myState.find_first_of("gG") == std::string::npos) {
188 : return false;
189 : }
190 475372 : if (myState.find_first_of("yY") != std::string::npos) {
191 : return false;
192 : }
193 : return true;
194 : }
195 :
196 :
197 : /** @brief Returns whether this phase is an "all red" phase
198 : *
199 : * "all red " means in this case that at all streams have red
200 : * and no stream has yellow.
201 : * @return Whether this phase is an "all red" phase
202 : */
203 : bool isAllRedPhase() const {
204 0 : return (int)myState.size() == (int)std::count(myState.begin(), myState.end(), 'r');
205 : }
206 :
207 :
208 : /** @brief Returns the state of the tls signal at the given position
209 : * @param[in] pos The position of the signal to return the state for
210 : * @return The state of the signal at the given position
211 : */
212 : LinkState getSignalState(int pos) const {
213 288 : return (LinkState) myState[pos];
214 : }
215 :
216 : inline bool isActuated() const {
217 26604 : return minDuration != maxDuration || minDuration == OVERRIDE_DURATION;
218 : }
219 :
220 : /** @brief Comparison operator
221 : *
222 : * Note that only the state must differ, not the duration!
223 : * @param[in] pd The phase definition to compare against
224 : * @return Whether the given phase definition differs
225 : */
226 0 : bool operator!=(const MSPhaseDefinition& pd) {
227 0 : return myState != pd.myState || name != pd.name;
228 : }
229 :
230 :
231 : /*
232 : * @return true if the phase type is undefined
233 : */
234 : bool isUndefined() const {
235 576 : return myUndefined;
236 : }
237 :
238 : /*
239 : * @return true if this is a target phase
240 : */
241 : bool isTarget() const {
242 : return !myTargetLaneSet.empty();
243 : }
244 :
245 : /*
246 : * @return true if this is a transient phase
247 : */
248 : bool isTransient() const {
249 193865 : return myTransientNotDecisional;
250 : }
251 :
252 : /*
253 : * @return true if this is a decisional phase
254 : */
255 : bool isDecisional() const {
256 : return !myTransientNotDecisional;
257 : }
258 :
259 : /*
260 : * @return true if this is a commit phase
261 : */
262 : bool isCommit() const {
263 113288 : return myCommit;
264 : }
265 :
266 : };
|